2021-08-10 17:47:07 -05:00
|
|
|
# Bash Template Command
|
|
|
|
|
2021-08-10 18:15:33 -05:00
|
|
|
*This `README.md` is autogenerated.*
|
2021-08-06 12:48:11 -05:00
|
|
|
|
2021-08-09 09:22:17 -05:00
|
|
|
This is a GitHub template repo that will be copied instead of forked to
|
|
|
|
create a new Bash command with a command something like this:
|
2021-08-08 20:34:35 -05:00
|
|
|
|
|
|
|
```
|
2021-08-09 09:22:17 -05:00
|
|
|
gh repo create rwxrob/mycmd -p rwxrob/template-bash-command
|
2021-08-08 20:34:35 -05:00
|
|
|
```
|
|
|
|
|
2021-08-23 21:10:27 -05:00
|
|
|
This `cmd` inside can then be renamed and finished.
|
2021-08-10 17:47:07 -05:00
|
|
|
|
2021-08-08 20:24:27 -05:00
|
|
|
## Naming Conventions
|
|
|
|
|
2021-08-09 09:22:17 -05:00
|
|
|
* Name repos containing single bash commands with `cmd-`
|
|
|
|
* Name template repos beginning with `template-`
|
2021-08-31 21:38:13 -05:00
|
|
|
* Start command functions with `x.` to be completed
|
|
|
|
* Name `CONFIG` accessors with `x.` and full path
|
|
|
|
* Use dot (`.`) pathing in `CONFIG` key names
|
2021-08-31 20:39:57 -05:00
|
|
|
|
2021-08-31 21:00:16 -05:00
|
|
|
Think of `x` as in "executable" command.
|
2021-08-31 08:47:57 -05:00
|
|
|
|
2021-08-31 21:38:13 -05:00
|
|
|
> ⚠️
|
|
|
|
> Note that all versions of Vim current have a bug that does not allow
|
|
|
|
> dot (`.`) to be included in the function name even though it is
|
|
|
|
> explicitly allowed by bash. So you may have to add `.` to your
|
|
|
|
> `/usr/share/vim/vim82/syntax/sh.vim` file anywhere a function name
|
|
|
|
> expression is defined. I have yet to isolate it out and override it in
|
|
|
|
> my own `.vimrc`. It is a minimal edit.
|
|
|
|
|
2021-08-31 08:47:57 -05:00
|
|
|
## Builtins and Utilities
|
|
|
|
|
|
|
|
A number of builtin and frequently used utility functions have been
|
|
|
|
included for convenience. These save developers from adding other
|
|
|
|
moronic things like `sed` and `awk` subprocesses. Obviously, not all of
|
|
|
|
this is needed for many Bash scripts. Just remove what you do not need
|
|
|
|
or want.
|
|
|
|
|
|
|
|
### `_initialize`
|
|
|
|
|
|
|
|
The `_initialize` function is meant to contain initialization code and
|
|
|
|
be placed at the beginning of the script to be found easily even though
|
|
|
|
it is called at the bottom of the script (as bash requires).
|
|
|
|
|
|
|
|
### `_have`
|
|
|
|
|
|
|
|
Returns true (0) if the first argument exists as an executable in the
|
|
|
|
current `PATH`. Otherwise, return false (1).
|
|
|
|
|
|
|
|
### `_checkdep`
|
|
|
|
|
|
|
|
Checks that the first argument exists as an executable in the current
|
|
|
|
`PATH`. If so, returns true (0). If not, prints a generic error message
|
|
|
|
in English and returns false (1). The "progressive enhancement" design
|
|
|
|
principle requires minimal functionality using what is available and
|
|
|
|
progressively upgrading based on what is detected.
|
|
|
|
|
|
|
|
### `_newest`
|
|
|
|
|
|
|
|
Uses `ls` to return the newest file or directory in the specified
|
|
|
|
directory.
|
|
|
|
|
|
|
|
### `_trim`
|
|
|
|
|
|
|
|
Removes all whitespace (`[:space:]`) from the beginning and ending
|
|
|
|
of a string without invoking a subprocess.
|
|
|
|
|
|
|
|
### `_filter`
|
|
|
|
|
|
|
|
Reads the first argument or each line of standard input passing
|
|
|
|
each individually as the first argument to the calling function one at
|
|
|
|
a time. The UNIX philosophy requires all commands be filters whenever possible.
|
|
|
|
|
|
|
|
### `_buffer`
|
|
|
|
|
|
|
|
Reads the first argument or all lines of standard input and then
|
|
|
|
passes them to the calling function as the first argument. The UNIX philosophy requires all command be filters whenever possible.
|
|
|
|
|
|
|
|
### `_reduce`
|
|
|
|
|
|
|
|
Takes the name of an array and a bash extended regular expression
|
|
|
|
and prints only the array entries that match, one to a line suitable for
|
2021-08-31 08:54:18 -05:00
|
|
|
converting back into an array with `IFS=$'\n'` or just as an in-memory
|
2021-08-31 08:47:57 -05:00
|
|
|
`grep` replacement.
|
|
|
|
|
|
|
|
### `_jsonstr`
|
|
|
|
|
|
|
|
Encodes first argument or all standard input into a single line of JSON text. This function depends on the `jq` command.
|
|
|
|
|
|
|
|
### `_urlencode`
|
|
|
|
|
|
|
|
Encodes the first argument or all standard input using standard URL
|
|
|
|
encoding suitable for passing to `curl` or whatever. This function has
|
|
|
|
no external dependencies.
|
|
|
|
|
2021-08-06 12:48:11 -05:00
|
|
|
## Dependencies
|
|
|
|
|
|
|
|
Required:
|
|
|
|
|
|
|
|
* Bash 4+
|
|
|
|
|
|
|
|
Optional:
|
|
|
|
|
|
|
|
* `pandoc` - for rich help docs
|
2021-08-23 21:10:27 -05:00
|
|
|
* `jq` - for `json` and anything that uses it
|
2021-08-06 12:48:11 -05:00
|
|
|
|
|
|
|
## Justification
|
|
|
|
|
2021-08-31 08:47:57 -05:00
|
|
|
Bash is the dominant shell scripting language and the official default
|
2021-08-06 12:48:11 -05:00
|
|
|
Linux interactive shell, which reduces cognitive overhead; every command
|
|
|
|
line *is* a line of code that could be put into script as is. Bash
|
|
|
|
scripts are at the core of cloud, containers, and Kubernetes. Bash 4+
|
|
|
|
with its associative array support, powerful regular expressions, and
|
|
|
|
multiple ways of feeding data to loops easily covers the needs
|
|
|
|
previously requiring Python and Perl scripts. Bash scripts are also much
|
|
|
|
more powerful, safer, flexible, and performant than POSIX shell or Zsh.
|
|
|
|
|
2021-08-10 18:37:51 -05:00
|
|
|
## Guidelines
|
2021-08-06 12:48:11 -05:00
|
|
|
|
2021-08-10 18:37:51 -05:00
|
|
|
* Write GitHub Flavored Markdown only
|
|
|
|
* Use present tense ("outputs" over "will output")
|
2021-08-23 21:10:27 -05:00
|
|
|
* Prefer term "output" and "display" over ~~print~~
|
2021-08-10 18:37:51 -05:00
|
|
|
* Follow the [naming conventions](#naming-conventions)
|
2021-08-15 15:56:56 -05:00
|
|
|
* Use the official bash path: `#!/bin/bash`
|
|
|
|
* Use of `#!/usr/bin/bash` is outdated
|
2021-08-06 12:48:11 -05:00
|
|
|
* Using `#!/usr/bin/env bash` introduces unnecessary risk
|
2021-08-10 18:37:51 -05:00
|
|
|
* Explicitly export `PATH` in script when possible
|
2021-08-06 12:48:11 -05:00
|
|
|
* Always check script with [`shellcheck`] before releasing
|
|
|
|
* Always use `bc` for *any* floating point math
|
|
|
|
|
|
|
|
[`shellcheck`]: <https://www.shellcheck.net>
|
|
|
|
|
|
|
|
## Legal
|
|
|
|
|
2021-08-06 12:50:56 -05:00
|
|
|
Copyright 2021 Rob Muhlestein <rob@rwx.gg>
|
|
|
|
Released under Apache-2.0 License
|
2021-08-23 21:27:03 -05:00
|
|
|
Please mention rwxrob.tv
|
2021-08-10 17:47:07 -05:00
|
|
|
|
2021-08-23 21:10:27 -05:00
|
|
|
## The `bar` Command
|
2021-08-10 17:47:07 -05:00
|
|
|
|
2021-08-23 21:10:27 -05:00
|
|
|
```
|
|
|
|
cmd bar
|
|
|
|
```
|
|
|
|
|
|
|
|
Bar the things.
|
|
|
|
|
|
|
|
## The `config` Command
|
|
|
|
|
|
|
|
```
|
|
|
|
cmd config
|
|
|
|
cmd config KEY
|
|
|
|
cmd config KEY VALUE
|
2021-08-24 23:52:39 -05:00
|
|
|
cmd config KEY ""
|
2021-08-29 11:19:03 -05:00
|
|
|
cmd config keys
|
|
|
|
cmd config val[ues]
|
|
|
|
cmd config dir[ectory]
|
2021-08-27 08:16:21 -05:00
|
|
|
cmd config path [file]
|
|
|
|
cmd config edit [file]
|
2021-08-29 11:19:03 -05:00
|
|
|
cmd config del[ete]
|
2021-08-23 21:10:27 -05:00
|
|
|
```
|
|
|
|
|
|
|
|
The `config` command is for reading, writing, and displaying standard
|
2021-08-24 23:52:39 -05:00
|
|
|
open desktop configuration properties. Pass an empty string to delete
|
|
|
|
a property.
|
2021-08-23 21:10:27 -05:00
|
|
|
|
|
|
|
### Arguments
|
2021-08-10 17:47:07 -05:00
|
|
|
|
2021-08-23 21:10:27 -05:00
|
|
|
With no arguments outputs all the currently cached configuration
|
2021-08-29 11:19:03 -05:00
|
|
|
settings.
|
2021-08-10 17:47:07 -05:00
|
|
|
|
2021-08-23 21:10:27 -05:00
|
|
|
With a single KEY argument fetches the value for that key and outputs
|
2021-08-27 08:16:21 -05:00
|
|
|
it unless it is one of the following special (reserved) key names:
|
|
|
|
|
2021-08-29 11:19:03 -05:00
|
|
|
* `dir*` full path to config directory
|
2021-08-27 08:16:21 -05:00
|
|
|
* `path` full path to specific config file (default: `values`)
|
|
|
|
* `edit` opens config file in editor (default: `editor` or `$EDITOR)
|
2021-08-29 11:19:03 -05:00
|
|
|
* `keys` output the configuration keys, one per line
|
|
|
|
* `val*` output the configuration values, one per line
|
|
|
|
* `del*` if key argument then delete a specific key, otherwise prompt
|
2021-08-10 17:47:07 -05:00
|
|
|
|
2021-08-23 21:10:27 -05:00
|
|
|
With more than one argument the remaining arguments after the KEY will
|
2021-08-23 21:21:28 -05:00
|
|
|
be combined into the VALUE and written to a `values` file in the
|
2021-08-24 23:52:39 -05:00
|
|
|
configuration directory.
|
|
|
|
|
|
|
|
### Configuration Directory
|
|
|
|
|
|
|
|
The configuration directory path relies on the following environment
|
|
|
|
variables:
|
|
|
|
|
|
|
|
* `EXE` - defaults to name of currently running command (cmd)
|
|
|
|
* `HOME` - checked for `$HOME/.config/$EXE/values`
|
|
|
|
* `XDG_CONFIG_HOME` - overrides `$HOME/.config`
|
|
|
|
* `CONFIG_DIR` - full path to directory containing `values` file
|
|
|
|
|
|
|
|
The `CONFIG_DIR` always takes priority over anything else if set, but is
|
|
|
|
never implied. If the directory does not exist it will be created the
|
|
|
|
first time a value is set.
|
2021-08-10 17:47:07 -05:00
|
|
|
|
2021-08-23 21:23:32 -05:00
|
|
|
### Configuration `values` File Format
|
2021-08-23 21:10:27 -05:00
|
|
|
|
2021-08-23 21:21:28 -05:00
|
|
|
The file (which is almost always located at
|
|
|
|
`~/.config/cmd/values`) uses the simplest possible format to
|
2021-08-23 21:14:42 -05:00
|
|
|
facilitate standard UNIX parsing and filtering with any number of
|
|
|
|
existing tools (and no `jq` dependency).
|
2021-08-23 21:10:27 -05:00
|
|
|
|
|
|
|
* One KEY=VALUE per line
|
|
|
|
* KEYs may be anything but the equal sign (`=`)
|
|
|
|
* VALUEs may be anything but line returns must be escaped
|
|
|
|
|
|
|
|
Note that this is *not* the same as Java properties and other similar
|
|
|
|
format. It is designed for ultimate simplicity, efficiency, and
|
|
|
|
portability.
|
|
|
|
|
|
|
|
## The `foo` Command
|
|
|
|
|
|
|
|
Foos things.
|
|
|
|
|
|
|
|
## The `help` Command
|
2021-08-10 17:47:07 -05:00
|
|
|
|
|
|
|
```
|
2021-08-23 21:10:27 -05:00
|
|
|
cmd help [COMMAND]
|
2021-08-10 17:47:07 -05:00
|
|
|
```
|
|
|
|
|
|
|
|
Displays specific help information. If no argument is passed displays
|
|
|
|
general help information (main). Otherwise, the documentation for the
|
|
|
|
specific argument keyword is displayed, which usually corresponds to
|
2021-08-23 21:10:27 -05:00
|
|
|
a COMMAND name (but not necessarily). All documentation is written in
|
2021-08-10 17:47:07 -05:00
|
|
|
GitHub Flavored Markdown and will displayed as a web page if `pandoc`
|
|
|
|
and `$HELP_BROWSER` are detected, otherwise, just the Markdown is sent
|
|
|
|
to `$PAGER` (default: more).
|
|
|
|
|
|
|
|
Also see `readme` and `usage` commands.
|
|
|
|
|
2021-08-23 21:10:27 -05:00
|
|
|
## Generate `README.md` File
|
2021-08-10 17:47:07 -05:00
|
|
|
|
|
|
|
```
|
2021-08-23 21:10:27 -05:00
|
|
|
cmd readme > README.md
|
2021-08-10 17:47:07 -05:00
|
|
|
```
|
|
|
|
|
|
|
|
The `readme` command will output the embedded help documentation in raw
|
|
|
|
GitHub Flavored Markdown suitable for use as a `README.md` file on
|
|
|
|
GitHub or similar hosting service.
|
|
|
|
|
2021-08-29 11:19:03 -05:00
|
|
|
## The `some.config.setting` Command
|
|
|
|
|
|
|
|
Get and set `some.config.setting`.
|
|
|
|
|
2021-08-23 21:10:27 -05:00
|
|
|
## The `usage` Command
|
2021-08-10 17:47:07 -05:00
|
|
|
|
|
|
|
Displays a summary of usage.
|
2021-08-06 12:48:11 -05:00
|
|
|
|
2021-08-10 18:15:33 -05:00
|
|
|
----
|
|
|
|
|
2021-08-31 21:38:13 -05:00
|
|
|
*Autogenerated Tue Aug 31 10:37:57 PM EDT 2021*
|
2021-08-10 18:15:33 -05:00
|
|
|
|