CMake: различия между версиями
[непроверенная версия] | [непроверенная версия] |
Alter73 (обсуждение | вклад) Изменён логотип Метки: через визуальный редактор с мобильного устройства из мобильной версии через расширенный мобильный режим |
м →История |
||
Строка 40: | Строка 40: | ||
}}</ref>. |
}}</ref>. |
||
В то время было нормой использовать [[ |
В то время было нормой использовать [[Конфигурационный файл|конфигурационные скрипты]] и [[Makefile|Make файлы]] для сборки программных проектов на [[Unix-подобная операционная система|Unix платформах]] и файлы проектов [[Visual Studio]] в среде [[Microsoft Windows|Windows]]. Такой подход к разработке вызывал огромное неудобство, так как, к примеру, добавление обыкновенного файла исходного кода в проект приводило к большим трудностям, так как для каждой платформы это приходилось делать по отдельности и совершенно разными методами. Очевидно, что разработчики хотели иметь единую унифицированную систему сборки, не отнимающую лишнее время и имеющую все преимущества существующих систем сборки, но при этом не имеющую их недостатков<ref>{{cite web |
||
|url = http://rus-linux.net/MyLDP/BOOKS/Architecture-Open-Source-Applications/Vol-1/cmake.html |
|url = http://rus-linux.net/MyLDP/BOOKS/Architecture-Open-Source-Applications/Vol-1/cmake.html |
||
|title = Перевод главы о CMake из книги «The Architecture of Open Source Applications» |
|title = Перевод главы о CMake из книги «The Architecture of Open Source Applications» |
Версия от 19:41, 12 ноября 2022
CMake | |
---|---|
Тип | система сборки[вд], свободное и открытое программное обеспечение и утилита |
Автор | Kitware[вд] |
Разработчики | Kitware[вд], Александр Нойндорф[вд], Кен Мартин[вд], Андрей Седильник[вд], Уильям Хоффман[вд] и Брэд Кинг[вд] |
Написана на | C++ и Си[3] |
Интерфейс | Qt[4][5][…] |
Операционные системы | Unix-подобная операционная система[6] и Windows[6] |
Языки интерфейса | английский |
Первый выпуск | 2000 |
Аппаратная платформа | кроссплатформенность[7] |
Последняя версия | |
Кандидат в релизы |
|
Репозиторий | gitlab.kitware.com/cmake… |
Состояние | активное |
Лицензия | модифицированная лицензия BSD[вд][8][9][…] |
Сайт | cmake.org (англ.) |
Медиафайлы на Викискладе |
CMake (МФА [ˈsiːmeɪk]; от англ. Cross-platform Make — «Кроссплатформенный Make»[10]) — это кроссплатформенная утилита, обладающая возможностями автоматизации сборки программного обеспечения из исходного кода. Сам CMake не занимается непосредственно сборкой, а лишь генерирует файлы сборки из предварительно написанного скрипт-файла «CMakeLists.txt» и предоставляет простой единый интерфейс управления. Помимо этого, CMake способен автоматизировать процесс установки и пакетирования.
Считается альтернативой распространённой в сообществе GNU системе Autotools, разработанной на базе Perl и M4, которая требует определённых навыков для практического использования, а существующие версии в ряде случаев несовместимы друг с другом.
В сравнении с альтернативой Autotools, появившейся в 2008 году системой SCons, основанной на Python, является более быстродействующей, поскольку написана на Си и использует крайне простой макроязык, но при этом SCons обладает большими возможностями по расширению.
История
Разработка CMake началась в 1999 году в ответ на потребность в кроссплатформенной системе сборки для ITK[англ.][11]. Проект, финансируемый национальной библиотекой медицины США как часть проекта «Visible Human Project[англ.]». Задача по разработке была возложена на небольшую компанию Kitware[англ.]. На него повлияла более ранняя система под названием "pcmaker", созданная Кеном Мартином (Ken Martin) и другими разработчиками для поддержки инструментария визуализации (VTK)[12].
В то время было нормой использовать конфигурационные скрипты и Make файлы для сборки программных проектов на Unix платформах и файлы проектов Visual Studio в среде Windows. Такой подход к разработке вызывал огромное неудобство, так как, к примеру, добавление обыкновенного файла исходного кода в проект приводило к большим трудностям, так как для каждой платформы это приходилось делать по отдельности и совершенно разными методами. Очевидно, что разработчики хотели иметь единую унифицированную систему сборки, не отнимающую лишнее время и имеющую все преимущества существующих систем сборки, но при этом не имеющую их недостатков[13][14].
Возможности
Ключевой особенностью является возможность (необязательно) размещать выходные данные компилятора (например, объектные файлы) вне дерева исходного кода. Это позволяет выполнять несколько вариаций сборок из одного и того же исходного кода, а также кросскомпиляцию. Такой подход разделения файлов исходного кода и файлов сборки даёт гарантию, что удаление каталога сборки не приведет к удалению исходного кода. Однако сами пользователи не защищены от случайного удаления каталога с исходными файлами[15].
Настраиваемая структура проекта
CMake может находить общесистемные и пользовательские каталоги исполняемых файлов, файлов конфигураций и библиотек. Эти местоположения хранятся в кэше, который можно конфигурировать перед созданием целевых файлов сборки. CMake кэш можно редактировать с помощью графического редактора, который поставляется вместе с CMake, либо вручную, посредством оболочки командной строки с помощью команд CMake.
Сложные иерархии каталогов проектов, рассчитанные на разные конфигурации, сборку с разными библиотеками и инструментами, также хорошо поддерживаются CMake. По сути CMake предоставляет возможность создавать подпроекты, собираемые перед сборкой основного проекта, что позволяет создавать цепочки зависимостей, собираемые в правильной необходимой разработчику последовательности.
Поддержка разных сред разработки
CMake может создавать файлы проектов для нескольких популярных ИСР, таких как Microsoft Visual Studio, Xcode и Eclipse CDT.
Он также может создавать сценарии сборки для:
- MSBuild и Nmake в Windows;
- Unix Make на Unix-подобных платформах, таких как Linux, BSD, macOS и Cygwin;
- А также Ninja, как на Windows, так и на Unix-подобных платформах.
Для упрощения внедрения поддержки CMake в новые ИСР, рекомендуется использовать файлы преднастройки «CMakePresets.json»[16], для более удобного конфигурирования процесса сборки, а также «File API»[17], содержащий всю необходимую для ИСР информацию.
Следующие ИСР поддерживают CMake изначально[18]:
Поддержка компиляторов
CMake позволяет определять свойства, которые компилятор должен поддерживать, чтобы скомпилировать целевую программу или библиотеку[19].
CMake поддерживает обширный список компиляторов[20], в который входят:
Процесс сборки
Сборка программы или библиотеки с помощью CMake, представляет собой двухэтапный процесс. Во-первых, стандартные файлы сборки создаются (генерируются) из файлов конфигурации (CMakeLists.txt), которые написаны на языке CMake. Затем задействуются системные инструменты сборки (Make, Ninja и т. п.) используемые для фактического создания программ[15][21].
Файлы сборки конфигурируются в зависимости от используемого генератора (например, генератор «Unix Makefiles» — для Make фaйлов). Продвинутые пользователи могут создавать и включать свои собственные генераторы файлов Make, для поддержки новых компиляторов и операционных систем. Сгенерированные файлы обычно помещаются (с помощью флага CMake) во внешний каталог, за пределами исходных файлов, например в каталог «build».
Каждый проект после сборки, в поддиректориях содержит «CMakeCache.txt» и каталог файлов Make, что помогает избежать или ускорить этап «перегенерации», после повторного запуска сборки[22].
Типы целей сборки
В зависимости от конфигурации CMakeLists.txt и выбранной цели, файлы сборки могут создавать:
- исполняемые файлы;
- разделяемые библиотеки (например, libxyz, xyz.dll и т. п.);
- библиотеки объектных файлов;
- псевдо цели (включая псевдонимы).
CMake может создавать объектные файлы, которые могут быть связаны с исполняемыми двоичными файлами / библиотеками, избегая динамического (во время выполнения) связывания и вместо этого используя статическое (во время компиляции). Это обеспечивает гибкость в настройке различных оптимизаций (зависимости сборки могут определяться автоматически)[23].
Предкомпилированные заголовочные файлы
Начиная с версии CMake 3.6, можно создавать предварительно скомпилированные заголовочные файлы[24].
Язык
CMake имеет относительно простой интерпретируемый императивный язык сценариев. Он поддерживает переменные, методы обработки строк, массивы, объявления функций и макросов, включение модулей (импортирование). Команды языка CMake (или директивы) считываются CMake из файла CMakeLists.txt. В этом файле указываются исходные файлы и параметры сборки, которые CMake размещает в спецификации сборки проекта (например, в файле Make). Кроме того, файлы с приставкой .cmake, могут содержать сценарии используемые CMake[25].
Синтаксис команд
Аргументы команд разделены пробелами и могут содержать ключевые слова, для разделения групп аргументов. Например, в команде
# Команда установки
install(TARGETS ... # ЦЕЛИ
CONFIGURATIONS ... # КОНФИГУРАЦИИ (Debug, Release…)
RUNTIME DESTINATION ...) # (Исполняемый файл, MACOSX_BUNDLE, DLL) МЕСТО_НАЗНАЧЕНИЯ
ключевые слова — TARGETS
, CONFIGURATIONS
и RUNTIME DESTINATION
. В данном случае TARGETS
и CONFIGURATIONS
служат разделителями между «целями» и «конфигурациями»[26].
Примеры команд CMake, которые определяют цели и их зависимости[27][28][29]:
add_executable(...)
— определяет цель (исполняемый файл, например .exe, зависит от целевой платформы);add_library(...)
— определяет цель (библиотеку, например .so или .dll);target_link_libraries(...)
— определяет зависимости указанной цели.
Поддержка JSON
CMake поддерживает извлечение значений данных в переменные из строк JSON (начиная с версии 3.19)[30].
Модули и инструменты
CMake поставляется с большим количеством модулей и инструментов «.cmake». Они облегчают такую работу, как поиск зависимостей (как встроенных, так и внешних, например, FindXYZ модули), инструменты для тестирования исполняемых файлов, упаковка (модуль CPack и команда cpack) и управление зависимостями от внешних проектов (модуль ExternalProject)[31][32]:
- ctest — используется для тестирования целей, заданных в CMakeLists.txt;
- ccmake и cmake-gui — настраивает и обновляет переменные конфигурации, предназначенные для целевой системы сборки;
- cpack — помогает упаковывать и устанавливать программное обеспечение.
CPack
Начиная с версии 2.4.2[33], в состав CMake включены система автоматизированной сборки пакетов программного обеспечения CPack и модуль CMake для взаимодействия с ней. Система позволяет создавать пакеты программного обеспечения для популярных пакетных менеджеров (DEB, RPM, DMG), средства установки программного обеспечения (NSIS для Microsoft Windows), а также архивы со сборкой (TGZ, TBZ2, ZIP, самораспаковывающийся TGZ)[34].
Программные проекты использующие CMake
CMake получил очень широкое распространение среди проектов с открытым исходным кодом, а также среди коммерческих и академических программных проектов.
Проекты с открытым исходным кодом
- Apache Qpid (система сообщений);
- Boost (набор C++ библиотек);
- Blender (программа 3D моделирования)[35];
- ReactOS (операционная система совместимая с Windows программами и драйверами);
- MySQL (система управления базами данных);
- KDE (среда рабочего стола и смежные проекты)[36];
- KiCad (САПР);
- FreeCAD (САПР);
- WebKit (веб движок);
- Hierarchical Data Format (иерархический формат данных).
Научно исследовательские проекты
Программное обеспечение, используемое в эксперименте ATLAS, создано с использованием CMake. Само программное обеспечение написано на C/C++ и Python[37].
Исследовательский институт во франции INRIA применил CMake в медицинском исследовании в проекте SOFA[англ.][38].
Компании и проекты с закрытым кодом
- Netflix (стриминговый сервис фильмов и сериалов)[39];
- Second Life (виртуальный мир с элементами социальной сети)[40].
Пример
Пример простого «Hello, World!» проекта на языке CMake.
# Файл — «CMakeLists.txt»
cmake_minimum_required(VERSION 3.16) # Выбираем минимальную необходимую версию cmake
project(my_project) # Присваиваем имя проекту
add_executable( # Создаём цель (исполняемый файл)
${PROJECT_NAME} # Имя файла
main.cpp # Список файлов исходного кода
) # Добавлять заголовочные файлы нет необходимости
install( # Указываем цель и путь установки
TARGETS ${PROJECT_NAME} # Путь прибавляется к префиксу
RUNTIME DESTINATION bin # bin - binary (путь к исполняемым файлам)
) # Стандартный префикс для UNIX систем
# "/usr/local" + "/bin"
// файл — «main.cpp»
# include <iostream>
int main()
{
std::cout << "Hello, World!" << std::endl;
return 0;
}
Сборка осуществляется посредством следующих команд в каталоге с файлами:
$ cmake . # Вызываем генерацию файлов сборки
$ cmake --build . # Собираем цель, на выходе получаем исполняемый файл
$ cmake --install . # По необходимости устанавливаем
При этом, есть возможность получить справочную информацию об отдельном элементе языка CMake и его команд.
$ cmake --help
$ cmake --help-command-list
$ cmake --help-command install
См. также
Примечания
- ↑ CMake 3.31.2 available for download (англ.) — 2024.
- ↑ CMake 3.31.0-rc3 is ready for testing (англ.) — 2024.
- ↑ The cmake Open Source Project on Open Hub: Languages Page — 2006.
- ↑ https://cmake.org/cmake/help/latest/manual/cmake-gui.1.html
- ↑ https://cmake.org/runningcmake
- ↑ 1 2 https://cmake.org/download/
- ↑ https://cmake.org/
- ↑ https://gitlab.kitware.com/cmake/cmake/blob/master/Copyright.txt
- ↑ The cmake Open Source Project on Open Hub: Licenses Page — 2006.
- ↑ Embracing Modern CMake How to recognize and use modern CMake interfaces (англ.) (PDF). Дата обращения: 4 апреля 2022. Архивировано 20 января 2022 года.
- ↑ FLOSS Weekly 111: CMake (англ.). podcast. TWiT Network.. Дата обращения: 19 января 2022. Архивировано 6 октября 2014 года.
- ↑ About CMake (англ.). cmake.org. Дата обращения: 15 марта 2022. Архивировано 14 марта 2022 года.
- ↑ Перевод главы о CMake из книги «The Architecture of Open Source Applications» . rus-linux.net (28 августа 2012). Дата обращения: 19 января 2022. Архивировано 7 мая 2021 года.
- ↑ Глава о CMake из книги «The Architecture of Open Source Applications» (англ.). aosabook.org (2012). Дата обращения: 19 января 2022. Архивировано 7 апреля 2022 года.
- ↑ 1 2 Александр Нойндорф (Alexander Neundorf). Why the KDE project switched to CMake — and how (англ.). lwn.net (21 июня 2006). Дата обращения: 19 января 2022. Архивировано 20 ноября 2021 года.
- ↑ CMake documentation: IDE Integration Guide (англ.). cmake.org. Дата обращения: 26 января 2022. Архивировано 26 января 2022 года.
- ↑ CMake documentation: cmake-file-api(7) (англ.). cmake.org. Дата обращения: 26 января 2022. Архивировано 26 января 2022 года.
- ↑ CMake documentation: IDEs with CMake integration (англ.). cmake.org. Дата обращения: 11 июля 2022.
- ↑ CMake compiler feature detect (англ.). scivision.dev (15 ноября 2020). Дата обращения: 4 апреля 2022. Архивировано 22 января 2022 года.
- ↑ Supported Compilers (англ.). CMake.org. Дата обращения: 4 апреля 2022. Архивировано 21 февраля 2022 года.
- ↑ CMake documentation: cmake-toolchains(7) (англ.). cmake.org. Дата обращения: 19 января 2022. Архивировано 19 января 2022 года.
- ↑ Дэниел Пфайфер (Daniel Pfeifer). Effective CMake (англ.) (PDF). GitHub (19 мая 2017). Дата обращения: 19 января 2022. Архивировано 19 января 2022 года.
- ↑ CMake documentation: cmake-buildsystem(7) — Object Libraries (англ.). cmake.org. Дата обращения: 19 января 2022. Архивировано 19 января 2022 года.
- ↑ CMake documentation: target precompile headers (англ.). cmake.org. Дата обращения: 19 января 2022. Архивировано 19 января 2022 года.
- ↑ CMake documentation: cmake-language(7) (англ.). cmake.org. Дата обращения: 19 января 2022. Архивировано 21 февраля 2022 года.
- ↑ Андрей Седильник (Andrej Cedilnik). Cross-Platform Software Development Using CMake (англ.). linuxjournal (3 октября 2003). Дата обращения: 19 января 2022. Архивировано 19 января 2022 года.
- ↑ CMake documentation: cmake-commands(7) ― add_executable (англ.). cmake.org. Дата обращения: 19 января 2022. Архивировано 19 января 2022 года.
- ↑ CMake documentation: cmake-commands(7) ― add_library (англ.). cmake.org. Дата обращения: 19 января 2022. Архивировано 19 января 2022 года.
- ↑ CMake documentation: cmake-commands(7) ― target_link_libraries (англ.). cmake.org. Дата обращения: 19 января 2022. Архивировано 19 января 2022 года.
- ↑ CMake documentation: CMake 3.19 Release Notes (англ.). cmake.org. Дата обращения: 19 января 2022. Архивировано 29 апреля 2022 года.
- ↑ CMake documentation: cmake-modules(7) (англ.). cmake.org. Дата обращения: 19 января 2022. Архивировано 9 декабря 2021 года.
- ↑ CMake documentation: cmake-modules(7) — ExternalProject (англ.). cmake.org. Дата обращения: 19 января 2022. Архивировано 21 февраля 2022 года.
- ↑ CMake:Packaging With CPack - KitwarePublic (англ.). GitLab. Дата обращения: 19 января 2022. Архивировано 19 января 2022 года.
- ↑ CMake:CPackPackageGenerators - KitwarePublic (англ.). GitLab. Дата обращения: 19 января 2022. Архивировано 19 января 2022 года.
- ↑ Blender wiki — Building Blender (англ.). blender.org. Дата обращения: 19 января 2022. Архивировано 24 января 2022 года.
- ↑ KDE Adopts CMake (англ.). kitware.com. Дата обращения: 15 марта 2022. Архивировано 14 марта 2022 года.
- ↑ J. Elmsheuser, A. Krasznahorkay, E. Obreshkov, A. Undrus. Large Scale Software Building with CMake in ATLAS (англ.) (PDF). ЦЕРН. Дата обращения: 19 января 2022. Архивировано 10 ноября 2021 года.
- ↑ Converting SOFA to CMake (англ.). kitware.com. Дата обращения: 15 марта 2022. Архивировано 14 марта 2022 года.
- ↑ CMake, CTest, and CDash at Netflix (англ.). kitware.com. Дата обращения: 15 марта 2022. Архивировано 14 марта 2022 года.
- ↑ Second Life Chooses CMake as its Build System (англ.). kitware.com. Дата обращения: 15 марта 2022. Архивировано 14 марта 2022 года.
Ссылки
- Официальный сайт
- Публикации
- Истории успеха
- Разработчики рассказывают о истории проекта CMake // Журнал «Открытые системы», 2007/03
- Что за штука CMake? // Журнал «Linux Format», #99 (12), Декабрь 2007 (wiki)
- Как использовать CMake в KDE4
- Статьи по CMake
- Почему KDE перешёл к использованию CMake (англ.)
- Программное обеспечение по алфавиту
- Программное обеспечение, разработанное в 2000 году
- Инструменты компиляции
- Автоматизация сборки
- Свободные системы автоматизации сборки
- Программное обеспечение с лицензией BSD
- Свободное программное обеспечение, написанное на Си
- Свободное программное обеспечение, написанное на C++
- Кроссплатформенное программное обеспечение