В процессе работы над проектом решил попробовать новый FindBoost поставляемый с версией 2.6.
Немного технических подробностей.
Проект представляет из себя множество под-проектов представленных в виде дерева фолдеров:
project_root/
----> modules/
---------> module1/[hdr,src]
---------> module2/[hdr,src]
...
---------> moduleN/[hdr,src]
CMakeLists.txt в фолдере modules не сложен и выглядит примерно так
-- начало ----
# говорим, что проект у нас С++!!!
project(project_name_of_the_whole_system CXX)
add_directory(module1)
...
add_directory(moduleN)
-- конец ----
Не каждый модуль использует Boost, и старается быть, по возможности, независим, но каждый является C++ кодом.
Соответственно, для каждого нового модуля, появляющегося в проекте, берем шаблон вида:
-- начало ----
# меняем конфигурационные параметры - изменяемая часть шаблона
# говорим, что проект у нас С++!!!
project(project_name_of_the_specific_module CXX)
# означает что будет собираться библиотека
set(is_module_exec false)
# означает что мы зависим от специфичной библиотеки
set(is_module_use_lib1 true)
# используем Boost C++ lib
set(is_module_use_boost true)
# не изменяемая часть
# здесь конфигурируем, в зависимости от установленных параметров выше
include(ModuleConfig)
# далее строим модуль
...
-- конец ----
С Cmake 2.6, в начальную конфигурацию добавляю
set(is_module_required_boost_libs
thread
system
program_options
)
правлю внутренний ModuleConfig.cmake примерно так
if(is_module_required_boost_libs)
find_package(Boost COMPONENTS ${is_module_required_boost_libs})
else(is_module_required_boost_libs)
find_package(Boost)
endif(is_module_required_boost_libs)
На Windows все прошло замечательно, поскольку библиотеки там прилинковываются автоматически (autolink feature от Visual C++). Для GNU C++ такой возможности нет (или по крайней мере я о ней не знаю - если кто подскажет, буду очень признателен). Посему, для g++ приходиться хитрить.
FindBoost должен все найти для меня. А я, по идее, пробегаясь foreach(my_requested_name ${is_module_required_boost_libs}) по всем компонентам получаю набор библиотек Boost-а, необходимых для передачи линкеру.
Вроде бы все логично, однако при добавлении system компоненты FindBoost выставляет Boost_FOUND в false.
Что за дела? Начинаю ковыряться...
BOOST_ROOT указывает в /usr/local - там версия 1.34.1. libboost-system-gcc41-... там присуствует.
Выкидываю system из требуемых компонент буста для модуля. Вывожу отладочную информацию по фолдеру с библиотеками - получаю /usr/lib. Обнаруживаю там библиотеки версии 1.33.1, поставляемые с RH5, но с названием вида libboost-thread-mt... Где gcc[ver] в имени либы? libboost-system там дейсвительно нет. Но почему же он ищет там, не учитывая BOOST_ROOT переменную? Долго осознаю, что происходит... :-) Не понимаю. Ругаюсь. Пытаюсь обмануть систему генерации, установив помимо BOOST_ROOT еще и BOOST_LIBRARYDIR - результат тот же.
Начитаю курочить FindBoost.cmake отладочной информацией. Понимая, что проблема с именованиями - проверяю определение компилятора и его версии в скрипте FindBoost. Скрипт дает мне информацию, что это Intel-овский компилятор C++, поскольку это UNIX и компилятор NOT GNUCC. Чертовски логично, учитывая что, скорее всего, он GNUCXX для C++ проекта.
---- кусок FindBoost --------
IF (UNIX)
IF (APPLE)
SET (_boost_COMPILER "")
ELSE (APPLE)
IF (NOT CMAKE_COMPILER_IS_GNUCC)
# This is for the intel compiler
SET (_boost_COMPILER "-il")
ELSE (NOT CMAKE_COMPILER_IS_GNUCC)
#find out the version of gcc being used.
EXEC_PROGRAM(${CMAKE_CXX_COMPILER}
ARGS --version
OUTPUT_VARIABLE _boost_COMPILER_VERSION
)
---- кусок FindBoost --------
Вот так...
Проект у меня C++, Boost вроде тоже библиотека С++, а проверяем CMAKE_COMPILER_IS_GNUCC, вместо CMAKE_COMPILER_IS_GNUCXX.
Для проверки своего предположения, добавил в проектный скрипт информацию по компилятору. Действительно, если проект объявлен CXX, CMAKE_COMPILER_IS_GNUCC не определен.
Как обходной маневр (workaround) объявил проект, как
# говорим, что проект у нас не только С++, но и C!!!
project(project_name_of_the_whole_system CXX С)
Думаю, что необходимо спросить мнения CMake-ров на эту тему в список рассылки и завести проблему в cmake багтрэкер, по соображениям изложенным выше.
Такой вот длинный рассказ на ночь :-).
Благодарю за внимание всех, кто дочитал до конца.
четверг, 26 июня 2008 г.
пятница, 20 июня 2008 г.
Subversion 1.5 released
Текущий месяц очень щедр на релизы :-)
Вышла новая версия Subversion (для тех не знает - система контроля версий).
Изменения описаны здесь.
Субъективно пока ничего сказать не могу - не пробовал, поскольку формат репозиториев изменился. Но судя по списку изменений, имеет смысл опробовать :-)
Вышла новая версия Subversion (для тех не знает - система контроля версий).
Изменения описаны здесь.
Субъективно пока ничего сказать не могу - не пробовал, поскольку формат репозиториев изменился. Но судя по списку изменений, имеет смысл опробовать :-)
четверг, 19 июня 2008 г.
Firefox 3 is out...
Вчера забрал с сайта мозиллы последнюю версию Firefox и установил себе на компьютер.
Первые впечатления весьма положительные.
Субъективно:
- возросла производительность
- перестал "зависать" с большим количеством открытых табов (видимо сократили размер потребляемой памяти)
- приятный вид
Проходит acid2, но не проходит acid3.
Из неудобств:
ни один из мной выбраных скинов для 2-го не стал работать в 3-ем :-)
Плюсов, всетаки, больше.
Рекомендую попробовать :-)
Первые впечатления весьма положительные.
Субъективно:
- возросла производительность
- перестал "зависать" с большим количеством открытых табов (видимо сократили размер потребляемой памяти)
- приятный вид
Проходит acid2, но не проходит acid3.
Из неудобств:
ни один из мной выбраных скинов для 2-го не стал работать в 3-ем :-)
Плюсов, всетаки, больше.
Рекомендую попробовать :-)
четверг, 12 июня 2008 г.
Back home...
Итак, я удачно съездил в первопрестольную, обучился и получил аттестат о том, что прослушал 2-х дневный курс "Designing and Analyzing Software Architecture" проведенный Риком Казманом (Rick Kazman).
Рик известен своим участием в написании книги Software Architecture in Practice (2nd Edition) (The SEI Series in Software Engineering).
Надо сказать вояж был полезен, прежде всего тем, что я нашел время почитать оригинал данной книги в электронном варианте. Кроме того, я доволен (!) качеством преподаваемого материала и самим лектором.
Вообще множество учебных материалов (литературы) связанных с программной инженерией вызывает у меня легкое deja-vu. Анализируя свой опыт разработки (вот так вот :-) ), понимаешь, что ты делал все очень похоже, как написано (видимо, интуитивно следуя какому-то процессу). Естественно, опуская какие-либо (кажущиеся тебе неважными) детали. Слушанье лекции, обеспечивает недостающие кусочки мозаики и объесняют причину их необходимости/важности.
Ну чтоже, нужно адаптировать и внедрить.
Рик известен своим участием в написании книги Software Architecture in Practice (2nd Edition) (The SEI Series in Software Engineering).
Надо сказать вояж был полезен, прежде всего тем, что я нашел время почитать оригинал данной книги в электронном варианте. Кроме того, я доволен (!) качеством преподаваемого материала и самим лектором.
Вообще множество учебных материалов (литературы) связанных с программной инженерией вызывает у меня легкое deja-vu. Анализируя свой опыт разработки (вот так вот :-) ), понимаешь, что ты делал все очень похоже, как написано (видимо, интуитивно следуя какому-то процессу). Естественно, опуская какие-либо (кажущиеся тебе неважными) детали. Слушанье лекции, обеспечивает недостающие кусочки мозаики и объесняют причину их необходимости/важности.
Ну чтоже, нужно адаптировать и внедрить.
четверг, 5 июня 2008 г.
На пути в Москву...
Итак, первые впечатления, от поездки:
1. Рейс перенесли с 13:30 на 21:55 - это значит я буду в Москве в 12-ом часу ночи, а не в 15:30 как это должно было быть... Н-да... Это поломало всю стройную структуру моих запланированных перемещений :( Спасибо Аэрофлоту.
2. Пробую здесь в аэропорту Владивостока дальсвязевский WiFi по карточке... Вроде неплохо - пока не понял :)
3. Батарейка в моем 2-х ядерном ноуте конечно слабовата - работает от силы 1.5 часа. Нашел единственное место в аэропорту с 2-мя розетками. Даже не в зале ожидания а внизу в холе. Тут и примостился. Не круто для аэропорта.
4. Аэрофлот походу вступил в SkyTeam, и, посему, я положил дистанцию туда и обратно на свой SkyPass полученный в 2002 году в Korean Air. Доволен :)
1. Рейс перенесли с 13:30 на 21:55 - это значит я буду в Москве в 12-ом часу ночи, а не в 15:30 как это должно было быть... Н-да... Это поломало всю стройную структуру моих запланированных перемещений :( Спасибо Аэрофлоту.
2. Пробую здесь в аэропорту Владивостока дальсвязевский WiFi по карточке... Вроде неплохо - пока не понял :)
3. Батарейка в моем 2-х ядерном ноуте конечно слабовата - работает от силы 1.5 часа. Нашел единственное место в аэропорту с 2-мя розетками. Даже не в зале ожидания а внизу в холе. Тут и примостился. Не круто для аэропорта.
4. Аэрофлот походу вступил в SkyTeam, и, посему, я положил дистанцию туда и обратно на свой SkyPass полученный в 2002 году в Korean Air. Доволен :)
Подписаться на:
Сообщения (Atom)