我刚刚重新安装了我的服务器,从Ubuntu 11.04切换到11.10,从32位切换到64位。之后我尝试重新安装我的自定义SWIG PHP扩展。
我用
编译swig -I/usr/local/include/poppler -Wall -php -c++ popplig.i
g++ -g -I. -I/usr/local/include/poppler -I/usr/include/php5 -I/usr/include/php5/main -I/usr/include/php5/TSRM -I/usr/include/php5/Zend -I/usr/include/php5/ext -I/usr/include/php5/ext/date/lib -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 -fpic -c popplig_wrap.cpp ExtensibleOutputDev.cc PDFFont.cc HtmlLinks.cc PDFImage.cc MarkedContentState.cc Error.cc
g++ -Wall -Wextra -g -lpoppler -shared popplig_wrap.o ExtensibleOutputDev.o PDFFont.o HtmlLinks.o PDFImage.o MarkedContentState.o Error.o -o popplig.so
链接完成,没有错误或警告。
但是当我运行php时,我得到
$ php -r ""
PHP Warning: PHP Startup: Unable to load dynamic library '/atlas/www/txtbear/poppler-swig/popplig.so' - /atlas/www/txtbear/poppler-swig/popplig.so: undefined symbol: _ZN15SplashOutputDev9updateAllEP8GfxState in Unknown on line 0
这个符号在我的libpoppler拷贝中定义
$ nm -g /usr/local/lib/libpoppler.so | grep _ZN15SplashOutputDev9updateAllEP8GfxState
0000000000141370 T _ZN15SplashOutputDev9updateAllEP8GfxState
他知道poppler
$ sudo ldconfig -v | grep poppler
libpoppler-cpp.so.0 -> libpoppler-cpp.so.0.1.0
libpoppler.so.6 -> libpoppler.so.6.0.0
libpoppler.so.6 -> libpoppler.so.6.0.0
libpoppler-glib.so.6 -> libpoppler-glib.so.6.0.0
但我的扩展似乎没有链接到它(尽管-lpoppler
)
$ ldd popplig.so
linux-vdso.so.1 => (0x00007fffbd079000)
libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007fa104957000)
libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fa1046d3000)
libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007fa1044bc000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fa10411d000)
/lib64/ld-linux-x86-64.so.2 (0x00007fa10502b000)
所以问题似乎在于g++没有链接到libpoppler。我怎样才能发现链接出了什么问题?
g++ -Wall -Wextra -g -lpoppler -shared popplig_wrap.o...
这个命令行是不正确的:库应该跟随在链接行上使用它们的对象。查看将-lpoppler
移动到链接行末尾是否会
- 让它出现在
ldd popplig.so
和 - 修复未解决的符号问题。