ld сообщает об отсутствии символов, но кажется, что символы существуют - PullRequest
6 голосов
/ 30 марта 2010

Я пытаюсь связать мое приложение Mac с замечательной библиотекой libancillary . Однако я изменил скрипт сборки библиотеки, чтобы создать общую библиотеку. Я могу проверить символы в этой библиотеке, используя nm libancillary.dylib - результат:

libancillary.dylib(single module):
         U ___sF
         U __keymgr_get_and_lock_processwide_ptr
         U __keymgr_get_and_lock_processwide_ptr_2
         U __keymgr_set_and_unlock_processwide_ptr
         U _abort
00002cfe T _ancil_recv_fd
00002c87 T _ancil_recv_fds
00002b6a T _ancil_recv_fds_with_buffer
00002e9e T _ancil_send_fd
00002e27 T _ancil_send_fds
00002d3f T _ancil_send_fds_with_buffer
         U _calloc
         U _dlopen
         U _dlsym
         U _fflush
         U _fprintf
         U _free
         U _malloc
         U _recvmsg
         U _sendmsg

Однако, когда я пытаюсь связать свое приложение, я получаю вывод:

g++ -headerpad_max_install_names -framework AppKit -framework Cocoa -framework IOKit -framework CoreFoundation -framework Carbon -framework OpenGL -framework SystemConfiguration -framework Security -Wl,-bind_at_load -arch i386 -o MyApp build/app.o build/client.o build/util.o -F/Library/Frameworks -L/Library/Frameworks -L../ancillary -lancillary
Undefined symbols:
  "ancil_recv_fd(int, int*)", referenced from:
      CIPCUnixUtils::readFD(int, int&) constin utils.o
  "ancil_send_fd(int, int)", referenced from:
      CIPCUnixUtils::writeFD(int, int) constin utils.o
ld: symbol(s) not found
collect2: ld returned 1 exit status
make: *** [ABClient] Error 1

(я немного отредактировал это, чтобы удалить очень длинный список объектных файлов).

Что может вызвать сбой этой связи? Символ существует и является общедоступным, и нет ошибок в том, что он не может найти библиотеку или какие-либо другие сообщения об ошибках.

Ответы [ 2 ]

7 голосов
/ 30 марта 2010

Эти символы являются символами C. Поскольку вы отметили это как C ++, я предполагаю, что вы компилируете с C ++. Если вы сделаете это, вам может понадобиться обернуть файлы заголовков библиотек во внешний блок в вашем коде:

extern "C" {
#include "library.h"
}

где library.h - это имя файла (ов) заголовка библиотеки, чтобы предотвратить их искажение в вызывающем коде.

1 голос
/ 30 марта 2010

Интересно, это проблема с искажением имен в C ++?

Попробуйте запустить nm для файла utils.o и посмотрите, какой символ он на самом деле ищет.

Возможно, вам придется обернуть заголовок в extern C.

...