diff options
| author | EuAndreh <eu@euandre.org> | 2022-11-17 17:58:41 -0300 |
|---|---|---|
| committer | EuAndreh <eu@euandre.org> | 2022-11-17 17:58:41 -0300 |
| commit | 62ca1a97e0848ef5f9043da69c6af8a9b0bb9808 (patch) | |
| tree | 9fa23a49cf205c7162a3604418775cbc798ee3c7 /bin/pre | |
| parent | Initial empty commit (diff) | |
| parent | opt/bin-dirs/clisp: Include custom build of CLISP (diff) | |
| download | dotfiles-62ca1a97e0848ef5f9043da69c6af8a9b0bb9808.tar.gz dotfiles-62ca1a97e0848ef5f9043da69c6af8a9b0bb9808.tar.xz | |
Merge remote-tracking branch 'tilde/main'
Diffstat (limited to 'bin/pre')
| -rwxr-xr-x | bin/pre | 78 |
1 files changed, 78 insertions, 0 deletions
@@ -0,0 +1,78 @@ +#!/bin/sh +set -eu + +usage() { + cat <<-'EOF' + Usage: + pre [-c COLOR] PREFIX + pre -h + EOF +} + +help() { + cat <<-'EOF' + + Options: + -c COLOR ANSI color to be used on the prefix text + -h, --help show this message + + Prefix STDIN with PREFIX. + + + Examples: + + Prefix with 'database': + + $ ./run-db.sh | pre 'database' + + + Prefix with yellow 'numbers': + + $ seq 10 | pre -c yellow numbers + EOF +} + +for flag in "$@"; do + case "$flag" in + --) + break + ;; + --help) + usage + help + exit + ;; + *) + ;; + esac +done + +COLOR='' +while getopts 'c:h' flag; do + case "$flag" in + c) + COLOR="$OPTARG" + ;; + h) + usage + help + exit + ;; + *) + usage >&2 + exit 2 + ;; + esac +done +shift $((OPTIND - 1)) + +PREFIX="${1:-}" +eval "$(assert-arg "$PREFIX" 'PREFIX')" + +while read -r line; do + if [ -z "$COLOR" ]; then + printf '%s: %s\n' "$PREFIX" "$line" + else + printf '%s: %s\n' "$(color -c "$COLOR" "$PREFIX")" "$line" + fi +done |
