[
https://issues.apache.org/jira/browse/THRIFT-3273?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=14645090#comment-14645090
]
Jens Geyer commented on THRIFT-3273:
------------------------------------
I get this with the tutorial (just the first thing I tried)
{code}
gen-c_glib/calculator.c: In function 'calculator_processor_init':
gen-c_glib/calculator.c:1280:3: error: 'for' loop initial declarations are only
allowed in C99 mode
for (guint index = 0; index < 4; index += 1)
^
gen-c_glib/calculator.c:1280:3: note: use option -std=c99 or -std=gnu99 to
compile your code
Makefile:613: recipe for target 'gen-c_glib/calculator.lo' failed
make[1]: *** [gen-c_glib/calculator.lo] Error 1
make[1]: Leaving directory '/home/jens/Arbeitsfläche/Thrift/tutorial/c_glib'
Makefile:501: recipe for target 'all' failed
make: *** [all] Error 2
{code}
> c_glib: Generated code tries to convert between function and void pointers
> --------------------------------------------------------------------------
>
> Key: THRIFT-3273
> URL: https://issues.apache.org/jira/browse/THRIFT-3273
> Project: Thrift
> Issue Type: Bug
> Components: C glib - Compiler
> Affects Versions: 0.9.3
> Environment: Fedora 22 (gcc 5.1.1) on x86_64
> Reporter: Simon South
> Assignee: Simon South
> Priority: Minor
> Labels: c_glib, compiler
>
> In code generated by the compiler for C (GLib), a service's processor class
> incorrectly treats function and void pointers as interchangeable: When adding
> to the {{process_map}} hash table it supplies a pointer to a function, while
> {{g_hash_table_insert}} expects a {{gpointer}} (effectively {{void *}}) to a
> data object.
> ISO C explicitly forbids this conversion as it is not compatible with all
> architectures, and with its {{-pedantic}} option enabled gcc will generate
> warnings like
> {code}
> gen-c_glib/calculator.c: In function 'calculator_processor_init':
> gen-c_glib/calculator.c:1231:24: warning: ISO C forbids passing argument 3 of
> 'g_hash_table_insert' between function pointer and 'void *' [-Wpedantic]
> calculator_processor_process_ping);
> {code}
> The compiler needs to be fixed so the code it generates does not try to use
> function pointers where data (void) pointers are expected.
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)