Scroll to navigation

dpt-lib.sh(5) Debian Perl packaging Tools dpt-lib.sh(5)

NAME

dpt-lib.sh - dpt shell library

DESCRIPTION

dpt-lib.sh is sourced by dpt(1) and contains a collection of shell functions and variables which can be used by dpt subcommands written in shell. As a side effect, it also sanity checks if the script is run from a source package directory with a .git/ sub directory.

USAGE

Source the file at the beginning of the shell script as

    . "${DPT__SCRIPTS:-/usr/share/pkg-perl-tools}/lib/dpt-lib.sh"

AVAILABLE FUNCTIONS

"die"
Parameters: $message

Echos "E: $message" to STDERR and exits 1.

"warn"
Parameters: $message

Echos "W: $message" to STDERR.

"info"
Parameters: $message

Echos "I: $message" to STDERR.

"header"
Parameters: $title

Outputs $title with an empty line before and underlined, kind of like a header.

"anykey"
Tells the user to press any key and waits for a keypress.
"promptyesno"
Parameters: $prompt

Issues a read() request with y/N options, printing $prompt. Returns true, if 'y' or 'Y' is pressed, false otherwise.

"is_command"
Parameters: $command, $package (optional)

Checks if $command can be executed (running "command -v"); returns false, outputs a warning (and optionally a hint to install $package).

"is_installed"
Parameters: $package_name, $minimum_package_version (optional)

Checks if $package_name is installed, optionally at $minimum_package_version, and returns false with a warning otherwise.

"is_pkg_perl"
Checks if debian/control contains the Debian Perl Group email address.
"gitddiff"
Offers to show the diff against the last debian/ tag, if there is any.
"colored"
Parameters: $color, $text

Outputs $text in $color, unless the NO_COLOR environment variable is set.

Available colors are (in capital letters): "BLACK", "RED", "GREEN", "YELLOW", "BLUE", "MAGENTA", "CYAN", "WHITE".

"extra_colored"
Parameters: $color, $bgcolor, $text

Outputs $text in foreground $color on $bgcolor, unless the NO_COLOR environment variable is set.

Available colors for both foreground and background are (in capital letters): "BLACK", "RED", "GREEN", "YELLOW", "BLUE", "MAGENTA", "CYAN", "WHITE".

AVAILABLE VARIABLES

"PKG"
Source package name, from debian/changelog.
"VER"
Source package version, from debian/changelog.
"UVER"
Upstream version, i.e. source package version (from debian/changelog) without epoch and Debian revision.
"DIST"
Source package distribution, from debian/changelog.
Cf. the colored() function above.

For using colors directly, the following variables exist;

"C_BLACK", "C_RED", "C_GREEN", "C_YELLOW", "C_BLUE", "C_MAGENTA", "C_CYAN", "C_WHITE", plus "C_RESET" to go back from coloring.

For background colors, the same colors exist as "BG_C_foo".

ENVIRONMENT VARIABLES

"OOT"
OOT (as in "out-of-tree"), if set, disables the check if a script is run in a source package directory and a Git repository.

Can be used as

    OOT=1 . "${DPT__SCRIPTS:-/usr/share/pkg-perl-tools}/lib/dpt-lib.sh"
    

and is useful for scripts which are run on build results etc.

This also means that the variables derived from debian/changelog are not available.

SEE ALSO

dpt-config(5) for discussion of "$DPT__SCRIPTS".

COPYRIGHT & LICENSE

Copyright 2022-2024 gregor herrmann gregoa@debian.org

Copyright 2022 Damyan Ivanov dmn@debian.org

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

2024-11-09 pkg-perl-tools 0.80