фиг там спать с этими вашими линуксами
А вот скажите мне, как в линуксе ищутся shared object, то бишь библиотеки?
Не могу понять, как получается, что там где я собрал Qt креатором проект, он работает, а на другом дебиане - нет. Пишет, что не может загрузить libQtSql.so.4
ldd выдает отличающиется списки используемых либ:
libQtSql.so.4 => not found
libQtGui.so.4 => not found
libQtNetwork.so.4 => not found
libQtCore.so.4 => not found
libQtSql.so.4 => /home/user/qtsdk-2009.02/qt/lib/libQtSql.so.4 (0xb7ebe000)
libQtGui.so.4 => /home/user/qtsdk-2009.02/qt/lib/libQtGui.so.4 (0xb74a4000)
libQtNetwork.so.4 => /home/user/qtsdk-2009.02/qt/lib/libQtNetwork.so.4 (0xb7178000)
libQtCore.so.4 => /home/user/qtsdk-2009.02/qt/lib/libQtCore.so.4 (0xb6f25000)
По аналогии с вендой - скопировал нужные либы в папку к проге - фиг, все равно не видит :)
Установка qt либ из репозитория не помогла - ldd теперь их видит, но прога не работает - версия либ (4.2) раньше той на которой я прогу собирал (4.5)
В натуре придется LD_LIBRARY_PATH править, хотя везде написано что это антигуманно. Или еще как-нибудь заставлять лоадер либы рядом с приложением искать.
А вот если я захочу вместо Qt4.2 поставить Qt4.5, сломается что нибудь в системе или нет? И как это сделать, не поломав голову менеджеру пакетов?
Не могу понять, как получается, что там где я собрал Qt креатором проект, он работает, а на другом дебиане - нет. Пишет, что не может загрузить libQtSql.so.4
ldd выдает отличающиется списки используемых либ:
libQtSql.so.4 => not found
libQtGui.so.4 => not found
libQtNetwork.so.4 => not found
libQtCore.so.4 => not found
libQtSql.so.4 => /home/user/qtsdk-2009.02/qt/lib/libQtSql.so.4 (0xb7ebe000)
libQtGui.so.4 => /home/user/qtsdk-2009.02/qt/lib/libQtGui.so.4 (0xb74a4000)
libQtNetwork.so.4 => /home/user/qtsdk-2009.02/qt/lib/libQtNetwork.so.4 (0xb7178000)
libQtCore.so.4 => /home/user/qtsdk-2009.02/qt/lib/libQtCore.so.4 (0xb6f25000)
По аналогии с вендой - скопировал нужные либы в папку к проге - фиг, все равно не видит :)
Установка qt либ из репозитория не помогла - ldd теперь их видит, но прога не работает - версия либ (4.2) раньше той на которой я прогу собирал (4.5)
В натуре придется LD_LIBRARY_PATH править, хотя везде написано что это антигуманно. Или еще как-нибудь заставлять лоадер либы рядом с приложением искать.
А вот если я захочу вместо Qt4.2 поставить Qt4.5, сломается что нибудь в системе или нет? И как это сделать, не поломав голову менеджеру пакетов?
no subject
no subject
И man ldconfig в тему этого
no subject
no subject
no subject
no subject
Почему микрософт пошел по тому же пути - вопрос достаточно сложный, помнится мне, ВСЕ пользователи Firebird в гугл-группе попросили разработчиков отломать нахер это от embedded engine, который часто используется в таком же стиле, как я хотел запустить эту прогу, т.н. xcopy deployment.
Впрочем, на эту тему тут уже неоднократно, кажется, спорили. Похоже, никто не понимает, зачем писать программы, изолированные и запускающиеся независимо от основной системы, т.к. редко сталкиваются с деплойментом прог в реальных условиях.
no subject
Ну, и явной точки нету в PATH тоже. Это гибче — добавь system-wide LD_LIBRARY_PATH=. и будет как в винде. А теперь сделай в винде наоборот :)
no subject
no subject
Понимаешь, эта задача в *IX решается шелл-скриптом на 10 строк. А вот в винде ничего ты изменить не можешь — как есть так и есть.
no subject
no subject
Гы-гы.
Ищет он в том, что при старте системы сказали ldconfig'у и там, где ты поставил переменную окружения LD_LIBRARY_PATH
no subject
Ничего не сломается. У Qt ABI совместимость в рамках мажорной ветки
no subject
no subject
Либо статическая сборка (плохо для LGPL) либо смириться с более раней версией glibc, либо удовлетворяться тестируемым репозитарием (lили lenny), либо искать обходные пути типа LD_LIBRARY_PATH + run скрипт.
А вообще - мужик ты умный, и прочитай всё-таки как установка и распространение программ происходит в линуксе, что там с билдингом, прочим.
Для примера, кстати, глянь на скайп - у них две версии пакетов - статическая сборка (отсутствие зависимостей) или рантайм (с зависимостями).
Распространяют они дистр-специфичные пакетики.
Можешь у
no subject
А со сборкой пакетов придется разобраться, это как факт.
no subject
В debian всегда есть бекпорты - порт новых версий библиотек под старые версии дистров.
Я тебе на ubuntu-janty x86_64 могу проверить =)
no subject
no subject