pure-bash-bible/README.md

83 lines
1.5 KiB
Markdown
Raw Normal View History

2018-06-13 03:43:02 +02:00
# PURE BASH
<!-- vim-markdown-toc GFM -->
* [Getting the terminal size (*in a script*).](#getting-the-terminal-size-in-a-script)
* [Convert a hex color to RGB](#convert-a-hex-color-to-rgb)
* [Convert an RGB color to hex.](#convert-an-rgb-color-to-hex)
* [`printf` as a `date` replacement.](#printf-as-a-date-replacement)
* [`dirname`](#dirname)
<!-- vim-markdown-toc -->
2018-06-13 03:39:17 +02:00
### Getting the terminal size (*in a script*).
This is handy when writing scripts in pure bash and `stty`/`tput` cant be
called.
2018-06-13 03:42:18 +02:00
```sh
2018-06-13 03:39:17 +02:00
get_term_size() {
# Usage: get_term_size
# (:;:) is a micro sleep to ensure the variables are
# exported immediately.
shopt -s checkwinsize; (:;:)
printf '%s\n' "$LINES $COLUMNS"
}
```
### Convert a hex color to RGB
2018-06-13 03:42:18 +02:00
```sh
2018-06-13 03:39:17 +02:00
hex_to_rgb() {
# Usage: hex_to_rgb "#FFFFFF"
((r=16#${1:1:2}))
((g=16#${1:3:2}))
((b=16#${1:5:6}))
printf '%s\n' "$r $g $b"
}
```
### Convert an RGB color to hex.
2018-06-13 03:42:18 +02:00
```sh
2018-06-13 03:39:17 +02:00
rgb_to_hex() {
# Usage: rgb_to_hex "r" "g" "b"
printf '#%02x%02x%02x\n' "$1" "$2" "$3"
}
```
### `printf` as a `date` replacement.
Bashs `printf` has a built-in method of getting the date which we can use
in place of the `date` command in a lot of cases.
**NOTE:** Requires bash4+
2018-06-13 03:42:18 +02:00
```sh
2018-06-13 03:39:17 +02:00
date() {
# Usage: date "format"
# See: 'man strftime' for format.
printf "%($1)T\\n"
}
```
### `dirname`
Extract the directory from a file path.
2018-06-13 03:42:18 +02:00
```sh
2018-06-13 03:39:17 +02:00
dirname() {
# Usage: dirname "path"
printf %s\n "${1%/*}/"
}
```