неопределенная ссылка при линковке с libresolv - PullRequest
1 голос
/ 20 октября 2010

У меня есть проект, который представляет собой библиотеку, которая ссылается на libresolv, Он отлично работает на последних дистрибутивах: Ubuntu 10.x Fedora 13, Mandriva 2010.1, но на Centos 5.x я получаю следующие ошибки

Установлен glibc: glibc-2.5-18.el5_1.1

g++ -DHAVE_CONFIG_H -I.  -I./include -I/usr/include/postgresql  -O3
-ansi   -Wall -Wno-deprecated  -D_FORTIFY_SOURCE=0 -MT testUpLog.o -MD
-MP -MF .deps/testUpLog.Tpo -c -o testUpLog.o testUpLog.cc
mv -f .deps/testUpLog.Tpo .deps/testUpLog.Po
/bin/sh ./libtool --tag=CXX   --mode=link g++  -O3 -ansi   -Wall
-Wno-deprecated  -D_FORTIFY_SOURCE=0  -L/usr/lib64 -L/lib64
-L/usr/lib64/mysql -o testUpLog testUpLog.o libUpTools.la -lpq
-lmysqlclient -lssl -lpthread
libtool: link: g++ -O3 -ansi -Wall -Wno-deprecated -D_FORTIFY_SOURCE=0
-o .libs/testUpLog testUpLog.o  -L/usr/lib64 -L/lib64
-L/usr/lib64/mysql ./.libs/libUpTools.so -lpq -lmysqlclient -lssl
-lpthread
./.libs/libUpTools.so: undefined reference to `__ns_name_uncompress'
./.libs/libUpTools.so: undefined reference to `__ns_initparse'
./.libs/libUpTools.so: undefined reference to `__ns_parserr'
collect2: ld returned 1 exit status
make[1]: *** [testUpLog] Error 1
make[1]: Leaving directory `/tmp/UpTools-8.5.3'
make: *** [check-am] Error 2

Файл library.la содержит:

dlname='libUpTools.so.0'
library_names='libUpTools.so.0.0.0 libUpTools.so.0 libUpTools.so'
old_library='libUpTools.a'
inherited_linker_flags=''
dependency_libs=' -L/usr/lib64 -L/lib64 -L/usr/lib64/mysql -lpq
-lmysqlclient -lssl -lpthread'
weak_library_names=''
current=0
age=0
revision=0
installed=no
shouldnotlink=no
dlopen=''
dlpreopen=''
libdir='/usr/lib'

Вы можете прочитать configure.ac на

http://pastebin.com/hs5q21Rq

Заранее спасибо

1 Ответ

2 голосов
/ 22 ноября 2010

Если libUpTools использует функции lib libresolv, вам нужно сказать так:

libUpTools_la_LIBADD = -lresolv (конечно, -lresolv может быть заменен переменными, определенными в configure и т. Д.)

Таким образом,-lresolv окажется в файле .la, а также в файле .so (если вы решили его создать), для которого вы можете запустить ldd для проверки.

...