kapow-2.4.0 is not a library.
About
Kapow is a template processor that provides the following directives to support injecting file contents, command output, current date/time, etc in generated files.
Block directives
| Directive | Description |
|---|---|
!inc:path |
Include file contents; path is relative to its containing file |
!run:command |
Run command and insert stdout |
- Block directives must be placed at the beginning of a line.
- Long commands can be backslash-wrapped.
Span directives
| Directive | Example | Description |
|---|---|---|
`!now` |
2023-03-13T17:31:59Z | Current date/time in UTC / RFC 3339 |
`!now:local` |
Mon 13 Mar 2023 13:31:59 EDT | Current date/time in local timezone |
`!now:local:%A %H:%M` |
Monday 13:31 | Current date/time in local timezone and custom format |
`!now:MST7MDT` |
Mon 13 Mar 2023 11:31:59 MDT | Current date/time in custom timezone |
`!now:MST7MDT:%A %H:%M` |
Monday 11:31 | Current date/time in custom timezone and format |
`!now:US/Hawaii` |
Mon 13 Mar 2023 07:31:59 HST | Current date/time in custom locale |
`!now:US/Hawaii:%A %H:%M` |
Monday 07:31 | Current date/time in custom locale and format |
`!now:UTC:%A %H:%M` |
Monday 17:31 | Current date/time in UTC and custom format |
`!now:x` |
Xh2CHVx | Current date/time in "x" format |
`!today` |
2023-03-13 | Current date in UTC / RFC 3339 |
`!today:local` |
2023-03-13 | Current date in local timezone |
`!today:MST7MDT` |
2023-03-13 | Current date in custom timezone |
`!today:MST7MDT:%v` |
13-Mar-2023 | Current date in custom timezone and format |
`!today:US/Hawaii` |
2023-03-13 | Current date in custom locale |
`!today:US/Hawaii:%x` |
03/13/23 | Current date in custom locale and format |
`!today:UTC:%A` |
Monday | Current date in UTC and custom format |
- Span directives must be placed inside a code span and may appear zero or more times in any line.
- Disable processing a span directive by escaping
!with a backslash:\!.
Usage
$ kapow -V
kapow 2.4.0
$ kapow -h
KAPOW!
Usage: kapow [OPTIONS] [INPUT_FILES]...
Arguments:
[INPUT_FILES]... Input file(s) [default: -]
Options:
-r, --readme Print readme
-h, --help Print help
-V, --version Print version
- The
-roption uses bat for paging and syntax highlighting if you have it installed (optional).
Errors
| Code | Description |
|---|---|
| 101 | Could not read input file |
| 102 | Could not read included file |
| 103 | Could not change directory |
Example
See the readme task in Makefile.toml:
- Generates
t/VERSION.mdfromt/VERSION.t.md!run:../target/release/kapow -V
- Generates
t/USAGE.mdfromt/USAGE.t.md!run:../target/release/kapow -h
- Generates
README.mdfromt/README.md!inc:VERSION.md!inc:USAGE.md`!now`(all variants)
Changelog
- 1.0.0 (2023-02-21): Initial release
- 1.0.1 (2023-02-21): Update dependencies
- 2.0.0 (2023-02-22): Include stderr in
!run:output; enable backslash-wrapping long commands; include whitespace in included files; process path of included files relative to the containing file instead of the current directory; input and included file processed more efficiently viaBufReaderinstead ofread_to_string; improved error handling - 2.1.0 (2023-02-24): Use
bat -pl mdas readme pager if have it installed; update dependencies - 2.1.1 (2023-02-24): Fix readme
- 2.1.2 (2023-02-24): Fix readme
- 2.2.0 (2023-03-10): Change to the directory of each input file in order to process included file paths and commands to be run relative to the input file path; run commands via the shell to enable more advanced commands and simplify usage; update dependencies
- 2.2.1 (2023-03-10): Remove shlex dependency
- 2.2.2 (2023-03-10): Fix readme; error if no input file(s) provided
- 2.2.3 (2023-03-10): Fix confict with readme option
- 2.2.4 (2023-03-10): Fix readme
- 2.3.0 (2023-03-11): Add
!todayspan directive; improved exit macro; change directory function; where clauses; fix watch task; fix readme - 2.3.1 (2023-03-11): Fix readme
- 2.4.0 (2023-03-13): Enable processing from stdin if no input files provided or input file is
-; update dependencies
Development