NAME
alpm-install-scriptlet – a custom install script for ALPM based packages.
DESCRIPTION
An optional shell script that defines custom actions to be performed during the installation, upgrade, or removal of a package.
The shell functions are executed in the root (/
) of the system, so all paths inside of it must be absolute.
Such files are located at the root of ALPM packages and are named .INSTALL.
General Format
An alpm-install-scriptlet may contain zero or more specific shell functions that define actions for different package lifecycle events. All of the functions are optional and only those necessary for a given package may be included.
The script may be written in a shell language that supports the -c
commandline option and calling named functions with additional arguments from the interpreter's commandline interface.
Note that the shell interpreter used by package management software to run the script is defined globally (e.g. per distribution). No shebang is used in the script and the decision on which shell to use for running it is not based on a package's metadata, but instead typically set at the distribution or system level. This implies that the shell interpreter cannot be changed on a per-package basis.
Functions
The available functions are listed below. They accept one or two arguments which are package versions, provided as alpm-package-version.
pre_install
Executed before a package is installed, with the new package version as its argument.
post_install
Executed after a package is installed, with the new package version as its argument.
pre_upgrade
Executed before a package is upgraded, with the following arguments:
- New package version
- Old package version
post_upgrade
Executed after a package is upgraded, with the following arguments:
- New package version
- Old package version
pre_remove
Executed before a package is removed, with the old package version as its argument.
post_remove
Executed after a package is removed, with the old package version as its argument.
EXAMPLES
Example of specifying an install script in the PKGBUILD file:
install=example.install
Example of a basic example.install script:
pre_install() {
echo "Preparing to install package version $1"
}
post_install() {
echo "Package version $1 installed"
}
pre_upgrade() {
echo "Preparing to upgrade from version $2 to $1"
}
post_upgrade() {
echo "Upgraded from version $2 to $1"
}
pre_remove() {
echo "Preparing to remove package version $1"
}
post_remove() {
echo "Package version $1 removed"
}
SEE ALSO
bash(1), sh(1), PKGBUILD(5), alpm-package-version(7), pacman(8), makepkg(8)