pure-bash-bible/README.md

98 lines
2.4 KiB
Markdown
Raw Normal View History

2018-06-13 04:04:46 +02:00
<h1 align="center">pure bash</h1> <p align="center">A [WIP] collection of
pure bash alternatives to external processes.</p>
2018-06-13 03:51:15 +02:00
2018-06-13 04:04:46 +02:00
The goal of this repository is to document known and unknown methods of
doing various tasks using only built-in bash features. Using the snippets
from this guide can help to remove unneeded dependencies from your scripts
and in most cases make them that little bit faster. I came across these
tips and discovered a few while developing
[neofetch](https://github.com/dylanaraps/neofetch),
[pxltrm](https://github.com/dylanaraps/pxltrm) and some other smaller
projects.
This repository is open to contribution. If you see something that is
incorrectly described, buggy or outright wrong, open an issue or send a
pull request. If you know a handy snippet that is not included in this
list, send a pull request!
## Table of Contents
2018-06-13 03:43:02 +02:00
<!-- vim-markdown-toc GFM -->
* [Getting the terminal size (*in a script*).](#getting-the-terminal-size-in-a-script)
2018-06-13 04:04:46 +02:00
* [Get the current date using `strftime`.](#get-the-current-date-using-strftime)
* [Get the directory name of a file path.](#get-the-directory-name-of-a-file-path)
2018-06-13 03:43:02 +02:00
* [Convert a hex color to RGB](#convert-a-hex-color-to-rgb)
* [Convert an RGB color to hex.](#convert-an-rgb-color-to-hex)
<!-- vim-markdown-toc -->
2018-06-13 03:39:17 +02:00
2018-06-13 03:52:15 +02:00
## Getting the terminal size (*in a script*).
2018-06-13 03:39:17 +02:00
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"
}
```
2018-06-13 04:04:46 +02:00
## Get the current date using `strftime`.
2018-06-13 03:39:17 +02:00
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.
2018-06-13 04:04:46 +02:00
**NOTE:** Requires `bash` 4+
2018-06-13 03:39:17 +02:00
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"
}
```
2018-06-13 04:04:46 +02:00
## Get the directory name of a file path.
2018-06-13 03:39:17 +02:00
2018-06-13 04:04:46 +02:00
Alternative to the `dirname` command.
2018-06-13 03:39:17 +02:00
2018-06-13 03:42:18 +02:00
```sh
2018-06-13 03:39:17 +02:00
dirname() {
# Usage: dirname "path"
2018-06-13 04:07:54 +02:00
printf '%s\n' "${1%/*}/"
2018-06-13 03:39:17 +02:00
}
```
2018-06-13 04:04:46 +02:00
## Convert a hex color to RGB
```sh
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.
```sh
rgb_to_hex() {
# Usage: rgb_to_hex "r" "g" "b"
printf '#%02x%02x%02x\n' "$1" "$2" "$3"
}
```
2018-06-13 03:39:17 +02:00