it-swarm.com.ru

Я не могу найти существующую библиотеку

Я пытаюсь связать приложение с g ++ в этой системе Debian lenny. ld жалуется, что не может найти указанные библиотеки. Конкретным примером здесь является ImageMagick, но у меня возникают похожие проблемы и с некоторыми другими библиотеками.

Я звоню компоновщику с:

g++ -w (..lots of .o files/include directories/etc..) \
-L/usr/lib -lmagic

л.Д. жалуется:

/usr/bin/ld: cannot find -lmagic

Однако libmagic существует:

$ locate libmagic.so
/usr/lib/libmagic.so.1
/usr/lib/libmagic.so.1.0.0
$ ls -all /usr/lib/libmagic.so.1*
lrwxrwxrwx 1 root root    17 2008-12-01 03:52 /usr/lib/libmagic.so.1 -> libmagic.so.1.0.0
-rwxrwxrwx 1 root root 84664 2008-09-09 00:05 /usr/lib/libmagic.so.1.0.0
$ ldd /usr/lib/libmagic.so.1.0.0 
    linux-gate.so.1 =>  (0xb7f85000)
    libz.so.1 => /usr/lib/libz.so.1 (0xb7f51000)
    libc.so.6 => /lib/i686/cmov/libc.so.6 (0xb7df6000)
    /lib/ld-linux.so.2 (0xb7f86000)
$ Sudo ldconfig -v | grep "libmagic"
    libmagic.so.1 -> libmagic.so.1.0.0

Как мне диагностировать эту проблему дальше, и что может быть не так? Я делаю что-то совершенно глупое?

160
maxpenguin

Проблема в том, что компоновщик ищет libmagic.so, но у вас есть только libmagic.so.1

Быстрый взлом заключается в том, чтобы использовать символическую ссылку libmagic.so.1 на libmagic.so

150
grepsedawk

Как только что сформулировал grepsedawk, ответ лежит в опции -lg++, вызывающей ld. Если вы посмотрите на справочную страницу этой команды, вы можете сделать:

  • g++ -l:libmagic.so.1 [...]
  • или: g++ -lmagic [...], если у вас есть ссылка с именем libmagic.so в вашем пути libs
65
Piotr Lesnicki

По соглашению Debian разделяемые библиотеки делятся на их компоненты времени выполнения (libmagic1: /usr/lib/libmagic.so.1 → libmagic.so.1.0.0) и их компоненты разработки (libmagic-dev: /usr/lib/libmagic.so → …).

Поскольку имя библиотеки - libmagic.so.1, это строка, которая встраивается в исполняемый файл, поэтому это файл, который загружается при запуске исполняемого файла.

Однако поскольку библиотека указана для компоновщика как -lmagic, она ищет libmagic.so, поэтому она необходима для разработки.

Смотрите Диего Э. Петтено: Линкеры и имена чтобы узнать, как все это работает в Linux.


Короче говоря, вы должны apt-get install libmagic-dev. Это даст вам не только libmagic.so, но и другие файлы, необходимые для компиляции, такие как /usr/include/magic.h.

31
ephemient

В Ubuntu вы можете установить libtool, который автоматически разрешает библиотеки.

$ Sudo apt-get install libtool

Это решило проблему с ltdl для меня, который был установлен как libltdl.so.7 и не был найден как просто -lltdl в make.

7
Mr Ed

Если я не ошибаюсь, libmagic или -lmagic - это не та же библиотека, что и ImageMagick. Вы заявляете, что хотите ImageMagick.

ImageMagick поставляется с утилитой для предоставления всех соответствующих опций компилятору.

Пример:

g++ program.cpp `Magick++-config --cppflags --cxxflags --ldflags --libs` -o "prog"
4
Brian Gianforcaro

Как упоминалось выше, компоновщик ищет libmagic.so, но у вас есть только libmagic.so.1.

Для решения этой проблемы просто выполните обновление кеша.

ldconfig -v 

Для проверки вы можете запустить:

$ ldconfig -p | grep libmagic
3
Miguel Ignacio Iglesias

Установка libgl1-mesa-dev из репозитория Ubuntu решила эту проблему для меня.

1
kirenpillay