Ninja (система сборки)
Ninja (МФА [nˈiɪnʤə]; с англ. — «ниндзя») — это кроссплатформенная консольная утилита, представляющая из себя систему сборки программного обеспечения из исходного кода. Утилита Ninja была разработана Эваном Мартином, сотрудником компании Google[8][9]. Ninja представляет собой улучшенную и доработанную версию утилиты Make. Главная цель которой — автоматизация сборки и её ускорение, а также ускорение последующих пересборок, на основе сгенерированных утилитой файлов и решение типовых проблем при кроссплатформенной разработке. ИсторияСистема сборки Ninja была разработана с целью заменить устаревшие системы сборки, не рассчитанные на крупные проекты с большим количеством кода. Кодовая база таких проектов как браузер Google Chrome и операционная система Android уже на то время (2007—2012) составляла несколько миллионов строк кода и более 40 тыс. вхождений. Первоначально разработчики использовали систему сборки SCons, основанную на Python, но по заверению Эвана Мартина, SCons оказался слишком медленным и отнимал около 40 секунд на один лишь только запуск, перед тем как начиналась сама сборка. После чего была предпринята попытка перевода проектов на систему Make, но после проведения очередных тестов оказалось, что Make также отнимал около 10 секунд на запуск и 10—20 секунд на инкрементальную сборку. Помимо этого, Make и SCons зачастую вызывали различные проблемы с кроссплатформенной разработкой. Это не устраивало Эвана и сподвигло его к разработке новой системы сборки, не имеющей таких недостатков[8][10]. Впервые Эван Мартин сообщил о планах и причинах разработки Ninja в своём блоге 6 февраля 2011 года[11]. На следующий год (8 мая 2012) состоялся первой выпуск Ninja[12] версии 120508 и был размещён на GitHub репозитории[12]. О системе сборкиВ ходе разработки система сборки Ninja приобрела множество новых особенностей, увеличивших скорость сборки[13][14][15]. Из таких особенностей можно отметить:
Сам Эван не рекомендует писать сборочные скрипты Ninja вручную, по той простой причине, что синтаксис скриптов Ninja остался подобен Make синтаксису. Скорее всего, это было сделано, ради упрощения перевода программ с Make на Ninja и в угоду скорости исполнения, так как Make имеет довольно простую синтаксическую структуру и подобен языку ассемблера. По этой причине, написание на нём скриптов человеком, может быть затруднительным, а чтение и анализ синтаксиса программами, остаются тривиальными. Вместо ручного написания, рекомендуется использовать Ninja в сочетании с более «умными» системами мета-сборки (GYP, CMake, Meson и т. п.), имеющими встроенный генератор файлов Ninja[18]. ФилософияПримерный перевод раздела о философии из руководства Ninja. Эван Мартин. «The Ninja build system manual: Philosophical overview»[19]:
Пример кодаДалее, приведён пример базового «.ninja» файла, демонстрирующего основную часть синтаксиса[20]. cflags = -Wall
rule cc
command = gcc $cflags -c $in -o $out
build foo.o: cc foo.c
КритикаNinja по умолчанию запускает сборку в параллельном режиме и задействует все доступные ресурсы компьютера. При определённых условиях это может привести к таким критичным проблемам, как переполнение буфера памяти или к перегреву вычислительного устройства, что случается с термоинтерфейсами, неспособными отводить большие объёмы тепла. Вследствие чего повышается риск программных ошибок из-за перегрева процессора и в итоге, может привести к аварийному отключению устройства. Ninja не выводит подробный лог о процессе сборки, в угоду скорости исполнения, что затрудняет анализ при сборке и кросскомпиляции таких сложных программ, как ядро операционной системы, компилятор и им подобных. См. такжеПримечания
Ссылки
|
Portal di Ensiklopedia Dunia