Hi all, I have: boost 1.39.0 g++ (GCC) 4.4.2 autoconf 2.64 automake 1.11 libtool 2.2.6a pkgconfig 0.23 flex 2.5.35 bison 2.4.1 on Arch Linux 32bit 2.6.31
When building thrift, I'm getting an error: struct.c:286: error: implicit declaration of function ‘strlcpy’ it seems like this is a known issue: http://issues.apache.org/jira/browse/THRIFT-605 http://github.com/fauna/cassandra/issues#issue/4 But what's the solution? for the sake of completeness, here is the output of bootstrap.sh, configure and the relevant part of make. Thanks! Dieter die...@dieter-ws-a7n8x-arch thrift svn up At revision 883118. die...@dieter-ws-a7n8x-arch thrift ./bootstrap.sh configure.ac:44: installing `./config.guess' configure.ac:44: installing `./config.sub' configure.ac:26: installing `./install-sh' configure.ac:26: installing `./missing' compiler/cpp/Makefile.am: installing `./depcomp' configure.ac: installing `./ylwrap' die...@dieter-ws-a7n8x-arch thrift ./configure checking for a BSD-compatible install... /bin/install -c checking whether build environment is sane... yes checking for a thread-safe mkdir -p... /bin/mkdir -p checking for gawk... gawk checking whether make sets $(MAKE)... yes checking for gcc... gcc ^[[Achecking for C compiler default output file name... a.out checking whether the C compiler works... yes checking whether we are cross compiling... no checking for suffix of executables... checking for suffix of object files... o checking whether we are using the GNU C compiler... yes checking whether gcc accepts -g... yes checking for gcc option to accept ISO C89... none needed checking for style of include used by make... GNU checking dependency style of gcc... gcc3 checking how to run the C preprocessor... gcc -E checking for g++... g++ checking whether we are using the GNU C++ compiler... yes checking whether g++ accepts -g... yes checking dependency style of g++... gcc3 checking build system type... i686-pc-linux-gnu checking host system type... i686-pc-linux-gnu checking for a sed that does not truncate output... /bin/sed checking for grep that handles long lines and -e... /bin/grep checking for egrep... /bin/grep -E checking for fgrep... /bin/grep -F checking for ld used by gcc... /usr/bin/ld checking if the linker (/usr/bin/ld) is GNU ld... yes checking for BSD- or MS-compatible name lister (nm)... /usr/bin/nm -B checking the name lister (/usr/bin/nm -B) interface... BSD nm checking whether ln -s works... yes checking the maximum length of command line arguments... 1572864 checking whether the shell understands some XSI constructs... yes checking whether the shell understands "+="... yes checking for /usr/bin/ld option to reload object files... -r checking for objdump... objdump checking how to recognize dependent libraries... pass_all checking for ar... ar checking for strip... strip checking for ranlib... ranlib checking command to parse /usr/bin/nm -B output from gcc object... ok checking for ANSI C header files... yes checking for sys/types.h... yes checking for sys/stat.h... yes checking for stdlib.h... yes checking for string.h... yes checking for memory.h... yes checking for strings.h... yes checking for inttypes.h... yes checking for stdint.h... yes checking for unistd.h... yes checking for dlfcn.h... yes checking whether we are using the GNU C++ compiler... (cached) yes checking whether g++ accepts -g... (cached) yes checking dependency style of g++... (cached) gcc3 checking how to run the C++ preprocessor... g++ -E checking for objdir... .libs checking if gcc supports -fno-rtti -fno-exceptions... no checking for gcc option to produce PIC... -fPIC -DPIC checking if gcc PIC flag -fPIC -DPIC works... yes checking if gcc static flag -static works... yes checking if gcc supports -c -o file.o... yes checking if gcc supports -c -o file.o... (cached) yes checking whether the gcc linker (/usr/bin/ld) supports shared libraries... yes checking whether -lc should be explicitly linked in... no checking dynamic linker characteristics... GNU/Linux ld.so checking how to hardcode library paths into programs... immediate checking whether stripping libraries is possible... yes checking if libtool supports shared libraries... yes checking whether to build shared libraries... yes checking whether to build static libraries... yes checking for ld used by g++... /usr/bin/ld checking if the linker (/usr/bin/ld) is GNU ld... yes checking whether the g++ linker (/usr/bin/ld) supports shared libraries... yes checking for g++ option to produce PIC... -fPIC -DPIC checking if g++ PIC flag -fPIC -DPIC works... yes checking if g++ static flag -static works... yes checking if g++ supports -c -o file.o... yes checking if g++ supports -c -o file.o... (cached) yes checking whether the g++ linker (/usr/bin/ld) supports shared libraries... yes checking dynamic linker characteristics... GNU/Linux ld.so checking how to hardcode library paths into programs... immediate checking whether make sets $(MAKE)... (cached) yes checking for bison... bison -y checking for flex... flex checking lex output file root... lex.yy checking lex library... -lfl checking whether yytext is a pointer... yes checking whether ln -s works... yes checking for boostlib >= 1.33.1... yes checking for libevent >= 1.0... yes checking for zlib >= 1.2.3... yes checking for pkg-config... /usr/bin/pkg-config checking pkg-config is at least version 0.9.0... yes checking for MONO... no checking for MONO... no checking for javac and java... yes checking for ant... no checking for Java class org.slf4j.Logger... no checking for Java class org.slf4j.impl.SimpleLogger... no checking for Java class org.apache.commons.lang.builder.HashCodeBuilder... no checking for erlc... no checking for a Python interpreter with version >= 2.4... python checking for python... /usr/bin/python checking for python version... 2.6 checking for python platform... linux2 checking for python script directory... ${prefix}/lib/python2.6/site-packages checking for python extension module directory... ${exec_prefix}/lib/python2.6/site-packages checking for perl... /usr/bin/perl checking for ruby... /usr/bin/ruby checking for spec... no checking for an ANSI C-conforming const... yes checking for inline... inline checking for working volatile... yes checking for stdbool.h that conforms to C99... yes checking for _Bool... no checking for ANSI C header files... (cached) yes checking whether time.h and sys/time.h may both be included... yes checking arpa/inet.h usability... yes checking arpa/inet.h presence... yes checking for arpa/inet.h... yes checking endian.h usability... yes checking endian.h presence... yes checking for endian.h... yes checking fcntl.h usability... yes checking fcntl.h presence... yes checking for fcntl.h... yes checking for inttypes.h... (cached) yes checking limits.h usability... yes checking limits.h presence... yes checking for limits.h... yes checking netdb.h usability... yes checking netdb.h presence... yes checking for netdb.h... yes checking netinet/in.h usability... yes checking netinet/in.h presence... yes checking for netinet/in.h... yes checking pthread.h usability... yes checking pthread.h presence... yes checking for pthread.h... yes checking stddef.h usability... yes checking stddef.h presence... yes checking for stddef.h... yes checking for stdlib.h... (cached) yes checking sys/socket.h usability... yes checking sys/socket.h presence... yes checking for sys/socket.h... yes checking sys/time.h usability... yes checking sys/time.h presence... yes checking for sys/time.h... yes checking for unistd.h... (cached) yes checking libintl.h usability... yes checking libintl.h presence... yes checking for libintl.h... yes checking malloc.h usability... yes checking malloc.h presence... yes checking for malloc.h... yes checking for pthread_create in -lpthread... yes checking for clock_gettime in -lrt... yes checking for setsockopt in -lsocket... no checking for int16_t... yes checking for int32_t... yes checking for int64_t... yes checking for int8_t... yes checking for mode_t... yes checking for off_t... yes checking for size_t... yes checking for ssize_t... yes checking for uint16_t... yes checking for uint32_t... yes checking for uint64_t... yes checking for uint8_t... yes checking for ptrdiff_t... yes checking whether struct tm is in sys/time.h or time.h... time.h checking whether AI_ADDRCONFIG is declared... yes checking for working alloca.h... yes checking for alloca... yes checking for stdlib.h... (cached) yes checking for GNU libc compatible malloc... yes checking for working memcmp... yes checking for stdlib.h... (cached) yes checking for GNU libc compatible realloc... yes checking sys/select.h usability... yes checking sys/select.h presence... yes checking for sys/select.h... yes checking for sys/socket.h... (cached) yes checking types of arguments for select... int,fd_set *,struct timeval * checking whether lstat dereferences a symlink specified with a trailing slash... yes checking whether stat accepts an empty string... no checking whether strerror_r is declared... yes checking for strerror_r... yes checking whether strerror_r returns char *... yes checking for strftime... yes checking for vprintf... yes checking for _doprnt... no checking for strtoul... yes checking for bzero... yes checking for ftruncate... yes checking for gethostbyname... yes checking for gettimeofday... yes checking for memmove... yes checking for memset... yes checking for mkdir... yes checking for realpath... yes checking for select... yes checking for socket... yes checking for strchr... yes checking for strdup... yes checking for strerror... yes checking for strstr... yes checking for strtol... yes checking for sqrt... yes checking for clock_gettime... yes checking for sched_get_priority_min... yes checking for sched_get_priority_max... yes checking the behavior of a signed right shift... arithmetic configure: creating ./config.status config.status: creating Makefile config.status: creating compiler/cpp/Makefile config.status: creating lib/Makefile config.status: creating lib/cpp/Makefile config.status: creating lib/cpp/thrift.pc config.status: creating lib/cpp/thrift-nb.pc config.status: creating lib/cpp/thrift-z.pc config.status: creating lib/csharp/Makefile config.status: creating lib/java/Makefile config.status: creating lib/perl/Makefile config.status: creating lib/perl/test/Makefile config.status: creating lib/py/Makefile config.status: creating lib/rb/Makefile config.status: creating test/Makefile config.status: creating test/py/Makefile config.status: creating test/rb/Makefile config.status: creating config.h config.status: executing depfiles commands config.status: executing libtool commands make: (...) creating build/temp.linux-i686-2.6/src/protocol gcc -pthread -fno-strict-aliasing -DNDEBUG -march=i686 -mtune=generic -O2 -pipe -fPIC -I/usr/include/python2.6 -c src/protocol/fastbinary.c -o build/temp.linux-i686-2.6/src/protocol/fastbinary.o gcc -pthread -shared build/temp.linux-i686-2.6/src/protocol/fastbinary.o -L/usr/lib -lpython2.6 -o build/lib.linux-i686-2.6/thrift/protocol/fastbinary.so make[3]: Leaving directory `/home/dieter/workspaces/eclipse/thrift/lib/py' Making all in rb make[3]: Entering directory `/home/dieter/workspaces/eclipse/thrift/lib/rb' /usr/bin/ruby setup.rb config ---> lib ---> lib/thrift ---> lib/thrift/serializer <--- lib/thrift/serializer ---> lib/thrift/server <--- lib/thrift/server ---> lib/thrift/transport <--- lib/thrift/transport ---> lib/thrift/core_ext <--- lib/thrift/core_ext ---> lib/thrift/protocol <--- lib/thrift/protocol <--- lib/thrift <--- lib ---> ext /usr/bin/ruby /home/dieter/workspaces/eclipse/thrift/lib/rb/ext/extconf.rb checking for strlcpy() in string.h... yes creating Makefile <--- ext /usr/bin/ruby setup.rb setup ---> lib ---> lib/thrift ---> lib/thrift/serializer <--- lib/thrift/serializer ---> lib/thrift/server <--- lib/thrift/server ---> lib/thrift/transport <--- lib/thrift/transport ---> lib/thrift/core_ext <--- lib/thrift/core_ext ---> lib/thrift/protocol <--- lib/thrift/protocol <--- lib/thrift <--- lib ---> ext make make[4]: Entering directory `/home/dieter/workspaces/eclipse/thrift/lib/rb/ext' gcc -I. -I/usr/include/ruby-1.9.1/i686-linux -I/usr/include/ruby-1.9.1/ruby/backward -I/usr/include/ruby-1.9.1 -I/home/dieter/workspaces/eclipse/thrift/lib/rb/ext -DHAVE_STRLCPY -D_FILE_OFFSET_BITS=64 -fPIC -g -O2 -Wall -Werror -o compact_protocol.o -c compact_protocol.c gcc -I. -I/usr/include/ruby-1.9.1/i686-linux -I/usr/include/ruby-1.9.1/ruby/backward -I/usr/include/ruby-1.9.1 -I/home/dieter/workspaces/eclipse/thrift/lib/rb/ext -DHAVE_STRLCPY -D_FILE_OFFSET_BITS=64 -fPIC -g -O2 -Wall -Werror -o thrift_native.o -c thrift_native.c gcc -I. -I/usr/include/ruby-1.9.1/i686-linux -I/usr/include/ruby-1.9.1/ruby/backward -I/usr/include/ruby-1.9.1 -I/home/dieter/workspaces/eclipse/thrift/lib/rb/ext -DHAVE_STRLCPY -D_FILE_OFFSET_BITS=64 -fPIC -g -O2 -Wall -Werror -o protocol.o -c protocol.c gcc -I. -I/usr/include/ruby-1.9.1/i686-linux -I/usr/include/ruby-1.9.1/ruby/backward -I/usr/include/ruby-1.9.1 -I/home/dieter/workspaces/eclipse/thrift/lib/rb/ext -DHAVE_STRLCPY -D_FILE_OFFSET_BITS=64 -fPIC -g -O2 -Wall -Werror -o memory_buffer.o -c memory_buffer.c gcc -I. -I/usr/include/ruby-1.9.1/i686-linux -I/usr/include/ruby-1.9.1/ruby/backward -I/usr/include/ruby-1.9.1 -I/home/dieter/workspaces/eclipse/thrift/lib/rb/ext -DHAVE_STRLCPY -D_FILE_OFFSET_BITS=64 -fPIC -g -O2 -Wall -Werror -o struct.o -c struct.c cc1: warnings being treated as errors struct.c: In function ‘get_field_value’: struct.c:286: error: implicit declaration of function ‘strlcpy’ make[4]: *** [struct.o] Error 1 make[4]: Leaving directory `/home/dieter/workspaces/eclipse/thrift/lib/rb/ext' setup.rb:655:in `command': system("make") failed (RuntimeError) from setup.rb:664:in `make' from setup.rb:1258:in `setup_dir_ext' from setup.rb:1532:in `block in traverse' from setup.rb:1549:in `dive_into' from setup.rb:1530:in `traverse' from setup.rb:1524:in `block in exec_task_traverse' from setup.rb:1519:in `each' from setup.rb:1519:in `exec_task_traverse' from setup.rb:1246:in `exec_setup' from setup.rb:996:in `exec_setup' from setup.rb:826:in `invoke' from setup.rb:773:in `invoke' from setup.rb:1578:in `<main>' make[3]: *** [all-local] Error 1 make[3]: Leaving directory `/home/dieter/workspaces/eclipse/thrift/lib/rb' make[2]: *** [all-recursive] Error 1 make[2]: Leaving directory `/home/dieter/workspaces/eclipse/thrift/lib' make[1]: *** [all-recursive] Error 1 make[1]: Leaving directory `/home/dieter/workspaces/eclipse/thrift' make: *** [all] Error 2
