Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
freebsd
GitHub Repository: freebsd/freebsd-ports
Path: blob/main/Tools/scripts/ai-master-prompt.md
18878 views

Project Context: FreeBSD ports

General Instructions

  • Individual port directories are under category directories: {category}/{port directory}

  • In order to perform operations on an individual port you need to change directory into this port.

  • In every port's directory there is a Makefile.

  • WRKDIR of every port can be determined by the command 'make -V WRKDIR'

  • WRKSRC of every port can be determined by the command 'make -V WRKSRC'

  • When any port is updated, the distinfo file can be regenerated using the 'make makesum' command.

  • Any port can download and extract the source files using the 'make patch' command.

  • Working directory can be removed (cleaned) using the 'make clean' command.

  • PORTREVISION should be removed when DISTVERSION or PORTVERSION is updated.

  • Any FreeBSD package that is needed can be installed using the command 'sudo pkg install -A {package name}'.

  • In case if any work* directories are present in the port directory before the port update such directories should be removed by the 'make clean' command.

  • The USES variable in port's Makefile defines what type of port this is.

    • When USES contains the word 'gmake' this is a port that is built using GNU Make (using the the gmake executable).

    • When USES contains the word 'cmake' this is a port that is built using cmake.

    • When USES contains the word 'python' this is a Python based port.

    • When USES contains the word 'cargo' this is a Rust based port.

    • When USES contains the word 'cabal' this is a Haskell based port.

  • Port uses GitHub to fetch distfiles if it has the USE_GITHUB=yes line.

  • Every port has a maintainer, maintainer's e-mail address is in the MAINTAINER variable.

Instructions for ports that use GitHub to fetch distfiles

  • GitHub account name of such ports is in GH_ACCOUNT, or otherwise PORTNAME is used as an account name.

  • GitHub project name of such ports is in GH_PROJECT, or otherwise PORTNAME is used as a project name.

  • The GitHub git URL is constructed as https://github.com/{GH_ACCOUNT}/{GH_PROJECT}.git

  • The latest released version of a git URL can be determined using the command '../../Tools/scripts/git-get-latest-remote-version.sh {Git-URL} {DISTVERSIONPREFIX}'

Instructions for Python based ports

  • The latest released version of the software can be determined using the command '../../Tools/scripts/pypi-get-latest-version.sh {python project name}'

  • Dependencies need to be updated when the port is updated. They need to be compared with the dependency requirements set in the project.

  • setuptools build dependency should never be added to BUILD_DEPENDS, and instead the distutils element should be present in USE_PYTHON.

  • numpy dependency should be added as ${PYNUMPY} instead of the usual syntax. No version information should be added in this case.

  • pillow dependency should be added as ${PY_PILLOW} instead of the usual syntax. No version information should be added in this case.

  • The cython build dependency should never be added to BUILD_DEPENDS. Instead, the cython element should be added to USE_PYTHON for cython dependencies of versions 1.x or 2.x, and the cython3 element should be added to USE_PYTHON for cython dependencies of versions 3.x

  • Do not add upper version limits for Python based ports.

  • Always replace exact version comparison in dependencies with >=.

Instructions for Haskell based ports

  • Directories of all Haskell ports have the prefix "hs-".

  • The latest released version of the software can be determined using the command '../../Tools/scripts/haskell-get-latest-version.sh {haskell project name}'