Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/astzweig/zshlib

🐣 Awesome functions for zsh CLI tools
https://github.com/astzweig/zshlib

Last synced: about 2 months ago
JSON representation

🐣 Awesome functions for zsh CLI tools

Awesome Lists containing this project

README

        

# Zsh Lib
Awesome functions that make writing Z shell CLI applications easier.

## Install
### Automated install
To install this library for the current user run:

```zsh
/bin/zsh -c "$(curl -fsSL https://raw.githubusercontent.com/astzweig/zshlib/main/bootstrap.sh)"
```

To install this library system wide run that as root.

### Using release version
You can also just download the latest release and put in in your `$fpath`.

### Using in development
To use this library in you own project add it as a [`git-submodule`][git-submodule]
to your repository.

```zsh
# Run inside your project directory
git submodule add https://github.com/astzweig/zshlib
```

### Using on the command line
Just add the zshlib directory to the beginning of your `PATH` variable and you
can call the commands from the command line. Alternatively you can enter the
whole path e.g. `/path/to/repo/hio --help`.

> **Caveat**: Remember that `sudo` does not inherit all environment variables.
> To pass your modified `PATH` variable run `sudo --preserve-env=PATH`.

### Using as a library
Just source the specific commands that you want inside your script. Alternatively
you can enable Zsh autoload:

```zsh
# This will register all commands to autoload
FPATH="/path/to/zshlib:${FPATH}"
local funcNames=("${(@f)$(find ./zshlib -type f -perm +u=x | awk -F/ '{ print $NF }')}")
autoload -Uz "${funcNames[@]}"
```
Or if you want to autoload only specific commands:

```zsh
# This will register only hio and getPrefDir to autoload
FPATH="/path/to/zshlib:${FPATH}"
autoload -Uz hio getPrefDir
```

## What's included

| name | description | dependencies | supported platforms |
| ---- | ----------- | ------------ | ------------------- |
| pf | Convenience function for highlighted output, combining print and tput. | [`tput`][tput], [`docopts`][docopts][^docopts] | all |
| hio | Highlighted output for predefined text styles for `pf`. | `pf`[^zshlib], `isTerminalBackgroundDark`[^zshlib], [`docopts`][docopts][^docopts] | all |
| lop | Log messages to syslog, file or print to command line with highlight. | `hio`[^zshlib], `pf`[^zshlib], `isTerminalBackgroundDark`[^zshlib], [`docopts`][docopts][^docopts] | all |
| indicateActivity | Show a spinner during run of a function if output is to a terminal else print three dots and done or failed afterwards. | `lop`[^zshlib], `hio`[^zshlib], `pf`[^zshlib], `isTerminalBackgroundDark`[^zshlib], [`docopts`][docopts][^docopts] | all |
| trim | Remove leading and trailing whitespace from string. | [`docopts`][docopts][^docopts] | all |
| loadModules | Find executable modules in module search paths and allow user to filter or inverse the list. | [`docopts`][docopts][^docopts] | all |
| askUserModuleQuestions | Ask user questions on behalf of modules with possibility to cache (or store) answers for future calls, e.g. using config. | [`docopts`][docopts][^docopts] | all |
| showSpinner | Show a loading animation during execution of a function. | `traps`[^zshlib], [`docopts`][docopts][^docopts] | all |
| askUser | Ask user for input. Supports questions, password, selections or confirmations. | `hio`[^zshlib], `traps`[^zshlib], [`docopts`][docopts][^docopts] | all |
| getPrefDir | Get system specific preferences directory. | [`docopts`][docopts][^docopts] | macOS, Linux, Windows Subsystem for Linux |
| traps | A trap handler for zsh scripts. | [`docopts`][docopts][^docopts] | macOS, Linux, Windows Subsystem for Linux |
| config | Config file writer and reader. | `getPrefDir`[^zshlib], `PlistBuddy`[^plistbuddy], [`docopts`][docopts][^docopts] | macOS, Linux, Windows Subsystem for Linux |
| abbreviatePaths | Truncate the passed paths so that they are minimal in length and pairwise distinct. Useful to save the user long path specifications. | [`docopts`][docopts][^docopts] | all |
| isTerminalBackgroundDark | Queries the terminal for its background color and returns zero if the color is rather dark or 1 otherwise. If the output is not connected to a terminal, code 10 will be returned. | `traps`[^zshlib] | all |

[^zshlib]: A command of Zsh Lib (this library).
[^docopts]: `docopts` with `-f, --function` option needed. See the
[Astzweig fork][astzweig-docopts] for example.
[^plistbuddy]: `/usr/libexec/PlistBuddy` is a utility found on macOS systems.
Apple does not provide any documentation besides the man page and the programs
`--help` output.

## Usage
Run any command with the `--help` option to read about its usage. e.g.
`/path/to/zshlib/hio --help`.

[git-submodule]: https://git-scm.com/docs/git-submodule
[docopts]: https://github.com/docopt/docopts
[tput]: https://www.gnu.org/software/termutils/manual/termutils-2.0/html_chapter/tput_1.html
[astzweig-docopts]: https://github.com/astzweig/docopts