Boost + ICU, Хинты по сборке |
Здравствуйте, гость ( Вход | Регистрация )
Boost + ICU, Хинты по сборке |
Iron Bug |
24.11.2011, 17:29
Сообщение
#1
|
Профессионал Группа: Модератор Сообщений: 1611 Регистрация: 6.2.2009 Из: Yekaterinburg Пользователь №: 533 Спасибо сказали: 219 раз(а) Репутация: 12 |
Я тут собирала новые библиотеки. Обнаружила некоторые косяки. Вот хинты для их обхода, если вдруг кому пригодится.
Сборка ICU 4.8.1.1: При сборке с MinGW к сорцам ICU нужно применить небольшой патч для исправление ошибки "undefined symbol _mkdir": В файле toolutil.cpp вот этот #include
меняем на <direct.h>
С остальными компиляторами вроде проблем не наблюдалось. Про кросскомпиляцию ICU читать readme.html в корне сорца! Там всё подробно написано. Сборка нетривиальная, так что лучше сначала прочитать документацию Сборка boost 1.48.0 c ICU 4.8.1.1: Далее, при сборке буста с новым форматом библиотеки ICU нужны дополнительные опции для bjam по сборке с ICU 4.8.1.1: Цитата -sHAVE_ICU=1 -sICU_PATH=путь_до_каталога_установки_ICU -sICU_LINK="-L$ICU_PATH/lib -licuuc48 -licuin48 -licudt48" (Путь до каталога ICU должен быть полный!) Это переопределение библиотек ICU для линковки, так как они теперь называются по-другому. О новых правилах именования написано тут: Цитата Windows: The DLLs you may need for your application are located in bin\icuXX##.dll, where "XX" are two letters (such as "uc" for the "common" library, "in" for the "i18n" library, etc.) and ## is the major and the minor version number (such as 42 for 4.2 / 4.2.0.1 or 4.2.4 ). Either place the DLLs in the same directory as your application's .EXE files, or set the PATH variable to point to the directory containing the ICU DLLs. For compiling applications, add the "include" direcotry (the parent of the "unicode" and "layout" directories) to the include search path. For linking applications, add the "lib" directory to the appropriate path. Other Platforms: For other platforms, the .tgz file unpacks to a "/usr/local" type hierarchy. For system-wide installation, you can unpack all of the files into /usr/local/bin, /usr/local/include, etc. The configuration script /usr/local/bin/icu-config or the similar Makefile include fragment /usr/local/lib/icu/current/Makefile.inc can be used in building applications. При сборке boost 1.48.0 с MinGW в скриптах boost build имеется баг, приводящий к ошибке Цитата error: Duplicate name of actual target: <pstage\lib>libboost_exception-mgw45-mt-1_48.a У меня не было времени детально копаться в скриптах, я выяснила, что обход бага в том, чтобы проставить threading=multi в параметрах сборки. Баг уже известен в переписке по бусту и, скорее всего, скоро будет поправлен. В прочих компиляторах баг не проявляется. Сообщение отредактировал Iron Bug - 25.11.2011, 10:03 |
|
|
Iron Bug |
17.10.2013, 10:07
Сообщение
#2
|
Профессионал Группа: Модератор Сообщений: 1611 Регистрация: 6.2.2009 Из: Yekaterinburg Пользователь №: 533 Спасибо сказали: 219 раз(а) Репутация: 12 |
Собрала тут в очередной раз комплект boost+ICU. На этот раз boost 1.54.0 и ICU 52.1.
Собрано было для MSVC и MinGW под вендой и GCC под линём. Для сборки в MSVC под вендой: ICU собирается в студии, открыванием солюшена icu/source/allinone/allinone.sln и полной сборкой релиза. Далее, для сборки boost запускается Bootstrap.bat (он компилирует bjam.exe). И далее, в консоли венды запускается следующий батничек:
Тут сборка идёт под 10-й студией, для 32-битной системы, многопоточные сборки со статической линковкой и разными линковками runtime библиотек. Если добавить в обе строки
то будет сборка boost::thread с наносекундными таймерами. Для MinGW под вендой: ICU собирается в MSys:
Инсталляция в отдельную папку нужна для последующего копирования файлов для работы в венде. Потом стандартно: make+make install. Забираем все файлы из папки, куда установилось, и копируем в удобное для себя место для хранения собранной ICU. Далее, собираем boost (из консоли венды): Bootstrap.bat (для собирания bjam, неважно, каким компилятором). Далее, батничек:
-DBOOST_DATE_TIME_POSIX_TIME_STD_CONFIG означает сборку boost::thread с наносекундными таймерами. Это можно опустить или добавить, по желанию. Я собираю с таймерами, ибо они мне нужны. Для запуска GCC нужно, чтобы в переменной окружения PATH был прописан путь до MinGW/bin. Также везде в опции bjam можно добавить -j2 для сборки на двух ядрах проца, например. Чтобы было быстрее. Собирается долго, жрёт много памяти и винта в каталоге для временных файлов. Можно указать конкретные библиотеки для сборки или исключить некоторые, по желанию. Под линюксом, с GCC: ICU собирается стандартно (configure+make+make install). Если нужен нестандарный каталог, то с prefix. Сборка boost: Если ICU установлен в нестандартный каталог, то указать, где:
Либо просто без параметров, если ICU установлен в общие каталоги. Далее, скрипт:
Собственно, параметры ICU_PATH и cxxflags тут нужны только если ICU был установлен в нестандартный каталог (с prefix). Ну и выбор дополнительных флагов можно добавить, по желанию. Например, или список библиотек, которые нужны, или -j2 для ускорения. Ну и разные параметры линковки, разумеется.
Сообщение отредактировал Iron Bug - 17.10.2013, 11:10 |
|
|
Текстовая версия | Сейчас: 25.11.2024, 4:22 |