2013-07-10 119 views
1

我试图在Ubuntu 12.04 x64上编译应用程序。 它是建立在OSX的铿锵声3.2,使用新的C++ 11标准,并具有依赖性来提升和GraphicsMagick ++并且运行良好。 使用gcc 4.8.1进行编译导致编译器崩溃。不幸的是,我们不得不尽快发布软件,不能等待gcc修复这些错误。在Linux上将GraphicsMagick ++与clang libC++链接

经过在linux上通过clang进行一些试验和错误,并通过一些邮件列表阅读后,我按照这篇文章https://plus.google.com/u/0/+DeWittClinton/posts/Vr7y8TPsKgR进行管理,使用clang 3.3和libC++(和libC++ abi)进行编译。所有与boost相关的单元测试(仅头文件和共享库文件)都执行得很好。 在我们开始链接到GraphicsMagick ++之后,它会在下面导致未定义的引用错误。

"/usr/bin/ld" -export-dynamic -z relro --hash-style=gnu --build-id --eh-frame-hdr -m elf_x86_64 -dynamic-linker /lib64/ld-linux-x86-64.so.2 -o ../test_xxx_import /usr/lib/gcc/x86_64-linux-gnu/4.8/../../../x86_64-linux-gnu/crt1.o /usr/lib/gcc/x86_64-linux-gnu/4.8/../../../x86_64-linux-gnu/crti.o /usr/lib/gcc/x86_64-linux-gnu/4.8/crtbegin.o -L/usr/local/lib/ -L/usr/lib/gcc/x86_64-linux-gnu/4.8 -L/usr/lib/gcc/x86_64-linux-gnu/4.8/../../../x86_64-linux-gnu -L/lib/x86_64-linux-gnu -L/lib/../lib64 -L/usr/lib/x86_64-linux-gnu -L/usr/lib/gcc/x86_64-linux-gnu/4.8/../../.. -L/lib -L/usr/lib -lc++ -lc++abi CMakeFiles/test_xxx_import.dir/xxx_http_binding_test.cpp.o CMakeFiles/test_xxx_import.dir/resource_test.cpp.o CMakeFiles/test_xxx_import.dir/slugify_test.cpp.o CMakeFiles/test_xxx_import.dir/product_test.cpp.o CMakeFiles/test_xxx_import.dir/field_semantic_test.cpp.o CMakeFiles/test_xxx_import.dir/files.index-parser_test.cpp.o CMakeFiles/test_xxx_import.dir/thread_pool_test.cpp.o CMakeFiles/test_xxx_import.dir/container_sink_test.cpp.o CMakeFiles/test_xxx_import.dir/factories_test.cpp.o CMakeFiles/test_xxx_import.dir/thread_safe_queue_test.cpp.o CMakeFiles/test_xxx_import.dir/container_device_test.cpp.o CMakeFiles/test_xxx_import.dir/product_catalog_test.cpp.o CMakeFiles/test_xxx_import.dir/config_object_test.cpp.o CMakeFiles/test_xxx_import.dir/sha1_test.cpp.o CMakeFiles/test_xxx_import.dir/resize_test.cpp.o CMakeFiles/test_xxx_import.dir/redis_connection_test.cpp.o CMakeFiles/test_xxx_import.dir/redis_util_test.cpp.o CMakeFiles/test_xxx_import.dir/redis_product_test.cpp.o CMakeFiles/test_xxx_import.dir/redis_string_util_test.cpp.o CMakeFiles/test_xxx_import.dir/redis_task_queue_test.cpp.o CMakeFiles/test_xxx_import.dir/stream_manipulator_test.cpp.o CMakeFiles/test_xxx_import.dir/category_info_test.cpp.o CMakeFiles/test_xxx_import.dir/localized_string_test.cpp.o CMakeFiles/test_xxx_import.dir/product_description_test.cpp.o CMakeFiles/test_xxx_import.dir/product_picture_test.cpp.o CMakeFiles/test_xxx_import.dir/product_relation_test.cpp.o CMakeFiles/test_xxx_import.dir/supplier_test.cpp.o CMakeFiles/test_xxx_import.dir/summary_description_test.cpp.o CMakeFiles/test_xxx_import.dir/summary_descriptions_test.cpp.o CMakeFiles/test_xxx_import.dir/stage_base_test.cpp.o CMakeFiles/test_xxx_import.dir/thread_reclaimer_test.cpp.o CMakeFiles/test_xxx_import.dir/product_sheet_download_test.cpp.o CMakeFiles/test_xxx_import.dir/image_scaling_test.cpp.o CMakeFiles/test_xxx_import.dir/image_download_test.cpp.o CMakeFiles/test_xxx_import.dir/product_data_sheet_parser_test.cpp.o ../libxxx_import.a /usr/local/lib/libboost_unit_test_framework.a /usr/local/lib/libboost_thread.a /usr/local/lib/libboost_date_time.a /usr/local/lib/libGraphicsMagick++.a /usr/local/lib/libboost_filesystem.a /usr/local/lib/libboost_system.a /usr/local/lib/libboost_exception.a /usr/local/lib/libboost_chrono.a /usr/local/lib/libboost_log.a /usr/local/lib/libPocoNet.so /usr/local/lib/libPocoFoundation.so /usr/local/lib/libPocoNetSSL.so /usr/local/lib/libPocoUtil.so -Bstatic -lexpat -lhiredis -Bdynamic /usr/local/lib/libboost_date_time.a /usr/local/lib/libGraphicsMagick++.a -rpath /usr/local/lib -lc++ -lm -lgcc_s -lgcc -lc -lgcc_s -lgcc /usr/lib/gcc/x86_64-linux-gnu/4.8/crtend.o /usr/lib/gcc/x86_64-linux-gnu/4.8/../../../x86_64-linux-gnu/crtn.o 
/usr/local/lib/libGraphicsMagick++.a(Image.o): In function `Magick::Image::signature(bool) const': 
/home/xxx_import/temp/GraphicsMagick-1.3.18/Magick++/lib/Image.cpp:3271: undefined reference to `GetImageAttribute' 
/home/xxx_import/temp/GraphicsMagick-1.3.18/Magick++/lib/Image.cpp:3274: undefined reference to `SignatureImage' 
/home/xxx_import/temp/GraphicsMagick-1.3.18/Magick++/lib/Image.cpp:3278: undefined reference to `GetImageAttribute' 
/usr/local/lib/libGraphicsMagick++.a(Image.o): In function `Magick::Image::read(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&)': 

GraphicsMagick工具-1.3.18配置了以下调用:

CC=clang CXX=clang++ ./configure --with-jbig=yes --with-png=yes --with-jpeg=yes --enable-shared=yes CXXFLAGS="-O2 -g -stdlib=libc++ -isystem /usr/local/include/c++/v1/" LDFLAGS="-stdlib=libc++ -L/usr/local/lib/ -R/usr/local/lib/" LIBS="-lc++ -lc++abi" 

事后建造和安装。

仰视手动发现为未定义的符号:

nm /usr/local/lib/libGraphicsMagick++.a | grep GetImageAttribute 
       U GetImageAttribute 

属性在/usr/local/lib/libGraphicsMagick.a找到。

我LDD输出如下:

ldd /usr/local/lib/libGraphicsMagick++.so 
linux-vdso.so.1 => (0x00007fff78592000) 
libGraphicsMagick.so.3 => /usr/local/lib/libGraphicsMagick.so.3 (0x00007fd0b0309000) 
libjpeg.so.8 => /usr/lib/x86_64-linux-gnu/libjpeg.so.8 (0x00007fd0b00b0000) 
libpng12.so.0 => /lib/x86_64-linux-gnu/libpng12.so.0 (0x00007fd0afe87000) 
libbz2.so.1.0 => /lib/x86_64-linux-gnu/libbz2.so.1.0 (0x00007fd0afc77000) 
libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007fd0afa60000) 
libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007fd0af842000) 
libc++abi.so.1 => /usr/local/lib/libc++abi.so.1 (0x00007fd0af5f5000) 
libc++.so.1 => /usr/local/lib/libc++.so.1 (0x00007fd0af351000) 
libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fd0af054000) 
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fd0aec95000) 
libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007fd0aea7f000) 
/lib64/ld-linux-x86-64.so.2 (0x00007fd0b09c3000) 
librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007fd0ae876000) 

它连接免受gcc工具一些C库。我应该用叮当建造它们吗? 任何建议都非常受欢迎。

+0

也许解决编译器崩溃问题比切换到另一个工具链更容易。也许回到gcc-4.7系列更容易。 –

+0

无论如何,你应该在源代码中搜索'GetImageAttribute'定义,确保它被编译(在.o/.a/.so文件中使用'nm'),然后确保这些对象*他们在链接器命令行中。 –

+0

我试过了,发现/usr/local/lib/libGraphicsMagick.a中的符号。正如答案所描述的,我必须明确链接到GraphicsMagick和所有依赖关系。 –

回答

0

你是否也显式链接GraphicsMagick ++的依赖关系?我认为,如果你列举GraphicsMagick工具的所有依赖++作为生产可执行文件的依赖关系,可能解决您的问题,所以这些库链接,以及:

-lGraphicsMagick -ljpeg -lpng12 -lbz2 -lz 

,看看你有较少的链接错误或无。

+0

这就像一个魅力。谢谢!!仍然不知道为什么他们自动链接到OSX。 –

相关问题