2.5 KiB
bat-extras: batpipe
A less
(and bat
) preprocessor for viewing more types of files in the terminal.
The only thing better than syntax highlighting? Syntax highlighting and code formatting. This script combines the best of both worlds by using various formatters to format source files before using bat
to highlight them.
Usage
Like lesspipe, batpipe
is designed to work with programs that support preprocessing with the LESSOPEN
environment variable. Setting up batpipe
will depend on your shell:
Bash:
eval "$(batpipe)"
Fish:
eval (batpipe)
Built-in Viewers
Files | Program |
---|---|
Directories | ls |
*.tar , *.tar.gz |
tar |
External Viewers
For file formats that aren't supported by default, an external file viewer can be added to batpipe
through the external viewer API.
External viewers are be added to batpipe by creating bash scripts inside the ~/.config/batpipe/viewers.d/
directory.
Creating Viewers
Viewers must define two functions and append the viewer's name to the $BATPIPE_VIEWERS
array.
viewer_${viewer}_supports [file_path] [file_basename]
viewer_${viewer}_process [file_path] [inner_file_path]
The viewer_${viewer}_supports
function is called to determine if the external viewer is capable of viewing the provided file. If this function returns successfully, the corresponding process
function will be called.
API
$BATPIPE_VIEWERS -- An array of loaded file viewers.
$BATPIPE_ENABLE_COLOR -- Whether color is supported. (`true`|`false`)
$BATPIPE_INSIDE_LESS -- Whether batpipe is inside less. (`true`|`false`)
batpipe_header [pattern] [...] -- Print a viewer header line.
batpipe_subheader [pattern] [...] -- Print a viewer subheader line.
strip_trailing_slashes [path] -- Strips trailing slashes from a path.
Caveats
- By default,
batpipe
will not use colors when previewed insideless
. Colors must be explicitly enabled withBATPIPE=color
.
Installation
This script is a part of the bat-extras
suite of scripts. You can find install instructions here.
Issues?
If you find an issue or have a feature suggestion, make a pull request or issue through GitHub! Contributions are always welcome.