Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/pawamoy/shellman

Write documentation in comments and render it with templates.
https://github.com/pawamoy/shellman

documentation script shell

Last synced: 1 day ago
JSON representation

Write documentation in comments and render it with templates.

Awesome Lists containing this project

README

        



Shell Script Documentation

Write documentation in comments and render it with templates.



ci


documentation


pypi


gitpod


gitter

`shellman` can generate man pages, wiki pages and help text
using documentation written in shell scripts comments.

For example:

```bash
#!/bin/bash

## \brief Just a demo
## \desc This script actually does nothing.

main() {
case "$1" in
## \option -h, --help
## Print this help and exit.
-h|--help) shellman "$0"; exit 0 ;;
esac
}

## \usage demo [-h]
main "$@"
```

Output when calling ``./demo -h``:

```
Usage: demo [-h]

This script actually does nothing.

Options:
-h, --help Print this help and exit.
```

You can see more examples in the documentation: https://pawamoy.github.io/shellman/.

Demo


In the demo above we saw the three builtin templates:
helptext, manpage and wikipage.

You can use your own templates
by specifying them with the ``--template path:my/template`` syntax.

You can also write a plugin, see the docs: https://pawamoy.github.io/shellman/plugins.

## Installation

```bash
pip install shellman
```

With [`uv`](https://docs.astral.sh/uv/):

```bash
uv tool install shellman
```

## Some projects using shellman

- [shellm](https://github.com/shellm-org) —
A collection of scripts and libraries
built on a [core inclusion-system](https://github.com/shellm-org/core),
all installable with [basher](https://github.com/basherpm/basher).
Here are a few examples:
- [daemon](https://github.com/shellm-org/daemon) —
A library that facilitates the writing of daemonized scripts that consume
files in a watched directory.
- [debug](https://github.com/shellm-org/debug) —
A simple script that sets the verbose/dry-run/debug
Bash flags before running another script.
- [format](https://github.com/shellm-org/format) —
Format your output with style and color.
- [home](https://github.com/shellm-org/home) —
A home for your shell scripts!
- [loop](https://github.com/shellm-org/loop) —
Control the flow of your loops (pause/resume/etc.).