# echo DEVELOPER=yes >> /etc/make.confРуководство FreeBSD по созданию портов
Этот перевод может быть устаревшим. Для того, чтобы помочь с переводом, пожалуйста, обратитесь к Сервер переводов FreeBSD.
товарные знаки
FreeBSD является зарегистрированным товарным знаком Фонда FreeBSD.
Sun, Sun Microsystems, Java, Java Virtual Machine, JDK, JRE, JSP, JVM, Netra, Solaris, StarOffice, SunOS это торговые марки или зарегистрированные торговые марки Sun Microsystems, Inc. в Соединенных Штатах и других странах.
Unix это зарегистрированная торговая марка Open Group в Соединенных Штатах и других странах.
Многие из обозначений, используемые производителями и продавцами для обозначения своих продуктов, заявляются в качестве товарных знаков. Когда такие обозначения появляются в этом документе, и Проекту FreeBSD известно о товарном знаке, к обозначению добавляется знак “™” или “®”.
Содержание
Глава 1. Введение
Коллекция портов FreeBSD является способом, используемым практически каждым для установки приложений ("портов") на FreeBSD. Как и почти всё остальное во FreeBSD, эта система в основном является добровольно поддерживаемым начинанием. Важно иметь это в виду при чтении данного документа.
Во FreeBSD каждый может прислать новый порт либо изъявить желание поддерживать существующий порт, если его никто ещё никто не поддерживает-вам не нужно иметь никаких особых привилегий на внесение изменений, чтобы это делать.
Глава 2. Как самому сделать новый порт
Итак, вы интересуетесь, как создать собственный порт или обновить существующий? Великолепно!
Ниже находятся некоторые указания по созданию нового порта для FreeBSD. Если вы хотите обновить существующий порт, вы должны прочесть их, а затем Обновление отдельного порта.
Если этот документ недостаточно подробен, вы должны обратиться к файлу /usr/ports/Mk/bsd.port.mk, который включается в make-файл каждого порта. Он хорошо прокомментирован, и даже если вы не занимаетесь хакингом make-файлов каждодневно, из него вы сможете узнать много нового. Кроме того, конкретные вопросы можно задать, послав письмо на адрес Список рассылки, посвящённый Портам FreeBSD.
Только часть переменных ( |
Ищете, с чего бы начать попроще? Посмотрите на перечень запрошенных портов, есть ли там такие, над которыми вы можете работать.
Глава 3. Быстрое портирование
В этом разделе описано, как быстро создать новый порт. Для случаев, когда этот быстрый метод не подходит, полный процесс "Медленного портирования" описан в разделе Медленное портирование.
Во-первых, скачайте оригинальный tar-файл и поместите его в каталог DISTDIR, который по умолчанию есть не что иное, как /usr/ports/distfiles.
Здесь предполагается, что программное обеспечение компилируется без проблем как есть, то есть для работы приложения на вашей системе FreeBSD не потребовалось абсолютно никаких изменений. Если требовалось что-то изменить, то вам придется обратиться также и к следующему разделу — Медленное портирование. |
Перед началом портирования рекомендуется установить переменную make(1) Эта настройка включает "режим разработчика", в котором отображаются предупреждения при использовании устаревших конструкций и задействуются некоторые дополнительные проверки при вызове команды |
3.1. Создание файла Makefile
Минимальный Makefile будет выглядеть примерно так:
PORTNAME= oneko DISTVERSION= 1.1b CATEGORIES= games MASTER_SITES= ftp://ftp.rediris.es/sites/ftp.freebsd.org/pub/FreeBSD/ MAINTAINER= youremail@example.com COMMENT= Cat chasing a mouse all over the screen WWW= http://www.daidouji.com/oneko/ .include <bsd.port.mk>
Посмотрим, сможете ли вы его понять. Более подробный пример приведен в секции пример Makefile.
3.2. Создание информационных файлов
Имеется два информационных файла, которые требуются для любого порта, вне зависимости от того, является ли он пакетом или нет. Это pkg-descr и pkg-plist. Префикс pkg- отличает их от других файлов.
3.2.1. pkg-descr
Это более подробное краткое описание порта. От одного до нескольких абзацев, кратко описывающих, что представляет собой порт, будет достаточно.
Это не руководство и не подробное описание того, как использовать или компилировать порт! Пожалуйста, будьте осторожны при копировании из README или manpage. Очень часто они не содержат краткого описания порта или имеют неудобный формат. Например, manpages используют выравнивание по ширине, что особенно плохо выглядит с моноширинными шрифтами. С другой стороны, содержимое файла pkg-descr должно быть длиннее, чем строка |
Хорошо составленный pkg-descr описывает порт достаточно полно, чтобы пользователю не приходилось сверяться с документацией или посещать вебсайт для понимания того, что делает данное программное обеспечение, чем оно может быть полезно или какие хорошие функции у него имеются. Упоминание про определённые требования, такие как используемый графический инструментарий, тяжёлые зависимости, окружение для запуска или используемый язык программирования помогут пользователям определиться, будет ли этот порт для них работать.
URL, который ранее включался в последнюю строку файла pkg-descr, был перемещен в Makefile. |
3.2.2. pkg-plist
Здесь перечисляются все файлы, устанавливаемые портом. Его также называют "списком для упаковки", потому что пакет генерируется упаковкой файлов, которые здесь указаны. Имена путей указываются относительно установочного префикса (обычно /usr/local).
Вот маленький пример:
bin/oneko man/man1/oneko.1.gz lib/X11/app-defaults/Oneko lib/X11/oneko/cat1.xpm lib/X11/oneko/cat2.xpm lib/X11/oneko/mouse.xpm
Обратитесь к странице справочной системы по команде pkg-create(8) с подробным описанием формата списка упаковки.
Рекомендуется, чтобы имена файлов в этом списке были отсортированы в алфавитном порядке. Это позволит значительно облегчить сверку изменений при обновлении порта. Фреймворк делает это корректно, когда список пакета сгенерирован автоматически. |
Создание списка упаковки вручную может оказаться весьма трудоёмкой задачей. Если порт устанавливает большое количество файлов, раздел об автоматическом построении списка упаковки может помочь сэкономить время. |
Существует только одно исключение, когда у порта может отсутствовать pkg-plist. Если порт устанавливает лишь несколько файлов, а возможно, и каталогов, то они могут быть перечислены в переменных PLIST_FILES и PLIST_DIRS, соответственно, внутри файла Makefile порта. К примеру, мы можем обойтись без файла pkg-plist у приведённого выше порта oneko, добавив следующие строки в Makefile:
PLIST_FILES= bin/oneko \ man/man1/oneko.1.gz \ lib/X11/app-defaults/Oneko \ lib/X11/oneko/cat1.xpm \ lib/X11/oneko/cat2.xpm \ lib/X11/oneko/mouse.xpm
Использование |
Если порту требуется создать пустой каталог или он создает каталоги вне ${PREFIX} во время установки, обратитесь к разделу Очистка пустых каталогов для получения дополнительной информации. |
Поскольку PLIST_FILES= "@sample ${ETCDIR}/oneko.conf.sample" |
Позже мы увидим, как pkg-plist и PLIST_FILES могут использоваться для выполнения более сложных задач.
3.3. Создание файла с контрольной суммой
Просто введите команду make makesum. Правила утилиты make автоматически сгенерируют файл distinfo. Не пытайтесь создавать этот файл вручную.
3.4. Тестирование порта
Вы должны удостовериться, что правила построения порта выполняют именно то, что вы хотите, включая создание пакета для порта. Вот те важные вещи, которые вы должны проверить:
pkg-plist не содержит ничего сверх того, что устанавливается портом.
pkg-plist содержит абсолютно все, что устанавливается портом.
Порт может быть установлен с помощью указания цели
install. Это позволяет убедиться в правильной работе сценария установки.Порт может быть правильным образом удалён с помощью указания цели
deinstall. Это позволяет убедиться в правильной работе сценария удаления.Порт имеет доступ к сетевым ресурсам только во время фазы цели
fetch. Это важно для сборщиков пакетов, таких как ports-mgmt/poudriere.Убедитесь, что команду
make packageможно выполнить от имени обычного пользователя (то есть не отroot). Если это не работает, возможно, потребуется исправить программное обеспечение. См. такжеfakerootиuidfix.
make stagemake check-orphansmake packagemake installmake deinstallmake package(как пользователь)
Убедитесь, что на любом из этапов не выдается никаких предупреждений.
Тщательное автоматизированное тестирование можно выполнить с помощью ports-mgmt/poudriere из коллекции портов, дополнительную информацию см. в poudriere. Он поддерживает клетки, в которых можно протестировать все указанные выше шаги без воздействия на состояние основной системы.
3.5. Проверка вашего порта утилитой portlint
Будьте добры, пользуйтесь утилитой portlint для проверки того, что ваш порт соответствует нашим рекомендациям. Программа ports-mgmt/portlint является частью Коллекции Портов. В частности, вы можете захотеть проверить, правильно ли сформирован файл Makefile и соответствующим ли образом именован пакет.
Не следуйте слепо выводу |
3.6. Посылка нового порта
Перед посылкой нового порта прочитайте раздел о том, что можно и нельзя делать.
Когда вы наконец довольны своим первым портом, единственное, что осталось сделать, это включить его в основное дерево портов FreeBSD и осчастливить этим всех остальных.
Нам не нужны каталог work или пакет pkgname.txz, поэтому их можно удалить. |
Далее создайте файл patch(1). Предположим, что порт называется oneko и находится в категории games.
Добавьте все файлы с помощью git add ., затем просмотрите изменения с помощью git diff. Например:
% git add .
% git diff --stagedУбедитесь, что все необходимые файлы включены, затем зафиксируйте изменение в вашей локальной ветке и создайте патч с помощью git format-patch
% git commit
% git format-patch origin/mainПатч, созданный с помощью git format-patch, будет содержать идентификатор автора и адреса электронной почты, что упрощает применение разработчиками (с помощью git am) и правильное указание авторства.
Отправьте файл oneko.diff через форму отправки отчётов об ошибках. Укажите продукт "Ports & Packages", компонент "Individual Port(s)" и следуйте приведённым там инструкциям. Добавьте краткое описание программы в поле Description PR (например, сокращённую версию COMMENT) и не забудьте прикрепить файл oneko.diff.
Хорошее описание в заголовке сообщения о проблеме значительно облегчает работу коммиттеров портов. Для новых портов мы предпочитаем нечто вроде "[NEW PORT] категория/название_порта краткое описание порта". Следование этой схеме упрощает и ускоряет начало работы по добавлению нового порта. |
После отправки порта, пожалуйста, потерпите. Время, необходимое для включения нового порта во FreeBSD, может занимать от нескольких дней до нескольких месяцев. Здесь можно увидеть список ожидающих PR для портов.
Чтобы получить список открытых PR для портов, выберите Open и Ports & Packages в форме поиска, затем нажмите Search.
После ознакомления с новым портом мы ответим, если это необходимо, и добавим его в дерево. Имя отправителя также будет добавлено в список Дополнительных участников FreeBSD и другие файлы.
Глава 4. Медленное портирование
Итак, все оказалось не так уж и просто, и порт потребовал некоторых модификаций для того, чтобы заставить его работать. В этом разделе мы расскажем, шаг за шагом, как его модифицировать, чтобы он работал с нашей системой портов.
4.1. Как всё это работает
Во-первых, когда пользователь дает в своем каталоге с портом команду make, происходит целая череда событий. Во время чтения этого текста может оказаться полезным иметь файл bsd.port.mk открытым в другом окне, что сильно поможет его понять.
Но не волнуйтесь сильно, если вы не до конца понимаете, что делается в bsd.port.mk, не так уж много людей его понимает… :-)
Запускается цель
fetch. Цельfetchотвечает за то, что архив исходных текстов имеется в наличии локально в каталогеDISTDIR. Если цельfetchне может найти требуемые файлы в каталогеDISTDIR, то они будут искаться по указателю URLMASTER_SITES, который устанавливается в Makefile, а также на наших FTP зеркалах, куда мы по возможности помещаем дистрибутивные файлы для архива. Затем она попытается сгрузить указанный файл с помощьюFETCH, полагая, что запрашивающая машина имеет прямое подключение к Интернет. Если файл скачается удачно, то он будет помещен в каталогDISTDIRдля последующего использования и обработки.Выполняется цель
extract. Она ищет дистрибутивный файл порта (как правило, tar-архивgzip) в каталогеDISTDIRи распаковывает его во временный каталог, задаваемый переменнойWRKDIR(по умолчанию work).Выполняется цель
patch. Во-первых, применяются все патчи, заданные переменнойPATCHFILES. Во-вторых, если какие-либо файлы с патчами, носящие имена patch-*, имеются в подкаталогеPATCHDIR(по умолчанию это каталог files), то они применяются в этот момент в алфавитном порядке.Запускается цель
configure. Здесь может выполняться любая из многих различных вещей.Если он существует, запускается scripts/configure.
Если установлены
HAS_CONFIGUREилиGNU_CONFIGURE, запускается WRKSRC/configure.
Выполняется цель
build. Она отвечает за переход в собственный рабочий каталог порта (WRKSRC) и его построение.Выполняется цель
stage. Конечный набор построенных файлов помещается во временный каталог (STAGEDIR, смотрите Staging). Иерархия этого каталога отражает иерархию каталогов системы, в которую данный пакет будет устанавливаться.Выполняется цель
package. При этом создается пакет с использованием файлов из временного каталога, созданного во время выполнения целиstage, и файла pkg-plist порта.Выполняется цель
install. Это устанавливает пакет, созданный во время целиpackage, в хост-систему.
Выше перечислены стандартные действия. Кроме того, вы сами можете определить цели pre-что-то или post-что-то, или создать скрипты с такими именами в подкаталоге scripts, и они будут запущены до или после выполнения действий по умолчанию.
Например, если у вас есть цель post-extract, определённая в вашем файле Makefile и файл pre-build в подкаталоге scripts, то после выполнения обычных действий по распаковке, будет вызвана цель post-extract а скрипт pre-build будет выполнен перед запуском стандартных правил построения. Рекомендуется использовать цели из Makefile, если действия достаточно просты, потому что в дальнейшем будет проще определить, какие нестандартные действия требует порт.
Действия по умолчанию выполняются целями do-что-то из bsd.port.mk. Например, команды для распаковки порта находятся в цели do-extract. Если вам не хватает цели по умолчанию, вы можете ее исправить, переопределив цель do-something в вашем файле Makefile.
"Основные" цели (к примеру, |
Теперь, когда вы представляете, что происходит, когда пользователь набирает команду make install, давайте пройдемся через шаги, рекомендуемые для создания настоящего порта.
4.2. Получение исходного кода
Получите оригинальные исходные тексты (обычно) в виде упакованного tar-архива (foo.tar.gz или foo.tar.bz2) и скопируйте его в каталог DISTDIR. Всегда используйте исходные тексты основной ветки разработки везде, где это возможно.
Вам потребуется задать значение переменной MASTER_SITES так, чтобы оно указывало на местоположение оригинального tar-архива. В файле bsd.sites.mk вы найдёте краткие обозначения для большинства популярных сайтов. Пожалуйста, используйте эти сайты-и соответствующие определения-везде, где это возможно, чтобы избежать проблем повторения одной и той же информации в базе источников. Так как эти сайты со временем меняются, для всех причастных поддержка становится настоящим кошмаром. Для подробностей смотрите MASTER_SITES.
Если вы не можете найти FTP/HTTP сайт с хорошим подключением к сети, или находите только сайты, которые имеют раздражающе нестандартные форматы, то можете захотеть поместить копию на надежный сервер FTP или HTTP, который вам доступен (например, ваша домашняя страница).
Если вы не можете найти доступного и надёжного места для помещения дистрибутивного файла, то мы сами сможем разместить его на сервере ftp.FreeBSD.org; однако это наименее рекомендуемое решение. Дистрибутивный файл должен быть помещён в каталог ~/public_distfiles/ одного из пользователей машины freefall. Попросите того, кто коммиттил ваш порт, сделать это. Этот человек также задаст переменной MASTER_SITES значение MASTER_SITE_LOCAL, а в переменной MASTER_SITE_SUBDIR укажет логин кластера FreeBSD.
Если дистрибутивные файлы вашего порта постоянно меняются по неизвестным причинам без изменения версий со стороны автора, остаётся только поместить дистрибутив на вашу домашнюю Web-страницу и указать её первой в списке MASTER_SITES. Если можете, попытайтесь договориться с автором порта об этом; это действительно помогает в достижении некоторого управления исходным кодом. Размещение собственной версии поможет избежать появления ошибок у пользователей типа checksum mismatch, а также уменьшит нагрузку на людей, сопровождающих наш FTP-сервер. Также, если у порта имеется только один основной сервер, то рекомендуется поместить архивную копию на свой сайт и указать его в списке MASTER_SITES вторым.
Если вашему порту требуются дополнительные патчи, доступные в Интернет, скачайте также и их, поместив в каталог DISTDIR. Не волнуйтесь, если они находятся не на том же сайте, откуда взят дистрибутивный архив, мы умеем обрабатывать такие ситуации (смотрите описание PATCHFILES ниже).
4.3. Модификация порта
Распакуйте копию дистрибутивного файла в отдельный каталог и внесите изменения, которые необходимы для того, чтобы порт компилировался нормально в текущей версии FreeBSD. Тщательно отслеживайте все, что вы делаете, этот процесс вам предстоит автоматизировать. Все, включая удаление, добавление или модификацию в файлах должны будут выполняться автоматически с помощью скриптов или файлов патчей, когда вы завершите работу над портом.
Если вашему порту во время компиляции, установки и настройки требуется довольно много взаимодействовать с пользователем, то посмотрите на один из классических скриптов Configure Лэрри Уолла (Larry Wall) и сделайте сами что-либо подобное. Предназначение новой коллекции портов - это сделать каждое приложение в стиле "plug-and-play" настолько, насколько это вообще возможно для конечного пользователя при минимальном использовании дискового пространства.
Если явно не указано обратное, то патчи, скрипты и другие файлы, которые вы создали и предоставили для Коллекции Портов FreeBSD, неявно подпадают под стандартные условия лицензии BSD. |
4.4. Работа с патчами
Файлы, которые добавлялись или изменялись в процессе создания порта, могут быть выявлены программой diff(1), а результат работы этой программы может быть в дальнейшем передан программе patch(1). Такое действие с обычным файлом подразумевает сохранение копии файла с первоначальным содержимым перед внесением каких-либо изменений.
% cp file file.origПатчи сохраняются в виде файлов с именем patch-*, где * обозначает путь к файлу, к которому применяется патч, такой как patch-Imakefile или patch-src-config.h.
Используйте |
4.4.1. Общие правила для установки патчей
Файлы патчей хранятся в PATCHDIR, обычно это files/, откуда они будут автоматически применены. Все исправления должны быть относительны к WRKSRC. Обычно WRKSRC является подкаталогом WRKDIR, каталога, в котором распаковывается distfile. Используйте make -V WRKSRC для просмотра фактического пути. Имена файлов патчей должны соответствовать следующим правилам:
Избегайте ситуации, когда несколько патчей изменяют один и тот же файл. Например, если и patch-foobar.c, и patch-foobar.c2 вносят изменения в ${WRKSRC}/foobar.c, это делает их хрупкими и затрудняет отладку.
При создании имен для файлов исправлений заменяйте каждое подчеркивание (
_) на два подчеркивания (__) и каждый слэш (/) на одно подчеркивание (_). Например, чтобы исправить файл с именем src/freeglut_joystick.c, назовите соответствующий исправление patch-src_freeglut__joystick.c. Не называйте исправления как patch-aa или patch-ab. Всегда используйте путь и имя файла в названиях исправлений. Использованиеmake makepatchавтоматически генерирует правильные имена.Патч может изменять несколько файлов, если изменения связаны между собой и патч назван соответствующим образом. Например, patch-add-missing-stdlib.h.
Используйте только символы
[-+._a-zA-Z0-9]для именования патчей. В частности, не используйте::как разделитель путей, вместо этого используйте_.
Минимизируйте количество нефункциональных изменений пробелов в патчах. В мире открытого исходного кода распространена практика, когда проекты используют обширные части кодовой базы, но следуют разным правилам стиля и отступов. При переносе работоспособного функционала из одного проекта для исправления аналогичных участков в другом будьте внимательны: итоговый патч может быть переполнен нефункциональными изменениями. Это не только увеличивает размер репозитория портов, но и затрудняет понимание того, что именно вызвало проблему и какие изменения были внесены.
Если файл необходимо удалить, сделайте это в цели post-extract, а не как часть исправления.
4.4.2. Ручное создание патчей
Ручное создание патчей обычно не требуется. Предпочтительным методом является автоматическая генерация патчей, как описано ранее в этом разделе. Однако иногда может потребоваться ручное исправление. |
Патчи сохраняются в файлы с именами patch-*, где * указывает на путь к файлу, который патчится, например patch-Imakefile или patch-src-config.h. Патчи с именами файлов, не начинающимися с patch-, не будут применены автоматически.
После изменения файла используется diff(1) для записи различий между оригинальной и изменённой версиями. -u заставляет diff(1) выводить различия файлов в "унифицированном" формате (unified diffs), которые являются предпочтительным форматом.
% diff -u file.orig file > patch-pathname-fileДля порождении патчей для новых добавляемых файлов используется параметр -N, который заставляет diff(1) трактовать несуществующие прежде файлы как если бы они существовали, но имели пустое содержимое:
% diff -u -N newfile.orig newfile > patch-pathname-newfileИспользование опции рекурсии (-r) в diff(1) для создания патчей допустимо, но пожалуйста, проверяйте полученные патчи, чтобы убедиться в отсутствии ненужных данных. В частности, различия между резервными файлами, Makefile, когда порт использует Imake или GNU configure, и т.д., являются избыточными и должны быть удалены. Если потребовалось отредактировать configure.in и запустить autoconf для перегенерации configure, не включайте различия в configure (его объем часто достигает нескольких тысяч строк!). Вместо этого определите USES=autoreconf и возьмите различия для configure.in.
4.4.3. Простая автоматическая замена
Простые замены могут быть выполнены напрямую из Makefile порта, используя режим редактирования на месте утилиты sed(1). Это полезно, когда изменения используют значение переменной:
post-patch:
@${REINPLACE_CMD} -e 's|/usr/local|${PREFIX}|g' ${WRKSRC}/MakefileДовольно часто портируемое программное обеспечение использует соглашение CR/LF в исходных файлах. Это может вызвать проблемы с дальнейшим наложением патчей, предупреждениями компилятора или выполнением скриптов (например, /bin/sh^M не найден). Для быстрого преобразования всех файлов из CR/LF в просто LF добавьте следующую запись в Makefile порта:
USES= dos2unix
Список конкретных файлов для преобразования может быть указан:
USES= dos2unix DOS2UNIX_FILES= util.c util.h
Используйте DOS2UNIX_REGEX для преобразования группы файлов во вложенных каталогах. Его аргумент — это совместимое с find(1) регулярное выражение. Подробнее о формате можно узнать в re_format(7). Эта опция полезна для преобразования всех файлов с заданным расширением. Например, преобразовать все исходные файлы кода, оставив двоичные файлы без изменений:
USES= dos2unix DOS2UNIX_REGEX= .*\.([ch]|cpp)
Аналогичной опцией является DOS2UNIX_GLOB, которая запускает find для каждого указанного в ней элемента.
USES= dos2unix DOS2UNIX_GLOB= *.c *.cpp *.h
Базовый каталог для преобразования может быть установлен. Это полезно, когда имеется несколько distfiles и в нескольких из них содержатся файлы, требующие преобразования окончаний строк.
USES= dos2unix
DOS2UNIX_WRKSRC= ${WRKDIR}4.4.4. Внесение исправлений при условии
Некоторые порты требуют патчей, которые применяются только для определённых версий FreeBSD или при включении или отключении конкретной опции. Условные патчи указываются путём размещения полных путей к файлам патчей в EXTRA_PATCHES. Имена файлов условных патчей обычно начинаются с extra-, хотя это и не обязательно. Однако их имена не должны начинаться с patch-. Если это произойдёт, они будут применены безусловно фреймворком, что нежелательно для условных патчей.
.include <bsd.port.options.mk>
# Patch in the iconv const qualifier before this
.if ${OPSYS} == FreeBSD && ${OSVERSION} < 1100069
EXTRA_PATCHES= ${PATCHDIR}/extra-patch-fbsd10
.endif
.include <bsd.port.mk>Когда для опции требуется патч, используйте opt_EXTRA_PATCHES и opt_EXTRA_PATCHES_OFF, чтобы сделать исправление зависимым от опции opt. Дополнительные сведения см. в Generic Variables Replacement.
OPTIONS_DEFINE= FOO BAR
FOO_EXTRA_PATCHES= ${PATCHDIR}/extra-patch-foo
BAR_EXTRA_PATCHES_OFF= ${PATCHDIR}/extra-patch-bar.c \
${PATCHDIR}/extra-patch-bar.hEXTRA_PATCHES с директориейИногда для функции требуется множество патчей, в таком случае можно указать EXTRA_PATCHES на директорию, и все файлы с именем patch-* в ней будут применены автоматически.
Создайте подкаталог в ${PATCHDIR} и переместите в него патчи. Например:
% ls -l files/foo-patches
-rw-r--r-- 1 root wheel 350 Jan 16 01:27 patch-Makefile.in
-rw-r--r-- 1 root wheel 3084 Jan 18 15:37 patch-configure.acЗатем добавьте это в Makefile:
OPTIONS_DEFINE= FOO
FOO_EXTRA_PATCHES= ${PATCHDIR}/foo-patchesЗатем фреймворк использует все файлы с именем patch-* в этом каталоге.
4.5. Конфигурирование
Поместите все дополнительные команды, требуемые для настройки, в ваш скрипт configure и сохраните его в подкаталоге scripts. Как отмечено выше, вы можете сделать это целями в файле Makefile и/или скриптами с именами pre-configure или post-configure.
4.6. Обработка пользовательского ввода
Если для построения, конфигурации или установки вашего порта требуется некоторый ввод со стороны пользователя, то вы должны задать переменную IS_INTERACTIVE в вашем файле Makefile. В случае "ночного построения" это позволит пропустить ваш порт, если пользователь в своем окружении задал переменную BATCH (и если пользователь установил переменную INTERACTIVE, то будут строиться только порты, которые требуют взаимодействия с пользователем. Это сэкономит значительное количество времени на части машин, которые постоянно строят порты (смотрите ниже).
При наличии разумных ответов на задаваемые вопросы, подходящих по умолчанию, также рекомендуется проверять переменную PACKAGE_BUILDING и выключать интерактивный скрипт, если он есть. Это позволит нам строить пакеты для помещения на компакт-диски и FTP-серверы.
Глава 5. Настройка Makefile
Настройка Makefile довольно проста, и мы снова рекомендуем изучить существующие примеры перед началом. Также в этом руководстве есть пример Makefile, поэтому ознакомьтесь с ним и, пожалуйста, соблюдайте порядок переменных и разделов в этом шаблоне, чтобы порт был удобнее для чтения другими.
Рассмотрите эти проблемы последовательно при разработке нового Makefile:
5.1. Оригинальный исходный код
Находится ли он в DISTDIR в виде стандартного архива gzip с именем вроде foozolix-1.2.tar.gz? Если да, переходите к следующему шагу. Если нет, возможно, для формата имени файла дистрибутива потребуется переопределить одну или несколько переменных: DISTVERSION, DISTNAME, EXTRACT_CMD, EXTRACT_BEFORE_ARGS, EXTRACT_AFTER_ARGS, EXTRACT_SUFX или DISTFILES.
В худшем случае создайте пользовательскую цель do-extract, чтобы переопределить стандартную. Это редко, если вообще когда-либо, необходимо.
5.2. Именование
Первая часть Makefile порта указывает его название, описывает номер версии и помещает его в соответствующую категорию.
5.2.1. PORTNAME
Установите PORTNAME как базовое имя программы. Оно используется в качестве основы для пакета FreeBSD и для DISTNAME.
Название пакета должно быть уникальным во всём дереве портов. Убедитесь, что |
5.2.2. Версии, DISTVERSION или PORTVERSION
Установите DISTVERSION в номер версии программы.
PORTVERSION — это версия, используемая для пакета FreeBSD. Она будет автоматически вычислена из DISTVERSION в соответствии со схемой версионирования пакетов FreeBSD. Если версия содержит буквы, может потребоваться задать PORTVERSION вместо DISTVERSION.
Только одна из переменных |
Время от времени некоторые программы используют схему версионирования, которая несовместима с тем, как DISTVERSION преобразуется в PORTVERSION.
При обновлении порта можно использовать аргумент |
pkg version -t принимает две версии в качестве аргументов и возвращает <, = или >, если первая версия меньше, равна или больше второй версии соответственно.
% pkg version -t 1.2 1.3
< (1)
% pkg version -t 1.2 1.2
= (2)
% pkg version -t 1.2 1.2.0
= (3)
% pkg version -t 1.2 1.2.p1
> (4)
% pkg version -t 1.2.a1 1.2.b1
< (5)
% pkg version -t 1.2 1.2p1
< (6)| 1 | 1.2 идёт перед 1.3. |
| 2 | 1.2 и 1.2 равны, так как имеют одинаковую версию. |
| 3 | 1.2 и 1.2.0 равны, так как ноль ничего не значит. |
| 4 | 1.2 идёт после 1.2.p1, так как .p1 означает «pre-release 1» (предрелизная версия 1). |
| 5 | 1.2.a1 предшествует 1.2.b1, представьте "alpha" и "beta", где a идёт перед b. |
| 6 | 1.2 находится перед 1.2p1, так же как 2p1 (читается как "2, уровень исправления 1") — это версия, следующая после любой 2.X, но перед 3. |
| DISTVERSION | .PORTVERSION |
|---|---|
0.7.1d | 0.7.1.d |
10Alpha3 | 10.a3 |
3Beta7-pre2 | 3.b7.p2 |
8:f_17 | 8f.17 |
DISTVERSIONЕсли версия содержит только числа, разделённые точками, тире или подчёркиваниями, используйте DISTVERSION.
PORTNAME= nekoto DISTVERSION= 1.2-4
Это сгенерирует PORTVERSION равный 1.2.4.
DISTVERSION когда версия начинается с буквы или префиксаКогда версия начинается или заканчивается буквой, или префиксом, или суффиксом, которые не являются частью версии, используйте DISTVERSIONPREFIX, DISTVERSION и DISTVERSIONSUFFIX.
Если версия v1.2-4:
PORTNAME= nekoto DISTVERSIONPREFIX= v DISTVERSION= 1_2_4
Некоторые проекты, использующие GitHub, могут включать своё название в версии. Например, версия может выглядеть как nekoto-1.2-4:
PORTNAME= nekoto DISTVERSIONPREFIX= nekoto- DISTVERSION= 1.2_4
Эти проекты также иногда используют строку в конце версии, например, 1.2-4_RELEASE:
PORTNAME= nekoto DISTVERSION= 1.2-4 DISTVERSIONSUFFIX= _RELEASE
Или они делают и то, и другое, например, nekoto-1.2-4_RELEASE:
PORTNAME= nekoto DISTVERSIONPREFIX= nekoto- DISTVERSION= 1.2-4 DISTVERSIONSUFFIX= _RELEASE
DISTVERSIONPREFIX и DISTVERSIONSUFFIX не будут использоваться при формировании PORTVERSION, а только в DISTNAME.
Все сгенерируют PORTVERSION равный 1.2.4.
DISTVERSION, когда версия содержит буквы, означающие "alpha", "beta" или "pre-release"Если версия содержит числа, разделённые точками, тире или подчёркиваниями, а буквы используются для обозначения "альфа", "бета" или "предварительной версии" (то есть до версии без букв), используйте DISTVERSION.
PORTNAME= nekoto DISTVERSION= 1.2-pre4
PORTNAME= nekoto DISTVERSION= 1.2p4
Оба варианта создадут PORTVERSION равную 1.2.p4, что предшествует версии 1.2. Для проверки этого факта можно использовать pkg-version(8):
% pkg version -t 1.2.p4 1.2
<DISTVERSION, если версия содержит буквы, означающие "уровень патча"Если версия содержит буквы, которые не означают "alpha", "beta" или "pre", а скорее указывают на "уровень исправления" и следуют после версии без букв, используйте PORTVERSION.
PORTNAME= nekoto PORTVERSION= 1.2p4
В данном случае использование DISTVERSION невозможно, так как это приведёт к генерации версии 1.2.p4, которая будет считаться более ранней, чем 1.2, а не более поздней. pkg-version(8) подтвердит это:
% pkg version -t 1.2 1.2.p4
> (1)
% pkg version -t 1.2 1.2p4
< (2)| 1 | 1.2 идёт после 1.2.p4, что в данном случае неверно. |
| 2 | 1.2 находится перед 1.2p4, что и требовалось. |
Для более сложных примеров настройки PORTVERSION, когда версия программного обеспечения действительно несовместима с FreeBSD, или DISTNAME, когда файл дистрибутива не содержит саму версию, см. DISTNAME.
5.2.3. PORTREVISION и PORTEPOCH
5.2.3.1. PORTREVISION
PORTREVISION — это монотонно возрастающее значение, которое сбрасывается в 0 при каждом увеличении DISTVERSION, обычно при каждом новом официальном выпуске от поставщика. Если PORTREVISION не равен нулю, его значение добавляется к имени пакета. Изменения PORTREVISION используются автоматизированными инструментами, такими как pkg-version(8), для определения доступности нового пакета.
PORTREVISION должен быть увеличен каждый раз, когда в порт вносятся изменения, которые так или иначе влияют на сгенерированный пакет. Это включает изменения, затрагивающие только пакеты, собранные с нестандартными опциями.
Примеры случаев, когда необходимо увеличить PORTREVISION:
Добавление исправлений для устранения уязвимостей безопасности, ошибок или для добавления новой функциональности в порт.
Изменения в Makefile порта для включения или отключения параметров сборки в пакете.
Изменения в списке файлов пакета или в поведении во время установки. Например, изменение скрипта, который генерирует начальные данные для пакета, такие как ключи хоста ssh(1).
Увеличение версии зависимости порта от общей библиотеки (в данном случае, попытка установить старый пакет после установки более новой версии зависимости завершится неудачей, так как будет искаться старая версия libfoo.x вместо libfoo.(x+1)).
Тихие изменения в дистрибутивном файле порта, которые имеют значительные функциональные отличия. Например, изменения в дистрибутивном файле, требующие корректировки файла distinfo без соответствующего изменения
DISTVERSION, когда сравнениеdiff -ruстарой и новой версий показывает нетривиальные изменения в коде.Изменения в
MAINTAINER.
Примеры изменений, которые не требуют увеличения PORTREVISION:
Стилевые изменения в каркасе портов без функциональных изменений в итоговом пакете.
Изменения в
MASTER_SITESили другие функциональные изменения порта, которые не влияют на итоговый пакет.Тривиальные исправления в дистрибутивном файле, такие как исправление опечаток, которые не настолько важны, чтобы пользователи пакета были вынуждены тратить время на обновление.
Исправления сборки, которые позволяют пакету компилироваться там, где ранее это не удавалось. При условии, что изменения не вносят функциональных изменений на других платформах, где порт ранее собирался. Поскольку
PORTREVISIONотражает содержимое пакета, если пакет ранее не мог быть собран, то нет необходимости увеличиватьPORTREVISIONдля обозначения изменений.
Эмпирическое правило заключается в том, чтобы решить, является ли изменение, внесённое в порт, чем-то, что принесёт пользу некоторым пользователям. Будь то улучшение, исправление или просто факт, что новый пакет вообще будет работать. Затем необходимо сопоставить это с тем, что всем, кто регулярно обновляет своё дерево портов, придётся выполнить обновление. Если ответ положительный, необходимо увеличить PORTREVISION.
Пользователи бинарных пакетов никогда не увидят обновления, если |
5.2.3.2. PORTEPOCH
Время от времени разработчики программного обеспечения или сопровождающие портов FreeBSD совершают ошибку и выпускают версию своего ПО, которая фактически имеет меньший номер по сравнению с предыдущей. Примером может служить переход с foo-20000801 на foo-1.0 (первая версия будет ошибочно считаться более новой, поскольку число 20000801 больше, чем 1.0).
Результаты сравнения номеров версий не всегда очевидны. Команда Символ |
В таких ситуациях необходимо увеличить PORTEPOCH. Если PORTEPOCH не равен нулю, он добавляется к имени пакета, как описано в разделе 0 выше. PORTEPOCH никогда не должен уменьшаться или сбрасываться до нуля, потому что это приведёт к ошибке при сравнении с пакетом из более ранней эпохи. Например, пакет не будет обнаружен как устаревший. Новый номер версии, 1.0,1 в приведённом выше примере, всё ещё численно меньше предыдущей версии, 20000801, но суффикс ,1 обрабатывается автоматизированными инструментами особым образом и считается большим, чем подразумеваемый суффикс ,0 у предыдущего пакета.
Неправильное удаление или сброс PORTEPOCH приводит к бесконечным проблемам. Если приведённое выше объяснение недостаточно ясно, обратитесь к Список рассылки, посвящённый Портам FreeBSD.
Ожидается, что PORTEPOCH не будет использоваться для большинства портов, и что разумное использование DISTVERSION или аккуратное применение PORTVERSION часто может предотвратить необходимость его использования, если будущий выпуск программного обеспечения изменит структуру версий. Однако разработчикам портов FreeBSD следует быть осторожными, когда вендор выпускает релиз без официального номера версии — например, релиз в виде "снимка" кода. Возникает соблазн обозначить такой релиз датой выпуска, что вызовет проблемы, как в примере выше, когда будет сделан новый "официальный" релиз.
Например, если снимок выпущен на дату 20000917, а предыдущая версия программного обеспечения была 1.2, не следует использовать 20000917 для DISTVERSION. Правильным будет указать DISTVERSION как 1.2.20000917 или подобное, чтобы следующая версия, например 1.3, оставалась численно большей.
5.2.3.3. Пример использования PORTREVISION и PORTEPOCH
Порт gtkmumble версии 0.10 добавлен в коллекцию портов:
PORTNAME= gtkmumble DISTVERSION= 0.10
PKGNAME становится gtkmumble-0.10.
Обнаружена уязвимость в безопасности, требующая локального исправления FreeBSD. PORTREVISION соответствующим образом увеличивается.
PORTNAME= gtkmumble DISTVERSION= 0.10 PORTREVISION= 1
PKGNAME принимает значение gtkmumble-0.10_1
Выпущена новая версия от поставщика под номером 0.2 (оказывается, автор изначально подразумевал, что 0.10 на самом деле означает 0.1.0, а не "то, что идет после 0.9" — увы, теперь уже поздно). Поскольку новая минорная версия 2 численно меньше предыдущей версии 10, необходимо увеличить PORTEPOCH, чтобы вручную заставить систему распознавать новый пакет как "более новый". Так как это новый релиз кода от поставщика, PORTREVISION сбрасывается до 0 (или удаляется из Makefile).
PORTNAME= gtkmumble DISTVERSION= 0.2 PORTEPOCH= 1
PKGNAME становится gtkmumble-0.2,1
Следующий выпуск — 0.3. Поскольку PORTEPOCH никогда не уменьшается, переменные версий теперь выглядят так:
PORTNAME= gtkmumble DISTVERSION= 0.3 PORTEPOCH= 1
PKGNAME принимает значение gtkmumble-0.3,1
Если бы |
5.2.4. PKGNAMEPREFIX и PKGNAMESUFFIX
Две необязательные переменные, PKGNAMEPREFIX и PKGNAMESUFFIX, объединяются с PORTNAME и PORTVERSION для формирования PKGNAME в виде ${PKGNAMEPREFIX}${PORTNAME}${PKGNAMESUFFIX}-${PORTVERSION}. Убедитесь, что это соответствует нашим рекомендациям по именованию пакетов. В частности, использование дефиса (-) в PORTVERSION не допускается. Кроме того, если имя пакета содержит часть language- или -compiled.specifics (см. ниже), используйте PKGNAMEPREFIX и PKGNAMESUFFIX соответственно. Не включайте их в PORTNAME.
5.2.5. Соглашения о наименовании пакетов
Вот соглашения, которым следует придерживаться при наименовании пакетов. Это сделано для того, чтобы каталог пакетов было легко просматривать, поскольку там уже тысячи пакетов, и пользователи могут отказаться от их использования, если это будет напрягать их глаза!
Имена пакетов имеют формат language_region-name-compiled.specifics-version.numbers.
Имя пакета определяется как ${PKGNAMEPREFIX}${PORTNAME}${PKGNAMESUFFIX}-${PORTVERSION}. Убедитесь, что переменные заданы в соответствии с этим форматом.
- language_region-
FreeBSD стремится поддерживать родной язык своих пользователей. Часть language- представляет собой двухбуквенное сокращение естественного языка, определённое стандартом ISO-639, когда порт относится к определённому языку. Примерами являются
jaдля японского,ruдля русского,viдля вьетнамского,zhдля китайского,koдля корейского иdeдля немецкого.Если порт относится к определённому региону в языковой зоне, добавьте также двухбуквенный код страны. Например,
en_USдля американского английского иfr_CHдля швейцарского французского.Часть language- задается в
PKGNAMEPREFIX.
- name
Убедитесь, что название порта и его версия четко разделены и указаны в
PORTNAMEиDISTVERSION. Единственная причина, по которойPORTNAMEможет содержать часть версии, — это если вышестоящее распространяемое ПО действительно так названо, как в портах textproc/libxml2 или japanese/kinput2-freewnn. В противном случаеPORTNAMEне может содержать информацию о версии. Довольно нормально, когда несколько портов имеют одинаковыйPORTNAME, как это делают порты www/apache*; в таком случае разные версии (и разные записи в индексе) различаются значениямиPKGNAMEPREFIXиPKGNAMESUFFIX.Существует традиция называть модули
Perl 5, добавляя префиксp5-и заменя разделитель в виде двойного двоеточия на дефис. Например, модульData::Dumperстановитсяp5-Data-Dumper.
- -compiled.specifics
Если порт может быть собран с различными жестко заданными значениями по умолчанию (обычно это часть имени каталога в семействе портов), часть -compiled.specifics указывает скомпилированные значения по умолчанию. Дефис является необязательным. Примерами могут служить размер бумаги и единицы измерения шрифтов.
Часть -compiled.specifics задаётся в
PKGNAMESUFFIX.
- -version.numbers
Строка версии следует после тире (
-) и представляет собой разделённый точками список целых чисел и строчных букв латинского алфавита. В частности, не допускается использование дополнительных тире внутри строки версии. Единственное исключение — строкаpl(означающая "уровень исправления"), которую можно использовать только в случае отсутствия у программного обеспечения номеров основной и дополнительной версий. Если в версии программного обеспечения встречаются строки типа "alpha", "beta", "rc" или "pre", следует взять первую букву и поместить её сразу после точки. Если после таких названий строка версии продолжается, числа следуют за буквой без дополнительной точки между ними (например,1.0b2).Идея заключается в упрощении сортировки портов за счёт анализа строки версии. В частности, необходимо убедиться, что компоненты номера версии всегда разделены точкой, а если дата является частью строки, использовать формат
dyyyy.mm.dd, а неdd.mm.yyyyили не соответствующий стандарту Y2K форматyy.mm.dd. Важно добавлять перед версией букву, в данном случаеd(от слова "дата"), на случай, если будет выпущена версия с фактическим номером, который численно окажется меньшеyyyy.
Название пакета должно быть уникальным среди всех портов в дереве. Убедитесь, что порт с таким же |
Вот несколько (реальных) примеров преобразования названия, указанного авторами программного обеспечения, в подходящее имя пакета. В каждой строке указана только одна из переменных DISTVERSION или PORTVERSION, в зависимости от того, какая используется в Makefile порта:
| Имя дистрибутива | PKGNAMEPREFIX | PORTNAME | PKGNAMESUFFIX | DISTVERSION | .PORTVERSION | Причина или комментарий |
|---|---|---|---|---|---|---|
mule-2.2.2 | (пусто) | mule | (пусто) | 2.2.2 | Никаких изменений не требуется | |
mule-1.0.1 | (пусто) | mule | 1 | 1.0.1 | Это версия 1 mule, а версия 2 уже существует | |
EmiClock-1.0.2 | (пусто) | emiclock | (пусто) | 1.0.2 | Нет имен в верхнем регистре для отдельных программ | |
rdist-1.3alpha | (пусто) | rdist | (пусто) | 1.3alpha | Версия будет | |
es-0.9-beta1 | (пусто) | es | (пусто) | 0.9-beta1 | Версия будет | |
mailman-2.0rc3 | (пусто) | mailman | (пусто) | 2.0rc3 | Версия будет | |
v3.3beta021.src | (пусто) | tiff | (пусто) | 3.3 | Что это вообще было? | |
tvtwm | (пусто) | tvtwm | (пусто) | p11 | Нет версии в имени файла, используйте то, что указано в исходном коде | |
piewm | (пусто) | piewm | (пусто) | 1.0 | Нет версии в имени файла, используйте то, что указано в исходном коде | |
xvgr-2.10pl1 | (пусто) | xvgr | (пусто) | 2.10.pl1 | В таком случае, | |
gawk-2.15.6 | ja- | gawk | (пусто) | 2.15.6 | Японская языковая версия | |
psutils-1.13 | (пусто) | psutils | -letter | 1.13 | Размер бумаги жестко задан во время сборки пакета | |
pkfonts | (пусто) | pkfonts | 300 | 1.0 | Пакет для шрифтов с разрешением 300dpi |
Если в исходном источнике полностью отсутствует информация о версии и маловероятно, что автор когда-либо выпустит новую версию, просто укажите строку версии как 1.0 (как в примере с piewm выше). В противном случае, спросите автора или используйте дату выпуска исходного файла в формате dyyyy.mm.dd или dyyyymmdd в качестве версии.
Используйте любую букву. Здесь |
5.3. Категоризация
5.3.1. CATEGORIES
При создании пакета он помещается в /usr/ports/packages/All, и ссылки на него создаются в одной или нескольких поддиректориях /usr/ports/packages. Имена этих поддиректорий задаются переменной CATEGORIES. Это предназначено для облегчения поиска пакетов пользователем при просмотре большого количества пакетов на FTP-сайте или CDROM. Пожалуйста, ознакомьтесь с текущим списком категорий и выберите подходящие для данного порта.
Этот список также определяет, где в дереве портов будет размещён порт. Если здесь указано несколько категорий, файлы порта должны быть помещены в подкаталог с названием первой категории. Дополнительные сведения о выборе подходящих категорий см. в ниже.
5.3.2. Текущий список категорий
Вот текущий список категорий портов. Категории, помеченные звёздочкой (*), являются виртуальными — они не имеют соответствующего подкаталога в дереве портов. Они используются только как вторичные категории и исключительно для целей поиска.
Для невиртуальных категорий в |
| Категория | Описание | Заметки |
|---|---|---|
accessibility | Порты для помощи пользователям с ограниченными возможностями. | |
afterstep | Порты для поддержки оконного менеджера AfterStep. | |
arabic | Поддержка арабского языка. | |
archivers | Инструменты для архивирования. | |
astro | Астрономические порты. | |
audio | Поддержка звука. | |
benchmarks | Утилиты для тестирования производительности. | |
biology | Программное обеспечение, связанное с биологией. | |
cad | Компьютерные средства автоматизированного проектирования. | |
chinese | Поддержка китайского языка. | |
comms | Программное обеспечение для связи. | В основном программное обеспечение для работы с последовательным портом. |
converters | Преобразователи символьных кодировок. | |
databases | Базы данных. | |
deskutils | Вещи, которые раньше находились на рабочем столе до изобретения компьютеров. | |
devel | Средства разработки. | Не размещайте библиотеки здесь только потому, что они являются библиотеками. Они не должны быть в этой категории, если только они действительно не подходят никуда больше. |
dns | Программное обеспечение, связанное с DNS. | |
docs | Мета-порты для документации FreeBSD. | |
editors | Общие редакторы. | Специализированные редакторы помещаются в раздел соответствующих инструментов. Например, редактор математических формул будет помещён в math, а editors будет для него второй категорией. |
education | Программное обеспечение для образования. | Это включает приложения, утилиты или игры, разработанные в первую очередь или в значительной степени для помощи пользователю в изучении конкретной темы или обучении в целом. Также сюда входят приложения для создания курсов, приложения для предоставления курсов и приложения для управления классом или школой |
elisp | Порты Emacs-lisp. | |
emulators | Эмуляторы других операционных систем. | Терминальные эмуляторы не относятся сюда. Основанные на X идут в x11, а текстовые — либо в comms, либо в misc, в зависимости от конкретной функциональности. |
enlightenment | Порты, связанные с оконным менеджером Enlightenment. | |
filesystems | Файловые системы и связанные утилиты. | |
finance | Монетарные, финансовые и связанные с ними приложения. | |
french | Поддержка французского языка. | |
ftp | Клиентские и серверные утилиты FTP. | Если порт поддерживает как FTP, так и HTTP, поместите его в ftp с дополнительной категорией www. |
games | Игры. | |
география | Программное обеспечение, связанное с географией. | |
german | Поддержка немецкого языка. | |
gnome | Порты из проекта GNOME. | |
gnustep | Программное обеспечение, связанное со средой рабочего стола GNUstep. | |
graphics | Графические утилиты. | |
hamradio | Программное обеспечение для радиолюбителей. | |
haskell | Программное обеспечение, связанное с языком Haskell. | |
hebrew | Поддержка иврита. | |
hungarian | Венгерская языковая поддержка. | |
irc | Утилиты Internet Relay Chat. | |
japanese | Поддержка японского языка. | |
java | Программное обеспечение, связанное с языком Java™. | Категория java не должна быть единственной для порта. За исключением портов, непосредственно связанных с языком Java, разработчикам также рекомендуется не использовать java в качестве основной категории для порта. |
kde | Порты проекта KDE (общие). | |
kde-приложения | Приложения от проекта KDE. | |
kde-frameworks | Дополнительные библиотеки от проекта KDE для программирования с использованием Qt. | |
kde-plasma | Рабочий стол от проекта KDE. | |
kld | Загружаемые модули ядра. | |
korean | Поддержка корейского языка. | |
lang | Языки программирования. | |
linux | Приложения и вспомогательные утилиты Linux. | |
lisp | Программное обеспечение, связанное с языком Lisp. | |
Почтовое программное обеспечение. | ||
mate | Порты, связанные с окружением рабочего стола MATE, форком GNOME 2. | |
math | Численные расчеты и другие математические утилиты. | |
mbone | Приложения MBone. | |
misc | Различные утилиты | Вещи, которые не подходят никуда больше. По возможности, попытайтесь найти для порта категорию лучше, чем |
multimedia | Мультимедийное программное обеспечение. | |
net | Различное сетевое программное обеспечение. | |
net-im | Программное обеспечение для обмена мгновенными сообщениями. | |
net-mgmt | Программное обеспечение для управления сетями. | |
net-p2p | Одноранговые сетевые приложения. | |
сеть-vpn | Виртуальные частные сети. | |
news | Программное обеспечение для USENET-новостей. | |
parallel | Приложения, работающие с параллелизмом в вычислениях. | |
pear | Порты, связанные с PHP-фреймворком Pear. | |
perl5 | Порты, требующие Perl версии 5 для работы. | |
plan9 | Различные программы с Plan9. | |
polish | Поддержка польского языка. | |
ports-mgmt | Порты для управления, установки и разработки портов и пакетов FreeBSD. | |
portuguese | Поддержка португальского языка. | |
Программное обеспечение для печати. | Инструменты для настольных издательских систем (превьюеры и т. д.) также относятся сюда. | |
python | Программное обеспечение, связанное с языком Python. | |
ruby | Программное обеспечение, связанное с языком Ruby. | |
rubygems | Порты пакетов RubyGems. | |
russian | Поддержка русского языка. | |
scheme | Программное обеспечение, связанное с языком Scheme. | |
science | Научные порты, которые не входят в другие категории, такие как astro, biology и math. | |
security | Средства обеспечения безопасности. | |
shells | Командные оболочки. | |
spanish | Поддержка испанского языка. | |
sysutils | Системные утилиты. | |
tcl | Порты, использующие Tcl для запуска. | |
textproc | Средства обработки текста. | Он не включает инструменты для настольных издательских систем, которые помещаются в print. |
tk | Порты, использующие Tk для работы. | |
ukrainian | Поддержка украинского языка. | |
vietnamese | Поддержка вьетнамского языка. | |
wayland | Порты для поддержки сервера дисплея Wayland. | |
windowmaker | Порты для поддержки оконного менеджера Window Maker. | |
www | Программное обеспечение, связанное с Всемирной паутиной. | Поддержка языка HTML также относится сюда. |
x11 | Система X Window и связанные компоненты. | Эта категория предназначена только для программного обеспечения, которое напрямую поддерживает оконную систему. Не помещайте сюда обычные X-приложения. Большинство из них относятся к другим категориям x11-* (см. ниже). |
x11-clocks | Часы X11. | |
x11-drivers | Драйверы X11. | |
x11-fm | Менеджеры файлов X11. | |
x11-fonts | Шрифты и утилиты для работы со шрифтами в X11. | |
x11-servers | Серверы X11. | |
x11-themes | Темы X11. | |
x11-toolkits | Инструментарии X11. | |
x11-wm | Оконные менеджеры X11. | |
xfce | Порты, связанные с окружением рабочего стола Xfce. | |
zope | Zope поддержка. |
5.3.3. Выбор подходящей категории
Поскольку многие категории пересекаются, выбор основной категории для порта может быть утомительным. Существует несколько правил, регулирующих этот вопрос. Вот список приоритетов в порядке убывания важности:
Первая категория должна быть физической (см. выше). Это необходимо для работы упаковки. Виртуальные категории и физические категории могут чередоваться после этого.
Языковые категории всегда указываются первыми. Например, если порт устанавливает японские шрифты для X11, то строка
CATEGORIESбудет выглядеть так: japanese x11-fonts.Конкретные категории перечислены перед менее специфичными. Например, HTML-редактор указывается как www editors, а не наоборот. Также не следует указывать net, если порт принадлежит к любой из категорий irc, mail, news, security или www, так как net подразумевается автоматически.
x11 используется как вторичная категория только в случае, когда основной категорией указан естественный язык. В частности, не указывайте x11 в строке категории для X-приложений.
Режимы Emacs размещаются в той же категории портов, что и приложение, поддерживаемое данным режимом, а не в editors. Например, режим Emacs для редактирования исходных файлов какого-либо языка программирования попадает в lang.
Порты, устанавливающие загружаемые модули ядра, также имеют виртуальную категорию kld в строке
CATEGORIES. Это одна из вещей, автоматически обрабатываемых при добавленииUSES=kmod.misc не встречается вместе с другими невиртуальными категориями. Если
miscуказан вместе с чем-то еще вCATEGORIES, это означает, чтоmiscможно безопасно удалить, а порт разместить только в другом подкаталоге.Если порт действительно не подходит никуда больше, поместите его в misc.
Если категория не определена четко, пожалуйста, укажите это в комментарии при отправке порта в баг-трекере, чтобы мы могли обсудить её перед импортом. Как коммиттер, отправьте сообщение в рассылку Список рассылки, посвящённый Портам FreeBSD, чтобы мы сначала обсудили это. Слишком часто новые порты импортируются в неправильную категорию, после чего их сразу же приходится перемещать.
5.3.4. Предложение новой категории
По мере роста Коллекции портов со временем были введены различные новые категории. Новые категории могут быть виртуальными — те, у которых нет соответствующего подкаталога в дереве портов, или физическими — те, у которых он есть. В этом разделе обсуждаются вопросы, связанные с созданием новой физической категории. Внимательно ознакомьтесь с ним, прежде чем предлагать новую.
Наша текущая практика заключается в том, чтобы избегать создания новой физической категории, если только либо большое количество портов логически принадлежит к ней, либо порты, которые к ней относятся, представляют собой логически обособленную группу, представляющую ограниченный общий интерес (например, категории, связанные с разговорными человеческими языками), или, желательно, оба условия одновременно.
Обоснование этого заключается в том, что такое изменение создает значительный объем работы как для коммиттеров, так и для всех пользователей, которые отслеживают изменения в Коллекции портов. Кроме того, предлагаемые изменения категорий, как правило, вызывают споры. (Возможно, это связано с отсутствием четкого консенсуса относительно того, когда категория становится «слишком большой», а также относительно того, должны ли категории способствовать удобству просмотра (и, следовательно, какое количество категорий было бы идеальным), и так далее.)
Вот процедура:
Предложите новую категорию на Список рассылки, посвящённый Портам FreeBSD. Включите подробное обоснование для новой категории, объясните, почему существующие категории недостаточны, и укажите список существующих портов, предлагаемых к перемещению. (Если в Bugzilla есть ожидающие рассмотрения новые порты, которые подходят под эту категорию, также перечислите их.) Если вы являетесь сопровождающим и/или подающим предложение, укажите это, так как это может помочь в рассмотрении.
Участвуйте в обсуждении.
Если кажется, что идея находит поддержку, оформите PR, включающий как обоснование, так и список существующих портов, которые необходимо переместить. В идеале, этот PR также должен содержать следующие исправления:
Makefile для новых портов после копирования их репозитория
Makefile для новой категории
Makefile для старых категорий портов
Makefile для портов, зависящих от старых портов
(для дополнительной оценки включите другие файлы, которые необходимо изменить, в соответствии с процедурой, описанной в Руководстве коммиттера.)
Поскольку это затрагивает инфраструктуру портов и включает перемещение и исправление многих портов, а также, возможно, проведение регрессионных тестов на сборочном кластере, назначьте PR для Группа Менеджеров Дерева Портов FreeBSD <portmgr@FreeBSD.org>.
Если этот PR будет одобрен, коммиттер должен будет выполнить оставшуюся часть процедуры, описанной в Руководстве коммиттера.
Предложение новой виртуальной категории аналогично описанному выше, но гораздо менее трудоёмко, так как фактически не потребуется перемещать порты. В этом случае единственные патчи, которые нужно включить в PR, — это добавление новой категории в CATEGORIES затронутых портов.
5.3.5. Предложение о реорганизации всех категорий
Изредка кто-то предлагает реорганизовать категории, используя либо двухуровневую структуру, либо какую-либо другую структуру ключевых слов. На сегодняшний день ни одно из этих предложений не было реализовано, потому что, хотя их очень легко выдвинуть, усилия, необходимые для переработки всей существующей коллекции портов в рамках любой реорганизации, пугают, мягко говоря. Пожалуйста, ознакомьтесь с историей этих предложений в архивах списка рассылки, прежде чем публиковать эту идею. Более того, будьте готовы к тому, что вас попросят предоставить рабочий прототип.
5.4. Файлы дистрибутива
Вторая часть Makefile описывает файлы, которые необходимо загрузить для сборки порта, и места, откуда их можно скачать.
5.4.1. DISTNAME
DISTNAME — это имя порта, используемое авторами программного обеспечения. По умолчанию DISTNAME имеет значение ${PORTNAME}-${DISTVERSIONPREFIX}${DISTVERSION}${DISTVERSIONSUFFIX}, а если не задано, DISTVERSION по умолчанию принимает значение ${PORTVERSION}, поэтому переопределяйте DISTNAME только при необходимости. DISTNAME используется только в двух случаях. Во-первых, список файлов дистрибутива (DISTFILES) по умолчанию имеет значение ${DISTNAME}${EXTRACT_SUFX}. Во-вторых, ожидается, что файл дистрибутива распакуется в подкаталог с именем WRKSRC, который по умолчанию равен work/${DISTNAME}.
Некоторые названия дистрибутивов от поставщиков, которые не соответствуют схеме ${PORTNAME}-${PORTVERSION}, могут обрабатываться автоматически путем установки DISTVERSIONPREFIX, DISTVERSION и DISTVERSIONSUFFIX. PORTVERSION будет автоматически вычисляться из DISTVERSION.
Только одна из переменных |
Если схема версий исходного проекта может быть преобразована в схему, совместимую с портами, установите некоторую переменную в версию исходного проекта, не используйте имя переменной DISTVERSION. Установите PORTVERSION в вычисленную версию на основе созданной вами переменной и задайте DISTNAME соответствующим образом.
Если схема версионирования вышестоящего проекта не может быть легко преобразована в значение, совместимое с портами, установите PORTVERSION в разумное значение и задайте DISTNAME как PORTNAME с дословной версией вышестоящего проекта.
PORTVERSION вручнуюBIND9 использует схему версионирования, несовместимую с версиями портов (в версиях используется -), и её нельзя получить с помощью DISTVERSION, так как после выпуска 9.9.9 выходят «уровни исправлений» в формате 9.9.9-P1. DISTVERSION преобразует это в 9.9.9.p1, что в схеме версионирования портов означает 9.9.9 pre-release 1, то есть версию, предшествующую 9.9.9, а не следующую за ней. Поэтому PORTVERSION вручную формируется из переменной ISCVERSION, чтобы получить 9.9.9p1.
Порядок, в котором система портов и pkg будут сортировать версии, проверяется с помощью аргумента -t из pkg-version(8):
% pkg version -t 9.9.9 9.9.9.p1
> (1)
% pkg version -t 9.9.9 9.9.9p1
< (2)| 1 | Знак > означает, что первый аргумент, переданный в -t, больше второго аргумента. 9.9.9 находится после 9.9.9.p1. |
| 2 | Знак < означает, что первый аргумент, переданный в -t, меньше второго аргумента. 9.9.9 находится перед 9.9.9p1. |
В файле Makefile порта, например dns/bind99, это достигается с помощью:
PORTNAME= bind
PORTVERSION= ${ISCVERSION:S/-P/P/:S/b/.b/:S/a/.a/:S/rc/.rc/}
CATEGORIES= dns net
MASTER_SITES= ISC/bind9/${ISCVERSION}
PKGNAMESUFFIX= 99
DISTNAME= ${PORTNAME}-${ISCVERSION}
MAINTAINER= mat@FreeBSD.org
COMMENT= BIND DNS suite with updated DNSSEC and DNS64
WWW= https://www.isc.org/bind/
LICENSE= ISCL
# ISC releases things like 9.8.0-P1 or 9.8.1rc1, which our versioning does not like
ISCVERSION= 9.9.9-P6Определите версию вышестоящего пакета в ISCVERSION, с комментарием, объясняющим, почему это необходимо. Используйте ISCVERSION для получения совместимого с портами PORTVERSION. Используйте ISCVERSION напрямую для получения правильного URL для загрузки файла дистрибутива. Используйте ISCVERSION напрямую для именования дистрибутивного файла.
DISTNAME из PORTVERSIONВремя от времени имя файла дистрибутива имеет мало отношения или вообще никакого отношения к версии программного обеспечения.
В пакете comms/kermit, в файле дистрибутива присутствует только последний элемент версии:
PORTNAME= kermit
PORTVERSION= 9.0.304
CATEGORIES= comms ftp net
MASTER_SITES= ftp://ftp.kermitproject.org/kermit/test/tar/
DISTNAME= cku${PORTVERSION:E}-dev20Модификатор :E make(1) возвращает суффикс переменной, в данном случае 304. Файл дистрибутива корректно создаётся как cku304-dev20.tar.gz.
Иногда нет связи между названием программы, её версией и файлом дистрибутива, в котором она распространяется.
Из пакета audio/libworkman:
PORTNAME= libworkman
PORTVERSION= 1.4
CATEGORIES= audio
MASTER_SITES= LOCAL/jim
DISTNAME= ${PORTNAME}-1999-06-20В пакете comms/librs232 файл дистрибутива не имеет версии, поэтому необходимо использовать DIST_SUBDIR:
PORTNAME= librs232
PORTVERSION= 20160710
CATEGORIES= comms
MASTER_SITES= http://www.teuniz.net/RS-232/
DISTNAME= RS-232
DIST_SUBDIR= ${PORTNAME}-${PORTVERSION}
|
5.4.2. MASTER_SITES
Запишите именем каталога из FTP/HTTP-URL, указывающего на исходный tarball, в MASTER_SITES. Не забудьте завершающий слэш (/)!
Макросы make будут пытаться использовать эту спецификацию для загрузки файла дистрибутива с помощью FETCH, если не смогут найти его уже в системе.
Рекомендуется включать в этот список несколько сайтов, желательно с разных континентов. Это обеспечит защиту от проблем в глобальной сети.
|
5.4.2.1. Использование переменных MASTER_SITE_*
Для популярных архивов, таких как SourceForge (SOURCEFORGE), GNU (GNU) или Perl CPAN (PERL_CPAN), доступны сокращённые обозначения. MASTER_SITES может использовать их напрямую:
MASTER_SITES= GNU/make
Старый расширенный формат по-прежнему работает, но все порты были преобразованы в компактный формат. Расширенный формат выглядит следующим образом:
MASTER_SITES= ${MASTER_SITE_GNU}
MASTER_SITE_SUBDIR= makeЭти значения и переменные определены в Mk/bsd.sites.mk. Новые записи добавляются часто, поэтому обязательно проверяйте последнюю версию этого файла перед отправкой порта.
Для любой переменной MASTER_SITES= FOO Если требуется MASTER_SITES= FOO/bar |
Некоторые имена
|
5.4.2.2. Волшебные макросы MASTER_SITES
Существует несколько "волшебных" макросов для популярных сайтов с предсказуемой структурой каталогов. Для них достаточно использовать сокращение, и система автоматически выберет подкаталог. Например, для порта с именем Stardict, версии 1.2.3, размещенного на SourceForge, добавьте следующую строку:
MASTER_SITES= SF
подразумевает подкаталог с именем /project/stardict/stardict/1.2.3. Если подразумеваемый каталог указан неверно, его можно переопределить:
MASTER_SITES= SF/stardict/WyabdcRealPeopleTTS/${PORTVERSION}Это также можно записать как
MASTER_SITES= SF
MASTER_SITE_SUBDIR= stardict/WyabdcRealPeopleTTS/${PORTVERSION}| Макрос | Предполагаемая поддиректория |
|---|---|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
5.4.3. USE_GITHUB
Если файл дистрибутива получен из определённого коммита или тега на GitHub, для которого нет официально выпущенного файла, существует простой способ автоматически установить правильные значения DISTNAME и MASTER_SITES.
По состоянию на 2023-02-21 GitHub объявили, что загрузки исходного кода будут стабильными в течение года. Пожалуйста, переключитесь на ресурсы выпусков (release assets), а если они недоступны, запросите их создание у вышестоящих разработчиков. |
Доступны следующие переменные:
| Переменная | Описание | По умолчанию |
|---|---|---|
| Имя учётной записи пользователя GitHub, который размещает проект |
|
| Название проекта на GitHub |
|
| Имя тега для загрузки (2.0.1, хэш, …) Использование имени ветки здесь некорректно. Также можно использовать хэш идентификатора коммита для создания снимка состояния. |
|
| Когда программному обеспечению требуется дополнительный файл дистрибутива для извлечения в
| (отсутствует) |
|
|
Не используйте |
USE_GITHUBПри попытке создать порт для версии 1.2.7 pkg от пользователя FreeBSD на github, по адресу https://github.com/freebsd/pkg/, файл Makefile в итоге будет выглядеть следующим образом (незначительно сокращено для примера):
PORTNAME= pkg DISTVERSION= 1.2.7 USE_GITHUB= yes GH_ACCOUNT= freebsd
Он автоматически получит MASTER_SITES установленным в GH и WRKSRC в ${WRKDIR}/pkg-1.2.7.
USE_GITHUBПри попытке создать порт для самой последней версии pkg от пользователя FreeBSD на github, по адресу https://github.com/freebsd/pkg/, файл Makefile в итоге выглядит следующим образом (незначительно сокращено для примера):
PORTNAME= pkg-devel DISTVERSION= 1.3.0.a.20140411 USE_GITHUB= yes GH_ACCOUNT= freebsd GH_PROJECT= pkg GH_TAGNAME= 6dbb17b
Он автоматически получит MASTER_SITES со значением GH и WRKSRC со значением ${WRKDIR}/pkg-6dbb17b.
USE_GITHUB с DISTVERSIONPREFIXВремя от времени GH_TAGNAME немного отличается от DISTVERSION. Например, если версия 1.0.2, то тег будет v1.0.2. В таких случаях можно использовать DISTVERSIONPREFIX или DISTVERSIONSUFFIX:
PORTNAME= foo DISTVERSIONPREFIX= v DISTVERSION= 1.0.2 USE_GITHUB= yes
Он автоматически установит GH_TAGNAME в v1.0.2, в то время как WRKSRC останется ${WRKDIR}/foo-1.0.2.
USE_GITHUB при отсутствии версий у исходного проектаЕсли никогда не было версии вышестоящего репозитория, не изобретайте её, например 0.1 или 1.0. Создайте порт с DISTVERSION в формате gYYYYMMDD, где g означает Git, а YYYYMMDD представляет дату коммита, указанного в GH_TAGNAME.
PORTNAME= bar DISTVERSION= g20140411 USE_GITHUB= yes GH_TAGNAME= c472d66b
Это создаёт схему версионирования, которая увеличивается со временем и всё ещё находится до версии 0. Подробности об использовании pkg-version(8) для сравнения версий смотрите в этой секции:
% pkg version -t g20140411 0
<Что означает, что использование PORTEPOCH не потребуется, если вышестоящий проект решит сократить версии в будущем.
USE_GITHUB для доступа к коммиту между двумя версиямиЕсли текущая версия программного обеспечения использует тег Git, и порт необходимо обновить до более новой промежуточной версии без тега, используйте git-describe(1), чтобы определить версию для использования:
% git describe --tags f0038b1
v0.7.3-14-gf0038b1v0.7.3-14-gf0038b1 можно разделить на три части:
v0.7.3Это последний тег Git, который появляется в истории коммитов перед запрошенным коммитом.
-14Это означает, что запрошенный коммит
f0038b1является 14-м коммитом после тегаv0.7.3.-gf0038b1-gозначает "Git", аf0038b1— это хеш коммита, на который указывает данная ссылка.
PORTNAME= bar DISTVERSIONPREFIX= v DISTVERSION= 0.7.3-14 DISTVERSIONSUFFIX= -gf0038b1 USE_GITHUB= yes
Это создаёт схему версионирования, которая увеличивается со временем (точнее, с коммитами) и не конфликтует с созданием версии 0.7.4. Подробности об использовании pkg-version(8) для сравнения версий смотрите в этой секции :
% pkg version -t 0.7.3 0.7.3.14
<
% pkg version -t 0.7.3.14 0.7.4
<5.4.3.1. Извлечение нескольких файлов из GitHub
Фреймворк USE_GITHUB также поддерживает загрузку нескольких файлов дистрибутива из разных мест в GitHub. Он работает очень похоже на Файлы дистрибуции или патчей из нескольких мест.
В GH_ACCOUNT, GH_PROJECT и GH_TAGNAME добавляются несколько значений. Каждому различному значению присваивается группа. Основное значение может не иметь группы или принадлежать группе :DEFAULT. Значение может быть опущено, если оно совпадает со значением по умолчанию, указанным в описании USE_GITHUB.
GH_TUPLE также можно использовать, когда имеется множество файлов дистрибутива. Это помогает сохранять учётные данные, проект, имя тега и информацию о группе в одном месте.
Для каждой группы создаётся вспомогательная переменная ${WRKSRC_group}, содержащая каталог, в который был извлечён файл. Переменные ${WRKSRC_group} могут использоваться для перемещения каталогов во время post-extract, добавления в CONFIGURE_ARGS или любых других действий, необходимых для корректной сборки программного обеспечения.
Часть |
Поскольку это всего лишь синтаксический сахар над |
При получении нескольких файлов из GitHub иногда файл дистрибутива по умолчанию не загружается из GitHub. Чтобы отключить загрузку файла дистрибутива по умолчанию, установите:
USE_GITHUB= nodefault
При использовании DISTFILES= ${DISTNAME}${EXTRACT_SUFX} |
USE_GITHUB с несколькими файлами дистрибутиваВремя от времени возникает необходимость загрузить более одного файла дистрибутива. Например, когда вышестоящий репозиторий git использует подмодули. Это можно легко сделать с помощью групп в переменных GH_*:
PORTNAME= foo
DISTVERSION= 1.0.2
USE_GITHUB= yes
GH_ACCOUNT= bar:icons,contrib
GH_PROJECT= foo-icons:icons foo-contrib:contrib
GH_TAGNAME= 1.0:icons fa579bc:contrib
GH_SUBDIR= ext/icons:icons
CONFIGURE_ARGS= --with-contrib=${WRKSRC_contrib}Это загрузит три файла дистрибутива с github. Стандартный берется из foo/foo и имеет версию 1.0.2. Второй, с группой icons, берется из bar/foo-icons и имеет версию 1.0. Третий берется из bar/foo-contrib и использует Git-коммит fa579bc. Файлы дистрибутива называются foo-foo-1.0.2_GH0.tar.gz, bar-foo-icons-1.0_GH0.tar.gz и bar-foo-contrib-fa579bc_GH0.tar.gz.
Все файлы дистрибутива извлекаются в ${WRKDIR} в соответствующих подкаталогах. Основной файл по-прежнему извлекается в ${WRKSRC}, в данном случае, ${WRKDIR}/foo-1.0.2. Каждый дополнительный файл дистрибутива извлекается в ${WRKSRC_group}. Здесь, для группы icons, он называется ${WRKSRC_icons} и содержит ${WRKDIR}/foo-icons-1.0. Файл с группой contrib называется ${WRKSRC_contrib} и содержит ${WRKDIR}/foo-contrib-fa579bc.
Система сборки программы ожидает найти иконки в подкаталоге ext/icons в её исходниках, поэтому используется GH_SUBDIR. GH_SUBDIR гарантирует, что ext существует, но ext/icons ещё не существует. Затем он выполняет следующее:
post-extract:
@${MV} ${WRKSRC_icons} ${WRKSRC}/ext/iconsUSE_GITHUB с несколькими файлами дистрибутива с помощью GH_TUPLEЭто функционально эквивалентно Использованию USE_GITHUB с несколькими файлами дистрибутива, но с использованием GH_TUPLE:
PORTNAME= foo
DISTVERSION= 1.0.2
USE_GITHUB= yes
GH_TUPLE= bar:foo-icons:1.0:icons/ext/icons \
bar:foo-contrib:fa579bc:contrib
CONFIGURE_ARGS= --with-contrib=${WRKSRC_contrib}В предыдущем примере использовалась группировка с bar:icons,contrib. В GH_TUPLE присутствует избыточная информация, так как группировка невозможна.
USE_GITHUB с подмодулями Git?Порты, использующие GitHub в качестве вышестоящего репозитория, иногда применяют подмодули. Подробнее см. git-submodule(1).
Проблема с подмодулями заключается в том, что каждый из них является отдельным репозиторием. Таким образом, каждый из них должен быть загружен отдельно.
В качестве примера используем пакет finance/moneymanagerex, его репозиторий на GitHub находится по адресу https://github.com/moneymanagerex/moneymanagerex/. В корне репозитория есть файл .gitmodules. Этот файл описывает все подмодули, используемые в данном репозитории, и перечисляет дополнительные необходимые репозитории. Этот файл покажет, какие дополнительные репозитории требуются:
[submodule "lib/wxsqlite3"] path = lib/wxsqlite3 url = https://github.com/utelle/wxsqlite3.git [submodule "3rd/mongoose"] path = 3rd/mongoose url = https://github.com/cesanta/mongoose.git [submodule "3rd/LuaGlue"] path = 3rd/LuaGlue url = https://github.com/moneymanagerex/LuaGlue.git [submodule "3rd/cgitemplate"] path = 3rd/cgitemplate url = https://github.com/moneymanagerex/html-template.git [...]
Единственная информация, отсутствующая в этом файле, — это хэш коммита или тег, который следует использовать в качестве версии. Эта информация находится после клонирования репозитория:
% git clone --recurse-submodules https://github.com/moneymanagerex/moneymanagerex.git
Cloning into 'moneymanagerex'...
remote: Counting objects: 32387, done.
[...]
Submodule '3rd/LuaGlue' (https://github.com/moneymanagerex/LuaGlue.git) registered for path '3rd/LuaGlue'
Submodule '3rd/cgitemplate' (https://github.com/moneymanagerex/html-template.git) registered for path '3rd/cgitemplate'
Submodule '3rd/mongoose' (https://github.com/cesanta/mongoose.git) registered for path '3rd/mongoose'
Submodule 'lib/wxsqlite3' (https://github.com/utelle/wxsqlite3.git) registered for path 'lib/wxsqlite3'
[...]
Cloning into '/home/mat/work/freebsd/ports/finance/moneymanagerex/moneymanagerex/3rd/LuaGlue'...
Cloning into '/home/mat/work/freebsd/ports/finance/moneymanagerex/moneymanagerex/3rd/cgitemplate'...
Cloning into '/home/mat/work/freebsd/ports/finance/moneymanagerex/moneymanagerex/3rd/mongoose'...
Cloning into '/home/mat/work/freebsd/ports/finance/moneymanagerex/moneymanagerex/lib/wxsqlite3'...
[...]
Submodule path '3rd/LuaGlue': checked out 'c51d11a247ee4d1e9817dfa2a8da8d9e2f97ae3b'
Submodule path '3rd/cgitemplate': checked out 'cd434eeeb35904ebcd3d718ba29c281a649b192c'
Submodule path '3rd/mongoose': checked out '2140e5992ab9a3a9a34ce9a281abf57f00f95cda'
Submodule path 'lib/wxsqlite3': checked out 'fb66eb230d8aed21dec273b38c7c054dcb7d6b51'
[...]
% cd moneymanagerex
% git submodule status
c51d11a247ee4d1e9817dfa2a8da8d9e2f97ae3b 3rd/LuaGlue (heads/master)
cd434eeeb35904ebcd3d718ba29c281a649b192c 3rd/cgitemplate (cd434ee)
2140e5992ab9a3a9a34ce9a281abf57f00f95cda 3rd/mongoose (6.2-138-g2140e59)
fb66eb230d8aed21dec273b38c7c054dcb7d6b51 lib/wxsqlite3 (v3.4.0)
[...]Это также можно найти на GitHub. Каждый подкаталог, который является подмодулем, отображается как директория @ хэш, например, mongoose @ 2140e59.
Теперь, когда вся необходимая информация собрана, можно написать Makefile (показаны только строки, связанные с GitHub):
PORTNAME= moneymanagerex DISTVERSIONPREFIX= v DISTVERSION= 1.3.0 USE_GITHUB= yes GH_TUPLE= utelle:wxsqlite3:v3.4.0:wxsqlite3/lib/wxsqlite3 \ moneymanagerex:LuaGlue:c51d11a:lua_glue/3rd/LuaGlue \ moneymanagerex:html-template:cd434ee:html_template/3rd/cgitemplate \ cesanta:mongoose:2140e59:mongoose/3rd/mongoose \ [...]
5.4.4. USE_GITLAB
Подобно GitHub, если файл дистрибутива поставляется с gitlab.com или использует программное обеспечение GitLab, эти переменные доступны для использования и могут потребовать установки.
| Переменная | Описание | По умолчанию |
|---|---|---|
| Название сайта, на котором размещен проект GitLab | |
| Имя учётной записи пользователя GitLab, размещающего проект |
|
| Название проекта на GitLab |
|
| Хэш коммита для загрузки. Должен быть полным 160-битным, 40-символьным шестнадцатеричным хэшем sha1. Это обязательная переменная для GitLab. |
|
| Когда программному обеспечению требуется дополнительный файл дистрибутива для извлечения в
| (отсутствует) |
|
|
USE_GITLABПытаясь создать порт для версии 1.14 библиотеки libsignon-glib от пользователя accounts-sso на gitlab.com, по адресу https://gitlab.com/accounts-sso/libsignon-glib/, файл Makefile будет выглядеть следующим образом для загрузки дистрибутивных файлов:
PORTNAME= libsignon-glib DISTVERSION= 1.14 USE_GITLAB= yes GL_ACCOUNT= accounts-sso GL_COMMIT= e90302e342bfd27bc8c9132ab9d0ea3d8723fd03
Он автоматически получит MASTER_SITES, установленный на gitlab.com, и WRKSRC на ${WRKDIR}/libsignon-glib-e90302e342bfd27bc8c9132ab9d0ea3d8723fd03-e90302e342bfd27bc8c9132ab9d0ea3d8723fd03.
USE_GITLABБолее полный пример использования вышеописанного, если порт не имеет версионирования и foobar принадлежит пользователю foo в проекте bar на самостоятельно размещенном сайте GitLab https://gitlab.example.com/, тогда Makefile будет выглядеть следующим образом для загрузки дистрибутивных файлов:
PORTNAME= foobar DISTVERSION= g20170906 USE_GITLAB= yes GL_SITE= https://gitlab.example.com GL_ACCOUNT= foo GL_PROJECT= bar GL_COMMIT= 9c1669ce60c3f4f5eb43df874d7314483fb3f8a6
В нем будет установлено MASTER_SITES в "https://gitlab.example.com" и WRKSRC в ${WRKDIR}/bar-9c1669ce60c3f4f5eb43df874d7314483fb3f8a6-9c1669ce60c3f4f5eb43df874d7314483fb3f8a6.
|
Протокол, порт и корневая директория веб-сервера |
5.4.4.1. Извлечение нескольких файлов из GitLab
Фреймворк USE_GITLAB также поддерживает загрузку нескольких файлов дистрибутивов из различных мест GitLab и сайтов, размещённых на GitLab. Он работает очень похоже на Несколько файлов дистрибутивов или патчей из разных местоположений и Загрузка нескольких файлов из GitLab.
В GL_SITE, GL_ACCOUNT, GL_PROJECT и GL_COMMIT добавляются множественные значения. Каждое уникальное значение назначается группе. Описание USE_GITLAB.
GL_TUPLE также может использоваться, когда имеется множество файлов дистрибутива. Это помогает хранить информацию о сайте, учётной записи, проекте, коммите и группе в одном месте.
Для каждой группы создаётся вспомогательная переменная ${WRKSRC_group}, содержащая каталог, в который был извлечён файл. Переменные ${WRKSRC_group} могут использоваться для перемещения каталогов во время post-extract, добавления в CONFIGURE_ARGS или любых других действий, необходимых для корректной сборки программного обеспечения.
Часть |
Поскольку это всего лишь синтаксический сахар над |
При получении нескольких файлов с использованием GitLab иногда файл дистрибутива по умолчанию не загружается с сайта GitLab. Чтобы отключить загрузку файла дистрибутива по умолчанию, установите:
USE_GITLAB= nodefault
При использовании DISTFILES= ${DISTNAME}${EXTRACT_SUFX} |
USE_GITLAB с несколькими файлами дистрибутиваВремя от времени возникает необходимость загрузить более одного файла дистрибутива. Например, когда вышестоящий git-репозиторий использует подмодули. Это можно легко сделать с помощью групп в переменных GL_*:
PORTNAME= foo
DISTVERSION= 1.0.2
USE_GITLAB= yes
GL_SITE= https://gitlab.example.com:9434/gitlab:icons
GL_ACCOUNT= bar:icons,contrib
GL_PROJECT= foo-icons:icons foo-contrib:contrib
GL_COMMIT= c189207a55da45305c884fe2b50e086fcad4724b ae7368cab1ca7ca754b38d49da064df87968ffe4:icons 9e4dd76ad9b38f33fdb417a4c01935958d5acd2a:contrib
GL_SUBDIR= ext/icons:icons
CONFIGURE_ARGS= --with-contrib=${WRKSRC_contrib}Это загрузит два файла дистрибутива с gitlab.com и один с gitlab.example.com, где размещается GitLab. По умолчанию файл берется из https://gitlab.com/foo/foo, а коммит — c189207a55da45305c884fe2b50e086fcad4724b. Второй файл, из группы icons, берется из https://gitlab.example.com:9434/gitlab/bar/foo-icons, а коммит — ae7368cab1ca7ca754b38d49da064df87968ffe4. Третий файл берется из https://gitlab.com/bar/foo-contrib, а коммит — 9e4dd76ad9b38f33fdb417a4c01935958d5acd2a. Файлы дистрибутива называются foo-foo-c189207a55da45305c884fe2b50e086fcad4724b_GL0.tar.gz, bar-foo-icons-ae7368cab1ca7ca754b38d49da064df87968ffe4_GL0.tar.gz и bar-foo-contrib-9e4dd76ad9b38f33fdb417a4c01935958d5acd2a_GL0.tar.gz.
Все файлы дистрибутива извлекаются в ${WRKDIR} в соответствующих подкаталогах. Основной файл по-прежнему извлекается в ${WRKSRC}, в данном случае это ${WRKDIR}/foo-c189207a55da45305c884fe2b50e086fcad4724b-c189207a55da45305c884fe2b50e086fcad4724b. Каждый дополнительный файл дистрибутива извлекается в ${WRKSRC_group}. Здесь для группы icons он называется ${WRKSRC_icons} и содержит ${WRKDIR}/foo-icons-ae7368cab1ca7ca754b38d49da064df87968ffe4-ae7368cab1ca7ca754b38d49da064df87968ffe4. Файл группы contrib называется ${WRKSRC_contrib} и содержит ${WRKDIR}/foo-contrib-9e4dd76ad9b38f33fdb417a4c01935958d5acd2a-9e4dd76ad9b38f33fdb417a4c01935958d5acd2a.
Система сборки программного обеспечения ожидает найти иконки в подкаталоге ext/icons в своих исходниках, поэтому используется GL_SUBDIR. GL_SUBDIR гарантирует, что ext существует, но ext/icons ещё не существует. Затем она выполняет следующее:
post-extract:
@${MV} ${WRKSRC_icons} ${WRKSRC}/ext/iconsUSE_GITLAB с несколькими файлами дистрибуции с помощью GL_TUPLEЭто функционально эквивалентно Использование USE_GITLAB с несколькими файлами дистрибуции, но с использованием GL_TUPLE:
PORTNAME= foo
DISTVERSION= 1.0.2
USE_GITLAB= yes
GL_COMMIT= c189207a55da45305c884fe2b50e086fcad4724b
GL_TUPLE= https://gitlab.example.com:9434/gitlab:bar:foo-icons:ae7368cab1ca7ca754b38d49da064df87968ffe4:icons/ext/icons \
bar:foo-contrib:9e4dd76ad9b38f33fdb417a4c01935958d5acd2a:contrib
CONFIGURE_ARGS= --with-contrib=${WRKSRC_contrib}В предыдущем примере использовалась группировка с bar:icons,contrib. Некоторую избыточную информацию приходится указывать с GL_TUPLE, так как группировка невозможна.
5.4.5. EXTRACT_SUFX
Если имеется один файл дистрибутива, и он использует нестандартное суффикс для указания механизма сжатия, установите EXTRACT_SUFX.
Например, если файл дистрибутива был назван foo.tar.gzip вместо более привычного foo.tar.gz, напишите:
DISTNAME= foo EXTRACT_SUFX= .tar.gzip
USES=tar[:xxx], USES=lha или USES=zip автоматически устанавливают EXTRACT_SUFX в наиболее распространённые расширения архивов при необходимости, подробнее см. Использование макросов USES. Если ни один из них не задан, EXTRACT_SUFX по умолчанию принимает значение .tar.gz.
Как |
5.4.6. DISTFILES
Иногда названия файлов для загрузки не имеют ничего общего с именем порта. Например, файл может называться source.tar.gz или подобным образом. В других случаях исходный код приложения может быть разбит на несколько различных архивов, все из которых необходимо загрузить.
Если это так, установите DISTFILES как список разделённых пробелами файлов, которые необходимо загрузить.
DISTFILES= source1.tar.gz source2.tar.gz
Если явно не задано, DISTFILES по умолчанию равно ${DISTNAME}${EXTRACT_SUFX}.
5.4.7. EXTRACT_ONLY
Если необходимо извлечь только некоторые из DISTFILES — например, один из них является исходным кодом, а другой — несжатым документом — укажите имена файлов, которые нужно извлечь, в EXTRACT_ONLY.
DISTFILES= source.tar.gz manual.html EXTRACT_ONLY= source.tar.gz
Если ни один из DISTFILES не требует распаковки, установите EXTRACT_ONLY в пустую строку.
EXTRACT_ONLY=
5.4.8. PATCHFILES
Если порт требует дополнительных исправлений, доступных через FTP или HTTP, установите PATCHFILES в имена файлов, а PATCH_SITES — в URL каталога, содержащего их (формат такой же, как у MASTER_SITES).
Если патч не относится к корню исходного дерева (то есть к WRKSRC), потому что содержит дополнительные пути, установите PATCH_DIST_STRIP соответствующим образом. Например, если все пути в патче имеют дополнительный префикс foozolix-1.0/ перед именами файлов, задайте PATCH_DIST_STRIP=-p1.
Не беспокойтесь, если патчи сжаты; они будут автоматически распакованы, если их имена заканчиваются на .Z, .gz, .bz2 или .xz.
Если патч распространяется вместе с другими файлами, такими как документация, в сжатом tarball, использование PATCHFILES невозможно. В таком случае добавьте имя и расположение tarball с патчами в DISTFILES и MASTER_SITES. Затем используйте EXTRA_PATCHES, чтобы указать на эти файлы, и bsd.port.mk автоматически применит их. В частности, не копируйте файлы патчей в ${PATCHDIR}. Этот каталог может быть недоступен для записи.
Если есть несколько патчей и для них требуются разные значения параметра strip, его можно добавить рядом с именем патча в PATCHFILES= patch1 patch2:-p1 Это не конфликтует с функцией группировки мастер-сайтов, добавление группы также работает: PATCHFILES= patch2:-p1:source2 |
Tarball уже будет распакован вместе с обычными исходными кодами, поэтому нет необходимости явно его распаковывать, если это обычный сжатый tarball. Будьте особенно осторожны, чтобы не перезаписать существующие файлы в этом каталоге при ручной распаковке. Также не забудьте добавить команду для удаления скопированного патча в цель |
5.4.9. Несколько файлов дистрибутивов или исправлений из нескольких местоположений
(Считайте, что это несколько «продвинутая тема»; тем, кто впервые читает этот документ, возможно, стоит сначала пропустить этот раздел).
Этот раздел содержит информацию о механизме загрузки, известном как MASTER_SITES:n и MASTER_SITES_NN. Мы будем называть этот механизм MASTER_SITES:n.
Небольшая предыстория. В OpenBSD есть удобная функция внутри DISTFILES и PATCHFILES, которая позволяет добавлять постфикс :n к файлам и патчам. Здесь n может быть любым словом, содержащим [0-9a-zA-Z_], и обозначать группу. Например:
DISTFILES= alpha:0 beta:1
В OpenBSD файл дистрибутива alpha будет связан с переменной MASTER_SITES0, а не с нашей общей MASTER_SITES, а beta — с MASTER_SITES1.
Это очень интересная функция, которая может сократить бесконечные поиски нужного сайта для загрузки.
Представьте 2 файла в DISTFILES и 20 сайтов в MASTER_SITES, причём сайты медленные как черепаха, где beta есть на всех сайтах из MASTER_SITES, а alpha можно найти только на 20-м сайте. Было бы так обидно проверять их все, если бы сопровождающий знал это заранее, не так ли? Не самое лучшее начало для чудесных выходных!
Теперь, когда вы поняли идею, представьте больше DISTFILES и больше MASTER_SITES. Безусловно, наш "мастер по исследованию distfiles" оценил бы снижение нагрузки на сеть, которое это принесло бы.
В следующих разделах будет приведена информация о реализации этой идеи в FreeBSD. Мы немного улучшили концепцию OpenBSD.
5.4.9.1. Упрощенная информация
В этом разделе объясняется, как быстро настроить детализированное получение нескольких файлов дистрибутивов и патчей с разных сайтов и подкаталогов. Здесь описывается случай упрощённого использования MASTER_SITES:n. Этого будет достаточно для большинства сценариев. Более подробная информация доступна в Подробная Информация.
Некоторые приложения состоят из нескольких распространяемых файлов, которые необходимо загрузить с различных сайтов. Например, Ghostscript включает основную часть программы и множество драйверов, используемых в зависимости от принтера пользователя. Некоторые из этих драйверов поставляются вместе с основной частью, но многие другие необходимо загружать с различных сайтов.
Для поддержки этого, каждая запись в DISTFILES может сопровождаться двоеточием и "именем группы". Затем каждый сайт, указанный в MASTER_SITES, сопровождается двоеточием и группой, которая указывает, какие файлы дистрибутива загружаются с данного сайта.
Например, рассмотрим приложение, исходный код которого разделён на две части: source1.tar.gz и source2.tar.gz, которые необходимо загрузить с двух разных сайтов. В Makefile порта будут присутствовать строки, подобные Упрощённое использование MASTER_SITES:n с одним файлом на сайт.
MASTER_SITES:n с одним файлом на сайтMASTER_SITES= ftp://ftp1.example.com/:source1 \ http://www.example.com/:source2 DISTFILES= source1.tar.gz:source1 \ source2.tar.gz:source2
Несколько файлов дистрибутивов могут принадлежать одной группе. Продолжая предыдущий пример, предположим, что существует третий файл дистрибутива source3.tar.gz, который загружается с ftp.example2.com. Тогда Makefile будет записан, как показано в Упрощённое использование MASTER_SITES:n с несколькими файлами на один сайт.
MASTER_SITES:n с несколькими файлами на одном сайтеMASTER_SITES= ftp://ftp.example.com/:source1 \ http://www.example.com/:source2 DISTFILES= source1.tar.gz:source1 \ source2.tar.gz:source2 \ source3.tar.gz:source2
5.4.9.2. Подробная информация
Хорошо, значит, предыдущий пример не отражал потребности нового порта? В этом разделе мы подробно объясним, как работает механизм детализированного получения MASTER_SITES:n и как его можно использовать.
Элементы могут иметь постфикс
:n, где n — это`, то есть _n_ концептуально может быть любой буквенно-цифровой строкой, но пока мы ограничим её `[a-zA-Z_][0-9a-zA-Z_].Более того, сравнение строк чувствительно к регистру; то есть,
nотличается отN.Элементы с постфиксом
:nпринадлежат группеn,:m— группеmи так далее.Элементы без постфикса не принадлежат к группам, все они относятся к специальной группе
DEFAULT. Элементы с постфиксомDEFAULTизбыточны, за исключением случаев, когда элемент одновременно принадлежит и кDEFAULT, и к другим группам (см. пункт 5).Эти примеры эквивалентны, но первый предпочтительнее:
MASTER_SITES= alpha
MASTER_SITES= alpha:DEFAULT
Группы не являются исключительными, элемент может принадлежать нескольким разным группам одновременно, а группа может содержать несколько разных элементов или не содержать их вовсе.
Когда элемент принадлежит нескольким группам одновременно, используйте оператор запятую (
,).Вместо повторения несколько раз, каждый раз с разным постфиксом, мы можем перечислить несколько групп сразу в одном постфиксе. Например,
:m,n,oобозначает элемент, принадлежащий группамm,nиo.Все эти примеры эквивалентны, но последний является предпочтительным:
MASTER_SITES= alpha alpha:SOME_SITE
MASTER_SITES= alpha:DEFAULT alpha:SOME_SITE
MASTER_SITES= alpha:SOME_SITE,DEFAULT
MASTER_SITES= alpha:DEFAULT,SOME_SITE
Все сайты в заданной группе сортируются согласно
MASTER_SORT_AWK. Все группы вMASTER_SITESиPATCH_SITESтакже сортируются.Семантика групп может использоваться в любых переменных
MASTER_SITES,PATCH_SITES,MASTER_SITE_SUBDIR,PATCH_SITE_SUBDIR,DISTFILESиPATCHFILESсогласно следующему синтаксису:Все элементы
MASTER_SITES,PATCH_SITES,MASTER_SITE_SUBDIRиPATCH_SITE_SUBDIRдолжны заканчиваться символом дробной черты/. Если элементы принадлежат к какой-либо группе, постфикс группы:nдолжен следовать сразу после завершающего символа/. МеханизмMASTER_SITES:nполагается на наличие завершающего символа/, чтобы избежать путаницы между элементами, где:nявляется допустимой частью элемента, и случаями, где:nобозначает группуn. В целях совместимости, поскольку ранее завершающий символ/не требовался в элементахMASTER_SITE_SUBDIRиPATCH_SITE_SUBDIR, если символ, непосредственно предшествующий постфиксу, не является/, то:nбудет считаться допустимой частью элемента, а не постфиксом группы, даже если элемент оканчивается на:n. См. оба раздела Подробное использованиеMASTER_SITES:nвMASTER_SITE_SUBDIRи Подробное использованиеMASTER_SITES:nс оператором запятая.Пример 28. Подробное использованиеMASTER_SITES:nвMASTER_SITE_SUBDIRMASTER_SITE_SUBDIR= old:n new/:NEW
Каталоги в группе
DEFAULT→ old:nКаталоги в группе
NEW→ new
Пример 29. Подробное использованиеMASTER_SITES:nс оператором запятая, несколькими файлами, сайтами и подкаталогамиMASTER_SITES= http://site1/%SUBDIR%/ http://site2/:DEFAULT \ http://site3/:group3 http://site4/:group4 \ http://site5/:group5 http://site6/:group6 \ http://site7/:DEFAULT,group6 \ http://site8/%SUBDIR%/:group6,group7 \ http://site9/:group8 DISTFILES= file1 file2:DEFAULT file3:group3 \ file4:group4,group5,group6 file5:grouping \ file6:group7 MASTER_SITE_SUBDIR= directory-trial:1 directory-n/:groupn \ directory-one/:group6,DEFAULT \ directory
Предыдущий пример приводит к такой детализированной загрузке файлов. Сайты перечислены в точном порядке их использования.
file1 будет загружен из
MASTER_SITE_OVERRIDEMASTER_SITE_BACKUP
file2 будет загружен точно так же, как file1, поскольку они оба принадлежат к одной и той же группе
MASTER_SITE_OVERRIDEMASTER_SITE_BACKUP
file3 будет загружен из
MASTER_SITE_OVERRIDEMASTER_SITE_BACKUP
file4 будет загружен из
MASTER_SITE_OVERRIDEMASTER_SITE_BACKUP
file5 будет загружен из
MASTER_SITE_OVERRIDEMASTER_SITE_BACKUP
file6 будет получен из
MASTER_SITE_OVERRIDEMASTER_SITE_BACKUP
Как сгруппировать один из специальных макросов из bsd.sites.mk, например, SourceForge (
SF)?Это максимально упрощено. См. Подробное использование
MASTER_SITES:nс SourceForge (SF).Пример 30. Подробное использованиеMASTER_SITES:nс SourceForge (SF)MASTER_SITES= http://site1/ SF/something/1.0:sourceforge,TEST DISTFILES= something.tar.gz:sourceforge
something.tar.gz будет загружен со всех сайтов в пределах SourceForge.
Как использовать это с
PATCH*?Все примеры были выполнены с
MASTER*, но они работают точно так же дляPATCH*, как можно увидеть в Упрощённое использованиеMASTER_SITES:nсPATCH_SITES.Пример 31. Упрощённое использованиеMASTER_SITES:nсPATCH_SITESPATCH_SITES= http://site1/ http://site2/:test PATCHFILES= patch1:test
5.4.9.3. Что меняется для портов? Что остается неизменным?
Все текущие порты остаются без изменений. Функция
MASTER_SITES:nактивируется только при наличии элементов с постфиксом:n, соответствующих указанным выше синтаксическим правилам, в частности, как показано в пункте 7.Порты сохраняют те же цели:
checksum,makesum,patch,configure,buildи т.д., за исключением очевидных случаев:do-fetch,fetch-list,master-sitesиpatch-sites.do-fetch: развертывает новую группировку с постфиксомDISTFILESиPATCHFILESс соответствующими групповыми элементами вMASTER_SITESиPATCH_SITES, которые используют соответствующие групповые элементы вMASTER_SITE_SUBDIRиPATCH_SITE_SUBDIR. Проверьте Подробное использованиеMASTER_SITES:nс оператором запятой.fetch-list: работает как старыйfetch-list, за исключением того, что группировка происходит так же, как вdo-fetch.master-sitesиpatch-sites: (несовместимо с более старыми версиями) возвращают только элементы группыDEFAULT; фактически они выполняют целиmaster-sites-defaultиpatch-sites-defaultсоответственно.Кроме того, предпочтительнее использовать цель
master-sites-allилиpatch-sites-all, чем напрямую проверятьMASTER_SITESилиPATCH_SITES. Кроме того, прямая проверка не гарантирует работу в будущих версиях. Для получения дополнительной информации об этих новых целях портов см. пункт B.
Новые цели портов
Существуют цели
master-sites-nиpatch-sites-n, которые будут выводить элементы соответствующей группы n вMASTER_SITESиPATCH_SITESсоответственно. Например, иmaster-sites-DEFAULT, иpatch-sites-DEFAULTвернут элементы группыDEFAULT,master-sites-testиpatch-sites-test— группыtest, и так далее.Существуют новые цели
master-sites-allиpatch-sites-all, которые выполняют работу старыхmaster-sitesиpatch-sites. Они возвращают элементы всех групп, как если бы они все принадлежали одной группе, с оговоркой, что перечисляется столько жеMASTER_SITE_BACKUPиMASTER_SITE_OVERRIDE, сколько определено групп вDISTFILESилиPATCHFILES; соответственно дляmaster-sites-allиpatch-sites-all.
5.4.10. DIST_SUBDIR
Не допускайте захламления портом каталога /usr/ports/distfiles. Если порт требует загрузки большого количества файлов или содержит файл с именем, которое может конфликтовать с другими портами (например, Makefile), установите DIST_SUBDIR в имя порта (подойдут ${PORTNAME} или ${PKGNAMEPREFIX}${PORTNAME}). Это изменит DISTDIR со значения по умолчанию /usr/ports/distfiles на /usr/ports/distfiles/${DIST_SUBDIR}, фактически помещая все необходимые для порта файлы в этот подкаталог.
Также будет проверяться подкаталог с тем же именем на основном резервном сайте по адресу http://distcache.FreeBSD.org (Явное указание DISTDIR в Makefile не решит эту задачу, поэтому используйте DIST_SUBDIR.)
Это не влияет на сайты в |
5.5. MAINTAINER
Установите здесь свой адрес электронной почты. Пожалуйста. :-)
Только один адрес без комментария допускается в качестве значения MAINTAINER. Используемый формат: user@hostname.domain. Пожалуйста, не включайте в эту запись описательный текст, например, настоящее имя. Это только вносит путаницу в инфраструктуру Ports и большинство инструментов, которые её используют.
Ответственный за поддержку порта обязан поддерживать порт в актуальном состоянии и обеспечивать его корректную работу. Подробное описание обязанностей ответственного за поддержку порта приведено в разделе Задача для сопровождающих портов.
Сопровождающий добровольно поддерживает порт в рабочем состоянии. Сопровождающие несут основную ответственность за свои порты, но не имеют исключительных прав на них. Порты существуют для пользы сообщества и, по сути, принадлежат сообществу. Это означает, что люди, не являющиеся сопровождающими, также могут вносить изменения в порт. Крупные изменения в коллекции портов могут потребовать правок во многих портах. Команда управления портами FreeBSD или члены других команд могут изменять порты для исправления проблем с зависимостями или других проблем, таких как обновление версии динамической библиотеки. Некоторые типы исправлений имеют "автоматическое согласование" от Группа Менеджеров Дерева Портов FreeBSD <portmgr@FreeBSD.org>, что позволяет любому коммиттеру исправлять эти категории проблем в любом порте. Такие исправления не требуют одобрения от сопровождающего. Автоматическое согласование для большинства портов применяется к исправлениям, таким как изменения инфраструктуры, или тривиальным и проверенным исправлениям сборки и выполнения. Текущий список доступен в разделе Портов Руководства коммиттера. |
Другие изменения в порте будут отправлены сопровождающему на проверку и утверждение перед внесением. Если сопровождающий не отвечает на запрос об обновлении в течение двух недель (за исключением основных государственных праздников), это считается превышением времени ожидания сопровождающего, и обновление может быть внесено без его явного одобрения. Если сопровождающий не отвечает в течение трех месяцев или если произошло три последовательных превышения времени ожидания, то сопровождающий считается отсутствующим без уведомления, и все его порты могут быть возвращены в общий пул. Исключениями являются порты, сопровождаемые Группа Менеджеров Дерева Портов FreeBSD <portmgr@FreeBSD.org> или Группа Офицеров Безопасности <security-officer@FreeBSD.org>. Никакие несанкционированные изменения не могут быть внесены в порты, сопровождаемые этими группами.
Мы оставляем за собой право изменять представленные сопровождающим материалы, чтобы лучше соответствовать существующим политикам и стилю Коллекции портов, без явного одобрения отправителя или сопровождающего. Кроме того, масштабные инфраструктурные изменения могут привести к модификации порта без согласия сопровождающего. Подобные изменения никогда не повлияют на функциональность порта.
Группа Менеджеров Дерева Портов FreeBSD <portmgr@FreeBSD.org> оставляет за собой право отозвать или изменить права сопровождающего по любой причине, а Группа Офицеров Безопасности <security-officer@FreeBSD.org> оставляет за собой право отозвать или изменить права сопровождающего по соображениям безопасности.
5.6. COMMENT
Комментарий — это однострочное описание порта, отображаемое командой pkg info. При составлении придерживайтесь следующих правил:
Строка COMMENT должна быть не длиннее 70 символов.
Не включайте название пакета или номер версии программного обеспечения.
Комментарий должен начинаться с заглавной буквы и заканчиваться без точки.
Не начинайте с неопределённого артикля (то есть A или An).
Пишите названия с заглавной буквы, например: Apache, JavaScript или Perl.
Используйте запятую для списков слов: "green, red, and blue."
Проверяйте на наличие орфографических ошибок.
Вот пример:
COMMENT= Cat chasing a mouse all over the screen
Переменная COMMENT следует сразу за переменной MAINTAINER в файле Makefile.
5.7. Веб-сайт проекта
Каждый порт должен указывать на веб-сайт, предоставляющий дополнительную информацию о программном обеспечении.
Везде, где это возможно, следует использовать официальный сайт проекта, поддерживаемый разработчиками программного обеспечения.
WWW= https://ffmpeg.org/
Но это также может быть каталог или ресурс в репозитории исходного кода:
WWW= https://sourceforge.net/projects/mpd/
Переменная WWW следует сразу за переменной COMMENT в файле Makefile.
Если один и тот же контент доступен по HTTP и HTTPS, следует использовать URL, начинающийся с https://. Если URI является корнем веб-сайта или директории, он должен заканчиваться косой чертой.
Эта информация ранее размещалась в последней строке файла pkg-descr. Она была перенесена в Makefile для удобства обслуживания и обработки. Наличие строки WWW: в конце файла pkg-descr считается устаревшим.
5.8. Лицензии
Каждый порт должен содержать документацию о лицензии, под которой он распространяется. Если лицензия не одобрена OSI, необходимо также указать любые ограничения на распространение.
5.8.1. LICENSE
Краткое название лицензии или лицензий, если применяется более одной лицензии.
Если это одна из лицензий, перечисленных в Предопределенный список лицензий, можно задать только переменные LICENSE_FILE и LICENSE_DISTFILES.
Если это лицензия, которая не определена в рамках портов (см. Список предопределённых лицензий), необходимо задать LICENSE_PERMS и LICENSE_NAME, а также LICENSE_FILE или LICENSE_TEXT. Также можно задать LICENSE_DISTFILES и LICENSE_GROUPS, но это не обязательно.
Предопределенные лицензии показаны в Список предопределенных лицензий. Текущий список всегда доступен в Mk/bsd.licenses.db.mk.
Когда в файле README какого-либо программного обеспечения указано: «Данное программное обеспечение распространяется на условиях GNU Lesser General Public License, опубликованной Free Software Foundation; либо версии 2.1 Лицензии, либо (по вашему выбору) любой более поздней версии», но сам файл лицензии не предоставлен, используйте следующее:
LICENSE= LGPL21+
Когда программное обеспечение предоставляет файл лицензии, используйте это:
LICENSE= LGPL21+
LICENSE_FILE= ${WRKSRC}/COPYINGДля предопределённых лицензий права по умолчанию: dist-mirror dist-sell pkg-mirror pkg-sell auto-accept.
| Короткое имя | Имя | Группа | Разрешения |
|---|---|---|---|
| Универсальная общественная лицензия GNU Affero версии 3 |
| (по умолчанию) |
| Универсальная общественная лицензия GNU Affero версии 3 (или позднее) |
| (по умолчанию) |
| Apache License 1.0 |
| (по умолчанию) |
| Apache License 1.1 |
| (по умолчанию) |
| Apache License 2.0 |
| (по умолчанию) |
| Художественная лицензия версия 1.0 |
| (по умолчанию) |
| Художественная лицензия версии 2.0 |
| (по умолчанию) |
| Художественная лицензия (perl) версия 1.0 |
| (по умолчанию) |
| Лицензия BSD, общая версия (устарела) |
| (по умолчанию) |
| BSD 2-пунктная лицензия "Упрощенная" |
| (по умолчанию) |
| BSD 3-пунктная лицензия "Новая" или "Пересмотренная" |
| (по умолчанию) |
| BSD 4-пунктная лицензия "Оригинальная" или "Старая" |
| (по умолчанию) |
| Лицензия программного обеспечения Boost |
| (по умолчанию) |
| Creative Commons с указанием авторства 1.0 | (по умолчанию) | |
| Creative Commons с указанием авторства 2.0 | (по умолчанию) | |
| Creative Commons с указанием авторства 2.5 | (по умолчанию) | |
| Creative Commons с указанием авторства 3.0 | (по умолчанию) | |
| Creative Commons с указанием авторства 4.0 | (по умолчанию) | |
| Creative Commons с указанием авторства – некоммерческая 1.0 |
| |
| Creative Commons с указанием авторства – некоммерческая 2.0 |
| |
| Creative Commons с указанием авторства – некоммерческая 2.5 |
| |
| Creative Commons с указанием авторства – некоммерческая 3.0 |
| |
| Creative Commons с указанием авторства – некоммерческая 4.0 |
| |
| Creative Commons с указанием авторства – некоммерческая – без производных 1.0 |
| |
| Creative Commons с указанием авторства – некоммерческая – без производных 2.0 |
| |
| Creative Commons с указанием авторства – некоммерческая – без производных 2.5 |
| |
| Creative Commons с указанием авторства – некоммерческая – без производных 3.0 |
| |
| Creative Commons с указанием авторства – некоммерческая – без производных 4.0 |
| |
| Creative Commons с указанием авторства – некоммерческая – на тех же условиях 1.0 |
| |
| Creative Commons с указанием авторства – некоммерческая – на тех же условиях 2.0 |
| |
| Creative Commons с указанием авторства – некоммерческая – на тех же условиях 2.5 |
| |
| Creative Commons с указанием авторства – некоммерческая – на тех же условиях 3.0 |
| |
| Creative Commons с указанием авторства – некоммерческая – на тех же условиях 4.0 |
| |
| Creative Commons с указанием авторства – без производных 1.0 | (по умолчанию) | |
| Creative Commons с указанием авторства – без производных 2.0 | (по умолчанию) | |
| Creative Commons с указанием авторства – без производных 2.5 | (по умолчанию) | |
| Creative Commons с указанием авторства – без производных 3.0 | (по умолчанию) | |
| Creative Commons с указанием авторства – без производных 4.0 | (по умолчанию) | |
| Creative Commons с указанием авторства – на тех же условиях 1.0 | (по умолчанию) | |
| Creative Commons с указанием авторства – на тех же условиях 2.0 | (по умолчанию) | |
| Creative Commons с указанием авторства – на тех же условиях 2.5 | (по умолчанию) | |
| Creative Commons с указанием авторства – на тех же условиях 3.0 | (по умолчанию) | |
| Creative Commons с указанием авторства – на тех же условиях 4.0 | (по умолчанию) | |
| Creative Commons Zero v1.0 Universal (Отказ от прав 1.0 Универсальная) |
| (по умолчанию) |
| Лицензия на совместную разработку и распространение |
| (по умолчанию) |
| Публичная лицензия общего распространения с указанием авторства |
| (по умолчанию) |
| Уточнённая художественная лицензия |
| (по умолчанию) |
| Публичная лицензия Eclipse |
| (по умолчанию) |
| GNU Свободная лицензия на документацию |
| (по умолчанию) |
| Модифицированная Общедоступная лицензия GNAT |
| (по умолчанию) |
| Универсальная общественная лицензия GNU версии 1 |
| (по умолчанию) |
| Универсальная общественная лицензия GNU версии 1 (или более поздняя) |
| (по умолчанию) |
| Универсальная общественная лицензия GNU версии 2 |
| (по умолчанию) |
| Универсальная общественная лицензия GNU версии 2 (или более поздняя) |
| (по умолчанию) |
| Универсальная общественная лицензия GNU версии 3 |
| (по умолчанию) |
| Универсальная общественная лицензия GNU версии 3 (или более поздняя) |
| (по умолчанию) |
| Исключение для библиотеки времени выполнения GNU GPL версии 3 |
| (по умолчанию) |
| Исключение для библиотеки времени выполнения GNU GPL версии 3 (или более поздняя) |
| (по умолчанию) |
| Лицензия Internet Systems Consortium |
| (по умолчанию) |
| Общедоступная лицензия GNU для библиотек, версия 2.0 |
| (по умолчанию) |
| Общедоступная лицензия GNU для библиотек, версия 2.0 (или более поздняя) |
| (по умолчанию) |
| Универсальная общественная лицензия GNU ограниченного применения, версия 2.1 |
| (по умолчанию) |
| Универсальная общественная лицензия GNU ограниченного применения, версия 2.1 (или более поздняя) |
| (по умолчанию) |
| Универсальная общественная лицензия GNU ограниченного применения, версия 3 |
| (по умолчанию) |
| Универсальная общественная лицензия GNU ограниченного применения, версия 3 (или более поздней) |
| (по умолчанию) |
| Публичная лицензия проекта LaTeX, версия 1.0 |
|
|
| Публичная лицензия проекта LaTeX, версия 1.1 |
|
|
| Публичная лицензия проекта LaTeX, версия 1.2 |
|
|
| Публичная лицензия проекта LaTeX, версия 1.3 |
|
|
| Публичная лицензия проекта LaTeX, версия 1.3a |
|
|
| Публичная лицензия проекта LaTeX, версия 1.3b |
|
|
| Публичная лицензия проекта LaTeX, версия 1.3c |
|
|
| Лицензия MIT / Лицензия X11 |
| (по умолчанию) |
| Публичная лицензия Mozilla, версия 1.0 |
| (по умолчанию) |
| Публичная лицензия Mozilla, версия 1.1 |
| (по умолчанию) |
| Публичная лицензия Mozilla, версия 2.0 |
| (по умолчанию) |
| Открытая лицензия Университета Иллинойса/NCSA |
| (по умолчанию) |
| Лицензия не указана |
| |
| Лицензия SIL Open Font версия 1.0 (https://scripts.sil.org/OFL/) |
| (по умолчанию) |
| Лицензия SIL Open Font версия 1.1 (https://scripts.sil.org/OFL/) |
| (по умолчанию) |
| Лицензия Открытых Произведений (owl.apotheon.org) |
| (по умолчанию) |
| Лицензия OpenSSL |
| (по умолчанию) |
| Общественное достояние |
| (по умолчанию) |
| Лицензия PHP версии 2.02 |
| (по умолчанию) |
| Лицензия PHP версии 3.0 |
| (по умолчанию) |
| Лицензия PHP версии 3.01 |
| (по умолчанию) |
| Лицензия Python Software Foundation |
| (по умолчанию) |
| Лицензия PostgreSQL |
| (по умолчанию) |
| Лицензия Ruby |
| (по умолчанию) |
| Отказ от лицензии (The Unlicense) |
| (по умолчанию) |
| Публичная лицензия "Делай что хочешь" версия 2 |
| (по умолчанию) |
| Публичная лицензия "Делай что хочешь" версия 1 |
| (по умолчанию) |
| Лицензия zlib |
| (по умолчанию) |
| Публичная лицензия Zope версия 2.1 |
| (по умолчанию) |
5.8.2. LICENSE_PERMS и LICENSE_PERMS_NAME_
Разрешения. Используйте none, если пусто.
dist-mirrorРазрешается распространение дистрибутивных файлов. Дистрибутивные файлы будут добавлены в CDN
MASTER_SITE_BACKUPFreeBSD.
no-dist-mirrorРаспространение дистрибутивных файлов запрещено. Это эквивалентно установке
RESTRICTED. Дистрибутивные файлы не будут добавлены в CDNMASTER_SITE_BACKUPFreeBSD.
dist-sellПродажа файлов дистрибутива разрешена. Файлы дистрибутива будут присутствовать на образах установщика.
no-dist-sellПродажа файлов дистрибутива запрещена. Это эквивалентно установке
NO_CDROM.
pkg-mirrorСвободное распространение пакета разрешено. Пакет будет распространяться через CDN пакетов FreeBSD https://pkg.freebsd.org/.
no-pkg-mirrorСвободное распространение пакета запрещено. Эквивалентно установке
NO_PACKAGE. Пакет не будет распространяться через FreeBSD CDN для пакетов https://pkg.freebsd.org/.
pkg-sellПродажа пакета разрешена. Пакет будет присутствовать на образах установщика.
no-pkg-sellПродажа пакета запрещена. Это эквивалентно установке
NO_CDROM. Пакет не будет присутствовать на образах установщика.
auto-acceptЛицензия принимается по умолчанию. Запросы на принятие лицензии не отображаются, если пользователь не определил
LICENSES_ASK. Используйте это, если в лицензии не указано, что пользователь должен принять условия лицензии.
no-auto-acceptЛицензия не принимается по умолчанию. Пользователь всегда будет запрошен на подтверждение принятия данной лицензии. Это должно использоваться, если лицензия требует, чтобы пользователь принял её условия.
Когда присутствуют и permission, и no-permission, то no-permission отменяет permission.
Когда permission отсутствует, это считается как no-permission.
Некоторые отсутствующие разрешения могут сделать порт (и все зависящие от него порты) непригодными для использования пользователями пакетов: Порт без разрешения Порт без разрешения |
Прочитайте условия лицензии и переведите их, используя доступные разрешения.
LICENSE= UNKNOWN
LICENSE_NAME= unknown
LICENSE_TEXT= This program is NOT in public domain.\
It can be freely distributed for non-commercial purposes only.
LICENSE_PERMS= dist-mirror no-dist-sell pkg-mirror no-pkg-sell auto-acceptПрочитайте условия лицензии и укажите их, используя доступные разрешения. В случае сомнений обратитесь за разъяснениями на Список рассылки, посвящённый Портам FreeBSD.
LICENSE= WARSOW GPLv2
LICENSE_COMB= multi
LICENSE_NAME_WARSOW= Warsow Content License
LICENSE_FILE_WARSOW= ${WRKSRC}/docs/license.txt
LICENSE_PERMS_WARSOW= dist-mirror pkg-mirror auto-acceptКогда разрешения лицензий GPLv2 и UNKNOWN смешиваются, порт получает dist-mirror dist-sell pkg-mirror pkg-sell auto-accept dist-mirror no-dist-sell pkg-mirror no-pkg-sell auto-accept. Опции no-разрешения отменяют соответствующие разрешения. Итоговый список разрешений: dist-mirror pkg-mirror auto-accept. Файлы дистрибутива и пакеты не будут доступны в образах установщика.
5.8.3. LICENSE_GROUPS и LICENSE_GROUPS_NAME
Группы, к которым принадлежит лицензия.
FSFОдобрено Free Software Foundation, см. Команда по лицензированию и соответствию FSF.
GPLСовместимые с GPL
OSIОдобрено OSI, см. страницу Открытых лицензий.
COPYFREEСоответствует определению стандарта Copyfree, см. страницу лицензий Copyfree.
FONTSЛицензии на шрифты
5.8.4. LICENSE_NAME и LICENSE_NAME_NAME
Полное название лицензии.
LICENSE_NAMELICENSE= UNRAR
LICENSE_NAME= UnRAR License
LICENSE_FILE= ${WRKSRC}/license.txt
LICENSE_PERMS= dist-mirror dist-sell pkg-mirror pkg-sell auto-accept5.8.5. LICENSE_FILE и LICENSE_FILE_NAME
Полный путь к файлу, содержащему текст лицензии, обычно ${WRKSRC}/some/file. Если файл отсутствует в дистрибутиве, а его содержимое слишком длинное для размещения в LICENSE_TEXT, поместите его в новый файл в ${FILESDIR}.
LICENSE_FILELICENSE= GPLv3+
LICENSE_FILE= ${WRKSRC}/COPYING5.8.6. LICENSE_TEXT и LICENSE_TEXT_NAME
Текст для использования в качестве лицензии. Полезно, когда лицензия отсутствует в файлах дистрибутива и её текст краток.
LICENSE_TEXTLICENSE= UNKNOWN
LICENSE_NAME= unknown
LICENSE_TEXT= This program is NOT in public domain.\
It can be freely distributed for non-commercial purposes only,\
and THERE IS NO WARRANTY FOR THIS PROGRAM.
LICENSE_PERMS= dist-mirror no-dist-sell pkg-mirror no-pkg-sell auto-accept5.8.7. LICENSE_DISTFILES и LICENSE_DISTFILES_NAME
Файлы дистрибутива, к которым применяются лицензии. По умолчанию — все файлы дистрибутива.
LICENSE_DISTFILESИспользуется, когда файлы дистрибутива имеют разные лицензии. Например, один файл имеет лицензию на код, а другой содержит некоторые произведения искусства, которые нельзя распространять:
MASTER_SITES= SF/some-game
DISTFILES= ${DISTNAME}${EXTRACT_SUFX} artwork.zip
LICENSE= BSD3CLAUSE ARTWORK
LICENSE_COMB= dual
LICENSE_NAME_ARTWORK= The game artwork license
LICENSE_TEXT_ARTWORK= The README says that the files cannot be redistributed
LICENSE_PERMS_ARTWORK= pkg-mirror pkg-sell auto-accept
LICENSE_DISTFILES_BSD3CLAUSE= ${DISTNAME}${EXTRACT_SUFX}
LICENSE_DISTFILES_ARTWORK= artwork.zip5.8.8. LICENSE_COMB
Установите значение multi, если применяются все лицензии. Установите значение dual, если применяется любая из лицензий. По умолчанию используется значение single.
Когда порт содержит указание «Это программное обеспечение может распространяться под GNU General Public License или Artistic License», это означает, что можно использовать любую из этих лицензий. Используйте следующее:
LICENSE= ART10 GPLv1 LICENSE_COMB= dual
Если предоставлены файлы лицензий, используйте это:
LICENSE= ART10 GPLv1
LICENSE_COMB= dual
LICENSE_FILE_ART10= ${WRKSRC}/Artistic
LICENSE_FILE_GPLv1= ${WRKSRC}/CopyingЕсли часть порта имеет одну лицензию, а другая часть — другую, используйте multi:
LICENSE= GPLv2 LGPL21+ LICENSE_COMB= multi
5.9. PORTSCOUT
Portscout — это автоматизированная утилита проверки distfile для Коллекции портов FreeBSD, подробно описанная в Portscout: сканирование distfile портов FreeBSD.
PORTSCOUT определяет специальные условия, в рамках которых работа сканера дистрибутивных файлов Portscout ограничена.
Ситуации, когда установлена переменная PORTSCOUT, включают:
Когда необходимо игнорировать distfiles для определённых версий. Например, чтобы исключить версию 8.2 и версию 8.3 из проверок версий distfiles, так как известно, что они неработоспособны, добавьте:
PORTSCOUT= skipv:8.2,8.3
Когда проверки версий distfile необходимо полностью отключить. Например, если порт больше не будет обновляться, добавьте:
PORTSCOUT= ignore:1
Когда необходимо проверять конкретные версии или определенные мажорные и минорные редакции distfile. Например, если нужно отслеживать только версию 0.6.4, потому что более новые версии имеют проблемы совместимости с FreeBSD, добавьте:
PORTSCOUT= limit:^0\.6\.4
Когда URL-адреса, перечисляющие доступные версии, отличаются от URL-адресов загрузки. Например, чтобы ограничить проверку версий distfile страницей загрузки для пакета: databases/pgtune добавьте:
PORTSCOUT= site:http://www.renpy.org/dl/release/
5.10. Зависимости
Многие порты зависят от других портов. Это очень удобная особенность большинства Unix-подобных операционных систем, включая FreeBSD. Несколько портов могут использовать общую зависимость вместо того, чтобы включать эту зависимость в каждый порт или пакет, который в ней нуждается. Существует семь переменных, которые можно использовать для обеспечения наличия всех необходимых компонентов на машине пользователя. Также есть предопределенные переменные зависимостей для распространенных случаев и несколько дополнительных для управления поведением зависимостей.
Когда у программного обеспечения есть дополнительные зависимости, предоставляющие дополнительные возможности, основные зависимости, перечисленные в |
5.10.1. LIB_DEPENDS
Эта переменная определяет разделяемые библиотеки, от которых зависит данный порт. Это список кортежей вида lib:dir, где lib — имя разделяемой библиотеки, а dir — директория, в которой её следует искать, если она недоступна. Например,
LIB_DEPENDS= libjpeg.so:graphics/jpeg
проверит наличие общей библиотеки jpeg с любой версией и перейдет в подкаталог graphics/jpeg дерева портов, чтобы собрать и установить её, если она не найдена.
Зависимость проверяется дважды: один раз внутри цели build и затем внутри цели install. Также имя зависимости добавляется в пакет, чтобы pkg install (см. pkg-install(8)) автоматически установил её, если её нет в системе пользователя.
5.10.2. RUN_DEPENDS
Эта переменная определяет исполняемые файлы или файлы, от которых зависит порт во время выполнения. Это список кортежей path:dir[:target], где path — это имя исполняемого файла или файла, dir — директория, в которой его следует искать, если он недоступен, а target — цель, которую нужно вызвать в этой директории. Если path начинается с косой черты (/), он считается файлом, и его существование проверяется с помощью test -e; в противном случае предполагается, что это исполняемый файл, и which -s используется для проверки наличия программы в пути поиска.
Например,
RUN_DEPENDS= ${LOCALBASE}/news/bin/innd:news/inn \
xmlcatmgr:textproc/xmlcatmgrпроверит, существует ли файл или каталог /usr/local/news/bin/innd, и соберет и установит его из подкаталога news/inn дерева портов, если он не найден. Также будет проверено, находится ли исполняемый файл xmlcatmgr в пути поиска, и если он не найден, будет выполнен переход в textproc/xmlcatmgr для сборки и установки.
В этом случае |
Официальный путь поиска /sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin |
Зависимость проверяется внутри цели install. Также имя зависимости добавляется в пакет, чтобы команда pkg install (см. pkg-install(8)) автоматически установила её, если она отсутствует в системе пользователя. Часть target может быть опущена, если она совпадает с DEPENDS_TARGET.
Довольно распространённая ситуация, когда RUN_DEPENDS буквально совпадает с BUILD_DEPENDS, особенно если портируемое программное обеспечение написано на скриптовом языке или требует одинаковой среды для сборки и выполнения. В этом случае возникает соблазн и интуитивное желание напрямую присвоить одно другому:
RUN_DEPENDS= ${BUILD_DEPENDS}Однако такое присваивание может загрязнить зависимости во время выполнения записями, не определёнными в оригинальном BUILD_DEPENDS порта. Это происходит из-за ленивого вычисления присваивания переменных в make(1). Рассмотрим Makefile с USE_*, которые обрабатываются ports/Mk/bsd.*.mk для добавления начальных зависимостей сборки. Например, USES= gmake добавляет devel/gmake в BUILD_DEPENDS. Чтобы предотвратить попадание таких дополнительных зависимостей в RUN_DEPENDS, создайте другую переменную с текущим содержимым BUILD_DEPENDS и присвойте её как BUILD_DEPENDS, так и RUN_DEPENDS:
MY_DEPENDS= some:devel/some \
other:lang/other
BUILD_DEPENDS= ${MY_DEPENDS}
RUN_DEPENDS= ${MY_DEPENDS}Не используйте |
5.10.3. BUILD_DEPENDS
Эта переменная указывает исполняемые файлы или файлы, необходимые для сборки данного порта. Как и RUN_DEPENDS, это список кортежей path:dir[:target]. Например,
BUILD_DEPENDS= unzip:archivers/unzip
проверит наличие исполняемого файла с именем unzip и перейдет в подкаталог archivers/unzip дерева портов, чтобы собрать и установить его, если он не будет найден.
"build" здесь означает все процессы от извлечения до компиляции. Зависимость проверяется внутри цели |
5.10.4. FETCH_DEPENDS
Эта переменная определяет исполняемые файлы или файлы, необходимые для загрузки этого порта. Как и предыдущие две, это список кортежей path:dir[:target]. Например,
FETCH_DEPENDS= ncftp2:net/ncftp2
проверит наличие исполняемого файла с именем ncftp2 и перейдет в подкаталог net/ncftp2 дерева портов для сборки и установки, если файл не будет найден.
Зависимость проверяется внутри цели fetch. Часть target может быть опущена, если она совпадает с DEPENDS_TARGET.
5.10.5. EXTRACT_DEPENDS
Эта переменная указывает исполняемые файлы или файлы, которые требуются для извлечения данного порта. Как и предыдущая, это список кортежей path:dir[:target]. Например,
EXTRACT_DEPENDS= unzip:archivers/unzip
проверит наличие исполняемого файла с именем unzip и перейдет в подкаталог archivers/unzip дерева портов, чтобы собрать и установить его, если он не будет найден.
Зависимость проверяется внутри цели extract. Часть target может быть опущена, если она совпадает с DEPENDS_TARGET.
Используйте эту переменную только если извлечение уже не работает (по умолчанию предполагается |
5.10.6. PATCH_DEPENDS
Эта переменная указывает исполняемые файлы или файлы, которые требуются этому порту для применения патчей. Как и предыдущая, это список кортежей path:dir[:target]. Например,
PATCH_DEPENDS= ${NONEXISTENT}:java/jfc:extractбудет спускаться в подкаталог java/jfc дерева портов для его извлечения.
Зависимость проверяется в рамках цели patch. Часть target может быть опущена, если она совпадает с DEPENDS_TARGET.
5.10.7. USES
Параметры могут быть добавлены для определения различных функций и зависимостей, используемых портом. Они указываются путем добавления этой строки в Makefile:
USES= feature[:arguments]
Для полного списка значений обратитесь к Использование макросов USES.
|
5.10.8. USE_*
Существует несколько переменных для определения общих зависимостей, используемых многими портами. Их использование необязательно, но помогает сократить многословность Makefile портов. Каждая из них оформлена как USE_*. Эти переменные могут использоваться только в Makefile портов и ports/Mk/bsd.*.mk. Они не предназначены для настраиваемых пользователем опций — для этой цели используйте PORT_OPTIONS.
Всегда неправильно устанавливать любые USE_GCC=X.Y (где X.Y — номер версии) добавит зависимость от gccXY для каждого порта, включая сам |
| Переменная | Значение | ||
|---|---|---|---|
| Порт требует GCC ( Например: USE_GCC=yes # порт требует текущей версии GCC USE_GCC=11:build # порт требует GCC 11 только во время сборки
|
Переменные, связанные с gmake и configure, описаны в Механизмы сборки, тогда как autoconf, automake и libtool описаны в Использование GNU Autotools. Переменные, связанные с Perl, описаны в Использование Perl. Переменные X11 перечислены в Использование X11. Использование GNOME посвящено GNOME, а Использование KDE — переменным, связанным с KDE. Использование Java документирует переменные Java, тогда как Веб-приложения содержит информацию о модулях Apache, PHP и PEAR. Python обсуждается в Использование Python, а Ruby — в Использование Ruby. Использование SDL предоставляет переменные, используемые для приложений SDL, и, наконец, Использование Xfce содержит информацию о Xfce.
5.10.9. Минимальная версия зависимого пакета
Минимальная версия зависимого пакета может быть указана в любом *_DEPENDS, кроме LIB_DEPENDS, используя следующий синтаксис:
p5-Spiffy>=0.26:devel/p5-Spiffy
Первое поле содержит имя зависимого пакета, которое должно соответствовать записи в базе данных пакетов, знак сравнения и версию пакета. Зависимость считается удовлетворённой, если на машине установлен p5-Spiffy-0.26 или новее.
5.10.10. Заметки о зависимостях
Как упомянуто выше, цель по умолчанию, вызываемая при необходимости зависимости, — это DEPENDS_TARGET. По умолчанию она установлена в install. Это пользовательская переменная; она никогда не определяется в Makefile порта. Если порту требуется особый способ обработки зависимости, используйте часть :target в *_DEPENDS вместо переопределения DEPENDS_TARGET.
При выполнении make clean зависимости портов также автоматически очищаются. Если это нежелательно, определите переменную NOCLEANDEPENDS в окружении. Это может быть особенно полезно, если среди зависимостей порта есть что-то, что требует много времени для пересборки, например KDE, GNOME или Mozilla.
Для безусловной зависимости от другого порта используйте переменную ${NONEXISTENT} в качестве первого поля BUILD_DEPENDS или RUN_DEPENDS. Используйте это только в случае, когда необходим исходный код другого порта. Время компиляции можно сократить, указав также цель. Например
BUILD_DEPENDS= ${NONEXISTENT}:graphics/jpeg:extractвсегда будет переходить к порту jpeg и извлекать его.
5.10.11. Циклические зависимости фатальны
Не создавайте циклических зависимостей в дереве портов! |
Технология сборки портов не допускает циклических зависимостей. Если такая зависимость будет добавлена, у кого-то в мире почти сразу окажется сломанной установка FreeBSD, а за этим последуют многие другие. Подобные проблемы бывает очень сложно обнаружить. Если есть сомнения, перед внесением изменений обязательно выполните: cd /usr/ports; make index. Этот процесс может быть довольно медленным на старых машинах, но он способен избавить множество людей, включая вас, от серьёзных проблем.
5.10.12. Проблемы, вызванные автоматическими зависимостями
Зависимости должны быть объявлены явно или с использованием OPTIONS framework. Использование других методов, таких как автоматическое обнаружение, усложняет индексацию, что вызывает проблемы для управления портами и пакетами.
.include <bsd.port.pre.mk>
.if exists(${LOCALBASE}/bin/foo)
LIB_DEPENDS= libbar.so:foo/bar
.endifПроблема с попыткой автоматического добавления зависимостей заключается в том, что файлы и настройки за пределами отдельного порта могут измениться в любой момент. Например: индекс строится, затем устанавливается группа портов. Но один из портов устанавливает проверяемый файл. Теперь индекс неверен, потому что у установленного порта неожиданно появилась новая зависимость. Индекс может оставаться неверным даже после пересборки, если другие порты также определяют свою потребность в зависимостях на основе существования других файлов.
OPTIONS_DEFINE= BAR BAR_DESC= Calling cellphones via bar BAR_LIB_DEPENDS= libbar.so:foo/bar
Проверка переменных опций является правильным методом. Это не вызовет несоответствий в индексе группы портов, при условии что опции были определены до сборки индекса. Затем можно использовать простые скрипты для автоматизации сборки, установки и обновления этих портов и их пакетов.
5.11. Подчиненные порты и MASTERDIR
Если порту необходимо собирать немного разные версии пакетов, используя переменную (например, разрешение или размер бумаги) с разными значениями, создайте по одному подкаталогу для каждого пакета, чтобы пользователям было проще понять, что делать, но старайтесь максимально использовать общие файлы между портами. Обычно, при грамотном использовании переменных, во всех каталогах, кроме одного, требуется лишь очень короткий Makefile. В единственном Makefile укажите директорию с остальными файлами с помощью MASTERDIR. Также используйте переменную как часть PKGNAMESUFFIX, чтобы пакеты имели разные имена.
Это лучше всего продемонстрировать на примере. Это часть файла print/pkfonts300/Makefile;
PORTNAME= pkfonts${RESOLUTION}
PORTVERSION= 1.0
DISTFILES= pk${RESOLUTION}.tar.gz
PLIST= ${PKGDIR}/pkg-plist.${RESOLUTION}
.if !defined(RESOLUTION)
RESOLUTION= 300
.else
.if ${RESOLUTION} != 118 && ${RESOLUTION} != 240 && \
${RESOLUTION} != 300 && ${RESOLUTION} != 360 && \
${RESOLUTION} != 400 && ${RESOLUTION} != 600
.BEGIN:
@${ECHO_MSG} "Error: invalid value for RESOLUTION: \"${RESOLUTION}\""
@${ECHO_MSG} "Possible values are: 118, 240, 300, 360, 400 and 600."
@${FALSE}
.endif
.endifПакет print/pkfonts300 также содержит все обычные исправления, файлы пакетов и т.д. При запуске make в этом месте будет взято значение разрешения по умолчанию (300), и порт будет собран в обычном режиме.
Что касается других разрешений, это полный print/pkfonts360/Makefile:
RESOLUTION= 360
MASTERDIR= ${.CURDIR}/../pkfonts300
.include "${MASTERDIR}/Makefile"(print/pkfonts118/Makefile, print/pkfonts600/Makefile и все остальные аналогичны). Определение MASTERDIR указывает bsd.port.mk, что стандартный набор подкаталогов, таких как FILESDIR и SCRIPTDIR, следует искать в pkfonts300. Строка RESOLUTION=360 переопределит строку RESOLUTION=300 в pkfonts300/Makefile, и порт будет собран с разрешением, установленным на 360.
5.12. Страницы Cправочника
Если порт размещает дерево man в другом месте, отличном от PREFIX, используйте MANDIRS для указания этих каталогов. Обратите внимание, что файлы, соответствующие страницам руководства, должны быть добавлены в pkg-plist вместе с остальными файлами. Назначение MANDIRS — обеспечить автоматическое сжатие страниц руководства, поэтому имена файлов имеют суффикс .gz.
5.13. Файлы информации
Если пакету требуется установить файлы GNU info, перечислите их в INFO (без завершающего .info), по одному документу на строку. Предполагается, что эти файлы будут установлены в PREFIX/INFO_PATH. Измените INFO_PATH, если пакет использует другое расположение. Однако это не рекомендуется. Эти записи содержат только путь относительно PREFIX/INFO_PATH. Например, пакет lang/gcc34 устанавливает файлы info в PREFIX/INFO_PATH/gcc34, и INFO будет выглядеть примерно так:
INFO= gcc34/cpp gcc34/cppinternals gcc34/g77 ...
Соответствующий код установки/удаления будет автоматически добавлен во временный файл pkg-plist перед регистрацией пакета.
5.14. Параметры Makefile
Многие приложения могут быть собраны с дополнительными или различными конфигурациями. Примеры включают выбор естественного (человеческого) языка, графический интерфейс или командная строка, тип поддерживаемой базы данных. Пользователям может потребоваться конфигурация, отличная от стандартной, поэтому система портов предоставляет хуки, которые автор порта может использовать для управления вариантом сборки. Правильная поддержка этих опций сделает пользователей счастливыми и эффективно предоставит два или более порта по цене одного.
5.14.1. OPTIONS
5.14.1.1. Пояснения
OPTIONS_* предоставляют пользователю, устанавливающему порт, диалоговое окно с доступными опциями, после чего сохраняют выбранные опции в ${PORT_DBDIR}/${OPTIONS_NAME}/options. При следующей сборке порта эти опции будут использованы повторно. PORT_DBDIR по умолчанию имеет значение /var/db/ports. OPTIONS_NAME соответствует имени порта (origin) с заменой разделителя на подчёркивания, например, для dns/bind99 это будет dns_bind99.
Когда пользователь запускает make config (или впервые запускает make build), система проверяет наличие файла ${PORT_DBDIR}/${OPTIONS_NAME}/options. Если этот файл не существует, используются значения OPTIONS_*, и отображается диалоговое окно, где можно включить или отключить опции. Затем файл options сохраняется, а настроенные переменные используются при сборке порта.
Если новая версия порта добавляет новые OPTIONS, пользователю будет показан диалог с сохранёнными значениями старых OPTIONS, заполненными заранее.
make showconfig показывает сохранённую конфигурацию. Используйте make rmconfig для удаления сохранённой конфигурации.
5.14.1.2. Синтаксис
OPTIONS_DEFINE содержит список OPTIONS, которые будут использоваться. Они независимы друг от друга и не сгруппированы:
OPTIONS_DEFINE= OPT1 OPT2
После определения OPTIONS описываются (необязательно, но настоятельно рекомендуется):
OPT1_DESC= Describe OPT1 OPT2_DESC= Describe OPT2 OPT3_DESC= Describe OPT3 OPT4_DESC= Describe OPT4 OPT5_DESC= Describe OPT5 OPT6_DESC= Describe OPT6
ports/Mk/bsd.options.desc.mk содержит описания для многих распространённых OPTIONS. Хотя они часто полезны, переопределите их, если описание недостаточно для порта.
При описании параметров рассматривайте их с точки зрения пользователя: «Какую функциональность это изменяет?» и «Зачем мне включать этот параметр?» Не просто повторяйте название. Например, описание параметра |
Названия параметров всегда пишутся в верхнем регистре. Они не могут использовать смешанный регистр или нижний регистр. |
OPTIONS могут быть сгруппированы как переключаемые варианты, где допускается только один выбор из каждой группы:
OPTIONS_SINGLE= SG1 OPTIONS_SINGLE_SG1= OPT3 OPT4
В каждый момент времени должна быть выбрана одна опция из каждой группы |
OPTIONS могут быть сгруппированы как переключаемые варианты, где ни один или только один вариант из каждой группы разрешён:
OPTIONS_RADIO= RG1 OPTIONS_RADIO_RG1= OPT7 OPT8
OPTIONS также могут быть сгруппированы в виде списков "множественного выбора", где хотя бы одна опция должна быть включена:
OPTIONS_MULTI= MG1 OPTIONS_MULTI_MG1= OPT5 OPT6
OPTIONS также могут быть сгруппированы в виде списков "множественного выбора", где ни одна или любые опции могут быть включены:
OPTIONS_GROUP= GG1 OPTIONS_GROUP_GG1= OPT9 OPT10
OPTIONS по умолчанию не установлены, если они не перечислены в OPTIONS_DEFAULT:
OPTIONS_DEFAULT= OPT1 OPT3 OPT6
Определения OPTIONS должны быть указаны до включения файла bsd.port.options.mk. Значения PORT_OPTIONS можно проверять только после включения bsd.port.options.mk. Включение bsd.port.pre.mk также может использоваться и до сих пор широко применяется в портах, написанных до введения bsd.port.options.mk. Однако следует учитывать, что некоторые переменные не будут работать как ожидается после включения bsd.port.pre.mk, обычно это некоторые флаги USE_*.
OPTIONSOPTIONS_DEFINE= FOO BAR OPTIONS_DEFAULT=FOO FOO_DESC= Option foo support BAR_DESC= Feature bar support # Will add --with-foo / --without-foo FOO_CONFIGURE_WITH= foo BAR_RUN_DEPENDS= bar:bar/bar .include <bsd.port.mk>
OPTIONS порта.if ! ${PORT_OPTIONS:MEXAMPLES}
CONFIGURE_ARGS+=--without-examples
.endifПриведённая выше форма не рекомендуется. Предпочтительный метод — использование параметра configure для фактического включения и отключения функции в соответствии с опцией:
# Will add --with-examples / --without-examples EXAMPLES_CONFIGURE_WITH= examples
OPTIONSOPTIONS_DEFINE= EXAMPLES OPTIONS_DEFAULT= PGSQL LDAP SSL OPTIONS_SINGLE= BACKEND OPTIONS_SINGLE_BACKEND= MYSQL PGSQL BDB OPTIONS_MULTI= AUTH OPTIONS_MULTI_AUTH= LDAP PAM SSL EXAMPLES_DESC= Install extra examples MYSQL_DESC= Use MySQL as backend PGSQL_DESC= Use PostgreSQL as backend BDB_DESC= Use Berkeley DB as backend LDAP_DESC= Build with LDAP authentication support PAM_DESC= Build with PAM support SSL_DESC= Build with OpenSSL support # Will add USE_PGSQL=yes PGSQL_USE= pgsql=yes # Will add --enable-postgres / --disable-postgres PGSQL_CONFIGURE_ENABLE= postgres ICU_LIB_DEPENDS= libicuuc.so:devel/icu # Will add --with-examples / --without-examples EXAMPLES_CONFIGURE_WITH= examples # Check other OPTIONS .include <bsd.port.mk>
5.14.1.3. Опции по умолчанию
Эти опции всегда включены по умолчанию.
DOCS— сборка и установка документации.NLS— Поддержка родного языка.EXAMPLES— сборка и установка примеров.IPV6— Поддержка протокола IPv6.
Нет необходимости добавлять их в |
5.14.2. Автоматическая активация функций
При использовании скрипта GNU configure следите за тем, какие дополнительные функции активируются автоматическим определением. Явно отключите ненужные дополнительные функции, добавив --without-xxx или --disable-xxx в CONFIGURE_ARGS.
.if ${PORT_OPTIONS:MFOO}
LIB_DEPENDS+= libfoo.so:devel/foo
CONFIGURE_ARGS+= --enable-foo
.endifВ приведённом выше примере представьте, что библиотека libfoo установлена в системе. Пользователь не хочет, чтобы это приложение использовало libfoo, поэтому он отключил соответствующую опцию в диалоге make config. Однако скрипт configure приложения обнаруживает библиотеку в системе и включает её поддержку в итоговом исполняемом файле. Теперь, когда пользователь решает удалить libfoo из системы, система портов не протестует (зависимость от libfoo не была записана), но приложение перестаёт работать.
FOO_LIB_DEPENDS= libfoo.so:devel/foo # Will add --enable-foo / --disable-foo FOO_CONFIGURE_ENABLE= foo
В некоторых случаях сокращенный синтаксис условных выражений может вызывать проблемы со сложными конструкциями. Ошибки обычно имеют вид .if !empty(VARIABLE:MVALUE) в качестве альтернативы .if ${VARIABLE:MVALUE} |
5.14.3. Помощники параметров
Существуют макросы, которые помогают упростить условные значения, различающиеся в зависимости от установленных опций. Для удобства приведён полный список:
PLIST_SUB,SUB_LISTДля автоматической генерации
%%OPT%%и%%NOOPT%%см.OPTIONS_SUB.Для более сложных случаев использования см. Замена общих переменных.
CONFIGURE_ARGSДля информации о
--enable-xи--disable-xсм.OPT_CONFIGURE_ENABLE.О
--with-xи--without-xсм.OPT_CONFIGURE_WITH.Во всех остальных случаях см.
OPT_CONFIGURE_ONиOPT_CONFIGURE_OFF.CMAKE_ARGSДля аргументов, которые являются булевыми значениями (
on,off,true,false,0,1), см.OPT_CMAKE_BOOLиOPT_CMAKE_BOOL_OFF.Для всех остальных случаев см.
OPT_CMAKE_ONиOPT_CMAKE_OFF.MESON_ARGSДля аргументов, принимающих
trueилиfalse, см.OPT_MESON_TRUEиOPT_MESON_FALSE.Для аргументов, принимающих
yesилиno, используйтеOPT_MESON_YESиOPT_MESON_NO.Для аргументов, принимающих
enabledилиdisabled, см.OPT_MESON_ENABLEDиOPT_MESON_DISABLED.Во всех остальных случаях используйте
OPT_MESON_ONиOPT_MESON_OFF.QMAKE_ARGSUSE_**_DEPENDSСм. Зависимости.
*(Любая переменная)Наиболее используемые переменные имеют своих помощников, см. Замена Общих Переменных.
Для любой переменной без специального помощника см.
OPT_VARSиOPT_VARS_OFF.- Зависимости параметров
Когда для работы опции требуется другая опция, см.
OPT_IMPLIES.- Конфликты опций
Когда опция не может работать, если включена другая, см.
OPT_PREVENTSиOPT_PREVENTS_MSG.- Цели сборки
Когда для опции требуется дополнительная обработка, см. Дополнительные цели сборки.
5.14.3.1. OPTIONS_SUB
Если OPTIONS_SUB установлен в yes, то каждая из опций, добавленных в OPTIONS_DEFINE, будет добавлена в PLIST_SUB и SUB_LIST, например:
OPTIONS_DEFINE= OPT1 OPTIONS_SUB= yes
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
PLIST_SUB+= OPT1="" NO_OPT1="@comment "
SUB_LIST+= OPT1="" NO_OPT1="@comment "
.else
PLIST_SUB+= OPT1="@comment " NO_OPT1=""
SUB_LIST+= OPT1="@comment " NO_OPT1=""
.endifЗначение |
5.14.3.2. OPT_USE и OPT_USE_OFF
Когда выбрана опция OPT, для каждой пары ключ=значение в OPT_USE, значение добавляется к соответствующему USE_KEY. Если значение содержит пробелы, замените их запятыми, и они будут преобразованы обратно в пробелы во время обработки. OPT_USE_OFF работает аналогично, но когда OPT не выбрана. Например:
OPTIONS_DEFINE= OPT1 OPT1_USES= xorg OPT1_USE= mysql=yes xorg=x11,xextproto,xext,xrandr OPT1_USE_OFF= openssl=yes
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
USE_MYSQL= yes
USES+= xorg
USE_XORG= x11 xextproto xext xrandr
.else
USE_OPENSSL= yes
.endif5.14.3.3. Помощники CONFIGURE_ARGS
5.14.3.3.1. OPT_CONFIGURE_ENABLE
Когда выбрана опция OPT, для каждого элемента в OPT_CONFIGURE_ENABLE к CONFIGURE_ARGS добавляется --enable-элемент. Если опция OPT не выбрана, к CONFIGURE_ARGS добавляется --disable-элемент. Необязательный аргумент может быть указан с помощью символа =. Этот аргумент добавляется только к опции конфигурации --enable-элемент. Например:
OPTIONS_DEFINE= OPT1 OPT2 OPT1_CONFIGURE_ENABLE= test1 test2 OPT2_CONFIGURE_ENABLE= test2=exhaustive
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
CONFIGURE_ARGS+= --enable-test1 --enable-test2
.else
CONFIGURE_ARGS+= --disable-test1 --disable-test2
.endif
.if ${PORT_OPTIONS:MOPT2}
CONFIGURE_ARGS+= --enable-test2=exhaustive
.else
CONFIGURE_ARGS+= --disable-test2
.endif5.14.3.3.2. OPT_CONFIGURE_WITH
Когда выбрана опция OPT, для каждого элемента в OPT_CONFIGURE_WITH к CONFIGURE_ARGS добавляется --with-_элемент. Если опция OPT не выбрана, к CONFIGURE_ARGS добавляется --without-элемент. Необязательный аргумент можно указать с помощью символа =. Этот аргумент добавляется только к опции конфигурации --with-элемент. Например:
OPTIONS_DEFINE= OPT1 OPT2 OPT1_CONFIGURE_WITH= test1 OPT2_CONFIGURE_WITH= test2=exhaustive
эквивалентно:
OPTIONS_DEFINE= OPT1 OPT2
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
CONFIGURE_ARGS+= --with-test1
.else
CONFIGURE_ARGS+= --without-test1
.endif
.if ${PORT_OPTIONS:MOPT2}
CONFIGURE_ARGS+= --with-test2=exhaustive
.else
CONFIGURE_ARGS+= --without-test2
.endif5.14.3.3.3. OPT_CONFIGURE_ON и OPT_CONFIGURE_OFF
Когда выбрана опция OPT, значение OPT_CONFIGURE_ON, если оно определено, добавляется к CONFIGURE_ARGS. OPT_CONFIGURE_OFF работает аналогично, но когда OPT не выбрана. Например:
OPTIONS_DEFINE= OPT1 OPT1_CONFIGURE_ON= --add-test OPT1_CONFIGURE_OFF= --no-test
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
CONFIGURE_ARGS+= --add-test
.else
CONFIGURE_ARGS+= --no-test
.endifВ большинстве случаев помощники |
5.14.3.4. Помощники CMAKE_ARGS
5.14.3.4.1. OPT_CMAKE_ON и OPT_CMAKE_OFF
Когда выбрана опция OPT, значение OPT_CMAKE_ON, если оно определено, добавляется к CMAKE_ARGS. OPT_CMAKE_OFF работает аналогично, но когда OPT не выбрана. Например:
OPTIONS_DEFINE= OPT1 OPT1_CMAKE_ON= -DTEST:BOOL=true -DDEBUG:BOOL=true OPT1_CMAKE_OFF= -DOPTIMIZE:BOOL=true
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
CMAKE_ARGS+= -DTEST:BOOL=true -DDEBUG:BOOL=true
.else
CMAKE_ARGS+= -DOPTIMIZE:BOOL=true
.endifСм. |
5.14.3.4.2. OPT_CMAKE_BOOL и OPT_CMAKE_BOOL_OFF
Когда выбрана опция OPT, для каждого элемента в OPT_CMAKE_BOOL добавляется -D_элемент_:BOOL=true к CMAKE_ARGS. Если опция OPT не выбрана, -D_элемент_:BOOL=false добавляется к CONFIGURE_ARGS. OPT_CMAKE_BOOL_OFF работает наоборот: -D_элемент_:BOOL=false добавляется к CMAKE_ARGS, когда опция выбрана, и -D_элемент_:BOOL=true, когда опция не выбрана. Например:
OPTIONS_DEFINE= OPT1 OPT1_CMAKE_BOOL= TEST DEBUG OPT1_CMAKE_BOOL_OFF= OPTIMIZE
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
CMAKE_ARGS+= -DTEST:BOOL=true -DDEBUG:BOOL=true \
-DOPTIMIZE:BOOL=false
.else
CMAKE_ARGS+= -DTEST:BOOL=false -DDEBUG:BOOL=false \
-DOPTIMIZE:BOOL=true
.endif5.14.3.5. Помощники MESON_ARGS
5.14.3.5.1. OPT_MESON_ON и OPT_MESON_OFF
Когда выбрана опция OPT, значение OPT_MESON_ON, если оно определено, добавляется к MESON_ARGS. OPT_MESON_OFF работает аналогичным образом, но когда OPT не выбрана. Например:
OPTIONS_DEFINE= OPT1 OPT1_MESON_ON= -Dopt=1 OPT1_MESON_OFF= -Dopt=2
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
MESON_ARGS+= -Dopt=1
.else
MESON_ARGS+= -Dopt=2
.endif5.14.3.5.2. OPT_MESON_TRUE и OPT_MESON_FALSE
Когда выбрана опция OPT, для каждого элемента в OPT_MESON_TRUE добавляется -D_элемент_=true в MESON_ARGS. Если опция OPT не выбрана, добавляется -D_элемент_=false в MESON_ARGS. OPT_MESON_FALSE работает противоположным образом: -D_элемент_=false добавляется в MESON_ARGS, когда опция выбрана, и -D_элемент_=true, когда опция не выбрана. Например:
OPTIONS_DEFINE= OPT1 OPT1_MESON_TRUE= test debug OPT1_MESON_FALSE= optimize
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
MESON_ARGS+= -Dtest=true -Ddebug=true \
-Doptimize=false
.else
MESON_ARGS+= -Dtest=false -Ddebug=false \
-Doptimize=true
.endif5.14.3.5.3. OPT_MESON_YES и OPT_MESON_NO
Когда выбрана опция OPT, для каждого элемента в OPT_MESON_YES добавляется -D_элемент_=yes к MESON_ARGS. Если опция OPT не выбрана, добавляется -D_элемент_=no к MESON_ARGS. OPT_MESON_NO работает противоположным образом: -D_элемент_=no добавляется к MESON_ARGS, когда опция выбрана, и -D_элемент_=yes, когда опция не выбрана. Например:
OPTIONS_DEFINE= OPT1 OPT1_MESON_YES= test debug OPT1_MESON_NO= optimize
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
MESON_ARGS+= -Dtest=yes -Ddebug=yes \
-Doptimize=no
.else
MESON_ARGS+= -Dtest=no -Ddebug=no \
-Doptimize=yes
.endif5.14.3.5.4. OPT_MESON_ENABLED и OPT_MESON_DISABLED
Когда выбрана опция OPT, для каждого элемента в OPT_MESON_ENABLED добавляется -D_элемент_=enabled к MESON_ARGS. Когда опция OPT не выбрана, добавляется -D_элемент_=disabled к MESON_ARGS. OPT_MESON_DISABLED работает противоположным образом: -D_элемент_=disabled добавляется к MESON_ARGS, когда опция выбрана, и -D_элемент_=enabled, когда опция не выбрана. Например:
OPTIONS_DEFINE= OPT1 OPT1_MESON_ENABLED= test OPT1_MESON_DISABLED= debug
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
MESON_ARGS+= -Dtest=enabled -Ddebug=disabled
.else
MESON_ARGS+= -Dtest=disabled -Ddebug=enabled
.endif5.14.3.6. OPT_QMAKE_ON и OPT_QMAKE_OFF
Когда выбрана опция OPT, значение OPT_QMAKE_ON, если оно определено, добавляется к QMAKE_ARGS. OPT_QMAKE_OFF работает аналогичным образом, но когда OPT не выбрана. Например:
OPTIONS_DEFINE= OPT1 OPT1_QMAKE_ON= -DTEST:BOOL=true OPT1_QMAKE_OFF= -DPRODUCTION:BOOL=true
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
QMAKE_ARGS+= -DTEST:BOOL=true
.else
QMAKE_ARGS+= -DPRODUCTION:BOOL=true
.endif5.14.3.7. OPT_IMPLIES
Предоставляет способ добавления зависимостей между опциями.
При выборе OPT все перечисленные в этой переменной опции также будут выбраны. В качестве примера можно использовать описанный ранее OPT_CONFIGURE_ENABLE:
OPTIONS_DEFINE= OPT1 OPT2 OPT1_IMPLIES= OPT2 OPT1_CONFIGURE_ENABLE= opt1 OPT2_CONFIGURE_ENABLE= opt2
Эквивалентно:
OPTIONS_DEFINE= OPT1 OPT2
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
CONFIGURE_ARGS+= --enable-opt1
.else
CONFIGURE_ARGS+= --disable-opt1
.endif
.if ${PORT_OPTIONS:MOPT2} || ${PORT_OPTIONS:MOPT1}
CONFIGURE_ARGS+= --enable-opt2
.else
CONFIGURE_ARGS+= --disable-opt2
.endifOPT_IMPLIESЭтот порт имеет опцию X11 и опцию GNOME, для сборки которой необходимо выбрать опцию X11.
OPTIONS_DEFINE= X11 GNOME OPTIONS_DEFAULT= X11 X11_USES= xorg X11_USE= xorg=xi,xextproto GNOME_USE= gnome=gtk30 GNOME_IMPLIES= X11
5.14.3.8. OPT_PREVENTS и OPT_PREVENTS_MSG
Предоставляет способ добавления конфликтов между опциями.
Когда выбрана OPT, все опции, перечисленные в OPT_PREVENTS, должны быть сняты. Если задано OPT_PREVENTS_MSG и возникает конфликт, его содержимое будет показано с объяснением причины конфликта. Например:
OPTIONS_DEFINE= OPT1 OPT2 OPT1_PREVENTS= OPT2 OPT1_PREVENTS_MSG= OPT1 and OPT2 enable conflicting options
Примерно эквивалентно:
OPTIONS_DEFINE= OPT1 OPT2
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT2} && ${PORT_OPTIONS:MOPT1}
BROKEN= Option OPT1 conflicts with OPT2 (select only one)
.endifЕдинственное отличие заключается в том, что первый вариант выведет ошибку после выполнения make config, предлагая изменить выбранные настройки.
OPT_PREVENTSЭтот порт имеет опции X509 и SCTP. Обе опции добавляют патчи, но патчи конфликтуют друг с другом, поэтому их нельзя выбрать одновременно.
OPTIONS_DEFINE= X509 SCTP
SCTP_PATCHFILES= ${PORTNAME}-6.8p1-sctp-2573.patch.gz:-p1
SCTP_CONFIGURE_WITH= sctp
X509_PATCH_SITES= http://www.roumenpetrov.info/openssh/x509/:x509
X509_PATCHFILES= ${PORTNAME}-7.0p1+x509-8.5.diff.gz:-p1:x509
X509_PREVENTS= SCTP
X509_PREVENTS_MSG= X509 and SCTP patches conflict5.14.3.9. OPT_VARS и OPT_VARS_OFF
Предоставляет универсальный способ установки и добавления значений переменным.
Перед использованием |
Когда выбрана опция OPT и определены OPT_VARS, пары key=value и key+=value обрабатываются из OPT_VARS. Оператор = приводит к перезаписи существующего значения KEY, а += добавляет к значению. OPT_VARS_OFF работает аналогично, но когда OPT не выбрана.
OPTIONS_DEFINE= OPT1 OPT2 OPT3
OPT1_VARS= also_build+=bin1
OPT2_VARS= also_build+=bin2
OPT3_VARS= bin3_build=yes
OPT3_VARS_OFF= bin3_build=no
MAKE_ARGS= ALSO_BUILD="${ALSO_BUILD}" BIN3_BUILD="${BIN3_BUILD}"эквивалентно:
OPTIONS_DEFINE= OPT1 OPT2
MAKE_ARGS= ALSO_BUILD="${ALSO_BUILD}" BIN3_BUILD="${BIN3_BUILD}"
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
ALSO_BUILD+= bin1
.endif
.if ${PORT_OPTIONS:MOPT2}
ALSO_BUILD+= bin2
.endif
.if ${PORT_OPTIONS:MOPT2}
BIN3_BUILD= yes
.else
BIN3_BUILD= no
.endifЗначения, содержащие пробелы, должны быть заключены в кавычки: OPT_VARS= foo="bar baz" Это связано с тем, как make(1) обрабатывает пробелы при раскрытии переменных. Когда Также не добавляйте лишние пробелы после знака OPT_VARS= foo= bar |
5.14.3.10. Зависимости, OPT_DEPTYPE и OPT_DEPTYPE_OFF
Для любого из этих типов зависимостей:
PKG_DEPENDSEXTRACT_DEPENDSPATCH_DEPENDSFETCH_DEPENDSBUILD_DEPENDSLIB_DEPENDSRUN_DEPENDS
Когда выбрана опция OPT, значение OPT_DEPTYPE, если оно определено, добавляется к DEPTYPE. OPT_DEPTYPE_OFF работает аналогично, но когда не выбрана OPT. Например:
OPTIONS_DEFINE= OPT1 OPT1_LIB_DEPENDS= liba.so:devel/a OPT1_LIB_DEPENDS_OFF= libb.so:devel/b
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
LIB_DEPENDS+= liba.so:devel/a
.else
LIB_DEPENDS+= libb.so:devel/b
.endif5.14.3.11. Универсальная замена переменных, OPT_VARIABLE и OPT_VARIABLE_OFF
Для любой из этих переменных:
ALL_TARGETBINARY_ALIASBROKENCATEGORIESCFLAGSCONFIGURE_ENVCONFLICTSCONFLICTS_BUILDCONFLICTS_INSTALLCPPFLAGSCXXFLAGSDESKTOP_ENTRIESDISTFILESEXTRACT_ONLYEXTRA_PATCHESGH_ACCOUNTGH_PROJECTGH_SUBDIRGH_TAGNAMEGH_TUPLEGL_ACCOUNTGL_COMMITGL_PROJECTGL_SITEGL_SUBDIRGL_TUPLEIGNOREINFOINSTALL_TARGETLDFLAGSLIBSMAKE_ARGSMAKE_ENVMASTER_SITESPATCHFILESPATCH_SITESPLIST_DIRSPLIST_FILESPLIST_SUBPORTDOCSPORTEXAMPLESSUB_FILESSUB_LISTTEST_TARGETUSES
Когда выбрана опция OPT, значение OPT_ABOVEVARIABLE, если оно определено, добавляется к ABOVEVARIABLE. OPT_ABOVEVARIABLE_OFF работает аналогично, но когда OPT не выбрана. Например:
OPTIONS_DEFINE= OPT1 OPT1_USES= gmake OPT1_CFLAGS_OFF= -DTEST
эквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MOPT1}
USES+= gmake
.else
CFLAGS+= -DTEST
.endifНекоторые переменные отсутствуют в этом списке, в частности |
Некоторые из этих переменных, по крайней мере С такими строками в Makefile: ALL_TARGET= all DOCS_ALL_TARGET= doc Если опция Только со строкой помощника опций в Makefile: DOCS_ALL_TARGET= doc Если опция |
5.14.3.12. Дополнительные цели сборки, target-OPT-on и target-OPT-off
Эти цели в Makefile могут принимать дополнительные опциональные цели сборки:
pre-fetchdo-fetchpost-fetchpre-extractdo-extractpost-extractpre-patchdo-patchpost-patchpre-configuredo-configurepost-configurepre-builddo-buildpost-buildpre-installdo-installpost-installpost-stagepre-packagedo-packagepost-package
Когда выбрана опция OPT, цель TARGET-OPT-on, если она определена, выполняется после TARGET. TARGET-OPT-off работает аналогично, но когда OPT не выбрана. Например:
OPTIONS_DEFINE= OPT1
post-patch-OPT1-on:
@${REINPLACE_CMD} -e '/opt1/s|/usr/bin/|${EXAMPLESDIR}/|' ${WRKSRC}/Makefile
post-patch-OPT1-off:
@${REINPLACE_CMD} -e '/opt1/s|/usr/bin/|${PREFIX}/bin/|' ${WRKSRC}/Makefileэквивалентно:
OPTIONS_DEFINE= OPT1
.include <bsd.port.options.mk>
post-patch:
.if ${PORT_OPTIONS:MOPT1}
@${REINPLACE_CMD} -e '/opt1/s|/usr/bin/|${EXAMPLESDIR}/|' ${WRKSRC}/Makefile
.else
@${REINPLACE_CMD} -e '/opt1/s|/usr/bin/|${PREFIX}/bin/|' ${WRKSRC}/Makefile
.endif5.15. Указание рабочего каталога
Каждый порт извлекается в рабочий каталог, который должен быть доступен для записи. Система портов по умолчанию распаковывает DISTFILES в каталог с именем ${DISTNAME}. Другими словами, если в Makefile указано:
PORTNAME= foo DISTVERSION= 1.0
то файлы дистрибутива порта содержат каталог верхнего уровня foo-1.0, и остальные файлы находятся в этом каталоге.
Если нужно расположение файлов в других каталогах, можно переопределить ряд переменных.
5.15.1. WRKSRC
Переменная указывает имя каталога, который создается при распаковке distfiles приложения. Чтобы в нашем предыдущем примере распаковка происходила в каталог с именем foo (а не foo-1.0), напишите:
WRKSRC= ${WRKDIR}/fooили можно
WRKSRC= ${WRKDIR}/${PORTNAME}5.15.2. WRKSRC_SUBDIR
Если исходные файлы, необходимые для порта, находятся в подкаталоге распакованного дистрибутива, присвойте WRKSRC_SUBDIR имя этого каталога.
WRKSRC_SUBDIR= src
5.15.3. NO_WRKSUBDIR
Если порт не распаковывается в подкаталог вообще, установите NO_WRKSUBDIR, чтобы указать это.
NO_WRKSUBDIR= yes
Поскольку |
5.16. Обработка конфликтов
Существует три различные переменные для регистрации конфликтов между пакетами и портами: CONFLICTS, CONFLICTS_INSTALL и CONFLICTS_BUILD.
Эти переменные автоматически устанавливают переменную |
При удалении одного из нескольких конфликтующих портов рекомендуется оставлять CONFLICTS в тех других портах на несколько месяцев, чтобы учесть пользователей, которые обновляются лишь время от времени.
CONFLICTS_INSTALLЕсли пакет не может сосуществовать с другими пакетами (из-за конфликтов файлов, несовместимости во время выполнения и т.д.). Проверка
CONFLICTS_INSTALLвыполняется после этапа сборки и перед этапом установки.
CONFLICTS_BUILDЕсли порт не может быть собран, когда уже установлены другие определённые порты. Конфликты сборки не фиксируются в результирующем пакете.
CONFLICTSЕсли порт не может быть собран, когда определённый порт уже установлен и итоговый пакет не может сосуществовать с другим пакетом. Проверка
CONFLICTSвыполняется до этапа сборки и до этапа установки.
Каждый элемент, разделённый пробелами, в значениях переменных CONFLICTS* сопоставляется с пакетами(кроме того, который собирается) с использованием правил раскрытия шаблонов имен файлов в оболочке shell. Это позволяет перечислить все варианты порта в списке конфликтов вместо необходимости исключать собираемый вариант из этого списка. Например, если установлен git-lite, CONFLICTS_INSTALL=git git-lite позволит выполнить:
% make -C devel/git FLAVOR=lite all deinstall installНо следующая команда сообщит о конфликте, так как установленное имя базового пакета — git-lite, а git будет собран, но не может быть установлен вместе с git-lite:
% make -C devel/git FLAVOR=default all deinstall installБез этой функции Makefile потребовал бы по одному _flavor__CONFLICTS_INSTALL для каждого варианта, перечисляя все остальные варианты.
Наиболее распространённым содержимым одной из этих переменных является база пакета другого порта. База пакета — это имя пакета без указания версии, её можно получить, выполнив команду make -V PKGBASE.
CONFLICTS*Пакет dns/bind99 не может быть установлен, если присутствует пакет dns/bind910, так как они устанавливают одинаковые файлы. Сначала соберите базовый пакет для использования:
% make -C dns/bind99 -V PKGBASE
bind99
% make -C dns/bind910 -V PKGBASE
bind910Затем добавьте в Makefile пакета dns/bind99:
CONFLICTS_INSTALL= bind910
И добавьте в Makefile пакета dns/bind910:
CONFLICTS_INSTALL= bind99
Иногда только определенные версии другого порта несовместимы. В этом случае используйте полное имя пакета, включая версию. При необходимости используйте подстановочные символы шаблонов имён файлов оболочки, такие как * и ?, чтобы охватить все необходимые версии.
CONFLICTS* с шаблонами имён файлов.В версиях с 2.0 по 2.4.1_2 пакет deskutils/gnotime устанавливал встроенную версию пакета databases/qof.
Чтобы отразить это прошлое, Makefile пакета databases/qof содержит:
CONFLICTS_INSTALL= gnotime-2.[0-3]* \ gnotime-2.4.0* gnotime-2.4.1 \ gnotime-2.4.1_[12]
Первый элемент соответствует версиям 2.0–2.3, второй — всем редакциям 2.4.0, третий — точно версии 2.4.1, а последний — первой и второй редакциям версии 2.4.1.
deskutils/gnotime не имеет строки конфликтов, потому что его текущая версия не конфликтует ни с чем другим.
Переменная DISABLE_CONFLICTS может быть временно установлена при выполнении целей, на которые не влияют конфликты. Эту переменную не следует устанавливать в Makefiles портов.
% make -DDISABLE_CONFLICTS patch5.17. Установка файлов
Фаза |
5.17.1. Макросы INSTALL_*
Используйте макросы, предоставленные в bsd.port.mk, чтобы обеспечить корректные режимы файлов в целях *-install порта. Устанавливайте владельца напрямую в pkg-plist в соответствующих записях, таких как @(владелец,группа,), @owner владелец и @group группа. Эти операторы действуют до переопределения или до конца pkg-plist, поэтому не забудьте сбросить их, когда они больше не нужны. Владелец по умолчанию — root:wheel. Дополнительную информацию см. в Базовые Ключевые Слова.
INSTALL_PROGRAM— команда для установки бинарных исполняемых файлов.INSTALL_SCRIPT— команда для установки исполняемых скриптов.INSTALL_LIB— это команда для установки общих библиотек (но не статических библиотек).INSTALL_KLD— это команда для установки загружаемых модулей ядра. Некоторые архитектуры не поддерживают удаление символов из модулей, поэтому используйте эту команду вместоINSTALL_PROGRAM.INSTALL_DATA— это команда для установки общих данных, включая статические библиотеки.INSTALL_MAN— это команда для установки man-страниц и другой документации (она ничего не сжимает).
Эти переменные передаются команде install(1) с соответствующими флагами для каждой ситуации.
Не используйте |
5.17.2. Удаление символов из бинарных файлов и разделяемых библиотек
Установленные бинарные файлы должны быть очищены от отладочной информации. Не очищайте бинарные файлы вручную, если это не является абсолютно необходимым. Макрос INSTALL_PROGRAM устанавливает и очищает бинарный файл одновременно. Макрос INSTALL_LIB делает то же самое с разделяемыми библиотеками.
Когда файл необходимо очистить, но ни макросы INSTALL_PROGRAM, ни INSTALL_LIB не подходят, ${STRIP_CMD} очищает программу или разделяемую библиотеку. Обычно это делается в цели post-install. Например:
post-install:
${STRIP_CMD} ${STAGEDIR}${PREFIX}/bin/xdlКогда необходимо удалить отладочную информацию из нескольких файлов:
post-install:
.for l in geometry media body track world
${STRIP_CMD} ${STAGEDIR}${PREFIX}/lib/lib${PORTNAME}-${l}.so.0
.endforИспользуйте file(1) для файла, чтобы определить, был ли он подвергнут удалению символов. file(1) сообщает, что бинарные файлы либо stripped (удалены символы), либо not stripped (символы не удалены). Кроме того, strip(1) обнаружит программы, которые уже были подвергнуты удалению символов, и завершит работу без ошибок.
Когда определён Переменные ( Некоторое программное обеспечение добавляет |
5.17.3. Установка целого дерева файлов
Иногда необходимо установить большое количество файлов с сохранением их иерархической структуры. Например, копирование всего дерева каталогов из WRKSRC в целевой каталог под PREFIX. Обратите внимание, что PREFIX, EXAMPLESDIR, DATADIR и другие переменные путей всегда должны предваряться STAGEDIR для соблюдения процедуры промежуточной установки (см. Промежуточная установка).
Для этой ситуации существуют два макроса. Преимущество использования этих макросов вместо cp заключается в том, что они гарантируют целевым файлам правильные значения владельца и разрешений. Первый макрос, COPYTREE_BIN, устанавливает все установленные файлы как исполняемые, что делает его подходящим для установки в PREFIX/bin. Второй макрос, `COPYTREE_SHARE#, не устанавливает исполняемые разрешения для файлов и, следовательно, подходит для установки файлов в PREFIX/share.
post-install:
${MKDIR} ${STAGEDIR}${EXAMPLESDIR}
(cd ${WRKSRC}/examples && ${COPYTREE_SHARE} . ${STAGEDIR}${EXAMPLESDIR})Этот пример установит содержимое каталога examples из дистрибутива вендора в соответствующее расположение примеров порта.
post-install:
${MKDIR} ${STAGEDIR}${DATADIR}/summer
(cd ${WRKSRC}/temperatures && ${COPYTREE_SHARE} "June July August" ${STAGEDIR}${DATADIR}/summer)И этот пример установит данные летних месяцев в подкаталог summer каталога DATADIR.
Дополнительные аргументы find могут быть переданы через третий аргумент макросов COPYTREE_*. Например, чтобы установить все файлы из первого примера, кроме Makefiles, можно использовать следующие команды.
post-install:
${MKDIR} ${STAGEDIR}${EXAMPLESDIR}
(cd ${WRKSRC}/examples && \
${COPYTREE_SHARE} . ${STAGEDIR}${EXAMPLESDIR} "! -name Makefile")Эти макросы не добавляют установленные файлы в pkg-plist. Их необходимо добавлять вручную. Для дополнительной документации (PORTDOCS, см. Установка дополнительной документации) и примеров (PORTEXAMPLES), префиксы %%PORTDOCS%% или %%PORTEXAMPLES%% должны быть добавлены в pkg-plist.
5.17.4. Установка дополнительной документации
Если у программного обеспечения есть документация, помимо стандартных страниц man и info, которая может быть полезна пользователю, установите её в DOCSDIR. Это можно сделать, как и в предыдущем пункте, в цели post-install.
Создайте новый каталог для порта. Имя каталога — DOCSDIR. Обычно оно равно PORTNAME. Однако, если пользователю может потребоваться установка разных версий порта одновременно, можно использовать полное имя PKGNAME.
Поскольку устанавливаются только файлы, перечисленные в pkg-plist, можно безопасно всегда устанавливать документацию в STAGEDIR (см. Staging). Поэтому блоки .if требуются только в тех случаях, когда устанавливаемые файлы достаточно велики, чтобы вызвать значительные накладные расходы на ввод-вывод.
post-install:
${MKDIR} ${STAGEDIR}${DOCSDIR}
${INSTALL_DATA} ${WRKSRC}/docs/xvdocs.ps ${STAGEDIR}${DOCSDIR}С другой стороны, если в порте есть опция DOCS, установите документацию в цели post-install-DOCS-on. Эти цели описаны в Дополнительные цели сборки.
Вот несколько полезных переменных и их стандартное раскрытие при использовании в Makefile:
DATADIRраскрывается в PREFIX/share/PORTNAME.DATADIR_RELраскрывается в share/PORTNAME.DOCSDIRраскрывается в PREFIX/share/doc/PORTNAME.DOCSDIR_RELраскрывается в share/doc/PORTNAME.EXAMPLESDIRраскрывается в PREFIX/share/examples/PORTNAME.EXAMPLESDIR_RELраскрывается в share/examples/PORTNAME.
Опция |
Эти переменные экспортируются в PLIST_SUB. Их значения будут представлены там в виде путей относительно PREFIX, если это возможно. То есть, share/doc/PORTNAME будет заменено на %%DOCSDIR%% в списке упаковки по умолчанию и так далее. (Подробнее о подстановках в pkg-plist см. здесь.)
Все условно устанавливаемые файлы и каталоги документации включаются в pkg-plist с префиксом %%PORTDOCS%%, например:
%%PORTDOCS%%%%DOCSDIR%%/AUTHORS %%PORTDOCS%%%%DOCSDIR%%/CONTACT
В качестве альтернативы перечислению файлов документации в pkg-plist, порт может установить переменную PORTDOCS в список имён файлов и шаблонов имен файлов shell для добавления в итоговый список упаковки. Имена будут относительны к DOCSDIR. Поэтому порт, использующий PORTDOCS и нестандартное расположение документации, должен соответствующим образом установить DOCSDIR. Если в PORTDOCS указан каталог или он соответствует шаблону из этой переменной, всё поддерево содержащихся файлов и каталогов будет зарегистрировано в итоговом списке упаковки. Если опция DOCS отключена, файлы и каталоги, перечисленные в PORTDOCS, не будут установлены или добавлены в список упаковки порта. Установка документации в PORTDOCS, как показано выше, остаётся на усмотрение самого порта. Типичный пример использования PORTDOCS:
PORTDOCS= README.* ChangeLog docs/*
Эквивалентами Содержимое файла pkg-message отображается при установке. Подробности см. в разделе использование файла pkg-message. Файл pkg-message не нужно добавлять в pkg-plist. |
5.17.5. Подкаталоги в PREFIX
Попробуйте сделать так, чтобы порт размещал файлы в правильных подкаталогах PREFIX. Некоторые порты собирают всё в кучу и помещают в подкаталог с именем порта, что неверно. Также многие порты размещают все файлы, кроме бинарников, заголовочных файлов и страниц руководства, в подкаталоге lib, что плохо согласуется с парадигмой BSD. Многие из этих файлов должны быть перемещены в один из следующих каталогов: etc (файлы настройки/конфигурации), libexec (исполняемые файлы для внутреннего использования), sbin (исполняемые файлы для суперпользователей/администраторов), info (документация для браузера info) или share (архитектурно-независимые файлы). Подробности см. в hier(7); правила, действующие для /usr, в основном применимы и к /usr/local. Исключение составляют порты, связанные с USENET "news". Они могут использовать PREFIX/news в качестве места назначения для своих файлов.
5.18. Используйте BINARY_ALIAS для переименования команд вместо исправления сборки
Когда определена переменная BINARY_ALIAS, будут созданы символьные ссылки на указанные команды в каталоге, который будет добавлен в начало переменной PATH.
Используйте это для замены жёстко заданных команд, от которых зависит этап сборки, без необходимости исправлять какие-либо файлы сборки.
BINARY_ALIAS для предоставления gsed в качестве sedНекоторые порты ожидают, что sed будет вести себя как GNU sed и используют возможности, которые sed(1) не предоставляет. GNU sed доступен в пакете textproc/gsed на FreeBSD.
Используйте BINARY_ALIAS для замены sed на gsed на время сборки:
BUILD_DEPENDS= gsed:textproc/gsed ... BINARY_ALIAS= sed=gsed
BINARY_ALIAS для создания псевдонимов жестко заданных команд python3Порт, в котором есть жёсткая ссылка на python3 в скриптах сборки, требует его наличия в PATH во время сборки. Используйте BINARY_ALIAS для создания псевдонима, указывающего на нужный бинарный файл Python 3:
USES= python:3.4+,build
...
BINARY_ALIAS= python3=${PYTHON_CMD}См. Использование Python для получения дополнительной информации о USES=python.
Бинарные псевдонимы создаются после обработки зависимостей, указанных через |
Глава 6. Особые соглашения
Имеется ещё несколько вещей, которые вы должны иметь в виду при создании порта. Этот раздел описывает наиболее часто встречающиеся из них.
6.1. Разделение длинных файлов
Иногда Makefiles могут быть очень длинными. Например, порты rust могут содержать очень длинный список CARGO_CRATES. В других случаях Makefile может содержать код, который варьируется в зависимости от архитектуры. В таких ситуациях может быть удобно разделить исходный Makefile на несколько файлов. bsd.port.mk автоматически включает некоторые типы Makefiles в основной Makefile порта.
Вот файлы, которые система обрабатывает автоматически, если они обнаружены:
Makefile.crates. Пример можно найти в пакете audio/ebur128.
Makefile.inc. Пример можно найти в пакете net/ntp.
Makefile.${ARCH}-${OPSYS}
Makefile.${OPSYS}. Пример можно найти в пакете net/cvsup-static.
Makefile.${ARCH}
Makefile.local
Также распространённой практикой является разделение списка пакетов порта на несколько файлов, если список сильно различается в зависимости от архитектуры или выбранного флейвора. В этом случае файл pkg-plist для каждой архитектуры именуется по шаблону pkg-plist.${ARCH} или pkg-plist.${FLAVOR}. Фреймворк не создаёт список пакетов автоматически, если существует несколько файлов pkg-plist. Ответственность за выбор подходящего файла pkg-plist и его присвоение переменной PLIST лежит на того, кто делает порт. Примеры работы с этим можно найти в портах audio/logitechmediaserver и deskutils/libportal.
6.2. Staging
bsd.port.mk ожидает, что порты будут работать с "директорией стадии". Это означает, что порт не должен устанавливать файлы напрямую в обычные целевые директории (например, под PREFIX), а вместо этого в отдельную директорию, из которой затем собирается пакет. Во многих случаях это не требует прав root, что позволяет собирать пакеты от имени непривилегированного пользователя. При использовании стадии порт собирается и устанавливается в директорию стадии STAGEDIR. Пакет создаётся из директории стадии и затем устанавливается в систему. Инструменты Automake называют эту концепцию DESTDIR, но в FreeBSD DESTDIR имеет другое значение (см. PREFIX и DESTDIR).
Ни один порт на самом деле не должен работать от root. Этого в большинстве случаев можно избежать, используя |
Метапорты, то есть порты, которые не устанавливают файлы непосредственно, а только зависят от других портов, должны по возможности избегать распаковки mtree(8) в каталог сборки. Это основная иерархия каталогов пакета, и эти пустые каталоги будут выглядеть лишними. Для предотвращения распаковки mtree(8) добавьте эту строку:
NO_MTREE= yes
Метапорты должны использовать |
Этап подготовки включается путем добавления STAGEDIR к путям, используемым в целях pre-install, do-install и post-install (см. примеры в книге). Обычно это включает PREFIX, ETCDIR, DATADIR, EXAMPLESDIR, DOCSDIR и т. д. Каталоги должны создаваться как часть цели post-install. По возможности избегайте использования абсолютных путей.
Порты, которые устанавливают модули ядра, должны добавлять |
6.2.1. Обработка символических ссылок
При создании символической ссылки настоятельно рекомендуется использовать относительные пути. Используйте ${RLN} для создания относительных символических ссылок. Эта команда использует install(1) для автоматического определения относительной ссылки, которую нужно создать.
${RLN} использует относительную символическую ссылку из install(1), что освобождает сборщика порта от вычисления относительного пути.
${RLN} ${STAGEDIR}${PREFIX}/lib/libfoo.so.42 ${STAGEDIR}${PREFIX}/lib/libfoo.so
${RLN} ${STAGEDIR}${PREFIX}/libexec/foo/bar ${STAGEDIR}${PREFIX}/bin/bar
${RLN} ${STAGEDIR}/var/cache/foo ${STAGEDIR}${PREFIX}/share/fooБудет создано:
% ls -lF ${STAGEDIR}${PREFIX}/lib
lrwxr-xr-x 1 nobody nobody 181 Aug 3 11:27 libfoo.so@ -> libfoo.so.42
-rwxr-xr-x 1 nobody nobody 15 Aug 3 11:24 libfoo.so.42*
% ls -lF ${STAGEDIR}${PREFIX}/bin
lrwxr-xr-x 1 nobody nobody 181 Aug 3 11:27 bar@ -> ../libexec/foo/bar
% ls -lF ${STAGEDIRDIR}${PREFIX}/share
lrwxr-xr-x 1 nobody nobody 181 Aug 3 11:27 foo@ -> ../../../var/cache/foo6.3. Встроенные библиотеки
Этот раздел объясняет, почему встроенные зависимости считаются плохими и что с этим делать.
6.3.1. Почему встроенные библиотеки — это плохо
Некоторое программное обеспечение требует от упаковщика найти сторонние библиотеки и добавить необходимые зависимости в порт. Другое ПО включает все необходимые библиотеки в дистрибутивный файл. Второй подход кажется проще на первый взгляд, но имеет серьёзные недостатки:
Этот список частично основан на вики Fedora и Gentoo, оба распространяются по лицензии CC-BY-SA 3.0.
- Безопасность
Если уязвимости обнаружены в вышестоящей библиотеке и исправлены там, они могут остаться неисправленными в библиотеке, поставляемой с портом. Одной из причин может быть то, что автор не знает о проблеме. Это означает, что портировщик должен исправить их или обновить до не уязвимой версии и отправить исправление автору. Всё это требует времени, что приводит к тому, что программное обеспечение остаётся уязвимым дольше, чем необходимо. Это, в свою очередь, затрудняет координацию исправления без неоправданного раскрытия информации об уязвимости.
- Ошибки
Эта проблема аналогична проблеме с безопасностью в последнем абзаце, но в целом менее серьезная.
- Ветвление
Автору проще создать форк upstream-библиотеки после её включения в дистрибутив. Хотя на первый взгляд это кажется удобным, такой подход приводит к расхождению кода с исходным репозиторием, что усложняет исправление уязвимостей и других проблем в ПО. Одна из причин — затруднённое применение патчей.
Еще одна проблема форкинга заключается в том, что из-за расхождения кода с основной веткой, ошибки исправляются снова и снова, вместо того чтобы быть исправленными один раз в центральном месте. Это противоречит самой идее открытого программного обеспечения.
- Конфликты символов
Когда библиотека установлена в системе, может возникнуть конфликт с встроенной в порт версией. Это может привести к немедленным ошибкам во время компиляции или компоновки. Также могут возникать ошибки при запуске программы, которые сложнее отследить. Последняя проблема может быть вызвана несовместимостью версий двух библиотек.
- Лицензирование
При объединении проектов из различных источников могут возникать проблемы с лицензиями, особенно если лицензии несовместимы.
- Растрата ресурсов
Библиотеки, поставляемые в комплекте, растрачивают ресурсы на нескольких уровнях. Сборка самого приложения занимает больше времени, особенно если эти библиотеки уже присутствуют в системе. Во время выполнения они могут занимать дополнительную память, когда общесистемная библиотека уже загружена одной программой, а входящая в комплект библиотека загружена другой программой.
- Пустая трата усилий
Когда библиотеке требуются патчи для FreeBSD, эти патчи приходится дублировать в составе библиотеки. Это приводит к потере времени разработчиков, поскольку патчи могут применяться некорректно. Кроме того, бывает сложно сразу заметить, что эти патчи вообще необходимы.
6.3.2. Что делать со встроенными библиотеками
По возможности используйте независимую версию библиотеки, добавив LIB_DEPENDS в порт. Если такого порта ещё не существует, рассмотрите возможность его создания.
Используйте встроенные библиотеки только в том случае, если разработчик имеет хорошую репутацию в вопросах безопасности, а использование внешних версий приводит к излишне сложным исправлениям.
В некоторых особых случаях, например, для эмуляторов, таких как Wine, порт должен включать библиотеки, потому что они предназначены для другой архитектуры или были изменены для использования в данном программном обеспечении. В таком случае эти библиотеки не должны быть доступны для связывания с другими портами. Добавьте |
6.4. Динамические библиотеки
Если ваш порт устанавливает одну или несколько динамических библиотек, определите переменную USE_LDCONFIG, которая приведёт к запуску из bsd.port.mk команды ${LDCONFIG} -m относительно каталога, в который устанавливается новая библиотека (как правило, это PREFIX/lib), во время выполнения цели post-install для её регистрации в кэше динамических библиотек. Эта переменная, если она определена, также приведёт к добавлению соответствующей пары команд @exec /sbin/ldconfig -m и @unexec /sbin/ldconfig -R в ваш файл pkg-plist, так что пользователь, устанавливающий пакет, сможет сразу же использовать динамическую библиотеку, а удаление пакета не приведёт к тому, что система будет предполагать, что библиотека всё ещё имеется в наличии.
USE_LDCONFIG= yes
Если нужно, вы можете переопределить каталог по умолчанию, задав значение USE_LDCONFIG, в котором должны быть перечислены каталоги, в которые устанавливаются динамические библиотеки. Например, если ваш порт устанавливает динамические библиотеки в каталоги PREFIX/lib/foo и PREFIX/lib/bar, то вы можете в файле Makefile указать следующее:
USE_LDCONFIG= ${PREFIX}/lib/foo ${PREFIX}/lib/barБудьте добры перепроверить, т.к. часто это вовсе не является необходимым и может быть решено иначе с помощью -rpath или установки LD_RUN_PATH во время компоновки (для примера смотрите lang/moscow_ml), или с помощью сценария-обёртки, который выставляет LD_LIBRARY_PATH перед запуском исполняемого файла как это делает www/seamonkey.
При установке 32-разрядных библиотек на 64-разрядной системе используйте вместо этого USE_LDCONFIG32.
Если программное обеспечение использует autotools, в частности libtool, добавьте USES=libtool.
Если при обновлении порта увеличивается старший номер версии библиотеки, то для всех портов, компонуемых с затронутой библиотекой, следует увеличить значение PORTREVISION для форсирования перекомпиляции с новой версией библиотеки.
6.5. Порты с ограничениями на распространение или с правовым обременением
Лицензии бывают разных видов, и некоторые накладывают ограничение на то, как приложение может быть оформлено в виде пакета, может ли оно продаваться для извлечения коммерческой выгоды, и так далее.
На вас, как на человека, портирующего приложение, ложится обязанность прочесть лицензионные соглашения на программное обеспечение и удостовериться, что проект FreeBSD не будет являться их нарушителем, если будет заниматься распространением исходного кода или в бинарном виде по FTP/HTTP или на CD-ROM. Если у вас возникли сомнения, то, пожалуйста, обратитесь в Список рассылки, посвящённый Портам FreeBSD. |
В подобных ситуациях можно использовать переменные, описываемые в последующих разделах.
6.5.1. NO_PACKAGE
Эта переменная указывает, что мы не можем создавать для приложения двоичный пакет. К примеру, лицензия не позволяет бинарное распространение или она может запрещать распространение пакетов, созданных из изменённых исходников.
Однако файлы DISTFILES могут свободно зеркалироваться по FTP/HTTP. Они также могут распространяться, используя CD-ROM (или на похожих носителях), если не установлена переменная NO_CDROM.
NO_PACKAGE должна также использоваться, если двоичный пакет, как правило, бесполезен, а приложение должно всегда компилироваться из исходного кода. К примеру, если в приложение во время компиляции жёстко включается конфигурационная информация, привязанная к конкретной системе, то задайте переменную NO_PACKAGE.
Значением переменной NO_PACKAGE должна быть строка, описывающая причину, по которой пакет не должен создаваться.
6.5.2. NO_CDROM
Эта переменная указывает на то, что, хотя мы имеем право создавать бинарные пакеты, мы не можем помещать эти пакеты или файлы DISTFILES порта на CD-ROM (или на похожие носители) для перепродажи. Однако бинарные пакеты и файлы DISTFILES порта будут оставаться доступными посредством FTP/HTTP.
Если эта переменная устанавливается вместе с NO_PACKAGE, то только файлы порта DISTFILES будут доступны, и только посредством FTP/HTTP.
В качестве значения NO_CDROM должна указываться строка, описывающая причины, по которым порт не может распространяться на CD-ROM. К примеру, это применяется, если лицензионное соглашение приложения предполагает только его "некоммерческое" использование.
6.5.3. NOFETCHFILES
Файлы, определенные в переменной NOFETCHFILES, не будут извлекаться ни из одного из MASTER_SITES. Примером такого файла является файл, поставляемый на CD-ROM.
Инструменты, проверяющие доступность этих файлов на MASTER_SITES, должны игнорировать эти файлы и не сообщать о них.
6.5.4. RESTRICTED
Задайте эту переменную, если лицензия на приложение не позволяет ни зеркалировать файлы DISTFILES, ни распространять бинарный пакет через FTP/HTTP или на CD-ROM.
Ни NO_CDROM, ни NO_PACKAGE не стоит устанавливать вместе с RESTRICTED, так как последняя переменная подразумевает первые две.
В качестве значения RESTRICTED должна указываться строка, описывающая причины, по которым порт нельзя распространять. Обычно это означает, что порт использует закрытое программное обеспечение, а пользователь должен вручную сгрузить файлы DISTFILES, возможно, после заполнения регистрационной формы или подтверждения соглашения с условиями EULA.
6.5.5. RESTRICTED_FILES
Если заданы RESTRICTED или NO_CDROM, то значение этой переменной по умолчанию соответствует ${DISTFILES} ${PATCHFILES}, в противном случае она пуста. Если ограничены в распространении лишь некоторые из дистрибутивных файлов, то в этой переменной задаётся их список.
6.5.6. LEGAL_TEXT
Если порт имеет правовое обременение, которое не покрывается перечисленными выше переменными, то переменной LEGAL_TEXT следует присвоить строку с описанием данного обременения. Например, если было получено особое разрешение для FreeBSD на распространение двоичного файла, то эта переменная должна содержать соответствующее указание.
6.5.7. /usr/ports/LEGAL и LEGAL
Порт, содержащий любую из перечисленных выше переменных, также должен быть добавлен в /usr/ports/LEGAL. Первый столбец содержит шаблон совпадения с дистрибутивными файлами, имеющими ограничения на распространение. Второй столбец содержит корень порта. Третий столбец содержит вывод make -VLEGAL.
6.5.8. Примеры
Предпочтительным способом реализации утверждения "архивы исходных текстов для этого порта должны загружаться самостоятельно" является следующее:
.if !exists(${DISTDIR}/${DISTNAME}${EXTRACT_SUFX})
IGNORE= may not be redistributed because of licensing reasons. Please visit some-website to accept their license and download ${DISTFILES} into ${DISTDIR}
.endifЭто одновременно и информирует пользователя, и устанавливает нужные метаданные на пользовательской машине для использования автоматическими программами.
Обратите внимание, что данная кляуза должна предшествовать подключению файла bsd.port.pre.mk.
6.6. Механизмы построения
6.6.1. Параллельное построение портов
Инфраструктура портов FreeBSD поддерживает параллельное построение с использованием множественных подпроцессов make, что позволяет системам SMP задействовать всю доступную мощность CPU, тем самым делая построение портов более быстрым и эффективным.
Это достигается путём передачи флага -jX команде make(1). Такое построение портов является поведением по умолчанию. К сожалению, не все порты поддерживают параллельную сборку достаточно хорошо, и поэтому может потребоваться выключить этот механизм явным образом путём добавления переменной MAKE_JOBS_UNSAFE=yes. Эта переменная используется в случае, когда известно, что порт ломается с -jX.
При установке |
6.6.2. make, gmake и imake
Существует несколько различных реализаций make. Переносимому программному обеспечению часто требуется конкретная реализация, например GNU make, известная в FreeBSD как gmake.
Если порт использует GNU make, добавьте gmake в USES.
MAKE_CMD может использоваться для ссылки на конкретную команду, настроенную параметром USES в Makefile порта. Используйте MAKE_CMD только внутри Makefile приложения в WRKSRC для вызова реализации make, ожидаемой портируемым программным обеспечением.
Если ваш порт является приложением X, которое создает файлы Makefile из Imakefile, используя imake, то установите USES= imake. Это заставит стадию конфигурирования автоматически выполнить xmkmf -a. Если флаг -a представляет для вашего порта проблему, то установите XMKMF=xmkmf. Если порт использует imake, но не понимает цель install.man, то следует установить NO_INSTALL_MANPAGES=yes.
Если исходный Makefile вашего порта имеет что-нибудь помимо all в качестве основной цели построения, то задайте соответствующее значение ALL_TARGET. То же касается install и INSTALL_TARGET.
6.6.3. Сценарий configure
Если ваш порт использует сценарий configure для получения файлов Makefile из файлов Makefile.in, то установите GNU_CONFIGURE=yes. Если вы хотите дать дополнительные параметры сценарию configure (аргументом по умолчанию является --prefix=${PREFIX} --infodir=${PREFIX}/${INFO_PATH} --mandir=${MANPREFIX}/man --build=${CONFIGURE_TARGET}), установите эти параметры в CONFIGURE_ARGS. Дополнительные переменные окружения можно передать, используя переменную CONFIGURE_ENV.
| Переменная | Значение |
|---|---|
| Порт использует сценарий |
| То же, что и |
| Дополнительные параметры, передаваемые сценарию |
| Дополнительные переменные окружения, задаваемые для запуска сценария |
| Переопределить цель configure по умолчанию. Значением по умолчанию является |
6.6.4. Использование cmake
Если порт использует CMake, определите USES= cmake.
| Переменная | Значение |
|---|---|
| Специфичные для порта флаги CMake, передаваемые в бинарный файл |
| Для каждой записи в |
| Для каждой записи в |
| Тип сборки (предопределённые профили сборки CMake). По умолчанию |
| Путь к исходному каталогу. По умолчанию |
| Дополнительные переменные окружения, которые должны быть установлены для бинарного файла |
| Переменная | Значение |
|---|---|
| Запрещает цветной вывод сообщений при построении. Значение по умолчанию не задано, если не заданы |
CMake поддерживает следующие профили построения: Debug, Release, RelWithDebInfo и MinSizeRel. Профили Debug и Release учитывают системные флаги *FLAGS; RelWithDebInfo и MinSizeRel соответственно определяют CFLAGS со значением -O2 -g и -Os -DNDEBUG. Значение CMAKE_BUILD_TYPE экспортируется в нижнем регистре в PLIST_SUB и должно использоваться, если порт устанавливает файлы *.cmake в зависимости от типа построения (для примера посмотрите на deskutils/strigi). Следует учитывать, что некоторые проекты могут определять собственные профили построения и/или форсировать конкретный тип построения через установку CMAKE_BUILD_TYPE в файлах CMakeLists.txt. Для того чтобы порт для такого проекта учитывал CFLAGS и WITH_DEBUG, из этих файлов должны быть удалены значения CMAKE_BUILD_TYPE.
Большинство проектов, основанных на CMake, поддерживают метод внешнего (out-of-source) построения. Для порта внешнее построение можно запросить с использованием суффикса :outsource. В этом случае CONFIGURE_WRKSRC, BUILD_WRKSRC и INSTALL_WRKSRC будут иметь значение ${WRKDIR}/.build для каталога, содержащего файлы, получаемые на этапах конфигурации и построения; при этом каталог с исходным кодом будет оставаться без изменений.
USES= cmakeСледующий отрывок демонстрирует использование CMake для порта. CMAKE_SOURCE_PATH обычно не требуется, но может быть установлен, когда исходный код не находится в верхнем каталоге или если порт используется для построения части проекта.
USES= cmake
CMAKE_SOURCE_PATH= ${WRKSRC}/subprojectCMAKE_ON и CMAKE_OFFПри добавлении логических значений в CMAKE_ARGS проще использовать переменные CMAKE_ON и CMAKE_OFF вместо этого. Это:
CMAKE_ON= VAR1 VAR2 CMAKE_OFF= VAR3
Эквивалентно:
CMAKE_ARGS= -DVAR1:BOOL=TRUE -DVAR2:BOOL=TRUE -DVAR3:BOOL=FALSE
Это относится только к значениям по умолчанию в |
6.6.5. Использование scons
Если порт использует SCons, определите USES=scons.
Чтобы сторонний SConstruct учитывал все, что передается в SCons через окружение (то есть, что наиболее важно, CC/CXX/CFLAGS/CXXFLAGS), исправьте SConstruct, чтобы сборка Environment создавалась следующим образом:
env = Environment(**ARGUMENTS)
Он может быть изменён с помощью env.Append и env.Replace.
6.6.6. Сборка приложений на Rust с помощью cargo
Для портов, использующих Cargo, определите USES=cargo.
| Переменная | По умолчанию | Описание |
|---|---|---|
| Список ящиков (crates), от которых зависит порт. Каждая запись должна быть в формате | |
| Список функций приложения для сборки (список через пробел). Чтобы отключить все функции по умолчанию, добавьте специальный токен | |
|
| Путь к файлу Cargo.toml, который следует использовать. |
|
| Путь к файлу Cargo.lock, используемому для |
| Список переменных окружения, передаваемых в Cargo, аналогично | |
| Флаги для передачи компилятору Rust. | |
|
| Используйте стандартный |
| Дополнительные аргументы для передачи Cargo во время фазы настройки. Допустимые аргументы можно посмотреть с помощью | |
|
| Добавить зависимость сборки на lang/rust. |
|
| Расположение бинарного файла |
|
| Используйте значение по умолчанию |
| Дополнительные аргументы для передачи Cargo во время фазы сборки. Допустимые аргументы можно посмотреть с помощью | |
|
| Используйте настройку |
| Дополнительные аргументы для передачи Cargo во время фазы установки. Допустимые аргументы можно посмотреть с помощью | |
|
| Путь к пакету для установки. Этот аргумент передается в |
|
| Используйте значение по умолчанию |
| Дополнительные аргументы для передачи Cargo во время тестовой фазы. Допустимые аргументы можно посмотреть с помощью | |
|
| Расположение выходного каталога cargo. |
| rust/crates | Каталог относительно |
|
| Расположение каталога сторонних поставщиков ПО, в который будут извлечены все крейты. Старайтесь держать его в пределах |
|
| Включить загрузку крейтов, привязанных к определённым коммитам Git на GitHub, с помощью |
|
| То же, что и |
Создание порта на основе Cargo — это процесс из трёх этапов. Сначала необходимо предоставить шаблон портов, который загружает дистрибутивный файл приложения:
PORTNAME= tokei DISTVERSIONPREFIX= v DISTVERSION= 7.0.2 CATEGORIES= devel MAINTAINER= tobik@FreeBSD.org COMMENT= Display statistics about your code WWW= https://github.com/XAMPPRocky/tokei/ USES= cargo USE_GITHUB= yes GH_ACCOUNT= Aaronepower .include <bsd.port.mk>
Сгенерировать первоначальный distinfo:
% make makesum
=> Aaronepower-tokei-v7.0.2_GH0.tar.gz doesn't seem to exist in /usr/ports/distfiles/.
=> Attempting to fetch https://codeload.github.com/Aaronepower/tokei/tar.gz/v7.0.2?dummy=/Aaronepower-tokei-v7.0.2_GH0.tar.gz
fetch: https://codeload.github.com/Aaronepower/tokei/tar.gz/v7.0.2?dummy=/Aaronepower-tokei-v7.0.2_GH0.tar.gz: size of remote file is not known
Aaronepower-tokei-v7.0.2_GH0.tar.gz 45 kB 239 kBps 00m00sТеперь файл дистрибутива готов к использованию, и мы можем продолжить, извлекая зависимости пакета из встроенного файла Cargo.lock:
% make cargo-crates
CARGO_CRATES= aho-corasick-0.6.4 \
ansi_term-0.11.0 \
arrayvec-0.4.7 \
atty-0.2.9 \
bitflags-1.0.1 \
byteorder-1.2.2 \
[...]Вывод этой команды необходимо вставить напрямую в Makefile:
PORTNAME= tokei
DISTVERSIONPREFIX= v
DISTVERSION= 7.0.2
CATEGORIES= devel
MAINTAINER= tobik@FreeBSD.org
COMMENT= Display statistics about your code
WWW= https://github.com/XAMPPRocky/tokei/
USES= cargo
USE_GITHUB= yes
GH_ACCOUNT= Aaronepower
CARGO_CRATES= aho-corasick-0.6.4 \
ansi_term-0.11.0 \
arrayvec-0.4.7 \
atty-0.2.9 \
bitflags-1.0.1 \
byteorder-1.2.2 \
[...]
.include <bsd.port.mk>distinfo необходимо перегенерировать, чтобы включить все дистрибутивные файлы крейтов:
% make makesum
=> rust/crates/aho-corasick-0.6.4.tar.gz doesn't seem to exist in /usr/ports/distfiles/.
=> Attempting to fetch https://crates.io/api/v1/crates/aho-corasick/0.6.4/download?dummy=/rust/crates/aho-corasick-0.6.4.tar.gz
rust/crates/aho-corasick-0.6.4.tar.gz 100% of 24 kB 6139 kBps 00m00s
=> rust/crates/ansi_term-0.11.0.tar.gz doesn't seem to exist in /usr/ports/distfiles/.
=> Attempting to fetch https://crates.io/api/v1/crates/ansi_term/0.11.0/download?dummy=/rust/crates/ansi_term-0.11.0.tar.gz
rust/crates/ansi_term-0.11.0.tar.gz 100% of 16 kB 21 MBps 00m00s
=> rust/crates/arrayvec-0.4.7.tar.gz doesn't seem to exist in /usr/ports/distfiles/.
=> Attempting to fetch https://crates.io/api/v1/crates/arrayvec/0.4.7/download?dummy=/rust/crates/arrayvec-0.4.7.tar.gz
rust/crates/arrayvec-0.4.7.tar.gz 100% of 22 kB 3237 kBps 00m00s
=> rust/crates/atty-0.2.9.tar.gz doesn't seem to exist in /usr/ports/distfiles/.
=> Attempting to fetch https://crates.io/api/v1/crates/atty/0.2.9/download?dummy=/rust/crates/atty-0.2.9.tar.gz
rust/crates/atty-0.2.9.tar.gz 100% of 5898 B 81 MBps 00m00s
=> rust/crates/bitflags-1.0.1.tar.gz doesn't seem to exist in /usr/ports/distfiles/.
[...]Порт теперь готов к тестовой сборке и дальнейшим настройкам, таким как создание plist, написание описания, добавление информации о лицензии, опций и т.д., как обычно.
Если вы не тестируете свой порт в чистой среде, например, с использованием poudriere, не забудьте выполнить make clean перед любым тестированием.
Некоторые приложения определяют дополнительные возможности в своем Cargo.toml. Их можно включить при компиляции, установив CARGO_FEATURES в порте.
Здесь мы включаем функции json и yaml в Tokei:
CARGO_FEATURES= json yaml
Пример раздела [features] в Cargo.toml может выглядеть так:
[features] pulseaudio_backend = ["librespot-playback/pulseaudio-backend"] portaudio_backend = ["librespot-playback/portaudio-backend"] default = ["pulseaudio_backend"]
pulseaudio_backend — это функция по умолчанию. Она всегда включена, если мы явно не отключим функции по умолчанию, добавив --no-default-features в CARGO_FEATURES. Здесь мы превращаем функции portaudio_backend и pulseaudio_backend в опции порта:
CARGO_FEATURES= --no-default-features OPTIONS_DEFINE= PORTAUDIO PULSEAUDIO PORTAUDIO_VARS= CARGO_FEATURES+=portaudio_backend PULSEAUDIO_VARS= CARGO_FEATURES+=pulseaudio_backend
Крейты имеют собственные лицензии. Важно знать, какие они, при добавлении блока LICENSE в порт (см. Лицензии). Вспомогательная цель cargo-crates-licenses попытается перечислить все лицензии всех ящиков, определённых в CARGO_CRATES.
% make cargo-crates-licenses
aho-corasick-0.6.4 Unlicense/MIT
ansi_term-0.11.0 MIT
arrayvec-0.4.7 MIT/Apache-2.0
atty-0.2.9 MIT
bitflags-1.0.1 MIT/Apache-2.0
byteorder-1.2.2 Unlicense/MIT
[...]Названия лицензий, которые выводит |
6.6.7. Использование meson
Для портов, использующих Meson, определите USES=meson.
| Переменная | Описание |
|---|---|
| Порт-специфичные флаги Meson, передаваемые в бинарный файл |
| Путь к директории сборки относительно |
USES=mesonЭтот фрагмент демонстрирует использование Meson для порта.
USES= meson MESON_ARGS= -Dfoo=enabled
6.6.8. Создание приложений на Go
Для портов, использующих Go, определите USES=go. Обратитесь к go для получения списка переменных, которые можно задать для управления процессом сборки.
В большинстве случаев достаточно установить переменную GO_MODULE в значение, указанное директивой module в go.mod:
PORTNAME= hey
DISTVERSIONPREFIX= v
DISTVERSION= 0.1.4
CATEGORIES= benchmarks
MAINTAINER= dmgk@FreeBSD.org
COMMENT= Tiny program that sends some load to a web application
WWW= https://github.com/rakyll/hey/
LICENSE= APACHE20
LICENSE_FILE= ${WRKSRC}/LICENSE
USES= go:modules
GO_MODULE= github.com/rakyll/hey
PLIST_FILES= bin/hey
.include <bsd.port.mk>Если «простой» способ не подходит или требуется больший контроль над зависимостями, полный процесс переноса описан ниже.
Создание порта на основе Go — это процесс из пяти этапов. Сначала необходимо предоставить шаблон портов, который загружает дистрибутивный файл приложения:
PORTNAME= ghq DISTVERSIONPREFIX= v DISTVERSION= 0.12.5 CATEGORIES= devel MAINTAINER= tobik@FreeBSD.org COMMENT= Remote repository management made easy WWW= https://github.com/x-motemen/ghq/ USES= go:modules USE_GITHUB= yes GH_ACCOUNT= motemen .include <bsd.port.mk>
Сгенерировать первоначальный distinfo:
% make makesum
===> License MIT accepted by the user
=> motemen-ghq-v0.12.5_GH0.tar.gz doesn't seem to exist in /usr/ports/distfiles/.
=> Attempting to fetch https://codeload.github.com/motemen/ghq/tar.gz/v0.12.5?dummy=/motemen-ghq-v0.12.5_GH0.tar.gz
fetch: https://codeload.github.com/motemen/ghq/tar.gz/v0.12.5?dummy=/motemen-ghq-v0.12.5_GH0.tar.gz: size of remote file is not known
motemen-ghq-v0.12.5_GH0.tar.gz 32 kB 177 kBps 00sТеперь файл дистрибутива готов к использованию, и мы можем извлечь необходимые зависимости модуля Go. Этот шаг требует наличия установленного пакета ports-mgmt/modules2tuple:
% make gomod-vendor
[...]
GH_TUPLE= \
Songmu:gitconfig:v0.0.2:songmu_gitconfig/vendor/github.com/Songmu/gitconfig \
daviddengcn:go-colortext:186a3d44e920:daviddengcn_go_colortext/vendor/github.com/daviddengcn/go-colortext \
go-yaml:yaml:v2.2.2:go_yaml_yaml/vendor/gopkg.in/yaml.v2 \
golang:net:3ec191127204:golang_net/vendor/golang.org/x/net \
golang:sync:112230192c58:golang_sync/vendor/golang.org/x/sync \
golang:xerrors:3ee3066db522:golang_xerrors/vendor/golang.org/x/xerrors \
motemen:go-colorine:45d19169413a:motemen_go_colorine/vendor/github.com/motemen/go-colorine \
urfave:cli:v1.20.0:urfave_cli/vendor/github.com/urfave/cliВывод этой команды необходимо вставить напрямую в Makefile:
PORTNAME= ghq DISTVERSIONPREFIX= v DISTVERSION= 0.12.5 CATEGORIES= devel MAINTAINER= tobik@FreeBSD.org COMMENT= Remote repository management made easy WWW= https://github.com/x-motemen/ghq/ USES= go:modules USE_GITHUB= yes GH_ACCOUNT= motemen GH_TUPLE= Songmu:gitconfig:v0.0.2:songmu_gitconfig/vendor/github.com/Songmu/gitconfig \ daviddengcn:go-colortext:186a3d44e920:daviddengcn_go_colortext/vendor/github.com/daviddengcn/go-colortext \ go-yaml:yaml:v2.2.2:go_yaml_yaml/vendor/gopkg.in/yaml.v2 \ golang:net:3ec191127204:golang_net/vendor/golang.org/x/net \ golang:sync:112230192c58:golang_sync/vendor/golang.org/x/sync \ golang:xerrors:3ee3066db522:golang_xerrors/vendor/golang.org/x/xerrors \ motemen:go-colorine:45d19169413a:motemen_go_colorine/vendor/github.com/motemen/go-colorine \ urfave:cli:v1.20.0:urfave_cli/vendor/github.com/urfave/cli .include <bsd.port.mk>
distinfo необходимо обновить, чтобы включить все дистрибутивные файлы:
% make makesum
=> Songmu-gitconfig-v0.0.2_GH0.tar.gz doesn't seem to exist in /usr/ports/distfiles/.
=> Attempting to fetch https://codeload.github.com/Songmu/gitconfig/tar.gz/v0.0.2?dummy=/Songmu-gitconfig-v0.0.2_GH0.tar.gz
fetch: https://codeload.github.com/Songmu/gitconfig/tar.gz/v0.0.2?dummy=/Songmu-gitconfig-v0.0.2_GH0.tar.gz: size of remote file is not known
Songmu-gitconfig-v0.0.2_GH0.tar.gz 5662 B 936 kBps 00s
=> daviddengcn-go-colortext-186a3d44e920_GH0.tar.gz doesn't seem to exist in /usr/ports/distfiles/.
=> Attempting to fetch https://codeload.github.com/daviddengcn/go-colortext/tar.gz/186a3d44e920?dummy=/daviddengcn-go-colortext-186a3d44e920_GH0.tar.gz
fetch: https://codeload.github.com/daviddengcn/go-colortext/tar.gz/186a3d44e920?dummy=/daviddengcn-go-colortext-186a3d44e920_GH0.tar.gz: size of remote file is not known
daviddengcn-go-colortext-186a3d44e920_GH0.tar. 4534 B 1098 kBps 00s
[...]Порт теперь готов к тестовой сборке и дальнейшим настройкам, таким как создание plist, написание описания, добавление информации о лицензии, опций и т.д., как обычно.
Если вы не тестируете свой порт в чистой среде, например, с использованием poudriere, не забудьте выполнить make clean перед любым тестированием.
Некоторые порты требуют установки результирующего бинарного файла под другим именем или в путь, отличный от стандартного ${PREFIX}/bin. Это можно сделать с помощью синтаксиса кортежа GO_TARGET, например:
GO_TARGET= ./cmd/ipfs:ipfs-go
установит бинарный файл ipfs как ${PREFIX}/bin/ipfs-go и
GO_TARGET= ./dnscrypt-proxy:${PREFIX}/sbin/dnscrypt-proxyустановит dnscrypt-proxy в ${PREFIX}/sbin.
6.6.9. Построение приложений на Haskell с помощью cabal
Для портов, использующих Cabal, система сборки определяет USES=cabal. Обратитесь к cabal для получения списка переменных, которые можно задать для управления процессом сборки.
При подготовке порта Haskell Cabal требуются программы devel/hs-cabal-install и ports-mgmt/hs-cabal2tuple, поэтому убедитесь, что они установлены заранее. Сначала необходимо определить общие переменные портов, которые позволяют cabal-install загрузить файл дистрибутива пакета:
PORTNAME= ShellCheck DISTVERSION= 0.6.0 CATEGORIES= devel MAINTAINER= haskell@FreeBSD.org COMMENT= Shell script analysis tool WWW= https://www.shellcheck.net/ USES= cabal .include <bsd.port.mk>
Этот минимальный Makefile загружает файл дистрибутива с помощью вспомогательной цели cabal-extract:
% make cabal-extract
[...]
Downloading the latest package list from hackage.haskell.org
cabal get ShellCheck-0.6.0
Downloading ShellCheck-0.6.0
Downloaded ShellCheck-0.6.0
Unpacking to ShellCheck-0.6.0/Теперь, когда у нас есть файл описания пакета ShellCheck.cabal в ${WRKSRC}, мы можем использовать cabal-configure для создания плана сборки:
% make cabal-configure
[...]
Resolving dependencies...
Build profile: -w ghc-8.10.7 -O1
In order, the following would be built (use -v for more details):
- Diff-0.4.1 (lib) (requires download & build)
- OneTuple-0.3.1 (lib) (requires download & build)
[...]После завершения можно сгенерировать список необходимых зависимостей:
% make make-use-cabal
USE_CABAL= QuickCheck-2.12.6.1 \
hashable-1.3.0.0 \
integer-logarithms-1.0.3 \
[...]Пакеты Haskell могут содержать ревизии, как и порты FreeBSD. Ревизии могут затрагивать только файлы .cabal. Обратите внимание на дополнительные номера версий после символа _. Замените старый список USE_CABAL на вновь сгенерированный.
Наконец, файл distinfo необходимо перегенерировать, чтобы он содержал все файлы дистрибутива:
% make makesum
=> ShellCheck-0.6.0.tar.gz doesn't seem to exist in /usr/local/poudriere/ports/git/distfiles/cabal.
=> Attempting to fetch https://hackage.haskell.org/package/ShellCheck-0.6.0/ShellCheck-0.6.0.tar.gz
ShellCheck-0.6.0.tar.gz 136 kB 642 kBps 00s
=> QuickCheck-2.12.6.1/QuickCheck-2.12.6.1.tar.gz doesn't seem to exist in /usr/local/poudriere/ports/git/distfiles/cabal.
=> Attempting to fetch https://hackage.haskell.org/package/QuickCheck-2.12.6.1/QuickCheck-2.12.6.1.tar.gz
QuickCheck-2.12.6.1/QuickCheck-2.12.6.1.tar.gz 65 kB 361 kBps 00s
[...]Порт теперь готов к тестовой сборке и дальнейшим настройкам, таким как создание plist, написание описания, добавление информации о лицензии, опций и т.д., как обычно.
Если вы не тестируете свой порт в чистой среде, например, с использованием poudriere, не забудьте выполнить make clean перед любым тестированием.
Некоторые порты Haskell устанавливают различные файлы данных в share/${PORTNAME}. В таких случаях требуется особая обработка на стороне порта. Порт должен определить параметр CABAL_WRAPPER_SCRIPTS, перечислив каждый исполняемый файл, который будет использовать файлы данных. Более того, в редких случаях портируемая программа использует файлы данных других пакетов Haskell, и тогда на помощь приходит FOO_DATADIR_VARS.
devel/hs-profiteur — это приложение на Haskell, которое генерирует одностраничный HTML с некоторым содержимым.
PORTNAME= profiteur [...] USES= cabal USE_CABAL= OneTuple-0.3.1_2 \ QuickCheck-2.14.2 \ [...] .include <bsd.port.mk>
Он устанавливает HTML-шаблоны в share/profiteur, поэтому необходимо добавить параметр CABAL_WRAPPER_SCRIPTS:
[...]
USE_CABAL= OneTuple-0.3.1_2 \
QuickCheck-2.14.2 \
[...]
CABAL_WRAPPER_SCRIPTS= ${CABAL_EXECUTABLES}
.include <bsd.port.mk>Программа также пытается получить доступ к файлу jquery.js, который является частью пакета Haskell js-jquery-3.3.1. Чтобы этот файл был найден, необходимо, чтобы скрипт-обёртка искал файлы данных js-jquery также в share/profiteur. Для этого используется profiteur_DATADIR_VARS:
[...]
CABAL_WRAPPER_SCRIPTS= ${CABAL_EXECUTABLES}
profiteur_DATADIR_VARS= js-jquery
.include <bsd.port.mk>Теперь порт установит непосредственно бинарный файл в libexec/cabal/profiteur, а скрипт — в bin/profiteur.
Не существует простого способа определить подходящее значение для параметра FOO_DATADIR_VARS, кроме как запустить программу и проверить, что всё работает. К счастью, необходимость использовать FOO_DATADIR_VARS возникает очень редко.
Еще один крайний случай при переносе сложных программ на Haskell — наличие зависимостей от систем контроля версий (VCS) в файле cabal.project.
net-p2p/cardano-node — это чрезвычайно сложное программное обеспечение. В его cabal.project содержится множество блоков, подобных этому:
[...] source-repository-package type: git location: https://github.com/input-output-hk/cardano-crypto tag: f73079303f663e028288f9f4a9e08bcca39a923e [...]
Зависимости типа source-repository-package автоматически подтягиваются cabal в процессе сборки. К сожалению, это приводит к использованию сети после этапа fetch, что запрещено в рамках системы портов. Эти исходники необходимо указать в Makefile порта. Вспомогательная цель make-use-cabal может упростить работу с пакетами, размещёнными на GitHub. Запуск этой цели после стандартных cabal-extract и cabal-configure позволит получить не только параметр USE_CABAL, но и GH_TUPLE:
% make make-use-cabal
USE_CABAL= Diff-0.4.1 \
Glob-0.10.2_3 \
HUnit-1.6.2.0 \
[...]
GH_TUPLE= input-output-hk:cardano-base:0f3a867493059e650cda69e20a5cbf1ace289a57:cardano_base/dist-newstyle/src/cardano-b_-c8db9876882556ed \
input-output-hk:cardano-crypto:f73079303f663e028288f9f4a9e08bcca39a923e:cardano_crypto/dist-newstyle/src/cardano-c_-253fd88117badd8f \
[...]Может быть полезно отделить элементы GH_TUPLE, поступающие из make-use-cabal, от остальных, чтобы упростить обновление порта:
GH_TUPLE= input-output-hk:cardano-base:0f3a867493059e650cda69e20a5cbf1ace289a57:cardano_base/dist-newstyle/src/cardano-b_-c8db9876882556ed \ input-output-hk:cardano-crypto:f73079303f663e028288f9f4a9e08bcca39a923e:cardano_crypto/dist-newstyle/src/cardano-c_-253fd88117badd8f \ [...] GH_TUPLE+= bitcoin-core:secp256k1:ac83be33d0956faf6b7f61a60ab524ef7d6a473a:secp
Версия Haskell-портов с зависимостями от систем контроля версий временно требует следующего обходного решения:
BINARY_ALIAS= git=true
6.7. Использование GNU Autotools
Если порту требуется какое-либо программное обеспечение GNU Autotools, добавьте USES=autoreconf. Подробнее см. в autoreconf.
6.8. Использование GNU gettext
6.8.1. Простые варианты использования
Если порт требует gettext, установите USES=gettext, и порт унаследует зависимость от libintl.so из пакета devel/gettext. Другие значения для использования gettext перечислены в USES=gettext.
Довольно распространённый случай — порт, использующий gettext и configure. Обычно GNU configure должен автоматически находить gettext.
USES= gettext GNU_CONFIGURE= yes
Если он не сработает, можно указать расположение gettext через CPPFLAGS и LDFLAGS, используя localbase следующим образом:
USES= gettext localbase:ldflags GNU_CONFIGURE= yes
6.8.2. Оптимальное использование
Некоторые программные продукты позволяют отключать NLS, к примеру, передавая параметр --disable-nls сценарию configure. В этом случае ваш порт должен использовать gettext, в зависимости от значения NLS. Для портов небольшой или средней сложности вы можете полагаться на следующую идиому:
GNU_CONFIGURE= yes OPTIONS_DEFINE= NLS OPTIONS_SUB= yes NLS_USES= gettext NLS_CONFIGURE_ENABLE= nls .include <bsd.port.mk>
Или используя старый способ с опциями:
GNU_CONFIGURE= yes
OPTIONS_DEFINE= NLS
.include <bsd.port.options.mk>
.if ${PORT_OPTIONS:MNLS}
USES+= gettext
PLIST_SUB+= NLS=""
.else
CONFIGURE_ARGS+= --disable-nls
PLIST_SUB+= NLS="@comment "
.endif
.include <bsd.port.mk>Следующий пункт в списке задач — организовать условное включение файлов каталогов сообщений в упаковочный список. Часть, связанная с Makefile, уже предусмотрена идиомой. Это объясняется в разделе расширенные практики работы с pkg-plist. Вкратце, каждое вхождение %%NLS%% в pkg-plist будет заменено на "`@comment ", если NLS отключен, или на пустую строку, если NLS включен. Следовательно, строки с префиксом `%%NLS%% станут обычными комментариями в итоговом упаковочном списке, если NLS выключен; в противном случае префикс будет просто удален. Затем вставьте %%NLS%% перед каждым путем к файлу каталога сообщений в pkg-plist. Например:
%%NLS%%share/locale/fr/LC_MESSAGES/foobar.mo %%NLS%%share/locale/no/LC_MESSAGES/foobar.mo
В особо сложных случаях вам понадобиться использовать более продвинутые техники, чем данный рецепт, такие как динамические списки упаковки.
6.8.3. Управление каталогами сообщений
Существует момент, который следует учитывать при установке файлов каталогов сообщений. Целевые каталоги для размещения, расположенные под LOCALBASE/shared/locale, редко когда должны создаваться и удаляться портом. Для наиболее популярных языков имеются собственные каталоги, перечисленные в PORTSDIR/Templates/BSD.local.dist. Каталоги для множества других языков управляются с помощью порта devel/gettext. Обратите внимание на его pkg-plist и посмотрите, куда данный порт собирается установить файлы каталогов сообщений для единственного в своем роде языка.
6.9. Использование Perl
Если MASTER_SITES установлена в значение CPAN, то правильная поддиректория выбирается автоматически. Если подкаталог по умолчанию указан неверно, можно использовать CPAN/Module для его изменения. Также можно установить MASTER_SITES в старое значение MASTER_SITE_PERL_CPAN, тогда предпочтительным значением MASTER_SITE_SUBDIR будет имя иерархии выше уровнем. Например, рекомендуемое значение для p5-Module-Name - Module. Иерархию верхнего уровня можно посмотреть на cpan.org. Это гарантирует работоспособность порта при смене автора модуля.
Исключением этого правила является отсутствие соответствующего каталога или файла с дистрибутивом в этом каталоге. В качестве MASTER_SITE_SUBDIR в этом случае разрешается использовать id автора. Можно использовать макрос CPAN:AUTHOR, который будет преобразован в хешированный каталог автора. Например, CPAN:AUTHOR преобразуется в authors/id/A/AU/AUTHOR.
Когда порту требуется поддержка Perl, он должен установить USES=perl5 с опциональным USE_PERL5, как описано в описание USES для perl5.
| Переменные (только для чтения) | Значение |
|---|---|
| Полный путь к интерпретатору Perl 5, будь то системный или установленный из порта, но без номера версии. Используйте это, когда программному обеспечению требуется путь к интерпретатору Perl. Для замены строк “`#! |
| Полная версия Perl установлена (например, |
| Установленная версия Perl в виде целого числа формата |
| Где Perl хранит архитектурно-зависимые библиотеки. По умолчанию: |
| Имя порта Perl, который установлен (например, |
| Имя каталога, в котором размещаются специфичные для сайта пакеты Perl. Это значение добавляется в |
Порты Perl-модулей, у которых нет официального сайта, должны ссылаться на |
Не используйте |
p5-IO-Tee>=0.64:devel/p5-IO-Tee
Для портов Perl, которые устанавливают страницы руководства, макросы PERL5_MAN3 и PERL5_MAN1 могут использоваться внутри pkg-plist. Например,
lib/perl5/5.14/man/man1/event.1.gz lib/perl5/5.14/man/man3/AnyEvent::I3.3.gz
может быть заменено на
%%PERL5_MAN1%%/event.1.gz %%PERL5_MAN3%%/AnyEvent::I3.3.gz
Для других разделов (x в |
Поскольку значение USE_PERL5 по умолчанию включает build и run, установите его в:
USES= perl5 USE_PERL5= build
ExtUtils::MakeMakerБольшинство модулей Perl поставляются с конфигурационным скриптом Makefile.PL. В этом случае установите:
USES= perl5 USE_PERL5= configure
Module::BuildКогда модуль Perl поставляется с конфигурационным скриптом Build.PL, он может требовать Module::Build, и в этом случае установите
USES= perl5 USE_PERL5= modbuild
Если вместо этого требуется Module::Build::Tiny, установите
USES= perl5 USE_PERL5= modbuildtiny
6.10. Использование X11
6.10.1. Компоненты X.Org
Реализация X11, доступная в Коллекции портов, — это X.Org. Если приложение зависит от компонентов X, добавьте USES= xorg и укажите необходимые компоненты в USE_XORG. Полный список можно найти в xorg.
Проект Mesa — это инициатива по предоставлению свободной реализации OpenGL. Чтобы указать зависимость от различных компонентов этого проекта, используйте USES=gl и USE_GL. См. gl для полного списка доступных компонентов. Для обратной совместимости значение yes соответствует glu.
USE_XORGUSES= gl xorg USE_GL= glu USE_XORG= xrender xft xkbfile xt xaw
| Порт использует |
| Установить путь к |
# Use some X11 libraries USES= xorg USE_XORG= x11 xpm
6.10.2. Порты, требующие Motif
Если порт требует библиотеку Motif, определите USES= motif в Makefile. Реализация Motif по умолчанию — это x11-toolkits/open-motif. Пользователи могут выбрать x11-toolkits/lesstif вместо этого, установив WANT_LESSTIF в своём make.conf. Аналогично x11-toolkits/open-motif-devel можно выбрать, установив WANT_OPEN_MOTIF_DEVEL в make.conf.
MOTIFLIB будет установлен в файле motif.mk для ссылки на соответствующую библиотеку Motif. Пожалуйста, исправьте исходный код порта, чтобы использовать ${MOTIFLIB} везде, где библиотека Motif упоминается в оригинальном Makefile или Imakefile.
Есть два распространённых случая:
Если порт ссылается на библиотеку Motif как
-lXmв своем Makefile или Imakefile, замените это на${MOTIFLIB}.Если порт использует
XmClientLibsв своем Imakefile, замените это на${MOTIFLIB} ${XTOOLLIB} ${XLIB}.
Обратите внимание, что MOTIFLIB (обычно) раскрывается в -L/usr/local/lib -lXm -lXp или /usr/local/lib/libXm.a, поэтому нет необходимости добавлять -L или -l перед этим.
6.10.3. Шрифты X11
Если порт устанавливает шрифты для X Window System, поместите их в LOCALBASE/lib/X11/fonts/local.
6.10.4. Получение поддельного DISPLAY с помощью Xvfb
Некоторые приложения требуют рабочего дисплея X11 для успешной компиляции. Это создаёт проблему для машин, работающих без монитора. При использовании этой переменной инфраструктура сборки запустит виртуальный X-сервер с буфером кадров. Рабочий DISPLAY затем передаётся в процесс сборки. См. USES=display для возможных аргументов.
USES= display
6.10.5. Desktop Entries (пункты рабочего стола)
Desktop entries (стандарт Freedesktop) предоставляют способ автоматической настройки функций рабочего стола при установке новой программы без вмешательства пользователя. Например, вновь установленные программы автоматически появляются в меню приложений совместимых сред рабочего стола. Desktop entries появились в среде GNOME, но теперь стали стандартом и также работают с KDE и Xfce. Эта автоматизация приносит реальную пользу пользователю, поэтому Desktop entries рекомендуются для приложений, которые могут использоваться в среде рабочего стола.
6.10.5.1. Использование предопределенных файлов .desktop
Порты, включающие предопределённые файлы *.desktop, должны добавлять эти файлы в pkg-plist и устанавливать их в директорию $LOCALBASE/share/applications. Для установки таких файлов полезен макрос INSTALL_DATA.
6.10.5.2. Обновление базы данных рабочего стола
Если порт имеет запись MimeType в файле portname.desktop, базу данных рабочего стола необходимо обновить после установки и удаления. Для этого определите USES= desktop-file-utils.
6.10.5.3. Создание Desktop Entries с помощью DESKTOP_ENTRIES
Desktop Entries могут быть легко созданы для приложений с использованием DESKTOP_ENTRIES. Файл с именем name.desktop будет создан, установлен и автоматически добавлен в pkg-plist. Синтаксис следующий:
DESKTOP_ENTRIES= "NAME" "COMMENT" "ICON" "COMMAND" "CATEGORY" StartupNotify
Список возможных категорий доступен на сайте Freedesktop. StartupNotify указывает, совместимо ли приложение с уведомлениями о запуске. Обычно это графический индикатор, например, часы, который появляется у указателя мыши, в меню или на панели, чтобы дать пользователю понять, что программа запускается. Программа, совместимая с уведомлениями о запуске, очищает индикатор после своего старта. Программы, не совместимые с уведомлениями о запуске, никогда не очищают индикатор (что может сбивать с толку и раздражать пользователя), и у них должен быть установлен параметр StartupNotify в значение false, чтобы индикатор вообще не отображался.
Пример:
DESKTOP_ENTRIES= "ToME" "Roguelike game based on JRR Tolkien's work" \
"${DATADIR}/xtra/graf/tome-128.png" \
"tome -v -g" "Application;Game;RolePlaying;" \
falseDESKTOP_ENTRIES устанавливаются в директорию, указанную переменной DESKTOPDIR. По умолчанию DESKTOPDIR имеет значение ${PREFIX}/share/applications
6.11. Использование GNOME
6.11.1. Введение
Эта глава объясняет фреймворк GNOME, используемый в портах. Фреймворк можно условно разделить на базовые компоненты, компоненты рабочего стола GNOME и несколько специальных макросов, упрощающих работу сопровождающих портов.
6.11.2. Использование USE_GNOME
Добавление этой переменной в порт позволяет использовать макросы и компоненты, определённые в bsd.gnome.mk. Код в bsd.gnome.mk добавляет необходимые зависимости для сборки, выполнения или библиотеки, а также обработку специальных файлов. Приложения GNOME в FreeBSD используют инфраструктуру USE_GNOME. Включите все необходимые компоненты в виде списка, разделённого пробелами. Компоненты USE_GNOME разделены на следующие виртуальные списки: основные компоненты, компоненты GNOME 3 и устаревшие компоненты. Если порту требуются только библиотеки GTK3, это кратчайший способ определить это:
USE_GNOME= gtk30
USE_GNOME компоненты автоматически добавляют необходимые им зависимости. Подробный список всех компонентов USE_GNOME, а также информацию о том, какие другие компоненты они подразумевают и их зависимости, можно найти в Компоненты GNOME.
Вот пример Makefile для порта GNOME, в котором используются многие методы, описанные в этом документе. Пожалуйста, используйте его в качестве руководства при создании новых портов.
PORTNAME= regexxer DISTVERSION= 0.10 CATEGORIES= devel textproc gnome MASTER_SITES= GNOME MAINTAINER= kwm@FreeBSD.org COMMENT= Interactive tool for performing search and replace operations WWW= http://regexxer.sourceforge.net/ USES= gettext gmake localbase:ldflags pathfix pkgconfig tar:xz GNU_CONFIGURE= yes USE_GNOME= gnomeprefix intlhack gtksourceviewmm3 GLIB_SCHEMAS= org.regexxer.gschema.xml .include <bsd.port.mk>
Макрос |
6.11.3. Переменные
Этот раздел объясняет, какие макросы доступны и как они используются. Как, например, в приведённом выше примере. В Компоненты GNOME содержится более подробное объяснение. Для использования этих макросов необходимо установить USE_GNOME.
GLIB_SCHEMASСписок всех файлов схем glib, которые устанавливает порт. Макрос добавит файлы в plist порта и обработает регистрацию этих файлов при установке и удалении.
Файлы схем glib написаны в XML и имеют расширение gschema.xml. Они устанавливаются в директорию share/glib-2.0/schemas/. Эти файлы схем содержат все настройки конфигурации приложений со значениями по умолчанию. Фактическая база данных, используемая приложениями, создаётся с помощью glib-compile-schema, которая запускается макросом
GLIB_SCHEMAS.GLIB_SCHEMAS=foo.gschema.xml
Не добавляйте схемы glib в файл pkg-plist. Если они указаны в pkg-plist, они не будут зарегистрированы, и приложения могут работать некорректно.
GCONF_SCHEMASПеречислите все файлы схем gconf. Макрос добавит файлы схем в plist порта и обеспечит их регистрацию при установке и удалении.
GConf — это база данных на основе XML, которую используют практически все приложения GNOME для хранения своих настроек. Эти файлы устанавливаются в директорию etc/gconf/schemas. Эта база данных определяется установленными файлами схем, которые используются для генерации ключевых файлов %gconf.xml. Для каждого файла схемы, устанавливаемого портом, должна быть запись в Makefile:
GCONF_SCHEMAS=my_app.schemas my_app2.schemas my_app3.schemas
Схемы Gconf перечислены в макросе
GCONF_SCHEMAS, а не в файле pkg-plist. Если они указаны в pkg-plist, они не будут зарегистрированы, и приложения могут работать некорректно.INSTALLS_OMFФайлы Open Source Metadata Framework (OMF) часто используются приложениями GNOME 2. Эти файлы содержат информацию о файлах справки приложений и требуют специальной обработки с помощью ScrollKeeper/rarian. Для правильной регистрации файлов OMF при установке приложений GNOME из пакетов убедитесь, что файлы
omfуказаны вpkg-plistи что в Makefile порта определеноINSTALLS_OMF:INSTALLS_OMF=yes
При установке bsd.gnome.mk автоматически сканирует pkg-plist и добавляет соответствующие директивы
@execи@unexecдля каждого файла .omf, который необходимо отслеживать в базе данных регистрации OMF.
6.12. Компоненты GNOME
Для получения дополнительной помощи с портом GNOME, ознакомьтесь с некоторыми из существующих портов в качестве примеров. На странице FreeBSD GNOME указана контактная информация, если требуется дополнительная помощь. Компоненты разделены на используемые в настоящее время компоненты GNOME и устаревшие компоненты. Если компонент поддерживает аргументы, они перечислены в скобках в описании. Первый аргумент является значением по умолчанию. "Both" указывается, если компонент по умолчанию добавляется как в зависимости для сборки, так и для выполнения.
| Компонент | Связанная программа | Описание |
|---|---|---|
| accessibility/atk | Инструментарий доступности (ATK) |
| accessibility/atkmm | C++ интерфейс для atk |
| graphics/cairo | Векторная графическая библиотека с поддержкой вывода на различные устройства |
| graphics/cairomm | C++ интерфейс для cairo |
| devel/dconf | Система базы данных конфигурации (both, build, run) |
| databases/evolution-data-server | Бэкенды данных для интегрированного почтового клиента/PIM Evolution |
| graphics/gdk-pixbuf2 | Графическая библиотека для GTK+ |
| devel/glib20 | Основная библиотека GNOME |
| devel/glibmm | C++ интерфейс для glib20 |
| sysutils/gnome-control-center | Центр управления GNOME 3 |
| x11/gnome-desktop | Библиотека пользовательского интерфейса рабочего стола GNOME 3 |
| audio/gsound | Библиотека GObject для воспроизведения системных звуков (both, build, run) |
| graphics/gtk-update-icon-cache | Утилита |
| x11-toolkits/gtk20 | Набор инструментов Gtk+ 2 |
| x11-toolkits/gtk30 | Набор инструментов Gtk+ 3 |
| x11-toolkits/gtkmm20 | C++ интерфейс 2.0 для инструментария gtk20 |
| x11-toolkits/gtkmm24 | C++ интерфейс 2.4 для инструментария gtk20 |
| x11-toolkits/gtkmm30 | C++ интерфейс 3.0 для набора инструментов gtk30 |
| x11-toolkits/gtksourceview2 | Виджет, добавляющий подсветку синтаксиса в GtkTextView |
| x11-toolkits/gtksourceview3 | Текстовая виджет, добавляющая подсветку синтаксиса к виджету GtkTextView |
| x11-toolkits/gtksourceviewmm3 | C++ интерфейс для библиотеки gtksourceview3 |
| devel/gvfs | Виртуальная файловая система GNOME |
| textproc/intltool | Инструмент для интернационализации (см. также intlhack) |
| devel/gobject-introspection | Базовые привязки (биндинги) интроспекции и инструменты для генерации привязок интроспекции. В большинстве случаев достаточно |
| databases/libgda5 | Обеспечивает единообразный доступ к различным типам источников данных |
| databases/libgda5-ui | Библиотека пользовательского интерфейса из библиотеки libgda5 |
| databases/libgdamm5 | привязки C++ для библиотеки libgda5 |
| devel/libgsf | Расширяемая абстракция ввода-вывода для работы со структурированными форматами файлов |
| graphics/librsvg2 | Библиотека для разбора и отображения SVG-файлов векторной графики |
| devel/libsigc++20 | Фреймворк обратных вызовов для C++ |
| textproc/libxml++26 | C++ привязки для библиотеки libxml2 |
| textproc/libxml2 | Библиотека парсера XML (both, build, run) |
| textproc/libxslt | Библиотека XSLT (сборка, выполнение) |
| x11-wm/metacity | Менеджер окон из GNOME |
| x11-fm/nautilus | GNOME файловый менеджер |
| x11-toolkits/pango | Открытый фреймворк для разметки и отображения интернационализированного текста |
| x11-toolkits/pangomm | C++ интерфейс для библиотеки pango |
| devel/py3-gobject3 | Python 3, интерфейс GObject 3.0 |
| devel/py-gobject3 | Python 2, интерфейс GObject 3.0 |
| x11-toolkits/vte3 | Виджет терминала с улучшенной поддержкой доступности и интернационализации (I18N) |
| Компонент | Описание |
|---|---|
| Предоставляет |
| То же, что и |
| Этот макрос предназначен для помощи в разделении API или справочной документации на собственный порт. |
| Компонент | Связанная программа | Описание |
|---|---|---|
| accessibility/at-spi | Интерфейс поставщика услуг вспомогательных технологий (AT-SPI) |
| audio/esound | Пакет звука Enlightenment |
| x11-toolkits/gal2 | Коллекция виджетов, взятых из GNOME 2 gnumeric |
| devel/gconf2 | Система базы данных конфигурации для GNOME 2 |
| devel/gconfmm26 | C привязки C для gconf2 |
| graphics/gdk-pixbuf | Графическая библиотека для GTK+ |
| devel/glib12 | Библиотека ядра glib 1.2 |
| textproc/gnome-doc-utils | Утилиты документации GNOME |
| misc/gnome-mime-data | База данных MIME и приложений для GNOME 2 |
| x11-toolkits/gnome-sharp20 | Интерфейсы GNOME 2 для среды выполнения .NET |
| accessibility/gnome-speech | GNOME 2 API преобразования текста в речь |
| devel/gnome-vfs | Виртуальная файловая система GNOME 2 |
| x11-toolkits/gtk12 | Набор инструментов Gtk+ 1.2 |
| www/gtkhtml3 | Облегченный движок для отображения/печати/редактирования HTML |
| www/gtkhtml4 | Облегченный движок для отображения/печати/редактирования HTML |
| x11-toolkits/gtk-sharp20 | Интерфейсы GTK+ и GNOME 2 для среды выполнения .NET |
| x11-toolkits/gtksourceview | Виджет, добавляющий подсветку синтаксиса в GtkTextView |
| graphics/libart_lgpl | Библиотека для высокопроизводительной 2D графики |
| devel/libbonobo | Система компонентов и составных документов для GNOME 2 |
| x11-toolkits/libbonoboui | Интерфейс для libbonobo в GNOME 2 |
| databases/libgda4 | Обеспечивает единообразный доступ к различным типам источников данных |
| devel/libglade2 | Библиотека glade для GNOME 2 |
| x11/libgnome | Библиотеки для GNOME 2, GNU окружения рабочего стола |
| graphics/libgnomecanvas | Графическая библиотека для GNOME 2 |
| x11/libgnomekbd | Динамическая библиотека клавиатуры GNOME 2 |
| print/libgnomeprint | Библиотека поддержки печати Gnome 2 |
| x11-toolkits/libgnomeprintui | Библиотека поддержки печати Gnome 2 |
| x11-toolkits/libgnomeui | Библиотеки для графического интерфейса GNOME 2, среды рабочего стола GNU |
| www/libgtkhtml | Облегченный движок для отображения/печати/редактирования HTML |
| x11-toolkits/libgtksourceviewmm | C++ интерфейс GtkSourceView |
| devel/libIDL | Библиотека для создания деревьев файлов CORBA IDL |
| devel/libsigc++12 | Фреймворк обратных вызовов для C++ |
| x11-toolkits/libwnck | Библиотека, используемая для написания пейджеров и списков задач |
| x11-toolkits/libwnck3 | Библиотека, используемая для написания пейджеров и списков задач |
| devel/ORBit2 | Высокопроизводительный CORBA ORB с поддержкой языка C |
| x11-toolkits/py-gnome2 | Интерфейс Python для GNOME 2 |
| devel/py-gobject | Python 2, интерфейс GObject 2.0 |
| x11-toolkits/py-gtk2 | Набор интерфейсов Python для GTK+ |
| x11-toolkits/py-gtksourceview | Интерфейс Python для GtkSourceView 2 |
| x11-toolkits/vte | Виджет терминала с улучшенной поддержкой доступности и интернационализации (I18N) |
| Компонент | Описание |
|---|---|
| pangox-compat устарел и был отделён от пакета pango. |
6.13. Использование Qt
Для портов, которые являются частью самого Qt, см. |
6.13.1. Порты, требующие Qt
Коллекция портов поддерживает Qt 5 и Qt 6 с помощью USES+=qt:5 и USES+=qt:6 соответственно. Установите USE_QT в список необходимых компонентов Qt (libraries, tools, plugins - библиотеки, инструменты, плагины).
Фреймворк Qt экспортирует ряд переменных, которые могут использоваться портами, некоторые из них перечислены ниже:
| Полный путь к исполняемому файлу |
| Полный путь к утилите |
| Полный путь к |
| Полный путь к |
| Полный путь к |
| Каталог включаемых файлов Qt. |
| Путь к библиотекам Qt. |
| Путь к плагинам Qt. |
6.13.2. Выбор компонентов
Отдельные зависимости инструментов и библиотек Qt должны быть указаны в USE_QT. Каждый компонент может иметь суффикс _build или _run, указывающий, требуется ли компонент во время сборки или выполнения. Если суффикс отсутствует, компонент будет требоваться как во время сборки, так и во время выполнения. Обычно компоненты библиотек указываются без суффикса, компоненты инструментов чаще всего указываются с суффиксом _build, а компоненты плагинов — с суффиксом _run. Наиболее часто используемые компоненты перечислены ниже (все доступные компоненты перечислены в _USE_QT_ALL, которая формируется из _USE_QT_COMMON и _USE_QT[56]_ONLY в /usr/ports/Mk/Uses/qt.mk):
| Имя | Описание |
|---|---|
| Модуль Qt3D |
| Модуль совместимости Qt 5 для Qt 6 |
| Браузер документации Qt 5 |
| Модуль Qt 6 base |
| Модуль Qt canvas3d |
| Модуль Qt 5 charts |
| Модуль многопоточности Qt |
| Модуль Qt для подключения (Bluetooth/NFC) |
| Ядро Qt, неграфический модуль |
| Модуль визуализации 3D данных Qt 5 |
| Модуль межпроцессного взаимодействия Qt D-Bus |
| Декларативный фреймворк Qt для динамических пользовательских интерфейсов |
| Интерфейсный конструктор Qt 5 для графического пользовательского интерфейса |
| Инструмент для сбора диагностической информации о Qt и его окружении |
| Документация Qt 5 |
| Исходный код примеров Qt 5 |
| Модуль Qt 5 Gamepad |
| Графические эффекты Qt Quick |
| Модуль графического интерфейса Qt |
| Модуль интеграции справки Qt в режиме онлайн |
| Локализованные сообщения Qt |
| Реализация протокола Language Server Protocol в Qt 6 |
| Инструмент перевода Qt 5 |
| Модуль Qt Location |
| Qt 6 QML API для отрисовки графики и анимаций |
| Модуль поддержки аудио, видео, радио и камеры Qt |
| Сетевой модуль Qt |
| Модуль сетевой аутентификации Qt |
| Модуль поддержки OpenGL, совместимый с Qt 5 |
| Клиент командной строки для QStandardPaths |
| Мультимедийный фреймворк KDE |
| Увеличитель экрана Qt 5 |
| Дампер метаданных плагинов Qt 5 |
| Qt 6 API позиционирования из источников, таких как спутники, Wi-Fi или текстовые файлы. |
| Модуль поддержки печати Qt |
| Интерфейс командной строки Qt для D-Bus |
| Графический интерфейс Qt 5 для D-Bus |
| Генератор документации Qt |
| Файлы конфигурации QDoc |
| Инструмент для интроспекции событий Qt QWidget |
| Генератор Makefile Qt |
| Набор элементов управления для создания полных интерфейсов в Qt Quick |
| Набор элементов управления для создания полных интерфейсов в Qt Quick |
| Модуль Qt 5 SXCML |
| Совместимый с Qt 4 модуль для написания сценариев |
| Дополнительные компоненты Qt Script |
| Модуль Qt 5 SXCML |
| Модуль Qt sensors |
| Функции Qt для доступа к промышленным шинным системам |
| Функции Qt для доступа к последовательным портам |
| Инструменты Qt 6 для кроссплатформенного конвейера шейдеров Qt |
| Доступность в Qt5 |
| Модуль интеграции с базой данных Qt SQL |
| Плагин Qt баз данных InterBase/Firebird |
| Плагин Qt базы данных MySQL |
| Плагин Qt ODBC |
| Плагин Qt базы данных PostgreSQL |
| Плагин Qt базы данных SQLite 2 |
| Плагин Qt базы данных SQLite 3 |
| Плагин Qt для подключение к базам данных по протоколу TDS |
| Модуль поддержки SVG в Qt |
| Модуль тестирования Qt |
| Различные инструменты Qt 6 |
| Модуль перевода Qt 6 |
| Интерфейс плагина пользовательского виджета Qt для Qt Designer |
| Модуль поддержки форм пользовательского интерфейса Qt Designer |
| Модуль виртуальной клавиатуры Qt 5 |
| Оболочка Qt 5 для Wayland |
| Библиотека Qt 5 для интеграции C++/QML с клиентами на HTML/js |
| Библиотека Qt 5 для отображения веб-содержимого |
| QtWebKit с более современной кодовой базой WebKit |
| Реализация протокола WebSocket на Qt |
| Реализация протокола WebSocket на Qt (привязки QML) |
| Компонент Qt для отображения веб-содержимого |
| Модуль виджетов Qt C++ |
| Платформо-специфичные возможности Qt для систем на основе X11 |
| Реализации SAX и DOM в Qt |
| Поддержка Qt для XPath, XQuery, XSLT и XML Schema |
Чтобы определить библиотеки, от которых зависит приложение, выполните ldd для основного исполняемого файла после успешной компиляции.
| Имя | Описание |
|---|---|
| инструменты сборки ( |
| инструменты локализации: |
| Генератор Makefile/утилита сборки |
| Имя | Описание |
|---|---|
| плагины для графических форматов TGA, TIFF и MNG |
В этом примере портированное приложение использует библиотеку графического интерфейса Qt 5, основную библиотеку Qt 5, все инструменты генерации кода Qt 5 и генератор Makefile Qt 5. Поскольку библиотека gui подразумевает зависимость от основной библиотеки, core не нужно указывать. Инструменты генерации кода Qt 5 moc, uic и rcc, а также генератор Makefile qmake требуются только во время сборки, поэтому они указаны с суффиксом _build:
USES= qt:5 USE_QT= gui buildtools_build qmake_build
6.13.3. Использование qmake
Если приложение предоставляет файл проекта qmake (*.pro), определите USES= qmake вместе с USE_QT. USES= qmake уже подразумевает зависимость сборки от qmake, поэтому компонент qmake может быть опущен в USE_QT. Подобно CMake, qmake поддерживает сборку вне исходного дерева, которую можно включить, указав аргумент outsource (см. пример USES= qmake). Также см. Возможные аргументы для USES qmake.
| Переменная | Описание |
|---|---|
| Не добавлять цель configure. Это подразумевается при |
| Подавить модификацию окружения configure и make. Это требуется только когда |
| Не передавать аргумент |
| Выполнить сборку вне исходного кода. |
| Переменная | Описание |
|---|---|
| Специфичные для порта флаги qmake, передаваемые в бинарный файл |
| Переменные окружения, которые должны быть установлены для бинарного файла |
| Путь к файлам проекта qmake (.pro). По умолчанию используется |
При использовании USES= qmake применяются следующие настройки:
CONFIGURE_ARGS+= --with-qt-includes=${QT_INCDIR} \
--with-qt-libraries=${QT_LIBDIR} \
--with-extra-libs=${LOCALBASE}/lib \
--with-extra-includes=${LOCALBASE}/include
CONFIGURE_ENV+= QTDIR="${QT_PREFIX}" QMAKE="${QMAKE}" \
MOC="${MOC}" RCC="${RCC}" UIC="${UIC}" \
QMAKESPEC="${QMAKESPEC}"
PLIST_SUB+= QT_INCDIR=${QT_INCDIR_REL} \
QT_LIBDIR=${QT_LIBDIR_REL} \
QT_PLUGINDIR=${QT_PLUGINDIR_REL}Некоторые скрипты configure не поддерживают указанные выше аргументы. Чтобы отключить изменение CONFIGURE_ENV и CONFIGURE_ARGS, установите USES= qmake:no_env.
USES= qmakeЭтот фрагмент демонстрирует использование qmake для порта Qt 5:
USES= qmake:outsource qt:5 USE_QT= buildtools_build
Приложения Qt часто разрабатываются как кроссплатформенные, и зачастую X11/Unix — не та платформа, на которой они создаются. Это, в свою очередь, приводит к определённым недоработкам, таким как:
Отсутствуют дополнительные пути для заголовочных файлов. Многие приложения поддерживают значки в системном трее, но не учитывают пути для заголовочных файлов и/или библиотек в каталогах X11. Чтобы добавить каталоги в пути поиска заголовочных файлов и библиотек для
qmakeчерез командную строку, используйте:QMAKE_ARGS+= INCLUDEPATH+=${LOCALBASE}/include \ LIBS+=-L${LOCALBASE}/libНекорректные пути установки. Иногда данные, такие как иконки или файлы .desktop, по умолчанию устанавливаются в каталоги, которые не сканируются приложениями, совместимыми с XDG. Например, editors/texmaker — посмотрите на файл patch-texmaker.pro в директории files этого порта, чтобы увидеть шаблон исправления этой проблемы напрямую в проектом файле
qmake.
6.14. Использование KDE
6.14.1. Определения переменных KDE
Если приложение зависит от KDE, установите USES+=kde:5 и USE_KDE в список необходимых компонентов. Суффиксы _build и _run можно использовать для принудительного указания типа зависимости компонентов (например, baseapps_run). Если суффикс не задан, будет использован тип зависимости по умолчанию. Чтобы принудительно задать оба типа, добавьте компонент дважды с обоими суффиксами (например, ecm_build ecm_run). Доступные компоненты перечислены ниже (актуальный список компонентов также приведён в /usr/ports/Mk/Uses/kde.mk):
| Имя | Описание |
|---|---|
| Среда выполнения и библиотека KF5 для организации работы в отдельных автивностях |
| KF5 статистика для активностей |
| Системный сервис для управления активностью пользователей, отслеживания шаблонов использования |
| Хранилище данных для KDE-Pim |
| Интеграция Akonadi с Календарем |
| Консоль управления и отладки Akonadi |
| Библиотеки и демоны для реализации управления контактами в Akonadi |
| Импорт данных из других почтовых клиентов в KMail |
| Библиотеки и демоны для реализации базовой обработки электронной почты |
| Библиотека KDE для доступа к хранилищам почты в формате MBox |
| Библиотеки и демоны для реализации поиска в Akonadi |
| Читатель лент от KDE |
| KDE API для будильников KAlarm |
| Документация API KF5 |
| Библиотека KF5, предоставляющая классы для работы с форматами архивов |
| Библиотека API Open Collaboration Services, версия для KDE5 |
| Библиотека API Open Collaboration Services, версия для KDE5 |
| Абстракция KF5 для системной политики и функций аутентификации |
| KF5 Фреймворк для поиска и управления пользовательскими метаданными |
| Библиотека BalooWidgets |
| KF5 Фреймворк для поиска и управления пользовательскими метаданными |
| KDE API для доступа к веб-логам |
| Библиотека KF5 для закладок и формата XBEL |
| Plasma5 artwork, стили и ресурсы для визуального стиля Breeze |
| Plasma5 Breeze визуальный стиль для Gtk |
| Тема значков Breeze для KDE |
| Библиотека доступа к календарю KDE |
| Библиотеки поддержки календарей для KDEPim |
| Утилита KDE и пользовательские функции интерфейса для доступа к календарю |
| Библиотека KF5 для работы со строками |
| KF5 вспомогательные средства и виджеты автодополнения текста |
| Виджеты KF5 для диалогов настройки |
| Виджеты KF5 для диалогов настройки |
| KDE API для управления контактной информацией |
| KF5 аддоны для QtCore |
| Библиотека KF5 для обработки анализа сбоев и отчётов об ошибках в приложениях |
| KF5 дополнения к QtDBus |
| Библиотека Plasma5 для создания оформления окон |
| Интеграция KF5 виджетов Frameworks в Qt Designer/Creator |
| Инструменты управления пакетами Plasma5 |
| Абстракция KF5 для системных функций DNSSD |
| Генерация документации KF5 из docbook |
| Обработчик сбоев Plasma5 |
| Дополнительные модули и скрипты для CMake |
| Библиотека KF5 для преобразования эмотиконов |
| Библиотеки просмотра событий для KDEPim |
| Библиотека KF5 для извлечения метаданных файлов |
| Плагины рабочего пространства KF5 и интеграции фреймворков |
| Библиотека на основе KDE для доступа к сервисам Google |
| Библиотека KF5 для добавления поддержки глобальных сочетаний клавиш рабочего пространства |
| Редактор тем Grantlee |
| KDE PIM grantleetheme |
| Библиотека для поддержки gravatar |
| KF5 аддоны для QtGui |
| Библиотека KDE для календарных праздников |
| Библиотека Plasma5 для горячих клавиш |
| KF5 — расширенная инфраструктура интернационализации |
| Библиотека KF5 для работы с иконками в приложениях |
| KDE pim идентификации |
| Библиотека KF5 для мониторинга активности пользователей |
| KDE API для поддержки IMAP |
| Инцидентные редакторские библиотеки для KDEPim |
| Утилита Plasma5, предоставляющая системную информацию |
| Запускатель процессов KF5 для ускорения запуска приложений KDE |
| Модели KF5 для системы Qt Model/View |
| KF5 виджеты-дополнения для Qt Model/View |
| Виджеты KF5 для отслеживания экземпляра KJob |
| Библиотека KF5, предоставляющая интерпретатор ECMAScript |
| Библиотека KF5 для привязки объектов JavaScript к QObjects |
| Менеджер контактов KDE |
| Планировщик персональных сигналов тревоги |
| Планировщик персональных сигналов тревоги |
| Базовая структура редактора для системы KDE |
| KF5 утилиты для работы с KCModules |
| Неинтерактивные системные инструменты Plasma5 |
| Plasma5 конфигуратор GTK2 и GTK3 |
| Библиотека KF5, обеспечивающая интеграцию QML и KDE Frameworks |
| KF5 расширяемый демон для предоставления системных сервисов |
| Помощник в портировании KF5 из KDELibs4 |
| Дополнения KDE PIM |
| Библиотеки KDE PIM, связанные с почтой |
| Инструменты и службы KDE PIM |
| Дополнения Plasma5 для улучшения работы с Plasma |
| Интеграция KF5 с su для повышенных привилегий |
| Библиотека KF5, обеспечивающая интеграцию QtWebKit |
| Настройки гаммы монитора Plasma5 |
| Механизм рендеринга KF5 KTHML |
| Библиотека KF5, обеспечивающая поддержку дополнительных форматов изображений |
| Абстракция ресурсов и сетевого доступа KF5 |
| Набор компонентов на основе QtQuick |
| Модель данных и система извлечения информации о бронировании путешествий |
| Клиент электронной почты KDE |
| Клиент электронной почты KDE |
| Мастер настройки почтового аккаунта KDE |
| Редактор меню Plasma5 |
| Всплывающие примечания |
| KDE Персональный Органайзер |
| KDE Персональный Органайзер |
| KDE glue для встраивания KParts в Kontact |
| Программа для календаря и планирования |
| Реализация протокола DAV с KJobs |
| Библиотека для работы с файлами паролей Apple Wallet |
| KF5 мультиязыковые прикладные скрипты |
| Библиотека управления экраном Plasma5 |
| Архитектура безопасной блокировки экрана Plasma5 |
| Библиотека на основе задач для отправки электронной почты через SMTP-сервер |
| Plasma5 интерфейс для ssh-add |
| Утилита Plasma5 для отслеживания и управления запущенными процессами |
| Интеграция Plasma5 KWallet с PAM |
| Интеграционные плагины для рабочего стола на основе Wayland |
| Менеджер окон Plasma5 |
| Демон Plasma5, ожидающий сообщения wall и write |
| API доступа к LDAP для KDE |
| Библиотека KDE CDDB |
| Библиотека KDE для взаимодействия с аудио-CD |
| Интерфейс LibRaw для KDE |
| Библиотеки, используемые играми KDE |
| Библиотеки KDE PIM |
| Библиотека для чтения и записи файлов словарей |
| Интерфейс библиотеки Exiv2 для KDE |
| Интерфейс плагинов изображений KDE |
| Менеджер сертификатов для KDE |
| Интерфейс библиотеки SANE для KDE |
| Библиотека управления экраном Plasma5 |
| Библиотеки Sieve для KDEPim |
| Библиотека Plasma5 для отслеживания и управления запущенными процессами |
| Общие библиотеки для KDEPim |
| Импорт файлов mbox в KMail |
| Библиотека KDE для управления транспортом почты |
| Виртуальный глобус и мировой атлас для KDE |
| Библиотека KDE для доступа к хранилищам почты в формате MBox |
| Импорт файлов mbox в KMail |
| Интерфейс плагина KF5 для функций медиаплеера |
| Библиотека для обработки сообщений |
| Plasma5 Plasmoid для поиска |
| Библиотека для обработки данных MIME |
| Библиотека KF5 для загрузки ресурсов приложений из сети |
| Абстракция KF5 для системных уведомлений |
| Система конфигурации KF5 для KNotify |
| Универсальная программа для просмотра документов KDE |
| Стиль Plasma5 Oxygen |
| Тема иконок Oxygen для KDE |
| Библиотека KF5 для загрузки и установки пакетов |
| KF5 система плагинов для работы с документами |
| Библиотека KF5, предоставляющая доступ к контактам |
| Импорт и экспорт настроек KDE PIM |
| Общие библиотеки для KDEPim |
| Библиотека KDE для утилит редактирования текста, специфичных для PIM |
| Компоненты Plasma5 для интеграции браузеров в рабочий стол |
| Plasma5 рабочий стол Plasma |
| KF5 - среда выполнения пользовательского интерфейса на основе плагинов, используемая для создания пользовательских интерфейсов |
| Плагины интеграции Qt Platform Theme для рабочего окружения Plasma |
| Plasma5 Микшер звука Plasma Pulse |
| Приложения Plasma5, полезные для разработки Plasma |
| Plasma5 Рабочее пространство Plasma |
| Обои Plasma5 |
| KF5 облегченный фреймворк для построения графиков |
| Демон Plasma5, предоставляющий интерфейс аутентификации polkit |
| Инструмент Plasma5 для управления настройками энергопотребления |
| Интерфейс API для создания штрихкодов |
| Абстракция pty KF5 |
| Предлагает доступные действия для конкретной цели |
| Стиль Qt QuickControl2 для KDE |
| KF5 параллелизованная система запросов |
| KF5 расширенные плагины и интроспекция сервисов |
| Интеграция и обнаружение оборудования KF5 |
| KF5 библиотека проверки орфографии на основе плагинов |
| Библиотека KDE для обработки RSS-лент |
| Движок подсветки синтаксиса KF5 для структурированного текста и кода |
| Настройки системы Plasma5 |
| KF5 продвинутый встраиваемый текстовый редактор |
| KF5 расширенные виджеты для редактирования текста |
| KF5 дополнения к QtDBus |
| KDE API для обработки данных TNEF |
| Библиотека KF5 для преобразования единиц измерения |
| Пользовательский менеджер Plasma5 |
| KF5 безопасный и унифицированный контейнер для паролей пользователей |
| Обёртка клиентской и серверной библиотек KF5 для библиотек Wayland |
| KF5 аддоны для QtWidgets |
| Библиотека KF5 для доступа к оконной системе |
| KF5 настраиваемые пользователем главные окна |
| Взаимодействие KF5 с XMLRPC-сервисами |
USE_KDEЭто простой пример порта для KDE. USES= cmake указывает порту использовать CMake, инструмент конфигурации, широко применяемый в проектах KDE (см. Использование cmake для подробного описания). USE_KDE добавляет зависимость от библиотек KDE. Необходимые компоненты KDE и другие зависимости можно определить через лог конфигурации. USE_KDE не подразумевает USE_QT. Если порту требуются некоторые компоненты Qt, укажите их в USE_QT.
USES= cmake kde:5 qt:5 USE_KDE= ecm USE_QT= core buildtools_build qmake_build
6.15. Использование LXQt
Приложения, зависящие от LXQt, должны устанавливать USES+= lxqt и задавать USE_LXQT списком необходимых компонентов из таблицы ниже
| Имя | Описание |
|---|---|
| Помощники для дополнительных модулей CMake |
| Привязки Libfm к Qt |
| Ядро библиотеки LXQt |
| Реализация Qt спецификаций freedesktop.org XDG |
USE_LXQTЭто простой пример, USE_LXQT добавляет зависимость от библиотек LXQt. Необходимые компоненты LXQt и другие зависимости можно определить из лога конфигурации.
USES= cmake lxqt qt:5 tar:xz USE_QT= core dbus widgets buildtools_build qmake_build USE_LXQT= buildtools libfmqt
6.16. Использование Java
6.16.1. Определения переменных
Если порту требуется Java™ Development Kit (JDK™) для сборки, запуска или даже извлечения distfile, определите USE_JAVA.
В коллекции портов доступно несколько JDK от различных поставщиков и в нескольких версиях. Если порт должен использовать определённую версию, укажите её с помощью переменной JAVA_VERSION. Самая актуальная версия — java/openjdk18, также доступны java/openjdk17, java/openjdk16, java/openjdk15, java/openjdk14, java/openjdk13, java/openjdk12, java/openjdk11, java/openjdk8 и java/openjdk7.
| Переменная | Значение |
|---|---|
| Определите для остальных переменных, чтобы они имели какой-либо эффект. |
| Список подходящих версий Java для порта, разделённых пробелами.
Необязательный символ |
| Список разделенных пробелами подходящих операционных систем портов JDK для порта (допустимые значения: |
| Список подходящих поставщиков портов JDK для порта через пробел (допустимые значения: |
| Когда установлено, добавляет выбранный порт JDK в зависимости сборки. |
| Когда установлено, добавляет выбранный порт JDK в зависимости времени выполнения. |
| Когда установлено, добавляет выбранный порт JDK в зависимости для извлечения. |
Ниже приведен список всех настроек, которые порт получит после установки USE_JAVA:
| Переменная | Значение |
|---|---|
| Имя порта JDK (например, |
| Полная версия порта JDK (например, |
| Операционная система, используемая портом JDK (например, |
| Поставщик порта JDK (например, |
| Описание операционной системы, используемой портом JDK (например, |
| Описание поставщика порта JDK (например, |
| Путь к каталогу установки JDK (например, '/usr/local/openjdk6'). |
| Путь к используемому компилятору Java (например, '/usr/local/openjdk6/bin/javac'). |
| Путь к инструменту |
| Путь к утилите |
| Путь к исполняемому файлу |
| Путь к программе |
| Путь к программе |
| Путь к программе |
| Путь к утилите |
| Путь к инструменту |
| Путь к программе |
| Путь к утилите |
| Путь к генератору RMI-заглушек/скелетов, |
| Путь к программе реестра RMI, |
| Путь к программе демона RMI |
| Путь к архиву, содержащему файлы классов JDK, ${JAVA_HOME}/jre/lib/rt.jar. |
Используйте цель java-debug в make для получения информации для отладки порта. Она отобразит значения многих из перечисленных ранее переменных.
Кроме того, определены следующие константы, чтобы все порты Java могли быть установлены единообразно:
| Константа | Значение |
|---|---|
| Базовый каталог для всего, связанного с Java. По умолчанию: ${PREFIX}/share/java. |
| Каталог, в котором установлены JAR-файлы. По умолчанию: ${JAVASHAREDIR}/classes. |
| Каталог, в котором расположены JAR-файлы, установленные другими портами. По умолчанию: ${LOCALBASE}/share/java/classes. |
Связанные записи определены как в PLIST_SUB (документировано в Изменение pkg-plist на основе переменных Make), так и в SUB_LIST.
6.16.2. Сборка с Ant
Когда порт должен собираться с использованием Apache Ant, он должен определять USE_ANT. Таким образом, Ant считается командой sub-make. Если цель do-build не определена в порте, будет установлена цель по умолчанию, которая запускает Ant в соответствии с MAKE_ENV, MAKE_ARGS и ALL_TARGET. Это аналогично механизму USES= gmake, который документирован в Building Mechanisms.
6.16.3. Лучшие практики
При переносе библиотеки Java порт должен устанавливать JAR-файл(ы) в ${JAVAJARDIR}, а все остальное — в ${JAVASHAREDIR}/${PORTNAME} (за исключением документации, см. ниже). Чтобы уменьшить размер упаковочного файла, ссылайтесь на JAR-файл(ы) напрямую в Makefile. Используйте следующую инструкцию (где myport.jar — имя JAR-файла, устанавливаемого как часть порта):
PLIST_FILES+= ${JAVAJARDIR}/myport.jarПри переносе Java-приложения порт обычно устанавливает все компоненты в единый каталог (включая зависимости в виде JAR-файлов). В этом отношении настоятельно рекомендуется использовать ${JAVASHAREDIR}/${PORTNAME}. Портеру предстоит решить, устанавливать ли дополнительные JAR-зависимости в этот каталог или использовать уже установленные (из ${JAVAJARDIR}).
При переносе Java™-приложения, которое требует сервера приложений, такого как www/tomcat7, для запуска службы, вендор часто распространяет файл .war. .war — это веб-архив приложения (Web application ARchive), который извлекается при вызове приложением. Избегайте добавления .war в pkg-plist. Это не считается лучшей практикой. Сервер приложений развернет архив war, но не очистит его должным образом при удалении порта. Более предпочтительный способ работы с этим файлом — извлечь архив, затем установить файлы и, наконец, добавить эти файлы в pkg-plist.
TOMCATDIR= ${LOCALBASE}/apache-tomcat-7.0
WEBAPPDIR= myapplication
post-extract:
@${MKDIR} ${WRKDIR}/${PORTDIRNAME}
@${TAR} xf ${WRKDIR}/myapplication.war -C ${WRKDIR}/${PORTDIRNAME}
do-install:
cd ${WRKDIR} && \
${INSTALL} -d -o ${WWWOWN} -g ${WWWGRP} ${TOMCATDIR}/webapps/${PORTDIRNAME}
cd ${WRKDIR}/${PORTDIRNAME} && ${COPYTREE_SHARE} \* ${WEBAPPDIR}/${PORTDIRNAME}Независимо от типа порта (библиотека или приложение), дополнительная документация устанавливается в том же месте, что и для любого другого порта. Известно, что инструмент Javadoc создает разный набор файлов в зависимости от версии используемого JDK. Для портов, которые не требуют использования конкретной версии JDK, указание списка упаковки (pkg-plist) становится сложной задачей. Это одна из причин, по которой разработчикам портов настоятельно рекомендуется использовать PORTDOCS. Более того, даже если набор файлов, генерируемых javadoc, можно предсказать, размер результирующего pkg-plist говорит в пользу использования PORTDOCS.
Значение по умолчанию для DATADIR — ${PREFIX}/share/${PORTNAME}. Рекомендуется переопределить DATADIR на ${JAVASHAREDIR}/${PORTNAME} для портов Java. Действительно, DATADIR автоматически добавляется в PLIST_SUB (документировано в Изменение pkg-plist на основе переменных Make), поэтому используйте %%DATADIR%% напрямую в pkg-plist.
Что касается выбора между сборкой портов Java из исходного кода или их непосредственной установкой из бинарного дистрибутива, на момент написания документации определённой политики не существует. Однако участники FreeBSD Java Project рекомендуют сопровождающим портов по возможности собирать их из исходного кода, если это не представляет сложностей.
Все функции, представленные в этом разделе, реализованы в bsd.java.mk. Если порту требуется более сложная поддержка Java, сначала ознакомьтесь с историей изменений bsd.java.mk, так как документирование новых функций обычно занимает некоторое время. Затем, если отсутствующая поддержка будет полезна для многих других Java-портов, не стесняйтесь обсудить это на списке рассылки freebsd-java.
Хотя существует категория java для PR, она относится к усилиям по портированию JDK в рамках проекта FreeBSD Java. Поэтому отправляйте порт Java в категорию ports, как и любой другой порт, если только проблема не связана либо с реализацией JDK, либо с bsd.java.mk.
Аналогично существует определённая политика в отношении CATEGORIES для портов Java, которая подробно описана в Категоризация.
6.17. Веб-приложения, Apache и PHP
6.17.1. Apache
| Порт требует Apache. Возможные значения: |
| Полный путь к бинарному файлу |
| Полный путь к бинарному файлу |
| Версия установленной Apache (переменная только для чтения). Эта переменная доступна только после включения bsd.port.pre.mk. Возможные значения: |
| Каталог для модулей Apache. Эта переменная автоматически раскрывается в pkg-plist. |
| Каталог для заголовков Apache. Эта переменная автоматически раскрывается в pkg-plist. |
| Каталог для файлов конфигурации Apache. Эта переменная автоматически раскрывается в pkg-plist. |
| Имя модуля. Значение по умолчанию — |
| Короткое имя модуля. Автоматически определяется из |
| Используйте |
| Также автоматически создаёт файл pkg-plist. |
| Добавляет каталог в путь поиска заголовков во время компиляции. |
| Добавляет каталог в путь поиска библиотек во время компиляции. |
| Дополнительные флаги для передачи в |
6.17.2. Веб-приложения
Веб-приложения должны быть установлены в PREFIX/www/appname. Этот путь доступен как в Makefile, так и в pkg-plist как WWWDIR, а путь относительно PREFIX доступен в Makefile как WWWDIR_REL.
Пользователь и группа процесса веб-сервера доступны как WWWOWN и WWWGRP, если необходимо изменить владельца некоторых файлов. Значения по умолчанию для обоих — www. Используйте WWWOWN?= myuser и WWWGRP?= mygroup, если порту требуются другие значения. Это позволяет пользователю легко их переопределить.
Используйте |
Не зависьте от Apache, если веб-приложение явно не требует Apache. Учитывайте, что пользователи могут захотеть запускать веб-приложение на другом веб-сервере, кроме Apache.
6.17.3. PHP
Веб-приложения PHP объявляют свою зависимость от него с помощью USES=php. Подробнее см. в php.
6.17.4. Модули PEAR
Портирование модулей PEAR — это очень простой процесс.
Добавьте USES=pear в Makefile порта. Фреймворк установит соответствующие файлы в нужные места и автоматически сгенерирует plist во время установки.
PORTNAME= Date DISTVERSION= 1.4.3 CATEGORIES= devel www pear MAINTAINER= someone@example.org COMMENT= PEAR Date and Time Zone Classes WWW= https://pear.php.net/package/Date/ USES= pear .include <bsd.port.mk>
Модули PEAR будут автоматически преобразованы в порт с флейвором с использованием флейворов PHP. |
Если используется нестандартный |
Модули PEAR не требуют определения |
6.17.4.1. Модули Horde
Также и перенос модулей Horde является простым процессом.
Добавьте USES=horde в Makefile порта. Фреймворк установит соответствующие файлы в нужные места и автоматически сгенерирует plist во время установки.
Переменные USE_HORDE_BUILD и USE_HORDE_RUN могут использоваться для добавления зависимостей времени сборки и выполнения от других модулей Horde. Полный список доступных модулей можно найти в Mk/Uses/horde.mk.
PORTNAME= Horde_Core DISTVERSION= 2.14.0 CATEGORIES= devel www pear MAINTAINER= horde@FreeBSD.org COMMENT= Horde Core Framework libraries WWW= https://pear.horde.org/ OPTIONS_DEFINE= KOLAB SOCKETS KOLAB_DESC= Enable Kolab server support SOCKETS_DESC= Depend on sockets PHP extension USES= horde USE_PHP= session USE_HORDE_BUILD= Horde_Role USE_HORDE_RUN= Horde_Role Horde_History Horde_Pack \ Horde_Text_Filter Horde_View KOLAB_USE= HORDE_RUN=Horde_Kolab_Server,Horde_Kolab_Session SOCKETS_USE= PHP=sockets .include <bsd.port.mk>
Поскольку модули Horde также являются модулями PEAR, они будут автоматически преобразованы с использованием флейворов PHP. |
6.18. Использование Python
Коллекция портов поддерживает параллельную установку нескольких версий Python. Порты должны использовать правильный интерпретатор python в соответствии с настраиваемым пользователем параметром PYTHON_VERSION. Важнее всего заменить путь к исполняемому файлу python в скриптах на значение PYTHON_CMD.
Порты, которые устанавливают файлы в PYTHON_SITELIBDIR, должны использовать префикс имени пакета pyXY-, чтобы их имя пакета включало версию Python, для которой они предназначены.
PKGNAMEPREFIX= ${PYTHON_PKGNAMEPREFIX}
| Порту требуется Python. Минимально необходимая версия может быть указана с такими значениями, как |
| Используйте Python distutils для настройки, компиляции и установки. Это требуется, когда порт поставляется с setup.py. Это переопределяет цели |
| Создать список пакетов автоматически. Это также требует установки |
| Порт будет использовать уникальный префикс, обычно |
| Порт не использует distutils, но по-прежнему поддерживает несколько версий Python. |
| Если текущая версия Python не является версией по умолчанию, порт получит |
| Используется как |
| Расположение дерева site-packages, которое содержит путь установки Python (обычно |
| Вариант PREFIX-clean для PYTHON_SITELIBDIR. Всегда используйте |
| Интерпретатор командной строки Python, включая номер версии. |
| Строка зависимости для числового расширения. |
| Строка зависимости для нового числового расширения, numpy. (PYNUMERIC устарел у вендора). |
| Строка зависимости для расширения XML (не требуется для Python 2.0 и выше, так как оно также входит в базовую поставку). |
| Условная зависимость от пакета devel/py-enum34 в зависимости от версии Python. |
| Условная зависимость от пакета devel/py-enum-compat в зависимости от версии Python. |
| Условная зависимость от пакета devel/py-pathlib в зависимости от версии Python. |
| Условная зависимость от пакета net/py-ipaddress в зависимости от версии Python. |
| Условная зависимость от пакета devel/py-futures в зависимости от версии Python. |
Полный список доступных переменных можно найти в /usr/ports/Mk/Uses/python.mk.
Все зависимости для портов Python, использующих флейворы Python (с |
PORTNAME= sample
DISTVERSION= 1.2.3
CATEGORIES= devel
MAINTAINER= fred.bloggs@example.com
COMMENT= Python sample module
WWW= https://example.com/project/sample/
RUN_DEPENDS= ${PYTHON_PKGNAMEPREFIX}six>0:devel/py-six@${PY_FLAVOR}
USES= python
USE_PYTHON= autoplist distutils
.include <bsd.port.mk>Некоторые приложения на Python заявляют о поддержке DESTDIR (что необходимо для промежуточной сборки), но она не работает (например, Mailman до версии 2.1.16). Это можно обойти, перекомпилировав скрипты. Это можно сделать, например, в цели post-build. Предполагая, что Python-скрипты должны находиться в PYTHONPREFIX_SITELIBDIR после установки, можно применить следующее решение:
(cd ${STAGEDIR}${PREFIX} \
&& ${PYTHON_CMD} ${PYTHON_LIBDIR}/compileall.py \
-d ${PREFIX} -f ${PYTHONPREFIX_SITELIBDIR:S;${PREFIX}/;;})Это перекомпилирует исходники с путём, относительным к stage-директории, и добавляет значение PREFIX к имени файла, записанному в байт-компилированном выходном файле с помощью -d. -f требуется для принудительной перекомпиляции, а :S;${PREFIX}/;; удаляет префиксы из значения PYTHONPREFIX_SITELIBDIR, чтобы сделать его относительным к PREFIX.
6.19. Использование Tcl/Tk
Коллекция Ports поддерживает параллельную установку нескольких версий Tcl/Tk. Порты должны стараться поддерживать как минимум версию Tcl/Tk по умолчанию и выше с помощью USES=tcl. Можно указать желаемую версию tcl, добавив :_xx_, например, USES=tcl:85.
| выбранная версия Tcl major.minor |
| полный путь к интерпретатору Tcl |
| путь к библиотекам Tcl |
| путь к заголовочным файлам Tcl C |
| Префикс библиотеки, согласно TIP595 |
| Заглушка библиотеки postfix |
| выбранная версия Tk major.minor |
| полный путь к интерпретатору Tk |
| путь к библиотекам Tk |
| путь к заголовочным файлам Tk C |
См. USES=tcl и USES=tk в Использование макросов USES для полного описания этих переменных. Полный список этих переменных доступен в /usr/ports/Mk/Uses/tcl.mk.
6.20. Использование SDL
USE_SDL используется для автоматической настройки зависимостей для портов, которые используют библиотеку на основе SDL, такие как devel/sdl12 и graphics/sdl_image.
Эти библиотеки SDL для версии 1.2 распознаются:
sdl: devel/sdl12
console: devel/sdl_console
gfx: graphics/sdl_gfx
image: graphics/sdl_image
mixer: audio/sdl_mixer
mm: devel/sdlmm
net: net/sdl_net
pango: x11-toolkits/sdl_pango
sound: audio/sdl_sound
ttf: graphics/sdl_ttf
Эти библиотеки SDL для версии 2.0 распознаются:
sdl: devel/sdl20
gfx: graphics/sdl2_gfx
image: graphics/sdl2_image
mixer: audio/sdl2_mixer
net: net/sdl2_net
ttf: graphics/sdl2_ttf
Следовательно, если порт зависит от net/sdl_net и audio/sdl_mixer, синтаксис будет следующим:
USE_SDL= net mixer
Пакет зависимости devel/sdl12, который требуется для net/sdl_net и audio/sdl_mixer, также автоматически добавляется.
Использование USE_SDL с указанием SDL 1.2 автоматически:
Добавить зависимость от sdl12-config в
BUILD_DEPENDSДобавьте переменную
SDL_CONFIGвCONFIGURE_ENVДобавьте зависимости выбранных библиотек в
LIB_DEPENDS
Используя USE_SDL с записями для SDL 2.0, это автоматически:
Добавить зависимость от sdl2-config в
BUILD_DEPENDSДобавьте переменную
SDL2_CONFIGвCONFIGURE_ENVДобавьте зависимости выбранных библиотек в
LIB_DEPENDS
6.21. Использование wxWidgets
Этот раздел описывает состояние библиотек wxWidgets в дереве портов и их интеграцию с системой портов.
6.21.1. Введение
Существует множество версий библиотек wxWidgets, которые конфликтуют между собой (устанавливают файлы с одинаковыми именами). В дереве портов эта проблема решена путем установки каждой версии под разными именами с использованием суффиксов номеров версий.
Очевидный недостаток этого подхода заключается в том, что каждое приложение необходимо модифицировать для поиска нужной версии. К счастью, большинство приложений вызывают скрипт wx-config для определения необходимых флагов компилятора и компоновщика. Имя этого скрипта отличается для каждой доступной версии. Большинство приложений учитывают переменную окружения или принимают аргумент configure, чтобы указать, какой скрипт wx-config вызывать. В противном случае их необходимо патчить.
6.21.2. Выбор версии
Чтобы порт использовал определённую версию wxWidgets, доступны две переменные для определения (если задана только одна, другая будет установлена в значение по умолчанию):
| Переменная | Описание | Значение по умолчанию |
|---|---|---|
| Список версий, которые порт может использовать | Все доступные версии |
| Список версий, которые порт не может использовать | Ничего |
Доступные версии wxWidgets и соответствующие порты в дереве:
| Версия | Порт |
|---|---|
| |
|
Переменные в Переменные для выбора версий wxWidgets могут быть установлены в одну или несколько комбинаций, разделенных пробелами:
| Описание | Пример |
|---|---|
Единственная версия |
|
Возрастающий диапазон |
|
Нисходящий диапазон |
|
Полный диапазон (должен быть возрастающим) |
|
Существуют также переменные для выбора предпочтительных версий из доступных. Их можно установить в виде списка версий, где первые будут иметь более высокий приоритет.
| Имя | Предназначен для |
|---|---|
| порт |
| пользователь |
6.21.3. Выбор компонентов
Существуют другие приложения, которые, не являясь библиотеками wxWidgets, связаны с ними. Эти приложения можно указать в WX_COMPS. Доступны следующие компоненты:
| Имя | Описание | Ограничение версии |
|---|---|---|
| основная библиотека | none |
| сторонние библиотеки |
|
| wxPython (интерфейс Python) |
|
Тип зависимости может быть выбран для каждого компонента путем добавления суффикса, разделенного точкой с запятой. Если он отсутствует, будет использоваться тип по умолчанию (см. Типы зависимостей wxWidgets по умолчанию). Доступны следующие типы:
| Имя | Описание |
|---|---|
| Компонент необходим для сборки, эквивалентен |
| Компонент необходим для запуска, эквивалентно |
| Компонент необходим для сборки и запуска, эквивалентен |
Значения по умолчанию для компонентов подробно описаны в этой таблице:
| Компонент | Тип зависимости |
|---|---|
|
|
|
|
|
|
|
|
|
|
Этот фрагмент соответствует порту, который использует wxWidgets версии 2.4 и дополнительные библиотеки.
USE_WX= 2.8 WX_COMPS= wx contrib
6.21.4. Обнаружение установленных версий
Для определения установленной версии определите WANT_WX. Если значение не задано для конкретной версии, компоненты будут иметь суффикс версии. HAVE_WX будет заполнен после обнаружения.
Этот фрагмент может использоваться в порте, который использует wxWidgets, если они установлены или выбран соответствующий параметр.
WANT_WX= yes .include <bsd.port.pre.mk> .if defined(WITH_WX) || !empty(PORT_OPTIONS:MWX) || !empty(HAVE_WX:Mwx-2.8) USE_WX= 2.8 CONFIGURE_ARGS+= --enable-wx .endif
Этот фрагмент может использоваться в порте, который включает поддержку wxPython, если она установлена или выбрана соответствующая опция, в дополнение к wxWidgets, обе версии 2.8.
USE_WX= 2.8 WX_COMPS= wx WANT_WX= 2.8 .include <bsd.port.pre.mk> .if defined(WITH_WXPYTHON) || !empty(PORT_OPTIONS:MWXPYTHON) || !empty(HAVE_WX:Mpython) WX_COMPS+= python CONFIGURE_ARGS+= --enable-wxpython .endif
6.21.5. Переменные, определенные в фреймворке
Эти переменные доступны в порте (после определения одной из переменных для выбора версий wxWidgets).
| Имя | Описание |
|---|---|
| Путь к скрипту |
| Путь к программе |
| Версия wxWidgets, которая будет использоваться (например, |
6.21.6. Обработка в bsd.port.pre.mk
Определите WX_PREMK, чтобы иметь возможность использовать переменные сразу после включения bsd.port.pre.mk.
При определении |
Этот фрагмент иллюстрирует использование WX_PREMK путем запуска скрипта wx-config для получения полной строки версии, присвоения её переменной и передачи в программу.
USE_WX= 2.8
WX_PREMK= yes
.include <bsd.port.pre.mk>
.if exists(${WX_CONFIG})
VER_STR!= ${WX_CONFIG} --release
PLIST_SUB+= VERSION="${VER_STR}"
.endifПеременные wxWidgets можно безопасно использовать в командах внутри целей без необходимости в |
6.21.7. Дополнительные параметры configure
Некоторые скрипты GNU configure не могут найти wxWidgets, если задана только переменная окружения WX_CONFIG, и требуют дополнительные параметры. WX_CONF_ARGS можно использовать для их указания.
| Возможное значение | Получаемый параметр |
|---|---|
|
|
|
|
6.22. Использование Lua
Этот раздел описывает состояние библиотек Lua в дереве портов и их интеграцию с системой портов.
6.22.1. Введение
Существует множество версий библиотек Lua и соответствующих интерпретаторов, которые конфликтуют между собой (устанавливают файлы с одинаковыми именами). В дереве портов эта проблема решена установкой каждой версии под разными именами с использованием суффиксов номеров версий.
Очевидный недостаток этого заключается в том, что каждое приложение необходимо модифицировать для поиска ожидаемой версии. Однако это можно решить, добавив дополнительные флаги компилятору и компоновщику.
Приложения, использующие Lua, обычно должны собираться только для одной версии. Однако загружаемые модули для Lua собираются в отдельных флейворах для каждой поддерживаемой версии Lua, и зависимости от таких модулей должны указывать флейвор с использованием суффикса @${LUA_FLAVOR} в расположении (origin) порта.
6.22.2. Выбор версии
Порт, использующий Lua, должен содержать строку следующего вида:
USES= lua
Если требуется определённая версия Lua или диапазон версий, его можно указать в виде параметра XY (который можно использовать несколько раз), XY+, -XY или XY-ZA. Версия Lua, установленная через DEFAULT_VERSIONS, будет использована, если она попадает в запрошенный диапазон, в противном случае будет использована ближайшая к умолчанию запрошенная версия. Например:
USES= lua:52-53
Обратите внимание, что не предпринимается попытка изменить выбор версии на основе наличия любой уже установленной версии Lua.
Форма указания версии |
6.22.3. Конфигурация и флаги компилятора
Программное обеспечение, использующее Lua, может быть написано с автоматическим определением версии Lua в использовании. В общем случае порты должны переопределять это предположение и принудительно использовать конкретную выбранную версию Lua, как описано выше. В зависимости от портируемого программного обеспечения, это может потребовать любого или всех из следующих действий:
Использование
LUA_VERв качестве части параметра для скрипта конфигурации программного обеспечения черезCONFIGURE_ARGSилиCONFIGURE_ENV(или эквивалентные для других систем сборки);Добавление
-I${LUA_INCDIR},-L${LUA_LIBDIR}и-llua-${LUA_VER}вCFLAGS,LDFLAGSиLIBSсоответственно, где это необходимо;Исправьте конфигурационные или файлы сборки программного обеспечения, чтобы выбрать правильную версию.
6.22.4. Флейворы версии
Порт, который устанавливает модуль Lua (а не приложение, просто использующее Lua), должен собирать отдельный флейвор для каждой поддерживаемой версии Lua. Это делается путем добавления параметра module:
USES= lua:module
Так же может быть указае номер версии или диапазон версий. Используйте запятую для разделения параметров.
Поскольку каждый флейвор должен иметь уникальное имя пакета, предоставляется переменная LUA_PKGNAMEPREFIX, которая будет установлена в соответствующее значение; предполагаемое использование:
PKGNAMEPREFIX= ${LUA_PKGNAMEPREFIX}Модульные порты обычно должны устанавливать файлы только в LUA_MODLIBDIR, LUA_MODSHAREDIR, LUA_DOCSDIR и LUA_EXAMPLESDIR, все из которых настроены на ссылки в версионно-зависимые подкаталоги. Установка любых других файлов должна выполняться с осторожностью, чтобы избежать конфликтов между версиями.
Порт (кроме модуля Lua), который хочет собрать отдельный пакет для каждой версии Lua, должен использовать параметр flavors:
USES= lua:flavors
Это работает так же, как параметр module, описанный выше, но без предположения, что пакет должен быть задокументирован как модуль Lua (поэтому LUA_DOCSDIR и LUA_EXAMPLESDIR по умолчанию не определены). Однако порт может определить LUA_DOCSUBDIR как подходящее имя подкаталога (обычно PORTNAME порта, если это не конфликтует с PORTNAME любого модуля), и в этом случае фреймворк определит как LUA_DOCSDIR, так и LUA_EXAMPLESDIR.
Как и в случае с модульными портами, порт с флейворами должен избегать установки файлов, которые могут конфликтовать между версиями. Обычно это достигается добавлением LUA_VER_STR в качестве суффикса к именам программ (например, с использованием uniquefiles), а также использованием LUA_VER или LUA_VER_STR в составе других файлов или поддиректорий, используемых вне LUA_MODLIBDIR и LUA_MODSHAREDIR.
6.22.5. Переменные, определенные в фреймворке
В порте доступны эти переменные.
| Имя | Описание |
|---|---|
| Версия Lua, которая будет использоваться (например, |
| Версия Lua без точек (например, |
| Имя флейвора, соответствующее выбранной версии Lua, используемое для указания зависимостей |
| Префикс, который должен использоваться для поиска Lua (и компонентов), уже установленных |
| Префикс, куда этим портом будут установлены Lua (и компоненты) |
| Каталог, в котором установлены заголовочные файлы Lua |
| Каталог, в котором установлены библиотеки Lua |
| Каталог, в котором находятся уже установленные библиотеки модулей Lua (.so) |
| Каталог, в котором находятся установленные модули Lua (.lua) |
| Каталог, в котором библиотеки модулей Lua (.so) должны быть установлены данным портом |
| Каталог, в котором должны быть установлены модули Lua (.lua) данным портом |
| Префикс имени пакета, используемый модулями Lua |
| Название интерпретатора Lua (например, |
| Название компилятора Lua (например, |
Эти дополнительные переменные доступны для портов, которые указали параметр module:
| Имя | Описание |
|---|---|
| каталог, в который должна быть установлена документация модуля. |
| каталог, в который должны быть установлены примеры файлов модуля. |
6.22.6. Примеры
Makefile для приложения, использующего LuaЭтот пример показывает, как сослаться на модуль Lua, требуемый во время выполнения. Обратите внимание, что ссылка должна указывать флейвор.
PORTNAME= sample
DISTVERSION= 1.2.3
CATEGORIES= whatever
MAINTAINER= fred.bloggs@example.com
COMMENT= Sample
WWW= https://example.com/lua_sample/sample/
RUN_DEPENDS= ${LUA_REFMODLIBDIR}/lpeg.so:devel/lua-lpeg@${LUA_FLAVOR}
USES= lua
.include <bsd.port.mk>Makefile для простого модуля LuaPORTNAME= sample
DISTVERSION= 1.2.3
CATEGORIES= whatever
PKGNAMEPREFIX= ${LUA_PKGNAMEPREFIX}
MAINTAINER= fred.bloggs@example.com
COMMENT= Sample
WWW= https://example.com/lua_sample/sample/
USES= lua:module
DOCSDIR= ${LUA_DOCSDIR}
.include <bsd.port.mk>6.23. Использование Guile
Этот раздел описывает состояние Guile в дереве портов и его интеграцию с системой портов.
6.23.1. Введение
Существует несколько версий библиотек Guile и соответствующих интерпретаторов, которые конфликтуют между собой (устанавливают файлы с одинаковыми именами). В дереве портов эта проблема решена путем установки каждой версии под разными именами с использованием суффиксов номеров версий. В большинстве случаев приложения должны определять правильную версию из предоставленных конфигурационных переменных и использовать pkg-config для определения имени и связанных путей. Однако некоторые приложения (особенно те, которые используют собственные правила конфигурации для cmake или meson) всегда будут пытаться использовать последнюю доступную версию. В этом случае либо исправьте порт, либо объявите конфликт сборки (см. опцию conflicts ниже), чтобы гарантировать создание правильной зависимости при сборке вне poudriere.
Приложения, использующие Guile, обычно должны собираться только для одной версии, предпочтительно указанной в DEFAULT_VERSIONS, или, если это невозможно, для последней поддерживаемой версии. Однако библиотеки Guile или Scheme, а также модули расширения для Guile собираются в отдельных флейворах для каждой поддерживаемой версии Guile. Зависимости от таких портов должны указывать флейвор с использованием суффикса @${GUILE_FLAVOR} в расположении (origin) порта.
6.23.2. Выбор версии
Порт, использующий Guile, должен определять USES=guile:arg,arg… с соответствующими параметрами следующим образом:
| Имя | Описание |
|---|---|
| Объявить совместимость с версией Guile |
| Создать флейвор для каждой указанной версии Guile.
Версия, указанная в |
| Добавить интерпретатор Guile только как зависимость для сборки, а не как зависимость библиотеки.
|
| Добавить интерпретатор Guile только как зависимость во время выполнения, а не как зависимость от библиотеки.
|
| Добавить значения |
| Объявить |
Некоторые дополнительные аргументы доступны для обработки нестандартных случаев; подробности см. в Mk/Uses/guile.mk.
Если не указано build или run, то LIB_DEPENDS получает зависимость от библиотеки libguile, а также любые дополнительные зависимости, требуемые версией guile, например, libgc. Обычно порту не требуются дополнительные зависимости, связанные с использованием Guile.
6.23.3. Флаги конфигурации
Программное обеспечение, использующее Guile, должно использовать механизм pkg-config для получения флагов компилятора и компоновщика. Некоторые старые или экзотические порты могут использовать guile-config или получать значения напрямую из guile, что также должно работать (в некоторых из этих случаев может быть полезен аргумент alias).
Фреймворк пытается сообщить порту желаемую версию Guile, используя следующие методы:
GUILE_EFFECTIVE_VERSIONдобавлен вCONFIGURE_ENV;Полный путь к исполняемому файлу Guile указан в переменной
GUILEвCONFIGURE_ENVиMAKE_ENV;Если используется опция
alias, то желаемые версии бинарных файлов Guile являются теми, которые имеют алиасы;Если параметр
aliasне используется, пути к инструментам нужной версии Guile (guild,guile-configи т.д.) добавляются вCONFIGURE_ENVиMAKE_ENVв виде переменныхGUILD,GUILE_CONFIGи т.д.
Для некоторых портов может потребоваться указать версию дополнительными способами, например, через CONFIGURE_ARGS или MESON_ARGS, в зависимости от порта.
Если ни один из этих методов не приводит к тому, что порт выбирает указанную версию Guile при наличии других версий, то предпочтительно исправить его, чтобы это происходило. Если это невозможно, укажите опцию conflicts, чтобы предотвратить сборку порта в условиях, когда он обнаруживает неправильную версию.
6.23.4. Флейворы версии
Порт, который устанавливает расширение или библиотеку Guile, или библиотеку Scheme, которая предварительно компилируется для Guile, должен собирать отдельный флейвор для каждой поддерживаемой версии Guile. Это делается путем добавления опции flavors.
Поскольку каждый флейвор должен иметь уникальное имя пакета, такие порты обычно устанавливают PKGNAMESUFFIX, например:
PKGNAMESUFFIX= -${FLAVOR}Такие порты должны устанавливать файлы Scheme в GUILE_SITE_DIR, а не в GUILE_GLOBAL_SITE_DIR, даже если файлы не зависят от версии. Это часто требует исправления порта.
Кроме того, если такой порт устанавливает файл .pc, он должен быть размещён в GUILE_PKGCONFIG_PATH, а не в глобальной директории pkgconfig. Это позволяет зависимым портам находить правильную конфигурацию для используемой версии Guile.
Если порт расширения Guile устанавливает файл .so, то обычно он должен быть размещён в специфичной для версии Guile директории extensions. Обычно не следует использовать USE_LDCONFIG.
Любые другие файлы, устанавливаемые портом с флейвором, также должны находиться в версионных каталогах или использовать версионные имена файлов. Для документации и примеров переменные GUILE_DOCS_DIR и GUILE_EXAMPLES_DIR указывают подходящие расположения, в которых порт должен создать подкаталог (см. ниже).
6.23.5. Переменные, определенные в фреймворке
В порте доступны эти переменные.
| Имя | Пример значения | Описание |
|---|---|---|
|
| Используемая версия Guile. |
|
| Короткий суффикс, используемый в некоторых именах. Используйте с осторожностью; может быть неуникальным или измениться в будущем. |
|
| Название флейвора, соответствующее выбранной версии. |
|
| Расположение порта (origin) для указанной версии Guile. |
|
| Префикс каталога для использования при установке. |
|
| Имя интерпретатора Guile с суффиксом версии. |
|
| Полный путь к интерпретатору Guile. |
|
| Название инструмента Guild, с суффиксом версии. |
|
| Полный путь к инструменту Guild. |
| Как | |
|
| Где пакеты, использующие |
|
| Подходящее значение для |
Следующие элементы определены как переменные и как записи PLIST_SUB. Форма переменной имеет суффикс _DIR и представляет собой полный путь (с префиксом GUILE_PREFIX).
| Имя | Пример значения | Описание |
|---|---|---|
|
| Каталог сайта, общий для всех версий guile; обычно не должен использоваться. |
|
| Каталог сайта для выбранной версии Guile. |
|
| Каталог для скомпилированных файлов байт-кода. |
|
| Родительский каталог для документации, специфичной для версий. |
|
| Родительский каталог для примеров, специфичных для версий. |
6.23.6. Примеры
Makefile для приложения, использующего GuileЭтот пример демонстрирует, как сослаться на библиотеку Guile, необходимую во время сборки и выполнения. Обратите внимание, что ссылка должна указывать флейвор. В этом примере предполагается, что приложение использует pkg-config для поиска зависимостей.
PORTNAME= sample
DISTVERSION= 1.2.3
CATEGORIES= whatever
MAINTAINER= fred.bloggs@example.com
COMMENT= Sample
WWW= https://example.com/guile_sample/sample/
BUILD_DEPENDS= guile-lib-${GUILE_FLAVOR}>=0.2.5:devel/guile-lib@${GUILE_FLAVOR}
RUN_DEPENDS= guile-lib-${GUILE_FLAVOR}>=0.2.5:devel/guile-lib@${GUILE_FLAVOR}
USES= guile:2.2,3.0 pkgconfig
.include <bsd.port.mk>6.24. Использование iconv
В FreeBSD имеется встроенная реализация iconv в самой операционной системе.
Для программного обеспечения, требующего iconv, определите USES=iconv.
Когда порт определяет USES=iconv, становятся доступны следующие переменные:
| Имя переменной | Назначение | Порт iconv (при использовании расширений WCHAR_T или //TRANSLIT) | Базовый iconv |
|---|---|---|---|
| Каталог, в котором находится бинарный файл |
| /usr/bin/iconv |
| аргумент |
| (пусто) |
| Каталог, в котором находится реализация |
| /usr |
| Предварительно сконструированный аргумент configure для скриптов configure |
| (пусто) |
| Предварительно сконструированный аргумент configure для скриптов configure |
| (пусто) |
Эти два примера автоматически заполняют переменные правильным значением для систем, использующих converters/libiconv или iconv, входящий в состав операционной системы, соответственно:
iconvUSES= iconv
LDFLAGS+= -L${LOCALBASE}/lib ${ICONV_LIB}iconv с configureUSES= iconv
CONFIGURE_ARGS+=${ICONV_CONFIGURE_ARG}Как показано выше, ICONV_LIB пуста, когда присутствует встроенный iconv. Это можно использовать для обнаружения встроенного iconv и действовать соответственно.
Иногда в программе аргумент ld или путь поиска жестко заданы в Makefile или скрипте configure. Для решения этой проблемы можно использовать следующий подход:
-liconvUSES= iconv
post-patch:
@${REINPLACE_CMD} -e 's/-liconv/${ICONV_LIB}/' ${WRKSRC}/MakefileВ некоторых случаях необходимо установить альтернативные значения или выполнить операции в зависимости от наличия встроенного iconv. bsd.port.pre.mk должен быть включен до проверки значения ICONV_LIB:
iconvUSES= iconv
.include <bsd.port.pre.mk>
post-patch:
.if empty(ICONV_LIB)
# native iconv detected
@${REINPLACE_CMD} -e 's|iconv||' ${WRKSRC}/Config.sh
.endif
.include <bsd.port.post.mk>6.25. Использование Xfce
Порты, которым требуются библиотеки или приложения Xfce, устанавливают USES=xfce.
Конкретные зависимости библиотек и приложений Xfce задаются с помощью значений, присвоенных USE_XFCE. Они определены в /usr/ports/Mk/Uses/xfce.mk. Возможные значения:
USE_XFCE- garcon
- libexo
- libgui
- libmenu
- libutil
- panel
- thunar
- xfconf
USES=xfceUSES= xfce USE_XFCE= libmenu
В этом примере портированное приложение использует пакет виджетов, специфичных для GTK2: x11/libxfce4menu и x11/xfce4-conf.
USES= xfce:gtk2 USE_XFCE= libmenu xfconf
Компоненты Xfce, включённые таким образом, автоматически загрузят все необходимые зависимости. Указывать полный список больше не требуется. Если порту нужен только x11-wm/xfce4-panel, используйте: USES= xfce USE_XFCE= panel Нет необходимости перечислять компоненты x11-wm/xfce4-panel, которые ему самому требуются, вот так: USES= xfce USE_XFCE= libexo libmenu libutil panel Однако компоненты Xfce и зависимости порта, не относящиеся к Xfce, должны быть явно включены. Не рассчитывайте, что компонент Xfce предоставит дополнительную зависимость, кроме себя, для основного порта. |
6.26. Использование Budgie
Приложения или библиотеки, зависящие от рабочего стола Budgie, должны указывать USES= budgie и устанавливать USE_BUDGIE в список необходимых компонентов.
| Имя | Описание |
|---|---|
| Ядро рабочего стола (библиотека) |
| Оконный менеджер X11 и библиотека композитинга Budgie |
| Универсальный центр в панели для доступа к различным виджетам приложений |
| Рабочий стол: специальная заставка |
Все виджеты приложений взаимодействуют через службу org.budgie_desktop.Raven. Зависимость по умолчанию включает время сборки и выполнения, её можно изменить с помощью USES= budgie USE_BUDGIE= screensaver:build |
USE_BUDGIEUSES= budgie gettext gnome meson pkgconfig USE_BUDGIE= libbudgie
6.27. Использование баз данных
Используйте один из макросов USES из Макросы USES для баз данных, чтобы добавить зависимость от базы данных.
| База данных | Макрос USES |
|---|---|
Berkeley DB | |
MariaDB, MySQL, Percona | |
PostgreSQL | |
SQLite |
USES= bdb:6
См. bdb для получения дополнительной информации.
Когда порту требуется клиентская библиотека MySQL, добавьте
USES= mysql
См. mysql для получения дополнительной информации.
Когда порту требуется сервер PostgreSQL версии 9.6 или новее, добавьте
USES= pgsql:9.6+ WANT_PGSQL= server
См. pgsql для получения дополнительной информации.
USES= sqlite:3
См. sqlite для получения дополнительной информации.
6.28. Запуск и остановка служб (скрипты rc)
rc.d скрипты используются для запуска служб при загрузке системы, а также предоставляют администраторам стандартный способ остановки, запуска и перезапуска служб. Порты интегрируются в систему rc.d. Подробности использования можно найти в соответствующей главе Handbook. Детальное объяснение доступных команд приведено в rc(8) и rc.subr(8). Наконец, существует статья, посвящённая практическим аспектам написания rc.d скриптов.
С мифическим портом под названием doorman, которому необходимо запустить демон doormand. Добавьте следующее в Makefile:
USE_RC_SUBR= doormand
Можно указать несколько скриптов, которые будут установлены. Скрипты должны быть размещены в подкаталоге files, и к их имени должен быть добавлен суффикс .in. Для этого файла будут выполнены стандартные подстановки SUB_LIST. Также настоятельно рекомендуется использовать подстановки %%PREFIX%% и %%LOCALBASE%%. Подробнее о SUB_LIST см. в соответствующем разделе.
Начиная с FreeBSD 6.1-RELEASE, локальные скрипты rc.d (включая те, что установлены через порты) включены в общий rcorder(8) базовой системы.
Пример простого скрипта rc.d для запуска демона doormand:
#!/bin/sh
# PROVIDE: doormand
# REQUIRE: LOGIN
# KEYWORD: shutdown
#
# Add these lines to /etc/rc.conf.local or /etc/rc.conf
# to enable this service:
#
# doormand_enable (bool): Set to NO by default.
# Set it to YES to enable doormand.
# doormand_config (path): Set to %%PREFIX%%/etc/doormand/doormand.cf
# by default.
. /etc/rc.subr
name=doormand
rcvar=doormand_enable
load_rc_config $name
: ${doormand_enable:="NO"}
: ${doormand_config="%%PREFIX%%/etc/doormand/doormand.cf"}
command=%%PREFIX%%/sbin/${name}
pidfile=/var/run/${name}.pid
command_args="-p $pidfile -f $doormand_config"
run_rc_command "$1"Если нет очень веской причины запускать службу раньше или она работает от имени определенного пользователя (не root), все скрипты портов должны использовать:
REQUIRE: LOGIN
Если скрипт запуска демона требует его остановки, следующий код активирует остановку службы при выключении системы:
KEYWORD: shutdown
Если скрипт не запускает постоянную службу, это не требуется.
Для необязательных элементов конфигурации предпочтительнее использовать стиль присваивания переменных по умолчанию "=" вместо стиля ":=", так как первый устанавливает значение по умолчанию только если переменная не задана, а второй — если переменная не задана или равна null. Пользователь может включить что-то вроде:
doormand_flags=""
в свой rc.conf.local, а подстановка переменной с использованием ":=" некорректно переопределила бы намерение пользователя. Переменная _enable не является опциональной и должна использовать ":" для значения по умолчанию.
Порты не должны запускать и останавливать свои службы при установке и удалении. Не злоупотребляйте ключевыми словами plist, описанными в разделе @preexec command,@postexec command,@preunexec command,@postunexec command, выполняя команды, которые изменяют работающую систему, включая запуск или остановку служб. |
6.28.1. Pre-Commit Checklist
Прежде чем внести порт с rc.d скриптом, и что более важно, перед его коммитом, пожалуйста, ознакомьтесь с этим контрольным списком, чтобы убедиться, что он готов.
Порт devel/rclint может проверить большинство из них, но он не заменяет тщательного просмотра и проверки.
Если это новый файл, имеет ли он расширение .sh? Если да, его необходимо изменить на просто file.in, поскольку файлы rc.d не могут оканчиваться таким расширением.
Совпадают ли имя файла (без .in), строка
PROVIDEи$`name? Совпадение имени файла с `PROVIDEупрощает отладку, особенно при проблемах с rcorder(8). Совпадение имени файла и `$`name облегчает понимание того, какие переменные актуальны в rc.conf[.local]. Это также является политикой для всех новых скриптов, включая те, что в базовой системе.Установлена ли строка
REQUIREв значениеLOGIN? Это обязательно для скриптов, выполняемых от имени непривилегированного пользователя. Если скрипт выполняется от имени root, есть ли веская причина для его запуска доLOGIN? Если нет, он должен запускаться после, чтобы локальные скрипты можно было условно сгруппировать в rcorder(8) после запуска большинства компонентов базовой системы.Запускает ли скрипт постоянную службу? Если да, он должен содержать
KEYWORD: shutdown.Убедитесь, что отсутствует
KEYWORD: FreeBSD. Это перестало быть необходимым или желательным уже много лет. Это также указывает на то, что новый скрипт был скопирован/вставлен из старого скрипта, поэтому следует проявить дополнительную осторожность при проверке.Если скрипт использует интерпретируемый язык, например
perl,pythonилиruby, убедитесь, чтоcommand_interpreterустановлен корректно. Например, для Perl добавьтеPERL=${PERL}вSUB_LISTи используйте%%PERL%%. В противном случае,# service name stopвероятно, не будет работать корректно. Дополнительную информацию смотрите в service(8).
Проверено, что все вхождения /usr/local заменены на
%%PREFIX%%?Делаются ли присваивания переменным по умолчанию после
load_rc_config?Используются ли пустые строки при присвоении значений по умолчанию? Такие присвоения должны быть удалены, но перепроверьте, что эти параметры задокументированы в комментариях в начале файла.
Действительно ли в сценариях используются значения, присвоенные переменным?
Являются ли опции, перечисленные в стандартном name`_flags`, обязательными? Если да, они должны быть в
command_args. Флаг-dздесь, как красный флаг (простите за каламбур), так как обычно это опция для "демонизации" процесса и, следовательно, фактически обязательна._name__flagsникогда не должны включаться вcommand_args(и наоборот, хотя такая ошибка встречается реже).Выполняет ли скрипт любой код безусловно? Это не приветствуется. Обычно такие вещи должны обрабатываться через
start_precmd.Все логические проверки должны использовать функцию
checkyesno. Не допускаются самодельные проверки на[Yy][Ee][Ss]и т.п.Если есть цикл (например, ожидание запуска чего-либо), есть ли в нём счётчик для завершения цикла? Мы не хотим, чтобы загрузка зависала навсегда в случае ошибки.
Создает ли скрипт файлы или каталоги, требующие определенных разрешений, например, pid, который должен принадлежать пользователю, запускающему процесс? Вместо традиционной последовательности touch(1)/chown(8)/chmod(1) рассмотрите использование install(1) с соответствующими аргументами командной строки, чтобы выполнить всю процедуру за один шаг.
6.29. Добавление пользователей и групп
Некоторые порты требуют наличия определённой учётной записи пользователя, обычно для демонов, работающих от имени этого пользователя. Для таких портов выберите уникальный UID в диапазоне от 50 до 999 и зарегистрируйте его в ports/UIDs (для пользователей) и ports/GIDs (для групп). Уникальный идентификатор должен быть одинаковым для пользователей и групп.
Пожалуйста, приложите патч для этих двух файлов, если требуется создать нового пользователя или группу для порта.
Затем используйте USERS и GROUPS в Makefile, и пользователь будет автоматически создан при установке порта.
USERS= pulse GROUPS= pulse pulse-access pulse-rt
Текущий список зарезервированных UID и GID можно найти в ports/UIDs и ports/GIDs.
6.30. Порты, зависящие от исходных кодов ядра
Некоторые порты (например, загружаемые модули ядра) требуют исходные файлы ядра для компиляции порта. Вот правильный способ проверить, установлены ли они у пользователя:
USES= kmod
Помимо этой проверки, функция kmod учитывает большинство аспектов, которые необходимо принимать во внимание данным портам.
6.31. Библиотеки Go
Порты не должны упаковывать или устанавливать библиотеки или исходный код Go. Порты Go должны загружать необходимые зависимости в обычное время загрузки и должны устанавливать только программы и то, что нужно пользователям, а не то, что нужно разработчикам на Go.
Порты должны (в порядке предпочтения):
Использовать зависимости, включенные в исходный код пакета.
Получить версии зависимостей, указанные вышестоящим проектом (в случае go.mod, vendor.json или аналогичных).
В крайнем случае (зависимости не включены и версии не указаны точно) получить версии зависимостей, доступные на момент разработки/выпуска вышестоящего проекта.
6.32. Библиотеки Haskell
Как и в случае с языком Go, коллекция портов не должна включать или устанавливать библиотеки Haskell. Порты Haskell должны статически линковаться со своими зависимостями и загружать все распространяемые файлы на этапе fetch.
6.33. Файлы завершения командной оболочки
Многие современные оболочки (включая bash, fish, tcsh и zsh) поддерживают табуляцию для параметров и/или опций. Эта поддержка обычно обеспечивается файлами завершения, которые содержат определения того, как будет работать завершение по табуляции для определённой команды. Порты иногда поставляются со своими собственными файлами завершения, или разработчики портов могут создавать их самостоятельно.
Если доступны файлы завершения, их всегда следует устанавливать. Нет необходимости создавать для этого опцию. Однако если опция используется, всегда включайте её в OPTIONS_DEFAULT.
| ${PREFIX}/etc/bash_completion.d or ${PREFIX}/share/bash-completion/completions | (любые уникальные имена файлов в одной из этих папок) |
| ${PREFIX}/share/fish/completions/${PORTNAME}.fish | |
| ${PREFIX}/share/zsh/site-functions/_${PORTNAME} |
Не регистрируйте зависимости от самих оболочек.
Глава 7. Флейворы
7.1. Введение в флейворы (Flavors)
Флейворы (Flavors) — это способ создания нескольких вариаций порта. Порт собирается несколько раз с различными вариациями.
Например, порт может иметь обычную версию с множеством функций и значительным количеством зависимостей, а также облегчённую "lite"-версию только с базовыми функциями и минимальными зависимостями.
Еще одним примером может быть порт с вариантом GTK и вариантом QT, в зависимости от используемого набора инструментов.
7.2. Использование FLAVORS
Чтобы объявить порт с несколькими флейворами, добавьте FLAVORS в его Makefile. Первый вариант в FLAVORS является вариантом по умолчанию.
Это может помочь упростить логику Makefile, также определив FLAVOR?= ${FLAVORS:[1]} |
Чтобы отличать флейворы от опций, которые всегда обозначаются заглавными буквами, названия флейворов могут содержать только строчные буквы, цифры и символ подчёркивания |
Если порт имеет "облегченный" подчиненный порт (lite slave port), подчиненный порт можно удалить, а порт преобразовать во флейворы с помощью:
FLAVORS= default lite
lite_PKGNAMESUFFIX= -lite
[...]
.if ${FLAVOR:U} != lite
[enable non lite features]
.endifЕсли порт имеет подчиненный порт -nox11, подчиненный порт можно удалить, а порт преобразовать в флейворы с помощью:
FLAVORS= x11 nox11
FLAVOR?= ${FLAVORS:[1]}
nox11_PKGNAMESUFFIX= -nox11
[...]
.if ${FLAVOR} == x11
[enable x11 features]
.endifВот слегка отредактированный отрывок из того, что присутствует в пакете devel/libpeas, порте, который использует флейворы Python. При стандартных версиях Python 2 и 3, а именно 2.7 и 3.6, он автоматически получит FLAVORS=py27 py36
USES= gnome python
USE_PYTHON= flavors
.if ${FLAVOR:Upy27:Mpy2*}
USE_GNOME= pygobject3
CONFIGURE_ARGS+= --enable-python2 --disable-python3
BUILD_WRKSRC= ${WRKSRC}/loaders/python
INSTALL_WRKSRC= ${WRKSRC}/loaders/python
.else # py3*
USE_GNOME+= py3gobject3
CONFIGURE_ARGS+= --disable-python2 --enable-python3 \
ac_cv_path_PYTHON3_CONFIG=${LOCALBASE}/bin/python${PYTHON_VER}-config
BUILD_WRKSRC= ${WRKSRC}/loaders/python3
INSTALL_WRKSRC= ${WRKSRC}/loaders/python3
.endif
py34_PLIST= ${.CURDIR}/pkg-plist-py3
py35_PLIST= ${.CURDIR}/pkg-plist-py3
py36_PLIST= ${.CURDIR}/pkg-plist-py3Этот порт не использует USE_PYTHON=distutils, но всё равно требует флейворы Python. Чтобы избежать ошибки в make(1) из-за пустого значения FLAVOR, используйте ${FLAVOR:U} в сравнениях строк вместо ${FLAVOR}. Привязки Gnome Python gobject3 имеют два разных названия: pygobject3 для Python 2 и py3gobject3 для Python 3. Скрипт configure должен выполняться в ${WRKSRC}, но нас интересует только сборка и установка частей программного обеспечения для Python 2 или Python 3, поэтому установите базовые каталоги сборки и установки соответствующим образом. Подсказка о правильном пути к конфигурационному скрипту Python 3. Список упаковки отличается при сборке с Python 3. Поскольку есть три возможные версии Python 3, установите PLIST для всех трёх с помощью вспомогательные инструменты флейворов.
7.2.1. Вспомогательные инструменты для флейворов (Flavors Helpers)
Чтобы упростить написание Makefile, существуют несколько вспомогательных инструментов (помощников) флейворов.
Этот список помощников установит их переменную:
flavor_PKGNAMEPREFIXflavor_PKGNAMESUFFIXflavor_PLISTflavor_DESCR
Этот список помощников будет добавлен к их переменной:
flavor_CONFLICTSflavor_CONFLICTS_BUILDflavor_CONFLICTS_INSTALLflavor_PKG_DEPENDSflavor_EXTRACT_DEPENDSflavor_PATCH_DEPENDSflavor_FETCH_DEPENDSflavor_BUILD_DEPENDSflavor_LIB_DEPENDSflavor_RUN_DEPENDSflavor_TEST_DEPENDS
PKGNAMEПоскольку все пакеты должны иметь уникальные имена, флейворы должны изменять их, используя flavor_PKGNAMEPREFIX и flavor_PKGNAMESUFFIX, что упрощает задачу:
FLAVORS= normal lite lite_PKGNAMESUFFIX= -lite
7.3. USES=php и флейворы
При использовании php с одним из этих аргументов: phpize, ext, zend или pecl, порт автоматически получит заполненный параметр FLAVORS с версиями PHP, которые он поддерживает.
USES=phpЭто создаст пакет для всех поддерживаемых версий:
PORTNAME= some-ext
PORTVERSION= 0.0.1
PKGNAMEPREFIX= ${PHP_PKGNAMEPREFIX}
USES= php:extЭто создаст пакет для всех поддерживаемых версий, кроме 7.2:
PORTNAME= some-ext
PORTVERSION= 0.0.1
PKGNAMEPREFIX= ${PHP_PKGNAMEPREFIX}
USES= php:ext
IGNORE_WITH_PHP= 727.3.1. Версии PHP с приложениями PHP
Приложения PHP также могут быть созданы с использованием флейворов.
Это позволяет создавать пакеты для всех версий PHP, чтобы пользователи могли использовать их с любой необходимой версией на своих серверах.
Приложения PHP, которые используют флейворы, обязаны добавлять |
Добавление поддержки флейворов в PHP-приложение просто:
PKGNAMESUFFIX= ${PHP_PKGNAMESUFFIX}
USES= php:flavorsПри добавлении зависимости к порту с вариантом PHP используйте |
7.4. USES=python и флейворы
При использовании python и USE_PYTHON=distutils порт автоматически получит заполненные FLAVORS с версиями Python, которые он поддерживает.
USES=pythonПредполагая, что поддерживаемые версии Python — 2.7, 3.4, 3.5 и 3.6, а версии Python 2 и 3 по умолчанию — 2.7 и 3.6, порт с параметрами:
USES= python USE_PYTHON= distutils
получит следующие флейворы: py27 и py36.
USES= python USE_PYTHON= distutils allflavors
получит следующие флейворы: py27, py34, py35 и py36.
USES=python с требованиями к версииПредполагая, что поддерживаемые версии Python — 2.7, 3.4, 3.5 и 3.6, а версии Python 2 и 3 по умолчанию — 2.7 и 3.6, порт с параметрами:
USES= python:-3.5 USE_PYTHON= distutils
получит следующие флейвор: py27.
USES= python:-3.5 USE_PYTHON= distutils allflavors
получит следующие флейворы: py27, py34 и py35.
USES= python:3.4+ USE_PYTHON= distutils
получит следующий флейвор: py36.
USES= python:3.4+ USE_PYTHON= distutils allflavors
получит следующие флейворы: py34, py35 и py36.
PY_FLAVOR доступен для указания правильной версии модулей Python. Все зависимости от вариантов портов Python должны использовать PY_FLAVOR, а не FLAVOR напрямую.
distutilsЕсли версия Python 3 по умолчанию — 3.6, следующая команда установит PY_FLAVOR в значение py36:
RUN_DEPENDS= ${PYTHON_PKGNAMEPREFIX}mutagen>0:audio/py-mutagen@${PY_FLAVOR}
USES= python:3.5+7.5. USES=lua и флейворы
При использовании lua:module или lua:flavors порт автоматически получит заполненный параметр FLAVORS с версиями Lua, которые он поддерживает. Однако предполагается, что обычные приложения (а не модули Lua) не должны использовать эту возможность; большинству приложений, которые встраивают или иным образом используют Lua, следует просто указывать USES=lua.
LUA_FLAVOR доступен (и должен использоваться) для зависимости от правильной версии зависимостей, независимо от того, использовал ли порт параметры flavors или module.
См. Использование Lua для получения дополнительной информации.
7.6. USES=guile и флейворы
При использовании guile:flavors порт автоматически получит заполненное поле FLAVORS с версиями Guile, которые он поддерживает. Однако не предполагается, что обычные приложения должны использовать эту возможность; она в первую очередь предназначена для библиотек и расширений, таких как guile-lib или guile-cairo.
GUILE_FLAVOR доступен (и должен использоваться) для зависимости от правильной версии зависимостей с флейворами, независимо от того, использовал ли порт параметр flavors или нет.
См. Использование Guile для получения дополнительной информации.
Глава 8. Продвинутые практики pkg-plist
8.1. Изменение содержимого pkg-plist в зависимости от make-переменных
Некоторые порты, в частности, порты p5-, должны менять содержимое своих файлов pkg-plist в зависимости от того, с какими параметрами они были отконфигурированы (или в зависимости от версии языка perl в случае портов p5-). Чтобы облегчить этот процесс, любые вхождения ключевых слов %%OSREL%%, %%PERL_VER%% и %%PERL_VERSION%% в файле pkg-plist будут заменяться соответствующими значениями. Значением %%OSREL%% является номер версии операционной системы (например, 4.9). %%PERL_VERSION%% и %%PERL_VER%% обозначают полный номер версии perl (например, 5.8.9). Некоторые другие %%VARS%%, имеющие отношение к файлам документации порта, описаны в соответствующем разделе.
Если вам нужно сделать другие подстановки, вы можете указать в переменной PLIST_SUB список пар VAR=VALUE, и все вхождения %%VAR%% в файле pkg-plist будут заменяться на значение VALUE.
Например, если порт устанавливает множество файлов в подкаталоге, зависящем от версии, используйте заполнитель для версии, чтобы файл pkg-plist не требовал перегенерации при каждом обновлении порта. Например, укажите:
OCTAVE_VERSION= ${PORTREVISION}
PLIST_SUB= OCTAVE_VERSION=${OCTAVE_VERSION}в файле Makefile и использовать %%OCTAVE_VERSION%% везде, где нужно указать номер версии в файле pkg-plist. Таким образом, при обновлении порта вам не нужно будет менять десятки (а в некоторых случаях и сотни) строк в файле pkg-plist.
Если файлы устанавливаются по условию в зависимости от опций, установленных в порте, обычный способ обработки — это добавление префикса %%OPT%% для строк в pkg-plist, которые нужны при включении опции, или %%NO_OPT%%, когда опция отключена, а также добавление OPTIONS_SUB=yes в Makefile. Подробнее см. OPTIONS_SUB.
Например, если есть файлы, которые устанавливаются только при включении опции X11, и в Makefile указано:
OPTIONS_DEFINE= X11 OPTIONS_SUB= yes
В pkg-plist укажите %%X11%% перед строками, которые устанавливаются только при включении опции, например:
%%X11%%bin/foo-gui
Эта подстановка будет сделана между выполнением целей pre-install и do-install, посредством чтения файла PLIST и записью в файл TMPPLIST (по умолчанию это файл WRKDIR/.PLIST.mktmp). Так что если ваш порт строит PLIST на лету, делайте это во время или до выполнения цели pre-install. Кроме того, если вашему порту требуется отредактировать получающийся файл, делайте это в цели post-install изменением файла TMPPLIST.
Ещё один способ изменения списка упаковки порта основан на установке переменных PLIST_FILES и PLIST_DIRS. Значение каждой переменной рассматривается как список путей для записи в TMPPLIST вместе с содержимым PLIST. Хотя имена, перечисленные в PLIST_FILES и PLIST_DIRS, подлежат замене %%VAR%%, как описано выше, лучше использовать ${VAR} напрямую. За исключением этого, имена из PLIST_FILES появятся в итоговом списке упаковки без изменений, тогда как к именам из PLIST_DIRS будет добавлен префикс @dir. Чтобы вступить в силу, PLIST_FILES и PLIST_DIRS должны быть установлены до записи TMPPLIST, то есть в pre-install или ранее.
Время от времени использования OPTIONS_SUB недостаточно. В таких случаях добавление специфичного TAG в PLIST_SUB внутри Makefile со специальным значением @comment заставляет инструменты пакетирования игнорировать строку. Например, если некоторые файлы устанавливаются только при включённой опции X11 и архитектуре i386:
.include <bsd.port.pre.mk>
.if ${PORT_OPTIONS:MX11} && ${ARCH} == "i386"
PLIST_SUB+= X11I386=""
.else
PLIST_SUB+= X11I386="@comment "
.endif8.2. Пустые каталоги
8.2.1. Очистка пустых каталогов
При удалении порт должен удалить пустые каталоги, которые он создал. Большинство этих каталогов автоматически удаляются с помощью pkg(8), но для каталогов, созданных вне ${PREFIX}, или пустых каталогов требуется дополнительная работа. Обычно это делается добавлением строк @dir для таких каталогов. Подкаталоги должны быть удалены до удаления родительских каталогов.
[...] @dir /var/games/oneko/saved-games @dir /var/games/oneko
8.2.2. Создание пустых каталогов
Пустые каталоги, созданные во время установки порта, требуют особого внимания. Они должны присутствовать при создании пакета. Если они не созданы кодом порта, создайте их в Makefile:
post-install:
${MKDIR} ${STAGEDIR}${PREFIX}/some/directoryДобавьте директорию в pkg-plist так же, как и любую другую. Например:
@dir some/directory
8.3. Файлы конфигурации
Если порт устанавливает файлы конфигурации в PREFIX/etc (или в другое место), не указывайте их в pkg-plist. Это приведёт к тому, что pkg delete удалит файлы, которые были тщательно отредактированы пользователем, а повторная установка перезапишет их.
Вместо этого устанавливайте образцы файлов с расширением filename.sample. Макрос @sample автоматизирует этот процесс; подробности его работы см. в разделе Расширение списка пакетов с помощью ключевых слов. Для каждого образца файла добавьте строку в pkg-plist:
@sample etc/orbit.conf.sample
Если существует очень веская причина не устанавливать рабочий файл конфигурации по умолчанию, укажите только имя примера файла в pkg-plist, без части @sample с последующим пробелом, и добавьте сообщение, указывающее, что пользователь должен скопировать и отредактировать файл перед тем, как программа заработает.
Когда порт устанавливает свою конфигурацию в подкаталоге ${PREFIX}/etc, используйте |
Примеры конфигурационных файлов всегда должны иметь суффикс .sample. Если по каким-то историческим причинам использование стандартного суффикса невозможно, или если примеры файлов взяты из другого каталога, используйте эту конструкцию: @sample etc/orbit.conf-dist etc/orbit.conf или @sample %%EXAMPLESDIR%%/orbit.conf etc/orbit.conf Формат: |
8.4. Динамический или статический список упаковки
Статический список упаковки — это список упаковки, который доступен в Коллекции Портов или как файл pkg-plist (с подстановкой переменных или без неё), или как встроенный в Makefile через PLIST_FILES и PLIST_DIRS. Даже если содержимое было автоматически сгенерировано инструментом или целью в Makefile до включения в Коллекцию портов коммиттером (например, с использованием make makeplist), такой список всё равно считается статическим, поскольку его можно посмотреть без необходимости загрузки или компиляции distfile.
Динамический список упаковки — это список упаковки, который генерируется во время компиляции порта на основе установленных файлов и каталогов. Невозможно изучить его до загрузки и компиляции исходного кода портированного приложения или после выполнения команды make clean.
Хотя использование динамических списков упаковки не запрещено, сопровождающие должны использовать статические списки упаковки везде, где это возможно, поскольку это позволяет пользователям выполнять grep(1) по доступным портам для обнаружения, например, какой порт устанавливает определенный файл. Динамические списки должны быть использованы в основном для сложных портов, для которых изменения в списке упаковки кардинальным образом основаны на возможностях порта, настраиваемых параметрами, (и, таким образом, делая сопровождение статических списков упаковки невозможным), или портов, которые изменяют список упаковки на основе версии используемого им программного обеспечения (например, порты, которые порождают документы при помощи Javadoc).
8.5. Автоматическое создание списка упаковки
Сначала убедитесь, что порт почти готов, и отсутствует только файл pkg-plist. Запуск команды make makeplist покажет пример для файла pkg-plist. Вывод makeplist необходимо дважды перепроверять на корректность, так как он пытается автоматически угадать некоторые вещи и может ошибаться.
Файлы конфигурации пользователя должны устанавливаться как filename.sample, как описано в разделе Файлы конфигурации. info/dir не должен быть указан, а соответствующие строки install-info должны быть добавлены, как указано в разделе info-файлы. Любые библиотеки, устанавливаемые портом, должны быть перечислены, как указано в разделе общие библиотеки.
8.5.1. Расширение PLIST_SUB с помощью регулярных выражений
Строки, которые нужно заменить, иногда должны быть очень конкретными, чтобы избежать нежелательных замен. Это распространённая проблема с короткими значениями.
Для решения этой проблемы для каждого PLACEHOLDER=значение можно задать PLACEHOLDER_regex=регулярное_выражение, где часть regex более точно соответствует значению.
Порты Perl могут устанавливать архитектурно-зависимые файлы в специальное дерево. В FreeBSD для упрощения портирования это дерево называется mach. Например, порт, который устанавливает файл, чей путь содержит mach, может иметь эту часть строки пути заменённой неправильными значениями. Рассмотрим этот Makefile:
PORTNAME= Machine-Build DISTVERSION= 1 CATEGORIES= devel perl5 MASTER_SITES= CPAN PKGNAMEPREFIX= p5- MAINTAINER= perl@FreeBSD.org COMMENT= Building machine WWW= https://search.cpan.org/dist/Machine-Build USES= perl5 USE_PERL5= configure PLIST_SUB= PERL_ARCH=mach
Файлы, установленные портом:
/usr/local/bin/machine-build /usr/local/lib/perl5/site_perl/man/man1/machine-build.1.gz /usr/local/lib/perl5/site_perl/man/man3/Machine::Build.3.gz /usr/local/lib/perl5/site_perl/Machine/Build.pm /usr/local/lib/perl5/site_perl/mach/5.20/Machine/Build/Build.so
Запуск make makeplist ошибочно создает:
bin/%%PERL_ARCH%%ine-build %%PERL5_MAN1%%/%%PERL_ARCH%%ine-build.1.gz %%PERL5_MAN3%%/Machine::Build.3.gz %%SITE_PERL%%/Machine/Build.pm %%SITE_PERL%%/%%PERL_ARCH%%/%%PERL_VER%%/Machine/Build/Build.so
Измените строку PLIST_SUB в Makefile на:
PLIST_SUB= PERL_ARCH=mach \ PERL_ARCH_regex=\bmach\b
Теперь make makeplist правильно генерирует:
bin/machine-build %%PERL5_MAN1%%/machine-build.1.gz %%PERL5_MAN3%%/Machine::Build.3.gz %%SITE_PERL%%/Machine/Build.pm %%SITE_PERL%%/%%PERL_ARCH%%/%%PERL_VER%%/Machine/Build/Build.so
8.6. Расширение списка пакетов используя ключевые слова
Все ключевые слова также могут принимать необязательные аргументы в скобках. Аргументами являются владелец, группа и режим доступа. Этот аргумент применяется к файлу или каталогу, на который ссылаются. Чтобы изменить владельца, группу и режим доступа конфигурационного файла, используйте:
@sample(games,games,640) etc/config.sample
Аргументы являются необязательными. Если необходимо изменить только группу и режим, используйте:
@sample(,games,660) etc/config.sample
Если ключевое слово используется в необязательной записи, оно должно быть добавлено после помощника: %%FOO%%@sample etc/orbit.conf.sample Это происходит потому, что вспомогательные функции plist для опций используются для закомментирования строки, поэтому они должны быть указаны первыми. Дополнительную информацию см. в |
8.6.1. @desktop-file-utils
Будет выполнять update-desktop-database -q после установки и удаления. Никогда не используйте напрямую, добавьте USES=desktop-file-utils в Makefile.
8.6.2. @fc каталог
Добавить запись @dir для каталога, переданного в качестве аргумента, и выполнить fc-cache -fs для этого каталога после установки и удаления.
8.6.3. @fontsdir каталог
Добавить запись @dir для каталога, переданного в качестве аргумента, и запустить mkfontscale и mkfontdir в этом каталоге после установки и удаления. Кроме того, при удалении удаляются кэш-файлы fonts.scale и fonts.dir, если они пусты.
8.6.4. @info файл
Добавляет файл, переданный в качестве аргумента, в plist и обновляет индекс документа info при установке и удалении. Кроме того, удаляет индекс, если он пуст, при удалении. Это никогда не следует использовать вручную, а только через INFO. Подробнее см. в Файлы Info.
8.6.5. @kld каталог
Выполняет kldxref для каталога при установке и удалении. Дополнительно при удалении каталог будет удалён, если он пуст.
8.6.7. @sample файл [файл]
Это используется для обработки установки файлов конфигурации, используя примеры файлов, поставляемых с пакетом. "Реальный" файл (не пример) — это либо второе имя файла, если оно присутствует, либо первое имя файла без расширения .sample.
Это делает три вещи. Во-первых, добавляет первый переданный файл в качестве аргумента, образец файла, в plist. Затем, при установке, если фактический файл не найден, копирует образец файла в фактический файл. И наконец, при удалении, удаляет фактический файл, если он не был изменён. Дополнительную информацию см. в Файлы конфигурации.
8.6.8. @shared-mime-info каталог
Выполняет update-mime-database для указанного каталога при установке и удалении.
8.6.9. @shell файл
Добавить файл, переданный в качестве аргумента, в plist.
При установке добавить полный путь к file в /etc/shells, убедившись, что он не добавлен повторно. При удалении удалите его из /etc/shells.
8.6.10. @terminfo
Не использовать самостоятельно. Если порт устанавливает файлы *.terminfo, добавьте USES=terminfo в его Makefile.
При установке и удалении, если присутствует tic, обновить ${PREFIX}/shared/misc/terminfo.db из файлов *.terminfo в ${PREFIX}/shared/misc.
8.6.11. Основные ключевые слова
Есть несколько ключевых слов, которые жестко закодированы и документированы в pkg-create(8). Для полноты изложения они также документированы здесь.
8.6.11.1. @ [файл]
Ключевое слово empty является заполнителем, используемым, когда необходимо изменить владельца, группу или права доступа к файлу. Например, чтобы установить группу файла в games и добавить бит setgid, добавьте:
@(,games,2755) sbin/daemon
8.6.11.2. @preexec команда, @postexec команда, @preunexec команда, @postunexec команда
Выполнить комманду как часть процесса установки или удаления пакета.
@preexecкомандаВыполнить команду как часть скриптов pre-install.
@postexecкомандаВыполнить команду как часть скриптов post-install.
@preunexecкомандаВыполнить команду как часть скриптов pre-deinstall.
@postunexecкомандаВыполнить команду как часть скриптов post-deinstall.
Если в команде содержится любая из этих последовательностей, они раскрываются непосредственно. Для следующих примеров предположим, что @cwd установлен в /usr/local, а последним извлечённым файлом был bin/emacs.
%FРаскрывается до последнего извлеченного имени файла (как указано). В примере bin/emacs.
%DРаскрыть до текущего префикса директории, установленного с помощью
@cwd. В этом примере /usr/local.%BРаскрыть до базового имени полного имени файла, то есть префикс текущего каталога плюс последняя спецификация файла, за вычетом имени файла в конце спецификации. В данном примере это будет /usr/local/bin.
%fРаскрывается до части имени файла в полном квалифицированном имени, или противоположный случай для
%B. В примере, emacs.
Эти ключевые слова предназначены для помощи в настройке пакета, чтобы он был максимально готов к использованию. Они не должны использоваться для запуска служб, остановки служб или выполнения любых других команд, которые изменяют текущую работающую систему. |
8.6.11.3. @mode режим
Установить разрешения по умолчанию для всех последующих извлекаемых файлов в режим. Формат такой же, как используется в chmod(1). Использование без аргумента вернёт разрешения по умолчанию (режим файла при упаковке).
Это должен быть числовой режим, например |
8.6.11.4. @owner пользователь
Установить владельца по умолчанию для всех последующих файлов в пользователь. Использование без аргумента вернёт владельца по умолчанию (root).
8.6.11.5. @group группа
Установить группу-владельца по умолчанию для всех последующих файлов в группу. Использование без аргумента вернёт группу-владельца по умолчанию (wheel).
8.6.11.7. @dir каталог
Объявить имя каталога. По умолчанию каталоги, созданные в PREFIX при установке пакета, автоматически удаляются. Используйте эту опцию, если необходимо создать пустой каталог в PREFIX или если каталогу требуется нестандартный владелец, группа или права. Каталоги за пределами PREFIX необходимо регистрировать. Например, /var/db/${PORTNAME} требует записи @dir, тогда как ${PREFIX}/shared/${PORTNAME} — нет, если он содержит файлы или использует стандартные владельца, группу и права.
8.6.11.8. @exec команда, @unexec команда (Устарело)
Выполнить команду как часть процесса установки или удаления. Рекомендуется использовать @preexec команда вместо этого.
8.6.12. Создание новых ключевых слов
Файлы списка пакетов могут быть расширены ключевыми словами, которые определены в каталоге ${PORTSDIR}/Keywords. Настройки каждого ключевого слова хранятся в файле UCL с именем keyword.ucl. Файл должен содержать как минимум один из следующих разделов:
attributesactionpre-installpost-installpre-deinstallpost-deinstallpre-upgradepost-upgrade
8.6.12.1. attributes
Изменяет владельца, группу или режим доступа, используемые ключевым словом. Содержит ассоциативный массив, в котором возможными ключами являются owner, group и mode. Значениями являются, соответственно, имя пользователя, имя группы и режим доступа к файлу. Например:
attributes: { owner: "games", group: "games", mode: 0555 }8.6.12.2. action
Определяет, что происходит с параметром ключевого слова. Содержит массив, где возможные значения:
setprefixУстановите префикс для следующих записей в plist.
dirЗарегистрировать каталог для создания при установке и удаления при деинсталляции.
dirrmЗарегистрировать каталог для удаления при деинсталляции. Устарело.
dirrmtryЗарегистрировать каталог для попытки удаления при деинсталляции. Устарело.
fileЗарегистрировать файл.
setmodeУстановить режим для следующих записей plist.
setownerУстановить владельца для следующих записей plist.
setgroupУстановить группу для следующих записей в plist.
commentНе выполняет никаких действий, эквивалентно отсутствию раздела
action.ignore_nextИгнорировать следующую запись в plist.
8.6.12.3. arguments
Если установлено значение true, добавляется обработка аргументов, разделяя всю строку, %@, на нумерованные аргументы, %1, %2, и так далее. Например, для такой строки:
@foo some.content other.content
%1 и %2 будут содержать:
some.content other.content
Это также влияет на работу записи action. Если аргументов больше одного, необходимо указать номер аргумента. Например:
actions: [file(1)]
8.6.12.4. pre-install, post-install, pre-deinstall, post-deinstall, pre-upgrade, post-upgrade
Эти ключевые слова содержат sh(1) скрипт, который выполняется до или после установки, удаления или обновления пакета. В дополнение к обычным заполнителям @exec %foo, описанным в @preexec команда, существует новый заполнитель %@, который представляет аргумент ключевого слова.
8.6.12.5. Примеры пользовательских ключевых слов
@dirrmtryechoЭто ключевое слово выполняет две функции: добавляет строку @dirrmtry directory в список упаковки и сообщает о том, что директория удаляется при деинсталляции пакета.
actions: [dirrmtry] post-deinstall: <<EOD echo "Directory %D/%@ removed." EOD
@sampleЭтот ключевое слово выполняет три действия. Оно добавляет первый filename, переданный в качестве аргумента @sample, в список упаковки, добавляет в скрипт post-install инструкции для копирования образца в фактический файл конфигурации, если он ещё не существует, и добавляет в инструкции post-deinstall удаление файла конфигурации, если он не был изменён.
actions: [file(1)]
arguments: true
post-install: <<EOD
case "%1" in
/*) sample_file="%1" ;;
*) sample_file="%D/%1" ;;
esac
target_file="${sample_file%.sample}"
set -- %@
if [ $# -eq 2 ]; then
target_file=${2}
fi
case "${target_file}" in
/*) target_file="${target_file}" ;;
*) target_file="%D/${target_file}" ;;
esac
if ! [ -f "${target_file}" ]; then
/bin/cp -p "${sample_file}" "${target_file}" && \
/bin/chmod u+w "${target_file}"
fi
EOD
pre-deinstall: <<EOD
case "%1" in
/*) sample_file="%1" ;;
*) sample_file="%D/%1" ;;
esac
target_file="${sample_file%.sample}"
set -- %@
if [ $# -eq 2 ]; then
set -- %@
target_file=${2}
fi
case "${target_file}" in
/*) target_file="${target_file}" ;;
*) target_file="%D/${target_file}" ;;
esac
if cmp -s "${target_file}" "${sample_file}"; then
rm -f "${target_file}"
else
echo "You may need to manually remove ${target_file} if it is no longer needed."
fi
EODГлава 9. pkg-*
Есть несколько приёмов работы с файлами pkg-*, которые мы ещё не описали, но они иногда могут быть очень кстати.
9.1. pkg-message
Если вам нужно вывести сообщение для человека, устанавливающего приложение, то вы можете поместить сообщение в файл pkg-message. Эта возможность часто оказывается полезной для вывода дополнительных шагов установки, которые нужно предпринять после выполнения команды pkg install, или для вывода информации о лицензировании.
|
pkg-message поддерживает два формата:
- raw
Обычный текстовый файл. Его сообщение отображается только при установке.
- UCL
Если файл начинается с символа “[”, то он считается файлом в формате UCL. Формат UCL описан на странице libucl’s GitHub page.
Не добавляйте запись для pkg-message в pkg-plist. |
9.1.1. UCL в pkg-message
Формат следующий. Это должен быть массив объектов. Сами объекты могут содержать следующие ключевые слова:
messageОтображаемое сообщение. Этот ключевой параметр является обязательным.
typeКогда сообщение должно быть отображено.
maximum_versionТолько если
typeимеет значениеupgrade. Отображается, если обновление выполняется с версии строго ниже указанной.minimum_versionТолько если
typeимеет значениеupgrade. Отображается, если обновление выполняется с версии, строго большей, чем указанная.
Ключевые слова maximum_version и minimum_version можно комбинировать.
Ключевое слово type может иметь три значения:
installСообщение должно отображаться только при установке пакета.
removeСообщение должно отображаться только при удалении пакета.
upgradeсообщение должно отображаться только во время обновления пакета.
Для сохранения совместимости с файлами pkg-message, не использующими UCL, первая строка UCL pkg-message ДОЛЖНА быть одиночным символом “[”, а последняя строка ДОЛЖНА быть одиночным символом “]”. |
Сообщение ограничено двойными кавычками ", это используется для простых однострочных строк:
[
{ type: install
message: "Simple message"
}
]Многострочные строки используют стандартную нотацию heredoc. Разделитель многострочной строки должен начинаться сразу после символов << без пробелов и должен состоять только из заглавных букв. Чтобы завершить многострочную строку, добавьте строку-разделитель на отдельной строке без пробелов. Сообщение из раздела Короткие строки UCL может быть записано как:
[
{ type: install
message: <<EOM
Simple message
EOM
}
]Когда сообщение нужно отображать только при установке или удалении, укажите тип:
[
{
type: remove
message: "package being removed."
}
{ type: install, message: "package being installed."}
]При обновлении порта отображаемое сообщение может быть ещё более адаптировано к потребностям порта.
[
{
type: upgrade
message: "Package is being upgraded."
}
{
type: upgrade
maximum_version: "1.0"
message: "Upgrading from before 1.0 need to do this."
}
{
type: upgrade
minimum_version: "1.0"
message: "Upgrading from after 1.0 should do that."
}
{
type: upgrade
maximum_version: "3.0"
minimum_version: "1.0"
message: "Upgrading from > 1.0 and < 3.0 remove that file."
}
]9.2. pkg-install, pkg-pre-install и pkg-post-install
Если порту необходимо выполнять команды при установке бинарного пакета с помощью pkg add или pkg install, используйте pkg-install. Он запускается дважды через pkg: первый раз как ${SH} pkg-install ${PKGNAME} PRE-INSTALL перед установкой пакета и второй раз как ${SH} pkg-install ${PKGNAME} POST-INSTALL после его установки. Переменная $2 может быть проверена, чтобы определить, в каком режиме выполняется скрипт. Переменная окружения PKG_PREFIX устанавливается равной имени каталога установки пакета.
Если используется pkg-pre-install или pkg-post-install, скрипт выполняется только один раз (до или после установки пакета), с единственным аргументом ${PKGNAME}. Использование pkg-pre-install.lua или pkg-post-install.lua запускает скрипт на Lua вместо shell-скрипта. Скрипты на Lua, выполняемые pkg, предоставляют некоторые расширения и несколько ограничений, которые описаны в pkg-lua-script(5).
Использование pkg-pre-install (или pkg-pre-install.lua) и pkg-post-install (или pkg-post-install.lua) предпочтительнее, чем использование pkg-install. |
Эти скрипты автоматически добавляются в список упаковки.
Эти скрипты предназначены для упрощения настройки пакетов после установки. Они не должны использоваться для запуска служб, остановки служб или выполнения любых других команд, которые изменяют текущую работающую систему. |
9.3. pkg-deinstall, pkg-pre-deinstall и pkg-post-deinstall
Эти скрипты выполняются при удалении пакета.
Скрипт pkg-deinstall выполняется дважды командой pkg delete. Первый раз как ${SH} pkg-deinstall ${PKGNAME} DEINSTALL до удаления порта и второй раз как ${SH} pkg-deinstall ${PKGNAME} POST-DEINSTALL после удаления порта. Переменная $2 может быть проверена для определения режима, в котором выполняется скрипт. Переменная окружения PKG_PREFIX устанавливается в каталог установки пакета.
Если используется pkg-pre-deinstall или pkg-post-deinstall, скрипт выполняется только один раз (до или после удаления пакета) с единственным аргументом ${PKGNAME}. Использование pkg-pre-deinstall.lua или pkg-post-deinstall.lua запустит скрипт на Lua вместо shell-скрипта. Скрипты на Lua, выполняемые pkg, предоставляют некоторые расширения и ограничения, которые описаны в pkg-lua-script(5).
Использование pkg-pre-deinstall (или pkg-pre-deinstall.lua) и pkg-post-deinstall (или pkg-post-deinstall.lua) предпочтительнее, чем использование pkg-deinstall. |
Эти скрипты автоматически добавляются в список упаковки.
Эти скрипты предназначены для упрощения очистки после удаления пакетов. Они не должны использоваться для запуска служб, остановки служб или выполнения любых других команд, которые изменяют текущую работающую систему. |
9.4. Изменение имён файлов pkg-*
Все имена файлов pkg-* определяются с помощью переменных, так что вы можете изменить их, если это нужно, в вашем файле Makefile. Это особенно полезно, если вы используете одни и те же файлы pkg-* совместно между несколькими портами или пишете в один из вышеперечисленных файлов (в главе о записи в каталоги, отличные от WRKDIR объяснено, почему не рекомендуется осуществлять запись непосредственно в файлы pkg-*).
Вот список имён переменных и их значений по умолчанию. (Значение PKGDIR по умолчанию равно ${MASTERDIR}.)
| Переменная | Значение по умолчанию |
|---|---|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
9.5. Использование SUB_FILES и SUB_LIST
Переменные SUB_FILES и SUB_LIST подходят для задания в файлах порта динамических значений, таких как PREFIX установки в pkg-message.
В переменной SUB_FILES указывается перечень файлов для автоматического изменения. Каждый file из перечня SUB_FILES обязан иметь соответствующий file.in, присутствующий в FILESDIR. Измененная версия будет создана в WRKDIR. Файлы, определенные в качестве значения USE_RC_SUBR (или устаревшего USE_RCORDER), автоматически добавляются в SUB_FILES. Для файлов pkg-message, pkg-install и pkg-deinstall устанавливается соответствующая переменная Makefile, указывающая на обработанную версию.
Переменная SUB_LIST содержит перечень пар VAR=VALUE. В каждом файле из SUB_FILES для каждой пары будет произведена замена %%VAR%% на VALUE. Некоторые общие пары определяются автоматически: PREFIX, LOCALBASE, DATADIR, DOCSDIR, EXAMPLESDIR, WWWDIR и ETCDIR. Любая строка, начинающаяся с @comment, будет удалена из конечного файла после подстановки переменной.
В следующем примере в pkg-message будет сделана замена %%ARCH%% на системную архитектуру:
SUB_FILES= pkg-message
SUB_LIST= ARCH=${ARCH}Обратите внимание, что в этом примере в FILESDIR обязательно существование файла pkg-message.in.
Пример хорошего pkg-message.in:
Now it is time to configure this package. Copy %%PREFIX%%/shared/examples/putsy/%%ARCH%%.conf into your home directory as .putsy.conf and edit it.
Глава 10. Тестирование порта
10.1. Запуск make describe
Некоторые утилиты FreeBSD для сопровождения портов, например, portupgrade(1), опираются на базу данных с именем /usr/ports/INDEX, в которой отслеживаются такие характеристики портов, как их зависимости. Файл INDEX создаётся при помощи ports/Makefile верхнего уровня по команде make index, спускающейся в подкаталог каждого порта и выполняющей в нём make describe. Таким образом, если выполнение make describe с каким-либо портом завершится неудачно, то никому не удастся создать INDEX, при этом много людей вскоре станут несчастны.
Возможность генерировать этот файл очень важна вне зависимости от того, какие параметры присутствуют в make.conf, поэтому, пожалуйста, избегайте, таких вещей, как использование декларации |
Если make describe выдаёт строчку, а не ошибку, то для вас это пройдёт безболезненно. Обратитесь к файлу bsd.port.mk, чтобы выяснить значение выдаваемых строк.
Также обратите внимание, что запуск актуальной версии portlint (как указано в следующем разделе) приведёт к автоматическому выполнению make describe.
10.2. Запуск make test
Даже если порт успешно собирается, рекомендуется убедиться, что программа корректно выполняет свои функции. Если исходный проект предоставляет тесты вместе с программным обеспечением, рекомендуется их запустить и проверить, что всё работает, как ожидается.
Порт может автоматически включить тесты, используя переменную TEST_TARGET. Когда эта переменная установлена, она содержит имя цели тестирования порта. Обычно это просто test, но другие варианты включают tests, check или, в специфических случаях, такие значения, как run_tests.py.
В дополнение к переменной TEST_TARGET фреймворк предоставляет следующие переменные для управления выполнением тестов:
TEST_WRKSRC— это каталог для выполнения тестов.TEST_ENVсодержит дополнительные переменные, которые передаются на этап тестирования.TEST_ARGSсодержит любые дополнительные аргументы, переданные на этапе тестирования.
Примеры использования этих переменных можно найти в cad/xyce, www/libjwt и других.
Убедитесь, что тесты не ломаются при обновлении порта. |
10.3. Portclippy / Portfmt
Эти инструменты поставляются из пакета:ports-mgmt/portfmt[].
Portclippy — это линтер, проверяющий, расположены ли переменные в файле Makefile в правильном порядке согласно Порядку переменных в Makefile портов.
Portfmt — это инструмент для автоматического форматирования Makefile.
10.4. Portlint
Проверьте свою работу командой portlint перед тем, как её отослать или перенести в дерево портов. portlint предупреждает вас о многих распространённых ошибках, как функциональных, так и стилистических. Для нового (или скопированного внутри хранилища) порта самым подходящим является запуск portlint -A; для уже существующего порта достаточно будет запустить portlint -C.
Так как для обнаружения ошибок portlint использует эвристические методы, то им могут выдаваться и ошибочные предупреждения. Кроме того, время от времени нечто, отмечаемое как некорректность, из-за ограничений механизма создания портов не может быть сделано никак иначе. Если вы сомневаетесь, то лучше всего спросить в Список рассылки, посвящённый Портам FreeBSD.
10.5. Инструменты для работы с портами
Программа ports-mgmt/porttools входит в состав Коллекции Портов.
port является сценарием переднего плана, который может упростить вам задачу тестирования. Если вы хотите проверить новый порт или обновить существующий, то вы можете использовать port test для проверки вашего порта, включая проверку portlint. Эта команда также находит и отображает любые файлы, которые невключенные в pkg-plist. Смотрите следующий пример:
# port test /usr/ports/net/csup10.6. PREFIX и DESTDIR
Переменная PREFIX определяет, куда будет установлен порт. По умолчанию это /usr/local, но может меняться пользователем на собственный путь, такой как /opt. В вашем порту значение этой переменной должно учитываться.
Если пользователь установил переменную DESTDIR, то она определяет полное альтернативное окружение, обычно, это jail или установленная система, смонтированная в месте, отличном от /. На самом деле порт устанавливается в DESTDIR/PREFIX и регистрируется в базе данных пакетов в DESTDIR/var/db/pkg. Поскольку управление DESTDIR производится автоматически инфраструктурой портов с помощью chroot(8), вам не нужны никакие изменения или проявление особой осторожности при написании портов, совместымых с DESTDIR.
Значение переменной PREFIX будет установлено в LOCALBASE (по умолчанию /usr/local). Если задана переменная USE_LINUX_PREFIX, то PREFIX примет значение LINUXBASE (по умолчанию /compat/linux).
Избегание явно прописываемых путей /usr/local в исходном коде сделает порт гораздо более гибким и способным удовлетворить потребности других серверов. Часто этого можно добиться простой заменой строк /usr/local в различных файлах Makefile внутри порта на ${PREFIX}. Эта переменная автоматически передаётся далее на каждом этапе построения и установки.
Проверьте, что ваше приложение не устанавливает чего-либо в каталог /usr/local вместо PREFIX. Наличие явно указанных путей можно быстро проверить следующим образом:
% make clean; make package PREFIX=/var/tmp/`make -V PORTNAME`Если что-то было установлено за пределами PREFIX, то процесс создания пакета сообщит об отсутствии файлов.
Это также стоит проверить с использованием поддержки каталога сборки (смотрите Staging):
% make stage && make check-plist && make stage-qa && make packagecheck-plistпроверяет отсутствующие в plist файлы и файлы в plist, которые не установлены портом.stage-qaпроверяет наличие распространённых проблем, таких как неправильный шебанг (интерпретаторная строка в первой строке скрипта), символьные ссылки, указывающие за пределы stage-директории,файлы с setuid битом и библиотеки с отладочной информацией…
Эти тесты не обнаружат жёстко заданные пути в файлах порта, а также не проверят, что LOCALBASE используется корректно для ссылок на файлы из других портов. Временно установленный порт в /var/tmp/make -V PORTNAME должен быть протестирован на корректную работу, чтобы убедиться в отсутствии проблем с путями.
PREFIX не должен быть явно установлен в Makefile порта. Пользователи, устанавливающие порт, могут задать PREFIX в другом месте, и порт должен учитывать эту настройку.
Обращайтесь к программам и файлам из других портов с помощью упомянутых выше переменных, а не явных путей. Например, если порт требует, чтобы макрос PAGER содержал полный путь к less, не используйте явный путь /usr/local/bin/less. Вместо этого используйте ${LOCALBASE}:
-DPAGER=\"${LOCALBASE}/bin/less\"Путь с LOCALBASE с большей вероятностью продолжит работать, если системный администратор переместил всё дерево /usr/local в другое место.
Все эти тесты выполняются автоматически при запуске |
10.7. poudriere
Для контрибьютора портов poudriere является одним из самых важных и полезных инструментов для тестирования и сборки. Его основные возможности включают:
Массовая сборка всего дерева портов, определенных подмножеств дерева портов или отдельного порта с его зависимостями
Автоматическая упаковка результатов сборки
Генерация файлов журнала сборки для каждого порта
Предоставление подписанного репозитория pkg(8)
Тестирование сборки портов перед отправкой патча в трекер ошибок FreeBSD или внесением изменений в дерево портов
Тестирование успешных сборок портов с использованием различных параметров
Поскольку poudriere выполняет сборку в чистой среде jail(8) и использует возможности zfs(8), он имеет несколько преимуществ по сравнению с традиционным тестированием на основной системе:
Отсутствие загрязнения основной среды: никаких оставшихся файлов, случайных удалений или изменений существующих конфигурационных файлов.
Проверяет pkg-plist на наличие отсутствующих или лишних записей
Коммиттеры портов иногда запрашивают журнал poudriere вместе с отправкой патча, чтобы оценить, готов ли патч для интеграции в дерево портов
Также его настройка и использование довольно просты, он не имеет зависимостей и будет работать в любой поддерживаемой версии FreeBSD. В этом разделе показано, как установить, настроить и запустить poudriere в рамках обычного рабочего процесса разработчика портов.
Примеры в этом разделе показывают стандартную структуру файлов, принятую в FreeBSD. Внесите соответствующие изменения, если у вас используются другие настройки. Дерево портов, обозначаемое как ${PORTSDIR}, находится в /usr/ports. По умолчанию ${LOCALBASE} и ${PREFIX} указывают на /usr/local.
10.7.1. Установка poudriere
poudriere доступен в дереве портов в пакете ports-mgmt/poudriere. Его можно установить с помощью pkg(8) или из портов:
# pkg install poudriereили
# make -C /usr/ports/ports-mgmt/poudriere install cleanТакже существует версия poudriere в разработке, которая в конечном итоге станет следующим релизом. Она доступна в пакете:ports-mgmt/poudriere-devel[]. Эта версия используется для официальных сборок пакетов FreeBSD, поэтому она хорошо протестирована. В ней часто появляются новые интересные функции. Коммиттер портов захочет использовать версию в разработке, так как именно она используется в продакшене и содержит все новые функции, которые гарантируют, что всё будет работать идеально. Контрибьютору не обязательно нужны эти функции, так как наиболее важные исправления переносятся в выпущенную версию. Основная причина использования версии в разработке для сборки официальных пакетов заключается в её скорости — она позволяет сократить время полной сборки с 18 до 17 часов при использовании высокопроизводительного сервера с 32 CPU и 128 ГБ оперативной памяти. Эти оптимизации не будут столь значимы при сборке портов на настольном компьютере.
10.7.2. Настройка poudriere
Порт устанавливает файл конфигурации по умолчанию, /usr/local/etc/poudriere.conf. Каждый параметр описан в этом файле конфигурации.
Вот минимальный пример конфигурационного файла:
ZPOOL=zroot BASEFS=/usr/local/poudriere DISTFILES_CACHE=/usr/ports/distfiles RESOLV_CONF=/etc/resolv.conf
ZPOOLИмя пула хранения ZFS, который будет использовать poudriere. Должно быть указано в выводе команды
zpool status.BASEFSКорневая точка монтирования файловых систем poudriere. Эта запись приведет к тому, что poudriere смонтирует
tank/poudriereв/poudriere.DISTFILES_CACHEОпределяет, где хранятся distfiles. В этом примере poudriere и хост используют общий каталог для хранения distfiles. Это позволяет избежать загрузки tарболов, которые уже присутствуют в системе. Пожалуйста, создайте этот каталог, если он ещё не существует, чтобы poudriere мог его найти.
RESOLV_CONFИспользуйте файл /etc/resolv.conf хоста внутри клеток для DNS. Это необходимо, чтобы клетки могли разрешать URL-адреса distfiles при загрузке. Это не требуется при использовании прокси. Обратитесь к файлу конфигурации по умолчанию для настройки прокси.
10.7.3. Создание клеток poudriere
Создайте базовые клетки, которые poudriere будет использовать для сборки:
# poudriere jail -c -j 131Ramd64 -v 13.1-RELEASE -a amd64Загрузите 13.1-RELEASE для amd64 с FTP-сервера, указанного в FREEBSD_HOST в poudriere.conf, создайте ZFS-файловую систему tank/poudriere/jails/131Ramd64, смонтируйте её в /poudriere/jails/131Ramd64 и распакуйте тарболлы 13.1-RELEASE в эту файловую систему.
# poudriere jail -c -j 12i386 -v stable/12 -a i386 -m git+httpsСоздайте tank/poudriere/jails/12i386, смонтируйте его на /poudriere/jails/12i386, затем извлеките верхушку ветки Git FreeBSD-12-STABLE из GIT_HOST в poudriere.conf или по умолчанию git.freebsd.org в /poudriere/jails/12i386/usr/src, после чего выполните buildworld и установите его в /poudriere/jails/12i386.
Хотя возможно собрать более новую версию FreeBSD на старой версии, в большинстве случаев она не запустится. Например, если требуется клетка на |
Для создания клетки poudriere для Для запуска клетки |
Список клеток, известных poudriere, можно вывести с помощью команды poudriere jail -l:
# poudriere jail -l
JAILNAME VERSION ARCH METHOD
131Ramd64 13.1-RELEASE amd64 ftp
12i386 12.4-STABLE i386 git+https10.7.4. Обновление клеток poudriere
Управление обновлениями очень простое. Команда:
# poudriere jail -u -j JAILNAMEобновляет указанную клетку до последней доступной версии. Для релизов FreeBSD обновление до последнего уровня исправлений с помощью freebsd-update(8). Для версий FreeBSD, собранных из исходников, обновление до последней ревизии git в ветке.
Для клеток, использующих метод |
10.7.5. Настройка деревьев портов для использования с poudriere
Существует несколько способов использования деревьев портов в poudriere. Наиболее простой способ — позволить poudriere создать для себя дерево портов по умолчанию, используя Git:
# poudriere ports -c -m git+https -B mainЭти команды создают tank/poudriere/ports/default, монтируют его в /poudriere/ports/default и заполняют с помощью Git. После этого он включается в список известных деревьев портов:
# poudriere ports -l
PORTSTREE METHOD TIMESTAMP PATH
default git+https 2020-07-20 04:23:56 /poudriere/ports/defaultОбратите внимание, что дерево портов "default" является особым. Каждая из команд сборки, объяснённых далее, будет неявно использовать это дерево портов, если явно не указано иное. Чтобы использовать другое дерево, добавьте |
Лучший способ работы с локальными изменениями для разработчика портов — использовать Git. Как и при создании клеток, можно использовать другой метод для создания дерева портов. Чтобы добавить дополнительное дерево портов для тестирования локальных изменений и разработки портов, предпочтительно использовать клонирование дерева через git (как описано выше).
10.7.6. Использование управляемых вручную деревьев портов с помощью poudriere
В зависимости от рабочего процесса может быть крайне полезно использовать деревья портов, которые поддерживаются вручную. Например, если существует локальная копия дерева портов в /work/ports, укажите poudriere на это расположение:
# poudriere ports -c -m null -M /work/ports -p developmentЭто будет указано в таблице известных деревьев:
# poudriere ports -l
PORTSTREE METHOD TIMESTAMP PATH
development null 2020-07-20 05:06:33 /work/portsТире или |
10.7.7. Обновление деревьев портов poudriere
Так же просто, как с клетками, описанными ранее:
# poudriere ports -u -p PORTSTREEОбновит указанное PORTSTREE, дерево, указанное в выводе команды poudriere -l, до последней доступной ревизии на официальных серверах.
Деревья портов без метода, см. Использование вручную управляемых деревьев портов с помощью poudriere, не могут быть обновлены таким образом и должны обновляться вручную сопровождающим портов. |
10.7.8. Тестирование портов
После настройки клеток и деревьев портов можно проверить результат изменений, внесенных участником в дерево портов.
Например, локальные изменения в порте www/firefox, расположенном в /work/ports/www/firefox, можно протестировать в ранее созданной клетке 13.1-RELEASE:
# poudriere testport -j 131Ramd64 -p development -o www/firefoxЭто соберет все зависимости Firefox. Если зависимость уже была собрана ранее и остается актуальной, будет установлен готовый пакет. Если для зависимости нет актуального пакета, он будет собран с параметрами по умолчанию в клетке. Затем будет собран сам Firefox.
Полная сборка каждого порта записывается в /poudriere/data/logs/bulk/131Ri386-development/build-time/logs.
Имя каталога 131Ri386-development формируется из аргументов -j и -p соответственно. Для удобства также поддерживается символическая ссылка /poudriere/data/logs/bulk/131Ri386-development/latest. Эта ссылка указывает на последний каталог времени сборки. Также в этом каталоге находится файл index.html, который позволяет наблюдать за процессом сборки через веб-браузер.
По умолчанию poudriere очищает клетки и оставляет файлы журналов в указанных выше каталогах. Для упрощения анализа клетки можно оставить запущенными после сборки, добавив -i к testport:
# poudriere testport -j 131Ramd64 -p development -i -o www/firefoxПосле завершения сборки, независимо от того, была ли она успешной, в клетке предоставляется оболочка. Эта оболочка используется для дальнейшего исследования. Можно указать poudriere оставить клетку запущенной после завершения сборки с помощью -I. poudriere покажет команду для выполнения, когда клетка больше не нужна. Затем можно использовать jexec(8) для входа в неё:
# poudriere testport -j 131Ramd64 -p development -I -o www/firefox
[...]
====>> Installing local Pkg repository to /usr/local/etc/pkg/repos
====>> Leaving jail 131Ramd64-development-n running, mounted at /poudriere/data/.m/131Ramd64-development/ref for interactive run testing
====>> To enter jail: jexec 131Ramd64-development-n env -i TERM=$TERM /usr/bin/login -fp root
====>> To stop jail: poudriere jail -k -j 131Ramd64 -p development
# jexec 131Ramd64-development-n env -i TERM=$TERM /usr/bin/login -fp root
# [do some stuff in the jail]
# exit
# poudriere jail -k -j 131Ramd64 -p development
====>> Umounting file systemsНеотъемлемой частью инфраструктуры сборки портов FreeBSD является возможность настройки портов под личные предпочтения с помощью опций. Их также можно тестировать с помощью poudriere. Добавление опции -c:
# poudriere testport -j 131Ramd64 -c -o www/firefoxПредставляет диалог настройки порта перед его сборкой. Порты, указанные после -o в формате категория/имя_порта, будут использовать указанные опции, все зависимости будут использовать опции по умолчанию. Тестирование зависимых портов с нестандартными опциями может быть выполнено с использованием наборов, см. Использование наборов.
При тестировании портов, где файл pkg-plist изменяется во время сборки в зависимости от выбранных опций, рекомендуется выполнить тестовый запуск со всеми выбранными опциями и один без выбранных опций. |
10.7.9. Использование наборов
Для всех действий, связанных со сборкой, можно указать так называемый набор с помощью -z имя_набора. Набор относится к полностью независимой сборке. Это позволяет, например, использовать testport с нестандартными параметрами для зависимых портов.
Для использования наборов poudriere ожидает, что будет использована структура каталогов, аналогичная PORT_DBDIR, по умолчанию /var/db/ports, в его конфигурационной директории. Этот каталог затем монтируется с помощью nullfs(5) в клетки, где собираются порты и их зависимости. Обычно подходящую начальную точку можно получить, рекурсивно скопировав существующий PORT_DBDIR в /usr/local/etc/poudriere.d/jailname-portname-setname-options. Это подробно описано в poudriere(8). Например, для тестирования www/firefox в определённом наборе с именем devset, добавьте параметр -z devset к команде testport:
# poudriere testport -j 131Ramd64 -p development -z devset -o www/firefoxЭто проверит наличие этих каталогов в следующем порядке:
/usr/local/etc/poudriere.d/131Ramd64-development-devset-options
/usr/local/etc/poudriere.d/131Ramd64-devset-options
/usr/local/etc/poudriere.d/131Ramd64-development-options
/usr/local/etc/poudriere.d/devset-options
/usr/local/etc/poudriere.d/development-options
/usr/local/etc/poudriere.d/131Ramd64-options
/usr/local/etc/poudriere.d/options
Из этого списка poudriere nullfs(5) монтирует первое существующее дерево каталогов в директорию /var/db/ports сборных клеток. Таким образом, все пользовательские настройки используются для всех портов во время этого запуска testport.
После предоставления структуры каталогов для набора можно изменить параметры для конкретного порта. Например:
# poudriere options -c www/firefox -z devsetОтображается диалог настройки www/firefox, где можно редактировать параметры. Выбранные параметры сохраняются в набор devset.
poudriere очень гибок в настройке опций. poudriere можно настроить для конкретных клеток, деревьев портов и для нескольких портов одной командой. Подробности см. в poudriere(8). |
10.7.10. Предоставление пользовательского файла make.conf
Подобно использованию наборов, poudriere также использует пользовательский make.conf, если он предоставлен. Для этого не требуется специального аргумента командной строки. Вместо этого poudriere ищет существующие файлы, соответствующие схеме именования, производной от командной строки. Например:
# poudriere testport -j 131Ramd64 -p development -z devset -o www/firefoxзаставляет poudriere проверять наличие этих файлов в следующем порядке:
/usr/local/etc/poudriere.d/make.conf
/usr/local/etc/poudriere.d/devset-make.conf
/usr/local/etc/poudriere.d/development-make.conf
/usr/local/etc/poudriere.d/131Ramd64-make.conf
/usr/local/etc/poudriere.d/131Ramd64-development-make.conf
/usr/local/etc/poudriere.d/131Ramd64-devset-make.conf
/usr/local/etc/poudriere.d/131Ramd64-development-devset-make.conf
В отличие от наборов, все найденные файлы будут добавлены, в указанном порядке, в один make.conf внутри клеток сборки. Таким образом, можно задать общие переменные make, предназначенные для влияния на все сборки, в файле /usr/local/etc/poudriere.d/make.conf. Специальные переменные, предназначенные только для определённых клеток или наборов, можно задать в специализированных файлах make.conf, например, в /usr/local/etc/poudriere.d/131Ramd64-development-devset-make.conf.
Для сборки набора с нестандартной версией Perl, например, 5.20, используя набор с именем perl5-20, создайте файл perl5-20-make.conf со следующей строкой:
DEFAULT_VERSIONS+= perl=5.20
10.7.11. Удаление ненужных файлов дистрибутива
poudriere имеет встроенный механизм для удаления устаревших файлов дистрибутива, которые больше не используются ни одним портом данного дерева. Команда
# poudriere distclean -p portstreeбудет сканировать папку файлов дистрибутива, DISTFILES_CACHE в poudriere.conf, сравнивая ее с деревом портов, указанным аргументом -p portstree, и запрашивать подтверждение на удаление этих файлов дистрибутива. Чтобы пропустить запрос и удалить все неиспользуемые файлы без подтверждения, можно добавить аргумент -y:
# poudriere distclean -p portstree -y10.8. Отладка портов
Иногда что-то идёт не так, и порт не работает во время выполнения. Фреймворк предоставляет некоторые средства для отладки портов. Эти вспомогательные инструменты ограничены, поскольку способ отладки порта во многом зависит от используемой технологии. Следующие переменные помогают в отладке портов:
WITH_DEBUG. Если установлено, порты собираются с отладочными символами.WITH_DEBUG_PORTS. Указывает список портов, которые должны собираться с установленнымWITH_DEBUG.DEBUG_FLAGS. Используется для указания дополнительных флагов дляCFLAGS. По умолчанию-g.
Когда WITH_DEBUG установлен, глобально или для списка портов, результирующие бинарные файлы не лишаются символов.
Эти переменные могут быть указаны в make.conf или в командной строке:
# cd category/port && make -DWITH_DEBUG DEBUG_FLAGSS="-g -O0"Если порт собирается с использованием ports-mgmt/poudriere, отладочные переменные должны быть указаны в make.conf poudriere, а не в /etc/make.conf. Подробности см. в документации ports-mgmt/poudriere. |
Пожалуйста, обратитесь к отладочной информации в Руководстве разработчика для получения более подробной информации о доступных инструментах отладки.
Глава 11. Обновление отдельного порта
Когда порт не является самой последней версией, доступной от авторов, обновите локальную рабочую копию /usr/ports. Возможно, порт уже был обновлён до новой версии.
При работе с большим количеством портов, вероятно, будет проще использовать Git для поддержания всей коллекции портов в актуальном состоянии, как описано в Использование коллекции портов. Это также позволит отслеживать все зависимости портов.
Следующий шаг — проверить, есть ли уже ожидающее обновление. Для этого есть два варианта. Доступен поиск в Сообщения о проблемах (PR) или база данных ошибок FreeBSD. Выберите Ports & Packages в меню множественного выбора Product и введите название порта в поле Summary.
Если таких отложенных PR не существует, то на следующем этапе следует послать сообщение электронной почты человеку, поддерживающему порт, который выдаётся по команде make maintainer. Этот человек может уже работать над обновлением, или иметь причину не обновлять порт прямо сейчас (например, из-за проблем со стабильностью функционирования новой версии); вам нет нужды дублировать их работу. Заметьте, что неподдерживаемые порты перечисляются с адресом сопровождающего ports@FreeBSD.org, который является всего лишь адресом общего списка рассылки, так что отправка туда сообщений, скорее всего, в данном случае не поможет.
Если сопровождающий просит вас выполнить обновление, либо сопровождающий отсутствует, то у вас появляется шанс помочь FreeBSD, приготовив обновление самим! Пожалуйста, делайте это с использованием команды diff(1) в основной системе.
Чтобы создать подходящий diff для одного патча, скопируйте файл, который нужно пропатчить, в something.orig, сохраните ваши изменения в something, а затем создайте ваше патч:
% diff -u something.orig something > something.diffВ противном случае используйте метод git diff (Использование Git для создания патчей) или скопируйте содержимое порта в совершенно другой каталог и используйте результат рекурсивного вывода diff(1) для новых и старых каталогов портов (например, если изменённый каталог порта называется superedit, а исходный находится в нашем дереве как superedit.bak, сохраните результат выполнения diff -ruN superedit.bak superedit). Подойдёт как унифицированный, так и контекстный diff, но коммиттеры портов обычно предпочитают унифицированные diff. Обратите внимание на использование опции -N — это общепринятый способ заставить diff корректно обрабатывать случаи добавления новых файлов или удаления старых. Перед отправкой diff, пожалуйста, проверьте вывод, чтобы убедиться, что все изменения имеют смысл. (В частности, не забудьте сначала очистить рабочие каталоги с помощью make clean).
Если некоторые файлы были добавлены, скопированы, перемещены или удалены, добавьте эту информацию в отчёт о проблеме, чтобы коммиттер, принимающий патч, знал, какие команды git(1) нужно выполнить. |
Для упрощения стандартных операций с файлами исправлений используйте make makepatch, как описано в Применение партчей. Существуют и другие инструменты, например /usr/ports/Tools/scripts/patchtool.py. Перед его использованием прочтите /usr/ports/Tools/scripts/README.patchtool.
Если порт никем не поддерживается, а вы активно его используете, пожалуйста, подумайте над тем, чтобы добровольно стать его сопровождающим. Во FreeBSD имеется более 4000 портов без поддержки, и это как раз та область, где всегда нужны добровольцы. (Детальное описание обязанностей сопровождающего можно найти в разделе Руководства Разработчика.)
Для отправки diff используйте форму отправки багов (продукт Ports & Packages, компонент Individual Port(s)). Всегда указывайте категорию с именем порта, за которой следует двоеточие и краткое описание проблемы. Примеры: категория/имя_порта: добавить опцию FOO; категория/имя_порта: Обновление до X.Y. Упоминайте в сообщении все добавленные или удалённые файлы, так как они должны быть явно указаны в git(1) при выполнении коммита. Не сжимайте и не кодируйте diff.
Прежде чем отправить сообщение об ошибке, ознакомьтесь с разделом Написание отчета о проблеме в статье "Отчеты о проблемах". В нем содержится гораздо больше информации о том, как составлять полезные отчеты о проблемах.
Если обновление вызвано соображениями информационной безопасности или наличием серьёзных ошибок в имеющемся порте, пожалуйста, оповестите Группа Менеджеров Дерева Портов FreeBSD <portmgr@FreeBSD.org> о необходимости немедленного перепостроения и повторного распространения пакета данного порта. В противном случае ничего не подозревающие пользователи |
Пожалуйста, используйте diff(1) или |
Теперь, когда вы проделали всё это, прочитайте о том, как поддерживать актуальное состояние, в Актуализация.
11.1. Использование Git для создания патчей
Когда это возможно, пожалуйста, предоставляйте патч или diff с помощью git(1). Их проще обрабатывать, чем различия между «новым и старым» каталогом. Так легче увидеть, что изменилось, и обновить diff, если что-то было изменено в Коллекции портов с момента начала работы над ней, или если коммиттер просит что-то исправить. Кроме того, патч, созданный с помощью git-format-patch(1) или git-diff(1), можно легко применить с помощью git-am(1) или git-apply(1), что сэкономит время коммиттера. Наконец, git-патч, созданный git-format-patch(1), включает информацию об авторе и сообщения коммитов. Они будут записаны в лог репозитория, и это рекомендуемый способ отправки ваших изменений.
% git clone https://git.FreeBSD.org/ports.git ~/my_wrkdir (1) (2)
% cd ~/my_wrkdir| 1 | Это может быть где угодно; место, в котором производится построение портов, не привязано к /usr/ports/. |
| 2 | git.FreeBSD.org — это публичный Git-сервер FreeBSD. Подробнее см. в таблице URL-репозиториев FreeBSD Git. |
Находясь в каталоге порта, внесите необходимые изменения. Если требуется добавить, переместить или удалить файл, используйте git для отслеживания этих изменений:
% git add new_file
% git mv old_name new_name
% git rm deleted_fileУбедитесь, что проверили порт, используя контрольный список в Тестирование порта и Проверка порта с помощью portlint.
Также обновите ссылку на контрольную сумму в distinfo с помощью make makesum.
Прежде чем создавать патч, загрузите последнюю версию репозитория и перебазируйте изменения поверх неё. Внимательно следите за выводом и следуйте ему. Если какие-либо файлы не удалось перебазировать, это означает, что исходные файлы изменились во время вашего редактирования, и конфликты необходимо разрешить вручную.
% git fetch origin main
% git rebase origin/mainПроверьте изменения, подготовленные для исправления:
% git status
% git diff --stagedПоследний шаг — создать унифицированный diff или патч изменений:
Для создания патча с помощью git-format-patch(1):
% git checkout -b my_branch
% git commit
% git format-patch mainЭто создаст файл исправления с именем вида 0001-foo.patch. Это предпочтительный способ, так как он включает идентификацию автора, а также удобнее, когда вы делаете серию изменений, которые не должны объединяться вместе.
Или для создания унифицированного diff с помощью git-diff(1):
% git diff --staged > ../`make -VPKGNAME`.diffЭто создаст файл с различиями с именем вида foo-1.2.3.diff. Здесь foo заменяется на первую строку сообщения коммита, то есть на тему сообщения коммита.
После создания патча вы можете переключиться на основную ветку для начала других разработок.
% git checkout mainПосле принятия и слияния патча вы можете удалить локальную ветку разработки, если хотите:
% git branch -D my_branchЕсли файлы были добавлены, перемещены или удалены, укажите использованные команды git(1) |
Отправьте исправление, следуя рекомендациям по отправке отчетов о проблемах.
11.2. UPDATING и MOVED
11.2.1. /usr/ports/UPDATING
Если обновление порта требует специальных действий, таких как изменение конфигурационных файлов или запуск определённой программы, это должно быть задокументировано в данном файле. Формат записи в этом файле следующий:
YYYYMMDD: AFFECTS: users of portcategory/portname AUTHOR: Your name <Your email address> Special instructions
При включении точных инструкций для portmaster, portupgrade и/или pkg, убедитесь в правильности экранирования в shell. Например, не используйте: Как показано, команда будет работать только с bourne-оболочками. Вместо этого используйте форму, приведённую ниже, которая будет работать как с bourne-оболочкой, так и с c-оболочкой: |
Рекомендуется, чтобы строка AFFECTS содержала glob-выражение, соответствующее всем портам, затронутым записью, чтобы автоматизированные инструменты могли максимально легко её обработать. Если обновление касается всех существующих версий BIND 9, содержимое |
11.2.2. /usr/ports/MOVED
Этот файл используется для перечисления перемещённых или удалённых портов. Каждая строка в файле состоит из названия порта, места, куда порт был перемещён, даты и причины. Если порт был удалён, раздел с указанием места перемещения может быть оставлен пустым. Каждый раздел должен быть отделён символом | (вертикальная черта), например:
old name|new name (blank for deleted)|date of move|reason
Дата должна быть введена в формате ГГГГ-ММ-ДД. Новые записи добавляются в конец списка, чтобы сохранить его в хронологическом порядке, при этом самая старая запись находится в начале списка.
Если порт был удален, но затем восстановлен, удалите строку в этом файле, которая указывает, что он был удален.
Если порт был переименован, а затем переименован обратно в исходное имя, добавьте новую запись с промежуточным именем для старого имени и удалите старую запись, чтобы не создавать цикл.
Любые изменения должны быть проверены с помощью Если используется каталог портов, отличный от /usr/ports, следует указать: |
Глава 12. Безопасность
12.1. Почему безопасность так важна
Ошибки в программном обеспечении появляются случайно. Возможно, самые опасные из них те, что создают уязвимости безопасности. С технической точки зрения подобные уязвимости должны быть закрыты путем исправления вызывающих их ошибок. Тем не менее, политики обработки несущественных ошибок и уязвимостей очень различаются.
Обычная небольшая ошибка затрагивает только тех пользователей, которые задействуют некоторые комбинации настроек, активирующие эту ошибку. Разработчик в конечном счете выпустит патч, а зачтем новую версию программного обеспечения, свободного от ошибки, но большинство пользователей не посчитают нужным сразу же произвести обновление, поскольку эта ошибка никогда у них не проявлялась. Критическая ошибка, которая может приводить к потере данных, представляет серьезную проблему. Тем не менее, предусмотрительные пользователи знают, что большинство возможных происшествий, и среди них программные ошибки, скорее всего приводят к потере данных, поэтому они выполняют резервное копирование важных данных; дополнительно, критическая ошибка будет обнаружена очень скоро.
С уязвимостью безопасности всё иначе. Во-первых, она может сохраняться необнаруженной целые годы, потому что чаще всего не вызывает ошибок в работе. Во-вторых, компания злоумышленников может использовать ее для получения неавторизованного доступа к уязвимой системе, уничтожить или подменить важные данные; в худшем случае пользователь даже не заметит нанесенный урон. В-третьих, взлом уязвимой системы часто упрощает задачу проникновения атакующих в другие системы, которые не могут быть скомпрометированы иначе. Таким образом, устранение уязвимости как таковой недостаточно: следует разослать всем заинтересованным уведомления в наиболее понятной и исчерпывающей форме, что позволит оценить риск и предпринять подходящие меры.
12.2. Исправление уязвимостей безопасности
Что касается портов и пакетов, уязвимость безопасности изначально может появиться в исходном дистрибутиве или файлах порта. В первом случае, разработчик исходного программного обеспечения скорее всего сразу же выпустит патч или новую версию, и вам лишь понадобится сразу обновить порт в соответствии с исправлением автора. Если исправление по какой-то причине задерживается, вам следует либо пометить порт как FORBIDDEN, либо добавить в порт ваш собственный патч. В случае уязвимости порта просто исправьте этот порт как можно скорее. В любом случае нужно следовать стандартной процедуре отправки вашего изменения, если вы не обладаете правами на коммит изменения непосредственно в дерево портов.
Быть коммиттером портов недостаточно для коммита произвольного порта. Помните, что обычно у портов есть сопровождающие, мнение которых вы должны учитывать. |
Пожалуйста, убедитесь, что ревизия порта после закрытия уязвимости увеличена. Вот как пользователи, обновляющие установленные пакеты на постоянной основе, увидят, что им нужно запустить обновление. Кроме того, новый пакет будет собран и распространен через FTP и WWW зеркала, замещая уязвимый. Если в процессе исправления уязвимости не было изменено значение PORTVERSION, то должно быть увеличено значение PORTREVISION. Вам следует увеличить значение PORTREVISION после добавления в порт файла с патчем, но не когда вы обновили порт до последней версии программного обеспечения, попутно затронув при этом PORTVERSION. За дальнейшей информацией обращайтесь к соответствующему разделу.
12.3. Обеспечение сообщества информацией
12.3.1. База данных VuXML
Очень важным и первостепенным шагом при действии как можно раньше после раскрытия уязвимости является уведомление сообщества пользователей порта об опасности. Такие уведомления служат двум целям. Во-первых, в случае действительно серьезной угрозы, будет посоветовано применить мгновенное воздействие. Например, остановить затрагиваемый сетевой сервис или даже удалить порт целиком, пока уязвимость не будет устранена. Во-вторых, масса пользователей имеет тенденцию обновлять установленные пакеты только от случая к случаю. Из уведомления они узнают, что должны обновить пакет без промедления сразу же после появления исправленной версии.
Учитывая огромное число портов в дереве, невозможно по каждому случаю выпускать бюллетень безопасности без создания флуда и потери внимания сообщества к моменту появления действительно серьезных причин. Поэтому уязвимости безопасности, обнаруженные в портах, записываются в базу данных FreeBSD VuXML. Члены Команды Офицеров Безопасности также отслеживают её на предмет появления вопросов, требующих их вмешательства.
Если вы обладаете правами коммиттера, вы можете сам обновить базу данных VuXML. Так вы поможете Команде Офицеров Безопасности и своевременно пошлете ценную информацию сообществу. Тем не менее, если вы не являетесь коммиттером или верите, что нашли исключительно серьезную уязвимость, то не задумываясь свяжитесь с Командой Офицеров Безопасности напрямую как это описано на странице информационной безопасности FreeBSD.
База данных VuXML является документом XML. Его исходный файл vuln.xml содержится прямо внутри порта security/vuxml. Следовательно, полное имя пути к файлу будет PORTSDIR/security/vuxml/vuln.xml. Каждый раз, при обнаружении вами в порте уязвимости безопасности добавьте об этом запись в этот файл. Пока вы не знакомы с VuXML, лучшее, что вы можете сделать, это найти существующую запись, подпадающую под ваш случай, затем скопировать ее и использовать в качестве шаблона.
12.3.2. Короткое вступление в VuXML
В совокупности XML является очень сложным форматом, и его описание выходит далеко за рамки этой книги. Тем не менее, для достижения основного понимания структуры записи VuXML вам понадобится всего лишь понять теги. Имена тегов XML обрамляются в угловые скобки. Каждый открывающий <tag> должен иметь совпадающий закрывающий </tag>. Теги могут быть вложенными. При вложенности внутренние теги должны быть закрыты до закрытия внешних. Существует иерархия тегов, т.е. более сложные правила вкладывания тегов. Это похоже на HTML. Основное отличие в расширяемости XML, т.е. в определении собственных тегов. Из-за своей характерной структуры XML придает форму разрозненным данным. В частности, XML подходит для разметки описаний уязвимостей безопасности.
Теперь рассмотрим настоящую запись VuXML:
<vuln vid="f4bc80f4-da62-11d8-90ea-0004ac98a7b9"> (1)
<topic>Several vulnerabilities found in Foo</topic> (2)
<affects>
<package>
<name>foo</name> (3)
<name>foo-devel</name>
<name>ja-foo</name>
<range><ge>1.6</ge><lt>1.9</lt></range> (4)
<range><ge>2.*</ge><lt>2.4_1</lt></range>
<range><eq>3.0b1</eq></range>
</package>
<package>
<name>openfoo</name> (5)
<range><lt>1.10_7</lt></range> (6)
<range><ge>1.2,1</ge><lt>1.3_1,1</lt></range>
</package>
</affects>
<description>
<body xmlns="http://www.w3.org/1999/xhtml">
<p>J. Random Hacker reports:</p> (7)
<blockquote
cite="http://j.r.hacker.com/advisories/1">
<p>Several issues in the Foo software may be exploited
via carefully crafted QUUX requests. These requests will
permit the injection of Bar code, mumble theft, and the
readability of the Foo administrator account.</p>
</blockquote>
</body>
</description>
<references> (8)
<freebsdsa>SA-10:75.foo</freebsdsa> (9)
<freebsdpr>ports/987654</freebsdpr> (10)
<cvename>CVE-2023-48795</cvename> (11)
<certvu>740169</certvu> (12)
<uscertta>SA10-99A</uscertta> (13)
<mlist msgid="201075606@hacker.com">http://marc.theaimsgroup.com/?l=bugtraq&m=203886607825605</mlist> (14)
<url>http://j.r.hacker.com/advisories/1</url> (15)
</references>
<dates>
<discovery>2010-05-25</discovery> (16)
<entry>2010-07-13</entry> (17)
<modified>2010-09-17</modified> (18)
</dates>
</vuln>Имена тегов должны быть самодокументируемыми, чтобы мы сфокусировались только на полях, нужных нам для заполнения:
| 1 | Это тег верхнего уровня записи VuXML. У него есть обязательный атрибут vid, указывающий на универсальный уникальный идентификатор (UUID) для этой записи (в кавычках). Вы должны формировать UUID для каждой новой записи VuXML (и не забудьте заменить ее для шаблона UUID, если вы не пишете запись с нуля). Для получения VuXML UUID вы можете использовать uuidgen(1). |
| 2 | Однострочное описание найденной проблемы. |
| 3 | Здесь перечислены имена затронутых пакетов. Может быть дано несколько имен, поскольку некоторые пакеты могут быть основаны на одном главном порте или программном продукте. Сюда можно включить стабильную ветвь и ветвь разработки, локализованные версии и подчиненные порты, зависящие от различного выбора важных вариантов конфигурации, указанных на этапе построения. |
| 4 | Затронутые версии пакета(ов) указаны там как один или несколько диапазонов с использованием комбинации элементов <lt>, <le>, <eq>, <ge> и <gt>. Убедитесь, что указанные диапазоны версий не перекрываются.В спецификации диапазона * (звёздочка) обозначает наименьший номер версии. В частности, 2.* меньше, чем 2.a. Таким образом, звёздочка может использоваться в диапазоне для соответствия всем возможным версиям alpha, beta и RC. Например, <ge>2.</ge><lt>3.</lt> выборочно соответствует каждой версии 2.x, тогда как <ge>2.0</ge><lt>3.0</lt> — нет, поскольку последний пропускает 2.r3 и включает 3.b.Приведённый пример указывает, что затронуты версии 1.6 и выше, но не включая 1.9, версии 2.x до 2.4_1 и версия 3.0b1. |
| 5 | Некоторые связанные группы пакетов (в конечном счете, порты) могут быть указаны в разделе <affected>. Это можно использовать, если некоторые программные продукты (скажем, FooBar, FreeBar and OpenBar) являются производными от общей кодовой базы и всё еще совместно используют её ошибки и уязвимости. Имейте в виду отличие от перечисления множественных имён в одном разделе <package>. |
| 6 | Диапазоны версий должны учитывать PORTEPOCH и PORTREVISION, если это применимо. Пожалуйста, помните, что в соответствии с правилами сравнения строк версия с ненулевым значением PORTEPOCH выше, чем любая версия без PORTEPOCH, например, 3.0,1 выше, чем 3.1 или даже 8.9. |
| 7 | Сводная информация о проблеме. В этом поле используется XHTML. По крайней мере, должны быть обрамляющие <p> и </p>. Может быть использована более сложная разметка, но только в целях аккуратности и ясности: без эстетства, пожалуйста. |
| 8 | Этот раздел содержит ссылки на имеющие отношение документы. Приветствуется как можно большее количество ссылок. |
| 9 | Это бюллетень безопасности FreeBSD. |
| 10 | Это сообщение об ошибке FreeBSD. |
| 11 | Идентификатор MITRE CVE. |
| 12 | Это SecurityFocus Bug ID. |
| 13 | Бюллетень безопасности US-CERT. |
| 14 | URL к архивному сообщению в списке рассылки. Атрибут msgid является необязательным и может указывать на message ID сообщения. |
| 15 | Это общий URL. Используйте его только если ни одна из других категорий ссылок не подходит. |
| 16 | Это дата, когда проблема была раскрыта (ГГГГ-ММ-ДД). |
| 17 | Это дата добавления записи (ГГГГ-ММ-ДД). |
| 18 | Это дата, когда любая информация в записи была последний раз изменена (ГГГГ-ММ-ДД). Новые записи не должны включать это поле. Добавьте его при редактировании существующей записи. |
12.3.3. Тестирование ваших изменений в базе данных VuXML
Этот пример описывает новую запись об уязвимости в пакете dropbear, которая была исправлена в версии dropbear-2013.59.
В качестве предварительного условия установите свежую версию порта security/vuxml.
Сначала проверьте, есть ли уже запись об этой уязвимости. Если бы такая запись существовала, она соответствовала бы предыдущей версии пакета 2013.58:
% pkg audit dropbear-2013.58Если запись не найдена, добавьте новую запись для этой уязвимости.
% cd ${PORTSDIR}/security/vuxml
% make newentryЕсли уязвимость имеет идентификатор MITRE CVE, можно использовать следующую команду:
% cd ${PORTSDIR}/security/vuxml
% make newentry CVE_ID=CVE-YYYY-XXXXXгде CVE-YYYYY-XXXX является действительным идентификатором CVE.
Если уязвимость относится к FreeBSD Security Advisory, вместо этого можно использовать следующую команду:
% cd ${PORTSDIR}/security/vuxml
% make newentry SA_ID=FreeBSD-SA-YY-XXXXXX.ascгде FreeBSD-SA-YY-XXXXXX.asc является опубликованным FreeBSD Security Advisory.
Проверьте его синтаксис и форматирование:
% make validateПредыдущая команда создает файл vuln-flat.xml. Его также можно создать с помощью:
% make vuln-flat.xmlДолжен быть установлен хотя бы один из следующих пакетов: textproc/libxml2, textproc/jade. |
Проверьте, что раздел <affected> записи соответствует правильным пакетам:
% pkg audit -f ${PORTSDIR}/security/vuxml/vuln-flat.xml dropbear-2013.58Убедитесь, что запись не создает ложных совпадений в выводе.
Теперь проверьте, соответствуют ли записи правильные версии пакетов:
% pkg audit -f ${PORTSDIR}/security/vuxml/vuln-flat.xml dropbear-2013.58 dropbear-2013.59
dropbear-2012.58 is vulnerable:
dropbear -- exposure of sensitive information, DoS
CVE: CVE-2013-4434
CVE: CVE-2013-4421
WWW: https://portaudit.FreeBSD.org/8c9b48d1-3715-11e3-a624-00262d8b701d.html
1 problem(s) in the installed packages found.Предыдущая версия совпадает, а последняя — нет.
12.3.4. Контрольный список для новой записи в VuXML
Проверьте название порта. Иногда имя проекта в вышестоящем репозитории не полностью совпадает с именем порта.
Добавить все флейворы. Если у порта есть варианты, все имена пакетов должны быть добавлены в запись как
<package>. Используйте следующий скрипт для генерации всех имен пакетов с вариантами:% for flavor in $(make -V FLAVORS); do FLAVOR="${flavor}" make -VPKGNAME;doneПроверить, имеет ли порт
PORTEPOCH. Приведённый выше фрагмент скрипта помогает в этом. Если порт используетPORTEPOCH, обязательно добавить его в тег<range>.Перепроверьте диапазоны. В случае диапазонов, ограниченных с обеих сторон, убедитесь, что элементы
<ge>и<lt>находятся внутри одного тега<range>. В противном случае запись может определить перекрывающийся диапазон.Проверка производных версий. Если в вышестоящем проекте обнаружена уязвимость, проверьте, затронуты ли также производные или форки проекта, включённые в дерево портов. Например, если уязвимость обнаружена в www/firefox, оцените, есть ли такая же уязвимость в производных, таких как www/librewolf, www/waterfox или других подобных проектах. Включите все затронутые производные в запись VuXML, чтобы пользователи этих портов были проинформированы. Также проверьте наличие Linux-версий этого порта в дереве. Например, уязвимости в databases/sqlite3 скорее всего затрагивают и пакеты вроде databases/linux-c7-sqlite3.
Не делайте коммит записи, не запустив сначала
make validate.
Глава 13. Что делать нужно, и что делать нельзя
13.1. Введение
Вот список часто встречающихся действий, которые нужно и которые нельзя делать во время процесса портирования. Проверьте порт по этому списку, и также проверьте порты в базе сообщений PR, которые присланы другими людьми. Присылайте любые комментарии о портах, которые вы проверили, так, как это описано в статье о Сообщениях об ошибках и общих замечаниях. Проверка портов в базе сообщений PR позволит нам быстрее коммиттить их и удостовериться, что вы знаете, что делаете.
13.2. WRKDIR
Не пишите ничего в файлы вне каталога WRKDIR. Каталог WRKDIR является единственным местом, которое гарантированно будет доступно для записи во время построения порта (обратитесь к главе об установке портов с CDROM за примером построения портов из дерева, доступного только для чтения). Если вам нужно изменить какой-либо из файлов pkg-*, сделайте это, переопределив переменную, но не перезаписывая их.
13.3. WRKDIRPREFIX
Добейтесь того, чтобы ваш порт принимал во внимание значение переменной WRKDIRPREFIX. Большинство портов об этом не заботятся. В частности, если вы обращаетесь к каталогу WRKDIR другого порта, заметьте, что его правильным местоположением является WRKDIRPREFIXPORTSDIR/subdir/name/work, а не PORTSDIR/subdir/work или .CURDIR/../../subdir/name/work мли что-то подобное. Кроме того, если вы сами задаете WRKDIR, то должны поставить перед ним знак ${WRKDIRPREFIX}${.CURDIR}.
13.4. Различение операционных систем и версий ОС
Вы можете встретиться с кодом, который требует модификаций или условной компиляции в зависимости от того, с какой версией FreeBSD Unix он работает. Предпочтительным способом отделения кода для версий FreeBSD является использование макросов __FreeBSD_version и __FreeBSD__, определённых в sys/param.h. Если этот файл не подключен, добавьте код
#include <sys/param.h>
в нужном месте файла .c.
__FreeBSD__ определён во всех версиях FreeBSD в качестве старшего номера версии системы. Например, в FreeBSD 9.x __FreeBSD__ определён со значением 9.
#if __FreeBSD__ >= 9 # if __FreeBSD_version >= 901000 /* 9.1+ release specific code here */ # endif #endif
Полный список значений __FreeBSD_version доступен в Значения __FreeBSD_version.
13.5. Написание чего-либо после bsd.port.mk
Не пишите ничего после строки .include <bsd.port.mk>. Этой строки можно избежать, включив в где-то в середину вашего файла Makefile файл bsd.port.pre.mk, и файл bsd.port.post.mk в конец.
Вам нужно включить либо пару файлов bsd.port.pre.mk/bsd.port.post.mk, либо только bsd.port.mk; не используйте оба этих метода одновременно. |
В файле bsd.port.pre.mk определяются лишь несколько переменных, которые могут быть использованы в тестах из файла Makefile, в файле bsd.port.post.mk заданы остальные.
Вот некоторые важные переменные, определенные в файле bsd.port.pre.mk (это не полный список, для выяснения полного списка прочтите, пожалуйста, сам файл bsd.port.mk).
| Переменная | Описание |
|---|---|
| Архитектура машины в виде, получаемом по команде |
| Тип операционной системы, получаемый по команде |
| Версия релиза операционной системы (например, |
| Версия операционной системы в виде числа, та же, что и |
| Корень дерева "local" (например, |
| Куда, собственно, устанавливается порт (обратитесь к подробной информации о |
Если вы задаете переменную |
Вот несколько примеров того, что вы можете написать после bsd.port.pre.mk:
# no need to compile lang/perl5 if perl5 is already in system
.if ${OSVERSION} > 300003
BROKEN= perl is in system
.endifВы не забываете об использовании табуляции вместо пробелов после BROKEN=.
13.6. Использование выражения exec в сценариях обёртках
Если порт устанавливает сценарий на языке shell, который служит для запуска другой программы, и если запуск этой программы является последним действием сценария, убедитесь, что запуск программы производится с использованием выражения exec, например:
#!/bin/sh exec %%LOCALBASE%%/bin/java -jar %%DATADIR%%/foo.jar "$@"
Выражение exec заменяет процесс сценария на указанную программу. Если exec опущен, то процесс сценария во время работы программы остается в памяти, бесполезно потребляя системные ресурсы.
13.7. Поступайте разумно
Файл Makefile должен выполнять действия просто и небеспричинно. Если вы можете сделать что-то на несколько строк короче или более читабельно, сделайте это. В качестве примеров можно привести использование конструкций .if утилиты make вместо соответствующей конструкции if командного процессора, ненужность переопределения цели do-extract при возможности переопределения EXTRACT* и использование GNU_CONFIGURE вместо CONFIGURE_ARGS += --prefix=${PREFIX}.
Если вы обнаружите, что для выполнения чего-то приходится писать много нового кода, то, пожалуйста, просмотрите файл bsd.port.mk на предмет того, не содержит ли он решение именно вашей проблемы. Хотя его трудно читать, имеется много проблем, выглядящих сложными, для которых файл bsd.port.mk уже содержит быстрое решение.
13.8. Относитесь внимательно как к CC, так и CXX
Порт должен принимать во внимание как переменную CC, так и CXX. Под этим мы подразумеваем, что порт ни в коем случае не должен устанавливать значения этих переменных, переопределяя имеющиеся значения; вместо этого можно добавлять нужные значения к уже имеющимся. Это связано с тем, что параметры построения, относящиеся ко всем портам, могут быть заданы глобально.
Если порт не учитывает значения этих переменных, добавьте строку NO_PACKAGE=ignores either cc or cxx в файл Makefile.
Далее следует пример файла Makefile, использующего как переменную CC, так и CXX. Обратите внимание на использование символов ?=:
CC?= gcc
CXX?= g++
Вот пример, в котором не принимаются во внимание ни CC, ни CXX:
CC= gcc
CXX= g++
В системах FreeBSD обе переменные CC и CXX могут быть определены в файле /etc/make.conf. В первом примере задаётся значение, если оно ранее не было определено в /etc/make.conf, что сохраняет любые определения, данные на уровне системы в целом. Второй пример переопределяет всё, что было задано ранее.
13.9. Относитесь внимательно к CFLAGS
Порт должен учитывать переменную CFLAGS. Под этим мы подразумеваем, что порт ни в коем случае не должен устанавливать значения этой переменной, переопределяя имеющиеся значения; вместо этого можно добавлять нужные значения к уже имеющимся. Это связано с тем, что параметры построения, относящиеся ко всем портам, могут быть заданы глобально.
Если порт не учитывает значения этой переменной, добавьте строку NO_PACKAGE=ignores cflags в файл Makefile.
Далее следует пример файла Makefile, использующего переменную CFLAGS. Обратите внимание на использование символов +=:
CFLAGS+= -Wall -Werror
А вот пример, в котором не учитывается значение переменной CFLAGS:
CFLAGS= -Wall -Werror
В системе FreeBSD переменная CFLAGS определена в файле /etc/make.conf. В первом примере к переменной CFLAGS добавляются дополнительные флаги, при этом сохраняются все определения, данные ранее на уровне системы. Во втором примере всё, что было задано ранее, игнорируется.
Из сторонних файлов Makefile следует удалить флаги оптимизации. Общесистемные флаги оптимизации находятся в системной переменной CFLAGS. Пример из немодифицированного Makefile:
CFLAGS= -O3 -funroll-loops -DHAVE_SOUND
При использовании системных флагов оптимизации Makefile станет похожим на следующий пример:
CFLAGS+= -DHAVE_SOUND
13.10. Подробные логи сборки
Заставьте систему сборки портов отображать все команды, выполняемые на этапе сборки. Полные логи сборки критически важны для отладки проблем с портами.
Пример неинформативного лога сборки (плохой):
CC source1.o CC source2.o CCLD someprogram
Пример подробного журнала сборки (хороший):
cc -O2 -pipe -I/usr/local/include -c -o source1.o source1.c cc -O2 -pipe -I/usr/local/include -c -o source2.o source2.c cc -o someprogram source1.o source2.o -L/usr/local/lib -lsomelib
Некоторые системы сборки, такие как CMake, ninja и GNU configure, настроены на подробное ведение журнала в рамках инфраструктуры портов. В других случаях портам могут потребоваться индивидуальные изменения.
13.11. Обратная связь
Посылайте подходящие изменения/патчи автору/сопровождающему для включения в следующий релиз. Это только сделает вашу работу гораздо легче при выходе следующего релиза.
13.12. README.html
README.html не является частью порта и генерируется при помощи make readme. Не включайте этот файл в патчи или коммиты.
Если не удается выполнить |
13.13. Пометка неустанавливаемого порта как BROKEN, FORBIDDEN или IGNORE
В некоторых случаях пользователи не должны допускаться к установке порта. Для того, чтобы сообщить пользователю, что порт не следует устанавливать, имеется несколько make-переменных, которые могут быть использованы в файле Makefile порта. Значения следующих make-переменных будут причиной, возвращаемой пользователям, по которой порт отказывает в установке. Пожалуйста, используйте корректные make-переменные, так как каждая переменная make передает абсолютно различный смысл как для пользователей, так и для автоматизированных систем, которые полагаются на файлы Makefile, таких как кластер построения портов, FreshPorts.
13.13.1. Переменные
BROKENпредназначена для портов, которые в настоящее время не компилируются, не устанавливаются или не удаляются правильно. Следует использовать, когда проблема считается временной.В особых случаях кластер построения будет продолжать попытки собрать их, чтобы показать, решена ли основная проблема. (Однако, как правило, кластер запускается без этой возможности.)
В частности, используйте
BROKEN, когда порт:не компилируется
выполняет со сбоем конфигурирование или процесс установки
устанавливает файлы вовне ${PREFIX}
не удаляет полностью все свои файлы при деинсталляции (тем не менее, это может быть допустимо, и подходит для портов, оставляющих после себя файлы, измененные пользователем)
имеет проблемы во время выполнения на системах, где он должен работать нормально.
FORBIDDENиспользуется для портов, которые содержат уязвимости в информационной безопасности или являются потенциально вредными в плане обеспечения информационной безопасности системы FreeBSD при установке данного порта (например: заведомо небезопасная программа или программа, которая предоставляет легко взламываемые сервисы). Порты должны помечаться какFORBIDDEN, как только в конкретном программном обеспечении обнаружилась уязвимость, но обновление выпущено не было. В идеальном случае порты должны обновляться максимально быстро после обнаружения уязвимости, чтобы уменьшить число уязвимых хостов FreeBSD (нам нравится иметь репутацию безопасной системы), однако иногда случается значительный временной разрыв между обнаружением уязвимости и выходом обновлённого релиза уязвимого программного обеспечения. Не помечайте порт какFORBIDDEN, если причина не вызвана соображениями информационной безопасности.IGNOREпредназначена для портов, которые не должны строиться по какой-либо другой причине. Следует использовать для портов, в случае когда проблема считается структурной. Кластер построения ни при каких условиях не будет строить порты, помеченные какIGNORE. В частности, используйтеIGNORE, когда порт:не работает на установленной версии FreeBSD
имеет distfile, который не может быть автоматически загружен из-за ограничений лицензирования
не работает с некоторыми другими установленными портами (например, порт зависит от www/drupal7, но установлен www/drupal8)
Если порт будет конфликтовать с уже установленным портом (например, если они устанавливают файл в то же место, но с иным функциональным назначением), то используйте вместо этого
CONFLICTS.CONFLICTSсам установит значениеIGNORE.
13.13.2. Заметки о реализации
Не заключайте значения переменных BROKEN, IGNORE и связанных с ними в кавычки. Из-за способа отображения информации пользователю, формулировка сообщений для каждой переменной отличается:
BROKEN= fails to link with base -lcrypto
IGNORE= unsupported on recent versions
и в результате make describe выведен информацию в таком виде :
===> foobar-0.1 is marked as broken: fails to link with base -lcrypto.
===> foobar-0.1 is unsupported on recent versions.
13.14. Архитектурные соображения
13.14.1. Общие замечания об архитектурах
FreeBSD работает на гораздо большем количестве архитектур процессоров, чем только хорошо известные x86-совместимые. Некоторые порты имеют ограничения, характерные для одной или нескольких из этих архитектур.
Для списка поддерживаемых архитектур выполните:
cd ${SRCDIR}; make targetsЗначения отображаются в форме TARGET/TARGET_ARCH. Переменная только для чтения ARCH в ports устанавливается на основе значения TARGET_ARCH. Makefile в портах должны проверять значение этой переменной.
13.14.2. Пометка порта как архитектурно нейтрального
Порты, которые не имеют зависимых от архитектуры файлов или требований, определяются установкой NO_ARCH=yes.
Пакеты, собранные из таких портов, имеют строку архитектуры, оканчивающуюся на :* (архитектура с подстановочным символом), в отличие от, например, freebsd:13:x86:64 (архитектура amd64).
|
13.14.3. Пометка порта как игнорируемого только на определенных архитектурах
Чтобы пометить порт как
IGNOREтолько для определенных архитектур, существуют две другие удобные переменные, которые автоматически устанавливаютIGNORE:ONLY_FOR_ARCHSиNOT_FOR_ARCHS. Примеры:ONLY_FOR_ARCHS= i386 amd64
NOT_FOR_ARCHS= ia64 sparc64
Пользовательское сообщение
IGNOREможно задать с помощьюONLY_FOR_ARCHS_REASONиNOT_FOR_ARCHS_REASON. Для отдельных архитектур возможны записи сONLY_FOR_ARCHS_REASON_ARCHиNOT_FOR_ARCHS_REASON_ARCH.
Если порт загружает и устанавливает бинарные файлы i386, установите
IA32_BINARY_PORT. Если эта переменная задана, /usr/lib32 должен присутствовать для IA32-версий библиотек, а ядро должно поддерживать совместимость с IA32. Если одно из этих двух условий не выполняется,IGNOREбудет установлен автоматически.
13.14.4. Специфические аспекты для кластеров
Некоторые порты пытаются оптимизировать себя под конкретную машину, на которой они собираются, указывая компилятору
-march=native. Этого следует избегать: либо добавить этот параметр в опцию, отключенную по умолчанию, либо удалить его полностью.В противном случае стандартный пакет, созданный кластером сборки, может не запускаться на каждой машине с данной
ARCH.
13.15. Пометка порта на удаление с DEPRECATED или EXPIRATION_DATE
Помните, что BROKEN и FORBIDDEN будут использованы как временное средство, если порт не является работающим. Постоянно неработоспособные порты должны полностью удаляться из дерева.
В подходящих ситуациях пользователи могут быть оповещены о предстоящем удалении через переменные DEPRECATED и EXPIRATION_DATE. Первое - это просто строка, сообщающая причину запланированного удаления порта; вторая является строкой в формате ISO 8601 (YYYY-MM-DD). Обе будут показаны пользователю.
Переменную DEPRECATED можно установить без использования EXPIRATION_DATE (в частности, при рекомендации новой версии порта), но обратный порядок не имеет никакого смысла.
При пометке порта как |
Не существует установленного правила о том, насколько заранее нужно уведомлять. Текущая практика предполагает один месяц для проблем, связанных с безопасностью, и два месяца для проблем сборки. Это также дает заинтересованным коммиттерам немного времени на исправление проблем.
13.16. Избегайте использования конструкции .error
Правильным способом подать сигнал для Makefile о том, что порт не может быть установлен из-за какого-то внешнего фактора (например, пользователь указал недопустимую комбинацию опций построения), является установка непустого значения для IGNORE. Это значение будет сформатировано и показано пользователю во время make install.
Использование для этих целей .error является распространенной ошибкой. Проблема в том, что в этой ситуации будут повреждены многие инструменты автоматизации, работающие с деревом портов. Наибольшим образом это распространено при попытке построить /usr/ports/INDEX (смотрите Запуск make describe). Тем не менее, даже более простые команды, такие как make maintainer, в этом случае также вернут ошибку. Это не является приемлемым.
.errorИз следующих двух вариантов строки файла Makefile первый приведёт к неудачному завершению работы make index, а второй - нет:
.error "option is not supported"
IGNORE=option is not supported
13.17. Использование sysctl
Использование sysctl не рекомендуется, кроме как при выполнении целей. Это вызвано тем, что вычисление любых makevar, таких как во время команды make index, с необходимостью запуска этой команды, еще больше замедляет весь процесс.
sysctl(8) следует всегда использовать через переменную SYSCTL, поскольку она содержит полностью заданный путь, и при необходимости может быть переопределена.
13.18. Меняющиеся дистрибутивные файлы
Иногда авторы программного обеспечения изменяют содержимое выпущенных дистрибутивных файлов, не меняя их названия. Убедитесь, что изменения официальны и были выполнены автором. В прошлом случалось, что дистрибутивный файл тихо изменялся на серверах загрузки с целью нанесения вреда или компрометации безопасности конечного пользователя.
Отложите старый distfile в сторону, загрузите новый, распакуйте их и сравните содержимое с помощью diff(1). Если ничего подозрительного нет, обновите distinfo.
Убедитесь, что вы выделили основные различия в PR и журнале коммитов, чтобы другие люди знали, что ничего плохого не произошло. |
Связжитесь с автором этого программного обеспечения для подтверждения изменений.
13.19. Используйте стандарты POSIX
В большинстве случаев порты FreeBSD ожидают соответствия стандарту POSIX. Некоторые программы и системы сборки делают предположения, основанные на конкретной операционной системе или окружении, что может вызывать проблемы при использовании в порте.
Не используйте /proc, если есть другие способы получить информацию. Например, setprogname(argv[0]) в main(), а затем getprogname(3) для получения имени исполняемого файла.
Не полагайтесь на поведение, не документированное в POSIX.
Не записывайте метки времени в критическом пути приложения, если оно работает и без них. Получение меток времени может быть медленным в зависимости от точности меток времени в ОС. Если метки времени действительно необходимы, определите, насколько точными они должны быть, и используйте API, которое, согласно документации, предоставляет только необходимую точность.
Ряд простых системных вызовов (например, gettimeofday(2), getpid(2)) работают намного быстрее в Linux® по сравнению с любой другой операционной системой из-за кэширования и используемой оптимизации vsyscall. Не полагайтесь на их дешевизну в критичных к производительности приложениях. В целом, старайтесь избегать системных вызовов там, где это возможно.
Не полагайтесь на специфичное для Linux® поведение сокета. В частности, отличаются размеры буфера сокета по умолчанию (выполните вызов setsockopt(2) с SO_SNDBUF и SO_RCVBUF, и в то время как в Linux® при заполнении буфера сокета send(2) блокируется, FreeBSD возвращает ошибку и устанавливает ENOBUFS в качестве значения errno.
Если требуется рассчитывать на нестандартное поведение, инкапсулируйте это должным образом в общий для всех API с проверкой поведения на этапе конфигурации, и если требуемое поведение не найдено, прекращайте выполнение.
Используйте страницы справочника для проверки, относится ли функция к интерфейсу POSIX (ищите раздел "STANDARDS" на странице справочника).
Не рассчитывайте на то, что в качестве /bin/sh используется bash. Убедитесь, что командная строка, переданная в system(3), будет работать в POSIX-совместимой оболочке.
Список основных bash-измов расположен здесь.
Проверьте, что используемые заголовочные файлы включены в POSIX или список, рекомендуемый страницей справочника, т.к. например, забыть подключить sys/types.h - не такая уж проблема в Linux®, однако это не так во FreeBSD.
Глава 14. Примерный Makefile
Образец Makefile, который можно использовать для создания нового порта.
Вам рекомендуется следовать этому формату (соблюдая порядок следования переменных, пустые строки между разделами, и так далее). Этот формат разработан для того, чтобы важная информация была легко найдена. Обратитесь главе о тестировании, чтобы узнать больше о lint, утилитах для форматирования и проверки файла Makefile.
PORTNAME= xdvi (1)
DISTVERSION= 18.2
CATEGORIES= print
MASTER_SITES= ${MASTER_SITE_XCONTRIB} (2)
MASTER_SITE_SUBDIR= applications
PKGNAMEPREFIX= ja-
DISTNAME= xdvi-pl18
EXTRACT_SUFX= .tar.Z (3)
PATCH_SITES= ftp://ftp.sra.co.jp/pub/X11/japanese/ (4)
PATCHFILES= xdvi-18.patch1.gz xdvi-18.patch2.gz
PATCH_DIST_STRIP= -p1 (5)
MAINTAINER= asami@FreeBSD.org (6)
COMMENT= DVI Previewer for the X Window System
WWW= http://xdvi.sourceforge.net/
LICENSE= BSD2CLAUSE (7)
LICENSE_FILE= ${WRKSRC}/LICENSE
RUN_DEPENDS= gs:print/ghostscript (8)
USES= gmake (9)
(10)
IS_INTERACTIVE= yes (11)
WRKSRC= ${WRKDIR}/xdvi-new (12)
GNU_CONFIGURE= yes (13)
(14)
OPTIONS_DEFINE= DOCS EXAMPLES FOO
OPTIONS_DEFAULT=FOO
OPTIONS_SUB= yes (15)
FOO_DESC= Enable foo support
FOO_CONFIGURE_ENABLE= foo
(16)
MY_FAVORITE_RESPONSE= "yeah, right"
(17)
pre-fetch:
i go fetch something, yeah
post-patch:
мне кое-что сделать после применения патча, великолепно
pre-install:
и потом еще кое-что перед установкой, ого
.include <bsd.port.mk> (18)| 1 | Секция для описания самого порта и его главного сайта: первыми идут переменные PORTNAME и PORTVERSION или DISTVERSION*, на ними CATEGORIES, затем MASTER_SITES, после которой идет MASTER_SITE_SUBDIR. Если нужно, то после нее идут PKGNAMEPREFIX и PKGNAMESUFFIX. Затем следуют DISTNAME, EXTRACT_SUFX и/или DISTFILES, и уже потом, если нужно, EXTRACT_ONLY. |
| 2 | Не забывайте про завершающую косую черту (/), если вы не используете макросы MASTER_SITE_*. |
| 3 | Задайте это, если исходный код поставляется не в виде стандартного файла ".tar.gz". |
| 4 | Секция патчей — может быть пустой. |
| 5 | Если распространяемые патчи не были созданы относительно ${WRKSRC},возможно, это потребуется исправить вручную. |
| 6 | Сопровождающий; обязательное поле! Это человек, который добровольно занимается обновлениями порта и неисправностями при построении, и которому пользователь может направлять вопросы и сообщения об ошибках. Для сохранения как можно более высокого качества Коллекции Портов мы больше не принимаем новые порты, назначенные на "ports@FreeBSD.org". |
| 7 | Лицензия — не следует оставлять пустым. |
| 8 | Зависимости — могут быть пустыми. |
| 9 | Если порт требует GNU make вместо стандартного FreeBSD make (make(1)) для сборки. Например, некоторым приложениям X требуется выполнение xmkmf -a, в этом случае порту понадобится USES=imake. |
| 10 | Этот раздел посвящён другим стандартным переменным bsd.port.mk, которые не относятся ни к одной из вышеперечисленных категорий. |
| 11 | Если порты задают интерактивные вопросы во время настройки, сборки, установки. |
| 12 | Если извлечение происходит в каталог, отличный от DISTNAME. |
| 13 | Если требуется запустить скрипт configure, сгенерированный GNU autoconf. |
| 14 | Этот раздел предназначен для настройки параметров портов. |
| 15 | Установите OPTIONS_SUB, если параметры изменят список файлов в plist. |
| 16 | В правилах ниже используются нестандартные переменные. |
| 17 | Специальные правила, в порядке их вызова фреймворком портов. |
| 18 | Наконец, эпилог. |
Глава 15. Порядок переменных в Makefile портов
Первые разделы Makefile всегда должны идти в одном и том же порядке. Это стандартное правило позволяет любому легко читать любой порт, не тратя время на поиск переменных в произвольном порядке.
Описаные здесь разделы и переменные являются обязательными в обычном порте. В подчиненном порте многие разделы и переменные могут быть пропущены. |
Каждый следующий блок должен быть отделен от предыдущего одним пустым пробелом. В следующих блоках устанавливайте только переменные, которые требуются для порта. Определяйте эти переменные в порядке, указанном здесь. |
15.1. Блок PORTNAME
Этот блок является наиболее важным. Он определяет имя порта, версию, расположение файла дистрибутива и категорию. Переменные должны быть в следующем порядке:
Может быть использован только один из параметров — PORTVERSION или DISTVERSION. |
15.4. Блок LICENSE
Этот блок является необязательным, хотя настоятельно рекомендуется. Переменные:
LICENSE_GROUPSилиLICENSE_GROUPS_NAMELICENSE_NAMEилиLICENSE_NAME_NAMELICENSE_TEXTилиLICENSE_TEXT_NAMELICENSE_FILEилиLICENSE_FILE_NAMELICENSE_PERMSилиLICENSE_PERMS_NAME_LICENSE_DISTFILESилиLICENSE_DISTFILES_NAME
Если имеется несколько лицензий, отсортируйте различные переменные LICENSE_VAR_NAME по названию лицензии.
15.5. Общие сообщения BROKEN/IGNORE/DEPRECATED
Этот блок необязателен. Переменные:
Если порт помечен как BROKEN при выполнении определённых условий, и эти условия можно проверить только после включения bsd.port.options.mk или bsd.port.pre.mk, то такие переменные должны быть установлены позже, в Остальные Переменные. |
15.7. Флейворы
Этот блок необязателен.
Начните этот раздел с определения FLAVORS. Затем рассмотрите возможные вспомогательные инструменты флейворов. Дополнительную информацию см. в разделе Использование флейворов (FLAVORS).
Конструкции, устанавливающие переменные, недоступные в виде помощников, с использованием .if ${FLAVOR:U} == foo, должны быть размещены в соответствующих разделах ниже.
15.8. USES и USE_x
Начните этот раздел с определения USES, а затем возможных USE_x.
Держите связанные переменные рядом. Например, если используется USE_GITHUB, всегда размещайте переменные GH_* сразу после неё.
15.9. Стандартные переменные bsd.port.mk
Этот блок раздела предназначен для переменных, которые могут быть определены в bsd.port.mk и не принадлежат ни к одному из предыдущих блоков разделов.
Порядок не важен, однако старайтесь держать схожие переменные вместе. Например, переменные uid и gid USERS и GROUPS. Конфигурационные переменные CONFIGURE_* и *_CONFIGURE. Списки файлов и директорий PORTDOCS и PORTEXAMPLES.
15.10. Параметры и помощники
Если порт использует фреймворк опций, сначала определите OPTIONS_DEFINE и OPTIONS_DEFAULT, затем остальные переменные OPTIONS_*, далее описания *_DESC, а затем вспомогательные опции. Старайтесь сортировать их все в алфавитном порядке.
Опции FOO и BAR не имеют стандартного описания, поэтому его необходимо написать. Остальные опции уже имеют описание в Mk/bsd.options.desc.mk, поэтому его создание не требуется. Переменные DOCS и EXAMPLES используют вспомогательные цели для установки своих файлов, они приведены здесь для полноты, хотя относятся к разделу Цели, поэтому перед ними могут быть вставлены другие переменные и цели.
OPTIONS_DEFINE= DOCS EXAMPLES FOO BAR
OPTIONS_DEFAULT= FOO
OPTIONS_RADIO= SSL
OPTIONS_RADIO_SSL= OPENSSL GNUTLS
OPTIONS_SUB= yes
BAR_DESC= Enable bar support
FOO_DESC= Enable foo support
BAR_CONFIGURE_WITH= bar=${LOCALBASE}
FOO_CONFIGURE_ENABLE= foo
GNUTLS_CONFIGURE_ON= --with-ssl=gnutls
OPENSSL_CONFIGURE_ON= --with-ssl=openssl
post-install-DOCS-on:
${MKDIR} ${STAGEDIR}${DOCSDIR}
cd ${WRKSRC}/doc && ${COPYTREE_SHARE} . ${STAGEDIR}${DOCSDIR}
post-install-EXAMPLES-on:
${MKDIR} ${STAGEDIR}${EXAMPLESDIR}
cd ${WRKSRC}/ex && ${COPYTREE_SHARE} . ${STAGEDIR}${EXAMPLESDIR}15.11. Остальные переменные
И затем, остальные переменные, которые не упоминались в предыдущих блоках.
15.12. Цели
После определения всех переменных можно определить дополнительные цели make(1). Следует располагать pre- перед post- и в том же порядке, в котором выполняются различные этапы:
fetchextractpatchconfigurebuildinstalltest
При использовании опций post-install: # install generic bits post-install-DOCS-on: # Install documentation post-install-X11-on: # Install X11 related bits post-install-X11-off: # Install bits that should be there if X11 is disabled |
Глава 16. Актуализация
Коллекция Портов FreeBSD постоянно изменяется. Здесь находится некоторая информация о том, как поддерживать её в актуальном состоянии.
16.1. FreshPorts
Самым простым способом отслеживать уже произошедшие обновления является подписка на FreshPorts. Для мониторинга вы можете выбрать несколько портов. Сопровождающим порта настоятельно рекомендуется подписаться здесь, потому что они будут получать уведомления не только о собственных изменениях, но и об изменениях, сделанных любым другим коммиттером FreeBSD. (Это часто необходимо для синхронизации с изменениями на более низком технологическом уровне, хотя более корректным было бы получение предупреждений от тех, кто вносит подобные изменения, иногда этот этап пропускается или он просто непрактичен. Кроме того, в некоторых случаях изменения по своей природе весьма незначительны. Мы полагаем, что любой разработчик в таких ситуациях будет руководствоваться здравым смыслом).
Если вы хотите использовать FreshPorts, то вам нужна только учётная запись. Если регистрационный адрес вашей электронной почты будет иметь вид @FreeBSD.org, то справа на Web-страницах вы увидите дополнительную ссылку. Для тех из вас, кто уже получил учётную запись FreshPorts, но не использовал собственный адрес электронной почты @FreeBSD.org, достаточно сменить адрес на @FreeBSD.org, подписаться, а затем сменить его обратно.
Во FreshPorts имеется также функция проверки правильности, которая автоматически проверяет каждое изменение, внесённое в дерево портов FreeBSD. Если вы подпишетесь на эту услугу, то будете оповещаться обо всех ошибках, обнаруженных FreshPorts при проверке внесённых вами изменений.
16.2. Web-интерфейс к хранилищу исходных текстов
Файлы в хранилище исходных текстов можно просматривать при помощи Web-интерфейса. Изменения, которые касаются в целом всей системы портов, теперь документируются в файле CHANGES. Изменения, касающиеся отдельных портов, отражаются теперь в файле UPDATING. Однако однозначный ответ на любой вопрос можно найти, только прочитав исходных код bsd.port.mk и связанных с ним файлов.
16.3. Список рассылки FreeBSD, посвящённый портам
Если вы поддерживаете порты, то должны следить за Список рассылки, посвящённый Портам FreeBSD. О важных изменениях, отражающихся на работе портов, будет сообщаться здесь, а затем они переносятся в CHANGES.
Если данный список рассылки слишком загружен сообщениями, вы можете отслеживать Список рассылки анонсов FreeBSD Ports, который модерируется и не является местом для дискуссий.
16.4. Кластер построения портов FreeBSD
Одной из наименее известных сильных сторон FreeBSD является тот факт, что для непрерывного построения Коллекции Портов для каждого из основных релизов ОС для каждой архитектуры уровня поддержки Tier-1 выделен целый кластер машин.
Отдельные порты собираются, если они специально не помечены как IGNORE. Для портов, помеченных как BROKEN, попытки будут продолжены для того, чтобы увидеть, если основная проблема была решена. (Это сделано через использование переменной TRYBROKEN для Makefile порта.)
16.5. Portscout: сканер дистрибутивных файлов портов FreeBSD
Кластер построения выделен для выполнения самого последнего релиза каждого из портов, дистрибутивные файлы которых уже были сгружены. Однако из-за постоянных изменений в Internet дистрибутивные файлы могут быстро исчезать. Portscout, средство сканирования дистрибутивных файлов FreeBSD пытается опросить каждый из сайтов, доступных для сгрузки каждого из портов, для определения того, доступны ли ещё дистрибутивные файлы. Portscout может готовить отчёты в HTML и рассылать электронные письма об имеющихся обновлениях для портов тем, кто это запрашивает. Сопровождающие периодически запрашивают наличие изменений либо вручную, либо используя ленту RSS.
Главная страница Portscout отображает email сопровождающего порта, количество портов, за которые ответственен сопровождающий, количество портов с новыми дистрибутивными файлами и процент устаревших портов. Функция поиска выполняет поиск сопровождающего по адресу электронной почты и позволяет выбирать между всеми портами или только устаревшими.
При щелчке по адресу электронной почты сопровождающего отображается список всех его портов, разделённых по категориям, вместе с текущим номером версии, информацией о наличии новой версии, временем последнего обновления порта и временем его последней проверки. Функция поиска на этой странице позволяет пользователю выполнять поиск конкретного порта.
По щелчку на название порта в списке отображается информация о порте FreshPorts.
Другим полезным ресурсом является репозиторий Portscout.
Глава 17. Использование макроса USES
17.1. Введение в USES
Макросы USES упрощают объявление требований и настроек для порта. Они могут добавлять зависимости, изменять поведение при сборке, добавлять метаданные в пакеты и так далее, просто выбирая предустановленные значения.
Каждый раздел в этой главе описывает возможное значение для USES, а также его возможные аргументы. Аргументы добавляются к значению после двоеточия (:). Несколько аргументов разделяются запятыми (,).
USES= bison perl
USES= tar:xz
USES= drupal:7,theme
USES= pgsql:9.3+ cpe python:2.7,build
17.2. 7z
Возможные аргументы: (нет), p7zip, partial
Извлечение с использованием 7z(1) вместо bsdtar(1) и устанавливает EXTRACT_SUFX=.7z. Опция p7zip добавляет зависимость от 7z из archivers/p7zip, если версия из базовой системы не может извлечь файлы. EXTRACT_SUFX не изменяется, если используется опция partial, это может быть полезно, если основной дистрибутивный файл не имеет расширения .7z.
17.3. ada
Возможные аргументы: (нет), 6, 12, (запуск)
Зависит от компилятора с поддержкой Ada и устанавливает CC соответствующим образом. По умолчанию используется gcc6-aux из портов.
17.4. angr
Возможные аргументы: binaries, nose
Обеспечить поддержку портов, требующих платформу бинарного анализа angr.
Если присутствует аргумент binaries, для тестирования порта требуются специальные бинарные файлы angr.
Если присутствует аргумент nose, порт использует nosetests для цели тестирования. Этот аргумент подразумевает USES=python:test.
Фреймворк предоставляет следующие переменные, которые могут быть установлены портом:
ANGR_VERSIONВерсия программ проекта
angr.ANGR_BINARIES_TAGNAMEИмя тега для бинарных файлов
angr.ANGR_NOSETESTSПуть к программе
nosetests.
17.5. ansible
Возможные аргументы: env, module, plugin
Обеспечивает поддержку портов, зависящих от пакета sysutils/ansible.
Если присутствует аргумент env, порт не зависит от sysutils/ansible, но требует установки некоторых переменных Ansible.
Если присутствует аргумент module, то порт является модулем Ansible.
Если присутствует аргумент plugin, то порт является плагином Ansible.
Фреймворк предоставляет следующие переменные порту:
ANSIBLE_CMDПуть к программе ansible.
ANSIBLE_DOC_CMDПуть к программе ansible-doc.
ANSIBLE_RUN_DEPENDSRUN_DEPENDS с портом Ansible.
ANSIBLE_DATADIRПуть к корню структуры каталогов, где хранятся все модули и плагины Ansible.
ANSIBLE_ETCDIRПуть к каталогу etc Ansible.
ANSIBLE_PLUGINS_PREFIXПуть к директории "plugins" в
${ANSIBLE_DATADIR}.ANSIBLE_MODULESDIRПуть к каталогу для локальных модулей Ansible.
ANSIBLE_PLUGINSDIRПуть к каталогу для локальных плагинов Ansible.
ANSIBLE_PLUGIN_TYPEТип плагина Ansible (например, "connection", "inventory" или "vars").
17.6. apache
Возможные аргументы: (нет), 2.4, build, run, server
Обеспечивает поддержку портов, зависящих от веб-сервера Apache.
Аргумент version можно использовать для указания конкретной версии Apache httpd. Можно задать определённую версию (USES=apache:2.4), минимальную версию (USES=apache:2.4+) или максимальную версию (USES=apache:-2.4).
Если указан аргумент build, к порту добавляется зависимость для сборки.
Если указан аргумент run, к порту добавляется зависимость времени выполнения.
Если указан аргумент server, это означает, что порт является серверным.
Фреймворк предоставляет следующие переменные, которые могут быть установлены портом:
AP_FAST_BUILDАвтоматическая сборка модуля
AP_GENPLISTАвтоматическое создание
PLISTплюс добавление модуля в отключенном состоянии в httpd.conf (только если нет файлаpkg-plist)MODULENAMEИмя модуля Apache. По умолчанию:
${PORTNAME}SHORTMODNAMEКраткое название модуля Apache. По умолчанию:
${MODULENAME:S/mod_//}SRC_FILEИсходный файл модуля APACHE. По умолчанию:
${MODULENAME}.c
Следующие переменные могут быть доступны для порта:
APACHE_VERSIONОсновная-вспомогательная версия выбранного сервера Apache, например 2.4
APACHEETCDIRРасположение каталога конфигурации Apache. По умолчанию: ${LOCALBASE}/etc/apache24
APACHEINCLUDEDIRРасположение include-файлов Apache. По умолчанию: ${LOCALBASE}/include/apache24
APACHEMODDIRРасположение модулей Apache. По умолчанию: ${LOCALBASE}/libxexec/apache24
APACHE_DEFAULT::Версия Apache по умолчанию
17.7. autoreconf
Возможные аргументы: (нет), build
Выполняет autoreconf. Эта команда объединяет функциональность aclocal, autoconf, autoheader, automake, autopoint и libtoolize. Каждая из этих команд применяется к ${AUTORECONF_WRKSRC}/configure.ac или его старому названию ${AUTORECONF_WRKSRC}/configure.in. Если configure.ac определяет подкаталоги с их собственными configure.ac с использованием AC_CONFIG_SUBDIRS, autoreconf также рекурсивно обновит их. Аргумент :build только добавляет зависимости времени сборки на эти инструменты, но не запускает autoreconf. Порт может установить AUTORECONF_WRKSRC, если WRKSRC не содержит путь к configure.ac.
17.8. azurepy
Возможные аргументы: (отсутствуют)
Обеспечить поддержку портов py-azure*. Удаляет пространства имен azure и очищает общие файлы.
17.9. blaslapack
Возможные аргументы: (нет), atlas, netlib (по умолчанию), gotoblas, openblas
Добавляет зависимости от библиотек Blas / Lapack.
17.10. bdb
Возможные аргументы: (отсутствуют), 5 (по умолчанию), 18
Добавить зависимость от библиотеки Berkeley DB. По умолчанию используется databases/db5. Также может зависеть от databases/db18 при использовании аргумента :18. Можно объявить диапазон допустимых значений: :5+ находит самую высокую установленную версию и возвращается к 5, если ничего другого не установлено. INVALID_BDB_VER можно использовать для указания версий, которые не работают с этим портом. Фреймворк предоставляет порту следующие переменные:
BDB_LIB_NAMEИмя библиотеки Berkeley DB. Например, при использовании databases/db5 она содержит
db-5.3.BDB_LIB_CXX_NAMEНазвание библиотеки Berkeley DBC++. Например, при использовании databases/db5 она содержит
db_cxx-5.3.BDB_INCLUDE_DIRРасположение каталога с заголовочными файлами Berkeley DB. Например, при использовании пакета databases/db5, он будет содержать
${LOCALBASE}/include/db5.BDB_LIB_DIRРасположение каталога библиотеки Berkeley DB. Например, при использовании databases/db5, он содержит
${LOCALBASE}/lib.BDB_VERОбнаруженная версия Berkeley DB. Например, при использовании
USES=bdb:5+и установленной Berkeley DB 18, будет содержать18.
databases/db48 устарел и не поддерживается. Он не должен использоваться ни одним портом. |
17.11. bison
Возможные аргументы: (нет), build, run, both
Использует пакет devel/bison По умолчанию, без аргументов или с аргументом build, подразумевается, что bison является зависимостью на этапе сборки, run — зависимостью на этапе выполнения, а both — зависимостью как на этапе сборки, так и на этапе выполнения.
17.12. budgie
Возможные аргументы: (отсутствуют)
Предоставить поддержку окружения рабочего стола Budgie. Используйте USE_BUDGIE для выбора необходимых компонентов порта. Дополнительную информацию см. в разделе Использование Budgie.
17.13. cabal
Порты не следует создавать для библиотек Haskell, подробнее см. в Библиотеки Haskell. |
Возможные аргументы: (отсутствуют), hpack, nodefault
Устанавливает значения и цели по умолчанию, используемые для сборки программного обеспечения на Haskell с помощью Cabal. Добавляется зависимость для сборки на порт компилятора Haskell (lang/ghc). Если в переменной BUILD_DEPENDS уже указана другая версия GHC (например, lang/ghc810), она будет использована вместо версии по умолчанию. Если указан аргумент hpack, добавляется зависимость для сборки на devel/hs-hpack, и hpack вызывается на этапе конфигурации для генерации файла .cabal. Если указан аргумент nodefault, фреймворк не будет пытаться загрузить основной дистрибутивный файл из Hackage. Этот аргумент добавляется неявно, если присутствует USE_GITHUB или USE_GITLAB.
Фреймворк предоставляет следующие переменные:
CABAL_REVISIONПакеты Haskell, размещённые на Hackage, могут иметь ревизии. Установите этот параметр в целочисленное значение, чтобы использовать исправленное описание пакета.
USE_CABALЕсли программное обеспечение использует зависимости на Haskell, перечислите их в этой переменной. Каждый элемент должен присутствовать на Hackage и быть указан в формате
имяпакета-0.1.2. Зависимости также могут иметь ревизии, которые указываются после символа_. Поддерживается автоматическое формирование списка зависимостей, см. Сборка приложений на Haskell с помощьюcabal.CABAL_FLAGSСписок флагов, передаваемых
cabal-installна этапах настройки и сборки. Флаги передаются в исходном виде. Эта переменная обычно используется для включения или отключения флагов, объявленных в файле .cabal. Передайтеfoo, чтобы включить флагfoo, и-foo, чтобы отключить его.CABAL_EXECUTABLESСписок исполняемых файлов, устанавливаемых портом. Значение по умолчанию:
${PORTNAME}. Для получения списка возможных значений этой переменной обратитесь к файлу .cabal портируемого проекта. Каждое значение соответствует разделуexecutableв файле .cabal. Элементы из этого списка автоматически добавляются в pkg-plist.SKIP_CABAL_PLISTЕсли определено, не добавлять элементы из
${CABAL_EXECUTABLES}в pkg-plist.opt_USE_CABALДобавляет элементы в
${USE_CABAL}в зависимости от опцииopt.opt_CABAL_EXECUTABLESДобавляет элементы в
${CABAL_EXECUTABLES}в зависимости от опцииopt.opt_CABAL_FLAGSЕсли
optвключён, добавить значение к${CABAL_FLAGS}. В противном случае добавить-value, чтобы отключить флаг. Обратите внимание, что это поведение немного отличается от простогоCABAL_FLAGS, так как оно не принимает значения, начинающиеся с-.CABAL_WRAPPER_SCRIPTSПодмножество
${CABAL_EXECUTABLES}, содержащее программы на Haskell, которые будут обёрнуты в shell-скрипт, устанавливающий переменные окружения*_datadirперед запуском программы. Это также приводит к тому, что фактический бинарный файл Haskell устанавливается в директориюlibexec/cabal/. Данная настройка необходима для программ на Haskell, которые устанавливают свои файлы данных в директориюshare/.FOO_DATADIR_VARSСписок дополнительных пакетов Haskell, чьи файлы данных должны быть доступны исполняемому файлу с именем
FOO. Исполняемый файл должен быть частью${CABAL_WRAPPER_SCRIPTS}. Указанные пакеты Haskell не должны иметь суффикса версии.CABAL_PROJECTНекоторые проекты на Haskell могут уже иметь файл
cabal.project, который также создаётся фреймворком портов. Если это так, используйте эту переменную, чтобы указать, что делать с оригинальным файломcabal.project. Установка этой переменной в значениеremoveприведёт к удалению оригинального файла. Установка этой переменной в значениеappendприведёт к следующему:Исходный файл переместится в
cabal.project.${PORTNAME}на этапеextract.Исходный файл
cabal.project.${PORTNAME}и сгенерированныйcabal.projectобъединятся в один файл после этапаpatch. Использованиеappendпозволяет выполнить патчинг исходного файла перед его объединением.
17.14. cargo
Возможные аргументы: (отсутствуют)
Использует Cargo для настройки, сборки и тестирования. Может применяться для портирования приложений на Rust, использующих систему сборки Cargo. Дополнительную информацию смотрите в Сборка приложений на Rust с помощью cargo.
17.15. charsetfix
Возможные аргументы: (отсутствуют)
Предотвращает установку файла charset.alias портом. Этот файл должен устанавливаться только пакетом converters/libiconv. Переменная CHARSETFIX_MAKEFILEIN может быть установлена в путь относительно WRKSRC, если charset.alias не устанавливается через ${WRKSRC}/Makefile.in.
17.16. cl
Возможные аргументы: (отсутствуют)
Предоставляет поддержку портов Common Lisp.
Фреймворк предоставляет следующие переменные, которые могут быть установлены портами:
ASDF_MODULESСписок модулей
ASDFдля сборки, когда установленFASL_TARGET(по умолчаниюPORTNAME)FASL_TARGETСобрать fasl вариант порта (один из
ccl,clispилиsbcl)USE_ASDFЗависит от пакета devel/cl-asdf
USE_ASDF_FASLЗависит от
devel/cl-asdf-<FASL_TARGET>USE_CCLЗависит от пакета lang/ccl; подразумевается при
FASL_TARGET=cclUSE_CLISPЗависит от пакета lang/clisp; подразумевается при
FASL_TARGET=clispUSE_SBCLЗависит от пакета lang/sbcl; подразумевается, если
FASL_TARGET=SBCL
Фреймворк предоставляет следующие переменные, которые могут быть прочитаны портами:
ASDF_PATHNAMEПуть к исходному коду CL
ASDF_REGISTRYПуть к реестру CL, содержащему файлы asd
CCLПуть к компилятору Clozure Common Lisp
CLISPПуть к компилятору GNU Common Lisp
CL_LIBDIR_RELКаталог библиотек CL относительно
LOCALBASEилиPREFIXFASL_DIR_RELОтносительный путь к скомпилированным fasl-файлам; зависит от
FASL_TARGETFASL_PATHNAMEПуть к CL fasl
LISP_EXTRA_ARGДополнительные аргументы, используемые при сборке fasl
SBCLПуть к компилятору Steel Bank Common Lisp
17.17. cmake
Возможные аргументы: (отсутствуют), insource, noninja, run, testing
Используйте CMake для настройки порта и генерации системы сборки.
По умолчанию выполняется сборка в дереве вне исходного кода, оставляя исходные файлы в WRKSRC свободными от артефактов сборки. С аргументом insource вместо этого будет выполнена сборка в исходном коде. Этот аргумент должен быть исключением и использоваться только в случае, когда обычная сборка вне исходного кода не работает.
По умолчанию для сборки используется Ninja (devel/ninja). В некоторых случаях это может работать некорректно. С аргументом noninja сборка будет использовать обычный make. Этот аргумент следует применять только если сборка на основе Ninja не работает.
С аргументом run регистрируется зависимость во время выполнения в дополнение к зависимости при сборке.
С аргументом testing, добавляется цель тестирования, использующая CTest. При запуске тестов порт будет переконфигурирован для тестирования и пересобран.
Для получения дополнительной информации см. Использование cmake.
17.18. compiler
Возможные аргументы: (нет), env (по умолчанию, подразумевается), C++17-lang, C++14-lang, C++11-lang, gcc-C++11-lib, C++11-lib, C++0x, c11, nestedfct, features
Определяет, какой компилятор использовать, исходя из заданных предпочтений. Используйте C++17-lang, если порту требуется компилятор с поддержкой C++17, C++14-lang, если порту требуется компилятор с поддержкой C++14, C++11-lang, если порту требуется компилятор с поддержкой C++11, gcc-C++11-lib, если порту требуется компилятор g++ с библиотекой C++11, или C++11-lib, если порту требуется стандартная библиотека с поддержкой C++11. Если порту требуется компилятор, понимающий C++0X, C11 или вложенные функции, следует использовать соответствующие параметры.
Используйте features для запроса списка возможностей, поддерживаемых компилятором по умолчанию. После включения bsd.port.pre.mk порт может проверить результаты с помощью следующих переменных:
COMPILER_TYPE: компилятор по умолчанию в системе, gcc или clangALT_COMPILER_TYPE: альтернативный компилятор в системе, gcc или clang. Устанавливается только при наличии двух компиляторов в базовой системе.COMPILER_VERSION: первые две цифры версии компилятора по умолчанию.ALT_COMPILER_VERSION: первые две цифры версии альтернативного компилятора, если он присутствует.CHOSEN_COMPILER_TYPE: выбранный компилятор, gcc или clangCOMPILER_FEATURES: возможности, поддерживаемые компилятором по умолчанию. В настоящее время указана библиотека C++.
17.19. cpe
Возможные аргументы: (отсутствуют)
Включает информацию о Common Platform Enumeration (CPE) в манифест пакета в виде строки формата CPE 2.3. Подробности см. в спецификации CPE. Чтобы добавить информацию CPE в порт, выполните следующие шаги:
Поищите официальную запись CPE для программного продукта, используя либо поисковую систему CPE от NVD, либо официальный словарь CPE (предупреждение: очень большой XML-файл). Никогда не создавайте данные CPE самостоятельно.
Добавьте
cpeвUSESи сравните результат выполненияmake -V CPE_STRс записью в словаре CPE. Продолжайте шаг за шагом, пока результатmake -V CPE_STRне станет корректным.Если название продукта (второе поле, по умолчанию
PORTNAME) указано неверно, определитеCPE_PRODUCT.Если название производителя (первое поле, по умолчанию
CPE_PRODUCT) указано неверно, определитеCPE_VENDOR.Если поле версии (третье поле, по умолчанию
PORTVERSION) указано неверно, определитеCPE_VERSION.Если поле обновления (четвертое поле, по умолчанию пустое) указано неверно, определите
CPE_UPDATE.Если это всё ещё неверно, проверьте файл Mk/Uses/cpe.mk для получения дополнительной информации или свяжитесь с Ports Security Team <ports-secteam@FreeBSD.org>.
Извлекайте как можно больше информации для имени CPE из существующих переменных, таких как
PORTNAMEиPORTVERSION. Используйте модификаторы переменных для извлечения соответствующих частей из этих переменных, вместо того чтобы жестко прописывать имя.Всегда выполняйте
make -V CPE_STRи проверяйте вывод перед коммитом любых изменений, затрагивающихPORTNAME,PORTVERSIONили любые другие переменные, используемые для формированияCPE_STR.
17.20. cran
Возможные аргументы: (нет), auto-plist, compiles
Использует Comprehensive R Archive Network. Укажите auto-plist для автоматического создания pkg-plist. Укажите compiles, если порт содержит код, который необходимо компилировать.
17.21. desktop-file-utils
Возможные аргументы: (отсутствуют)
Использует update-desktop-database из пакета devel/desktop-file-utils. Дополнительный шаг post-install будет выполнен без вмешательства в уже существующие шаги post-install в Makefile порта. Строка с @desktop-file-utils будет добавлена в plist. Используйте этот макрос только если порт предоставляет файл .desktop, содержащий запись MimeType.
17.22. desthack
Возможные аргументы: (отсутствуют)
Изменяет поведение GNU configure для корректной поддержки DESTDIR в случае, если исходное программное обеспечение этого не делает.
17.23. display
Возможные аргументы: (отсутствуют), ARGS
Настраивает виртуальное окружение для отображения. Если переменная окружения DISPLAY не установлена, то Xvfb добавляется как зависимость при сборке, а CONFIGURE_ENV расширяется с указанием номера порта текущего запущенного экземпляра Xvfb. Параметр ARGS по умолчанию имеет значение install и управляет фазой, вокруг которой запускается и останавливается виртуальный дисплей.
17.24. dos2unix
Возможные аргументы: (отсутствуют)
Порт содержит файлы с символами конца строки в формате DOS, которые необходимо преобразовать. Несколько переменных могут быть установлены для контроля, какие файлы будут преобразованы. По умолчанию преобразуются все файлы, включая бинарные. См. Простые автоматические замены для примеров.
DOS2UNIX_REGEX: сопоставлять имена файлов на основе регулярного выражения.DOS2UNIX_FILES: соответствуют точным именам файлов.DOS2UNIX_GLOB: сопоставлять имена файлов на основе шаблона файлов оболочки.DOS2UNIX_WRKSRC: каталог, с которого начинать преобразования. По умолчанию${WRKSRC}.
17.25. drupal
Возможные аргументы: 7, module, theme
Автоматизирует установку порта, который является темой или модулем Drupal. Использовать с версией Drupal, которую ожидает порт. Например, USES=drupal:7,module означает, что этот порт создает модуль Drupal 7. Тему Drupal 7 можно указать с помощью USES=drupal:7,theme.
17.26. ebur128
Возможные аргументы: (нет), build, lib, run, test
Добавляет зависимость от пакета audio/ebur128. Позволяет прозрачно зависеть от вариантов rust или legacy, используя DEFAULT_VERSIONS в make.conf. Например, для использования устаревшей версии укажите DEFAULT_VERSIONS+=ebur128=legacy
Без аргументов поведение аналогично случаю с предоставлением аргумента lib. Остальные аргументы указывают соответствующую категорию зависимости.
17.27. eigen
Возможные аргументы: 2, 3, build (по умолчанию), run
Добавить зависимость от пакета math/eigen.
17.28. electronfix
Возможные аргументы: 31, 32, 33
Предоставить поддержку для простого портирования Electron-приложений, распространяемых в бинарной форме. Добавляет зависимость на этапах сборки и выполнения от devel/electron31, devel/electron32 или devel/electron33 в зависимости от используемого аргумента.
Фреймворк предоставляет следующие переменные, которые могут быть установлены портами:
ELECTRONFIX_SYMLINK_FILESСписок файлов для создания символьных ссылок из дистрибутива Electron.
ELECTRONFIX_MAIN_EXECUTABLEИмя файла основного исполняемого файла, который будет заменен оригинальным бинарным файлом Electron.
17.29. elfctl
Возможные аргументы: (отсутствуют), build (по умолчанию), stage
Установите управляющие заметки функций ELF-бинарных файлов, задав ELF_FEATURES.
Когда не указан аргумент или указан аргумент build, операции выполняются над бинарными файлами в BUILD_WRKSRC, а файлы, перечисленные в ELF_FEATURES, указываются относительно BUILD_WRKSRC. Когда указан аргумент stage, операции выполняются над бинарными файлами в STAGEDIR, а файлы, перечисленные в ELF_FEATURES, указываются относительно STAGEDIR.
ELF_FEATURES= featurelist:path/to/file1 \ featurelist:path/to/file2
Формат featurelist описан в elfctl(1).
17.30. elixir
Возможные аргументы: (отсутствуют)
Предоставить поддержку для портов, использующих lang/elixir. Добавляет зависимость во время сборки и выполнения на lang/elixir.
Предоставляемые фреймворком переменные:
ELIXIR_APP_NAMEНазвание приложения Elixir, как оно установлено в каталоге lib Elixir
ELIXIR_LIB_ROOTПуть к библиотекам Elixir по умолчанию
ELIXIR_APP_ROOTКорневая директория для этого приложения Elixir
ELIXIR_HIDDENПриложения, которые необходимо скрыть из пути выполнения кода; обычно
${PORTNAME}ELIXIR_LOCALEЛокаль UTF-8, которая будет использоваться Elixir во время сборки (подойдет любая локаль UTF-8)
MIX_CMDКоманда
mixMIX_COMPILEКоманда
mix, используемая для компиляции приложения на ElixirMIX_REWRITEАвтоматически заменять зависимости Mix на пути к коду
MIX_BUILD_DEPSСписок
BUILD_DEPENDSв формате категория/имя_порта (часто упоминаемый как "deps" в Erlang и Elixir)MIX_RUN_DEPSСписок
RUN_DEPENDSв формате категория/имя портаMIX_DOC_DIRSДополнительные каталоги документации для установки в
DOCSDIRMIX_DOC_FILESДополнительные файлы документации для установки в
DOCSDIR(обычно README.md)MIX_ENVОкружение для сборки Mix (в том же формате, что и
MAKE_ENV)MIX_ENV_NAMEИмя среды сборки Mix, обычно "prod"
MIX_BUILD_NAMEИмя выходного файла сборки в _build/, обычно
${MIX_ENV_NAME}MIX_TARGETИмя цели Mix, обычно "compile"
MIX_EXTRA_APPSСписок подприложений для сборки, если имеются
MIX_EXTRA_DIRSСписок дополнительных каталогов для установки в
ELIXIR_APP_ROOTMIX_EXTRA_FILESСписок дополнительных файлов для установки в
ELIXIR_APP_ROOT
17.31. emacs
Возможные аргументы: (нет) (по умолчанию), build, run, noflavors
Предоставляет поддержку для портов, требующих Emacs. Аргумент build создает зависимость сборки от Emacs. Аргумент run создает зависимость выполнения от Emacs. Если оба аргумента build и run отсутствуют, создаются зависимости сборки и выполнения от Emacs. Аргумент noflavors запрещает флейворы и подразумевается, если нет зависимости выполнения от Emacs.
Стандартный вариант Emacs для портов с USES=emacs можно определить в make.conf. Например, для варианта nox используйте DEFAULT_VERSIONS+= emacs=nox. Допустимые флейворы: full, canna, nox, wayland, devel_full, devel_nox.
Переменные, которые могут быть установлены портами:
EMACS_FLAVORS_EXCLUDEНЕ собирать эти флейворы Emacs. Если
EMACS_FLAVORS_EXCLUDEне определена и:существует зависимость во время выполнения от Emacs
аргумент noflavors не указан
то предполагаются все допустимые флейворы Emacs.
EMACS_NO_DEPENDSНЕ добавлять зависимости сборки или выполнения от Emacs. Это предотвратит создание вариантов, и никакие файлы байт-кода не будут сгенерированы как часть пакета.
Переменные, которые могут быть прочитаны портами:
EMACS_CMDКоманда Emacs с полным путём (например, /usr/local/bin/emacs-30.1)
EMACS_FLAVORИспользуется для зависимостей (например,
BUILD_DEPENDS= dash.el${EMACS_PKGNAMESUFFIX}>0:devel/dash@${EMACS_FLAVOR})EMACS_LIBDIRКаталог библиотек Emacs без
${PREFIX}(например, share/emacs)EMACS_LIBDIR_WITH_VERКаталог библиотеки без
${PREFIX}, включая версию (например, share/emacs/30.1)EMACS_MAJOR_VERОсновная версия Emacs (например, 30)
EMACS_PKGNAMESUFFIXPKGNAMESUFFIXдля различия вариантов EmacsEMACS_SITE_LISPDIRКаталог site-lisp Emacs без
${PREFIX}(например, share/emacs/site-lisp)EMACS_VERВерсия Emacs (например, 30.1)
EMACS_VERSION_SITE_LISPDIRКаталог site-lisp Emacs, включая номер версии (например, share/emacs/30.1/site-lisp)
17.32. erlang
Возможные аргументы: (нет), enc, rebar, rebar3
Добавляет зависимость на время сборки и выполнения от lang/erlang. В зависимости от аргумента, добавляет дополнительные зависимости для сборки. enc добавляет зависимость от devel/erlang-native-compiler, rebar добавляет зависимость от devel/rebar, а rebar3 добавляет зависимость от devel/rebar3.
В дополнение, следующие переменные доступны для порта:
ERL_APP_NAME: Имя приложения Erlang, как оно установлено в каталоге lib Erlang (без указания версии)ERL_APP_ROOT: Корневой каталог для этого приложения ErlangREBAR_CMD: Путь к команде "rebar"REBAR3_CMD: Путь к команде "rebar3"REBAR_PROFILE: Профиль RebarREBAR_TARGETS: Список целей Rebar (обычно compile, возможно escriptize)ERL_BUILD_NAME: Имя сборки для rebar3ERL_BUILD_DEPS: Список BUILD_DEPENDS в формате категория/имя_портаERL_RUN_DEPS: Список RUN_DEPENDS в формате категория/имя_портаERL_DOCS: Список файлов и каталогов документации
17.33. fakeroot
Возможные аргументы: (отсутствуют)
Изменяет некоторые стандартные поведения систем сборки для разрешения установки от имени пользователя. Дополнительную информацию о fakeroot можно найти на https://wiki.debian.org/FakeRoot.
17.34. fam
Возможные аргументы: (нет), fam, gamin
Использует монитор изменений файлов (FAM — File Alteration Monitor) как зависимость от библиотеки, либо devel/fam, либо devel/gamin. Конечные пользователи могут задать WITH_FAM_SYSTEM, чтобы указать свои предпочтения.
17.35. firebird
Возможные аргументы: (отсутствуют), 25
Добавить зависимость от клиентской библиотеке базы данных Firebird.
17.36. fonts
Возможные аргументы: (отсутствуют), fc, fontsdir (по умолчанию), none
Добавляет зависимость во время выполнения на инструменты, необходимые для регистрации шрифтов. В зависимости от аргумента добавляет строку @fc ${FONTSDIR}, строку @fontsdir ${FONTSDIR} или не добавляет строку, если аргумент none, в plist. FONTSDIR по умолчанию имеет значение ${PREFIX}/share/fonts/${FONTNAME}, а FONTNAME — ${PORTNAME}. Добавляет FONTSDIR в PLIST_SUB и SUB_LIST
17.38. fpc
Возможные аргументы: (нет), run
Обеспечить поддержку портов на основе Free Pascal. Установит компилятор Free Pascal и модули.
Добавляет зависимость сборки от lang/fpc.
Если указан аргумент run, также добавляется зависимость запуска.
17.39. fuse
Возможные аргументы: 2 (по умолчанию), 3
Порт будет зависеть от библиотеки FUSE и обрабатывать зависимость от модуля ядра в зависимости от версии FreeBSD.
17.40. gem
Возможные аргументы: (отсутствуют), noautoplist
Обработка сборки с RubyGems. Если используется noautoplist, список упаковки не генерируется автоматически.
Это подразумевает USES=ruby.
17.41. gettext
Возможные аргументы: (отсутствуют)
Устарело. Будет включать как gettext-runtime, так и gettext-tools.
17.42. gettext-runtime
Возможные аргументы: (отсутствуют), lib (по умолчанию), build, run
Использует пакет devel/gettext-runtime. По умолчанию, без аргументов или с аргументом lib, подразумевает зависимость от библиотеки libintl.so. Аргументы build и run подразумевают, соответственно, зависимость во время сборки и во время выполнения от gettext.
17.43. gettext-tools
Возможные аргументы: (отсутствуют), build (по умолчанию), run
Использует пакет devel/gettext-tools. По умолчанию, без аргумента или с аргументом build, регистрируется зависимость во время сборки от msgfmt. С аргументом run регистрируется зависимость во время выполнения.
17.44. ghostscript
Возможные аргументы: X, build, run, nox11
Можно указать конкретную версию X. Доступные версии: 7, 8, 9 и agpl (по умолчанию). nox11 указывает, что требуется версия порта -nox11. build и run добавляют зависимости на Ghostscript во время сборки и выполнения соответственно. По умолчанию добавляются зависимости как на сборку, так и на выполнение.
17.45. gl
Возможные аргументы: (отсутствуют)
Предоставляет простой способ зависеть от компонентов GL. Компоненты должны быть перечислены в USE_GL. Доступные компоненты:
eglдобавить зависимость от библиотеки libEGL.so из пакета graphics/libglvnd
gbmДобавить зависимость от библиотеки libgbm.so из пакета graphics/mesa-libs
glДобавить зависимость от библиотеки libGL.so из пакета graphics/libglvnd
glesv2Добавить зависимость от библиотеки libGLESv2.so из пакета graphics/libglvnd
glewДобавить зависимость от библиотеки libGLEW.so из пакета graphics/glew
gluДобавить зависимость от библиотеки libGLU.so из graphics/libGLU
glutДобавить зависимость от библиотеки libglut.so из graphics/freeglut
openglДобавить зависимость от библиотеки libOpenGL.so из graphics/libglvnd
17.46. gmake
Возможные аргументы: (отсутствуют)
Использует пакет devel/gmake как зависимость во время сборки и настраивает окружение для использования gmake в качестве стандартного make при сборке.
17.47. gnome
Возможные аргументы: (отсутствуют)
Предоставляет простой способ зависеть от компонентов GNOME. Компоненты должны быть перечислены в USE_GNOME. Доступные компоненты:
atkatkmmcairocairommdconfesoundevolutiondataserver3gconf2gconfmm26gdkpixbufgdkpixbuf2glib12glib20glibmmgnomecontrolcenter3gnomedesktop3gnomedesktop4gnomedocutilsgnomemenus3gnomemimedatagnomeprefixgnomesharp20gnomevfs2gsoundgtk-update-icon-cachegtk12gtk20gtk30gtkhtml3gtkhtml4gtkmm20gtkmm24gtkmm30gtksharp20gtksourceviewgtksourceview2gtksourceview3gtksourceviewmm3gvfsintlhackintltoolintrospectionlibartlgpl2libbonobolibbonobouilibgda5libgda5-uilibgdamm5libglade2libgnomelibgnomecanvaslibgnomekbdlibgnomeprintlibgnomeprintuilibgnomeuilibgsflibgtkhtmllibgtksourceviewmmlibidllibrsvg2libsigc++12libsigc++20libwncklibwnck3libxml++26libxml2libxsltmetacitynautilus3orbit2pangopangommpangox-compatpy3gobject3pygnome2pygobjectpygobject3pygtk2pygtksourceviewreferencehackvtevte3
Зависимость по умолчанию — на время сборки и выполнения, её можно изменить с помощью :build или :run. Например:
USES= gnome USE_GNOME= gnomemenus3:build intlhack
См. Использование GNOME для получения дополнительной информации.
17.48. go
Порты не следует создавать для библиотек Go, дополнительную информацию см. в Библиотеки Go. |
Возможные аргументы: (нет), N.NN, N.NN-devel, modules, no_targets, run
Устанавливает значения и цели по умолчанию, используемые для сборки ПО на Go. Добавляется зависимость сборки от порта компилятора Go, сопровождающие порта могут установить требуемую версию. По умолчанию сборка выполняется в режиме GOPATH. Если ПО на Go использует модули, режим с поддержкой модулей можно включить с помощью аргумента modules. no_targets настроит окружение сборки, как GO_ENV, GO_BUILDFLAGS, но пропустит создание целей извлечения (extract) и сборки (build). run также добавит зависимость выполнения от порта компилятора Go.
Процесс сборки контролируется несколькими переменными:
GO_MODULEИмя модуля приложения, указанное директивой
moduleвgo.mod. В большинстве случаев это единственная необходимая переменная для портов, использующих модули Go.GO_PKGNAMEИмя пакета Go при сборке в режиме GOPATH. Это каталог, который будет создан в
${GOPATH}/src. Если не задано явно и присутствуетGH_SUBDIRилиGL_SUBDIR, тоGO_PKGNAMEбудет выведено из них. Не требуется при сборке в режиме с поддержкой модулей.GO_TARGETПакеты для сборки. Значение по умолчанию —
${GO_PKGNAME}.GO_TARGETтакже может быть кортежем в форматеpackage:path, где path может быть либо простым именем файла, либо полным путём, начинающимся с${PREFIX}.GO_TESTTARGETПакеты для тестирования. Значение по умолчанию —
./…(текущий пакет и все подпакеты).CGO_CFLAGSДополнительные значения
CFLAGS, передаваемые компилятору C с помощьюgo.CGO_LDFLAGSДополнительные значения
LDFLAGS, передаваемые компилятору C черезgo.GO_BUILDFLAGSДополнительные аргументы сборки, передаваемые в
go build.GO_TESTFLAGSДополнительные аргументы сборки, передаваемые в
go test.
См. Сборка приложений на Go для примеров использования.
17.49. gperf
Возможные аргументы: (отсутствуют)
Добавить зависимость во время сборки на devel/gperf, если gperf отсутствует в базовой системе.
17.50. grantlee
Возможные аргументы: 5, selfbuild
Обработать зависимость от Grantlee. Указать 5 для зависимости от версии на основе Qt5, devel/grantlee5. selfbuild используется внутри devel/grantlee5 для получения номеров их версий.
17.51. groff
Возможные аргументы: build, run, both
Регистрирует зависимость от textproc/groff, если пакет отсутствует в базовой системе.
17.52. gssapi
Возможные аргументы: (отсутствуют), base (по умолчанию), heimdal, mit, flags, bootstrap
Обрабатывает зависимости, необходимые для использования GSS-API. Доступны только библиотеки, предоставляющие механизм Kerberos. По умолчанию (или при значении base) используется библиотека GSS-API из базовой системы. Также можно установить значение heimdal для использования security/heimdal или mit для использования security/krb5.
Если локальная установка Kerberos не находится в LOCALBASE, установите HEIMDAL_HOME (для heimdal) или KRB5_HOME (для krb5) на каталог установки Kerberos.
Эти переменные экспортируются для использования портами:
GSSAPIBASEDIRGSSAPICPPFLAGSGSSAPIINCDIRGSSAPILDFLAGSGSSAPILIBDIRGSSAPILIBSGSSAPI_CONFIGURE_ARGS
Опция flags может быть указана вместе с base, heimdal или mit для автоматического добавления GSSAPICPPFLAGS, GSSAPILDFLAGS и GSSAPILIBS в CFLAGS, LDFLAGS и LDADD соответственно. Например, используйте base,flags.
Опция bootstrap — это специальный префикс, предназначенный только для использования в security/krb5 и security/heimdal. Например, используйте bootstrap,mit.
OPTIONS_SINGLE= GSSAPI
OPTIONS_SINGLE_GSSAPI= GSSAPI_BASE GSSAPI_HEIMDAL GSSAPI_MIT GSSAPI_NONE
GSSAPI_BASE_USES= gssapi
GSSAPI_BASE_CONFIGURE_ON= --with-gssapi=${GSSAPIBASEDIR} ${GSSAPI_CONFIGURE_ARGS}
GSSAPI_HEIMDAL_USES= gssapi:heimdal
GSSAPI_HEIMDAL_CONFIGURE_ON= --with-gssapi=${GSSAPIBASEDIR} ${GSSAPI_CONFIGURE_ARGS}
GSSAPI_MIT_USES= gssapi:mit
GSSAPI_MIT_CONFIGURE_ON= --with-gssapi=${GSSAPIBASEDIR} ${GSSAPI_CONFIGURE_ARGS}
GSSAPI_NONE_CONFIGURE_ON= --without-gssapi17.53. gstreamer
Возможные аргументы: (отсутствуют)
Предоставляет простой способ зависимости от компонентов GStreamer. Компоненты должны быть перечислены в USE_GSTREAMER. Доступные компоненты:
a52decaalibamrnbamrwbdecaomassrenderbadbs2bcairocdiocdparanoiachromaprintcurldashdtlsdtsdvdvddvdreadediting-servicesfaacfaadflacflitegdkpixbufglgmegnonlingoodgsmgtk4gtkhalhlsjackjpegkatekmsladspalamelibavlibcacalibde265libmmslibvisuallv2mmmodplugmpeg2decmpeg2encmpg123mplexmusepackneonoggopencvopenexropenh264openjpegopenmptopuspangopngpulseqtresindvdrsvgrtmpshout2sidplaysmoothstreamingsndfilesndiosoundtouchsoupspandspspeexsrtptaglibtheorattmltwolameuglyv4l2vorbisvpxvulkanwavpackwebpwebrtcdspx264x265xximagesrczbar
17.54. guile
Возможные аргументы: (нет), X.Y, flavors, build, run, alias, conflicts
Добавляет зависимость от Guile. По умолчанию это зависимость от соответствующей библиотеки libguile*.so, если не переопределено опциями build и/или run. Опция alias настраивает BINARY_ALIAS соответствующим образом (см. Использование BINARY_ALIAS).
Версия по умолчанию устанавливается с помощью обычного механизма DEFAULT_VERSIONS; если версия по умолчанию не входит в список указанных версий, то используется последняя доступная версия из списка.
Приложения, использующие Guile, обычно собираются только для одной версии Guile. Однако модули расширений или библиотек должны использовать опцию flavors для сборки с несколькими флейворами.
Для получения дополнительной информации см. Использование Guile.
17.55. horde
Возможные аргументы: (отсутствуют)
Добавить зависимости времени сборки и выполнения для devel/pear-channel-horde. Другие зависимости Horde можно добавить с помощью USE_HORDE_BUILD и USE_HORDE_RUN. Дополнительную информацию см. в разделе Модули Horde.
17.56. iconv
Возможные аргументы: (нет), lib, build, patch, translit, wchar_t
Использует функции iconv, либо из порта converters/libiconv как зависимость на этапе сборки и выполнения, либо из базовой системы. По умолчанию, без аргументов или с аргументом lib, подразумевает iconv с зависимостями на этапе сборки и выполнения. build подразумевает зависимость на этапе сборки, а patch — на этапе патчинга. Если порт использует расширения WCHAR_T или //TRANSLIT для iconv, добавьте соответствующие аргументы, чтобы использовалась правильная версия iconv. Для получения дополнительной информации см. Использование iconv.
17.57. imake
Возможные аргументы: (нет), env, notall, noman
Добавить devel/imake как зависимость на этапе сборки и выполнить xmkmf -a на этапе configure. Если указан аргумент env, цель configure не устанавливается. Если флаг -a вызывает проблемы для порта, добавьте аргумент notall. Если xmkmf не генерирует цель install.man, добавьте аргумент noman.
17.58. java
Возможные аргументы: (нет), ant, build, extract, run
По умолчанию используется USES=java:build,run, если аргументы не предоставлены и NO_BUILD не определен. Если NO_BUILD определен, используется USES=java:run. Если указан аргумент ant, порт использует Apache Ant. Если указан аргумент build, порт JDK добавляется в зависимости сборки. Если указан аргумент extract, порт JDK добавляется в зависимости извлечения. Если указан аргумент run, порт JDK добавляется в зависимости выполнения.
Фреймворк предоставляет следующие переменные, которые могут быть установлены портом:
JAVA_VERSIONСписок подходящих версий Java для порта, разделенных пробелами. Необязательный символ
+позволяет указать диапазон версий. (допустимые значения8[+],11[+],17[+],18[+],19[+],20[+],21[+],22[+],22[+])JAVA_OSСписок поддерживаемых операционных систем для порта JDK, разделённых пробелами. (допустимые значения:
native,linux)JAVA_VENDORСписок подходящих поставщиков портов JDK для порта, разделенных пробелами. (допустимые значения:
openjdk,oracle)
Фреймворк предоставляет следующие переменные для чтения портом:
JAVA_PORTИмя порта JDK. (например, 'java/openjdk8')
JAVA_PORT_VERSIONВерсия порта JDK. (например, '8')
JAVA_PORT_OSИспользуемая операционная система для порта JDK. (например, 'linux')
JAVA_PORT_VENDORПоставщик порта JDK. (например, 'openjdk')
JAVA_PORT_OS_DESCRIPTIONОписание операционной системы, используемой портом JDK. (например, 'Linux')
JAVA_PORT_VENDOR_DESCRIPTIONОписание поставщика порта JDK. (например, 'OpenJDK BSD Porting Team')
JAVA_HOMEПуть к каталогу установки JDK. (например, /usr/local/openjdk8)
JAVACПуть к используемому компилятору Java. (например, /usr/local/openjdk8/bin/javac или /usr/local/bin/javac)
JARПуть к используемому инструменту JAR. (например, /usr/local/openjdk8/bin/jar или /usr/local/bin/fastjar)
APPLETVIEWERПуть к утилите appletviewer. (например, /usr/local/linux-jdk1.8.0/bin/appletviewer)
JAVAПуть к исполняемому файлу
java. Используется для запуска программ на Java. (например, /usr/local/openjdk8/bin/java)JAVADOCПуть к программе
javadoc.JAVAHПуть к программе
javah.JAVAPПуть к программе
javap.JAVA_KEYTOOLПуть к утилите
keytool.JAVA_N2AПуть к инструменту
native2ascii.JAVA_POLICYTOOLПуть к программе
policytool.JAVA_SERIALVERПуть к утилите
serialver.RMICПуть к генератору RMI-заглушек/скелетов,
rmic.RMIREGISTRYПуть к программе реестра RMI,
rmiregistry.RMIDПуть к программе демона RMI.
JAVA_CLASSESПуть к архиву, содержащему файлы классов JDK. В большинстве JDK это ${JAVA_HOME}/jre/lib/rt.jar.
JAVASHAREDIRБазовый каталог для всех общих ресурсов Java.
JAVAJARDIRКаталог, в котором порт должен устанавливать JAR-файлы.
JAVALIBDIRКаталог, в котором находятся JAR-файлы, установленные другими портами.
17.59. jpeg
Возможные аргументы: lib (по умолчанию, подразумевается), build, run
Помощь в обработке зависимостей от jpeg.
Если указан аргумент lib или аргументы не предоставлены, то в порт добавляется зависимость от библиотеки.
Если указан аргумент build, то в порт добавляется зависимость сборки.
Если указан аргумент run, то к порту добавляется зависимость времени выполнения.
Если указан аргумент both, то к порту добавляется зависимость для сборки и зависимость для выполнения.
Фреймворк предоставляет следующую переменную, которая может быть установлена портами:
JPEG_PORTУказывает реализацию JPEG для использования. Возможные значения:
graphics/jpeg-turbo (по умолчанию)
17.60. kde
Возможные аргументы: 5
Добавить зависимость от компонентов KDE. Подробнее см. в Использование KDE.
17.61. kmod
Возможные аргументы: (отсутствуют), debug
Заполняет шаблон для портов модулей ядра, в настоящее время:
Добавьте
kldвCATEGORIES.Установите
SSP_UNSAFE.Установите
IGNORE, если исходные коды ядра не найдены вSRC_BASE.Определить
KMODDIRпо умолчанию как /boot/modules, добавить его вPLIST_SUBиMAKE_ENV, а также создать его при установке. ЕслиKMODDIRустановлен в /boot/kernel, он будет перезаписан в /boot/modules. Это предотвращает повреждение пакетов при обновлении ядра из-за переименования /boot/kernel в /boot/kernel.old в процессе.Обрабатывать перекрестные ссылки на модули ядра при установке и удалении, используя
@kld.Если указан аргумент
debug, порт может установить отладочную версию модуля в KERN_DEBUGDIR/KMODDIR. По умолчаниюKERN_DEBUGDIRкопируется изDEBUGDIRи устанавливается в /usr/lib/debug. Фреймворк позаботится о создании и удалении необходимых каталогов.
17.62. kodi
Возможные аргументы: (отсутствуют), noautoplist
Обеспечить поддержку дополнений для multimedia/kodi. Если указан аргумент noautoplist, автоматическое создание plist не выполняется.
17.63. lazarus
Возможные аргументы: (отсутствуют), gtk2 (по умолчанию), qt5, qt6, flavors
Обеспечить поддержку портов на основе editors/lazarus.
Если аргументы не предоставлены или указан gtk2, приложение lazarus-app будет собрано с интерфейсом gtk2, и порт editors/lazarus будет собран с интерфейсом gtk2.
Если указан аргумент qt5, приложение lazarus-app собирается с интерфейсом qt5.
Если указан аргумент qt6, приложение lazarus-app собирается с интерфейсом qt6.
Если указан аргумент flavors, приложение lazarus-app собирается с поддержкой функций флейворов.
Если порт не требует автоматической компиляции файлов проекта lazarus, можно определить следующую переменную:
NO_LAZBUILD= yes
Доступны следующие переменные для портов:
LAZARUS_PROJECT_FILESСписок lpi-файлов. Он не должен быть пустым. По умолчанию: пусто
LAZARUS_DIRПуть к директории установки lazarus. По умолчанию: ${LOCALBASE}/share/lazarus-${LAZARUS_VER}
LAZBUILD_ARGSДополнительные аргументы lazbuild. В большинстве случаев это может быть
-d. Подробнее см. lazbuild(1). По умолчанию: пустоLAZARUS_NO_FLAVORSНе собирать эти флейворы lazarus. Если
LAZARUS_NO_FLAVORSне определена, то предполагаются все допустимые флейворы lazarus.WANT_LAZARUS_DEVELЕсли установлено значение
yes, то используйте lazarus/devel как зависимость сборки.
17.64. ldap
Возможные аргументы: (нет), <версия>, клиент, сервер
Регистрирует зависимость от пакета net/openldap. Использует конкретную <версию> (без точечной нотации), если она указана. В противном случае пытается найти установленную версию. При необходимости возвращается к версии по умолчанию, указанной в bsd.default-versions.mk. client указывает на зависимость во время выполнения от клиентской библиотеки. Это также значение по умолчанию. server указывает на зависимость во время выполнения от сервера.
Следующие переменные могут быть доступны для порта:
IGNORE_WITH_OPENLDAPЭта переменная может быть определена, если порты не поддерживают одну или несколько версий OpenLDAP.
WITH_OPENLDAP_VERПользовательская переменная для установки версии OpenLDAP.
OPENLDAP_VERОбнаруженная версия OpenLDAP.
17.66. libarchive
Возможные аргументы: (отсутствуют)
Регистрирует зависимость от archivers/libarchive. Любые порты, зависящие от libarchive, должны включать USES=libarchive.
17.67. libedit
Возможные аргументы: (отсутствуют)
Регистрирует зависимость от devel/libedit. Все порты, зависящие от libedit, должны включать USES=libedit.
17.68. libtool
Возможные аргументы: (нет), keepla, build
Исправляет скрипты libtool. Это должно быть добавлено во все порты, использующие libtool. Аргумент keepla может быть использован для сохранения файлов .la. Некоторые порты не поставляются с собственной копией libtool и требуют зависимость во время сборки от devel/libtool, используйте аргумент :build для добавления такой зависимости.
17.69. linux
Возможные аргументы: c6, c7
Порт фреймворка совместимости с Linux. Укажите c6 для зависимостей от пакетов CentOS 6. Укажите c7 для зависимостей от пакетов CentOS 7. Доступные пакеты:
allegroalsa-plugins-ossalsa-plugins-pulseaudioalsalibatkavahi-libsbasecairocups-libscurlcyrus-sasl2dbusglibdbuslibsdevtoolsdriexpatflacfontconfiggdkpixbuf2gnutlsgraphite2gtk2harfbuzzjasperjbigkitjpeglibasyncnslibaudiofilelibelflibgcryptlibgfortranlibgpg-errorlibmnglibogglibpciaccesslibsndfilelibsouplibssh2libtasn1libthailibtheoralibv4llibvorbislibxml2mikmodnaslibsncurses-basensprnssopenalopenal-softopenldapopenmotifopensslpangopixmanpngpulseaudio-libsqtqt-x11qtwebkitscimlibssdl12sdlimagesdlmixersqlite3tcl85tcp_wrappers-libstifftk85uclxorglibs
17.70. llvm
Возможные аргументы: (нет), XY, min=XY, max=XY, build, run, lib
Добавляет зависимость от LLVM. По умолчанию это зависимость для сборки, если не переопределено опциями run или lib. Версия по умолчанию задаётся в LLVM_DEFAULT. Также можно указать конкретную версию. Минимальную и максимальную версии можно указать с помощью параметров min и max соответственно. Фреймворк портов экспортирует следующие переменные в порт:
LLVM_VERSIONВерсия, выбранная из аргументов к llvm.mk
LLVM_PORTВыбранный порт llvm
LLVM_CONFIGllvm-configвыбранного портаLLVM_LIBLLVMlibLLVM.soвыбранного портаLLVM_PREFIXПрефикс инсталляции выбранного порта
17.71. localbase
Возможные аргументы: (отсутствуют), ldflags
Гарантирует использование библиотек из зависимостей в LOCALBASE вместо библиотек из базовой системы. Указывает ldflags для добавления -L${LOCALBASE}/lib в LDFLAGS вместо LIBS. Порты, зависящие от библиотек, которые также присутствуют в базовой системе, должны использовать эту опцию. Она также используется внутри несколькими другими USES.
17.72. lua
Возможные аргументы: (нет), XY, XY+, -XY, XY-ZA, module, flavors, build, run, env
Добавляет зависимость от Lua. По умолчанию это зависимость от библиотеки, если не переопределено опциями build и/или run. Опция env предотвращает добавление любой зависимости, при этом все обычные переменные остаются определенными.
Версия по умолчанию устанавливается с помощью обычного механизма DEFAULT_VERSIONS, если только версия или диапазон версий не указаны в качестве аргумента, например, 51 или 51-54.
Приложения, использующие Lua, обычно собираются только для одной версии Lua. Однако модули библиотек, предназначенные для загрузки кодом Lua, должны использовать опцию module для сборки с несколькими вариантами.
Для получения дополнительной информации см. Использование Lua.
17.73. luajit
Возможные аргументы: (нет), X
Добавляет зависимость от среды выполнения luajit. Можно указать конкретную версию X. Доступные версии: luajit, luajit-devel, luajit-openresty
После включения bsd.port.options.mk или bsd.port.pre.mk порт может проверять эти переменные:
LUAJIT_VERВыбранная версия luajit
LUAJIT_INCDIRПуть к заголовочным файлам luajit
LUAJIT_LUAVERКакой версии спецификации luajit выбрана (2.0 для luajit, иначе 2.1)
Для получения дополнительной информации см. Использование Lua.
17.74. lxqt
Возможные аргументы: (отсутствуют)
Обработка зависимостей для рабочей среды LXQt. Используйте USE_LXQT для выбора необходимых компонентов для порта. Дополнительную информацию см. в разделе Использование LXQt.
17.75. magick
Возможные аргументы: (нет), X, build, nox11, run, test
Добавить зависимость библиотеки от ImageMagick. Можно указать конкретную версию X. Доступные версии: 6 и 7 (по умолчанию). nox11 означает, что требуется версия порта -nox11. build, run и test добавляют зависимости на сборку, выполнение и тестирование для ImageMagick.
17.76. makeinfo
Возможные аргументы: (отсутствуют)
Добавить зависимость во время сборки на makeinfo, если его нет в базовой системе.
17.77. makeself
Возможные аргументы: (отсутствуют)
Указывает, что файлы дистрибутива являются архивами makeself и устанавливает соответствующие зависимости.
17.78. mate
Возможные аргументы: (отсутствуют)
Предоставляет простой способ зависимостей от компонентов MATE. Компоненты должны быть перечислены в USE_MATE. Доступные компоненты:
autogencajacommoncontrolcenterdesktopdialogsdocutilsiconthemeintlhackintltoollibmatekbdlibmateweathermarcomenusnotificationdaemonpanelplumapolkitsessionsettingsdaemon
Зависимость по умолчанию — на время сборки и выполнения, её можно изменить с помощью :build или :run. Например:
USES= mate USE_MATE= menus:build intlhack
17.79. meson
Возможные аргументы: (отсутствуют)
Предоставить поддержку для проектов на основе Meson. Дополнительную информацию смотрите в Использование meson.
17.80. metaport
Возможные аргументы: (отсутствуют)
Устанавливает следующие переменные для упрощения создания метапорта: MASTER_SITES, DISTFILES, EXTRACT_ONLY, NO_BUILD, NO_INSTALL, NO_MTREE, NO_ARCH.
17.81. minizip
Возможные аргументы: (отсутствуют), ng
Добавляет зависимость библиотеки от archivers/minizip или archivers/minizip-ng соответственно.
17.82. mlt
Возможные аргументы: 7, nodepend
Обеспечить поддержку портов, зависящих от multimedia/mlt7.
Если указан аргумент nodepend, зависимости от библиотек не создаются. Этот аргумент имеет смысл только для портов multimedia/mlt7*.
17.83. mysql
Возможные аргументы: (отсутствуют), версия, client (по умолчанию), server, embedded
Предоставить поддержку MySQL. Если версия не указана, попытаться определить установленную версию. В случае неудачи использовать версию по умолчанию, MySQL-5.6. Возможные версии: 55, 55m, 55p, 56, 56p, 56w, 57, 57p, 80, 100m, 101m и 102m. Суффиксы m и p обозначают флейворс MariaDB и Percona для MySQL. Параметры server и embedded добавляют зависимости во время сборки и выполнения на сервер MySQL. При использовании server или embedded добавьте client, чтобы также включить зависимость от libmysqlclient.so. Порт может установить IGNORE_WITH_MYSQL, если некоторые версии не поддерживаются.
Фреймворк устанавливает MYSQL_VER в обнаруженную версию MySQL.
17.84. mono
Возможные аргументы: (отсутствуют), nuget
Добавляет зависимость от фреймворка Mono (в настоящее время только C#), устанавливая соответствующие зависимости.
Укажите nuget, если порт использует пакеты nuget. NUGET_DEPENDS должен содержать имена и версии пакетов nuget в формате имя=версия. Можно добавить необязательное расположение пакета (origin), используя имя=версия:_ расположение _.
Вспомогательная цель buildnuget выведет содержимое NUGET_DEPENDS на основе предоставленного файла packages.config.
17.85. motif
Возможные аргументы: (отсутствуют)
Использует x11-toolkits/open-motif как зависимость библиотеки. Конечные пользователи могут установить WANT_LESSTIF в make.conf, чтобы использовать x11-toolkits/lesstif как зависимость вместо x11-toolkits/open-motif. Аналогично, установка WANT_OPEN_MOTIF_DEVEL в make.conf добавит зависимость от x11-toolkits/open-motif-devel
17.86. mpi
Возможные аргументы: mpich (по умолчанию), openmpi
Обеспечить поддержку портов, зависящих от MPI.
Если указан аргумент mpich, в порт добавляется зависимость от net/mpich.
Если указан аргумент openmpi, в порт добавляется зависимость от net/openmpi.
Фреймворк портов предоставляет следующие переменные, которые могут быть прочитаны портом:
MPI_LIBSБиблиотеки, необходимые для связывания программ с использованием
MPI.MPI_CFLAGSФлаги компилятора, необходимые для сборки программ с использованием
MPI.MPICCРасположение исполняемого файла
mpicc. По умолчанию: ${MPI_HOME}/bin/mpicc.MPICXXРасположение исполняемого файла
mpicxx. По умолчанию: ${MPI_HOME}/bin/mpicxx.MPIF90Расположение исполняемого файла
mpif90. По умолчанию: ${MPI_HOME}/bin/mpif90.MPIFCТо же, что и выше.
MPI_HOMEКаталог установки
MPI. По умолчанию используется${LOCALBASE}дляMPICH.MPIEXECРасположение исполняемого файла
mpiexec. По умолчанию: ${MPI_HOME}/bin/mpiexec.MPIRUNРасположение исполняемого файла
mpirun. По умолчанию: ${MPI_HOME}/bin/mpirun.
17.87. ncurses
Возможные аргументы: (нет), base, port
Использует ncurses и устанавливает некоторые полезные переменные.
17.88. nextcloud
Возможные аргументы: (отсутствуют)
Добавляет поддержку приложений Nextcloud, добавляя зависимость во время выполнения на www/nextcloud.
17.89. ninja
Возможные аргументы: (нет), build, make (по умолчанию), run
Если указаны аргументы build или run, это соответственно добавляет зависимость во время сборки или выполнения от пакета devel/ninja. Если указан make или аргументы не предоставлены, используется ninja для сборки порта вместо make. make подразумевает build. Если переменная NINJA_DEFAULT установлена в samurai, тогда зависимости устанавливаются для пакета devel/samurai вместо этого.
17.90. nodejs
Возможные аргументы: (нет), build, run, current, lts, 10, 14, 16,
17.
Использует nodejs. Добавляет зависимость от пакета www/node*. Если указана поддерживаемая версия, то также необходимо указать run и/или build.
17.91. objc
Возможные аргументы: (отсутствуют)
Добавить зависимости Objective C (компилятор, библиотека времени выполнения), если базовая система их не поддерживает.
17.92. ocaml
Возможные аргументы: (нет), build, camlp4, dune, findlib, findplist, ldconfig, run, tk, tkbuild, tkrun, wash
Обеспечить поддержку OCaml.
Если аргументы не указаны, по умолчанию используются build, run.
Если указан аргумент build, то lang/ocamlc добавляется в BUILD_DEPENDS, EXTRACT и PATCH_DEPENDS.
Если указан аргумент camlp4, то для сборки используется devel/ocamlp4.
Если указан аргумент dune, то devel/ocaml-dune используется как система сборки.
Если указан аргумент findlib, то для установки пакетов будет использоваться ocamlfind. Директории пакетов будут автоматически удалены.
Если указан аргумент findplist, то содержимое целевых каталогов findlib будет добавлено автоматически.
Если указан аргумент ldconfig, то файл ld.conf OCaml будет обработан автоматически. При использовании dune Dune может устанавливать stublibs в директориях пакетов site-lib или в отдельной директории ниже DUNE_LIBDIR site-lib. Установите, если ваш порт устанавливает общие библиотеки в ocaml
Если указан аргумент run, добавить ocamlc в RUN_DEPENDS.
Если указан аргумент tk, то в порт добавляется зависимость на сборку и выполнение от пакета x11-toolkits/ocaml-labltk. Подразумевает tkbuild и tkrun.
Если указан аргумент tkbuild, то пакет x11-toolkits/ocaml-labltk добавляется в BUILD_DEPENDS, EXTRACT и PATCH_DEPENDS.
Если указан аргумент tkrun, то x11-toolkits/ocaml-labltk добавляется в RUN_DEPENDS.
Если указан аргумент wash, общие каталоги Ocaml будут очищены при удалении. Полезно при установке в нестандартный PREFIX.
Портом могут быть установлены следующие переменные:
OCAML_PKGDIRSКаталоги в site-lib для обработки, если указан аргумент
findlib. По умолчанию:${PORTNAME}OCAML_LDLIBSКаталоги в
PREFIX, которые будут автоматически добавлены/удалены из ld.conf. По умолчанию:${OCAML_SITELIBDIR}/${PORTNAME}OCAML_PACKAGESСписок пакетов для сборки и установки. По умолчанию
${PORTNAME}
17.93. octave
Возможные аргументы: (нет), env
Использует math/octave. env загружает только одну переменную окружения OCTAVE_VERSION.
17.94. openal
Возможные аргументы: al, soft (по умолчанию), si, alut
Использует OpenAL. Бэкенд может быть указан, с программной реализацией по умолчанию. Пользователь может указать предпочтительный бэкенд с помощью WANT_OPENAL. Допустимые значения для этой настройки: soft (по умолчанию) и si.
17.95. pathfix
Возможные аргументы: (отсутствуют)
Ищите Makefile.in и configure в PATHFIX_WRKSRC (по умолчанию WRKSRC) и исправляйте стандартные пути, чтобы они соответствовали иерархии FreeBSD. Например, исправляется каталог установки для файлов .pc pkgconfig на ${PREFIX}/libdata/pkgconfig. Если порт использует USES=autoreconf, Makefile.am будет автоматически добавлен в PATHFIX_MAKEFILEIN.
Если порт USES=cmake, он будет искать файл CMakeLists.txt в PATHFIX_WRKSRC. При необходимости это имя файла по умолчанию можно изменить с помощью PATHFIX_CMAKELISTSTXT.
17.96. pear
Возможные аргументы: env
Добавляет зависимость от пакета devel/pear. Настраивает поведение по умолчанию для программного обеспечения, использующего PHP Extension and Application Repository. Использование аргументов env только устанавливает переменные окружения PEAR. Дополнительную информацию см. в Модули PEAR.
17.97. perl5
Возможные аргументы: (отсутствуют)
Зависит от Perl. Настройка выполняется с помощью USE_PERL5.
USE_PERL5 может содержать фазы, в которых используется Perl: extract, patch, build, run или test.
USE_PERL5 также может содержать configure, modbuild или modbuildtiny, если требуется Makefile.PL, Build.PL или вариант Build.PL для Module::Build::Tiny.
USE_PERL5 по умолчанию имеет значение build run. При использовании configure, modbuild или modbuildtiny, build и run подразумеваются автоматически.
См. Использование Perl для получения дополнительной информации.
17.98. pgsql
Возможные аргументы: (нет), X.Y, X.Y+, X.Y-, X.Y-Z.A
Предоставить поддержку PostgreSQL. Ответственный за порт может указать требуемую версию. Можно указать минимальную и максимальную версии или диапазон; например, 9.0-, 8.4+, 8.4-9.2
По умолчанию добавляемая зависимость будет клиентской, но если порту требуются дополнительные компоненты, это можно указать с помощью WANT_PGSQL=компонент[:цель]; например, WANT_PGSQL=server:configure pltcl plperl. Доступные компоненты:
clientcontribdocspgtclplperlplpythonpltclserver
17.99. php
Возможные аргументы: (нет), phpize, ext, zend, build, cli, cgi, mod, web, embed, pecl, flavors, noflavors
Обеспечить поддержку PHP. Добавить зависимость во время выполнения на версию PHP по умолчанию, lang/php81.
phpizeИспользуется для создания расширения PHP. Поддерживает флейворы.
extИспользуется для сборки, установки и регистрации расширения PHP. Поддерживает флейворы.
zendИспользуется для сборки, установки и регистрации Zend-расширения. Поддерживает флейворы.
buildУстановить PHP также как зависимость во время сборки.
cliТребуется версия PHP для командной строки.
cgiТребуется CGI-версия PHP.
modТребуется модуль Apache для PHP.
webТребуется модуль Apache или CGI-версия PHP.
embedТребуется встроенная версия библиотеки PHP.
peclУстановить значения по умолчанию для загрузки расширений PHP из репозитория PECL. Включает флейворы.
flavorsВключить автоматическую генерацию флейворов PHP. Флейворы будут созданы для всех версий PHP, за исключением указанных в
IGNORE_WITH_PHP.noflavorsОтключить автоматическое создание флейворов PHP. Должно использоваться только с расширениями, предоставляемыми самим PHP.
Переменные используются для указания необходимых модулей PHP, а также версий PHP, которые поддерживаются.
USE_PHPСписок необходимых расширений PHP во время выполнения. Добавьте
:buildк названию расширения, чтобы указать зависимость во время сборки. Пример:pcre xml:build gettext
IGNORE_WITH_PHPПорт не работает с PHP указанной версии. Возможные значения можно посмотреть в содержимом
_ALL_PHP_VERSIONSв Mk/Uses/php.mk.
При сборке расширения PHP или Zend с помощью :ext или :zend, можно задать следующие переменные:
PHP_MODNAMEИмя расширения PHP или Zend. Значение по умолчанию:
${PORTNAME}.PHP_HEADER_DIRSСписок подкаталогов, из которых следует устанавливать заголовочные файлы. Фреймворк всегда будет устанавливать заголовочные файлы, находящиеся в том же каталоге, что и расширение.
PHP_MOD_PRIOПриоритет загрузки расширения. Это число от
00до99.Для расширений, которые не зависят от других расширений, приоритет автоматически устанавливается в
20, а для расширений, зависящих от другого расширения, приоритет автоматически устанавливается в30. Некоторые расширения могут требовать загрузки перед всеми остальными, например, www/php56-opcache. Некоторые могут требовать загрузки после расширения с приоритетом30. В таком случае добавьтеPHP_MOD_PRIO=XXв Makefile порта. Например:USES= php:ext USE_PHP= wddx PHP_MOD_PRIO= 40
Эти переменные доступны для использования в PKGNAMEPREFIX или PKGNAMESUFFIX:
PHP_PKGNAMEPREFIXСодержит
php_XY_-, где XY — версия PHP текущей редакции. Используется с расширениями и модулями PHP.PHP_PKGNAMESUFFIXСодержит
-php_XY_, где XY — версия PHP текущего варианта. Используется с PHP-приложениями.PECL_PKGNAMEPREFIXСодержит
php_XY_-pecl-, где XY — версия PHP текущей редакции. Используется с модулями PECL.
С вариантами сборки все расширения PHP, расширения PECL, модули PEAR должны иметь разные имена пакетов, поэтому они должны использовать одну из трёх переменных в |
17.100. pkgconfig
Возможные аргументы: (отсутствуют), build (по умолчанию), run, both
Использует devel/pkgconf. Без аргументов или с аргументом build подразумевает зависимость от pkg-config во время сборки. run подразумевает зависимость во время выполнения, а both — зависимости как во время выполнения, так и во время сборки.
17.101. pure
Возможные аргументы: (нет), ffi
Использует lang/pure. В основном применяется для сборки портов, зависящих от pure. С аргументом ffi подразумевает devel/pure-ffi как зависимость во время выполнения.
17.102. pyqt
Возможные аргументы: (нет), 4, 5
Использует PyQt. Если порт является частью самого PyQT, установите PYQT_DIST. Используйте USE_PYQT для выбора необходимых порту компонентов. Доступные компоненты:
coredbusdbussupportdemodesignerdesignerplugindocguimultimedianetworkopenglqscintilla2sipsqlsvgtestwebkitxmlxmlpatterns
Эти компоненты доступны только с PyQT4:
assistantdeclarativehelpphononscriptscripttools
Эти компоненты доступны только с PyQT5:
multimediawidgetsprintsupportqmlserialportwebkitwidgetswidgets
Зависимость по умолчанию для каждого компонента — это время сборки и выполнения. Чтобы выбрать только сборку или выполнение, добавьте _build или _run к имени компонента. Например:
USES= pyqt USE_PYQT= core doc_build designer_run
17.103. pytest
Возможные аргументы: (нет), 4
Вводит новую зависимость от devel/pytest. Он определяет цель do-test, которая будет правильно запускать тесты. Используйте аргумент, чтобы зависеть от определённой версии devel/pytest. Для портов, использующих devel/pytest, рекомендуется использовать это вместо конкретной цели do-test. Фреймворк предоставляет порту следующие переменные:
PYTEST_ARGSДополнительные аргументы для pytest (по умолчанию пусто).
PYTEST_IGNORED_TESTSсписки шаблонов
pytest -kдля игнорирования тестов (по умолчанию пустые). Для тестов, которые не должны проходить, например, требующих доступа к базе данных.PYTEST_BROKEN_TESTSсписки шаблонов
pytest -kтестов для игнорирования (по умолчанию пустые). Для сломанных тестов, которые требуют исправления.
В дополнение следующие переменные могут быть заданы пользователем:
PYTEST_ENABLE_IGNORED_TESTSВключить тесты, которые в противном случае игнорируются
PYTEST_IGNORED_TESTS.PYTEST_ENABLE_BROKEN_TESTSВключить тесты, которые в противном случае игнорируются
PYTEST_BROKEN_TESTS.PYTEST_ENABLE_ALL_TESTSВключить тесты, которые в противном случае игнорируются
PYTEST_IGNORED_TESTSиPYTEST_BROKEN_TESTS.
17.104. python
Возможные аргументы: (нет), X.Y, X.Y+, -X.Y, X.Y-Z.A, patch, build, run, test
Использует Python. Можно указать поддерживаемую версию или диапазон версий. Если Python требуется только во время сборки, выполнения или тестирования, его можно установить как зависимость для сборки, выполнения или тестирования с помощью build, run или test. Если Python также требуется на этапе исправлений, используйте patch. Дополнительную информацию см. в разделе Использование Python.
USES=python:env можно использовать, когда необходимы переменные, экспортируемые фреймворком, но зависимость от Python не требуется. Это может быть полезно при использовании с USES=shebangfix, если цель состоит только в исправлении shebang без добавления зависимости от Python.
17.105. qmail
Возможные аргументы: (нет), build, run, both, vars
Использует mail/qmail. С аргументом build подразумевается зависимость от qmail во время сборки. Аргумент run подразумевает зависимость во время выполнения. Использование без аргументов или с аргументом both подразумевает зависимости как во время выполнения, так и во время сборки. Аргумент vars только устанавливает переменные QMAIL для использования в порте.
17.106. qmake
Возможные аргументы: (отсутствуют), norecursive, outsource, no_env, no_configure
Использует QMake для настройки. Для получения дополнительной информации см. Использование qmake.
17.107. qt
Возможные аргументы: 5, 6, no_env
Добавить зависимость от компонентов Qt. no_env передаётся напрямую в USES= qmake. Подробнее см. в Использование Qt.
17.108. qt-dist
Possible arguments: (none) or 5 and (none) or 6 and (none) or one of 3d, 5compat, base, charts, connectivity, datavis3d, declarative, doc languageserver, gamepad, graphicaleffects, imageformats, locat ion, lottie, multimedia, networkauth, positioning, quick3d, quickcontrols2, quickcontrols, quicktimeline, remoteobjects, script, scxml `, `sensors, serialbus, serialport, shadertools, speech, svg, tools, translations, virtualkeyboard, wayland, webchannel, webengine, webglplugin, websockets, webview, x11extras, xmlpatterns.
Предоставляет поддержку сборки компонентов Qt 5 и Qt 6. Обеспечивает настройку соответствующей конфигурации окружения для сборки порта.
Порт представляет собой компонент networkauth из Qt 5, который входит в файл дистрибутива networkauth.
PORTNAME= networkauth
DISTVERSION= ${QT5_VERSION}
USES= qt-dist:5Порт представляет собой компонент websockets из Qt 6, который входит в файл дистрибутива websockets.
PORTNAME= websockets
PORTVERSION= ${QT6_VERSION}
USES= qt-dist:6Если PORTNAME не совпадает с именем компонента, его можно передать как аргумент в qt-dist.
Порт представляет собой компонент gui из Qt 5, который входит в файл дистрибутива base.
PORTNAME= gui
DISTVERSION= ${QT5_VERSION}
USES= qt-dist:5,base17.109. readline
Возможные аргументы: (нет), port
Использует readline в качестве зависимости библиотеки и устанавливает CPPFLAGS и LDFLAGS по необходимости. Если используется аргумент port или если readline отсутствует в базовой системе, добавляет зависимость от devel/readline
17.110. ruby
Возможные аргументы: (нет), build, extconf, run, setup
Предоставить поддержку для портов, связанных с Ruby. (none) без аргументов добавляет зависимость во время выполнения на lang/ruby. build добавляет зависимость на lang/ruby во время сборки. extconf указывает, что порт использует extconf.rb для настройки. run добавляет зависимость на lang/ruby во время выполнения. Это также значение по умолчанию. setup указывает, что порт использует setup.rb для настройки и сборки.
Пользователь может определить следующие переменные:
RUBY_VERАльтернативная короткая версия ruby в виде
x.y.RUBY_DEFAULT_VERУстановите (например)
2.7, чтобы использоватьruby27в качестве версии по умолчанию.RUBY_ARCHУстановите имя архитектуры (например, i386-freebsd7).
Следующие переменные экспортируются для использования портом:
RUBYУстановлена в полный путь к ruby. Если задано, значения следующих переменных автоматически получаются из исполняемого файла ruby:
RUBY_ARCH,RUBY_ARCHLIBDIR,RUBY_LIBDIR,RUBY_SITEARCHLIBDIR,RUBY_SITELIBDIR,RUBY_VERиRUBY_VERSIONRUBY_VERУстановлена в альтернативную короткую версию ruby в формате
x.y.RUBY_EXTCONFУстановлена в альтернативное имя для extconf.rb (по умолчанию: extconf.rb).
RUBY_EXTCONF_SUBDIRSУстановлена в список подкаталогов, если включено несколько модулей.
RUBY_SETUPУстановлена в альтернативное имя для setup.rb (по умолчанию: setup.rb).
17.111. samba
Возможные аргументы: build, env, lib, run
Обработать зависимость от Samba. env не добавит никаких зависимостей, а только установит переменные. build и run добавят зависимости во время сборки и выполнения на smbd. lib добавит зависимость на libsmbclient.so. Экспортируемые переменные:
SAMBA_PORTРасположение порта Samba по умолчанию.
SAMBA_INCLUDEDIRРасположение заголовочных файлов Samba.
SAMBA_LIBSКаталог, в котором доступны общие библиотеки Samba.
SAMBA_LDB_PORTРасположение порта ldb, используемого выбранной версией Samba (например, databases/ldb28). Он должен использоваться, если порту требуется зависимость от той же версии ldb, что и у выбранной версии Samba.
SAMBA_TALLOC_PORTРасположение порта talloc, используемого выбранной версией Samba. Следует использовать, если порту требуется зависеть от той же версии talloc, что и выбранная версия Samba.
SAMBA_TDB_PORTРасположение порта TDB, используемого выбранной версией Samba. Его следует использовать, если порту требуется зависеть от той же версии TDB, что и выбранная версия Samba.
SAMBA_TEVENT_PORTРасположение порта tevent, используемого выбранной версией Samba. Это следует использовать, если порту необходимо зависеть от той же версии tevent, что и выбранная версия Samba.
17.112. scons
Возможные аргументы: (отсутствуют)
Предоставить поддержку для использования devel/scons. Дополнительную информацию смотрите в Использование scons.
17.113. sdl
Возможные аргументы: sdl
Обеспечить поддержку использования пакетов SDL. Переменная USE_SDL является обязательной и указывает, какие компоненты добавить в зависимости.
Поддерживаемые в настоящее время модули SDL1.2:
sdl
console
gfx
image
mixer
mm
net
pango
sound
ttf
Текущие поддерживаемые модули SDL2:
sdl2
gfx2
image2
mixer2
net2
sound2
ttf2
Текущие поддерживаемые модули SDL3:
sdl3
image3
ttf3
17.114. shared-mime-info
Возможные аргументы: (отсутствуют)
Использует update-mime-database из пакета misc/shared-mime-info. Это автоматически добавит шаг post-install таким образом, что сам порт всё ещё может указать собственный шаг post-install при необходимости. Также добавляет запись @shared-mime-info в plist.
17.115. shebangfix
Возможные аргументы: (отсутствуют)
Множество программ используют некорректные расположения для интерпретаторов скриптов, особенно /usr/bin/perl и /bin/bash. Макрос shebangfix исправляет строки shebang в скриптах, перечисленных в SHEBANG_REGEX, SHEBANG_GLOB или SHEBANG_FILES.
SHEBANG_REGEXСодержит одно расширенное регулярное выражение и используется с аргументом
-iregexв find(1). См.USESshebangfixсSHEBANG_REGEX.SHEBANG_GLOBСодержит список шаблонов, используемых с аргументом
-nameв find(1). См.USESshebangfixсSHEBANG_GLOB.SHEBANG_FILESСодержит список файлов или шаблонов sh(1). Макрос shebangfix выполняется из
${WRKSRC}, поэтомуSHEBANG_FILESможет содержать пути, относительные к${WRKSRC}. Также он может работать с абсолютными путями, если требуется исправление файлов вне${WRKSRC}. См.USESshebangfixсSHEBANG_FILES.
В настоящее время Bash, Java, Ksh, Lua, Perl, PHP, Python, Ruby, Tcl и Tk поддерживаются по умолчанию.
Существует три переменных конфигурации:
SHEBANG_LANGСписок поддерживаемых интерпретаторов.
_interp__CMDПуть к интерпретатору команд в FreeBSD. Значение по умолчанию —
${LOCALBASE}/bin/interp._interp__OLD_CMDСписок неправильных вызовов интерпретаторов. Обычно это устаревшие пути или пути, используемые в других операционных системах, которые неверны в FreeBSD. Они будут заменены на правильные пути в
_interp__CMD.Эти пути всегда будут частью
interp__OLD_CMD:"/usr/bin/env _interp" /bin/interp /usr/bin/interp /usr/local/bin/interp._interp__OLD_CMDсодержит несколько значений. Любая запись с пробелами должна быть заключена в кавычки. См. Указание всех путей при добавлении интерпретатора вUSESshebangfix.
Исправление шебанг-строк выполняется на этапе Правильные пути для поддерживаемых интерпретаторов доступны в |
При использовании с |
USES=shebangfixЧтобы добавить другой интерпретатор, установите SHEBANG_LANG. Например:
SHEBANG_LANG= lua
USES=shebangfixЕсли они еще не были определены и не было значений по умолчанию для _interpOLD_CMD и _interpCMD, запись Ksh можно определить как:
SHEBANG_LANG= ksh
ksh_OLD_CMD= "/usr/bin/env ksh" /bin/ksh /usr/bin/ksh
ksh_CMD= ${LOCALBASE}/bin/kshНекоторое программное обеспечение использует нестандартные пути для интерпретатора. Например, приложение может ожидать, что Python будет расположен в /opt/bin/python2.7. Нестандартный путь, который нужно заменить, можно указать в Makefile порта:
python_OLD_CMD= /opt/bin/python2.7
USES=shebangfix с SHEBANG_REGEXДля исправления всех файлов в ${WRKSRC}/scripts, оканчивающихся на .pl, .sh или .cgi, выполните:
USES= shebangfix SHEBANG_REGEX= ./scripts/.*\.(sh|pl|cgi)
|
USES=shebangfix с SHEBANG_GLOBДля исправления всех файлов в ${WRKSRC} с окончанием .pl или .sh выполните:
USES= shebangfix SHEBANG_GLOB= *.sh *.pl
USES=shebangfix с SHEBANG_FILESДля исправления файлов script/foobar.pl и script/*.sh в ${WRKSRC} выполните:
USES= shebangfix SHEBANG_FILES= scripts/foobar.pl scripts/*.sh
17.116. sqlite
Возможные аргументы: (нет), 2, 3
Добавить зависимость от SQLite. Используемая по умолчанию версия — 3, но также возможна версия 2 с использованием модификатора :2.
17.118. ssl
Возможные аргументы: (нет), build, run
Обеспечить поддержку OpenSSL. Зависимость только для сборки или выполнения может быть указана с использованием build или run. Эти переменные доступны для использования портом, а также добавлены в MAKE_ENV:
OPENSSLBASEПуть к базовой установке OpenSSL.
OPENSSLDIRПуть к файлам конфигурации OpenSSL.
OPENSSLLIBПуть к библиотекам OpenSSL.
OPENSSLINCПуть к заголовочным файлам OpenSSL.
OPENSSLRPATHЕсли определено, путь, который требуется компоновщику для поиска библиотек OpenSSL.
Если порт не собирается с вариантом OpenSSL, установите переменную BROKEN_SSL= libressl BROKEN_SSL_REASON_libressl= needs features only available in OpenSSL |
17.119. tar
Возможные аргументы: (нет), Z, bz2, bzip2, lzma, tbz, tbz2, tgz, txz, xz, zst, zstd
Установите EXTRACT_SUFX в .tar, .tar.Z, .tar.bz2, .tar.bz2, .tar.lzma, .tbz, .tbz2, .tgz, .txz, .tar.xz, .tar.zst или .tar.zstd соответственно.
17.120. tcl
Возможные аргументы: version, wrapper, build, run, tea
Добавьте зависимость от Tcl. Конкретная версия может быть запрошена с помощью version. Версия может быть пустой, одной или несколькими точными номерами версий (в настоящее время 84, 85 или 86), либо минимальным номером версии (в настоящее время 84+, 85+ или 86+). Чтобы запросить только неспецифичную для версии обёртку, используйте wrapper. Зависимость только на время сборки или выполнения может быть указана с помощью build или run. Для сборки порта с использованием Tcl Extension Architecture используйте tea. После включения bsd.port.pre.mk порт может проверить результаты с помощью этих переменных:
TCL_VER: выбранная версия Tcl в формате major.minorTCLSH: полный путь к интерпретатору TclTCL_LIBDIR: путь к библиотекам TclTCL_INCLUDEDIR: путь к заголовочным файлам Tcl на языке CTCL_PKG_LIB_PREFIX: Префикс библиотеки, согласно TIP595TCL_PKG_STUB_POSTFIX: Постфикс библиотеки заглушкиTK_VER: выбранная версия Tk в формате major.minorWISH: полный путь к интерпретатору TkTK_LIBDIR: путь к библиотекам TkTK_INCLUDEDIR: путь к заголовочным файлам Tk на языке C
17.121. terminfo
Возможные аргументы: (отсутствуют)
Добавляет @terminfo в файл plist. Используется, когда порт устанавливает файлы *.terminfo в каталог ${PREFIX}/share/misc.
17.122. tex
Возможные аргументы: (отсутствуют)
Обеспечить поддержку tex. Загружает все стандартные переменные для портов, связанных с TEX, и не добавляет зависимостей от других портов.
Переменные используются для указания того, какие модули TEX требуются.
USE_TEXСписок необходимых расширений TEX во время выполнения. Добавьте
:buildк названию расширения, чтобы добавить зависимость на время сборки,:run— для зависимости во время выполнения,:test— для зависимости во время тестирования,:extract— для зависимости во время извлечения. Пример:base texmf:build source:run
Текущие возможные аргументы следующие:
basetexmfsourcedocsweb2ckpathseaptexencbasictlmgrtexluatexluajitsynctexxpdfopendvipskdvipdfmxxdvikgbklatexformatstexlatexpdftexjadetexluatexptexxetexxmltextexhashupdmapfmtutil
17.123. tk
Так же, как аргументы для tcl
Небольшая обертка при использовании Tcl и Tk. Возвращаются те же переменные, что и при использовании Tcl.
17.124. trigger
Возможные аргументы: (отсутствуют)
Предоставить поддержку для портов, требующих выполнения триггеров с помощью pkg(8). Триггеры выполняются в конце транзакции, если условия выполнены.
Следующая переменная может быть установлена портами:
TRIGGERSСписок триггеров для пакета. По умолчанию используется
${PORTNAME}.
Триггеры указываются в формате UCL и обычно размещаются в каталоге files/ порта.
17.125. uidfix
Возможные аргументы: (отсутствуют)
Изменяет некоторые стандартные настройки (в основном переменные) системы сборки, чтобы позволить установку этого порта обычным пользователем. Попробуйте это в порте перед использованием USES=fakeroot или исправлением.
17.126. uniquefiles
Возможные аргументы: (нет), dirs
Сделать файлы или каталоги 'уникальными', добавляя префикс или суффикс. Если используется аргумент dirs, порту требуется префикс (и только префикс) на основе UNIQUE_PREFIX для стандартных каталогов DOCSDIR, EXAMPLESDIR, DATADIR, WWWDIR, ETCDIR. Эти переменные доступны для портов:
UNIQUE_PREFIX: Префикс, используемый для каталогов и файлов. По умолчанию:${PKGNAMEPREFIX}.UNIQUE_PREFIX_FILES: Список файлов, которые необходимо предварить префиксом. По умолчанию: пусто.UNIQUE_SUFFIX: Суффикс, используемый для файлов. По умолчанию:${PKGNAMESUFFIX}.UNIQUE_SUFFIX_FILES: Список файлов, к которым необходимо добавить суффикс. По умолчанию: пусто.
17.128. varnish
Возможные аргументы: 4 (по умолчанию), 6, 7
Обрабатывает зависимости для Varnish Cache. Добавляет зависимость от пакета www/varnish*.
17.129. waf
Возможные аргументы: (отсутствуют)
Обеспечить поддержку портов, использующих систему сборки waf.
Это подразумевает USES=python:build.
Следующие переменные экспортируются для использования портом:
WAF_CMDРасположение скрипта
waf. Установите этот параметр, если скриптwafне находится в WRKSRC/waf.CONFIGURE_TARGETЦель для
configure. По умолчанию –configure.ALL_TARGETЦель для
all. По умолчаниюbuild.INSTALL_TARGETЦель для
install. По умолчаниюinstall.
17.130. webplugin
Возможные аргументы: (нет), ARGS
Автоматически создавать и удалять символические ссылки для каждого приложения, поддерживающего фреймворк webplugin. ARGS может быть одним из:
gecko: поддержка плагинов на основе Geckonative: поддержка плагинов для Gecko, Opera и WebKit-GTKlinux: поддержка Linux плагиновall(по умолчанию, неявно): поддержка всех типов плагинов(отдельные записи): поддерживаются только перечисленные браузеры
Эти переменные можно настроить:
WEBPLUGIN_FILES: Значение по умолчанию отсутствует, должно быть установлено вручную. Файлы плагинов для установки.WEBPLUGIN_DIR: Каталог для установки файлов плагина, по умолчанию PREFIX/lib/browser_plugins/WEBPLUGIN_NAME. Установите это значение, если порт устанавливает файлы плагина вне стандартного каталога, чтобы избежать битых символических ссылок.WEBPLUGIN_NAME: Конечный каталог для установки файлов плагина, по умолчаниюPKGBASE.
17.131. xfce
Возможные аргументы: (нет), gtk2
Предоставить поддержку для портов, связанных с Xfce. Подробности см. в Использование Xfce.
Аргумент gtk2 указывает, что порт требует поддержки GTK2. Он добавляет дополнительные возможности, предоставляемые некоторыми основными компонентами, например, x11/libxfce4menu и x11-wm/xfce4-panel.
17.132. xorg
Возможные аргументы: (отсутствуют)
Предоставляет простой способ зависеть от компонентов X.org. Компоненты должны быть перечислены в USE_XORG. Доступные компоненты:
| Имя | Описание |
|---|---|
| Библиотека расширений DMX |
| Библиотека fontenc |
| Создать индекс файлов шрифтов X в каталоге |
| Библиотека Inter Client Exchange для X11 |
| Библиотека FS |
| Универсальная библиотека доступа к PCI |
| Библиотека для низкоуровневого управления пикселями |
| Библиотека управления сеансами для X11 |
| Библиотека X11 |
| Библиотека протокола аутентификации для X11 |
| Библиотека X Athena Widgets |
| Библиотека X Athena Widgets |
| Библиотека X Athena Widgets |
| Данные растровых изображений X.Org |
| Библиотека с интерфейсом языка С для X протокола (XCB) |
| Библиотека расширения X Composite |
| X библиотека загрузки курсоров на стороне клиента |
| Библиотека расширения X Damage |
| Библиотека протокола управления дисплейным менеджером X (XDMCP) |
| Библиотека расширений X11 |
| Библиотека расширений X Fixes |
| Библиотека шрифтов X |
| Библиотека шрифтов X |
| Клиентский API шрифтов для приложений X |
| Библиотека расширения X Input |
| Библиотека X11 Xinerama |
| Библиотека файлов XKB |
| Библиотека X Miscellaneous Utilities |
| Библиотека X Miscellaneous Utilities |
| X.Org макросы разработки aclocal |
| Сервер X.Org X и относящиеся к нему программы |
| Заголовочные файлы протокола xorg |
| Библиотека X Pixmap |
| Библиотека расширений X Present |
| Библиотека расширений X Resize and Rotate |
| Библиотека расширения X Render |
| Библиотека мониторинга ресурсов X Resource usage |
| Библиотека XScrnSaver |
| Примитив синхронизации "SyncFence" в разделяемой памяти |
| Библиотека X Toolkit |
| Абстрактный сетевой код для X |
| Расширение X Test |
| Библиотека расширения X Video |
| Библиотека X Video Extension Motion Compensation |
| Расширение X DGA |
| Расширение X Vidmode |
17.133. xorg-cat
Возможные аргументы: app, data, doc, driver, font, lib, proto, util, xserver и (без аргументов) или один из autotools (по умолчанию), meson
Обеспечивает поддержку сборки компонентов Xorg. Управляет настройкой общих зависимостей и необходимой конфигурационной среды. Предназначено только для компонентов Xorg.
Категория должна соответствовать категориям вышестоящего репозитория.
Второй аргумент — используемая система сборки. По умолчанию используется autotools, но также поддерживается meson.
Глава 18. Значения __FreeBSD_version
Здесь удобный список значений __FreeBSD_version как определено в sys/param.h:
18.1. Версии FreeBSD 15
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
1500000 | 24 августа 2023 | 15.0-CURRENT. | |
1500001 | 17 сентября 2023 | 15.0-CURRENT после реализации | |
1500002 | 18 октября 2023 | 15.0-CURRENT после изменения внутреннего KAPI между модулями nfscommon и nfscl. | |
1500003 | 1 ноября 2023 | 15.0-CURRENT после удаления кода обратной совместимости для преобразования inode64. | |
1500004 | 23 ноября 2023 | 15.0-CURRENT после добавления новой функции VFS под названием | |
1500005 | 27 ноября 2023 | 15.0-CURRENT после серии механических изменений в дереве: идентификаторы SCCS удалены, закомментированные строки с авторскими правами удалены с помощью | |
1500006 | 8 декабря 2023 | 15.0-CURRENT после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до llvmorg-17.0.6-0-g6009708b4367, также известного как релиз 17.0.6. | |
1500007 | 11 декабря 2023 | 15.0-CURRENT после предоставления доступа к execvpe для совместимости с Linux в libc. | |
1500008 | 24 декабря 2023 | 15.0-CURRENT после изменений в LinuxKPI. | |
1500009 | 11 января 2024 | 15.0-CURRENT после добавления vnode_pager_clean_async(9) и vnode_pager_clean_sync(9). | |
1500010 | 12 января 2024 | 15.0-CURRENT после изменения внутреннего KAPI между модулями nfscommon и nfscl. | |
1500011 | 17 января 2024 | 15.0-CURRENT после добавления поддержки zfs.dataset в jail(8). | |
1500012 | 24 января 2024 | 15.0-CURRENT после добавления kern_openatfp(9) и kcmp(2). | |
1500013 | 7 февраля 2024 | 15.0-CURRENT после добавления libsys. | |
1500014 | 11 февраля 2024 | 15.0-CURRENT после переключения clang и других исполняемых файлов LLVM на сборку как PIE. | |
1500015 | 13 марта 2024 | 15.0-CURRENT после удаления избыточных аргументов | |
1500016 | 18 марта 2024 | 15.0-CURRENT после введения livedump_start_vnode(9). | |
1500017 | 20 марта 2024 | 15.0-CURRENT после исправления утверждения или сбоя clang при сборке последних библиотек boost. | |
1500018 | 6 апреля 2024 | 15.0-CURRENT после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии llvmorg-18.1.3-0-gc13b7485b879, также известной как релиз 18.1.3. | |
1500019 | 31 мая 2024 | 15.0-CURRENT после переопределения | |
1500020 | 12 июля 2024 | 15.0-CURRENT после удаления поддержки сборки armv6. | |
1500021 | 21 июля 2024 | 15.0-CURRENT после изменений в LinuxKPI. | |
1500022 | 29 июля 2024 | 15.0-CURRENT после удаления поддержки подкачки стека ядра. | |
1500023 | 30 июля 2024 | 15.0-CURRENT после добавления новых флагов в malloc(9). | |
1500024 | 2 октября 2024 | 15.0-CURRENT после увеличения версии libmd.so.6 до libmd.so.7. | |
1500025 | 6 октября 2024 | 15.0-CURRENT после расширения поля | |
1500026 | 23 октября 2024 | 15.0-CURRENT после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии llvmorg-19.1.2-0-g7ba7d8e2f7b6, также известной как релиз 19.1.2. | |
1500027 | 14 ноября 2024 | 15.0-CURRENT после скрытия | |
1500028 | 25 ноября 2024 | 15.0-CURRENT после добавления флага | |
1500029 | 6 декабря 2024 | 15.0-CURRENT после добавления | |
1500030 | 2 января 2025 | 15.0-CURRENT после изменения | |
1500037 | 12 апреля 2025 | 15.0-CURRENT после внесения изменений в alloc в LinuxKPI. | |
1500038 | gitref:[repository="src",length=12] | 19 апреля 2025 | 15.0-CURRENT после удаления vm_page_next() и _prev. |
1500039 | gitref:[repository="src",length=12] | 4 мая 2025 | 15.0-CURRENT после введения правильно типизированных jiffies. |
1500040 | gitref:[repository="src",length=12] | 4 мая 2025 | 15.0-CURRENT после изменения внутреннего API между модулями nfscommon и nfscl. |
1500045 | 3 июня 2025 | 15.0-CURRENT после внесения изменений dma-mapping.h из drm-kmod в LinuxKPI. | |
1500062 | 17 августа 2025 | 15.0-CURRENT после добавления VTYPE_ISDEV(), VN_ISDEV() и VATTR_ISDEV(). |
18.2. Версии FreeBSD 14
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
1400000 | 22 января 2021 | 14.0-CURRENT. | |
1400001 | 23 января 2021 | 14.0-CURRENT после добавления поддержки символьных ссылок к бесблокировочному поиску. | |
1400002 | 26 января 2021 | 14.0-CURRENT после исправления утверждения clang при сборке порта devel/onetbb. | |
1400003 | 28 января 2021 | 14.0-CURRENT после добавления различных компонентов LinuxKPI, конфликтующих с drm-kmod. | |
1400004 | 8 февраля 2021 | 14.0-CURRENT после изменения интерфейсов ядра для диспетчеризации криптографических операций. | |
1400005 | 17 февраля 2021 | 14.0-CURRENT после изменения API ptrace(2) | |
1400006 | 17 марта 2021 | 14.0-CURRENT после добавления перечисляющих ioctl в sndstat(4). | |
1400007 | 6 апреля 2021 | 14.0-CURRENT после исправления некорректного | |
1400008 | 11 апреля 2021 | 14.0-CURRENT после изменения внутреннего KAPI между модулями | |
1400009 | 20 апреля 2021 | 14.0-CURRENT после добавления поддержки TCP LRO для VLAN и VxLAN. | |
1400010 | 21 апреля 2021 | 14.0-CURRENT после изменения схемы и определений | |
1400015 | 25 мая 2021 | 14.0-CURRENT после добавления дополнительных изменений LinuxKPI, требующих корректировки drm-kmod. | |
1400016 | 25 мая 2021 | 14.0-CURRENT после удаления поддержки программных бэкендов KTLS. | |
1400017 | 25 мая 2021 | 14.0-CURRENT после добавления | |
1400018 | 30 мая 2021 | 14.0-CURRENT после разрешения реализации VFS_QUOTACTL(9) указывать изменения состояния занятости. | |
1400019 | 7 июня 2021 | 14.0-CURRENT после включения | |
1400020 | 9 июня 2021 | 14.0-CURRENT после добавления макросов для | |
1400021 | 10 июня 2021 | 14.0-CURRENT после добавления макроса | |
1400022 | 11 июня 2021 | 14.0-CURRENT после коммита e1a907a25cfa изменил внутренний KAPI между модулями | |
1400023 | 13 июня 2021 | 14.0-CURRENT после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии llvmorg-12.0.0-0-gd28af7c654d8, также известной как релиз 12.0.0. | |
1400024 | 18 июня 2021 | 14.0-CURRENT после различных добавлений в LinuxKPI. | |
1400025 | 5 июля 2021 | 14.0-CURRENT после различных добавлений в LinuxKPI. | |
1400026 | 16 июля 2021 | 14.0-CURRENT после изменения внутреннего KAPI между модулями nfscommon и nfsd. | |
1400027 | 28 июля 2021 | 14.0-CURRENT после добавления вспомогательных функций LSE атомарных операций вне строки в libcompiler_rt.a для архитектуры aarch64. | |
1400028 | 31 июля 2021 | 14.0-CURRENT после обеспечения потокобезопасности разделов FPU в LinuxKPI. | |
1400029 | 5 августа 2021 | 14.0-CURRENT после добавления fspacectl(2), vn_deallocate(9) и VOP_DEALLOCATE(9). | |
1400030 | 12 августа 2021 | 14.0-CURRENT после изменений параметров VOP_DEALLOCATE(9) и добавления поддержки fspacectl(2) для POSIX разделяемой памяти. | |
1400031 | 24 августа 2021 | 14.0-CURRENT после изменения fspacectl(2), vn_deallocate(9) и VOP_DEALLOCATE(9) для обновления rmsr.r_offset до значимого значения. | |
1400032 | 25 августа 2021 | 14.0-CURRENT после изменения fspacectl(2), vn_deallocate(9) и VOP_DEALLOCATE(9) для упрощения подсчёта количества обнулённых байт. | |
1400033 | 7 сентября 2021 | 14.0-CURRENT после перемещения блокировок буфера сокета в содержащий сокет и переименования sb(un)lock в SOCK_IO_RECV_LOCK, SOCK_IO_RECV_UNLOCK, SOCK_IO_SEND_LOCK и SOCK_IO_SEND_UNLOCK. | |
1400034 | 29 сентября 2021 | 14.0-CURRENT после изменений в LinuxKPI. | |
1400035 | 4 октября 2021 | 14.0-CURRENT после разделения libtinfow и libncurses. | |
1400036 | 6 октября 2021 | 14.0-CURRENT после расширения шифров AES-CCM и Chacha20-Poly1305 в OCF для поддержки нескольких длин одноразовых номеров. | |
1400037 | 11 октября 2021 | 14.0-CURRENT после удаления аргумента thread из VOP_STAT(9) и | |
1400038 | 17 октября 2021 | 14.0-CURRENT после того, как LinuxKPI получил поддержку отложенного выделения BAR. | |
1400039 | 19 октября 2021 | 14.0-CURRENT после изменений в аллокаторе страниц. | |
1400040 | 30 октября 2021 | 14.0-CURRENT после увеличения номера версии разделяемой библиотеки libdialog. | |
1400041 | 6 ноября 2021 | 14.0-CURRENT после изменения аргументов для VOP_ALLOCATE(9). | |
1400042 | 13 ноября 2021 | 14.0-CURRENT после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до llvmorg-13.0.0-0-gd7b669b3a303, также известного как релиз 13.0.0. | |
1400043 | 25 ноября 2021 | 14.0-CURRENT после удаления неиспользуемого аргумента потока из NDINIT(9)*. | |
1400044 | 9 декабря 2021 | 14.0-CURRENT после изменения встроенных программных криптографических преобразований для поддержки AEAD-шифров и изменения аутентификационных преобразований Blake-2S/B для поддержки Init перед Setkey, как в других аутентификационных преобразованиях. | |
1400045 | 15 декабря 2021 | 14.0-CURRENT после изменения аргумента cookies в VOP_READDIR(9) на | |
1400046 | 30 декабря 2021 | 14.0-CURRENT после приведения макросов CPU_SET в соответствие с glibc. | |
1400047 | January 17, 2022 | 14.0-CURRENT после множества изменений LinuxKPI, необходимых для drm-kmod. | |
1400048 | 18 января 2022 | 14.0-CURRENT после добавления <crypto/chacha20_poly1305.h>. | |
1400049 | January 24, 2022 | 14.0-CURRENT after adding <crypto/curve25519.h>. | |
1400050 | 25 января 2022 | 14.0-CURRENT после iflib добавляет возможность, при которой драйвер может установить свою собственную функцию выбора TX-очереди как | |
1400051 | 25 января 2022 | 14.0-CURRENT после добавления поддержки i2c для LinuxKPI. | |
1400052 | February 14, 2022 | 14.0-CURRENT после добавления поддержки GUID_INIT и pm_qos.h для LinuxKPI. | |
1400053 | February 17, 2022 | 14.0-CURRENT после добавления mmap_lock.h в LinuxKPI. | |
1400054 | 28 марта 2022 | 14.0-CURRENT после изменения | |
1400055 | 29 марта 2022 | 14.0-CURRENT после добавления | |
1400056 | 31 марта 2022 | 14.0-CURRENT после обновления zlib до версии 1.2.12 | |
1400057 | 22 апреля 2022 | 14.0-CURRENT после изменения прототипа udp_tun_func_t(). | |
1400058 | 7 мая 2022 | 14.0-CURRENT после изменений в newbus для удаления аргументов devclass. | |
1400059 | 14 мая 2022 | 14.0-CURRENT после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии llvmorg-14.0.3-0-g1f9140064dfb, также известной как релиз 14.0.3. | |
1400060 | 6 июня 2022 | 14.0-CURRENT после исправлений LinuxKPI dmi_matches(). | |
1400061 | 8 июня 2022 | 14.0-CURRENT после изменений структуры mbuf(9). | |
1400062 | 18 июня 2022 | 14.0-CURRENT после изменений структуры | |
1400063 | 29 июня 2022 | 14.0-CURRENT после множества изменений LinuxKPI, необходимых для drm-kmod. | |
1400064 | 18 июля 2022 | 14.0-CURRENT после удаления OBJT_DEFAULT. | |
1400065 | 8 августа 2022 | 14.0-CURRENT после множества изменений LinuxKPI, необходимых для drm-kmod. | |
1400066 | 18 августа 2022 | 14.0-CURRENT после множества изменений LinuxKPI, необходимых для drm-kmod. | |
1400069 | 22 сентября 2022 | 14.0-CURRENT после нескольких изменений в LinuxKPI. | |
1400070 | 22 сентября 2022 | 14.0-CURRENT после изменений KPI в pmap_unmapdev() и kmem_*(). | |
1400071 | 26 сентября 2022 | 14.0-CURRENT после изменений KPI, когда списки OID sysctl были преобразованы в RB-деревья. | |
1400072 | 22 сентября 2022 | 14.0-CURRENT после изменения прототипа | |
1400073 | 17 октября 2022 | 14.0-CURRENT after introduction of v2 of TX Queue Select Functionality. | |
1400074 | 9 декабря 2022 | 14.0-CURRENT после добавления запасных слотов fops в fileops. | |
1400078 | 13 января 2023 | 14.0-CURRENT после изменения LinuxKPI pci.h. | |
1400079 | 8 февраля 2023 | 14.0-CURRENT после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до llvmorg-15.0.7-0-g8dfdcc7b7bf6, также известного как релиз 15.0.7. | |
1400084 | 23 марта 2023 | 14.0-CURRENT после изменения структур reg, gpreg, trapframe и pcb для архитектуры arm64. | |
1400085 | 28 марта 2023 | 14.0-CURRENT после нескольких изменений в LinuxKPI. | |
1400086 | 8 апреля 2023 | 14.0-CURRENT после изменений аргументов vn_lock_pair(). | |
1400087 | 22 апреля 2023 | 14.0-CURRENT после обновлений LinuxKPI. | |
1400088 | 24 апреля 2023 | 14.0-CURRENT после миграции LinuxKPI на IfAPI. | |
1400089 | 25 апреля 2023 | 14.0-CURRENT после динамического выделения массива stoppcbs в smp. | |
1400090 | 7 июня 2023 | 14.0-CURRENT после того, как ptrace начал очищать TDB_BORN во время PT_DETACH. | |
1400091 | 22 июня 2023 | 14.0-CURRENT после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до llvmorg-16.0.6-0-g7cbf1a259152, также известного как релиз 16.0.6. | |
1400092 | 24 июня 2023 | 14.0-CURRENT после импорта OpenSSL 3.0.9 в базовую систему. | |
1400093 | 5 июля 2023 | 14.0-CURRENT после использования __enum_uint8 для vtype и vstate в VFS | |
1400097 | 24 августа 2023 | 14.0-STABLE после ветвления stable/14 | |
1400500 | 8 сентября 2023 | 14.0-STABLE после ветвления releng/14.0 | |
1400501 | 19 ноября 2023 | 14.0-STABLE после реализации | |
1400502 | 24 декабря 2023 | 14.0-STABLE после изменения внутреннего API между модулями kgssapi и krpc. | |
1400503 | 29 декабря 2023 | 14.0-STABLE после изменения внутреннего KAPI между модулями nfscommon и nfscl. | |
1400504 | 7 января 2024 | 14.0-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до llvmorg-17.0.6-0-g6009708b4367, также известного как релиз 17.0.6. | |
1400505 | 7 января 2024 | 14.0-STABLE после добавления vnode_pager_clean_async(9) и vnode_pager_clean_sync(9). | |
1400506 | 19 января 2024 | 14.0-STABLE после изменения внутреннего KAPI между модулями nfscommon и nfscl. | |
1400507 | 31 января 2024 | 14.0-STABLE после добавления kern_openatfp(9) и kcmp(2). | |
1400508 | 18 февраля 2024 | 14.0-STABLE после обновлений LinuxKPI. | |
1400509 | 18 февраля 2024 | 14.0-STABLE после изменения внутренней структуры | |
1400510 | 23 марта 2024 | 14.0-STABLE после исправления утверждения или падения clang при сборке последних библиотек boost. | |
1400511 | 20 апреля 2024 | 14.0-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии llvmorg-18.1.3-0-gc13b7485b879, также известной как релиз 18.1.3. | |
1401500 | 2 мая 2024 | 14.1-STABLE после переименования из 14.1-PRERELEASE. | |
1401501 | 6 июня 2024 | 14.1-STABLE после добавления модуля linuxkpi_video. | |
1401502 | 2 августа 2024 | 14.1-STABLE после изменений в LinuxKPI. | |
1401503 | 15 октября 2024 | 14.1-STABLE после расширения поля | |
1402500 | 31 октября 2024 | 14.2-STABLE после переименования из 14.2-PRERELEASE. | |
1402501 | 1 декабря 2024 | 14.2-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до llvmorg-19.1.4-0-gaadaa00de76e, также известного как релиз 19.1.4. | |
1402502 | 27 февраля 2025 | 14.2-STABLE после удаления избыточных аргументов | |
1402503 | 27 февраля 2025 | 14.2-STABLE после добавления | |
1402505 | 18 апреля 2025 | 14.2-STABLE после изменения аллокации в LinuxKPI и удаления микропрограммы iwlwifi. | |
1403503 | 13 июля 2025 | 14.3-STABLE после изменений в LinuxKPI dma-mapping.h and acpi. |
18.3. FreeBSD 13 Версии
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
1300000 | 19 октября 2018 | 13.0-CURRENT. | |
1300001 | 25 октября 2018 | 13.0-CURRENT после увеличения номеров версий разделяемых библиотек OpenSSL. | |
1300002 | 25 октября 2018 | 13.0-CURRENT после восстановления sys/joystick.h. | |
1300003 | 2 ноября 2018 | 13.0-CURRENT после изменения API | |
1300004 | 23 ноября 2018 | 13.0-CURRENT после включения кода crtbegin и crtend. | |
1300005 | 11 декабря 2018 | 13.0-CURRENT после включения контрольных сумм inode в UFS. | |
1300006 | 24 декабря 2018 | 13.0-CURRENT после исправления включения sys/random.h для использования из C++. | |
1300007 | 30 декабря 2018 | 13.0-CURRENT после изменения размера | |
1300008 | 4 января 2019 | 13.0-CURRENT после добавления системных переменных | |
1300009 | 20 января 2019 | 13.0-CURRENT после изменения структуры | |
1300010 | 27 января 2019 | 13.0-CURRENT после увеличения | |
1300011 | 12 февраля 2019 | 13.0-CURRENT после исправления renameat(2) для работы с ядрами, собранными с опцией | |
1300012 | 12 февраля 2019 | 13.0-CURRENT после того, как | |
1300013 | 19 февраля 2019 | 13.0-CURRENT после удаления drm и drm2. | |
1300014 | 4 марта 2019 | 13.0-CURRENT после обновления clang, llvm, lld, lldb, compiler-rt и libc++ до версии 8.0.0 rc3. | |
1300015 | 15 марта 2019 | 13.0-CURRENT после деанонимизации перечислений состояний потоков и процессов, что позволяет приложениям пользовательского пространства использовать их без переопределения имен значений. | |
1300016 | 16 марта 2019 | 13.0-CURRENT после включения LLVM OpenMP 8.0.0 rc5 на amd64 по умолчанию. | |
1300017 | 19 марта 2019 | 13.0-CURRENT после раскрытия размера буфера Rx mbuf для драйверов в iflib. | |
1300018 | 16 марта 2019 | 13.0-CURRENT после введения системного вызова | |
1300019 | 16 апреля 2019 | 13.0-CURRENT после добавления is_random_seeded(9) в random(4). | |
1300020 | 18 апреля 2019 | 13.0-CURRENT после восстановления доступности random(4) с учетом компромиссов до 346250 и добавления новых настроек и диагностических sysctl для программного обнаружения проблем с ранней инициализацией семени после загрузки. | |
1300021 | 24 апреля 2019 | 13.0-CURRENT после того, как LinuxKPI использует bus_dma(9) для совместимости с IOMMU. | |
1300022 | 4 мая 2019 | 13.0-CURRENT после исправления регрессии, возникшей после 346645 в LinuxKPI. | |
1300023 | 6 мая 2019 | 13.0-CURRENT после преобразования конфигурации устройства дампа ядра в список. | |
1300024 | 8 мая 2019 | 13.0-CURRENT после увеличения номеров версий драйверов Mellanox (mlx4en(4); mlx5en(4)). | |
1300025 | 13 мая 2019 | 13.0-CURRENT после переименования | |
1300026 | 14 мая 2019 | 13.0-CURRENT после добавления члена контекста к ww_mutex в LinuxKPI. | |
1300027 | 14 мая 2019 | 13.0-CURRENT после добавления prepare в | |
1300028 | 17 мая 2019 | 13.0-CURRENT после удаления драйверов | |
1300029 | 20 мая 2019 | 13.0-CURRENT после удаления некоторых загрязнений заголовков из-за sys/eventhandler.h. Затронутые файлы теперь могут требовать явного включения одного или нескольких заголовков: sys/eventhandler.h, sys/ktr.h, sys/lock.h или sys/mutex.h, тогда как ранее они могли включаться неявно до версии 1300029. | |
1300030 | 29 мая 2019 | 13.0-CURRENT после добавления поддержки перемещения в libdwarf на powerpc64 для исправления обработки DWARF-информации в несвязанных объектах. Оригинальный коммит в ссылке:https://svnweb.freebsd.org/changeset/base/348347[348347]. | |
1300031 | 8 июня 2019 | 13.0-CURRENT после добавления исправлений разделов dpcpu и vnet в модули ядра i386 для предотвращения паники в определённых условиях. Модули ядра i386 необходимо перекомпилировать с включёнными изменениями в скрипт компоновщика, иначе они откажутся загружаться. | |
1300032 | 17 июня 2019 | 13.0-CURRENT после выделения реализации | |
1300033 | June 21, 2019 | 13.0-CURRENT после добавлений в список | |
1300034 | 24 июня 2019 | 13.0-CURRENT после удаления NAND и NANDFS. | |
1300035 | 8 июля 2019 | 13.0-CURRENT после объединения механизмов удержания и фиксации | |
1300036 | 13 июля 2019 | 13.0-CURRENT после добавления | |
1300037 | 24 июля 2019 | 13.0-CURRENT после удаления libcap_random(3). | |
1300038 | 30 июля 2019 | 13.0-CURRENT после удаления поддержки gzip’ed a.out. | |
1300039 | 7 августа 2019 | 13.0-CURRENT после объединения fusefs из projects/fuse2. | |
1300040 | 16 августа 2019 | 13.0-CURRENT после удаления sys/dir.h, который был устаревшим с 1997 года. | |
(не изменено) | 23 августа 2019 | 13.0-CURRENT после изменения большинства аргументов в ping6(8). | |
1300041 | 25 августа 2019 | 13.0-CURRENT после удаления zlib 1.0.4 по завершении унификации zlib в ядре. | |
1300042 | 27 августа 2019 | 13.0-CURRENT после добавления поддержки TLS внутри ядра на уровне ядра. | |
1300043 | 2 сентября 2019 | 13.0-CURRENT после удаления gets(3). | |
1300044 | 2 сентября 2019 | 13.0-CURRENT после добавления функций создания/удаления sysfs, обрабатывающих несколько файлов за один вызов, в LinuxKPI. | |
1300045 | 3 сентября 2019 | 13.0-CURRENT после добавления системного вызова sysctlbyname(3). | |
1300046 | 6 сентября 2019 | 13.0-CURRENT после улучшений LinuxKPI sysfs. | |
1300047 | 9 сентября 2019 | 13.0-CURRENT после изменения правил синхронизации для подсчета ссылок | |
1300048 | 25 сентября 2019 | 13.0-CURRENT после добавления системного вызова shm_open2 для поддержки готовящегося системного вызова memfd_create(2). | |
1300049 | 7 октября 2019 | 13.0-CURRENT после вынесения проверки отключения VNET в отдельное поле структуры vnet. | |
1300050 | 9 октября 2019 | 13.0-CURRENT после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до финального релиза 9.0.0 r372316. | |
1300051 | 17 октября 2019 | 13.0-CURRENT после выделения более универсального debugnet(4) из netdump(4). | |
1300052 | 17 октября 2019 | 13.0-CURRENT после преобразования поля busy page в полноценную блокировку, которая больше не требует блокировки объекта для обеспечения согласованности. | |
1300053 | 17 октября 2019 | 13.0-CURRENT после реализации NetGDB. | |
1300054 | 21 октября 2019 | 13.0-CURRENT после удаления устаревших KPIs, которые использовались для доступа к спискам адресов интерфейсов. | |
1300055 | 4 ноября 2019 | 13.0-CURRENT после включения атрибутов группы классов устройств в LinuxKPI. | |
1300056 | 7 ноября 2019 | 13.0-CURRENT после исправления потенциальной проблемы безопасности с чтением за границами в libc++. | |
1300057 | 13 ноября 2019 | 13.0-CURRENT после добавления поддержки | |
1300058 | 18 ноября 2019 | 13.0-CURRENT после расширения поля | |
1300059 | 18 ноября 2019 | 13.0-CURRENT после преобразования встроенных целей | |
1300060 | 20 ноября 2019 | 13.0-CURRENT после добавления символической ссылки /etc/os-release на /var/run/os-release. | |
1300061 | 21 ноября 2019 | 13.0-CURRENT после добавления функций в bitstring(3) для поиска непрерывных последовательностей установленных или сброшенных битов. | |
1300062 | 2 декабря 2019 | 13.0-CURRENT после добавления поддержки TCP_STATS. | |
1300063 | 8 декабря 2019 | 13.0-CURRENT после удаления VI_DOOMED (используйте VN_IS_DOOMED вместо этого). | |
1300064 | 9 декабря 2019 | 13.0-CURRENT после исправления проверки версии C++ для объявления timespec_get(3). | |
1300065 | 12 декабря 2019 | 13.0-CURRENT после добавления расширений | |
1300066 | 12 декабря 2019 | 13.0-CURRENT после изменения внутреннего интерфейса между модулями NFS в рамках внедрения NFS 4.2. | |
1300067 | 13 декабря 2019 | 13.0-CURRENT после удаления устаревших функций | |
1300068 | 16 декабря 2019 | 13.0-CURRENT после удвоения значения | |
1300069 | 24 декабря 2019 | 13.0-CURRENT после добавления шаблонов busdma. | |
1300070 | 27 декабря 2019 | 13.0-CURRENT после устранения последнего различия MI в определениях AT_* (для powerpc). | |
1300071 | 27 декабря 2019 | 13.0-CURRENT после изменения статистики USB для каждого устройства вместо каждой шины. | |
1300072 | 29 декабря 2019 | 13.0-CURRENT после удаления класса | |
1300073 | 2 января 2020 | 13.0-CURRENT после удаления arm/arm как допустимой цели. | |
1300074 | 3 января 2020 | 13.0-CURRENT после удаления аргумента flags из | |
1300075 | 6 января 2020 | 13.0-CURRENT после добавления собственного счетчика отмененных USB-передач. | |
1300076 | 8 января 2020 | 13.0-CURRENT после внедрения реализации | |
(не изменено) | 2 февраля 2020 | 13.0-CURRENT после удаления кода архитектуры armv5 из дерева src. | |
1300077 | 3 февраля 2020 | 13.0-CURRENT после удаления кода архитектуры sparc64 из дерева src. | |
1300078 | 17 февраля 2020 | 13.0-CURRENT после изменения | |
1300079 | 20 февраля 2020 | 13.0-CURRENT после обновления ncurses до версии 6.2.x | |
1300080 | 20 февраля 2020 | 13.0-CURRENT после добавления системного вызова | |
1300081 | 21 февраля 2020 | 13.0-CURRENT после недавних изменений в linuxkpi. | |
1300082 | 1 марта 2020 | 13.0-CURRENT после удаления bktr(4). | |
1300083 | 10 марта 2020 | 13.0-CURRENT после удаления amd(8), r358821. | |
1300084 | 10 марта 2020 | 13.0-CURRENT после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии 10.0.0-rc3 c290cb61fdc. | |
1300085 | 23 марта 2020 | 13.0-CURRENT после импорта тестового фреймворка kyua. | |
1300086 | 26 марта 2020 | 13.0-CURRENT после переключения powerpc и powerpcspe на компоновщик lld. | |
1300087 | 27 марта 2020 | 13.0-CURRENT после рефакторинга интерфейсов драйвера и потребителя для внутриядерного шифрования. | |
1300088 | 1 апреля 2020 | 13.0-CURRENT после удаления поддержки отладки процессов через procfs. | |
1300089 | 8 апреля 2020 | 13.0-CURRENT после разделения интерфейса RCU на части с возможностью ожидания и без неё в LinuxKPI. | |
1300090 | 9 апреля 2020 | 13.0-CURRENT после удаления старого драйвера устройства блокировки NFS, использующего Giant. | |
1300091 | 12 апреля 2020 | 13.0-CURRENT после реализации системного вызова close_range(2). | |
1300092 | 14 апреля 2020 | 13.0-CURRENT после переработки немэппированных mbuf в KTLS для хранения | |
1300093 | 27 апреля 2020 | 13.0-CURRENT после добавления поддержки выгрузки приема TLS в ядре. | |
1300094 | 7 мая 2020 | 13.0-CURRENT после изменений в linuxkpi. | |
1300095 | 20 мая 2020 | 13.0-CURRENT после добавления поддержки сокетов HyperV для гостевых систем FreeBSD. | |
1300096 | 23 мая 2020 | 13.0-CURRENT после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии 10.0.1 rc1 f79cd71e145. | |
1300097 | 2 июня 2020 | 13.0-CURRENT после реализации макроса функции | |
1300098 | 14 июня 2020 | 13.0-CURRENT после изменения поля | |
1300099 | 20 июня 2020 | 13.0-CURRENT после перевода liblzma на использование реализации SHA256 из libmd. | |
1300100 | June 26, 2020 | 13.0-CURRENT после изменения внутреннего API между модулями ядра NFS. | |
1300101 | 10 июля 2020 | 13.0-CURRENT после реализации функции | |
1300102 | 26 июля 2020 | 13.0-CURRENT после реализации бесблокировочного поиска в слое VFS. | |
1300103 | 1 августа 2020 | 13.0-CURRENT после того, как права для NDINIT_ALL стали обязательными. | |
1300104 | 2 августа 2020 | 13.0-CURRENT после изменений в структуре vnode. | |
1300105 | 5 августа 2020 | 13.0-CURRENT после изменения | |
1300106 | 11 августа 2020 | 13.0-CURRENT после добавления аргумента в | |
1300107 | 11 августа 2020 | 13.0-CURRENT после изменения для клонирования полей структуры задачи, связанных с RCU. | |
1300108 | 14 августа 2020 | 13.0-CURRENT после добавления нескольких функций | |
1300109 | 16 августа 2020 | 13.0-CURRENT после удаления аргумента | |
(не изменено) | 16 августа 2020 | 13.0-CURRENT после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии release/11.x llvmorg-11.0.0-rc1-47-gff47911ddfc. | |
1300110 | 18 августа 2020 | 13.0-CURRENT после удаления неиспользуемого аргумента | |
1300111 | 22 августа 2020 | 13.0-CURRENT после добавления поддержки TLS в RPC ядра. | |
1300112 | August 25, 2020 | 13.0-CURRENT после объединения поддержки OpenZFS. | |
1300113 | August 25, 2020 | 13.0-CURRENT после добавления атомарных функций и функций | |
1300114 | 8 сентября 2020 | 13.0-CURRENT после изменения определений AT_HWCAP для arm64 в elf_aux_info(3). | |
1300115 | 14 сентября 2020 | 13.0-CURRENT после исправления сборки приложения crunchgen(1) с | |
1300116 | 22 сентября 2020 | 13.0-CURRENT после введения архитектуры powerpc64le. | |
1300117 | 23 сентября 2020 | 13.0-CURRENT после перереализации | |
1300118 | 2 октября 2020 | 13.0-CURRENT после добавления поддержки подсветки и функций | |
1300119 | 6 октября 2020 | 13.0-CURRENT после заполнения поля контекста получения | |
1300120 | 13 октября 2020 | 13.0-CURRENT после исправления отображений только для записи на arm64. | |
1300121 | 15 октября 2020 | 13.0-CURRENT после добавления | |
1300122 | 17 октября 2020 | 13.0-CURRENT после добавления | |
1300123 | 20 октября 2020 | 13.0-CURRENT после изменений | |
1300124 | 30 октября 2020 | 13.0-CURRENT после добавления | |
1300125 | 4 ноября 2020 | 13.0-CURRENT после использования блокировки | |
1300126 | 5 ноября 2020 | 13.0-CURRENT после оптимизации зон на каждый процессор. | |
1300127 | 6 ноября 2020 | 13.0-CURRENT после перемещения | |
1300128 | 9 ноября 2020 | 13.0-CURRENT после добавлений LinuxKPI для реализации частей ACPI, необходимых | |
1300129 | 12 ноября 2020 | 13.0-CURRENT после удаления | |
1300130 | 17 ноября 2020 | 13.0-CURRENT после разделения | |
1300131 | 7 декабря 2020 | 13.0-CURRENT после удаления криптографических файловых дескрипторов. | |
1300132 | 15 декабря 2020 | 13.0-CURRENT после улучшения обработки альтернативных настроек в стеке USB. | |
1300133 | 23 декабря 2020 | 13.0-CURRENT после изменения внутреннего API между модулями NFS и RPC ядра. | |
1300134 | 7 января 2021 | 13.0-CURRENT после выделения аппаратно-независимой части поддержки USB HID в новый модуль. | |
1300135 | 12 января 2021 | 13.0-CURRENT после добавления | |
1300136 | 17 января 2021 | 13.0-CURRENT после переработки очереди | |
1300137 | 30 января 2021 | 13.0-CURRENT после исправления утверждения clang при сборке порта devel/onetbb. | |
1300138 | 1 февраля 2021 | 13.0-ALPHA3 после добавления блокировки при поиске символьных ссылок в кэше VFS. | |
1300139 | 2 февраля 2021 | 13.0-ALPHA3 после добавления различных компонентов LinuxKPI, конфликтующих с drm-kmod. | |
1300500 | 5 февраля 2021 | 13.0-STABLE после ветвления releng/13.0. | |
1300501 | 23 апреля 2021 | 13.0-STABLE после исправления | |
1300501 | 23 апреля 2021 | 13.0-STABLE после исправления | |
1300502 | 23 апреля 2021 | 13.0-STABLE после реализации | |
1300503 | 23 апреля 2021 | 13.0-STABLE после изменения внутреннего KAPI между krpc и NFS. | |
1300504 | 30 апреля 2021 | 13.0-STABLE после обновления LinuxKPI для поддержки обновления drm-kmod 5.5. | |
1300505 | 10 мая 2021 | 13.0-STABLE после изменения внутреннего KAPI между модулями nscl.ko и nfscommon.ko. | |
1300506 | 2 июня 2021 | 13.0-STABLE после добавления поддержки TCP LRO для VLAN и VxLAN. | |
1300507 | 2 июня 2021 | 13.0-STABLE после добавления нового элемента в структуру отслеживания EPOCH(9). | |
1300508 | 11 июня 2021 | 13.0-STABLE после добавления макросов для | |
1300509 | 14 июня 2021 | 13.0-STABLE после добавления макроса | |
1300510 | 26 июня 2021 | 13.0-STABLE после изменения внутреннего KAPI между модулями krpc и nfsd. | |
1300511 | 7 июля 2021 | 13.0-STABLE после изменения | |
1300512 | 18 июля 2021 | 13.0-STABLE после различных слияний LinuxKPI, OFED, net80211 и драйверов. | |
1300513 | 31 июля 2021 | 13.0-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии llvmorg-12.0.1-0-gfed41342a82f, также известной как релиз 12.0.1. | |
1300514 | 3 августа 2021 | Несовместимые изменения в KBI внутренних интерфейсов между NFS требуют пересборки модулей. | |
1300515 | 22 сентября 2021 | 13.0-STABLE возвращается к KBI 13.0 для linuxkpi. | |
1300518 | 21 октября 2021 | 13.0-STABLE после добавления | |
1300519 | 21 октября 2021 | 13.0-STABLE после расширения шифров AES-CCM и Chacha20-Poly1305 в OCF для поддержки нескольких длин одноразовых номеров. | |
1300521 | 19 ноября 2021 | 13.0-STABLE после различных слияний с LinuxKPI и net80211. | |
1300522 | 24 ноября 2021 | 13.0-STABLE после изменения внутреннего KAPI между модулями NFS. | |
(не изменено) | 6 декабря 2021 | 13.0-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии llvmorg-13.0.0-0-gd7b669b3a303, также известной как релиз 13.0.0. | |
1300523 | 18 декабря 2021 | 13.0-STABLE после добавления двух аргументов в VOP_ALLOCATE(9). | |
1300524 | 14 января 2022 | 13.0-STABLE после обеспечения совместимости макросов CPU_SET с glibc. | |
1300525 | 22 января 2022 | 13.0-STABLE после множества изменений LinuxKPI, необходимых для drm-kmod. | |
1300526 | 20 февраля 2022 | 13.0-STABLE после нескольких изменений LinuxKPI, пересекающихся, но не конфликтующих с drm-kmod. | |
1301000 | 10 марта 2022 | Ветка releng/13.1 создана. | |
1301500 | 10 марта 2022 | 13.1-STABLE после ветвления releng/13.1. | |
1301501 | 27 марта 2022 | 13.1-STABLE после различных слияний с LinuxKPI и net80211. | |
1301502 | 27 апреля 2022 | 13.1-STABLE после различных слияний с LinuxKPI. | |
1301503 | 19 мая 2022 | 13.1-STABLE после добавления альтернативных макросов DRIVER_MODULE без аргумента devclass. | |
1301504 | 4 июня 2022 | 13.1-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии llvmorg-14.0.3-0-g1f9140064dfb, также известной как релиз 14.0.3. | |
1301505 | 21 июня 2022 | 13.1-STABLE после различных слияний с LinuxKPI. | |
1301506 | 13 июля 2022 | 13.1-STABLE после добавления <crypto/chacha20_poly1305.h> и <crypto/curve25519.h>. | |
1301507 | 21 июня 2022 | 13.1-STABLE после различных слияний с LinuxKPI. | |
1301508 | 17 октября 2022 | 13.1-STABLE после различных слияний в LinuxKPI и для удаления макросов из pause(). | |
1301509 | 19 октября 2022 | 13.1-STABLE после введения версии 2 функциональности выбора очереди TX. | |
1301510 | 8 декабря 2022 | 13.1-STABLE после исправлений LinuxKPI dmi_matches(). | |
1301511 | 17 декабря 2022 | 13.1-STABLE после добавления нового rc: | |
1302500 | 9 февраля 2023 | 13.2-STABLE после ветвления releng/13.2. | |
1302501 | 16 февраля 2023 | 13.2-STABLE после добавления | |
1302502 | 17 февраля 2023 | 13.2-STABLE после различных слияний с LinuxKPI. | |
1302503 | 21 февраля 2023 | 13.2-STABLE после различных слияний с LinuxKPI. | |
1302504 | 12 марта 2023 | 13.2-STABLE после объединения machine-id в | |
1302505 | 9 апреля 2023 | 13.2-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до llvmorg-15.0.7-0-g8dfdcc7b7bf6, также известного как релиз 15.0.7. | |
1302506 | 26 июня 2023 | 13.2-STABLE после различных слияний с LinuxKPI. | |
1302507 | 23 июля 2023 | 13.2-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до llvmorg-16.0.6-0-g7cbf1a259152, также известного как релиз 16.0.6. | |
1302508 | 6 сентября 2023 | 13.2-STABLE после того, как ptrace начал очищать TDB_BORN во время PT_DETACH. | |
1302509 | 2 декабря 2023 | 13.2-STABLE после добавления новой функции VFS под названием | |
1302510 | 7 января 2024 | 13.2-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до llvmorg-17.0.6-0-g6009708b4367, также известного как релиз 17.0.6. | |
1303001 | 19 февраля 2024 | 13.3-BETA3 после изменения внутренней структуры | |
1303501 | 19 февраля 2024 | 13.3-STABLE после изменения внутренней структуры | |
1303502 | 23 марта 2024 | 13.3-STABLE после исправления утверждения или падения clang при сборке последних библиотек boost. | |
1303503 | 20 апреля 2024 | 13.3-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до llvmorg-18.1.3-0-gc13b7485b879, также известного как релиз 18.1.3. | |
1304500 | 1 августа 2024 | 13.4-STABLE после переименования из 13.4-PRERELEASE. | |
1304501 | 1 декабря 2024 | 13.4-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до llvmorg-19.1.4-0-gaadaa00de76e, также известного как релиз 19.1.4. |
18.4. Версии FreeBSD 12
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
1200000 | 7 июля 2016 | 12.0-CURRENT. | |
1200001 | 12 июля 2016 | 12.0-CURRENT после удаления правил сортировки из диапазонов типа | |
1200002 | 18 августа 2016 | 12.0-CURRENT после удаления неиспользуемого и устаревшего системного вызова | |
1200003 | 22 августа 2016 | 12.0-CURRENT после добавления поддержки | |
1200004 | 24 августа 2016 | 12.0-CURRENT после исправления LC*MASK для newlocale(3) и querylocale(3) (rev 304703). | |
1200005 | 25 августа 2016 | 12.0-CURRENT после изменения некоторых интерфейсов ioctl в ревизии 304787 между пользовательскими программами iSCSI и ядром. | |
1200006 | 1 сентября 2016 | 12.0-CURRENT после исправления META_MODE в crunchgen(1) в 305254. | |
1200007 | 5 сентября 2016 | 12.0-CURRENT после разрешения взаимоблокировки между | |
1200008 | 15 сентября 2016 | 12.0-CURRENT после удаления совместимого с 4.3BSD макроса | |
1200009 | 21 сентября 2016 | 12.0-CURRENT после удаления | |
1200010 | 23 сентября 2016 | 12.0-CURRENT после монтирования msdosfs(5) с поддержкой | |
1200011 | 1 октября 2016 | 12.0-CURRENT после добавления поля | |
1200012 | 2 октября 2016 | 12.0-CURRENT после изменений в net80211(4) (rev 306590, 306591). | |
1200013 | 12 октября 2016 | 12.0-CURRENT после установки заголовочных файлов, необходимых для разработки с | |
1200014 | 17 октября 2016 | 12.0-CURRENT после объединения общего кода в rtwn(4) и urtwn(4), а также добавления поддержки устройств 802.11ac. | |
1200015 | 20 ноября 2016 | 12.0-CURRENT после некоторого изменения ABI для исправления powerpc. | |
1200016 | 22 ноября 2016 | 12.0-CURRENT после удаления полей, связанных с | |
1200017 | 25 ноября 2016 | 12.0-CURRENT после обновления копий clang, llvm, lldb, compiler-rt и libc++ до версии 3.9.0 и добавления lld 3.9.0. | |
1200018 | 7 декабря 2016 | 12.0-CURRENT после добавления члена | |
1200019 | 16 декабря 2016 | 12.0-CURRENT после начала закладки основы для поддержки 11ac. | |
1200020 | 13 января 2017 | 12.0-CURRENT после удаления | |
1200021 | 16 февраля 2017 | 12.0-CURRENT после удаления поддержки MCA и EISA. | |
1200022 | 21 февраля 2017 | 12.0-CURRENT после обеспечения сохранности структуры задач LinuxKPI между системными вызовами. | |
(не изменено) | 2 марта 2017 | 12.0-CURRENT после удаления поддержки бинарной совместимости с System V Release 4. | |
1200023 | 2 марта 2017 | 12.0-CURRENT после обновления копий clang, llvm, lld, lldb, compiler-rt и libc++ до версии 4.0.0. | |
1200024 | 7 марта 2017 | 12.0-CURRENT после удаления pcap-int.h | |
1200025 | 16 марта 2017 | 12.0-CURRENT после добавления заголовочного файла <dev/mmc/mmc_ioctl.h>. | |
1200026 | 16 марта 2017 | 12.0-CURRENT после скрытия | |
1200027 | 21 марта 2017 | 12.0-CURRENT после того, как блокировка CAM SIM стала опциональной. | |
1200028 | 10 апреля 2017 | 12.0-CURRENT после переименования | |
1200029 | April 19, 2017 | 12.0-CURRENT после удаления | |
1200030 | 24 апреля 2017 | 12.0-CURRENT после удаления поддержки NATM, включая en(4), fatm(4), hatm(4) и patm(4). | |
1200031 | 23 мая 2017 | 12.0-CURRENT после расширения типов | |
1200032 | 8 июня 2017 | 12.0-CURRENT после удаления | |
1200033 | 17 июня 2017 | 12.0-CURRENT после того, как тип члена | |
1200034 | 19 июня 2017 | 12.0-CURRENT после изменения клиента и сервера NFS для фактического использования 64-битного | |
1200035 | June 24, 2017 | 12.0-CURRENT после добавления флага | |
1200036 | 26 июня 2017 | 12.0-CURRENT после изменения | |
1200037 | 1 июля 2017 | 12.0-CURRENT после очистки и встраивания функций | |
1200038 | 10 июля 2017 | 12.0-CURRENT после коммита MMC CAM (320844). | |
1200039 | 22 июля 2017 | 12.0-CURRENT после обновления копий clang, llvm, lld, lldb, compiler-rt и libc++ до версии 5.0.0 (trunk r308421). | |
1200040 | 29 июля 2017 | 12.0-CURRENT после добавления поддержки принудительного демонтирования клиента NFS | |
1200041 | 21 августа 2017 | 12.0-CURRENT после того, как инструкция WRFSBASE стала работоспособной на amd64. | |
1200042 | 25 августа 2017 | 12.0-CURRENT после изменения счетчиков PLPMTUD для использования counter(9). | |
1200043 | 28 августа 2017 | 12.0-CURRENT после уменьшения CACHE_LINE_SIZE для x86 до 64 байт. | |
1200044 | 8 сентября 2017 | 12.0-CURRENT после реализации | |
1200045 | 18 сентября 2017 | 12.0-CURRENT после добавления поддержки разделяемой памяти в LinuxKPI. (323703). | |
1200046 | 22 сентября 2017 | 12.0-CURRENT после добавления поддержки 32-битных совместимых IOCTL в LinuxKPI. | |
1200047 | 26 сентября 2017 | 12.0-CURRENT после удаления M_HASHTYPE_RSS_UDP_IPV4_EX. (324052). | |
1200048 | 2 октября 2017 | 12.0-CURRENT после скрытия | |
1200049 | 4 октября 2017 | 12.0-CURRENT после добавления поля | |
1200050 | 5 октября 2017 | 12.0-CURRENT после добавления | |
1200051 | 9 октября 2017 | 12.0-CURRENT после удаления libstand.a как публичного интерфейса. (324454). | |
1200052 | 26 октября 2017 | 12.0-CURRENT после исправления | |
1200053 | 7 ноября 2017 | 12.0-CURRENT после изменения структуры | |
1200054 | 15 ноября 2017 | 12.0-CURRENT после изменения структуры | |
1200055 | 9 января 2018 | 12.0-CURRENT после добавления поддержки | |
1200056 | 14 января 2018 | 12.0-CURRENT после обновления clang, llvm, lld, lldb, compiler-rt и libc++ до версии 6.0.0 (ветки/release_60 r321788). | |
1200057 | 8 февраля 2018 | 12.0-CURRENT после применения исправления в clang 6.0.0 для корректной сборки портов wine. | |
1200058 | 12 февраля 2018 | 12.0-CURRENT после включения загрузчика Lua. | |
1200059 | 2 марта 2018 | 12.0-CURRENT после удаления объявления | |
1200060 | 4 марта 2018 | 12.0-CURRENT после обновления clang, llvm, lld, lldb, compiler-rt и libc++ до версии 6.0.0. | |
1200061 | 6 апреля 2018 | 12.0-CURRENT после изменения syslog(3) для генерации сообщений в формате RFC 5424. | |
1200062 | 12 апреля 2018 | 12.0-CURRENT после изменения API Netmap. | |
1200063 | 10 мая 2018 | 12.0-CURRENT после переработки параметров интерфейса и внутренней части CTL для использования nv(3), разрешено создание нескольких портов ioctl интерфейса. | |
1200064 | 22 мая 2018 | 12.0-CURRENT после изменения ifnet address и multicast address TAILQ на CK_STAILQ. | |
1200065 | 28 мая 2018 | 12.0-CURRENT после изменения dwatch(1) для разрешения использования '-E code' для переопределения EVENT_DETAILS в профиле. | |
1200066 | 1 июня 2018 | 12.0-CURRENT после удаления внутриядерных таблиц pmc для Intel. | |
1200067 | 9 июня 2018 | 12.0-CURRENT после добавления констант DW_LANG в libdwarf. | |
1200068 | 12 июня 2018 | 12.0-CURRENT после изменения интерфейса между модулями NFS. | |
1200069 | 15 июня 2018 | 12.0-CURRENT после изменения | |
1200070 | 2 июля 2018 | 12.0-CURRENT после встраивания atomic(9) в модули на amd64 и i386, что потребовало пересборки всех модулей потребителей для этих архитектур. | |
1200071 | 4 июля 2018 | 12.0-CURRENT после изменения ABI и API epoch(9) (335924), что потребовало пересборки модулей потребителей. | |
1200072 | 5 июля 2018 | 12.0-CURRENT после изменения ABI и API | |
1200073 | 15 июля 2018 | 12.0-CURRENT после изменения ABI и API структур | |
1200074 | 16 июля 2018 | 12.0-CURRENT после обновления конфигурации libstdc++ для использования функций C99. | |
1200075 | 19 июля 2018 | 12.0-CURRENT после объединения | |
1200076 | 30 июля 2018 | 12.0-CURRENT после изменений KPI в | |
1200077 | 10 августа 2018 | 12.0-CURRENT после добавления в систему timespec_get(3). | |
1200078 | 15 августа 2018 | 12.0-CURRENT после выполнения хука exec.created для клеток. | |
1200079 | 19 августа 2018 | 12.0-CURRENT после перевода | |
1200080 | 22 августа 2018 | 12.0-CURRENT после удаления драйверов drm. | |
1200081 | 21 августа 2018 | 12.0-CURRENT после изменений KPI для NVMe. | |
1200082 | 24 августа 2018 | 12.0-CURRENT после отмены удаления драйверов drm. | |
1200083 | 26 августа 2018 | 12.0-CURRENT после удаления | |
1200084 | 5 сентября 2018 | 12.0-CURRENT после обновления objcopy(1) для корректной обработки little-endian MIPS64 объектных файлов. | |
1200085 | 19 октября 2018 | 12.0-STABLE после обновления OpenSSL до версии 1.1.1. | |
1200086 | 25 октября 2018 | 12.0-STABLE после обновления номеров версий разделяемых библиотек OpenSSL. | |
1200500 | 16 ноября 2018 | 12-STABLE после ветвления releng/12.0. | |
1200501 | 6 января 2019 | 12-STABLE после слияния исправления поведения | |
1200502 | January 17, 2019 | 12-STABLE после включения #include <sys/random.h> в C++. | |
1200503 | 15 февраля 2019 | 12-STABLE после слияния исправления renameat(2) для ядер с CAPABILITIES. | |
1200504 | 15 марта 2019 | 12-STABLE после слияния CCM для работы с портом ZoF. | |
1200505 | 20 марта 2019 | 12-STABLE после объединения поддержки выборочного отключения ZFS без отключения загрузчика. | |
1200506 | 12 апреля 2019 | 12-STABLE после слияния llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp 8.0.0 финальный релиз r356365. | |
1200507 | 17 апреля 2019 | 12-STABLE после слияния изменений iflib из ревизий 345303, 345658, и частично из 345305. | |
1200508 | 27 апреля 2019 | 12-STABLE после появления | |
1200509 | 16 мая 2019 | 12-STABLE после обновления номеров версий драйверов Mellanox (mlx4en(4); mlx5en(4)). | |
1200510 | 21 мая 2019 | 12-STABLE после изменения структуры в linuxkpi из 348035. | |
1200511 | 24 мая 2019 | 12-STABLE после MFC изменения 347843: добавление элемента | |
1200512 | 24 мая 2019 | 12-STABLE после добавления элемента контекста к ww_mutex в LinuxKPI. | |
1200513 | 5 июля 2019 | 12-STABLE после MFC epoch(9) изменил: 349763, 340404, 340415, 340417, 340419, 340420. | |
1200514 | 17 июля 2019 | 12-STABLE после добавлений в список rcu LinuxKPI. | |
1200515 | 11 августа 2019 | 12-STABLE после слияния изменений 349891 (реорганизация списков SRCS в виде одного файла на строку с последующей сортировкой по алфавиту) и 349972 (добавление обёрток системных вызовов | |
1200516 | 20 августа 2019 | 12-STABLE после слияния различных изменений в iflib (MFC) 351276. | |
1200517 | 9 сентября 2019 | 12-STABLE после добавления функций создания/удаления sysfs, обрабатывающих несколько файлов за один вызов в LinuxKPI. | |
1200518 | 10 сентября 2019 | 12-STABLE после дополнительных обновлений LinuxKPI в sysfs. | |
1200519 | 15 сентября 2019 | 12-STABLE после переноса (MFC) нового драйвера fusefs. | |
1201000 | 20 сентября 2019 | releng/12.1 ответвился от stable/12@r352480. | |
1201500 | 20 сентября 2019 | 12-STABLE после ветвления releng/12.1. | |
1201501 | 10 ноября 2019 | 12-STABLE после исправления потенциальной проблемы безопасности OOB-чтения в libc++. | |
1201502 | 11 ноября 2019 | 12-STABLE после включения атрибутов группы классов устройств в LinuxKPI. | |
1201503 | 21 ноября 2019 | 12-STABLE после добавления поддержки | |
1201504 | 10 ноября 2019 | 12-STABLE после исправления проверки версии C++ для объявления timespec_get(3). | |
1201505 | 19 декабря 2019 | 12-STABLE после добавления расширений | |
1201506 | 21 декабря 2019 | 12-STABLE после удвоения значения | |
1201507 | 2 января 2020 | 12-STABLE после добавления функций в bitstring(3) для поиска непрерывных последовательностей установленных или сброшенных битов. | |
1201508 | 6 января 2020 | 12-STABLE после изменения статистики USB для каждого устройства вместо каждой шины. | |
1201509 | 7 января 2020 | 12-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до финального релиза 9.0.0 r372316. | |
1201510 | 13 января 2020 | 12-STABLE после добавления собственного счётчика для отменённых USB-передач. | |
1201511 | 31 января 2020 | 12-STABLE после добавления символической ссылки /etc/os-release на /var/run/os-release. | |
1201512 | 6 февраля 2020 | 12-STABLE после недавних изменений в LinuxKPI. | |
1201513 | 15 апреля 2020 | 12-STABLE после разделения интерфейса RCU на допускающий и не допускающий сон части в LinuxKPI. | |
1201514 | 1 мая 2020 | 12-STABLE после реализации полной поддержки bus_dma(9) в LinuxKPI и включения всех зависимостей. | |
1201515 | 1 мая 2020 | 12-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии 10.0.0. | |
1201516 | 4 мая 2020 | 12-STABLE после перемещения | |
1201517 | 21 мая 2020 | 12-STABLE после переименования | |
1201518 | 18 июня 2020 | 12-STABLE после реализации макроса функции | |
1201519 | 4 июля 2020 | 12-STABLE после перевода liblzma на использование реализации SHA256 из libmd. | |
1201520 | 24 июля 2020 | 12-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии 10.0.1. | |
1201521 | 3 августа 2020 | 12-STABLE после реализации функции | |
1201522 | 4 августа 2020 | 12-STABLE после добавления системного вызова sysctlbyname. | |
1201523 | 19 августа 2020 | 12-STABLE после изменения для клонирования полей структуры задачи, связанных с RCU. | |
1201524 | 5 сентября 2020 | 12-STABLE после выделения XDR в отдельный модуль ядра для минимизации зависимостей ZFS. | |
1201525 | 8 сентября 2020 | 12-STABLE после добавления атомарных функций и функций | |
1201526 | 10 сентября 2020 | 12-STABLE после обновления net80211 и изменений API проверки привилегий ядра. | |
1202000 | 11 сентября 2020 | releng/12.2 ответвился от stable/12@r365618. | |
1202500 | 11 сентября 2020 | 12-STABLE после ветвления releng/12.2. | |
1202501 | 12 сентября 2020 | 12-STABLE после последующих коммитов в libcompiler_rt. | |
1202502 | 16 сентября 2020 | 12-STABLE после исправления сборки приложения crunchgen(1) с | |
1202503 | 20 октября 2020 | 12-STABLE после заполнения поля контекста захвата | |
1202504 | 9 ноября 2020 | 12-STABLE после добавления ptsname_r(3). | |
1202505 | 28 декабря 2020 | 12-STABLE после улучшения обработки альтернативных настроек в стеке USB. | |
1202506 | 30 апреля 2021 | 12-STABLE после изменения внутреннего KAPI между krpc и NFS. | |
1202507 | 10 мая 2021 | 12-STABLE после изменения внутреннего KAPI между модулями nscl.ko и nfscommon.ko. | |
1202508 | 26 июня 2021 | 12-STABLE после изменения внутреннего KAPI между модулями krpc и nfsd. | |
1203500 | 20 октября 2021 | 12-STABLE после ветвления releng/12.3. | |
1203501 | 22 декабря 2021 | 12-STABLE после добавления атомарных функций и функций | |
1203502 | 22 декабря 2021 | 12-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии 11.0.1. | |
1203503 | 25 декабря 2021 | 12-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии 12.0.0. | |
1203504 | 25 декабря 2021 | 12-STABLE после добавления вспомогательных функций LSE атомарных операций вне строки в libcompiler_rt.a для архитектуры aarch64. | |
1203505 | 25 декабря 2021 | 12-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии 13.0.0. | |
1203506 | 12 февраля 2022 | 12-STABLE после восстановления компромисса доступности random(4). | |
1203507 | 9 апреля 2022 | 12-STABLE после объединения zlib. | |
1203508 | 19 октября 2022 | 12-STABLE после iflib: Разрешить драйверам определять, в какую очередь передавать данные. | |
1204000 | 20 октября 2022 | releng/12.4 — ветка от stable/12. | |
1204500 | 20 октября 2022 | 12-STABLE после ветвления releng/12.4. |
18.5. FreeBSD 11 Версии
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
1100000 | 10 октября 2013 | 11.0-CURRENT. | |
1100001 | 19 октября 2013 | 11.0-CURRENT после добавления поддержки сценариев rc.d для "первой загрузки", что позволяет портам использовать эту возможность. | |
1100002 | 5 ноября 2013 | 11.0-CURRENT после прекращения поддержки устаревших ioctl. | |
1100003 | 17 ноября 2013 | 11.0-CURRENT после изменений в iconv. | |
1100004 | 15 декабря 2013 | 11.0-CURRENT после изменения поведения | |
1100005 | 28 декабря 2013 | 11.0-CURRENT после 259951 - Не объединять записи в vm_map_stack(9). | |
1100006 | 28 января 2014 | 11.0-CURRENT после обновления libelf и libdwarf. | |
1100007 | 30 января 2014 | 11.0-CURRENT после обновления libc++ до версии 3.4. | |
1100008 | February 14, 2014 | 11.0-CURRENT после исправления совместимости ABI в libc++ 3.4. | |
1100009 | 16 февраля 2014 | 11.0-CURRENT после обновления llvm/clang до версии 3.4. | |
1100010 | 28 февраля 2014 | 11.0-CURRENT после обновления ncurses до версии 5.9 (ревизия 262629). | |
1100011 | 13 марта 2014 | 11.0-CURRENT после изменения ABI в структуре | |
1100012 | 14 марта 2014 | 11.0-CURRENT после удаления поддержки протокола Novell IPX. | |
1100013 | 14 марта 2014 | 11.0-CURRENT после удаления поддержки протокола AppleTalk. | |
1100014 | March 16, 2014 | 11.0-CURRENT после переименования <sys/capability.h> в <sys/capsicum.h> во избежание конфликта с одноименными заголовочными файлами в других операционных системах. Совместимый заголовочный файл оставлен для уменьшения количества проблем при сборке, но в будущем будет устаревшим. | |
1100015 | 22 марта 2014 | 11.0-CURRENT после переименования | |
1100016 | 23 марта 2014 | 11.0-CURRENT после добавления | |
1100017 | 4 апреля 2014 | 11.0-CURRENT после удаления поддержки GCC для определения | |
1100018 | 6 апреля 2014 | 11.0-CURRENT после добавления поддержки протокола UDP-Lite (RFC 3828). | |
1100019 | 8 апреля 2014 | 11.0-CURRENT после FreeBSD-SA-14:06.openssl (ревизия 264265). | |
1100020 | 1 мая 2014 | 11.0-CURRENT после удаления | |
1100021 | 6 мая 2014 | 11.0-CURRENT после изменений в src.opts.mk, отделяющих make.conf(5) от | |
1100022 | 30 мая 2014 | 11.0-CURRENT после изменений в strcasecmp(3), перемещении strcasecmp_l(3) и strncasecmp_l(3) из <string.h> в <strings.h> для соответствия POSIX 2008 (rev 266865). | |
1100023 | 13 июня 2014 | 11.0-CURRENT после подключения библиотеки CUSE и модуля ядра к сборке по умолчанию. | |
1100024 | 27 июня 2014 | 11.0-CURRENT после изменения API sysctl(3). | |
1100025 | 30 июня 2014 | 11.0-CURRENT после обновления библиотеки regex(3) для добавления разделителей ">" и "<". | |
1100026 | 1 июля 2014 | 11.0-CURRENT после изменения внутреннего интерфейса между модулями NFS, включая krpc, в (rev 268115). | |
1100027 | 8 июля 2014 | 11.0-CURRENT после FreeBSD-SA-14:17.kmem (ссылка на ревизию:https://svnweb.freebsd.org/changeset/base/268431[268431]). | |
1100028 | 21 июля 2014 | 11.0-CURRENT после исправления соответствия hdestroy(3) изменился ABI. | |
1100029 | 3 августа 2014 | 11.0-CURRENT после исправления ошибки | |
1100030 | 1 сентября 2014 | 11.0-CURRENT после того, как сокеты | |
1100031 | 9 сентября 2014 | 11.0-CURRENT после FreeBSD-SA-14:18.openssl (ссылка на ревизию:https://svnweb.freebsd.org/changeset/base/269686[269686]). | |
1100032 | 11 сентября 2014 | 11.0-CURRENT после изменений API в | |
1100033 | 9 сентября 2014 | 11.0-CURRENT после изменения | |
1100034 | 16 сентября 2014 | 11.0-CURRENT после FreeBSD-SA-14:19.tcp (rev 271666). | |
1100035 | 17 сентября 2014 | 11.0-CURRENT после добавления поддержки аппаратного контекста i915. | |
1100036 | 17 сентября 2014 | Увеличение версии для различия в ABI-примечании бинарных файлов, готовых к строгой проверке флагов mmap(2) (изменение 271724). | |
1100037 | 6 октября 2014 | 11.0-CURRENT после добавления explicit_bzero(3) (изменение:https://svnweb.freebsd.org/changeset/base/272673[272673]). | |
1100038 | October 11, 2014 | 11.0-CURRENT после очистки заголовков TCP wrapper. | |
1100039 | 18 октября 2014 | 11.0-CURRENT после удаления | |
1100040 | 21 октября 2014 | 11.0-CURRENT после FreeBSD-SA-14:23 (ссылка на ревизию:https://svnweb.freebsd.org/changeset/base/273146[273146]). | |
1100041 | 30 октября 2014 | 11.0-CURRENT после изменений API в | |
1100042 | 3 ноября 2014 | 11.0-CURRENT после изменения | |
1100043 | 4 ноября 2014 | 11.0-CURRENT после включения vt(4) по умолчанию. | |
1100044 | 4 ноября 2014 | 11.0-CURRENT после добавления новых библиотек/утилит ( | |
1100045 | 4 ноября 2014 | 11.0-CURRENT после FreeBSD-SA-14:23, FreeBSD-SA-14:24 и FreeBSD-SA-14:25. | |
1100046 | 13 ноября 2014 | 11.0-CURRENT после изменения сигнатуры | |
1100047 | 13 ноября 2014 | 11.0-CURRENT после удаления no-at версий вспомогательных системных вызовов VFS, таких как | |
1100048 | 1 декабря 2014 | 11.0-CURRENT после начала процесса удаления использования устаревшего флага "M_FLOWID" из сетевого кода. | |
1100049 | 9 декабря 2014 | 11.0-CURRENT после импорта важного исправления в векторизатор LLVM, которое в некоторых случаях могло приводить к переполнению буфера. | |
1100050 | 12 декабря 2014 | 11.0-CURRENT после добавления AES-ICM и AES-GCM в OpenCrypto. | |
1100051 | December 23, 2014 | 11.0-CURRENT после удаления старого кода клиента и сервера NFS из ядра. | |
1100052 | 31 декабря 2014 | 11.0-CURRENT после обновления clang, llvm и lldb до версии 3.5.0. | |
1100053 | 7 января 2015 | 11.0-CURRENT после того, как MCLGET(9) получил возвращаемое значение (rev 276750). | |
1100054 | 15 января 2015 | 11.0-CURRENT после переработки подсистемы вызовов. | |
1100055 | 22 января 2015 | 11.0-CURRENT после отмены изменений callout в 277213. | |
1100056 | 23 января 2015 | 11.0-CURRENT после добавления системных вызовов | |
1100057 | 29 января 2015 | 11.0-CURRENT после удаления | |
1100058 | 5 февраля 2015 | 11.0-CURRENT после добавления поддержки запроса страницы расширенного запроса SCSI VPD (0x86). | |
1100059 | 9 февраля 2015 | 11.0-CURRENT после импорта xz 5.2.0, который добавил многопоточное сжатие, и lzma получила зависимость от libthr (rev 278433). | |
1100060 | 16 февраля 2015 | 11.0-CURRENT после пересылки | |
1100061 | 18 февраля 2015 | 11.0-CURRENT после добавления | |
1100062 | 23 февраля 2015 | 11.0-CURRENT после добавлений API mtio(4) и sa(4), а также ioctl(2). | |
1100063 | 7 марта 2015 | 11.0-CURRENT после добавления поддержки мьютексов в API | |
1100064 | 7 марта 2015 | 11.0-CURRENT после добавления поддержки PPS в драйверы USB-последовательных портов. | |
1100065 | 15 марта 2015 | 11.0-CURRENT после обновления clang, llvm и lldb до версии 3.6.0. | |
1100066 | 20 марта 2015 | 11.0-CURRENT после удаления поддержки SSLv2 из OpenSSL. | |
1100067 | 25 марта 2015 | 11.0-CURRENT после удаления поддержки SSLv2 из fetch(1) и fetch(3). | |
1100068 | 6 апреля 2015 | 11.0-CURRENT после изменения системной настройки net.inet6.ip6.mif6table. | |
1100069 | 15 апреля 2015 | 11.0-CURRENT после удаления квалификатора const из iconv(3). | |
1100070 | 16 апреля 2015 | 11.0-CURRENT после перемещения ALTQ из contrib в net/altq. | |
1100071 | 29 апреля 2015 | ||
1100072 | 1 мая 2015 | 11.0-CURRENT после добавления reallocarray(3) в libc (изменение 282314). | |
1100073 | 8 мая 2015 | 11.0-CURRENT после увеличения максимального количества разрешённых PCM-каналов в PCM-потоке до 127 и уменьшения максимального количества подканалов до 1. | |
1100074 | 25 мая 2015 | 11.0-CURRENT после добавления предварительной поддержки бинарных файлов Linux для x86-64 (rev 283424) и обновления clang и llvm до версии 3.6.1. | |
1100075 | 27 мая 2015 | 11.0-CURRENT после | |
1100076 | 4 июня 2015 | 11.0-CURRENT после отключения генерации записей в устаревших форматах баз данных паролей по умолчанию. | |
1100077 | 10 июня 2015 | 11.0-CURRENT после изменений API в | |
1100078 | 12 августа 2015 | 11.0-CURRENT после изменений crunchgen(1) в ревизиях 284356 до 285986. | |
1100079 | 18 августа 2015 | 11.0-CURRENT после импорта jemalloc 4.0.0 (ревизия 286866). | |
1100080 | 5 октября 2015 | 11.0-CURRENT после обновления clang, llvm, lldb, compiler-rt и libc++ до версии 3.7.0. | |
1100081 | 16 октября 2015 | 11.0-CURRENT после | |
1100082 | 19 октября 2015 | 11.0-CURRENT после обновлений Linux KPI. | |
1100083 | October 22, 2015 | 11.0-CURRENT после переименования linuxapi.ko в linuxkpi.ko. | |
1100084 | 29 октября 2015 | 11.0-CURRENT после перемещения модуля LinuxKPI в стандартную сборку ядра. | |
1100085 | 30 октября 2015 | 11.0-CURRENT после импорта OpenSSL 1.0.2d. | |
1100086 | 2 ноября 2015 | 11.0-CURRENT после изменения макросов figpar(3) для большей уникальности. | |
1100087 | 7 ноября 2015 | 11.0-CURRENT после изменения ABI sysctl_add_oid(9). | |
1100088 | 7 ноября 2015 | 11.0-CURRENT после переработки сортировки строк и локалей. | |
1100089 | 7 ноября 2015 | 11.0-CURRENT после изменения API в sysctl_add_oid(9) (rev 290475). | |
1100090 | 10 ноября 2015 | 11.0-CURRENT после изменения API для макроса callout_stop; (ссылка на ревизию:https://svnweb.freebsd.org/changeset/base/290664[290664]). | |
1100091 | 30 ноября 2015 | 11.0-CURRENT после изменения интерфейса между модулями nfsd.ko и nfscommon.ko в 291527. | |
1100092 | 19 декабря 2015 | 11.0-CURRENT после удаления | |
1100093 | 30 декабря 2015 | 11.0-CURRENT после удаления sys/crypto/sha2.h (изменение 292782). | |
1100094 | 15 января 2016 | 11.0-CURRENT после изменений LinuxKPI PCI (rev 294086). | |
1100095 | 19 января 2016 | 11.0-CURRENT после оптимизаций LRO. | |
1100096 | 21 января 2016 | 11.0-CURRENT после добавления LinuxKPI idr_*. | |
1100097 | 26 января 2016 | 11.0-CURRENT после изменения API в dpv(3). | |
1100098 | 16 февраля 2016 | 11.0-CURRENT после изменения API в | |
1100099 | 18 февраля 2016 | 11.0-CURRENT после разрешения драйверам устанавливать лимит агрегации сегментов TCP ACK/данных. | |
1100100 | 26 февраля 2016 | 11.0-CURRENT после добавления API bus_alloc_resource_any(9). | |
1100101 | 5 марта 2016 | 11.0-CURRENT после обновления копий clang, llvm, lldb и compiler-rt до релиза 3.8.0. | |
1100102 | 12 марта 2016 | 11.0-CURRENT после исправления кросс-эндианности libelf в ревизии 296685. | |
1100103 | 18 марта 2016 | 11.0-CURRENT после использования | |
1100104 | 21 марта 2016 | 11.0-CURRENT после отслеживания использования | |
1100105 | 6 апреля 2016 | 11.0-CURRENT после исправления функций | |
1100106 | 22 апреля 2016 | 11.0-CURRENT после исправлений для использования IPv6-адресов с RDMA. | |
1100107 | 4 мая 2016 | 11.0-CURRENT после улучшения производительности и функциональности API bitstring(3). | |
1100108 | 12 мая 2016 | 11.0-CURRENT после исправления обработки IOCTL в LinuxKPI. | |
1100109 | 16 мая 2016 | 11.0-CURRENT после реализации дополнительных функций, связанных с устройствами Linux, в LinuxKPI. | |
1100110 | 19 мая 2016 | 11.0-CURRENT после добавления поддержки управления дисками с черепичной магнитной записью (Shingled Magnetic Recording, SMR). | |
1100111 | 20 мая 2016 | 11.0-CURRENT после удаления | |
1100112 | 23 мая 2016 | 11.0-CURRENT после добавления | |
1100113 | 26 мая 2016 | 11.0-CURRENT после отключения ошибок выравнивания на armv6. | |
1100114 | 26 мая 2016 | 11.0-CURRENT после исправления использования crunchgen(1) с | |
1100115 | 30 мая 2016 | 11.0-CURRENT после добавления флага mbuf для | |
1100116 | 31 мая 2016 | 11.0-CURRENT после добавления SHA-512t256 (ревизия 300903) и Skein (ревизия 300966) в libmd, libcrypt, ядро и ZFS (ревизия 301010). | |
1100117 | 6 июня 2016 | 11.0-CURRENT после синхронизации libpam с основной версией 301602, что привело к увеличению версии библиотеки. | |
1100118 | 21 июня 2016 | 11.0-CURRENT после нарушения бинарной совместимости структуры disk 302069. | |
1100119 | 23 июня 2016 | 11.0-CURRENT после перевода | |
1100120 | 23 июня 2016 | 11.0-CURRENT после добавления запасных элементов в struct ifnet. | |
1100121 | 12 августа 2015 | 11-STABLE после того, как ветка | |
1100500 | 12 августа 2016 | 11.0-STABLE добавлена ветвленная link: 303976. | |
1100501 | 22 августа 2016 | 11.0-STABLE после добавления поддержки | |
1100502 | 26 августа 2016 | 11.0-STABLE после исправления | |
1100503 | 12 сентября 2016 | 11.0-STABLE после устранения взаимоблокировки между | |
1100504 | 14 октября 2016 | 11.0-STABLE после объединения ZFS. | |
1100505 | 19 октября 2016 | 11.0-STABLE после изменения | |
1100506 | 28 октября 2016 | 11.0-STABLE после установки заголовочных файлов, необходимых для разработки с | |
1100507 | 15 декабря 2016 | 11.0-STABLE после добавления члена | |
1100508 | 26 декабря 2016 | 11.0-STABLE после обновления копий clang, llvm, lldb, compiler-rt и libc++ до версии 3.9.1, а также добавления lld 3.9.1. | |
1100509 | 3 января 2017 | 11.0-STABLE после исправления META_MODE в crunchgen(1) (изменение 311185). | |
1100510 | 15 марта 2017 | 11.0-STABLE после MFC изменений, связанных с | |
1100511 | 2 апреля 2017 | 11.0-STABLE после нескольких MFC, обновляющих clang, llvm, lld, lldb, compiler-rt и libc++ до версии 4.0.0. | |
1100512 | 4 апреля 2017 | 11.0-STABLE после того, как блокировка CAM SIM стала опциональной (ревизии 315673, 315674). | |
1100513 | 11 мая 2017 | 11.0-STABLE после объединения добавления заголовочного файла <dev/mmc/mmc_ioctl.h>. | |
1100514 | 31 мая 2017 | 11.0-STABLE после нескольких MFC для | |
1101000 | June 30, 2017 |
| |
1101001 | June 30, 2017 | 11.1-RC1 После объединения добавления флага | |
1101500 | June 30, 2017 | 11-STABLE после ветвления | |
1101501 | 5 июля 2017 | 11-STABLE после объединения добавления флага | |
1101502 | 29 июля 2017 | 11-STABLE после объединения поддержки принудительного демонтирования клиента NFS с добавлением | |
1101503 | 11 сентября 2017 | 11-STABLE после объединения изменений, сделавших инструкцию WRFSBASE работоспособной на amd64. | |
1101504 | 26 сентября 2017 | 11-STABLE после слияния libm из head, что добавляет cacoshl(3), cacosl(3), casinhl(3), casinl(3), catanl(3), catanhl(3), sincos(3), sincosf(3) и sincosl(3). | |
1101505 | 26 сентября 2017 | 11-STABLE после объединения clang, llvm, lld, lldb, compiler-rt и libc++ версии 5.0.0. | |
1101506 | 25 октября 2017 | 11-STABLE после слияния 324281, добавления поля | |
1101507 | 24 января 2018 | 11-STABLE после слияния с 325028, исправление | |
1101508 | 24 января 2018 | 11-STABLE после объединения изменений 316648, переименование | |
1101509 | 1 февраля 2018 | 11-STABLE после обратного переноса (overwrite merge) LinuxKPI из FreeBSD-head. | |
1101510 | 17 февраля 2018 | 11-STABLE после того, как макрос | |
1101511 | 25 февраля 2018 | 11-STABLE после завершения недавних обновлений, связанных с LinuxKPI. | |
1101512 | 19 марта 2018 | 11-STABLE после объединения поддержки | |
1101513 | 31 марта 2018 | 11-STABLE после объединения clang, llvm, lld, lldb, compiler-rt и libc++ версии 6.0.0, а также нескольких последующих исправлений. | |
1101514 | 5 апреля 2018 | 11-STABLE после объединения изменений 328331, добавляющего новую и несовместимую интерпретацию | |
1101515 | 10 апреля 2018 | 11-STABLE после отмены изменений из 331880, удаляющих новую и несовместимую интерпретацию | |
1101516 | 30 мая 2018 | 11-STABLE после доработок dwatch(1). | |
1102000 | 1 июня 2018 |
| |
1102500 | 1 июня 2018 | 11-STABLE после ветвления releng/11.2. | |
1102501 | June 20, 2018 | 11-STABLE после обновлений LinuxKPI, требующих перекомпиляции внешних модулей ядра. | |
1102502 | 12 сентября 2018 | 11-STABLE после добавления сокет-опции SO_TS_CLOCK и исправления системного вызова | |
1102503 | 25 сентября 2018 | 11-STABLE после объединения исправления контрольной суммы TCP в iflib(9) и добавления новых типов носителей в if_media.h | |
1102504 | 9 ноября 2018 | 11-STABLE после нескольких MFC: обновление objcopy(1) для корректной обработки little-endian MIPS64 объектов; исправление теста mips64el для использования заголовка ELF; добавление теста для 64-битного ELF в _libelf_is_mips64el. | |
1102505 | 6 января 2019 | 11-STABLE после слияния исправления поведения | |
1102506 | 17 февраля 2019 | 11-STABLE после объединения нескольких коммитов в lualoader. | |
1102507 | 16 апреля 2019 | 11-STABLE после объединения llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp 8.0.0 финальный релиз r356365. | |
1102508 | 27 апреля 2019 | 11-STABLE после появления | |
1102509 | 6 мая 2019 | 11-STABLE после слияния изменений 345303, 345658, и частично 345305. | |
1102510 | 16 мая 2019 | 11-STABLE после увеличения номеров версий драйверов Mellanox (mlx4en(4); mlx5en(4)). | |
1103000 | 14 июня 2019 |
| |
1103500 | 14 июня 2019 | 11-STABLE после ветвления releng/11.3. | |
1103501 | 10 ноября 2019 | 11-STABLE после исправления потенциальной проблемы безопасности OOB-чтения в libc++. | |
1103502 | 11 ноября 2019 | 11-STABLE после добавления функций создания/удаления sysfs, обрабатывающих несколько файлов за один вызов в LinuxKPI. | |
1103503 | 11 ноября 2019 | 11-STABLE после улучшений LinuxKPI sysfs. | |
1103504 | 11 ноября 2019 | 11-STABLE после включения атрибутов группы классов устройств в LinuxKPI. | |
1103505 | 19 декабря 2019 | 11-STABLE после добавления расширений | |
1103506 | 6 января 2020 | 11-STABLE после изменения статистики USB для каждого устройства вместо каждой шины. | |
1103507 | 13 января 2020 | 11-STABLE после добавления собственного счетчика для отмененных USB-передач. | |
1103508 | 6 февраля 2020 | 11-STABLE после недавних изменений в LinuxKPI. | |
1103509 | 15 апреля 2020 | 11-STABLE после перемещения | |
1103510 | 5 мая 2020 | 11-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до финального релиза 9.0.0 r372316. | |
1103511 | 7 мая 2020 | 11-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии 10.0.0. | |
1104000 | 8 мая 2020 |
| |
1104001 | 8 мая 2020 | 11.4-BETA1 после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии 10.0.0. | |
1104500 | 8 мая 2020 | 11-STABLE после ветвления releng/11.4. | |
1104501 | 18 июня 2020 | 11-STABLE после реализации макроса функции | |
1104502 | 4 июля 2020 | 11-STABLE после перевода liblzma на использование реализации SHA256 из libmd. | |
1104503 | 24 июля 2020 | 11-STABLE после обновления llvm, clang, compiler-rt, libc++, libunwind, lld, lldb и openmp до версии 10.0.1. | |
1104504 | 3 августа 2020 | 11-STABLE после реализации функции | |
1104505 | 19 августа 2020 | 11-STABLE после изменения для клонирования полей структуры задачи, связанных с RCU. | |
1104506 | 8 сентября 2020 | 11-STABLE после добавления атомарных функций и функций | |
1104507 | 12 сентября 2020 | 11-STABLE после последующих коммитов в libcompiler_rt. | |
1104508 | 20 октября 2020 | 11-STABLE после заполнения поля контекста получения в | |
1104509 | 20 октября 2020 | 11-STABLE после добавлений в список | |
1104510 | 9 ноября 2020 | 11-STABLE после добавления |
18.6. Версии FreeBSD 10
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
1000000 | 26 сентября 2011 | 10.0-CURRENT. | |
1000001 | 4 ноября 2011 | 10-CURRENT после добавления системного вызова posix_fadvise(2). | |
1000002 | 12 декабря 2011 | 10-CURRENT после определения булевых значений true/false в sys/types.h, размер sizeof(bool) мог измениться (ревизия 228444). 10-CURRENT после введения xlocale.h (ревизия 227753). | |
1000003 | 16 декабря 2011 | 10-CURRENT после значительных изменений в carp(4), изменения размера структур | |
1000004 | 1 января 2012 | 10-CURRENT после удаления | |
1000005 | 16 января 2012 | 10-CURRENT после удаления поддержки ioctls SIOCSIFADDR, SIOCSIFNETMASK, SIOCSIFBRDADDR, SIOCSIFDSTADDR. | |
1000006 | 26 января 2012 | 10-CURRENT после внедрения асинхронного уведомления о данных пропускной способности чтения в слое cam(4). | |
1000007 | 5 февраля 2012 | 10-CURRENT после введения новых параметров сокета tcp(4): TCP_KEEPINIT, TCP_KEEPIDLE, TCP_KEEPINTVL и TCP_KEEPCNT. | |
1000008 | 11 февраля 2012 | 10-CURRENT после введения нового расширяемого интерфейса sysctl(3) NET_RT_IFLISTL для запроса списков адресов. | |
1000009 | 25 февраля 2012 | 10-CURRENT после импорта libarchive 3.0.3 (rev 232153). | |
1000010 | 31 марта 2012 | 10-CURRENT после очистки | |
1000011 | 16 апреля 2012 | Импорт LLVM/Clang 3.1 из 10-CURRENT, ссылка на ревизию: 154661 (ревизия 234353). | |
1000012 | 2 мая 2012 | 10-CURRENT импорт jemalloc. | |
1000013 | 22 мая 2012 | 10-CURRENT после импорта | |
1000014 | 27 июня 2012 | 10-CURRENT после того, как BSD sort стал сортировкой по умолчанию (rev 237629). | |
1000015 | 12 июля 2012 | 10-CURRENT после импорта OpenSSL 1.0.1c. | |
(не изменено) | July 13, 2012 | 10-CURRENT после исправления регрессии в LLVM/Clang 3.1. | |
1000016 | 8 августа 2012 | 10-CURRENT после изменения KBI в ucom(4). | |
1000017 | 8 августа 2012 | 10-CURRENT после добавления функции потоков в стек USB. | |
1000018 | 8 сентября 2012 | 10-CURRENT после значительной переработки pf(4). | |
1000019 | 6 октября 2012 | 10-CURRENT после изменения KBI/KPI в pfil(9) для передачи пакетов в порядке байтов сети к хукам фильтрации AF_INET. | |
1000020 | 16 октября 2012 | 10-CURRENT после изменения KPI клонирования сетевых интерфейсов и структура | |
1000021 | 22 октября 2012 | 10-CURRENT после удаления поддержки не-MPSAFE файловых систем и добавления поддержки FUSEFS (rev 241519). | |
1000022 | 22 октября 2012 | 10-CURRENT после перевода всего стека IPv4 на сетевой порядок байтов для хранения заголовков IP-пакетов. | |
1000023 | 5 ноября 2012 | 10-CURRENT после буфера джиттера в общем коде драйвера USB-последовательного порта, для временного хранения символов, если буфер TTY заполнен. Добавлены сигналы остановки и возобновления потока при возникновении такой ситуации. | |
1000024 | 5 ноября 2012 | 10-CURRENT после того, как clang стал компилятором по умолчанию для i386 и amd64. | |
1000025 | 17 ноября 2012 | 10-CURRENT после того, как переменная-член sin6_scope_id в структуре sockaddr_in6 была изменена таким образом, что ядро заполняет её перед передачей структуры в пользовательское пространство через sysctl или сокет маршрутизации. Это означает, что специфичный для KAME встроенный идентификатор области в sin6_addr.s6_addr[2] всегда очищается в пользовательских приложениях. | |
1000026 | 11 января 2013 | 10-CURRENT после установки получил флаг -N. Также может использоваться для указания наличия nmtree. | |
1000027 | 29 января 2013 | 10-CURRENT после того, как команда | |
1000028 | 13 февраля 2013 | 10-CURRENT после перемещения USB в структуру драйверов, требующую пересборки всех модулей USB. | |
1000029 | 4 марта 2013 | 10-CURRENT после внедрения бестиковой системы отложенных вызовов, которая также изменила структуру struct callout (rev 247777). | |
1000030 | 12 марта 2013 | 10-CURRENT после нарушения KPI, внесённого в подсистему VM для поддержки блокировок чтения/записи (rev 248084). | |
1000031 | 26 апреля 2013 | 10-CURRENT после изменения параметра | |
1000032 | 1 мая 2013 | 10-CURRENT после введения системных вызовов accept4(2) (rev 250154) и pipe2(2) (rev 250159). | |
1000033 | 21 мая 2013 | 10-CURRENT после импорта flex 2.5.37. | |
1000034 | 3 июня 2013 | 10-CURRENT после добавления следующих функций в libm: cacos(3), cacosf(3), cacosh(3), cacoshf(3), casin(3), casinf(3), casinh(3), casinhf(3), catan(3), catanf(3), catanh(3), catanhf(3), logl(3), log2l(3), log10l(3), log1pl(3), expm1l(3). | |
1000035 | 8 июня 2013 | 10-CURRENT после введения системного вызова aio_mlock(2) (изменение 251526). | |
1000036 | 9 июля 2013 | 10-CURRENT после добавления новой функции в интерфейс вызовов функций модуля ядра GSSAPI. | |
1000037 | 9 июля 2013 | 10-CURRENT после миграции структур статистики на PCPU-счетчики. Измененные структуры включают: | |
1000038 | 16 июля 2013 | 10-CURRENT после установки | |
1000039 | 22 июля 2013 | 10-CURRENT после изменений в сканировании драйверов | |
1000040 | 24 июля 2013 | 10-CURRENT после добавления файлов | |
1000041 | 5 августа 2013 | 10-CURRENT после изменения с | |
1000042 | 9 августа 2013 | 10-CURRENT после изменения подсистемы VM для объединения механизмов мягкой и жесткой занятости. | |
1000043 | 13 августа 2013 | 10-CURRENT после того, как | |
1000044 | 15 августа 2013 | 10-CURRENT после преобразования libc.so в скрипт ld(1) (изменение rev 251668). | |
1000045 | 15 августа 2013 | 10-CURRENT после изменения программного интерфейса devfs путем замены флага | |
1000046 | 19 августа 2013 | 10-CURRENT после добавления | |
1000047 | 21 августа 2013 | 10-CURRENT после обновления stat(2), позволяющего сохранять некоторые атрибуты файлов Windows/DOS и CIFS в виде флагов stat(2). | |
1000048 | August 22, 2013 | 10-CURRENT после изменения структуры | |
1000049 | 24 августа 2013 | 10-CURRENT после поддержки physio(9) для устройств, которые работают некорректно с разделённым вводом-выводом, таких как sa(4). | |
1000050 | 24 августа 2013 | 10-CURRENT после изменений структуры | |
1000051 | 25 августа 2013 | 10-CURRENT после импорта драйвера Radeon KMS (ревизия 254885). | |
1000052 | 3 сентября 2013 | 10-CURRENT после импорта NetBSD | |
1000053 | 6 сентября 2013 | 10-CURRENT после изменений API и ABI в рамках Capsicum. | |
1000054 | 6 сентября 2013 | 10-CURRENT после того, как | |
1000055 | 6 сентября 2013 | 10-CURRENT после добавления флага | |
1000100 | December 7, 2013 |
| |
1000500 | 10 октября 2013 | 10-STABLE после ветвления от | |
1000501 | 22 октября 2013 | 10-STABLE после добавления поддержки rc(8) при первой загрузке. | |
1000502 | 20 ноября 2013 | 10-STABLE после удаления символов iconv из | |
1000510 | December 7, 2013 |
| |
1000700 | December 7, 2013 | 10-STABLE после ветки | |
1000701 | 15 декабря 2013 | 10.0-STABLE после исправления кодирования Heimdal. | |
1000702 | 31 декабря 2013 | 10-STABLE после исправлений MAP_STACK. | |
1000703 | 5 марта 2014 | 10-STABLE после обновления libc++ до версии 3.4. | |
1000704 | 7 марта 2014 | 10-STABLE после слияния из ветки vt(4) драйвера (ревизия 262861). | |
1000705 | 21 марта 2014 | 10-STABLE после обновления llvm/clang до версии 3.4. | |
1000706 | 6 апреля 2014 | 10-STABLE после удаления поддержки GCC для определения | |
1000707 | 8 апреля 2014 | 10-STABLE после FreeBSD-SA-14:06.openssl. | |
1000708 | 30 апреля 2014 | 10-STABLE после FreeBSD-SA-14:07.devfs, FreeBSD-SA-14:08.tcp и FreeBSD-SA-14:09.openssl. | |
1000709 | 13 мая 2014 | 10-STABLE после добавления поддержки протокола UDP-Lite (RFC 3828). | |
1000710 | 13 июня 2014 | 10-STABLE после изменений в strcasecmp(3), переноса strcasecmp_l(3) и strncasecmp_l(3) из <string.h> в <strings.h> для соответствия POSIX 2008. | |
1000711 | 8 июля 2014 | 10-STABLE после FreeBSD-SA-14:17.kmem (ревизия:https://svnweb.freebsd.org/changeset/base/268432[268432]). | |
1000712 | 1 августа 2014 | ||
1000713 | 3 августа 2014 | 10-STABLE после обновления библиотеки regex(3) для добавления разделителей ">" и "<". | |
1000714 | 3 августа 2014 | 10-STABLE после исправления ошибки | |
1000715 | 9 сентября 2014 | 10-STABLE после FreeBSD-SA-14:18 (rev 269686). | |
1000716 | 16 сентября 2014 | 10-STABLE после FreeBSD-SA-14:19 (ревизия 271667). | |
1000717 | 18 сентября 2014 | 10-STABLE после добавления поддержки аппаратного контекста i915. | |
1001000 | 2 октября 2014 | 10.1-RC1 после ветки releng/10.1. | |
1001500 | 2 октября 2014 | 10-STABLE после ветки releng/10.1. | |
1001501 | 21 октября 2014 | 10-STABLE после исправлений уязвимостей FreeBSD-SA-14:20, FreeBSD-SA-14:22 и FreeBSD-SA-14:23 (ссылка на ревизию: 273411). | |
1001502 | 4 ноября 2014 | 10-STABLE после FreeBSD-SA-14:23, FreeBSD-SA-14:24 и FreeBSD-SA-14:25. | |
1001503 | 25 ноября 2014 | 10-STABLE после объединения новых библиотек/утилит (dpv(1), dpv(3) и figpar(3)) для визуализации пропускной способности данных. | |
1001504 | 13 декабря 2014 | 10-STABLE после объединения важного исправления в векторизатор LLVM, которое в некоторых случаях могло приводить к переполнению буфера. | |
1001505 | 3 января 2015 | 10-STABLE после объединения некоторых констант ARM в 276312. | |
1001506 | 12 января 2015 | 10-STABLE после объединения обновления максимального размера таблицы для yacc. | |
1001507 | 27 января 2015 | 10-STABLE после изменений в обратном вызове туннелирования UDP для предоставления указателя контекста и исходного | |
1001508 | 18 февраля 2015 | 10-STABLE после добавления типа запроса | |
1001509 | 25 февраля 2015 | 10-STABLE после FreeBSD-EN-15:01.vt, FreeBSD-EN-15:02.openssl, FreeBSD-EN-15:03.freebsd-update, FreeBSD-SA-15:04.igmp и FreeBSD-SA-15:05.bind. | |
1001510 | 26 февраля 2015 | 10-STABLE после MFC ревизии 278964. | |
1001511 | 19 марта 2015 | 10-STABLE после переименования sys/capability.h в sys/capsicum.h (изменение:https://svnweb.freebsd.org/changeset/base/280224/[280224/]). | |
1001512 | 24 марта 2015 | ||
1001513 | 24 апреля 2015 | 10-STABLE после начала процесса удаления использования устаревшего флага "M_FLOWID" из сетевого кода. | |
1001514 | 30 апреля 2015 | 10-STABLE после MFC исправлений iconv(3). | |
1001515 | 11 мая 2015 | 10-STABLE после возврата | |
1001516 | 24 мая 2015 | 10-STABLE после переноса (MFC) множества изменений, связанных с USB. | |
1001517 | 3 июня 2015 | 10-STABLE после слияния изменений, связанных со звуком. | |
1001518 | 10 июня 2015 | 10-STABLE после MFC исправлений vfs для zfs (rev 284203). | |
1001519 | 23 июня 2015 | 10-STABLE после отмены увеличения | |
1002000 | 24 июля 2015 |
| |
1002500 | 24 июля 2015 | 10-STABLE после того, как ветка | |
1002501 | 8 октября 2015 | 10-STABLE после объединения изменений ZFS, затронувших внутренний интерфейс структуры | |
1002502 | 24 ноября 2015 | 10-STABLE после объединения изменений устройств дампа, которые затронули аргументы | |
1002503 | 14 декабря 2015 | 10-STABLE после объединения изменений во внутренний интерфейс между модулями nfsd.ko и nfscommon.ko, что требует их совместного обновления (rev 292223). | |
1002504 | 22 декабря 2015 | 10-STABLE после слияния xz 5.2.2 (поддержка многопоточности) (rev 292588). | |
1002505 | 30 декабря 2015 | 10-STABLE после объединения изменений в pci(4) (rev 292907). | |
1002506 | 9 января 2016 | 10-STABLE после объединения utimensat(2) (изменение 293473). | |
1002507 | 9 января 2016 | 10-STABLE после объединения изменений в linux(4) (rev 293477 через 293609). | |
1002508 | 9 января 2016 | 10-STABLE после объединения изменений в типы/макросы figpar(3) (rev 290275). | |
1002509 | 1 февраля 2016 | 10-STABLE после объединения изменения API в dpv(3). | |
1003000 | 4 марта 2016 |
| |
1003500 | 4 марта 2016 | 10-STABLE после того, как ветка | |
1003501 | 19 июня 2016 | 10-STABLE после добавления опции -P для | |
1003502 | 19 июня 2016 | 10-STABLE после того, как libcrypto.so стала позиционно-независимой. | |
1003503 | 19 июня 2016 | 10-STABLE после разрешения переопределений | |
1003504 | 21 июня 2016 | 10-STABLE после переноса изменений | |
1003505 | 27 июня 2016 | 10-STABLE после замены в sed на использование REG_STARTEND, с исправлением проблемы в Mesa. | |
1003506 | 22 августа 2016 | 10-STABLE после добавления поддержки | |
1003507 | 26 августа 2016 | 10-STABLE после исправления | |
1003508 | 12 сентября 2016 | 10-STABLE после устранения взаимоблокировки между | |
1003509 | 14 октября 2016 | 10-STABLE после слияния с ZFS. | |
1003510 | 28 октября 2016 | 10-STABLE после установки заголовочных файлов, необходимых для разработки с libzfs_core. | |
1003511 | 15 декабря 2016 | 10-STABLE после экспорта полного имени потока в | |
1003512 | 22 марта 2017 | 10-STABLE после изменений в libmd (rev 314143). | |
1003513 | 4 апреля 2017 | 10-STABLE после того, как блокировка CAM SIM стала опциональной (ревизии 315673, 315674). | |
1003514 | 11 мая 2017 | 10-STABLE после объединения добавления заголовочного файла <dev/mmc/mmc_ioctl.h>. | |
1003515 | 19 июля 2017 | 10-STABLE после добавления функций освобождения памяти с указанием размера из C14 в libc. | |
1003516 | 30 июля 2017 | 10-STABLE после объединения добавления флага | |
1004000 | 15 сентября 2017 |
| |
1004500 | 15 сентября 2017 | 10-STABLE после того, как ветка | |
1004501 | 24 января 2018 | 10-STABLE после слияния изменений 325028, исправляющего | |
1004502 | 6 января 2020 | 10-STABLE после изменения статистики USB для каждого устройства вместо каждой шины. | |
1004503 | 13 января 2020 | 10-STABLE после добавления собственного счетчика для отмененных USB-передач. |
18.7. Версии FreeBSD 9
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
900000 | 22 августа 2009 | 9.0-CURRENT. | |
900001 | 8 сентября 2009 | 9.0-CURRENT после импорта x86emu, программного эмулятора процессора x86 в реальном режиме из OpenBSD. | |
900002 | 23 сентября 2009 | 9.0-CURRENT после реализации функциональности фильтра | |
900003 | 2 декабря 2009 | 9.0-CURRENT после добавления sigpause(2) и поддержки PIE в | |
900004 | 6 декабря 2009 | 9.0-CURRENT после добавления libulog и его совместимого интерфейса libutempter. | |
900005 | December 12, 2009 | 9.0-CURRENT после добавления sleepq_sleepcnt(9), который может использоваться для запроса количества ожидающих в конкретной очереди ожидания. | |
900006 | 4 января 2010 | 9.0-CURRENT после изменения прототипов scandir(3) и alphasort(3) для соответствия SUSv4. | |
900007 | 13 января 2010 | 9.0-CURRENT после удаления utmp(5) и добавления | |
900008 | 20 января 2010 | 9.0-CURRENT после импорта BSDL bc/dc и устаревания GNU bc/dc. | |
900009 | 26 января 2010 | 9.0-CURRENT после добавления ioctl SIOCGIFDESCR и SIOCSIFDESCR к сетевым интерфейсам. Эти ioctl могут использоваться для управления описанием интерфейса, по аналогии с OpenBSD. | |
900010 | 22 марта 2010 | 9.0-CURRENT после импорта zlib 1.2.4. | |
900011 | April 24, 2010 | 9.0-CURRENT после добавления журналирования soft-updates. | |
900012 | 10 мая 2010 | 9.0-CURRENT после добавления liblzma, xz, xzdec и lzmainfo. | |
900013 | 24 мая 2010 | 9.0-CURRENT после внесения исправлений для USB в linux(4). | |
900014 | 10 июня 2010 | 9.0-CURRENT после добавления Clang. | |
900015 | 22 июля 2010 | 9.0-CURRENT после импорта BSD grep. | |
900016 | 28 июля 2010 | 9.0-CURRENT после добавления | |
900017 | 23 августа 2010 | 9.0-CURRENT после возврата к GNU grep по умолчанию и добавления параметра WITH_BSD_GREP. | |
900018 | 24 августа 2010 | 9.0-CURRENT после того, как сигнал, сгенерированный через pthread_kill(3), идентифицируется как SI_LWP в | |
900019 | 28 августа 2010 | 9.0-CURRENT после добавления флага MAP_PREFAULT_READ в mmap(2). | |
900020 | 9 сентября 2010 | 9.0-CURRENT после добавления функциональности drain в | |
900021 | 13 сентября 2010 | 9.0-CURRENT после того, как DTrace обзавелся поддержкой трассировки в пользовательском пространстве. | |
900022 | 2 октября 2010 | 9.0-CURRENT после добавления утилит man под лицензией BSDL и удаления утилит man под лицензией GNU/GPL. | |
900023 | 11 октября 2010 | 9.0-CURRENT после обновления xz до снимка git 20101010. | |
900024 | 11 ноября 2010 | 9.0-CURRENT после замены libgcc.a на libcompiler_rt.a. | |
900025 | 12 ноября 2010 | 9.0-CURRENT после внедрения модульной системы управления перегрузкой. | |
900026 | 30 ноября 2010 | 9.0-CURRENT после введения сквозной передачи Serial Management Protocol (SMP) и CAM | |
900027 | 5 декабря 2010 | 9.0-CURRENT после добавления log2 в libm. | |
900028 | 21 декабря 2010 | 9.0-CURRENT после добавления Hhook (Helper Hook), Khelp (Kernel Helpers) и KPI Object Specific Data (OSD). | |
900029 | 28 декабря 2010 | 9.0-CURRENT после модификации стека TCP для разрешения модулям Khelp взаимодействовать с ним через точки подключения вспомогательных функций и хранить данные для каждого соединения в блоке управления TCP. | |
900030 | 12 января 2011 | 9.0-CURRENT после обновления libdialog до версии 20100428. | |
900031 | 7 февраля 2011 | 9.0-CURRENT после добавления pthread_getthreadid_np(3). | |
900032 | 8 февраля 2011 | 9.0-CURRENT после удаления прототипа и символа | |
900033 | 18 февраля 2011 | 9.0-CURRENT после обновления binutils до версии 2.17.50. | |
900034 | 8 марта 2011 | 9.0-CURRENT после изменений в структуре | |
900035 | 29 марта 2011 | 9.0-CURRENT после обновления базового gcc и libstdc++ до последней ревизии, лицензированной под GPLv2. | |
900036 | 18 апреля 2011 | 9.0-CURRENT после удаления libobjc и поддержки Objective-C из базовой системы. | |
900037 | 13 мая 2011 | 9.0-CURRENT после импорта библиотеки libprocstat(3) и утилиты fuser(1) в базовую систему. | |
900038 | 22 мая 2011 | 9.0-CURRENT после добавления аргумента флага блокировки к VFS_FHTOVP(9). | |
900039 | 28 июня 2011 | 9.0-CURRENT после импорта pf из OpenBSD 4.5. | |
900040 | 19 июля 2011 | Увеличить значение MAXCPU по умолчанию для FreeBSD до 64 на amd64 и ia64 и до 128 для XLP (mips). | |
900041 | 13 августа 2011 | Версия 9.0-CURRENT после реализации возможностей Capsicum; fget(9) получает аргумент rights. | |
900042 | 28 августа 2011 | Увеличьте номера версий общих библиотек для библиотек, чей ABI изменился в рамках подготовки к 9.0. | |
900043 | 2 сентября 2011 | Добавить автоматическое обнаружение USB-накопителей, которые не поддерживают команду SCSI "no synchronize cache". | |
900044 | 10 сентября 2011 | Переработка автоматического определения особенностей оборудования (auto-quirk). 9.0-RELEASE. | |
900045 | 2 января 2012 | 9-STABLE после MFC значения true/false из 1000002. | |
900500 | 2 января 2012 | 9.0-STABLE. | |
900501 | 6 января 2012 | 9.0-STABLE после объединения добавления системного вызова posix_fadvise(2). | |
900502 | 16 января 2012 | 9.0-STABLE после слияния gperf 3.0.3 | |
900503 | 15 февраля 2012 | 9.0-STABLE после введения нового расширяемого интерфейса sysctl(3) NET_RT_IFLISTL для запроса списков адресов. | |
900504 | 3 марта 2012 | 9.0-STABLE после изменений, связанных с монтированием файловой системы внутри клетки. | |
900505 | 13 марта 2012 | 9.0-STABLE после введения новых параметров сокета tcp(4): TCP_KEEPINIT, TCP_KEEPIDLE, TCP_KEEPINTVL и TCP_KEEPCNT. | |
900506 | 22 мая 2012 | 9.0-STABLE после введения функции | |
901000 | 5 августа 2012 | 9.1-RELEASE. | |
901500 | 6 августа 2012 | 9.1-STABLE после ветвления releng/9.1 (RELENG_9_1). | |
901501 | 11 ноября 2012 | 9.1-STABLE после LIST_PREV(3) добавлен в queue.h (изменение rev 242893) и изменения KBI в USB последовательных устройствах. | |
901502 | 28 ноября 2012 | 9.1-STABLE после того, как буфер дрожания USB serial требует пересборки модулей устройств USB serial. | |
901503 | 21 февраля 2013 | 9.1-STABLE после перемещения USB в структуру драйверов, что потребовало пересборки всех модулей USB. Также указывает на наличие nmtree. | |
901504 | 15 марта 2013 | 9.1-STABLE после установки получил флаги -l, -M, -N и связанные с ними, а cat получил опцию -l. | |
901505 | 13 июня 2013 | 9.1-STABLE после исправлений в начальной загрузке | |
902001 | 3 августа 2013 |
| |
902501 | 2 августа 2013 | 9.2-STABLE после создания ветки | |
902502 | 26 августа 2013 | 9.2-STABLE после включения флага запроса пути CAM | |
902503 | 27 августа 2013 | 9.2-STABLE после включения флага | |
902504 | 22 октября 2013 | 9.2-STABLE после добавления поддержки скриптов "первой загрузки" rc(8). | |
902505 | 12 декабря 2013 | 9.2-STABLE после исправления кодировки Heimdal. | |
902506 | 31 декабря 2013 | 9-STABLE после исправлений MAP_STACK (rev 260082). | |
902507 | 5 марта 2014 | 9-STABLE после обновления libc++ до версии 3.4. | |
902508 | 14 марта 2014 | 9-STABLE после объединения драйвера Radeon KMS (rev 263170). | |
902509 | 21 марта 2014 | 9-STABLE после обновления llvm/clang до версии 3.4. | |
902510 | 27 марта 2014 | 9-STABLE после слияния драйвера vt(4). | |
902511 | 27 марта 2014 | 9-STABLE после FreeBSD-SA-14:06.openssl. | |
902512 | 30 апреля 2014 | 9-STABLE после FreeBSD-SA-14:08.tcp. | |
903000 | 20 июня 2014 | 9-RC1 ветка | |
903500 | 20 июня 2014 | 9.3-STABLE ветка | |
903501 | 8 июля 2014 | 9-STABLE после FreeBSD-SA-14:17.kmem (изменение:https://svnweb.freebsd.org/changeset/base/268433[268433]). | |
903502 | 19 августа 2014 | 9-STABLE после исправления ошибки | |
903503 | 9 сентября 2014 | 9-STABLE после FreeBSD-SA-14:18 (ссылка на ревизию:https://svnweb.freebsd.org/changeset/base/269687[269687]). | |
903504 | 16 сентября 2014 | 9-STABLE после FreeBSD-SA-14:19 (rev 271668). | |
903505 | 21 октября 2014 | 9-STABLE после исправлений FreeBSD-SA-14:20, FreeBSD-SA-14:21 и FreeBSD-SA-14:22 (rev 273412). | |
903506 | 4 ноября 2014 | 9-STABLE после FreeBSD-SA-14:23, FreeBSD-SA-14:24 и FreeBSD-SA-14:25. | |
903507 | 13 декабря 2014 | 9-STABLE после объединения важного исправления в векторизатор LLVM, которое в некоторых случаях могло приводить к переполнению буфера. | |
903508 | 25 февраля 2015 | 9-STABLE после FreeBSD-EN-15:01.vt, FreeBSD-EN-15:02.openssl, FreeBSD-EN-15:03.freebsd-update, FreeBSD-SA-15:04.igmp и FreeBSD-SA-15:05.bind. | |
903509 | 29 февраля 2016 | 9-STABLE после увеличения значения по умолчанию | |
903510 | 19 мая 2016 | 9-STABLE после того, как страница System Binary Interface (SBI) была перемещена в последней версии Berkeley Boot Loader (BBL) из-за увеличения размера кода в 300234. | |
903511 | 12 сентября 2016 | 9-STABLE после разрешения взаимоблокировки между |
18.8. Версии FreeBSD 8
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
800000 | 11 октября 2007 | 8.0-CURRENT. Разделение | |
800001 | 16 октября 2007 | 8.0-CURRENT после импорта libpcap 0.9.8 и tcpdump 3.9.8. | |
800002 | 21 октября 2007 | 8.0-CURRENT после переименования kthread_create(9) и связанных функций в kproc_create(9) и т.д. | |
800003 | 24 октября 2007 | 8.0-CURRENT после того, как была добавлена обратная совместимость ABI с версиями FreeBSD 4/5/6 для IOCTL PCIOCGETCONF, PCIOCREAD и PCIOCWRITE, что потребовало снова нарушить ABI IOCTL PCIOCGETCONF | |
800004 | 12 ноября 2007 | 8.0-CURRENT после перемещения драйвера agp(4) из src/sys/pci в src/sys/dev/agp | |
800005 | 4 декабря 2007 | 8.0-CURRENT после изменений в аллокаторе джамбо-фреймов (rev 174247). | |
800006 | 7 декабря 2007 | 8.0-CURRENT после добавления функциональности захвата | |
800007 | 25 декабря 2007 | 8.0-CURRENT после | |
800008 | 28 декабря 2007 | 8.0-CURRENT после удаления опции LK_EXCLUPGRADE. | |
800009 | 9 января 2008 | 8.0-CURRENT после введения lockmgr_disown(9) | |
800010 | 10 января 2008 | 8.0-CURRENT после изменения прототипа vn_lock(9). | |
800011 | 13 января 2008 | 8.0-CURRENT после изменений прототипов VOP_LOCK(9) и VOP_UNLOCK(9). | |
800012 | 19 января 2008 | 8.0-CURRENT после введения lockmgr_recursed(9), BUF_RECURSED(9) и BUF_ISLOCKED(9), а также удаления | |
800013 | 23 января 2008 | 8.0-CURRENT после введения кодировки "ASCII". | |
800014 | 24 января 2008 | 8.0-CURRENT после изменения прототипа lockmgr(9) и удаления | |
800015 | 26 января 2008 | 8.0-CURRENT после расширения типов структур fts(3). | |
800016 | 1 февраля 2008 | 8.0-CURRENT после добавления аргумента в MEXTADD(9) | |
800017 | 6 февраля 2008 | 8.0-CURRENT после введения опций LK_NODUP и LK_NOWITNESS в пространстве lockmgr(9). | |
800018 | 8 февраля 2008 | 8.0-CURRENT после добавления | |
800019 | 9 февраля 2008 | 8.0-CURRENT после добавления поддержки текущего рабочего каталога, корневого каталога и каталога клетки в sysctl kern.proc.filedesc. | |
800020 | 13 февраля 2008 | 8.0-CURRENT после добавления lockmgr_assert(9) и функций | |
800021 | 15 февраля 2008 | 8.0-CURRENT после введения lockmgr_args(9) и удаления флага LK_INTERNAL. | |
800022 | (отменено) | 8.0-CURRENT после изменения стандартной системной ar на BSD ar(1). | |
800023 | 25 февраля 2008 | 8.0-CURRENT после изменения прототипов lockstatus(9) и VOP_ISLOCKED(9);, а именно удаления аргумента | |
800024 | 1 марта 2008 | 8.0-CURRENT после удаления функций | |
800025 | 8 марта 2008 | 8.0-CURRENT после добавления команды F_DUP2FD в fcntl(2). | |
800026 | 12 марта 2008 | 8.0-CURRENT после изменения параметра приоритета на | |
800027 | 24 марта 2008 | 8.0-CURRENT после изменения ABI мониторинга bpf при добавлении буферов bpf с | |
800028 | 26 марта 2008 | 8.0-CURRENT после добавления | |
800029 | March 28, 2008 | 8.0-CURRENT после повторного включения функции | |
800030 | 1 апреля 2008 | 8.0-CURRENT после введения функций rw_try_rlock(9) и rw_try_wlock(9). | |
800031 | 6 апреля 2008 | 8.0-CURRENT после введения функций | |
800032 | 8 апреля 2008 | 8.0-CURRENT после реализации системных вызовов | |
800033 | 8 апреля 2008 | 8.0-CURRENT после добавления поддержки write(2) для psm(4) на уровне нативной работы. Теперь произвольные команды можно записывать в /dev/psm%d, а статус — считывать из него. | |
800034 | 10 апреля 2008 | 8.0-CURRENT после введения функции | |
800035 | 16 апреля 2008 | 8.0-CURRENT после введения функции | |
800036 | 20 апреля 2008 | 8.0-CURRENT после перехода на поддержку multi-bss в беспроводных сетях 802.11 (также известную как | |
800037 | 9 мая 2008 | 8.0-CURRENT после добавления поддержки нескольких таблиц маршрутизации (также известных как setfib(1), setfib(2)). | |
800038 | 26 мая 2008 | 8.0-CURRENT после удаления | |
800039 | 14 июня 2008 | 8.0-CURRENT после удаления | |
800040 | 26 июня 2008 | 8.0-CURRENT с клиентом | |
800041 | 22 июля 2008 | 8.0-CURRENT после добавления arc4random_buf(3) и arc4random_uniform(3). | |
800042 | 8 августа 2008 | 8.0-CURRENT после добавления cpuctl(4). | |
800043 | 13 августа 2008 | 8.0-CURRENT после изменения bpf(4) для использования единого узла устройства вместо клонирования устройств. | |
800044 | 17 августа 2008 | 8.0-CURRENT после внесения изменений, связанных с первым этапом проекта VIMAGE, переименованы глобальные переменные, подлежащие виртуализации, с добавлением префикса | |
800045 | 20 августа 2008 | 8.0-CURRENT после интеграции MPSAFE TTY слоя, включая изменения в различных драйверах и утилитах, взаимодействующих с ним. | |
800046 | 8 сентября 2008 | 8.0-CURRENT после разделения GDT для каждого процессора на архитектуре amd64. | |
800047 | 10 сентября 2008 | 8.0-CURRENT после удаления VSVTX, VSGID и VSUID. | |
800048 | 16 сентября 2008 | 8.0-CURRENT после преобразования кода монтирования ядра NFS для поддержки отдельных опций монтирования в | |
800049 | 17 сентября 2008 | 8.0-CURRENT после удаления suser(9) и suser_cred(9). | |
800050 | 20 октября 2008 | 8.0-CURRENT после изменения API кэша буфера. | |
800051 | 23 октября 2008 | ||
800052 | 28 октября 2008 | 8.0-CURRENT после введения | |
800053 | 2 ноября 2008 | 8.0-CURRENT после изменения прототипа vfs_busy(9) и введения флагов MBF_NOWAIT и MBF_MNTLSTLOCK. | |
800054 | 22 ноября 2008 | 8.0-CURRENT после добавления | |
800055 | 27 ноября 2008 | 8.0-CURRENT после добавления поддержки Intel™ Core, Core2 и Atom в hwpmc(4). | |
800056 | 29 ноября 2008 | 8.0-CURRENT после введения многопользовательских/без IPv4/v6 клеток. | |
800057 | 1 декабря 2008 | 8.0-CURRENT после перехода на исходный код | |
800058 | 12 декабря 2008 | 8.0-CURRENT после введения операции VOP_VPTOCNP. | |
800059 | 15 декабря 2008 | 8.0-CURRENT включает новую переработанную версию arp-v2. | |
800060 | 19 декабря 2008 | 8.0-CURRENT после добавления makefs. | |
800061 | 15 января 2009 | 8.0-CURRENT после TCP Appropriate Byte Counting. | |
800062 | 28 января 2009 | 8.0-CURRENT после удаления | |
800063 | 18 февраля 2009 | 8.0-CURRENT после изменения конфигурации GENERIC для использования стека USB2, а также добавления fdevname(3). | |
800064 | 23 февраля 2009 | 8.0-CURRENT после переноса стека USB2 и замены dev/usb. | |
800065 | 26 февраля 2009 | 8.0-CURRENT после переименования всех функций в libmp(3). | |
800066 | 27 февраля 2009 | 8.0-CURRENT после изменения обработки и структуры USB devfs. | |
800067 | 28 февраля 2009 | 8.0-CURRENT после добавления | |
800068 | 2 марта 2009 | 8.0-CURRENT после переименования класса устройств | |
800069 | 9 марта 2009 | 8.0-CURRENT после переименования libusb20.so.1 в libusb.so.1. | |
800070 | 9 марта 2009 | 8.0-CURRENT после объединения IGMPv3 и Source-Specific Multicast (SSM) в стек IPv4. | |
800071 | 14 марта 2009 | 8.0-CURRENT после того, как gcc был исправлен для использования семантики встраивания C99 в режимах c99 и gnu99. | |
800072 | March 15, 2009 | 8.0-CURRENT после удаления флага IFF_NEEDSGIANT; неподдерживаемые MPSAFE драйверы сетевых устройств больше не поддерживаются. | |
800073 | 18 марта 2009 | 8.0-CURRENT после реализации подстановки динамических строковых токенов для rpath и необходимых путей. | |
800074 | 24 марта 2009 | 8.0-CURRENT после импорта tcpdump 4.0.0 и libpcap 1.0.0. | |
800075 | 6 апреля 2009 | 8.0-CURRENT после изменения структуры структур vnet_net, vnet_inet и vnet_ipfw. | |
800076 | 9 апреля 2009 | 8.0-CURRENT после добавления профилей задержки в dummynet. | |
800077 | 14 апреля 2009 | 8.0-CURRENT после удаления | |
800078 | 15 апреля 2009 | 8.0-CURRENT после добавления полей | |
800079 | 15 апреля 2009 | 8.0-CURRENT после добавления указателей на структуру | |
800080 | 15 апреля 2009 | 8.0-CURRENT после изменения структуры inpcb. | |
800081 | 19 апреля 2009 | 8.0-CURRENT после изменения структуры | |
800082 | 21 апреля 2009 | 8.0-CURRENT после изменения структуры struct ifnet и с | |
800083 | 22 апреля 2009 | 8.0-CURRENT после реализации низкоуровневого API HCI Bluetooth. | |
800084 | 29 апреля 2009 | 8.0-CURRENT после изменений в IPv6 SSM и MLDv2. | |
800085 | 30 апреля 2009 | 8.0-CURRENT после включения поддержки сборки ядра с VIMAGE с одним активным образом. | |
800086 | 8 мая 2009 | 8.0-CURRENT после добавления поддержки строк ввода произвольной длины в patch(1). | |
800087 | 11 мая 2009 | 8.0-CURRENT после некоторых изменений в VFS KPI. Аргумент потока был удален из частей FSD в VFS. Функциям | |
800088 | 20 мая 2009 | 8.0-CURRENT после изменений режима монитора в net80211. | |
800089 | 23 мая 2009 | 8.0-CURRENT после добавления поддержки блока управления UDP. | |
800090 | 23 мая 2009 | 8.0-CURRENT после виртуализации клонирования интерфейсов. | |
800091 | 27 мая 2009 | 8.0-CURRENT после добавления иерархических клеток и удаления глобального securelevel. | |
800092 | 29 мая 2009 | 8.0-CURRENT после изменения KPI | |
800093 | 29 мая 2009 | 8.0-CURRENT после добавления | |
800094 | 30 мая 2009 | 8.0-CURRENT после добавления VOP_ACCESSX(9). | |
800095 | 30 мая 2009 | 8.0-CURRENT после изменения KPI для polling. Обработчики polling теперь возвращают количество обработанных пакетов. Также введена новая возможность | |
800096 | 1 июня 2009 | 8.0-CURRENT после обновления до новой реализации netisr и после изменения способа хранения и доступа к FIB. | |
800097 | 8 июня 2009 | 8.0-CURRENT после введения хуков и инфраструктуры деструктора vnet. | |
(не изменено) | 11 июня 2009 | 8.0-CURRENT после введения в netgraph обнаружения вызовов пути из исходящего во входящий и организации очередей, что также изменило структуру struct thread. | |
800098 | 14 июня 2009 | 8.0-CURRENT после импорта OpenSSL 0.9.8k. | |
800099 | 22 июня 2009 | 8.0-CURRENT после обновления NGROUPS и переноса виртуализации маршрутов в собственный модуль VImage. | |
800100 | 24 июня 2009 | 8.0-CURRENT после изменения ABI SYSVIPC. | |
800101 | 29 июня 2009 | 8.0-CURRENT после удаления символьных устройств /dev/net/* для каждого интерфейса. | |
800102 | 12 июля 2009 | 8.0-CURRENT после добавления заполнения к структурам | |
800103 | 13 июля 2009 | 8.0-CURRENT после замены структуры | |
800104 | 14 июля 2009 | 8.0-CURRENT после добавления распределителя на основе наборов компоновщика для каждого vnet. | |
800105 | 19 июля 2009 | 8.0-CURRENT после увеличения версии для всех разделяемых библиотек, у которых не включено управление версиями символов. | |
800106 | 24 июля 2009 | 8.0-CURRENT после введения типа объекта VM OBJT_SG. | |
800107 | 2 августа 2009 | 8.0-CURRENT после освобождения подсистемы newbus от Giant путем добавления | |
800108 | 21 ноября 2009 | 8.0-STABLE после реализации фильтра | |
800500 | 7 января 2010 | 8.0-STABLE после увеличения | |
800501 | 24 января 2010 | 8.0-STABLE после изменения прототипов scandir(3) и alphasort(3) для соответствия SUSv4. | |
800502 | 31 января 2010 | 8.0-STABLE после добавления sigpause(2). | |
800503 | 25 февраля 2010 | 8.0-STABLE после добавления ioctl SIOCGIFDESCR и SIOCSIFDESCR к сетевым интерфейсам. Эти ioctl могут использоваться для управления описанием интерфейса, по аналогии с OpenBSD. | |
800504 | 1 марта 2010 | 8.0-STABLE после MFC импорта x86emu, программного эмулятора реального режима x86 CPU из OpenBSD. | |
800505 | 18 мая 2010 | 8.0-STABLE после MFC добавления liblzma, xz, xzdec и lzmainfo. | |
801000 | 14 июня 2010 | 8.1-RELEASE | |
801500 | 14 июня 2010 | 8.1-STABLE после 8.1-RELEASE. | |
801501 | 3 ноября 2010 | 8.1-STABLE после изменения KBI в структуре | |
802000 | 22 декабря 2010 | 8.2-RELEASE | |
802500 | 22 декабря 2010 | 8.2-STABLE после 8.2-RELEASE. | |
802501 | 28 февраля 2011 | 8.2-STABLE после объединения изменений DTrace, включая поддержку трассировки пользовательского пространства. | |
802502 | 6 марта 2011 | 8.2-STABLE после объединения log2 и log2f в libm. | |
802503 | 1 мая 2011 | 8.2-STABLE после обновления gcc до последней версии GPLv2 из ветки FSF gcc-4_2-branch. | |
802504 | 28 мая 2011 | 8.2-STABLE после введения KPI и поддерживающей инфраструктуры для модульного управления перегрузкой. | |
802505 | 28 мая 2011 | 8.2-STABLE после введения KPIs Hhook и Khelp. | |
802506 | 28 мая 2011 | 8.2-STABLE после добавления OSD в структуру tcpcb. | |
802507 | 6 июня 2011 | 8.2-STABLE после импорта ZFS v28. | |
802508 | 8 июня 2011 | 8.2-STABLE после удаления обработчика событий | |
802509 | 14 июля 2011 | 8.2-STABLE после объединения поддержки SSSE3 в binutils. | |
802510 | 19 июля 2011 | 8.2-STABLE после добавления флага RFTSIGZMB для rfork(2). | |
802511 | 9 сентября 2011 | 8.2-STABLE после добавления автоматического обнаружения USB-накопителей, которые не поддерживают команду SCSI "no synchronize cache". | |
802512 | 10 сентября 2011 | 8.2-STABLE после объединения рефакторинга auto-quirk. | |
802513 | 25 октября 2011 | 8.2-STABLE после объединения флага MAP_PREFAULT_READ в mmap(2). | |
802514 | 16 ноября 2011 | 8.2-STABLE после объединения добавления системного вызова posix_fallocate(2). | |
802515 | 6 января 2012 | 8.2-STABLE после объединения добавления системного вызова posix_fadvise(2). | |
802516 | 16 января 2012 | 8.2-STABLE после объединения gperf 3.0.3 | |
802517 | 15 февраля 2012 | 8.2-STABLE после введения нового расширяемого интерфейса sysctl(3) NET_RT_IFLISTL для запроса списков адресов. | |
803000 | 3 марта 2012 | 8.3-RELEASE. | |
803500 | 3 марта 2012 | 8.3-STABLE после ветвления releng/8.3 (RELENG_8_3). | |
803501 | 21 февраля 2013 | 8.3-STABLE после слияния двух исправлений для USB (ссылки на ревизии: 246616 и 246759). | |
804000 | 28 марта 2013 | 8.4-RELEASE. | |
804500 | 28 марта 2013 | 8.4-STABLE после 8.4-RELEASE. | |
804501 | 16 декабря 2013 | 8.4-STABLE после MFC исправления кодировки из вышестоящего Heimdal. | |
804502 | 30 апреля 2014 | 8.4-STABLE после FreeBSD-SA-14:08.tcp. | |
804503 | 9 июля 2014 | 8.4-STABLE после FreeBSD-SA-14:17.kmem. | |
804504 | 9 сентября 2014 | 8.4-STABLE после FreeBSD-SA-14:18 (ссылка на ревизию:https://svnweb.freebsd.org/changeset/base/271305[271305]). | |
804505 | 16 сентября 2014 | 8.4-STABLE после FreeBSD-SA-14:19 (ревизия 271668). | |
804506 | 21 октября 2014 | 8.4-STABLE после FreeBSD-SA-14:21 (ссылка на ревизию:https://svnweb.freebsd.org/changeset/base/273413[273413]). | |
804507 | 4 ноября 2014 | 8.4-STABLE после FreeBSD-SA-14:23, FreeBSD-SA-14:24 и FreeBSD-SA-14:25. | |
804508 | 25 февраля 2015 | 8-STABLE после FreeBSD-EN-15:01.vt, FreeBSD-EN-15:02.openssl, FreeBSD-EN-15:03.freebsd-update, FreeBSD-SA-15:04.igmp и FreeBSD-SA-15:05.bind. | |
804509 | 12 сентября 2016 | 8-STABLE после устранения взаимоблокировки между |
18.9. Версии FreeBSD 7
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
700000 | 11 июля 2005 | 7.0-CURRENT. | |
700001 | 23 июля 2005 | 7.0-CURRENT после увеличения версий всех общих библиотек, которые не изменялись с RELENG_5. | |
700002 | 13 августа 2005 | 7.0-CURRENT после добавления аргумента учетных данных в обработчик события | |
700003 | 25 августа 2005 | 7.0-CURRENT после добавления memmem(3) в libc. | |
700004 | 30 октября 2005 | 7.0-CURRENT после изменения аргументов ядра solisten(9) для принятия параметра backlog. | |
700005 | 11 ноября 2005 | 7.0-CURRENT после изменения | |
700006 | 11 ноября 2005 | 7.0-CURRENT после добавления члена | |
700007 | 2 декабря 2005 | 7.0-CURRENT после включения скриптов из каталогов | |
700008 | 5 декабря 2005 | 7.0-CURRENT после удаления опции монтирования MNT_NODEV. | |
700009 | 19 декабря 2005 | 7.0-CURRENT после изменений типа ELF-64 и версионирования символов. | |
700010 | 20 декабря 2005 | 7.0-CURRENT после добавления драйверов | |
700011 | 31 декабря 2005 | 7.0-CURRENT после того, как | |
700012 | 8 января 2006 | 7.0-CURRENT после изменения ldconfig_local_dirs. | |
700013 | 12 января 2006 | 7.0-CURRENT после изменений в /etc/rc.d/abi для поддержки /compat/linux/etc/ld.so.cache в виде символьной ссылки в файловой системе только для чтения. | |
700014 | 26 января 2006 | 7.0-CURRENT после импорта pts. | |
700015 | 26 марта 2006 | 7.0-CURRENT после введения версии 2 ABI hwpmc(4). | |
700016 | 22 апреля 2006 | 7.0-CURRENT после добавления fcloseall(3) в libc. | |
700017 | 13 мая 2006 | 7.0-CURRENT после удаления ip6fw. | |
700018 | 15 июля 2006 | 7.0-CURRENT после импорта snd_emu10kx. | |
700019 | 29 июля 2006 | 7.0-CURRENT после импорта OpenSSL 0.9.8b. | |
700020 | 3 сентября 2006 | 7.0-CURRENT после добавления функции | |
700021 | 4 сентября 2006 | 7.0-CURRENT после импорта libpcap 0.9.4 и tcpdump 3.9.4. | |
700022 | 9 сентября 2006 | 7.0-CURRENT после изменения | |
700023 | 23 сентября 2006 | 7.0-CURRENT после добавления новых звуковых IOCTL для API микшера OSSv4. | |
700024 | 28 сентября 2006 | 7.0-CURRENT после импорта OpenSSL 0.9.8d. | |
700025 | 11 ноября 2006 | 7.0-CURRENT после добавления libelf. | |
700026 | 26 ноября 2006 | 7.0-CURRENT после значительных изменений в звуковых sysctls. | |
700027 | 30 ноября 2006 | 7.0-CURRENT после добавления особенности Wi-Spy. | |
700028 | 15 декабря 2006 | 7.0-CURRENT после добавления вызовов | |
700029 | 26 января 2007 | 7.0-CURRENT после того, как реализация GNU gzip(1) была заменена на версию с лицензией BSD, портированную из NetBSD. | |
700030 | 7 февраля 2007 | 7.0-CURRENT после удаления инкапсуляции туннеля IPIP (VIFF_TUNNEL) из кода переадресации IPv4 multicast. | |
700031 | 23 февраля 2007 | 7.0-CURRENT после изменения | |
700032 | 2 марта 2007 | ||
700033 | 9 марта 2007 | 7.0-CURRENT после включения поддержки широких символов ncurses. | |
700034 | 19 марта 2007 | 7.0-CURRENT после изменений в работе | |
700035 | 26 марта 2007 | 7.0-CURRENT после добавления механизма уведомлений об изменениях частоты CPU. | |
700036 | 6 апреля 2007 | 7.0-CURRENT после импорта файловой системы ZFS. | |
700037 | 8 апреля 2007 | 7.0-CURRENT после добавления периферийного устройства CAM 'SG', реализующего подмножество API сквозного устройства SCSI SG в Linux. | |
700038 | 30 апреля 2007 | 7.0-CURRENT после изменения getenv(3), putenv(3), setenv(3) и unsetenv(3) для соответствия стандарту POSIX. | |
700039 | 1 мая 2007 | 7.0-CURRENT после отмены изменений в 700038. | |
700040 | 10 мая 2007 | 7.0-CURRENT после добавления flopen(3) в libutil. | |
700041 | 13 мая 2007 | 7.0-CURRENT после включения версионирования символов и изменения библиотеки потоков по умолчанию на libthr. | |
700042 | 19 мая 2007 | 7.0-CURRENT после импорта gcc 4.2.0. | |
700043 | 21 мая 2007 | 7.0-CURRENT после увеличения версий всех общих библиотек, которые не изменялись с RELENG_6. | |
700044 | 7 июня 2007 | 7.0-CURRENT после изменения аргумента для | |
700045 | 10 июня 2007 | 7.0-CURRENT после изменения pam_nologin(8) для предоставления функции управления учетными записями вместо функции аутентификации в рамках PAM. | |
700046 | 11 июня 2007 | 7.0-CURRENT после обновления поддержки беспроводных сетей 802.11. | |
700047 | 11 июня 2007 | 7.0-CURRENT после добавления возможностей интерфейса TCP LRO. | |
700048 | 12 июня 2007 | 7.0-CURRENT после добавления поддержки API RFC 3678 в стек IPv4. Устаревшее поведение RFC 1724 для ioctl IP_MULTICAST_IF теперь удалено; 0.0.0.0/8 больше нельзя использовать для указания индекса интерфейса. Вместо этого используйте структуру | |
700049 | 3 июля 2007 | 7.0-CURRENT после импорта pf из OpenBSD 4.1 | |
(не изменено) | 7.0-CURRENT после добавления поддержки IPv6 для FAST_IPSEC, удаления KAME IPSEC и переименования FAST_IPSEC в IPSEC. | ||
700050 | 4 июля 2007 | 7.0-CURRENT после преобразования вызовов setenv/putenv/etc. из традиционного BSD в POSIX. | |
700051 | 4 июля 2007 | 7.0-CURRENT после добавления новых системных вызовов mmap/lseek и др. | |
700052 | 6 июля 2007 | 7.0-CURRENT после перемещения заголовков I4B в include/i4b. | |
700053 | 30 сентября 2007 | 7.0-CURRENT после добавления поддержки доменов PCI | |
700054 | 25 октября 2007 | 7.0-STABLE после переноса изменений (MFC) разделения широких и однобайтовых ctype. | |
700055 | 28 октября 2007 | 7.0-RELEASE и 7.0-CURRENT после того, как обратная совместимость ABI с версиями FreeBSD 4/5/6 для IOCTL PCIOCGETCONF, PCIOCREAD и PCIOCWRITE была перенесена в стабильную ветку (MFC), что потребовало снова нарушить ABI IOCTL PCIOCGETCONF | |
700100 | 22 декабря 2007 | 7.0-STABLE после 7.0-RELEASE | |
700101 | 8 февраля 2008 | 7.0-STABLE после MFC | |
700102 | 30 марта 2008 | 7.0-STABLE после MFC | |
700103 | 10 апреля 2008 | 7.0-STABLE после добавления | |
700104 | 11 апреля 2008 | 7.0-STABLE после MFC procstat(1). | |
700105 | 11 апреля 2008 | 7.0-STABLE после MFC функций | |
700106 | 15 апреля 2008 | ||
700107 | 20 апреля 2008 | 7.0-STABLE после MFC команды F_DUP2FD в fcntl(2). | |
700108 | 5 мая 2008 | 7.0-STABLE после некоторых изменений в lockmgr(9), что делает необходимым включение sys/lock.h для использования lockmgr(9). | |
700109 | 27 мая 2008 | 7.0-STABLE после MFC функции memrchr(3). | |
700110 | 5 августа 2008 | 7.0-STABLE после MFC клиента | |
700111 | 20 августа 2008 | 7.0-STABLE после добавления поддержки физически непрерывных больших кадров (jumbo frame). | |
700112 | 27 августа 2008 | 7.0-STABLE после переноса изменений (MFC) поддержки DTrace в ядре. | |
701000 | 25 ноября 2008 | 7.1-RELEASE | |
701100 | 25 ноября 2008 | 7.1-STABLE после 7.1-RELEASE. | |
701101 | 10 января 2009 | 7.1-STABLE после слияния strndup(3). | |
701102 | 17 января 2009 | 7.1-STABLE после добавления поддержки cpuctl(4). | |
701103 | 7 февраля 2009 | 7.1-STABLE после объединения клеток с поддержкой multi-/no-IPv4/v6. | |
701104 | 14 февраля 2009 | 7.1-STABLE после сохранения владельца приостановки в структуре mount и добавления метода vfs_susp_clean в структуру vfsops. | |
701105 | 12 марта 2009 | 7.1-STABLE после несовместимого изменения sysctl kern.ipc.shmsegs для выделения больших сегментов разделяемой памяти SysV на 64-битных архитектурах. | |
701106 | 14 марта 2009 | 7.1-STABLE после объединения исправления для операций ожидания семафоров POSIX. | |
702000 | 15 апреля 2009 | 7.2-RELEASE | |
702100 | 15 апреля 2009 | 7.2-STABLE после 7.2-RELEASE. | |
702101 | 15 мая 2009 | 7.2-STABLE после изменения ichsmb(4) для использования выравнивания по левому краю вторичной адресации, чтобы соответствовать другим драйверам контроллеров SMBus. | |
702102 | 28 мая 2009 | 7.2-STABLE после слияния из ветки man функции fdopendir[3]. | |
702103 | 6 июня 2009 | 7.2-STABLE после MFC PmcTools. | |
702104 | 14 июля 2009 | 7.2-STABLE после MFC системного вызова closefrom(2). | |
702105 | 31 июля 2009 | 7.2-STABLE после слияния изменения ABI SYSVIPC. | |
702106 | 14 сентября 2009 | 7.2-STABLE после слияния изменений (MFC) улучшений PAT для x86 и добавления | |
703000 | 9 февраля 2010 | 7.3-RELEASE | |
703100 | 9 февраля 2010 | 7.3-STABLE после 7.3-RELEASE. | |
704000 | 22 декабря 2010 | 7.4-RELEASE | |
704100 | 22 декабря 2010 | 7.4-STABLE после 7.4-RELEASE. | |
704101 | 2 мая 2011 | 7.4-STABLE после MFC gcc в ревизии 221317. |
18.10. Версии FreeBSD 6
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
600000 | 18 августа 2004 | 6.0-CURRENT | |
600001 | 27 августа 2004 | 6.0-CURRENT после постоянного включения PFIL_HOOKS в ядре. | |
600002 | 30 августа 2004 | 6.0-CURRENT после первоначального добавления | |
600003 | 8 сентября 2004 | 6.0-CURRENT после повторного добавления члена | |
600004 | 29 сентября 2004 | 6.0-CURRENT после добавления аргумента struct inpcb в API pfil. | |
600005 | 5 октября 2004 | 6.0-CURRENT после добавления аргумента "-d DESTDIR" в newsyslog. | |
600006 | 4 ноября 2004 | 6.0-CURRENT после добавления опций заполнения в стиле glibc для strftime(3). | |
600007 | 12 декабря 2004 | 6.0-CURRENT после добавления обновлений для фреймворка 802.11. | |
600008 | 25 января 2005 | 6.0-CURRENT после изменений в функциях | |
600009 | 4 февраля 2005 | 6.0-CURRENT после добавления фреймворка cpufreq и драйверов. | |
600010 | 6 февраля 2005 | 6.0-CURRENT после импорта nc(1) из OpenBSD. | |
600011 | 12 февраля 2005 | 6.0-CURRENT после удаления подобия поддержки | |
600012 | 15 февраля 2005 | 6.0-CURRENT после увеличения размера стеков потоков по умолчанию. | |
600013 | 19 февраля 2005 | 6.0-CURRENT после исправлений в <src/include/stdbool.h> и <src/sys/i386/include/_types.h> для обеспечения совместимости с GCC компилятора Intel C/C++. | |
600014 | 21 февраля 2005 | 6.0-CURRENT после исправления проверок EOVERFLOW в vswprintf(3). | |
600015 | 25 февраля 2005 | 6.0-CURRENT после изменения члена структуры | |
600016 | 26 февраля 2005 | 6.0-CURRENT после изменения формата диска LC_CTYPE. | |
600017 | 27 февраля 2005 | 6.0-CURRENT после изменения формата диска каталогов NLS. | |
600018 | 27 февраля 2005 | 6.0-CURRENT после изменения формата диска LC_COLLATE. | |
600019 | 28 февраля 2005 | Установка | |
600020 | 9 марта 2005 | Добавление флага MSG_NOSIGNAL в API send(2). | |
600021 | 17 марта 2005 | Добавление полей в cdevsw | |
600022 | 21 марта 2005 | Удален gtar из базовой системы. | |
600023 | 13 апреля 2005 | Добавлены параметры сокета LOCAL_CREDS, LOCAL_CONNWAIT в unix(4). | |
600024 | 19 апреля 2005 | hwpmc(4) и связанные инструменты добавлены в 6.0-CURRENT. | |
600025 | 26 апреля 2005 | Структура | |
600026 | 3 мая 2005 | pf обновлен до версии 3.7. | |
600027 | 6 мая 2005 | Добавлены libalias в ядре и | |
600028 | 13 мая 2005 | POSIX ttyname_r(3), доступный через unistd.h и libc. | |
600029 | 29 мая 2005 | 6.0-CURRENT после обновления libpcap до v0.9.1 alpha 096. | |
600030 | 5 июня 2005 | 6.0-CURRENT после импорта if_bridge(4) из NetBSD. | |
600031 | 10 июня 2005 | 6.0-CURRENT после того, как структура ifnet была вынесена из | |
600032 | 11 июля 2005 | 6.0-CURRENT после импорта libpcap v0.9.1. | |
600033 | 25 июля 2005 | 6.0-STABLE после увеличения версий всех общих библиотек, которые не изменялись с RELENG_5. | |
600034 | 13 августа 2005 | 6.0-STABLE после добавления аргумента credential в обработчик события | |
600100 | 1 ноября 2005 | 6.0-STABLE после 6.0-RELEASE | |
600101 | 21 декабря 2005 | 6.0-STABLE после включения скриптов из каталогов | |
600102 | 30 декабря 2005 | 6.0-STABLE после обновления типов и констант ELF. | |
600103 | 15 января 2006 | 6.0-STABLE после переноса изменений (MFC) API pidfile(3). | |
600104 | 17 января 2006 | 6.0-STABLE после MFC изменений ldconfig_local_dirs. | |
600105 | 26 февраля 2006 | 6.0-STABLE после поддержки каталога NLS в csh(1). | |
601000 | 6 мая 2006 | 6.1-RELEASE | |
601100 | 6 мая 2006 | 6.1-STABLE после 6.1-RELEASE. | |
601101 | 22 июня 2006 | 6.1-STABLE после импорта | |
601102 | 11 июля 2006 | 6.1-STABLE после обновления iwi(4). | |
601103 | 17 июля 2006 | 6.1-STABLE после обновления резолвера до BIND9 и добавления реентерабельной версии функций | |
601104 | 8 августа 2006 | 6.1-STABLE после включения поддержки DSO (динамически разделяемых объектов) в OpenSSL. | |
601105 | 2 сентября 2006 | 6.1-STABLE после исправлений 802.11 изменил API для ioctl IEEE80211_IOC_STA_INFO. | |
602000 | 15 ноября 2006 | 6.2-RELEASE | |
602100 | 15 сентября 2006 | 6.2-STABLE после 6.2-RELEASE. | |
602101 | 12 декабря 2006 | 6.2-STABLE после добавления особенности Wi-Spy. | |
602102 | 28 декабря 2006 | 6.2-STABLE после добавления | |
602103 | 16 января 2007 | 6.2-STABLE после MFC изменения | |
602104 | 28 января 2007 | 6.2-STABLE после слияния изменений (MFC) узлов netgraph ng_deflate(4) и ng_pred1(4), а также новых режимов сжатия и шифрования для узла ng_ppp(4). | |
602105 | 20 февраля 2007 | 6.2-STABLE после переноса (MFC) версии gzip(1) под лицензией BSD из NetBSD. | |
602106 | 31 марта 2007 | 6.2-STABLE после слияния изменений (MFC) поддержки PCI MSI и MSI-X. | |
602107 | 6 апреля 2007 | 6.2-STABLE после слияния изменений (MFC) ncurses 5.6 с поддержкой широких символов. | |
602108 | 11 апреля 2007 | 6.2-STABLE после слияния изменений (MFC) для периферийного устройства CAM 'SG', реализующего подмножество API сквозного устройства SCSI SG в Linux. | |
602109 | 17 апреля 2007 | 6.2-STABLE после MFC набора исправлений readline 5.2 patch-set 002. | |
602110 | 2 мая 2007 | 6.2-STABLE после слияния изменений (MFC) функций | |
602111 | 11 июня 2007 | 6.2-STABLE после слияния изменений BOP_BDFLUSH, что привело к нарушению KBI модулей файловой системы. | |
602112 | 21 сентября 2007 | 6.2-STABLE после libutil(3) MFC’s. | |
602113 | 25 октября 2007 | 6.2-STABLE после слияния изменений (MFC) разделения широких и однобайтовых символов ctype. Вновь скомпилированные двоичные файлы, ссылающиеся на ctype.h, могут требовать новый символ | |
602114 | 30 октября 2007 | 6.2-STABLE после восстановления прямой совместимости ABI ctype. | |
602115 | 21 ноября 2007 | 6.2-STABLE после отмены разделения широких и однобайтовых символов ctype. | |
603000 | 25 ноября 2007 | 6.3-RELEASE | |
603100 | 25 ноября 2007 | 6.3-STABLE после 6.3-RELEASE. | |
(не изменено) | 7 декабря 2007 | 6.3-STABLE после исправления поддержки многобайтовых типов в макросе bit. | |
603102 | 24 апреля 2008 | 6.3-STABLE после добавления | |
603103 | 27 мая 2008 | 6.3-STABLE после MFC функции memrchr(3). | |
603104 | 15 июня 2008 | 6.3-STABLE после MFC поддержки модификатора переменной | |
604000 | 4 октября 2008 | 6.4-RELEASE | |
604100 | 4 октября 2008 | 6.4-STABLE после 6.4-RELEASE. |
18.11. Версии FreeBSD 5
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
500000 | 13 марта 2000 | 5.0-CURRENT | |
500001 | 18 апреля 2000 | 5.0-CURRENT после добавления дополнительных полей заголовка ELF и изменения метода маркировки ELF-бинарников. | |
500002 | 2 мая 2000 | 5.0-CURRENT после изменений метаданных kld. | |
500003 | 18 мая 2000 | 5.0-CURRENT после изменений в buf/bio. | |
500004 | 26 мая 2000 | 5.0-CURRENT после обновления binutils. | |
500005 | 3 июня 2000 | 5.0-CURRENT после объединения кода libxpg4 с libc и после введения интерфейса TASKQ. | |
500006 | 10 июня 2000 | 5.0-CURRENT после добавления интерфейсов AGP. | |
500007 | 29 июня 2000 | 5.0-CURRENT после обновления Perl до версии 5.6.0 | |
500008 | 7 июля 2000 | 5.0-CURRENT после обновления кода KAME до исходников от 2000/07. | |
500009 | 14 июля 2000 | 5.0-CURRENT после изменений в | |
500010 | 16 июля 2000 | 5.0-CURRENT после изменения настроек mtree обратно на исходный вариант, с добавлением -L для следования по символьным ссылкам. | |
500011 | 18 июля 2000 | 5.0-CURRENT после изменения API kqueue. | |
500012 | 2 сентября 2000 | 5.0-CURRENT после переноса setproctitle(3) из libutil в libc. | |
500013 | 10 сентября 2000 | 5.0-CURRENT после первого коммита SMPng. | |
500014 | 4 января 2001 | 5.0-CURRENT после перемещения <sys/select.h> в <sys/selinfo.h>. | |
500015 | 10 января 2001 | 5.0-CURRENT после объединения libgcc.a и libgcc_r.a, а также связанных изменений в компоновке GCC. | |
500016 | 24 января 2001 | 5.0-CURRENT после изменения, разрешающего совместную линковку libc и libc_r, с объявлением устаревшим параметра -pthread. | |
500017 | 18 февраля 2001 | 5.0-CURRENT после перехода со структуры | |
500018 | 24 февраля 2001 | 5.0-CURRENT после добавления переменной сборки CPUTYPE для управления оптимизациями под конкретный процессор. | |
500019 | 9 июня 2001 | 5.0-CURRENT после перемещения machine/ioctl_fd.h в sys/fdcio.h | |
500020 | 15 июня 2001 | 5.0-CURRENT после переименования названий локалей. | |
500021 | 22 июня 2001 | 5.0-CURRENT после импорта Bzip2. Также означает удаление S/Key. | |
500022 | 12 июля 2001 | 5.0-CURRENT после поддержки SSE. | |
500023 | 14 сентября 2001 | 5.0-CURRENT после второго этапа KSE. | |
500024 | 1 октября 2001 | 5.0-CURRENT после | |
500025 | 4 октября 2001 | 5.0-CURRENT после изменения ABI для передачи дескрипторов и | |
500026 | 9 октября 2001 | 5.0-CURRENT после перехода на XFree86 4 по умолчанию для сборки пакетов и после добавления новой функции | |
500027 | 10 октября 2001 | 5.0-CURRENT после добавления новой функции | |
500028 | 14 декабря 2001 | 5.0-CURRENT после импорта компонентов пользовательского пространства smbfs. | |
(не изменено) | 5.0-CURRENT после добавления новых целочисленных типов фиксированной ширины C99. | ||
500029 | 29 января 2002 | 5.0-CURRENT после изменения возвращаемого значения sendfile(2). | |
500030 | 15 февраля 2002 | 5.0-CURRENT после введения типа | |
500031 | 24 февраля 2002 | 5.0-CURRENT после переименования элемента структуры usb. | |
500032 | 16 марта 2002 | 5.0-CURRENT после внедрения Perl 5.6.1. | |
500033 | 3 апреля 2002 | 5.0-CURRENT после того, как переменная | |
500034 | 30 апреля 2002 | 5.0-CURRENT после того, как | |
500035 | 13 мая 2002 | 5.0-CURRENT с Gcc 3.1. | |
500036 | 17 мая 2002 | 5.0-CURRENT без Perl в /usr/src | |
500037 | 29 мая 2002 | 5.0-CURRENT после добавления dlfunc(3) | |
500038 | 24 июля 2002 | 5.0-CURRENT после изменения типов некоторых членов структуры | |
500039 | 1 сентября 2002 | 5.0-CURRENT после импорта GCC 3.2.1. Также после того, как заголовки перестали использовать BSD_FOO_T и начали использовать _FOO_T_DECLARED. Это значение также можно использовать как консервативную оценку начала поддержки пакета bzip2(1). | |
500040 | 20 сентября 2002 | 5.0-CURRENT после внесения различных изменений в функции работы с дисками, направленных на устранение зависимости от внутренней структуры disklabel. | |
500041 | 1 октября 2002 | 5.0-CURRENT после добавления getopt_long(3) в libc. | |
500042 | 15 октября 2002 | 5.0-CURRENT после обновления Binutils 2.13, которое включило новую эмуляцию FreeBSD, | |
500043 | 1 ноября 2002 | 5.0-CURRENT после добавления слабых заглушек pthread_XXX в libc, что сделало устаревшей libXThrStub.so. 5.0-RELEASE. | |
500100 | 17 января 2003 | 5.0-CURRENT после ветвления для RELENG_5_0 | |
500101 | 19 февраля 2003 | <sys/dkstat.h> пустой. Не включайте его. | |
500102 | 25 февраля 2003 | 5.0-CURRENT после изменения интерфейса d_mmap_t. | |
500103 | 26 февраля 2003 | 5.0-CURRENT после изменения | |
500104 | 27 февраля 2003 |
| |
500105 | 4 марта 2003 | 5.0-CURRENT после новой инициализации метода cdevsw. | |
500106 | 8 марта 2003 |
| |
500107 | 15 марта 2003 | Изменение интерфейса | |
500108 | 15 марта 2003 | Изменения в интерфейсе Token-Ring. | |
500109 | 25 марта 2003 | Добавление | |
500110 | 28 марта 2003 | 5.0-CURRENT после того, как realpath(3) стал потокобезопасным | |
500111 | 9 апреля 2003 | 5.0-CURRENT после синхронизации usbhid(3) с NetBSD | |
500112 | 17 апреля 2003 | 5.0-CURRENT после новой реализации NSS и добавления функций POSIX.1 getpw*_r, getgr*_r | |
500113 | 2 мая 2003 | 5.0-CURRENT после удаления старой системы rc. | |
501000 | 4 июня 2003 | 5.1-RELEASE. | |
501100 | 2 июня 2003 | 5.1-CURRENT после ветвления для RELENG_5_1. | |
501101 | 29 июня 2003 | 5.1-CURRENT после исправления семантики sigtimedwait(2) и sigwaitinfo(2). | |
501102 | 3 июля 2003 | 5.1-CURRENT после добавления полей | |
501103 | 31 июля 2003 | 5.1-CURRENT после интеграции снимка GCC 3.3.1-pre 20030711. | |
501104 | 5 августа 2003 | 5.1-CURRENT Изменения API 3ware в twe. | |
501105 | 17 августа 2003 | 5.1-CURRENT динамически связанные /bin и /sbin поддержка и перемещение библиотек в /lib. | |
501106 | 8 сентября 2003 | 5.1-CURRENT после добавления поддержки ядра для Coda 6.x. | |
501107 | 17 сентября 2003 | 5.1-CURRENT после того, как константы UART 16550 были перемещены из <dev/sio/sioreg.h> в <dev/ic/ns16550.h>. Также когда функциональность libmap стала безусловно поддерживаться rtld. | |
501108 | 23 сентября 2003 | 5.1-CURRENT после обновления API PFIL_HOOKS | |
501109 | 27 сентября 2003 | 5.1-CURRENT после добавления kiconv(3) | |
501110 | 28 сентября 2003 | 5.1-CURRENT после изменения операций по умолчанию для open и close в cdevsw | |
501111 | 16 октября 2003 | 5.1-CURRENT после изменения структуры cdevsw | |
501112 | 16 октября 2003 | 5.1-CURRENT после добавления множественного наследования kobj | |
501113 | 31 октября 2003 | 5.1-CURRENT после изменения | |
501114 | 16 ноября 2003 | 5.1-CURRENT после изменения /bin и /sbin на динамически линкуемые | |
502000 | 7 декабря 2003 | 5.2-RELEASE | |
502010 | 23 февраля 2004 | 5.2.1-RELEASE | |
502100 | 7 декабря 2003 | 5.2-CURRENT после ветвления для RELENG_5_2 | |
502101 | 19 декабря 2003 | 5.2-CURRENT после добавления функций | |
502102 | 30 января 2004 | 5.2-CURRENT после изменения стандартной библиотеки потоков с libc_r на libpthread. | |
502103 | 21 февраля 2004 | 5.2-CURRENT после масштабного патча API драйверов устройств. | |
502104 | 25 февраля 2004 | 5.2-CURRENT после добавления | |
502105 | 5 марта 2004 | 5.2-CURRENT после того, как NULL заменён на ((void *)0) для C, что вызывает больше предупреждений. | |
502106 | 8 марта 2004 | 5.2-CURRENT после подключения pf к сборке и установке. | |
502107 | 10 марта 2004 | 5.2-CURRENT после изменения | |
502108 | 12 марта 2004 | 5.2-CURRENT после поддержки компилятора Intel C/C++ в некоторых заголовочных файлах и изменений в execve(2) для более строгого соответствия POSIX. | |
502109 | 22 марта 2004 | 5.2-CURRENT после введения API | |
502110 | 27 марта 2004 | 5.2-CURRENT после добавления локалей UTF-8 | |
502111 | 11 апреля 2004 | 5.2-CURRENT после удаления API getvfsent(3) | |
502112 | 13 апреля 2004 | 5.2-CURRENT после добавления директивы .warning для make. | |
502113 | 4 июня 2004 | 5.2-CURRENT после того, как | |
502114 | 13 июня 2004 | 5.2-CURRENT после импорта инфраструктуры ALTQ. | |
502115 | 14 июня 2004 | 5.2-CURRENT после изменения sema_timedwait(9) для возврата 0 при успехе и ненулевого кода ошибки при сбое. | |
502116 | 16 июня 2004 | 5.2-CURRENT после изменения типа | |
502117 | 17 июня 2004 | 5.2-CURRENT после изменения ядра | |
502118 | 17 июня 2004 | 5.2-CURRENT после добавления поддержки CLOCK_VIRTUAL и CLOCK_PROF в clock_gettime(2) и clock_getres(2). | |
502119 | 22 июня 2004 | 5.2-CURRENT после изменения переработки клонирования сетевых интерфейсов. | |
502120 | 2 июля 2004 | 5.2-CURRENT после обновления инструментов пакетов до ревизии 20040629. | |
502121 | 9 июля 2004 | 5.2-CURRENT после пометки кода Bluetooth как не специфичного для i386. | |
502122 | 11 июля 2004 | 5.2-CURRENT после внедрения фреймворка отладчика KDB, преобразования DDB в бэкенд и добавления бэкенда GDB. | |
502123 | 12 июля 2004 | 5.2-CURRENT после изменения, чтобы VFS_ROOT принимал аргумент struct thread, как и vflush. Структура | |
502124 | 24 июля 2004 | 5.2-CURRENT после изменения, разделяющего способ запуска rc.d портов и устаревших скриптов. | |
502125 | 28 июля 2004 | 5.2-CURRENT после отмены предыдущего изменения. | |
502126 | 31 июля 2004 | 5.2-CURRENT после удаления | |
502127 | 2 августа 2004 | 5.2-CURRENT после изменения UMA API ядра для разрешения ошибок в ctors/inits. | |
502128 | 8 августа 2004 | 5.2-CURRENT после изменения сигнатуры vfs_mount, а также глобальной замены PRISON_ROOT на SUSER_ALLOWJAIL для API suser(9). | |
503000 | 23 августа 2004 | 5.3-BETA/RC до изменения API pfil | |
503001 | 22 сентября 2004 | 5.3-RELEASE | |
503100 | 16 октября 2004 | 5.3-STABLE после ветвления для RELENG_5_3 | |
503101 | 3 декабря 2004 | 5.3-STABLE после добавления опций заполнения strftime(3) в стиле glibc. | |
503102 | 13 февраля 2005 | 5.3-STABLE после импорта nc(1) из OpenBSD MFC. | |
503103 | 27 февраля 2005 | 5.4-PRERELEASE после MFC исправлений в <src/include/stdbool.h> и <src/sys/i386/include/_types.h> для обеспечения совместимости с GCC компилятора Intel C/C++. | |
503104 | 28 февраля 2005 | 5.4-PRERELEASE после MFC изменения | |
503105 | 2 марта 2005 | 5.4-PRERELEASE после переноса исправления проверки EOVERFLOW в vswprintf(3). | |
504000 | 3 апреля 2005 | 5.4-RELEASE. | |
504100 | 3 апреля 2005 | 5.4-STABLE после ветвления для RELENG_5_4 | |
504101 | 11 мая 2005 | 5.4-STABLE после увеличения размеров стеков потоков по умолчанию | |
504102 | 24 июня 2005 | 5.4-STABLE после добавления sha256 | |
504103 | 3 октября 2005 | 5.4-STABLE после слияния изменений (MFC) if_bridge | |
504104 | 13 ноября 2005 | 5.4-STABLE после слияния изменений (MFC) bsdiff и portsnap | |
504105 | 17 января 2006 | 5.4-STABLE после MFC изменений ldconfig_local_dirs. | |
505000 | 12 мая 2006 | 5.5-RELEASE. | |
505100 | 12 мая 2006 | 5.5-STABLE после ветвления для RELENG_5_5 |
18.12. Версии FreeBSD 4
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
400000 | 22 января 1999 | 4.0-CURRENT после ветки 3.4 | |
400001 | 20 февраля 1999 | 4.0-CURRENT после изменения в обработке динамического компоновщика | |
400002 | 13 марта 1999 | 4.0-CURRENT после изменения порядка конструкторов/деструкторов C++ | |
400003 | 27 марта 1999 | 4.0-CURRENT после функционирования dladdr(3) | |
400004 | 5 апреля 1999 | 4.0-CURRENT после исправления ошибки динамического компоновщика | |
400005 | 27 апреля 1999 | 4.0-CURRENT после изменения API suser(9) (также 4.0-CURRENT после newbus) | |
400006 | 31 мая 1999 | 4.0-CURRENT после изменения регистрации cdevsw | |
400007 | 17 июня 1999 | 4.0-CURRENT после добавления | |
400008 | 20 июня 1999 | 4.0-CURRENT после добавления обёртки системного вызова poll в libc_r | |
400009 | 20 июля 1999 | 4.0-CURRENT после изменения типа | |
400010 | 25 сентября 1999 | 4.0-CURRENT после исправления уязвимости в jail(2) | |
400011 | 29 сентября 1999 | 4.0-CURRENT после изменения типа данных | |
400012 | 15 ноября 1999 | 4.0-CURRENT после перехода на компилятор GCC 2.95.2 | |
400013 | 4 декабря 1999 | 4.0-CURRENT после добавления подключаемых обработчиков ioctl в режиме linux | |
400014 | 18 января 2000 | 4.0-CURRENT после импорта OpenSSL | |
400015 | 27 января 2000 | 4.0-CURRENT после изменения ABI C++ в GCC 2.95.2 с -fvtable-thunks на -fno-vtable-thunks по умолчанию | |
400016 | 27 февраля 2000 | 4.0-CURRENT после импорта OpenSSH | |
400017 | 13 марта 2000 | 4.0-RELEASE | |
400018 | 17 марта 2000 | 4.0-STABLE после 4.0-RELEASE | |
400019 | 5 мая 2000 | 4.0-STABLE после введения отложенных контрольных сумм. | |
400020 | 4 июня 2000 | 4.0-STABLE после объединения кода libxpg4 в libc. | |
400021 | 8 июля 2000 | 4.0-STABLE после обновления Binutils до 2.10.0, изменения маркировки ELF и tcsh в базовой системе. | |
410000 | 14 июля 2000 | 4.1-RELEASE | |
410001 | 29 июля 2000 | 4.1-STABLE после 4.1-RELEASE | |
410002 | 16 сентября 2000 | 4.1-STABLE после перемещения setproctitle(3) из libutil в libc. | |
411000 | 25 сентября 2000 | 4.1.1-RELEASE | |
411001 | 4.1.1-STABLE после 4.1.1-RELEASE | ||
420000 | 31 октября 2000 | 4.2-RELEASE | |
420001 | 10 января 2001 | 4.2-STABLE после объединения libgcc.a и libgcc_r.a, а также связанных изменений в компоновке GCC. | |
430000 | 6 марта 2001 | 4.3-RELEASE | |
430001 | 18 мая 2001 | 4.3-STABLE после введения | |
430002 | 22 июля 2001 | 4.3-STABLE после объединения API управления состоянием питания PCI. | |
440000 | 1 августа 2001 | 4.4-RELEASE | |
440001 | 23 октября 2001 | 4.4-STABLE после введения | |
440002 | 4 ноября 2001 | 4.4-STABLE после изменений в структуре монтирования (затрагивает модули файловых систем klds). | |
440003 | 18 декабря 2001 | 4.4-STABLE после импорта компонентов пользовательского пространства smbfs. | |
450000 | 20 декабря 2001 | 4.5-RELEASE | |
450001 | 24 февраля 2002 | 4.5-STABLE после переименования элемента структуры usb. | |
450002 | 12 марта 2002 | 4.5-STABLE после изменений локали. | |
450003 | (Никогда не создавался) | ||
450004 | 16 апреля 2002 | 4.5-STABLE после того, как переменная | |
450005 | 27 апреля 2002 | 4.5-STABLE после перехода на XFree86 4 по умолчанию для сборки пакетов. | |
450006 | 1 мая 2002 | 4.5-STABLE после исправления фильтрации accept, чтобы он больше не был подвержен простой DoS-атаке. | |
460000 | 21 июня 2002 | 4.6-RELEASE | |
460001 | 21 июня 2002 | 4.6-STABLE sendfile(2) исправлен для соответствия документации, чтобы не учитывать отправленные заголовки в объеме данных, отправляемых из файла. | |
460002 | 19 июля 2002 | 4.6.2-RELEASE | |
460100 | 26 июня 2002 | 4.6-STABLE | |
460101 | 26 июня 2002 | 4.6-STABLE после MFC | |
460102 | 1 сентября 2002 | 4.6-STABLE после MFC множества новых функций pkg_install из HEAD. | |
470000 | 8 октября 2002 | 4.7-RELEASE | |
470100 | 9 октября 2002 | 4.7-STABLE | |
470101 | 10 ноября 2002 | Начинать генерировать ссылки | |
470102 | 23 января 2003 | 4.7-STABLE после MFC изменений mbuf для замены | |
470103 | 14 февраля 2003 | 4.7-STABLE получает OpenSSL 0.9.7 | |
480000 | 30 марта 2003 | 4.8-RELEASE | |
480100 | 5 апреля 2003 | 4.8-STABLE | |
480101 | 22 мая 2003 | 4.8-STABLE после того, как realpath(3) стал потокобезопасным | |
480102 | 10 августа 2003 | 4.8-STABLE Изменения API 3ware в twe. | |
490000 | 27 октября 2003 | 4.9-RELEASE | |
490100 | 27 октября 2003 | 4.9-STABLE | |
490101 | 8 января 2004 | 4.9-STABLE после добавления | |
490102 | 4 февраля 2004 | 4.9-STABLE после MFC функциональности libmap для rtld. | |
491000 | 25 мая 2004 | 4.10-RELEASE | |
491100 | 1 июня 2004 | 4.10-STABLE | |
491101 | 11 августа 2004 | 4.10-STABLE после слияния изменения из ревизии 20040629 пакета tools | |
491102 | 16 ноября 2004 | 4.10-STABLE после исправления VM, связанного с обработкой размонтирования фиктивных страниц | |
492000 | 17 декабря 2004 | 4.11-RELEASE | |
492100 | 17 декабря 2004 | 4.11-STABLE | |
492101 | 18 апреля 2006 | 4.11-STABLE после добавления каталогов libdata/ldconfig в файлы mtree. |
18.13. Версии FreeBSD 3
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
300000 | 19 февраля 1996 | 3.0-CURRENT до изменения mount(2) | |
300001 | 24 сентября 1997 | 3.0-CURRENT после изменения mount(2) | |
300002 | 2 июня 1998 | 3.0-CURRENT после изменения semctl(2) | |
300003 | 7 июня 1998 | 3.0-CURRENT после изменений аргументов ioctl | |
300004 | 3 сентября 1998 | 3.0-CURRENT после преобразования в ELF | |
300005 | 16 октября 1998 | 3.0-RELEASE | |
300006 | 16 октября 1998 | 3.0-CURRENT после 3.0-RELEASE | |
300007 | 22 января 1999 | 3.0-STABLE после ветвления 3/4 | |
310000 | 9 февраля 1999 | 3.1-RELEASE | |
310001 | 27 марта 1999 | 3.1-STABLE после 3.1-RELEASE | |
310002 | 14 апреля 1999 | 3.1-STABLE после изменения порядка конструкторов/деструкторов C++ | |
320000 | 3.2-RELEASE | ||
320001 | 8 мая 1999 | 3.2-STABLE | |
320002 | 29 августа 1999 | 3.2-STABLE после бинарно-несовместимых изменений в IPFW и сокетах | |
330000 | 2 сентября 1999 | 3.3-RELEASE | |
330001 | 16 сентября 1999 | 3.3-STABLE | |
330002 | 24 ноября 1999 | 3.3-STABLE после добавления mkstemp(3) в libc | |
340000 | 5 декабря 1999 | 3.4-RELEASE | |
340001 | 17 декабря 1999 | 3.4-STABLE | |
350000 | 20 июня 2000 | 3.5-RELEASE | |
350001 | 12 июля 2000 | 3.5-STABLE |
18.14. Версии FreeBSD 2.2
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
220000 | 19 февраля 1997 | 2.2-RELEASE | |
(не изменено) | 2.2.1-RELEASE | ||
(не изменено) | 2.2-STABLE после 2.2.1-RELEASE | ||
221001 | 15 апреля 1997 | 2.2-STABLE после texinfo-3.9 | |
221002 | 30 апреля 1997 | 2.2-STABLE после обновления | |
222000 | 16 мая 1997 | 2.2.2-RELEASE | |
222001 | 19 мая 1997 | 2.2-STABLE после 2.2.2-RELEASE | |
225000 | 2 октября 1997 | 2.2.5-RELEASE | |
225001 | 20 ноября 1997 | 2.2-STABLE после 2.2.5-RELEASE | |
225002 | 27 декабря 1997 | 2.2-STABLE после слияния ldconfig -R | |
226000 | 24 марта 1998 | 2.2.6-RELEASE | |
227000 | 21 июля 1998 | 2.2.7-RELEASE | |
227001 | 21 июля 1998 | 2.2-STABLE после 2.2.7-RELEASE | |
227002 | 19 сентября 1998 | 2.2-STABLE после изменения semctl(2) | |
228000 | 29 ноября 1998 | 2.2.8-RELEASE | |
228001 | 29 ноября 1998 | 2.2-STABLE после 2.2.8-RELEASE |
Обратите внимание, что 2.2-STABLE иногда идентифицирует себя как "2.2.5-STABLE" после выпуска 2.2.5-RELEASE. Ранее использовался шаблон "год-месяц", но сообщество решило изменить его на более простую систему "основной/второстепенный", начиная с версии 2.2. Это связано с тем, что параллельная разработка нескольких веток сделала невозможным классифицировать выпуски только по датам их фактического выхода. Не беспокойтесь о старых версиях -CURRENT; они приведены здесь только для справки. |
18.15. FreeBSD 2 Версии до 2.2-RELEASE
| Значение | Версия | Дата | Релиз |
|---|---|---|---|
119411 | 2.0-RELEASE | ||
199501 | 19 марта 1995 | 2.1-CURRENT | |
199503 | 24 марта 1995 | 2.1-CURRENT | |
199504 | 9 апреля 1995 | 2.0.5-RELEASE | |
199508 | 26 августа 1995 | 2.2-CURRENT до 2.1 | |
199511 | 10 ноября 1995 | 2.1.0-RELEASE | |
199512 | 10 ноября 1995 | 2.2-CURRENT до 2.1.5 | |
199607 | 10 июля 1996 | 2.1.5-RELEASE | |
199608 | 12 июля 1996 | 2.2-CURRENT до 2.1.6 | |
199612 | 15 ноября 1996 | 2.1.6-RELEASE | |
199612 | 2.1.7-RELEASE |
Изменено: 18 сентября 2025 г. by Vladlen Popolitov