Blame etc/README.md

Lucio Andrés Illanes Albornoz a6970c
> N.B. If you're interested in building Midipix using this script, please join
Lucio Andrés Illanes Albornoz 2128b8
the project's IRC channel #midipix on Libera and ask for the address of the
Lucio Andrés Illanes Albornoz a6970c
internal repositories required in order to build Midipix.
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "{{{ Table of contents"
Lucio Andrés Illanes Albornoz a6970c
# Table of Contents
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
1. [What is midipix, and how is it different?](#1-what-is-midipix-and-how-is-it-different)  
Lucio Andrés Illanes Albornoz a99d13
2. [Building and deployment](#2-building-and-deployment)  
Lucio Andrés Illanes Albornoz a99d13
	2.1. [Building, installing, and using a midipix distribution](#21-building-installing-and-using-a-midipix-distribution)  
Lucio Andrés Illanes Albornoz a99d13
		2.1.1. [Build-time dependencies](#211-build-time-dependencies)  
Lucio Andrés Illanes Albornoz a99d13
			2.1.1.1. [Alpine-specific notate bene](#2111-alpine-specific-notate-bene)  
Lucio Andrés Illanes Albornoz a6970c
	2.2. [Deployment](#22-deployment)  
Lucio Andrés Illanes Albornoz a6970c
	2.3. [System requirements](#23-system-requirements)  
Lucio Andrés Illanes Albornoz ac032e
	2.4. [Troubleshooting](#24-troubleshooting)  
Lucio Andrés Illanes Albornoz a99d13
3. [Common concepts and tasks](#3-common-concepts-and-tasks)  
Lucio Andrés Illanes Albornoz a99d13
	3.1. [Common tasks](#31-common-tasks)  
Lucio Andrés Illanes Albornoz a6970c
	3.2. [Adding a package](#32-adding-a-package)  
Lucio Andrés Illanes Albornoz a6970c
	3.3. [Addressing build failure](#33-addressing-build-failure)  
Lucio Andrés Illanes Albornoz a99d13
	3.4. [Package archive files and Git repositories](#34-package-archive-files-and-git-repositories)  
Lucio Andrés Illanes Albornoz a99d13
	3.5. [``-s``: package build shell environment](#35--s-package-build-shell-environment)  
Lucio Andrés Illanes Albornoz a99d13
	3.6. [Package-package and {package,group}-group relationships](#36-package-package-and-packagegroup-group-relationships)  
Lucio Andrés Illanes Albornoz a99d13
	3.7. [Patches and ``vars`` files](#37-patches-and-vars-files)  
Lucio Andrés Illanes Albornoz a99d13
4. [Units reference](#4-units-reference)  
Lucio Andrés Illanes Albornoz a6970c
	4.1. [Build steps](#41-build-steps)  
Lucio Andrés Illanes Albornoz a99d13
	4.2. [Build variables](#42-build-variables)  
Lucio Andrés Illanes Albornoz a99d13
	4.3. [Fault-tolerant & highly optimised 3D laser show-equipped usage screen](#43-fault-tolerant--highly-optimised-3d-laser-show-equipped-usage-screen)  
Lucio Andrés Illanes Albornoz a99d13
	4.4. [File installation DSL](#44-file-installation-dsl)  
Lucio Andrés Illanes Albornoz a99d13
	4.5. [Package variables](#45-package-variables)  
Lucio Andrés Illanes Albornoz a99d13
		4.5.1. [Package variable types](#451-package-variable-types)  
Lucio Andrés Illanes Albornoz a99d13
		4.5.2. [Package variables](#452-package-variables)  
Lucio Andrés Illanes Albornoz a99d13
	4.6. [``pkgtool.sh``](#46-pkgtoolsh)  
Lucio Andrés Illanes Albornoz a6970c
5. [References](#5-references)  
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: "}}}"
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "{{{ 1. What is midipix, and how is it different?"
Lucio Andrés Illanes Albornoz a6970c
## 1. What is midipix, and how is it different?
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
midipix is a development environment that lets you create programs
Lucio Andrés Illanes Albornoz a6970c
for Windows using the standard C and POSIX APIs. No compromises made,
Lucio Andrés Illanes Albornoz a6970c
no shortcuts taken.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
If you are interested in cross-platform programming that reclaims
Lucio Andrés Illanes Albornoz a6970c
the notion of write once, compile everywhere; if you believe that the
Lucio Andrés Illanes Albornoz a6970c
'standard' in the C Standard Library should not be a null signifier;
Lucio Andrés Illanes Albornoz a6970c
and if you like cooking your code without #ifdef hell and low-level
Lucio Andrés Illanes Albornoz a6970c
minutiae, then this page is for you.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
midipix makes cross-platform programming better, simpler and faster,
Lucio Andrés Illanes Albornoz a6970c
specifically by bringing a modern, conforming C Runtime Library to the
Lucio Andrés Illanes Albornoz a6970c
Windows platform. While the idea itself is not new, the approach taken
Lucio Andrés Illanes Albornoz a6970c
in midipix to code portability is radically different from that found
Lucio Andrés Illanes Albornoz a6970c
in other projects.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
*(reproduced from [[2](https://midipix.org/#sec-midipix)])*
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: "}}}"
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 2. Building and deployment"
Lucio Andrés Illanes Albornoz a99d13
## 2. Building and deployment
Lucio Andrés Illanes Albornoz a99d13
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 2.1. Building, installing, and using a midipix distribution"
Lucio Andrés Illanes Albornoz a99d13
### 2.1. Building, installing and using a midipix distribution
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
A Midipix distribution consists of the following:
Lucio Andrés Illanes Albornoz a6970c
* the native Midipix toolchain, consisting of perk, gcc, its dependencies,
Lucio Andrés Illanes Albornoz a6970c
  and binutils,
Lucio Andrés Illanes Albornoz a6970c
* musl, a lightweight, fast, simple, and free libc[[1](https://www.musl-libc.org/faq.html)] used by Midipix,
Lucio Andrés Illanes Albornoz a6970c
* the Midipix runtime components that bridge the gap between the libc and the
Lucio Andrés Illanes Albornoz a6970c
  executive subsystems of all Windows NT-derived Windows OS starting with and
Lucio Andrés Illanes Albornoz a6970c
  including Windows XP, and
Lucio Andrés Illanes Albornoz a6970c
* a steadily increasing number of 3rd party open source packages, as expected in
Lucio Andrés Illanes Albornoz a6970c
  any modern POSIX-compliant \*nix environment, including GNU coreutils, shells,
Lucio Andrés Illanes Albornoz a6970c
  libraries such as ncurses, libressl, as well as Perl and Python.
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a99d13
Install the build-time dependencies listed in section [2.1.1](#211-build-time-dependencies),
Lucio Andrés Illanes Albornoz f4b29e
clone this repository (e.g. ``git clone https://dev.midipix.org/build/midipix_build``)
Lucio Andrés Illanes Albornoz f4b29e
and run the following command line:
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
```shell
Lucio Andrés Illanes Albornoz a6970c
./build.sh -a nt64 -b release -D zipdist -P -v
Lucio Andrés Illanes Albornoz a6970c
```
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
By default, the build will take place within ``${HOME}/midipix/nt64/release``
Lucio Andrés Illanes Albornoz a6970c
and package archive files and/or Git repositores will be downloaded into
Lucio Andrés Illanes Albornoz a99d13
``${HOME}/midipix/dlcache``. Consult sections [4.2](#42-build-variables) and
Lucio Andrés Illanes Albornoz a99d13
[4.5](#45-package-variables) for the list of available build/package variables
Lucio Andrés Illanes Albornoz a99d13
and how to override them.  
Lucio Andrés Illanes Albornoz a6970c
Parallelisation is enabled by the above command line for both packages that can
Lucio Andrés Illanes Albornoz a6970c
be built independently of each other and ``make(1)`` via ``-j``, limited to the
Lucio Andrés Illanes Albornoz a6970c
amount of logical processors on the build host divided by two (2).
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 2.1.1. Build-time dependencies"
Lucio Andrés Illanes Albornoz a99d13
### 2.1.1. Build-time dependencies
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz 98b1bd
* **Alpine Linux**:
Lucio Andrés Illanes Albornoz 98b1bd
  binutils bzip2 cmake coreutils curl findutils g++ gawk gcc git grep gzip libc-dev linux-headers lzip make musl-dev net-tools patch perl perl-xml-parser procps sed tar util-linux wget xz zip
Lucio Andrés Illanes Albornoz 98b1bd
* **Debian/-derived Linux**:
Lucio Andrés Illanes Albornoz 98b1bd
  binutils bzip2 clzip cmake coreutils curl findutils g++ gawk gcc git grep gzip hostname libc6-dev libxml-parser-perl lzma make patch perl procps sed tar util-linux wget xz-utils zip
Lucio Andrés Illanes Albornoz 98b1bd
* **Gentoo Linux**:
Lucio Andrés Illanes Albornoz 98b1bd
  binutils bzip2 cmake coreutils curl findutils gawk =gcc-7.5.0-r1 dev-vcs/git grep gzip lzip make patch perl dev-perl/XML-Parser procps sed tar util-linux wget xz-utils zip
Lucio Andrés Illanes Albornoz 98b1bd
* **OpenSUSE Linux**:
Lucio Andrés Illanes Albornoz 98b1bd
  binutils bzip2 cmake coreutils curl findutils gawk gcc gcc-c++ git grep gzip hostname linux-glibc-devel lzip make patch perl perl-XML-Parser procps sed tar util-linux wget xz zip
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz 360eb6
> N.B. Busybox is not supported. Awk implementations other than GNU Awk are not supported.  
Lucio Andrés Illanes Albornoz 360eb6
  
Lucio Andrés Illanes Albornoz a99d13
> N.B. gcc versions >7.5.0 are not supported. clang is not supported.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 2.1.1.1. Alpine-specific notate bene"
Lucio Andrés Illanes Albornoz a99d13
#### 2.1.1.1. Alpine-specific notate bene
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
Some packages (*coreutils*, *grep*, and *tar*, among others) override Alpine's
Lucio Andrés Illanes Albornoz a6970c
BusyBox utilities of the same name, as the latter are either non-conformant or
Lucio Andrés Illanes Albornoz a6970c
defective.
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a6970c
[//]: # "{{{ 2.2. Deployment"
Lucio Andrés Illanes Albornoz a6970c
### 2.2. Deployment
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
On successful completion of the build, a ZIP archive containing the Midipix
Lucio Andrés Illanes Albornoz a99d13
distribution will be created inside ``${PREFIX}`` (see section [4.2](#42-build-variables).)
Lucio Andrés Illanes Albornoz a6970c
Create a directory on the target machine and extract the contents of the distribution
Lucio Andrés Illanes Albornoz a6970c
ZIP archive into it, run ``bash.bat``, and then ``/install.sh`` inside the resulting
Lucio Andrés Illanes Albornoz a6970c
self-contained Midipix installation shell window.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
> N.B. The pathname of the target directory containing ``bash.bat`` and all other
Lucio Andrés Illanes Albornoz a6970c
distribution files must not contain whitespaces.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
> N.B. The Midipix installer defaults to ``/dev/fs/c/midipix (C:\midipix)``. If left
Lucio Andrés Illanes Albornoz a6970c
unchanged, the distribution ZIP archive must not be extracted into a directory of the
Lucio Andrés Illanes Albornoz a6970c
same pathname.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz 6bc7e5
> N.B. The user installing and using Midipix must have been delegated the ``SeCreateSymbolicLinkPrivilege``
Lucio Andrés Illanes Albornoz 6bc7e5
("Create symbolic links") privilege[[3](https://docs.microsoft.com/en-us/windows/security/threat-protection/security-policy-settings/user-rights-assignment)] and additionally be a non-administrator account
Lucio Andrés Illanes Albornoz 6bc7e5
owing to the UAC-related filtering policy of tokens introduced by Windows Vista[[4](https://docs.microsoft.com/en-us/previous-versions/dotnet/articles/bb530410%28v%3dmsdn%2e10%29)].  
Lucio Andrés Illanes Albornoz 6bc7e5
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a6970c
[//]: # "{{{ 2.3. System requirements"
Lucio Andrés Illanes Albornoz a6970c
### 2.3. System requirements
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz ac032e
The following build-time system requirements are assessed on build hosts
Lucio Andrés Illanes Albornoz ac032e
equipped with the following hardware at minimum:
Lucio Andrés Illanes Albornoz a6970c
* Intel(R) Xeon(R) CPU W3520 @ 2.67GHz (8 cores)
Lucio Andrés Illanes Albornoz a6970c
* 7200 RPM SATA 3.1 HDD
Lucio Andrés Illanes Albornoz a6970c
* 6 GB RAM
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
| Target architecture | Build kind | Distribution kinds selected | Average build time | Disk space required | Peak RAM usage |
Lucio Andrés Illanes Albornoz a6970c
| ------------------- | ---------- | --------------------------- | ------------------ | ------------------- | -------------- |
Lucio Andrés Illanes Albornoz a6970c
| nt64                | debug      | (none)                      | 2 hours            | 57.62 GB            | 3.55 GB        |
Lucio Andrés Illanes Albornoz a6970c
| nt64                | release    | (none)                      | 1 hours 45 minutes | 36.51 GB            | 3.21 GB        |
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
Package archive files and/or Git repositories additionally consume at least
Lucio Andrés Illanes Albornoz a6970c
1.82 GB.
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
*(last update: Thu, 05 Mar 2020 09:25:41 +0000)*
Lucio Andrés Illanes Albornoz ac032e
Lucio Andrés Illanes Albornoz c10b30
These are the Midipix distribution disk space system requirements:
Lucio Andrés Illanes Albornoz ac032e
Lucio Andrés Illanes Albornoz c10b30
| Target architecture | Build kind | Distribution | Installation directory | Archive file |
Lucio Andrés Illanes Albornoz c10b30
| ------------------- | ---------- | ------------ | ---------------------- | ------------ |
Lucio Andrés Illanes Albornoz c10b30
| nt64                | debug      | 7.3 GB       |  2.3 GB                | 2.1 GB       |
Lucio Andrés Illanes Albornoz c10b30
| nt64                | release    | 3.2 GB       |  913 MB                | 830 MB       |
Lucio Andrés Illanes Albornoz c10b30
Lucio Andrés Illanes Albornoz c10b30
The installation directory and archive file may be safely deleted post-installation.
Lucio Andrés Illanes Albornoz c10b30
Lucio Andrés Illanes Albornoz c10b30
*(last update: Thu, 07 Jan 2021 18:20:06 +0000)*
Lucio Andrés Illanes Albornoz ac032e
  
Lucio Andrés Illanes Albornoz ac032e
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz ac032e
Lucio Andrés Illanes Albornoz ac032e
[//]: # "}}}"
Lucio Andrés Illanes Albornoz ac032e
[//]: # "{{{ 2.4. Troubleshooting"
Lucio Andrés Illanes Albornoz ac032e
### 2.4. Troubleshooting
Lucio Andrés Illanes Albornoz ac032e
Lucio Andrés Illanes Albornoz ac032e
Midipix presently provides, inter alia, strace-like functionality via
Lucio Andrés Illanes Albornoz 6ab687
ntctty's logging capabilities. This is available both through the regular
Lucio Andrés Illanes Albornoz 6ab687
``strace(1)`` command as distributed, which however **must** be provided
Lucio Andrés Illanes Albornoz 6ab687
with an absolute pathname without consideration for ``${PATH}``, as well
Lucio Andrés Illanes Albornoz 6ab687
as directly via ``ntctty.exe`` for a session by running ``ntctty.exe``
Lucio Andrés Illanes Albornoz 6ab687
with the ``--log-level 7`` option, e.g.:
Lucio Andrés Illanes Albornoz ac032e
Lucio Andrés Illanes Albornoz ac032e
```shell
Lucio Andrés Illanes Albornoz 6ab687
$ #strace ls -la /        # (incorrect, relative pathname)
Lucio Andrés Illanes Albornoz 6ab687
$ strace /bin/ls -la /    # (correct, absolute pathname)
Lucio Andrés Illanes Albornoz 6ab687
$ ntctty.exe --log-level 7 -e /bin/ls -la /
Lucio Andrés Illanes Albornoz 6ab687
$ ntctty.exe --log-level=7 -e /bin/ls -la /
Lucio Andrés Illanes Albornoz 6ab687
$ ntctty.exe --log-level 7 -e /bin/sh -c "ls -la /"
Lucio Andrés Illanes Albornoz 6ab687
$ ntctty.exe --log-level=7 -e /bin/sh -c "ls -la /"
Lucio Andrés Illanes Albornoz ac032e
```
Lucio Andrés Illanes Albornoz ac032e
Lucio Andrés Illanes Albornoz 6ab687
By default, ``ntctty.exe`` log files are written into the /var/log/ntctty
Lucio Andrés Illanes Albornoz 6ab687
directory; this may be adjusted with the ``--log-dir`` and/or
Lucio Andrés Illanes Albornoz 6ab687
``--log-file`` options. ``strace(1)`` logs to stderr by default.
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 3. Common concepts and tasks"
Lucio Andrés Illanes Albornoz a99d13
## 3. Common concepts and tasks
Lucio Andrés Illanes Albornoz a99d13
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 3.1. Common tasks"
Lucio Andrés Illanes Albornoz a99d13
### 3.1. Common tasks
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
Rebuild set of packages in isolation:
Lucio Andrés Illanes Albornoz a6970c
```shell
Lucio Andrés Illanes Albornoz a6970c
./build.sh [ ... ] -r mc,zsh
Lucio Andrés Illanes Albornoz a6970c
```
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz 370e98
Restart the ``@install`` (shorthand alias) step, with implicit ``finish``, of the
Lucio Andrés Illanes Albornoz 370e98
``mc`` and ``zsh`` packages.
Lucio Andrés Illanes Albornoz 370e98
```shell
Lucio Andrés Illanes Albornoz 370e98
./build.sh [ ... ] -r mc,zsh:@install
Lucio Andrés Illanes Albornoz 370e98
```
Lucio Andrés Illanes Albornoz 370e98
  
Lucio Andrés Illanes Albornoz a6970c
Rebuild set of packages along w/ their dependencies, if any, as needed, or forcibly,
Lucio Andrés Illanes Albornoz a6970c
respectively:
Lucio Andrés Illanes Albornoz a6970c
```shell
Lucio Andrés Illanes Albornoz a6970c
./build.sh [ ... ] -r \*mc,zsh
Lucio Andrés Illanes Albornoz a6970c
./build.sh [ ... ] -r \*\*mc,zsh
Lucio Andrés Illanes Albornoz a6970c
```
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
Forcibly rebuild all reverse dependencies of a set of packages:
Lucio Andrés Illanes Albornoz a6970c
```shell
Lucio Andrés Illanes Albornoz a6970c
./build.sh [ ... ] -r \*\*\*glib,libflac
Lucio Andrés Illanes Albornoz a6970c
```
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz 370e98
Restart the ``@configure``, ``@build``, and ``@install`` (shorthand alias) steps of the
Lucio Andrés Illanes Albornoz 370e98
``coreutils`` package:
Lucio Andrés Illanes Albornoz a6970c
```shell
Lucio Andrés Illanes Albornoz 370e98
./build.sh -r coreutils:@configure,@build,@install
Lucio Andrés Illanes Albornoz a6970c
```
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
Rebuild entire build groups including or excluding group dependencies, respectively:
Lucio Andrés Illanes Albornoz a6970c
```shell
Lucio Andrés Illanes Albornoz a6970c
./build.sh [ ... ] -r ALL native_runtime
Lucio Andrés Illanes Albornoz a6970c
./build.sh [ ... ] -r ALL =native_runtime
Lucio Andrés Illanes Albornoz a6970c
```
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz 81d35d
Forcibly (re)download all archive files and/or Git repositories associated with all packages:
Lucio Andrés Illanes Albornoz 81d35d
```shell
Lucio Andrés Illanes Albornoz 81d35d
./build.sh [ ... ] -r ALL:@fetch
Lucio Andrés Illanes Albornoz 81d35d
```
Lucio Andrés Illanes Albornoz 81d35d
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a6970c
[//]: # "{{{ 3.2. Adding a package"
Lucio Andrés Illanes Albornoz a6970c
## 3.2. Adding a package
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
Packages are grouped into *build groups* according to sets of common package
Lucio Andrés Illanes Albornoz a6970c
variable defaults, such as ``${PKG_CFLAGS_CONFIGURE}, ${PKG_LDFLAGS_CONFIGURE}``
Lucio Andrés Illanes Albornoz a6970c
and ``${PKG_CONFIGURE_ARGS}``, and semantic interrelatedness, such as the
Lucio Andrés Illanes Albornoz a6970c
``native_runtime`` build group comprising the Midipix runtime components.
Lucio Andrés Illanes Albornoz a6970c
Packages may belong to more than one build group such as when subsumed by a shorthand
Lucio Andrés Illanes Albornoz a6970c
build group e.g. the ``dev_packages`` build group, as long as the default set of build
Lucio Andrés Illanes Albornoz a6970c
groups or as overriden on the command line does not entail group membership conflicts.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
Build groups files beneath ``groups/`` named ``[0-9][0-9][0-9].<group name>.group``
Lucio Andrés Illanes Albornoz a6970c
contain package variable defaults, the alphabetically sorted list of contained
Lucio Andrés Illanes Albornoz a6970c
packages in ``<upper case group name>_PACKAGES``, and their package variables
Lucio Andrés Illanes Albornoz a6970c
sorted alphabetically with the exception of ``${PKG_DEPENDS}`` (if present,)
Lucio Andrés Illanes Albornoz a6970c
``${PKG_SHA256SUM}``, ``${PKG_URL}``, and ``${PKG_VERSION}``, and/or ``${PKG_URLS_GIT}``,
Lucio Andrés Illanes Albornoz a6970c
which are specified in this order.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
Pick a build group according to the criteria mentioned, add the package to the
Lucio Andrés Illanes Albornoz a6970c
build group's list of contained packages in its corresponding file, and add the
Lucio Andrés Illanes Albornoz a99d13
set of package variables required (see above and section [4.5](#45-package-variables).)  
Lucio Andrés Illanes Albornoz a99d13
Consult section [3.7](#37-patches-and-vars-files) if the package to be added
Lucio Andrés Illanes Albornoz a6970c
requires patches or additional code amending or replacing package build steps
Lucio Andrés Illanes Albornoz a6970c
or the entire package build. Consult section [4.1](#41-build-steps) for a list
Lucio Andrés Illanes Albornoz a6970c
of package build steps and how they are overriden.
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a6970c
[//]: # "{{{ 3.3. Addressing build failure"
Lucio Andrés Illanes Albornoz a6970c
## 3.3. Addressing build failure
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
During package build, standard error and output are redirected into a log file beneath
Lucio Andrés Illanes Albornoz a6970c
``${BUILD_WORKDIR}`` named ``${PKG_NAME}_stderrout.log``, following a package variable
Lucio Andrés Illanes Albornoz a6970c
dump. If ``-vv`` was specified, package logs will additionally be printed to standard
Lucio Andrés Illanes Albornoz a6970c
output. If ``-vvv`` was specified, ``xtrace`` will be set during package builds for
Lucio Andrés Illanes Albornoz a6970c
rudimentary debugging purposes. Additionally, packages using GNU autotools will, if
Lucio Andrés Illanes Albornoz a6970c
package configuration failed or appears relevant, log the configuration process in detail
Lucio Andrés Illanes Albornoz a6970c
in, most usually, ``${PKG_BUILD_DIR}/config.log``.  
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
If ``--dump-on-abort`` was specified, a subset of the variables set and environment
Lucio Andrés Illanes Albornoz a6970c
variables exported will be written to ``${BUILD_WORKDIR}/${PKG_NAME}.dump``, which may
Lucio Andrés Illanes Albornoz a6970c
subsequently be used in order to obtain a package build shell environment with the
Lucio Andrés Illanes Albornoz a99d13
``pkgtool.sh`` script (see sections [4.6](#46-pkgtoolsh), [3.5](#35--s-package-build-shell-environment).)
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 3.4. Package archive files and Git repositories"
Lucio Andrés Illanes Albornoz a99d13
### 3.4. Package archive files and Git repositories
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
Packages may have either or both of a SHA-256 message digest checked and to be extracted tarball
Lucio Andrés Illanes Albornoz a99d13
(set in ``${PKG_URL}``, ``${PKG_FNAME}``, and ``${PKG_SHA256SUM}``) and/or Git repository or set
Lucio Andrés Illanes Albornoz a99d13
thereof (set in ``${PKG_URLS_GIT}``.) Complementing these, an implicitly inferred or, in the
Lucio Andrés Illanes Albornoz a99d13
presence of both, explicit primary source directory is specified for each package in ``${PKG_SUBDIR}``.
Lucio Andrés Illanes Albornoz a99d13
Furthermore, these may be subject to download caching and/or setting up as well as maintaining
Lucio Andrés Illanes Albornoz a99d13
mirrors, including automatic cleanup as well as deduplication in both cases.  
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
A list of pertinent package variables and their formats follows:  
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
| Name           | Format                                          |
Lucio Andrés Illanes Albornoz a99d13
| -------------- | ----------------------------------------------- |
Lucio Andrés Illanes Albornoz a99d13
| PKG_FNAME      | ``<single file name>``                          |
Lucio Andrés Illanes Albornoz a99d13
| PKG_SHA256SUM  | ``<SHA-256 message digest>``                    |
Lucio Andrés Illanes Albornoz a99d13
| PKG_SUBDIR     | ``<relative or single directory name>``         |
Lucio Andrés Illanes Albornoz a99d13
| PKG_URL        | ``scheme:[//authority]path[?query][#fragment]`` |
Lucio Andrés Illanes Albornoz a99d13
| PKG_URLS_GIT   | ``[subdir=]URL[@branch]``                       |
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 3.5. -s: package build shell environment"
Lucio Andrés Illanes Albornoz a99d13
### 3.5. -s: package build shell environment
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
When ``build.sh`` is executed with the ``--dump-on-abort`` option, a subset of the
Lucio Andrés Illanes Albornoz a6970c
variables set and environment variables exported will be written to ``${BUILD_WORKDIR}/${PKG_NAME}.dump``
Lucio Andrés Illanes Albornoz a6970c
on build failure, which may subsequently be used in order to obtain a package build shell
Lucio Andrés Illanes Albornoz a6970c
environment with the ``pkgtool.sh`` script, e.g.:  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
```
Lucio Andrés Illanes Albornoz a6970c
midipix_build@sandbox:(src/midipix_build)> $ ./pkgtool.sh -a nt64 -b debug -s mc
Lucio Andrés Illanes Albornoz a6970c
==> 2020/03/11 15:46:28 Launching shell `/usr/bin/zsh' within package environment and `/home/midipix_build/midipix/nt64/debug/tmp'.
Lucio Andrés Illanes Albornoz a6970c
==> 2020/03/11 15:46:28 Run $R to rebuild `mc'.
Lucio Andrés Illanes Albornoz a6970c
==> 2020/03/11 15:46:28 Run $RS <step> to restart the specified build step of `mc'
Lucio Andrés Illanes Albornoz a6970c
==> 2020/03/11 15:46:28 Run $D to automatically regenerate the patch for `mc'.
Lucio Andrés Illanes Albornoz 6ab687
midipix_build@sandbox:(mc-native-x86_64-nt64-midipix/obj)> $
Lucio Andrés Illanes Albornoz a6970c
```
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
If a package build shell environment is desired for a package that has either not been
Lucio Andrés Illanes Albornoz a6970c
built at all or built successfully, ``pkgshell.sh`` will attempt to rebuild the package
Lucio Andrés Illanes Albornoz a6970c
at build steps up until, by default, ``build``, and then forcibly abort the build and
Lucio Andrés Illanes Albornoz a6970c
write ``${BUILD_WORKDIR}/${PKG_NAME}.dump`` as above prior to entering the shell.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a99d13
Consult sections [3.2](#32-adding-a-package), [3.7](#37-patches-and-vars-files), [4.2](#42-build-variables),
Lucio Andrés Illanes Albornoz a99d13
[4.1](#41-build-steps), and [4.5](#45-package-variables) for further information
Lucio Andrés Illanes Albornoz a6970c
concerning the package build process.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 3.6. Package-package and {package,group}-group relationships"
Lucio Andrés Illanes Albornoz a99d13
### 3.6. Package-package and {package,group}-group relationships
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
Packages, as well as groups, are interrelated through implicit as well as explicit parametrised,
Lucio Andrés Illanes Albornoz a99d13
typed relationships and form namespaces correspondingly.  
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
These primarily, by expressing modalities of constraining, derivation, and/or subdividision, govern
Lucio Andrés Illanes Albornoz a99d13
the build and mirroring, etc. processes with regard to ordering constraints (e.g. ``depends``)
Lucio Andrés Illanes Albornoz a99d13
and derivation or sharing of sets of variables and/or patches and/or ``vars/`` files (e.g.
Lucio Andrés Illanes Albornoz a99d13
``group``, ``flavour``, ``inherit``) or build and/or source directories (e.g. ``module``,) etc.  
Lucio Andrés Illanes Albornoz a99d13
They may, however, also be subject to enquiry for descriptive, diagnostic, or visualising purposes,
Lucio Andrés Illanes Albornoz a99d13
particularly as concerns the namespaces they form.  
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
A list of relationship types follows:  
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
| Type     | Mode     | Description                                                                                                                            |
Lucio Andrés Illanes Albornoz a99d13
| -------- | -------- | -------------------------------------------------------------------------------------------------------------------------------------- |
Lucio Andrés Illanes Albornoz a99d13
| depends  | implicit | Direct and recursively evaluated package dependency                                                                                    |
Lucio Andrés Illanes Albornoz a99d13
| suggests | explicit | Suggested or recommended optional package                                                                                              |
Lucio Andrés Illanes Albornoz a99d13
| group    | implicit | Simple and overridable group variable inheritance (e.g. ``host_toolchain``, ``native_packages``)                                       |
Lucio Andrés Illanes Albornoz a99d13
| inherit  | both     | Simple and overridable package variable inheritance                                                                                    |
Lucio Andrés Illanes Albornoz a99d13
| flavour  | explicit | Exclusive package flavours set membership (e.g. ``vim_gtk``, ``vim_x11``) (conflicts w/ ``module``)                                    |
Lucio Andrés Illanes Albornoz a99d13
| module   | explicit | Package modularisation with implicit source and build directory sharing (e.g. ``gcc_stage1``, ``gcc_full``) (conflicts w/ ``flavour``) |
Lucio Andrés Illanes Albornoz a99d13
| target   | both     | Simple super- or subset derivation (e.g. ``host``, ``minipix``)                                                                        |
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a99d13
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 3.7. Patches and ``vars`` files"
Lucio Andrés Illanes Albornoz a99d13
## 3.7. Patches and ``vars`` files
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a99d13
Package patches are applied prior and/or subsequent to (GNU autotools or similar) package
Lucio Andrés Illanes Albornoz a99d13
configuration during the ``configure_patch_pre`` and/or ``configure_patch`` build steps,
Lucio Andrés Illanes Albornoz a99d13
respectively (see section [4.1](#41-build-steps).) Patch files are searched for beneath
Lucio Andrés Illanes Albornoz a99d13
``patches/`` with the following globs and in-order:
Lucio Andrés Illanes Albornoz a99d13
* ``${PKG_NAME}-${PKG_VERSION}_pre.local.patch``
Lucio Andrés Illanes Albornoz a99d13
  or ``${PKG_NAME}_pre.local.patch`` (for packages lacking ``${PKG_VERSION}``)
Lucio Andrés Illanes Albornoz a99d13
* ``${PKG_NAME}-${PKG_VERSION}_pre.local@${BUILD_HNAME}.patch``
Lucio Andrés Illanes Albornoz a99d13
  or ``${PKG_NAME}_pre.local@${BUILD_HNAME}.patch`` (for packages lacking ``${PKG_VERSION}``)
Lucio Andrés Illanes Albornoz a99d13
* ``${PKG_NAME}/*.patch``
Lucio Andrés Illanes Albornoz a99d13
* ``${PKG_NAME}-${PKG_VERSION}.local.patch``
Lucio Andrés Illanes Albornoz a99d13
  or ``${PKG_NAME}.local.patch`` (for packages lacking ``${PKG_VERSION}``)
Lucio Andrés Illanes Albornoz a99d13
* ``${PKG_NAME}-${PKG_VERSION}.local@${BUILD_HNAME}.patch``
Lucio Andrés Illanes Albornoz a99d13
  or ``${PKG_NAME}.local@${BUILD_HNAME}.patch`` (for packages lacking ``${PKG_VERSION}``)
Lucio Andrés Illanes Albornoz a99d13
* ``${PKG_PATCHES_EXTRA}`` (if set)
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
If the default set of package build steps does not suffice, such as if additional commands
Lucio Andrés Illanes Albornoz a99d13
must be executed after package configuration or prior to building, or if an entire or all
Lucio Andrés Illanes Albornoz a99d13
build step must be replaced, overrides may be specified in the form of functions in the
Lucio Andrés Illanes Albornoz a99d13
package's ``vars/${PKG_NAME}.vars`` ``vars`` file. Consult section [4.1](#41-build-steps)
Lucio Andrés Illanes Albornoz a99d13
for a list of package build steps and how they are overriden.
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 4. Units reference"
Lucio Andrés Illanes Albornoz a99d13
## 4. Units reference
Lucio Andrés Illanes Albornoz a99d13
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a6970c
[//]: # "{{{ 4.1. Build steps"
Lucio Andrés Illanes Albornoz a6970c
## 4.1. Build steps
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
Package builds are divided up into consecutively executed build steps until
Lucio Andrés Illanes Albornoz a6970c
completion or aborted on failure unless relaxed mode is enabled by passing
Lucio Andrés Illanes Albornoz a6970c
``-R``.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
Each build step corresponds to a function in the corresponding ``subr/pkg_*.subr``
Lucio Andrés Illanes Albornoz a6970c
script and may be overriden entirely by a function named ``pkg_<package name>_<build step>()``
Lucio Andrés Illanes Albornoz a6970c
or composed in terms of prior and/or subsequent execution by a function named
Lucio Andrés Illanes Albornoz a6970c
``pkg_<package name>_<build step>_pre()`` and/or ``pkg_<package name>_<build step>_post()``,
Lucio Andrés Illanes Albornoz a6970c
respectively, in the package's ``vars`` file. If a function named ``pkg_<package name>_all()``
Lucio Andrés Illanes Albornoz a6970c
exists, it will override all build steps.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
Build step status is tracked on a per-package basis by state files beneath
Lucio Andrés Illanes Albornoz a6970c
``${BUILD_WORKDIR}`` following the format ``.<package name>.<build step>``;
Lucio Andrés Illanes Albornoz a6970c
package build completion corresponds to the pseudo-build step ``finish``.
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz b9a715
| Name                | Description                                                                                                                                                                                                           |
Lucio Andrés Illanes Albornoz b9a715
| ------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
Lucio Andrés Illanes Albornoz b9a715
| fetch_clean         | Delete and create ``${PKG_SUBDIR}''                                                                                                                                                                                   |
Lucio Andrés Illanes Albornoz b9a715
| fetch_download      | Download package archive & verify w/ SHA-256 message digest and/or clone Git repository/ies                                                                                                                           |
Lucio Andrés Illanes Albornoz b9a715
| fetch_extract       | Extract package archive, if any                                                                                                                                                                                       |
Lucio Andrés Illanes Albornoz b9a715
| configure_clean     | Delete and create ``${PKG_BUILD_DIR}''                                                                                                                                                                                |
Lucio Andrés Illanes Albornoz b9a715
| configure_patch_pre | Apply ``chainport`` patches and/or patches beneath ``patches/`` prior to (GNU autotools or similar) configuration                                                                                                     |
Lucio Andrés Illanes Albornoz b9a715
| configure_autotools | Bootstrap (GNU autools or similar) environment, and install ``config.sub`` and ``config.cache``                                                                                                                       |
Lucio Andrés Illanes Albornoz b9a715
| configure_patch     | Apply patches beneath ``patches/`` and/or set in ``${PKG_PATCHES_EXTRA}`` after (GNU autotools or similar) configuration                                                                                              |
Lucio Andrés Illanes Albornoz b9a715
| configure           | Perform package (GNU autools or similar or CMake) configuration w/ configuration-time set of environment variables                                                                                                    |
Lucio Andrés Illanes Albornoz b9a715
| build_clean         | Clean ``${PKG_BUILD_DIR}'' w/ ``make clean'' invocation                                                                                                                                                               |
Lucio Andrés Illanes Albornoz b9a715
| build               | Call ``make(1)`` w/ build-time set of make variables                                                                                                                                                                  |
Lucio Andrés Illanes Albornoz b9a715
| install_clean       | Delete and create ``${PKG_DESTDIR}''                                                                                                                                                                                  |
Lucio Andrés Illanes Albornoz b9a715
| install_subdirs     | Create default directory hierarchy in ``${PKG_DESTDIR}``, optionally amended w/ ``${PKG_INSTALL_FILES_DESTDIR_EXTRA}``                                                                                                |
Lucio Andrés Illanes Albornoz b9a715
| install_make        | Call ``make(1)`` w/ ``${PKG_INSTALL_TARGET}`` (defaults to ``install``) and installation-time set of make variables                                                                                                   |
Lucio Andrés Illanes Albornoz b9a715
| install_files       | Install ``${PKG_INSTALL_FILES}``, fix directory and file mode bits within ``${PKG_DESTDIR}`` and optionally ``${PKG_DESTDIR_HOST}``, ``pkgconf(1)`` package files, and/or stripped binaries within ``${PKG_DESTDIR}`` |
Lucio Andrés Illanes Albornoz b9a715
| install_libs        | Purge libtool ``.la`` files and install shared objects within ``${PKG_DESTDIR}`` w/ ``perk`` and corresponding symbolic links                                                                                         |
Lucio Andrés Illanes Albornoz b9a715
| install             | Install into ``${PKG_PREFIX}``, and optionally ``${PKG_DESTDIR_HOST}`` into ``${PREFIX}``, under mutex, and add package to ``${PREFIX}/pkglist.${PKG_BUILD_TYPE}`` (unless inhibited)                                 |
Lucio Andrés Illanes Albornoz b9a715
| install_rpm         | Build package RPM w/ auto-generated specifiation file based on ``etc/package.spec`` beneath ``${PREFIX_RPM}``                                                                                                         |
Lucio Andrés Illanes Albornoz b9a715
| clean               | Clean ``${PKG_BUILD_DIR}`` and/or ``${PKG_DESTDIR}`` and/or ``${PKG_DESTDIR_HOST}`` and/or ``${PKG_BASE_DIR}/${PKG_SUBDIR}`` as per ``-C build,dest,src``, resp., if any                                              |
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 4.2. Build variables"
Lucio Andrés Illanes Albornoz a99d13
## 4.2. Build variables
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
The following variables are primarily defined in ``midipix.env`` and may be
Lucio Andrés Illanes Albornoz a99d13
overriden on a per-build basis on the command-line, the environment, and/or
Lucio Andrés Illanes Albornoz a99d13
``${HOME}/midipix_build.vars``, ``${HOME}/.midipix_build.vars``, and/or
Lucio Andrés Illanes Albornoz a99d13
``../midipix_build.vars``, e.g.:
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
```shell
Lucio Andrés Illanes Albornoz a99d13
./build.sh -a nt64 -b release -D minipix,zipdist -P -v PREFIX_ROOT="${HOME}/midipix_tmp"
Lucio Andrés Illanes Albornoz a99d13
env ARCH=nt64 BUILD_KIND=release PREFIX_ROOT="${HOME}/midipix_tmp" ./build.sh -D minipix,zipdist -P -v
Lucio Andrés Illanes Albornoz a99d13
```
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
| Variable name    | Default value                        | Description                                                                   |
Lucio Andrés Illanes Albornoz a99d13
| ---------------- | ------------------------------------ | ----------------------------------------------------------------------------- |
Lucio Andrés Illanes Albornoz a99d13
| ARCH             | nt64                                 | Target 32-bit (nt32) or 64-bit (nt64) architecture                            |
Lucio Andrés Illanes Albornoz a99d13
| BUILD_DLCACHEDIR | ${PREFIX_ROOT}/dlcache               | Absolute pathname to package downloads cache root directory                   |
Lucio Andrés Illanes Albornoz a99d13
| BUILD_HNAME      | $(hostname)                          | Build system hostname                                                         |
Lucio Andrés Illanes Albornoz a99d13
| BUILD_KIND       | debug                                | Build w/ debugging (debug) or release compiler flags                          |
Lucio Andrés Illanes Albornoz a99d13
| BUILD_WORKDIR    | ${PREFIX}/tmp                        | Absolute pathname to temporary package build root directory                   |
Lucio Andrés Illanes Albornoz a99d13
| PREFIX           | ${PREFIX_ROOT}/${ARCH}/${BUILD_KIND} | Absolute pathname to architecture- & build type-specific build root directory |
Lucio Andrés Illanes Albornoz a99d13
| PREFIX_CROSS     | ${PREFIX}/${DEFAULT_TARGET}          | Absolute pathname to toolchain root directory                                 |
Lucio Andrés Illanes Albornoz a99d13
| PREFIX_MINGW32   | ${PREFIX}/x86_64-w64-mingw32         | Absolute pathname to MinGW toolchain root directory                           |
Lucio Andrés Illanes Albornoz a99d13
| PREFIX_MINIPIX   | ${PREFIX}/minipix                    | Absolute pathname to minipix distribution root directory                      |
Lucio Andrés Illanes Albornoz a99d13
| PREFIX_NATIVE    | ${PREFIX}/native                     | Absolute pathname to cross-compiled packages root directory                   |
Lucio Andrés Illanes Albornoz a99d13
| PREFIX_ROOT      | ${HOME}/midipix                      | Absolute pathname to top-level directory                                      |
Lucio Andrés Illanes Albornoz a99d13
| PREFIX_RPM       | ${PREFIX}/rpm                        | Absolute pathname to package RPM archive root directory                       |
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 4.3. Fault-tolerant & highly optimised 3D laser show-equipped usage screen"
Lucio Andrés Illanes Albornoz a99d13
## 4.3. Fault-tolerant & highly optimised 3D laser show-equipped usage screen
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
```
Lucio Andrés Illanes Albornoz a99d13
usage: ./build.sh [-a nt32|nt64]  [-b debug|release]    [-C dir[,..]]  [-D kind[,..]]
Lucio Andrés Illanes Albornoz a99d13
                  [-F ipv4|ipv6|offline]   [-h|--help] [-p jobs] [-P]   [-r ALL|LAST]
Lucio Andrés Illanes Albornoz a99d13
                  [-r [*[*[*]]]name[,..][:[^|<|<=|>|>=]step,..]] [-R] [-v[v[v]]] [-x]
Lucio Andrés Illanes Albornoz a99d13
                  [--as-needed]  [--debug-minipix] [--dump-on-abort]  [--reset-state]
Lucio Andrés Illanes Albornoz a99d13
                  [--roar]      [[=]<group>|<variable name>=<variable override>[ ..]]
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
        -a nt32|nt64      Selects 32-bit or 64-bit architecture; defaults to nt64.
Lucio Andrés Illanes Albornoz a99d13
        -b debug|release  Selects debug or release build kind; defaults to debug.
Lucio Andrés Illanes Albornoz a99d13
        -C dir[,..]       Clean build directory (build,) ${PREFIX} before processing build
Lucio Andrés Illanes Albornoz a99d13
                          scripts (prefix,) source directory (src,) and/or destination
Lucio Andrés Illanes Albornoz a99d13
                          directory (dest) after successful package builds.
Lucio Andrés Illanes Albornoz a99d13
        -D kind[,..]      Produce minimal midipix distribution directory (minipix,) RPM
Lucio Andrés Illanes Albornoz a99d13
                          binary packages (rpm,) and/or deployable distribution ZIP
Lucio Andrés Illanes Albornoz a99d13
                          archive (zipdist.) zipdist implies minipix.
Lucio Andrés Illanes Albornoz a99d13
        -F ipv4|ipv6|offline
Lucio Andrés Illanes Albornoz a99d13
                          Force IPv4 (ipv4) or IPv6 (ipv6) when downloading package
Lucio Andrés Illanes Albornoz a99d13
                          archives and/or Git repositories or don't download either at all
Lucio Andrés Illanes Albornoz a99d13
                          (offline.)
Lucio Andrés Illanes Albornoz a99d13
        -h|--help         Show short/full help screen, respectively.
Lucio Andrés Illanes Albornoz a99d13
        -p jobs           Enables parallelisation at group-level, whenever applicable.
Lucio Andrés Illanes Albornoz a99d13
        -P                The maximum count of jobs defaults to the number of logical
Lucio Andrés Illanes Albornoz a99d13
                          processors on the host system divided by two (2.)
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
                          If -R is not specified and at least one (1) package fails to
Lucio Andrés Illanes Albornoz a99d13
                          build, all remaining package builds will be forcibly aborted.
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
        -r ALL|LAST       Restart all packages or the last failed package and resume
Lucio Andrés Illanes Albornoz a99d13
                          build, resp.
Lucio Andrés Illanes Albornoz a99d13
        -r [*[*[*]]]name[,..][:ALL|LAST|[^|<|<=|>|>=]step,..]
Lucio Andrés Illanes Albornoz a99d13
                          Restart the specified comma-separated package(s) w/ inhibition
Lucio Andrés Illanes Albornoz a99d13
                          of package build step state resetting completely (`ALL',) starting
Lucio Andrés Illanes Albornoz a99d13
                          at the resp. last successfully executed build steps (`LAST',) or the
Lucio Andrés Illanes Albornoz a99d13
                          specified comma-separated list of build steps, optionally subject
Lucio Andrés Illanes Albornoz a99d13
                          concerning package name(s) and/or build step(s) to the below modifiers:
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
                          Prepend name w/ `*' to automatically include dependencies, `**'
Lucio Andrés Illanes Albornoz a99d13
                          to forcibly rebuild all dependencies, and `***` to forcibly
Lucio Andrés Illanes Albornoz a99d13
                          rebuild all packages that depend on the specified package(s).
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
                          Prepend step w/ `^' to filter build steps with, `<' or `<='
Lucio Andrés Illanes Albornoz a99d13
                          to constrain build steps to below or below or equal with, resp.,
Lucio Andrés Illanes Albornoz a99d13
                          `>' or `>=' to constrain build steps to above or above or equal
Lucio Andrés Illanes Albornoz a99d13
                          with, resp.
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
                          Currently defined build steps are:
Lucio Andrés Illanes Albornoz a99d13
                          fetch_clean, fetch_download, fetch_extract, configure_clean,
Lucio Andrés Illanes Albornoz a99d13
                          configure_patch_pre, configure_autotools, configure_patch,
Lucio Andrés Illanes Albornoz a99d13
                          configure, build_clean, build, install_clean, install_subdirs,
Lucio Andrés Illanes Albornoz a99d13
                          install_make, install_files, install_libs, install, install_rpm,
Lucio Andrés Illanes Albornoz a99d13
                          and clean.
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
                          Additionally, the following virtual steps are provided:
Lucio Andrés Illanes Albornoz a99d13
                          @fetch, @configure, @build, @install, @clean, and finish.
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
        -R                Ignore build failures, skip printing package logs, and continue
Lucio Andrés Illanes Albornoz a99d13
                          building (relaxed mode.)
Lucio Andrés Illanes Albornoz a99d13
        -v[v[v]]          Be verbose; -vv: always print package logs; -vvv: logs fileops.
Lucio Andrés Illanes Albornoz a99d13
        -x                Set xtrace during package builds.
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
        --as-needed       Don't build unless the midipix_build repository has received
Lucio Andrés Illanes Albornoz a99d13
                          new commits.
Lucio Andrés Illanes Albornoz a99d13
        --debug-minipix   Don't strip(1) minipix binaries to facilitate debugging minipix.
Lucio Andrés Illanes Albornoz a99d13
        --dump-on-abort   Produce package environment dump files on build failure to be
Lucio Andrés Illanes Albornoz a99d13
                          used in conjuction with pkg_shell.sh script (excludes -R.)
Lucio Andrés Illanes Albornoz a99d13
        --reset-state     Reset package build step state on exit.
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
        <group>[ ..]      One of: dev_packages, dist, host_deps, host_deps_rpm,
Lucio Andrés Illanes Albornoz a99d13
                          host_toolchain, host_tools, minipix, native_packages,
Lucio Andrés Illanes Albornoz a99d13
                          native_runtime, native_toolchain, native_tools.
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
                          Prepend w/ `=' to inhibit group-group dependency expansion.
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
        <variable name>=<variable override>[ ..]
Lucio Andrés Illanes Albornoz a99d13
                          Override build or package variable.
Lucio Andrés Illanes Albornoz a99d13
```
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 4.4. File installation DSL"
Lucio Andrés Illanes Albornoz a99d13
## 4.4. File installation DSL
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
File and directory installation, comprising e.g. copying, moving, creating
Lucio Andrés Illanes Albornoz a99d13
symbolic links, setting owner and/or permission metadata, are expressed in
Lucio Andrés Illanes Albornoz a99d13
a descriptive domain-specific language and integrated with package building
Lucio Andrés Illanes Albornoz a99d13
via the package variables ``${PKG_INSTALL_FILES}``, applying during ``install_files``
Lucio Andrés Illanes Albornoz a99d13
after the ``install_make`` build step,``${PKG_INSTALL_FILES_DESTDIR}`` and
Lucio Andrés Illanes Albornoz a99d13
``${PKG_INSTALL_FILES_DESTDIR_EXTRA}`` during ``install_subdirs`` with the
Lucio Andrés Illanes Albornoz a99d13
following syntax specified in EBNF:  
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
```
Lucio Andrés Illanes Albornoz a99d13
(*
Lucio Andrés Illanes Albornoz a99d13
SH_GLOB_PATTERN      = any valid portable shell pattern (see sh(1)); superset of PATHNAME
Lucio Andrés Illanes Albornoz a99d13
SH_SUBSTRING_PATTERN = any valid portable substring processing shell pattern (see sh(1));
Lucio Andrés Illanes Albornoz a99d13
                       superset of PATHNAME
Lucio Andrés Illanes Albornoz a99d13
PARAMETER            = any valid portable shell variable name except that [0-9] may occur
Lucio Andrés Illanes Albornoz a99d13
                       the beginning
Lucio Andrés Illanes Albornoz a99d13
PATHNAME             = any valid filename, directory name, relative or absolute pathname
Lucio Andrés Illanes Albornoz a99d13
                       excluding the characters NUL and NL
Lucio Andrés Illanes Albornoz a99d13
 *)
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
spec                 = { op_flag, } op_unary, "=", op_spec, "\n", { spec } ;
Lucio Andrés Illanes Albornoz a99d13
                     | { op_flag, } op_binary, op_spec, "=" op_spec, "\n", { spec } ;
Lucio Andrés Illanes Albornoz a99d13
                     | "#" COMMENT ;
Lucio Andrés Illanes Albornoz a99d13
op_unary             = "-" | "/" | "t" ;
Lucio Andrés Illanes Albornoz a99d13
op_binary            = ":" | "!" | "@" | "+" | "g" | "m" | "o" | "T" ;
Lucio Andrés Illanes Albornoz a99d13
op_flag              = "?" ;
Lucio Andrés Illanes Albornoz a99d13
op_spec              = pattern_spec | PATHNAME | expr_spec | op_spec ;
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
pattern_spec         = "%<", SH_GLOB_PATTERN, ">" ;
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
expr_spec            = "%[", expr, { sexpr_spec }, "%]" ;
Lucio Andrés Illanes Albornoz a99d13
expr                 = [ "@" ], "0" .. "9" | "DNAME" | "FNAME" | "ITEM" | PARAMETER ;
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
sexpr_spec           = sexpr_op_unary, SH_SUBSTRING_PATTERN, { sexpr } ;
Lucio Andrés Illanes Albornoz a99d13
sexpr_op_unary       = "##" | "#" | "%%" | "%" ;
Lucio Andrés Illanes Albornoz a99d13
```
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
Single ``"="`` characters in ``spec``, the ``"%<"`` and ``"%["`` character
Lucio Andrés Illanes Albornoz a99d13
sequences in ``pattern_spec`` and ``expr_spec``, resp., and the ``sexpr_op_unary``
Lucio Andrés Illanes Albornoz a99d13
as well as ``sexpr_op_binary`` characters or character sequences may be
Lucio Andrés Illanes Albornoz a99d13
escaped with a single backslash (``"\"``.) ``SH_SUBSTRING_PATTERN`` differs
Lucio Andrés Illanes Albornoz a99d13
from ``SH_GLOB_PATTERN`` solely in that any of ``sexpr_op_unary`` and
Lucio Andrés Illanes Albornoz a99d13
``sexpr_op_binary`` occuring at the beginning of or in the former must
Lucio Andrés Illanes Albornoz a99d13
be escaped with a single backslash (``"\"``,) e.g. ``"#\#pattern"`` and
Lucio Andrés Illanes Albornoz a99d13
``"%\%pattern"``, etc. and ``"#pat\%ern"`` and ``%patt\#ern", etc., resp.  
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
Named parameters (``PARAMETER``) are supplied via the ``-p name=value``
Lucio Andrés Illanes Albornoz a99d13
argument to ``rtl_install()``, whereas numbered parameters are for
Lucio Andrés Illanes Albornoz a99d13
internal usage only; the ``"DNAME"``, ``"FNAME"``, and ``"ITEM"`` parameters
Lucio Andrés Illanes Albornoz a99d13
lazily evaluate to the directory name, file (aka base) name, and full
Lucio Andrés Illanes Albornoz a99d13
pathname of the current item being processed relative to a specification
Lucio Andrés Illanes Albornoz a99d13
with a pattern in it.
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
The following parameters are defined by default during ``install_files``:
Lucio Andrés Illanes Albornoz a99d13
| Name           | Value                                  |
Lucio Andrés Illanes Albornoz a99d13
| -------------  | -------------------------------------- |
Lucio Andrés Illanes Albornoz a99d13
| _builddir      | ${PKG_BUILD_DIR}                       |
Lucio Andrés Illanes Albornoz a99d13
| _destdir       | ${PKG_BASE_DIR}/${PKG_DESTDIR}         |
Lucio Andrés Illanes Albornoz a99d13
| _destdir_host  | ${PKG_BASE_DIR}/${PKG_DESTDIR_HOST}    |
Lucio Andrés Illanes Albornoz a99d13
| _files         | ${MIDIPIX_BUILD_PWD}/files/${PKG_NAME} |
Lucio Andrés Illanes Albornoz a99d13
| _name          | ${PKG_NAME}                            |
Lucio Andrés Illanes Albornoz a99d13
| _prefix        | ${PKG_PREFIX}                          |
Lucio Andrés Illanes Albornoz a99d13
| _prefix_host   | ${PREFIX}                              |
Lucio Andrés Illanes Albornoz a99d13
| _prefix_native | ${PREFIX_NATIVE}                       |
Lucio Andrés Illanes Albornoz a99d13
| _subdir        | ${PKG_BASE_DIR}/${PKG_SUBDIR}          |
Lucio Andrés Illanes Albornoz a99d13
| _target        | ${PKG_TARGET}                          |
Lucio Andrés Illanes Albornoz a99d13
| _version       | ${PKG_VERSION:-}                       |
Lucio Andrés Illanes Albornoz a99d13
| _workdir       | ${BUILD_WORKDIR}                       |
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
The following operation flags are defined:
Lucio Andrés Illanes Albornoz a99d13
| Flag      | Description              |
Lucio Andrés Illanes Albornoz a99d13
| --------- | ------------------------ |
Lucio Andrés Illanes Albornoz a99d13
| ``?``     | Continue on soft failure |
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
The following operations are defined:
Lucio Andrés Illanes Albornoz a99d13
| Operation      | Arity  | Description                                                      |
Lucio Andrés Illanes Albornoz a99d13
| -------------- | ------ | ---------------------------------------------------------------- |
Lucio Andrés Illanes Albornoz a99d13
| ``-``          | Unary  | Remove directories and/or files                                  |
Lucio Andrés Illanes Albornoz a99d13
| ``/``          | Unary  | Create directories or trees thereof                              |
Lucio Andrés Illanes Albornoz a99d13
| ``t``          | Unary  | touch(1) files and/or directories                                |
Lucio Andrés Illanes Albornoz a99d13
| ``:''          | Binary | Copy directories and/or files                                    |
Lucio Andrés Illanes Albornoz a99d13
| ``!``          | Binary | Move/rename directories and/or files                             |
Lucio Andrés Illanes Albornoz a99d13
| ``@``          | Binary | Create/update symbolic links                                     |
Lucio Andrés Illanes Albornoz a99d13
| ``+``          | Binary | Copy directories and/or files if newer and follow symbolic links |
Lucio Andrés Illanes Albornoz a99d13
| ``g``          | Binary | Set group owner of files and/or directories                      |
Lucio Andrés Illanes Albornoz a99d13
| ``m``          | Binary | Set mode bits of files and/or directories                        |
Lucio Andrés Illanes Albornoz a99d13
| ``o``          | Binary | Set user and/or group owner of files and/or directories          |
Lucio Andrés Illanes Albornoz a99d13
| ``T``          | Binary | touch(1) files and/or directories with timestamp                 |
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
The following expression modifiers are defined:
Lucio Andrés Illanes Albornoz a99d13
| Modifier       | Description                               |
Lucio Andrés Illanes Albornoz a99d13
| -------------- | ----------------------------------------- |
Lucio Andrés Illanes Albornoz a99d13
| ``@``          | Recursively reevaluate after substituting |
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
The following subexpression operators are defined:
Lucio Andrés Illanes Albornoz a99d13
| Operation      | Arity  | Description                                                      |
Lucio Andrés Illanes Albornoz a99d13
| -------------- | ------ | ---------------------------------------------------------------- |
Lucio Andrés Illanes Albornoz a99d13
| ``##``         | Unary  | Remove largest prefix from left-hand side                        |
Lucio Andrés Illanes Albornoz a99d13
| ``#``          | Unary  | Remove prefix from left-hand side                                |
Lucio Andrés Illanes Albornoz a99d13
| ``%%``         | Unary  | Remove largest postfix from right-hand side                      |
Lucio Andrés Illanes Albornoz a99d13
| ``%``          | Unary  | Remove postfix from right-hand side                              |
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
```shell
Lucio Andrés Illanes Albornoz a99d13
#
Lucio Andrés Illanes Albornoz a99d13
# Examples:
Lucio Andrés Illanes Albornoz a99d13
# 
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
#
Lucio Andrés Illanes Albornoz a99d13
# Create directory %[_minipix]/bin and copy all files
Lucio Andrés Illanes Albornoz a99d13
# in %[_minipix_dist]/bin/ to %[_minipix]/bin/ with
Lucio Andrés Illanes Albornoz a99d13
# identical file names.
Lucio Andrés Illanes Albornoz a99d13
/=%[_minipix]/bin
Lucio Andrés Illanes Albornoz a99d13
?%[_minipix_dist]/bin/%<*>=%[_minipix]/bin/%[FNAME]
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
#
Lucio Andrés Illanes Albornoz a99d13
# Rename all files in share/info/ matching *.info to
Lucio Andrés Illanes Albornoz a99d13
# their filenames with the `.info' postfix removed and
Lucio Andrés Illanes Albornoz a99d13
# `-2.64.info' appended and all files in share/man/man1/
Lucio Andrés Illanes Albornoz a99d13
# matching *.1 with the `.1' postfix removed and -2.64.1
Lucio Andrés Illanes Albornoz a99d13
# appended.
Lucio Andrés Illanes Albornoz a99d13
!share/info/%<*.info>=share/info/%[FNAME%.info]-2.64.info
Lucio Andrés Illanes Albornoz a99d13
!share/man/man1/%<*.1>=share/man/man1/%[FNAME%.1]-2.64.1
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
#
Lucio Andrés Illanes Albornoz a99d13
# Create/update symbolic links named include/ffi.h and
Lucio Andrés Illanes Albornoz a99d13
# include/ffitarget.h with ../lib/libffi-3.2.1/include/ffi.h
Lucio Andrés Illanes Albornoz a99d13
# and ../lib/libffi-3.2.1/include/ffitarget.h as targets, resp.
Lucio Andrés Illanes Albornoz a99d13
@../lib/libffi-3.2.1/include/ffi.h=include/ffi.h
Lucio Andrés Illanes Albornoz a99d13
@../lib/libffi-3.2.1/include/ffitarget.h=include/ffitarget.h
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
#
Lucio Andrés Illanes Albornoz a99d13
# Manual invocation:
Lucio Andrés Illanes Albornoz a99d13
PKG_INSTALL_FILES="
Lucio Andrés Illanes Albornoz a99d13
        [ ... ]
Lucio Andrés Illanes Albornoz a99d13
";
Lucio Andrés Illanes Albornoz a99d13
rtl_install                                                     \
Lucio Andrés Illanes Albornoz a99d13
                -p "_builddir=${PKG_BASE_DIR}/${PKG_BUILD_DIR}" \
Lucio Andrés Illanes Albornoz a99d13
                -p "_minipix=${PREFIX_MINIPIX##*/}"             \
Lucio Andrés Illanes Albornoz a99d13
                -p "_minipix_dist=${PREFIX}/minipix_dist"       \
Lucio Andrés Illanes Albornoz a99d13
                -p "_native=${PREFIX_NATIVE##*/}"               \
Lucio Andrés Illanes Albornoz a99d13
                -p "_subdir=${PKG_BASE_DIR}/${PKG_SUBDIR}"      \
Lucio Andrés Illanes Albornoz a99d13
                -p "_target=${PKG_TARGET}"                      \
Lucio Andrés Illanes Albornoz a99d13
                -n -- "${PREFIX}"                               \
Lucio Andrés Illanes Albornoz a99d13
                "${PKG_INSTALL_FILES}"; then
Lucio Andrés Illanes Albornoz a99d13
        return 1;
Lucio Andrés Illanes Albornoz a99d13
fi;
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
#
Lucio Andrés Illanes Albornoz a99d13
# Usage screen:
Lucio Andrés Illanes Albornoz a99d13
usage: rtl_install [-i] [-I ifs] [-n] [-p name=val] [-v] prefix spec_list
Lucio Andrés Illanes Albornoz a99d13
       -i...........: continue on soft errors
Lucio Andrés Illanes Albornoz a99d13
       -I ifs.......: process spec_list with ifs instead of NL
Lucio Andrés Illanes Albornoz a99d13
       -n...........: perform dry run
Lucio Andrés Illanes Albornoz a99d13
       -p name=val..: set named parameter
Lucio Andrés Illanes Albornoz a99d13
       -v...........: increase verbosity
Lucio Andrés Illanes Albornoz a99d13
       prefix.......: pathname prefix
Lucio Andrés Illanes Albornoz a99d13
       spec_list....: ifs-separated list of specs
Lucio Andrés Illanes Albornoz a99d13
```
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 4.5. Package variables"
Lucio Andrés Illanes Albornoz a99d13
### 4.5. Package variables
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
The following variables are package-specific and receive their value from either
Lucio Andrés Illanes Albornoz a99d13
top-level defaults defined in ``midipix.env``, build group-specific defaults from the
Lucio Andrés Illanes Albornoz a99d13
build group the package pertains to and defined in its corresponding file beneath
Lucio Andrés Illanes Albornoz a99d13
``groups/``, or package-specific overrides defined either in the latter and/or in its
Lucio Andrés Illanes Albornoz a99d13
corresponding file beneath ``vars/``, with one of the following prefixes:
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
| Variable name prefix					|
Lucio Andrés Illanes Albornoz a99d13
| ----------------------------------------------------- |
Lucio Andrés Illanes Albornoz a99d13
| DEFAULT						|
Lucio Andrés Illanes Albornoz a99d13
| DEFAULT_``${BUILD_TYPE}``				|
Lucio Andrés Illanes Albornoz a99d13
| DEFAULT_``${GROUP_NAME}``				|
Lucio Andrés Illanes Albornoz a99d13
| ``${GROUP_NAME}``					|
Lucio Andrés Illanes Albornoz a99d13
| [PKG_``${RELATED_PACKAGE(S)}``]			|
Lucio Andrés Illanes Albornoz a99d13
| [PKG_``${RELATED_PACKAGE(S)}``_``${BUILD_KIND}``]	|
Lucio Andrés Illanes Albornoz a99d13
| PKG_``${NAME}``					|
Lucio Andrés Illanes Albornoz a99d13
| PKG_``${NAME}``_``${BUILD_KIND}``			|
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
Additionally, overrides may be specified on a per-build basis on the command-
Lucio Andrés Illanes Albornoz 685e16
line, with each variable prefixed w/ ``PKG_``, e.g.:
Lucio Andrés Illanes Albornoz a6970c
``./build.sh [ ... ] PKG_ZSH_CC="/usr/bin/clang"``.  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
The minimum set of package variables that must be provided is ``SHA256SUM, URL,
Lucio Andrés Illanes Albornoz a6970c
VERSION`` and/or ``URLS_GIT``, respectively.
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 4.5.1 Package variable types"
Lucio Andrés Illanes Albornoz a99d13
## 4.5.1 Package variable types
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
| Type definition               | Description                                                                                                                                  |
Lucio Andrés Illanes Albornoz a99d13
| ----------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------- |
Lucio Andrés Illanes Albornoz a99d13
| DirName(Abs)			| Absolute pathname to directory                                                                                                               |
Lucio Andrés Illanes Albornoz a99d13
| DirName(Rel)			| Relative pathname to director                                                                                                                |
Lucio Andrés Illanes Albornoz a99d13
| DirName(Unit)			| Single non-{absolute,relative} directory nam                                                                                                 |
Lucio Andrés Illanes Albornoz a99d13
| DirName			| Absolute or relative pathname to director                                                                                                    |
Lucio Andrés Illanes Albornoz a99d13
| CmdName			| Absolute or relative pathname to comman                                                                                                      |
Lucio Andrés Illanes Albornoz a99d13
| FileName(Abs)			| Absolute pathname to file                                                                                                                    |
Lucio Andrés Illanes Albornoz a99d13
| FileName(Rel)			| Relative pathname to file                                                                                                                    |
Lucio Andrés Illanes Albornoz a99d13
| FileName(Unit)		| Single non-{absolute,relative} file name                                                                                                     |
Lucio Andrés Illanes Albornoz a99d13
| FileName			| Absolute or relative pathname to file                                                                                                        |
Lucio Andrés Illanes Albornoz a99d13
| Flag(<type>,<default>)	| Boolean flag of type <type>, e.g. Flag(Boolean) (``true``, ``false``,) Flag(UInt) (0, 1,) Flag(ExitStatus) (>=1, 0) with default or ``auto`` |
Lucio Andrés Illanes Albornoz a99d13
| FlagLine			| String of {SP,VT}-separated flags, arguments, options, etc. pp. to a command                                                                 |
Lucio Andrés Illanes Albornoz a99d13
| List(<sep>[,<sep|type>..])	| <sep>-separated list, optionally recursively and/or sub-typing, e.g.: ``List(:,=,String)`` and ``"name=value:name2=va lue "``                |
Lucio Andrés Illanes Albornoz a99d13
| PkgName			| Single name of package                                                                                                                       |
Lucio Andrés Illanes Albornoz a99d13
| PkgRelation			| Single, possibly parametrised, package-package relation; see section [3.6](#36-package-package-and-packagegroup-group-relationships)        |
Lucio Andrés Illanes Albornoz a99d13
| PkgVersion			| Single version of package                                                                                                                    |
Lucio Andrés Illanes Albornoz a99d13
| Set(<type>)			| Set of alternatives of <type>, e.g. one of ``cross``, ``host``, ``native``                                                                   |
Lucio Andrés Illanes Albornoz a99d13
| String			| Semantically generic string                                                                                                                  |
Lucio Andrés Illanes Albornoz a99d13
| URL				| URL in standard format; see section [3.4](#34-package-archive-files-and-git-repositories)                                                    |
Lucio Andrés Illanes Albornoz a99d13
| URL(Git)			| Git URL in the format ``[subdir=]URL[@branch]``; see section [3.4](#34-package-archive-files-and-git-repositories)                           |
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
<sup id="fn42101">
Lucio Andrés Illanes Albornoz a99d13
4.2.1:1 
Lucio Andrés Illanes Albornoz a99d13
</sup>
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 4.5.2 Package variables"
Lucio Andrés Illanes Albornoz a99d13
## 4.5.2 Package variables
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
| Package variable name        | Type             | Description                                                                                                                                |
Lucio Andrés Illanes Albornoz a99d13
| ---------------------------- | ---------------- | ------------------------------------------------------------------------------------------------------------------------------------------ |
Lucio Andrés Illanes Albornoz a99d13
| AR                           | CmdName          | Toolchain library archive editor ``ar(1)``                                                                                                 |
Lucio Andrés Illanes Albornoz a99d13
| BASE_DIR                     | DirName(Abs)     | Package build root directory beneath ``${BUILD_WORKDIR}``                                                                                  |
Lucio Andrés Illanes Albornoz a99d13
| BUILD_DIR                    | DirName(Unit)    | Package build directory beneath ``${PKG_BASE_DIR}``                                                                                        |
Lucio Andrés Illanes Albornoz a99d13
| BUILD_STAGES_DISABLE         | List( )          | Build stages to disable during package build                                                                                               |
Lucio Andrés Illanes Albornoz a99d13
| BUILD_TYPE                   | Set(String)      | ``cross``: Cross-compiled toolchain, ``host``: host, ``native``: cross-compiled package                                                    |
Lucio Andrés Illanes Albornoz a99d13
| CC                           | FileName         | Toolchain C compiler ``cc(1)``                                                                                                             |
Lucio Andrés Illanes Albornoz a99d13
| CFLAGS_BUILD_EXTRA           | FlagLine         | Additional C compiler flags during package ``make(1)``  build                                                                              |
Lucio Andrés Illanes Albornoz a99d13
| CFLAGS_BUILD                 | FlagLine         | C compiler flags during package ``make(1)``  build                                                                                         |
Lucio Andrés Illanes Albornoz a99d13
| CFLAGS_CONFIGURE_EXTRA       | FlagLine         | Additional C compiler flags during package (GNU autotools in implementation and/or interface) configuration                                |
Lucio Andrés Illanes Albornoz a99d13
| CFLAGS_CONFIGURE             | FlagLine         | C compiler flags during package (GNU autotools in implementation and/or interface) configuration                                           |
Lucio Andrés Illanes Albornoz a99d13
| CMAKE_ARGS_EXTRA             | FlagLine         | Additional arguments to ``cmake(1)``                                                                                                       |
Lucio Andrés Illanes Albornoz a99d13
| CMAKE_ARGS                   | FlagLine         | Arguments to ``cmake(1)``                                                                                                                  |
Lucio Andrés Illanes Albornoz a99d13
| CMAKE                        | CmdName          | ``cmake(1)`` executable                                                                                                                    |
Lucio Andrés Illanes Albornoz a99d13
| CMAKE_LISTFILE               | FileName         | ``cmake(1)`` listfile                                                                                                                      |
Lucio Andrés Illanes Albornoz a99d13
| CONFIG_CACHE_EXTRA           | List(\n)         | Additional GNU autotools configuration cache variables                                                                                     |
Lucio Andrés Illanes Albornoz a99d13
| CONFIG_CACHE                 | List(\n)         | GNU autotools configuration cache variables                                                                                                |
Lucio Andrés Illanes Albornoz a99d13
| CONFIG_CACHE_LOCAL           | List(\n)         | Additional GNU autotools configuration cache variables                                                                                     |
Lucio Andrés Illanes Albornoz a99d13
| CONFIGURE_ARGS_EXTRA         | FlagLine         | Additional arguments to package (GNU autotools in implementation and/or interface) configuration script                                    |
Lucio Andrés Illanes Albornoz a99d13
| CONFIGURE_ARGS               | FlagLine         | Arguments to package (GNU autotools in implementation and/or interface) configuration script                                               |
Lucio Andrés Illanes Albornoz a99d13
| CONFIGURE                    | CmdName          | Package's (GNU autotools in implementation and/or interface) configuration script                                                          |
Lucio Andrés Illanes Albornoz a99d13
| CONFIGURE_TYPE               | String           | Either of ``autotools`` (GNU autotools or similar) or ``sofort`` or ``cmake`` (CMake)                                                      |
Lucio Andrés Illanes Albornoz a99d13
| CXX                          | CmdName          | Toolchain C++ compiler ``c++(1)``                                                                                                          |
Lucio Andrés Illanes Albornoz a99d13
| CXXFLAGS_CONFIGURE_EXTRA     | FlagLine         | Additional C++ compiler flags during package (GNU autotools in implementation and/or interface) configuration                              |
Lucio Andrés Illanes Albornoz a99d13
| CXXFLAGS_CONFIGURE           | FlagLine         | C++ compiler flags during package (GNU autotools in implementation and/or interface) configuration                                         |
Lucio Andrés Illanes Albornoz a99d13
| DEPENDS                      | List( )          | Mandatory package-package dependencies                                                                                                     |
Lucio Andrés Illanes Albornoz a99d13
| DESTDIR                      | DirName(Unit)    | Package installation destination directory beneath ``${PKG_BASE_DIR}``                                                                     |
Lucio Andrés Illanes Albornoz a99d13
| DESTDIR_HOST                 | DirName(Unit)    | Optional host package installation destination directory beneath ``${PKG_BASE_DIR}``                                                       |
Lucio Andrés Illanes Albornoz a99d13
| DISABLED                     | Flag(UInt,0)     | Disable package                                                                                                                            |
Lucio Andrés Illanes Albornoz a99d13
| ENV_VARS_EXTRA               | List(:,=)        | Name-value pairs of environment variables to set during package build                                                                      |
Lucio Andrés Illanes Albornoz a99d13
| FNAME                        | FileName(Unit)   | Filename of package archive file                                                                                                           |
Lucio Andrés Illanes Albornoz a99d13
| FORCE_AUTORECONF             | Flag(UInt,0)     | Forcibly run ``autoreconf -fiv`` prior to package (GNU autotools in implementation and/or interface) configuration                         |
Lucio Andrés Illanes Albornoz a99d13
| GITROOT                      | URL              | midipix packages Git URL prefix                                                                                                            |
Lucio Andrés Illanes Albornoz a99d13
| INHERIT_FROM                 | String           | Inherit variables from named package                                                                                                       |
Lucio Andrés Illanes Albornoz a99d13
| INSTALL_FILES_DESTDIR_EXTRA  | List( )          | Additional files to initialise the package installation destination directory beneath ``${PKG_BASE_DIR}`` with                             |
Lucio Andrés Illanes Albornoz a99d13
| INSTALL_FILES_DESTDIR        | List( )          | Files to initialise the package installation destination directory beneath ``${PKG_BASE_DIR}`` with                                        |
Lucio Andrés Illanes Albornoz a99d13
| INSTALL_FILES                | List( )          | Files to manually install into the package installation destination directory beneath ``${PKG_BASE_DIR}``                                  |
Lucio Andrés Illanes Albornoz a99d13
| INSTALL_TARGET_EXTRA         | String           | Additional name of package build ``make(1)`` installation target                                                                           |
Lucio Andrés Illanes Albornoz a99d13
| INSTALL_TARGET               | String           | Name of package build ``make(1)`` installation target                                                                                      |
Lucio Andrés Illanes Albornoz a99d13
| IN_TREE                      | Flag(UInt,auto)  | Build package in-tree within ``${PKG_SUBDIR}``                                                                                             |
Lucio Andrés Illanes Albornoz a99d13
| LDFLAGS_BUILD_EXTRA          | FlagLine         | Additional linker flags during package ``make(1)``  build                                                                                  |
Lucio Andrés Illanes Albornoz a99d13
| LDFLAGS_CONFIGURE_EXTRA      | FlagLine         | Additional linker flags during package (GNU autotools in implementation and/or interface) configuration                                    |
Lucio Andrés Illanes Albornoz a99d13
| LDFLAGS_CONFIGURE            | FlagLine         | Linker flags during package (GNU autotools in implementation and/or interface) configuration                                               |
Lucio Andrés Illanes Albornoz a99d13
| LIBTOOL                      | CmdName          | ``libtool(1)`` implementation (defaults to ``slibtool``)                                                                                   |
Lucio Andrés Illanes Albornoz a99d13
| MAKE                         | CmdLine          | Command line of ``make(1)``                                                                                                                |
Lucio Andrés Illanes Albornoz a99d13
| MAKEFLAGS_BUILD_EXTRA        | FlagLine         | Additional ``make(1)`` flags during package ``make(1)``  build                                                                             |
Lucio Andrés Illanes Albornoz a99d13
| MAKEFLAGS_BUILD              | FlagLine         | ``make(1)`` flags during package ``make(1)``  build                                                                                        |
Lucio Andrés Illanes Albornoz a99d13
| MAKEFLAGS_INSTALL_EXTRA      | FlagLine         | ``make(1)`` flags during package ``make(1)``  installation                                                                                 |
Lucio Andrés Illanes Albornoz a99d13
| MAKEFLAGS_INSTALL            | FlagLine         | ``make(1)`` flags during package ``make(1)``  installation                                                                                 |
Lucio Andrés Illanes Albornoz a99d13
| MAKEFLAGS_VERBOSITY          | String           | Variable-value pair to pass to ``make(1)`` in order to force echo-back of command lines prior to execution                                 |
Lucio Andrés Illanes Albornoz a99d13
| MAKE_INSTALL_VNAME           | String           | Variable name of ``make(1)`` installation destination directory variable during package ``make(1)``  installation                          |
Lucio Andrés Illanes Albornoz a99d13
| MAKE_SUBDIRS                 | List( )          | ``make(1)`` subdirectories to exclusively build                                                                                            |
Lucio Andrés Illanes Albornoz a99d13
| MIRRORS_GIT                  | List( )          | Package Git repository mirror base URLs to attempt cloning from; cf. ``pkgtool.sh -m <dname>``                                             |
Lucio Andrés Illanes Albornoz a99d13
| MIRRORS                      | List( )          | Package archive mirror base URLs to attempt downloading from; cf. ``pkgtool.sh -m <dname>``                                                |
Lucio Andrés Illanes Albornoz a99d13
| NO_CLEAN_BASE_DIR            | Flag(UInt,0)     | Inhibit cleaning of package build root directory beneath ``${BUILD_WORKDIR}``                                                              |
Lucio Andrés Illanes Albornoz a99d13
| NO_CLEAN                     | Flag(UInt,0)     | Inhibit cleaning of package build directory beneath ``${PKG_BASE_DIR}`` pre-finish                                                         |
Lucio Andrés Illanes Albornoz a99d13
| NO_LOG_VARS                  | Flag(UInt,0)     | Inhibit logging of build & package variables pre-package build                                                                             |
Lucio Andrés Illanes Albornoz a99d13
| PATCHES_EXTRA                | List( )          | Additional patches to apply                                                                                                                |
Lucio Andrés Illanes Albornoz a99d13
| PKG_CONFIG                   | CmdName          | ``pkg-config(1)`` implementation                                                                                                           |
Lucio Andrés Illanes Albornoz a99d13
| PKG_CONFIG_LIBDIR            | DirName          | ``pkg-config(1)`` search directory                                                                                                         |
Lucio Andrés Illanes Albornoz a99d13
| PKGLIST_DISABLE              | Flag(UInt,0)     | Inhibit inclusion into ``${PREFIX}/pkglist.${PKG_BUILD_TYPE}``                                                                             |
Lucio Andrés Illanes Albornoz a99d13
| PREFIX                       | DirName(Abs)     | Top-level installation directory and package search path                                                                                   |
Lucio Andrés Illanes Albornoz a99d13
| PYTHON                       | CmdName          | Python >=3.x interpreter                                                                                                                   |
Lucio Andrés Illanes Albornoz a99d13
| RANLIB                       | CmdName          | Toolchain library archive index generator ``ranlib(1)``                                                                                    |
Lucio Andrés Illanes Albornoz a99d13
| RELATES                      | Set(PkgRelation) | Package-package relationships                                                                                                              |
Lucio Andrés Illanes Albornoz a99d13
| RPM_DISABLE                  | Flag(UInt,0)     | Inhibit creation of RPM archive                                                                                                            |
Lucio Andrés Illanes Albornoz a99d13
| SHA256SUM                    | String           | SHA-256 message digest of package archive                                                                                                  |
Lucio Andrés Illanes Albornoz a99d13
| SOFORT_NATIVE_CC             | FileName         | ``sofort`` variable during ``native`` build: Toolchain C compiler ``cc(1)``                                                                |
Lucio Andrés Illanes Albornoz a99d13
| SOFORT_NATIVE_CFLAGS_EXTRA   | FlagLine         | ``sofort`` variable during ``native`` build: Additional C compiler flags during package (GNU autotools or similar) configuration           |
Lucio Andrés Illanes Albornoz a99d13
| SOFORT_NATIVE_CFLAGS         | FlagLine         | ``sofort`` variable during ``native`` build: C compiler flags during package (GNU autotools or similar) configuration                      |
Lucio Andrés Illanes Albornoz a99d13
| SOFORT_NATIVE_CXXFLAGS_EXTRA | FlagLine         | ``sofort`` variable during ``native`` build: Additional list of C++ compiler flags during package (GNU autotools or similar) configuration |
Lucio Andrés Illanes Albornoz a99d13
| SOFORT_NATIVE_CXXFLAGS       | FlagLine         | ``sofort`` variable during ``native`` build: List of C++ compiler flags during package (GNU autotools or similar) configuration            |
Lucio Andrés Illanes Albornoz a99d13
| SOFORT_NATIVE_CXX            | FlagLine         | ``sofort`` variable during ``native`` build: Command- or pathname of toolchain C++ compiler ``c++(1)``                                     |
Lucio Andrés Illanes Albornoz a99d13
| SOFORT_NATIVE_LDFLAGS_EXTRA  | FlagLine         | ``sofort`` variable during ``native`` build: Additional linker flags during package (GNU autotools or similar) configuration               |
Lucio Andrés Illanes Albornoz a99d13
| SOFORT_NATIVE_LDFLAGS        | FlagLine         | ``sofort`` variable during ``native`` build: Linker flags during package (GNU autotools or similar) configuration                          |
Lucio Andrés Illanes Albornoz a99d13
| SOFORT_NATIVE_LD             | FileName         | ``sofort`` variable during ``native`` build: Command- or pathname of toolchain C compiler ``cc(1)``                                        |
Lucio Andrés Illanes Albornoz a99d13
| SUBDIR                       | DirName(Rel)     | Extracted archive or git-{clone,pull}(1)'d directory                                                                                       |
Lucio Andrés Illanes Albornoz a99d13
| TARGET                       | String           | Dash-separated {build,host,target} triplet                                                                                                 |
Lucio Andrés Illanes Albornoz a99d13
| URL                          | List( ,URL)      | URL to package archives w/ optional alternatives; see section [3.4](#34-package-archive-files-and-git-repositories)                        |
Lucio Andrés Illanes Albornoz a99d13
| URLS_GIT                     | List( ,URL(Git)) | Package Git URL(s) (format: ``[subdir=]URL[@branch]``, see section [3.4](#34-package-archive-files-and-git-repositories))                  |
Lucio Andrés Illanes Albornoz a99d13
| VARS_FILE                    | FileName         | Optional package variables file (defaults to ``vars/${PKG_NAME}.vars``)                                                                    |
Lucio Andrés Illanes Albornoz a99d13
| VERSION                      | PkgVersion       | Package version                                                                                                                            |
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a99d13
[//]: # "{{{ 4.6. ``pkgtool.sh``"
Lucio Andrés Illanes Albornoz a99d13
## 4.6. ``pkgtool.sh``
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
```
Lucio Andrés Illanes Albornoz a99d13
usage: ./pkgtool.sh [-a nt32|nt64] [-b debug|release] [-i|-m <dname> -M <dname>|-r|-s|-t] [-v]
Lucio Andrés Illanes Albornoz a99d13
                    [<variable name>=<variable override>[ ..]] name
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
        -a nt32|nt64          Selects 32-bit or 64-bit architecture; defaults to nt64.
Lucio Andrés Illanes Albornoz a99d13
        -b debug|release      Selects debug or release build kind; defaults to debug.
Lucio Andrés Illanes Albornoz a99d13
        -i                    List package variables and dependencies of single named package.
Lucio Andrés Illanes Albornoz a99d13
        -m <dname>            Setup package archives mirror in <dname> and/or
Lucio Andrés Illanes Albornoz a99d13
        -M <dname>            Setup Git repositories mirror in <dname>
Lucio Andrés Illanes Albornoz a99d13
        -r                    List reverse dependencies of single named package.
Lucio Andrés Illanes Albornoz a99d13
        -s                    Enter interactive package build shell environment for single
Lucio Andrés Illanes Albornoz a99d13
                              named package; requires a package dump file. If the package
Lucio Andrés Illanes Albornoz a99d13
                              has not been built yet or built successfully, it will be rebuilt
Lucio Andrés Illanes Albornoz a99d13
                              at build steps up until, by default, the `build' build step and
Lucio Andrés Illanes Albornoz a99d13
                              forcibly aborted and dumped prior to enterting the shell.
Lucio Andrés Illanes Albornoz a99d13
        -t                    Produce tarball of package build root directory and build log
Lucio Andrés Illanes Albornoz a99d13
                              file for the purpose of distribution given build failure.
Lucio Andrés Illanes Albornoz a99d13
        -v                    Increase verbosity.
Lucio Andrés Illanes Albornoz a99d13
Lucio Andrés Illanes Albornoz a99d13
        <variable name>=<variable override>[ ..]
Lucio Andrés Illanes Albornoz a99d13
                              Override build variable.
Lucio Andrés Illanes Albornoz a99d13
```
Lucio Andrés Illanes Albornoz a99d13
  
Lucio Andrés Illanes Albornoz a99d13
> N.B. When using ``pkgtool.sh`` on a build w/ build variables (see section [4.2](#42-build-variables))
Lucio Andrés Illanes Albornoz a99d13
overriden on the command line or via the environment, ensure that they are included in the
Lucio Andrés Illanes Albornoz a99d13
``pkgtool.sh`` command line, preceding the package name, or exported, respectively.
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "{{{ 5. References"
Lucio Andrés Illanes Albornoz a6970c
## 5. References
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
* ``Sun, 25 Apr 2016 09:04:08 +0000 [1]`` musl FAQ  
Lucio Andrés Illanes Albornoz a6970c
* ``Wed, 04 Mar 2020 13:36:19 +0000 [2]`` midipix - what is midipix, and how is it different?  
Lucio Andrés Illanes Albornoz 6bc7e5
* ``Wed, 29 Apr 2020 23:33:34 +0100 [3]`` User Rights Assignment (Windows 10) - Windows security | Microsoft Docs  
Lucio Andrés Illanes Albornoz 6bc7e5
* ``Wed, 29 Apr 2020 23:33:50 +0100 [4]`` Windows Vista Application Development Requirements for User Account Control Compatibility | Microsoft Docs  
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[Back to top](#table-of-contents)
Lucio Andrés Illanes Albornoz a6970c
Lucio Andrés Illanes Albornoz a6970c
[//]: # "}}}"
Lucio Andrés Illanes Albornoz a6970c
  
Lucio Andrés Illanes Albornoz a6970c
[modeline]: # ( vim: set tw=0: )