2018-05-22 19:54:34 +00:00
< p align = "center" >
< img src = "doc/logo-header.svg" alt = "bat - a cat clone with wings" > < br >
2020-08-02 19:53:59 +00:00
< a href = "https://github.com/sharkdp/bat/actions?query=workflow%3ACICD" > < img src = "https://github.com/sharkdp/bat/workflows/CICD/badge.svg" alt = "Build Status" > < / a >
2018-05-30 19:02:40 +00:00
< img src = "https://img.shields.io/crates/l/bat.svg" alt = "license" >
2018-05-30 19:10:14 +00:00
< a href = "https://crates.io/crates/bat" > < img src = "https://img.shields.io/crates/v/bat.svg?colorB=319e8c" alt = "Version info" > < / a > < br >
2018-05-22 19:54:34 +00:00
A < i > cat(1)< / i > clone with syntax highlighting and Git integration.
< / p >
2018-04-21 12:23:57 +00:00
2018-05-30 19:23:24 +00:00
< p align = "center" >
< a href = "#syntax-highlighting" > Key Features< / a > •
< a href = "#how-to-use" > How To Use< / a > •
< a href = "#installation" > Installation< / a > •
< a href = "#customization" > Customization< / a > •
2020-06-05 20:42:32 +00:00
< a href = "#project-goals-and-alternatives" > Project goals, alternatives< / a > < br >
[< a href = "https://github.com/chinanf-boy/bat-zh" > 中文< / a > ] [< a href = "doc/README-ja.md" > 日本語< / a > ] [< a href = "doc/README-ko.md" > 한국어< / a > ] [< a href = "doc/README-ru.md" > Русский< / a > ]
2018-05-30 19:23:24 +00:00
< / p >
2018-04-22 13:30:28 +00:00
### Syntax highlighting
2018-05-07 18:06:01 +00:00
`bat` supports syntax highlighting for a large number of programming and markup
languages:
2018-04-22 13:30:28 +00:00
2018-04-25 22:02:53 +00:00
![Syntax highlighting example ](https://imgur.com/rGsdnDe.png )
2018-04-22 13:30:28 +00:00
### Git integration
2018-05-07 18:06:01 +00:00
`bat` communicates with `git` to show modifications with respect to the index
(see left side bar):
2018-04-25 22:02:53 +00:00
2018-04-25 22:03:25 +00:00
![Git integration example ](https://i.imgur.com/2lSW4RE.png )
2018-04-22 14:15:07 +00:00
2018-11-11 12:19:34 +00:00
### Show non-printable characters
2018-11-11 13:28:18 +00:00
You can use the `-A` /`--show-all` option to show and highlight non-printable
characters:
2018-11-11 13:32:59 +00:00
![Non-printable character example ](https://i.imgur.com/WndGp9H.png )
2018-11-11 12:19:34 +00:00
2018-05-08 22:12:25 +00:00
### Automatic paging
2020-08-03 15:47:59 +00:00
`bat` can pipe its own output to a pager (e.g `less` ) if the output is too large for one screen.
2018-05-08 22:12:25 +00:00
### File concatenation
Oh.. you can also use it to concatenate files :wink:. Whenever
2018-11-11 13:35:08 +00:00
`bat` detects a non-interactive terminal (i.e. when you pipe into another process
or into a file), `bat` will act as a drop-in replacement for `cat` and
fall back to printing the plain file contents.
2018-05-08 22:12:25 +00:00
2018-05-30 19:23:24 +00:00
## How to use
2018-05-08 22:33:49 +00:00
Display a single file on the terminal
2018-05-30 18:40:02 +00:00
```bash
2018-05-08 22:33:49 +00:00
> bat README.md
```
Display multiple files at once
2018-05-30 18:40:02 +00:00
```bash
2018-05-08 22:33:49 +00:00
> bat src/*.rs
```
2020-06-03 05:47:33 +00:00
Read from stdin, determine the syntax automatically (note, highlighting will
only work if the syntax can be determined from the first line of the file,
usually through a shebang such as `#!/bin/sh` )
2018-05-08 22:33:49 +00:00
2018-05-30 18:40:02 +00:00
```bash
2018-10-07 16:39:52 +00:00
> curl -s https://sh.rustup.rs | bat
2018-05-08 22:33:49 +00:00
```
2018-10-07 16:39:52 +00:00
Read from stdin, specify the language explicitly
2018-05-30 18:40:02 +00:00
```bash
2018-10-07 16:39:52 +00:00
> yaml2json .travis.yml | json_pp | bat -l json
2018-05-08 22:33:49 +00:00
```
2018-11-11 13:28:18 +00:00
Show and highlight non-printable characters:
```bash
> bat -A /etc/hosts
```
2018-10-07 16:39:52 +00:00
2018-11-11 13:28:18 +00:00
Use it as a `cat` replacement:
2018-05-31 20:57:18 +00:00
```bash
bat > note.md # quickly create a new file
bat header.md content.md footer.md > document.md
bat -n main.rs # show line numbers (only)
2018-06-01 14:32:33 +00:00
bat f - g # output 'f', then stdin, then 'g'.
2018-05-31 20:57:18 +00:00
```
2018-05-08 22:33:49 +00:00
2019-02-11 20:38:18 +00:00
### Integration with other tools
#### `find` or `fd`
You can use the `-exec` option of `find` to preview all search results with `bat` :
```bash
find … -exec bat {} +
```
2019-02-17 01:57:21 +00:00
If you happen to use [`fd` ](https://github.com/sharkdp/fd ), you can use the `-X` /`--exec-batch` option to do the same:
2019-02-11 20:38:18 +00:00
```bash
fd … -X bat
```
2019-09-18 21:10:11 +00:00
#### `ripgrep`
With [`batgrep` ](https://github.com/eth-p/bat-extras/blob/master/doc/batgrep.md ), `bat` can be used as the printer for [`ripgrep` ](https://github.com/BurntSushi/ripgrep ) search results.
```bash
2019-09-21 07:01:54 +00:00
batgrep needle src/
2019-09-18 21:10:11 +00:00
```
2019-02-11 20:54:16 +00:00
#### `tail -f`
`bat` can be combined with `tail -f` to continuously monitor a given file with syntax highlighting.
```bash
tail -f /var/log/pacman.log | bat --paging=never -l log
```
Note that we have to switch off paging in order for this to work. We have also specified the syntax
explicitly (`-l log`), as it can not be auto-detected in this case.
2019-10-29 20:20:35 +00:00
#### `git`
2019-02-11 21:04:22 +00:00
You can combine `bat` with `git show` to view an older version of a given file with proper syntax
highlighting:
```bash
git show v0.6.0:src/main.rs | bat -l rs
```
2019-10-29 21:00:19 +00:00
Note that syntax highlighting within diffs is currently not supported. If you are looking for this, check out [`delta` ](https://github.com/dandavison/delta ).
2019-10-29 20:20:35 +00:00
2019-02-11 21:01:03 +00:00
#### `xclip`
The line numbers and Git modification markers in the output of `bat` can make it hard to copy
the contents of a file. To prevent this, you can call `bat` with the `-p` /`--plain` option or
simply pipe the output into `xclip` :
2019-02-11 21:04:22 +00:00
```bash
2019-02-11 21:01:03 +00:00
bat main.cpp | xclip
```
`bat` will detect that the output is being redirected and print the plain file contents.
2019-08-31 12:32:37 +00:00
#### `man`
2019-09-21 06:51:26 +00:00
`bat` can be used as a colorizing pager for `man` , by setting the
`MANPAGER` environment variable:
2019-09-18 21:10:11 +00:00
2019-09-18 20:43:32 +00:00
```bash
2019-09-21 06:44:26 +00:00
export MANPAGER="sh -c 'col -bx | bat -l man -p'"
2019-08-31 12:32:37 +00:00
man 2 select
```
2019-09-21 06:51:26 +00:00
It might also be necessary to set `MANROFFOPT="-c"` if you experience
formatting problems.
If you prefer to have this bundled in a new command, you can also use [`batman` ](https://github.com/eth-p/bat-extras/blob/master/doc/batman.md ).
2020-03-25 18:43:18 +00:00
Note that the [Manpage syntax ](assets/syntaxes/02_Extra/Manpage.sublime-syntax ) is developed in this repository and still needs some work.
2019-08-31 12:32:37 +00:00
2020-10-01 19:46:36 +00:00
Also, note that this will [not work ](https://github.com/sharkdp/bat/issues/1145 ) with Mandocs `man` implementation.
2019-09-18 21:10:11 +00:00
#### `prettier` / `shfmt` / `rustfmt`
The [`prettybat` ](https://github.com/eth-p/bat-extras/blob/master/doc/prettybat.md ) script is a wrapper that will format code and print it with `bat` .
2018-04-22 14:15:07 +00:00
## Installation
2019-09-01 09:03:35 +00:00
[![Packaging status ](https://repology.org/badge/vertical-allrepos/bat.svg )](https://repology.org/project/bat/versions)
2020-05-12 08:47:33 +00:00
### On Ubuntu (using `apt`)
2018-08-28 18:55:15 +00:00
*... and other Debian-based Linux distributions.*
2018-05-02 18:01:43 +00:00
2020-04-17 06:57:44 +00:00
`bat` is making its way through the [Ubuntu ](https://packages.ubuntu.com/eoan/bat ) and
[Debian ](https://packages.debian.org/sid/bat ) package release process, and is available
for Ubuntu as of Eoan 19.10. On Debian `bat` is currently only available on the unstable
"Sid" branch.
If your Ubuntu/Debian installation is new enough you can simply run:
2019-10-26 14:33:17 +00:00
```bash
apt install bat
```
2020-05-12 15:41:15 +00:00
If you install `bat` this way, please note that the executable may be installed as `batcat` instead of `bat` (due to [a name
2020-06-02 14:19:31 +00:00
clash with another package](https://github.com/sharkdp/bat/issues/982)). You can set up a `bat -> batcat` symlink or alias to prevent any issues that may come up because of this and to be consistent with other distributions:
2020-05-12 15:41:15 +00:00
``` bash
2020-05-12 16:35:35 +00:00
mkdir -p ~/.local/bin
2020-05-12 15:41:15 +00:00
ln -s /usr/bin/batcat ~/.local/bin/bat
```
2020-05-12 08:47:33 +00:00
2020-05-12 15:42:52 +00:00
### On Ubuntu (using most recent `.deb` packages)
*... and other Debian-based Linux distributions.*
2020-05-12 08:47:33 +00:00
2020-04-17 06:57:44 +00:00
If the package has not yet been promoted to your Ubuntu/Debian installation, or you want
the most recent release of `bat` , download the latest `.deb` package from the
[release page ](https://github.com/sharkdp/bat/releases ) and install it via:
2019-09-18 20:43:32 +00:00
```bash
2020-10-01 20:23:51 +00:00
sudo dpkg -i bat_0.16.0_amd64.deb # adapt version number and architecture
2018-08-28 18:55:15 +00:00
```
2018-04-25 22:02:53 +00:00
2019-06-10 23:42:32 +00:00
### On Alpine Linux
You can install [the `bat` package ](https://pkgs.alpinelinux.org/packages?name=bat )
from the official sources, provided you have the appropriate repository enabled:
```bash
apk add bat
```
2018-08-28 19:04:41 +00:00
### On Arch Linux
2018-04-30 22:04:40 +00:00
2018-08-28 18:55:15 +00:00
You can install [the `bat` package ](https://www.archlinux.org/packages/community/x86_64/bat/ )
from the official sources:
2018-04-30 22:04:40 +00:00
```bash
2018-06-08 09:34:57 +00:00
pacman -S bat
2018-04-30 22:04:40 +00:00
```
2018-12-02 20:02:56 +00:00
### On Fedora
2019-07-21 08:57:16 +00:00
You can install [the `bat` package ](https://koji.fedoraproject.org/koji/packageinfo?packageID=27506 ) from the official [Fedora Modular ](https://docs.fedoraproject.org/en-US/modularity/using-modules/ ) repository.
2018-12-02 20:02:56 +00:00
```bash
2019-07-21 08:57:16 +00:00
dnf install bat
2018-12-02 20:02:56 +00:00
```
2019-06-09 09:10:44 +00:00
### On Gentoo Linux
You can install [the `bat` package ](https://packages.gentoo.org/packages/sys-apps/bat )
from the official sources:
```bash
emerge sys-apps/bat
```
2018-08-28 18:55:15 +00:00
### On Void Linux
You can install `bat` via xbps-install:
2019-09-18 20:43:32 +00:00
```bash
2018-08-28 18:55:15 +00:00
xbps-install -S bat
```
2018-08-28 19:04:41 +00:00
### On FreeBSD
2018-05-16 17:13:13 +00:00
You can install a precompiled [`bat` package ](https://www.freshports.org/textproc/bat ) with pkg:
2018-05-30 18:40:02 +00:00
```bash
2018-05-16 17:13:13 +00:00
pkg install bat
```
or build it on your own from the FreeBSD ports:
2018-05-30 18:40:02 +00:00
```bash
2018-05-16 17:13:13 +00:00
cd /usr/ports/textproc/bat
make install
```
2018-10-11 18:05:17 +00:00
### Via nix
You can install `bat` using the [nix package manager ](https://nixos.org/nix ):
```bash
nix-env -i bat
```
2018-11-06 14:53:39 +00:00
### On openSUSE
You can install `bat` with zypper:
2019-09-18 20:43:32 +00:00
```bash
2018-11-06 14:53:39 +00:00
zypper install bat
```
2020-10-03 19:05:46 +00:00
### On macOS (or Linux) via Homebrew
2020-10-03 18:23:58 +00:00
2020-10-03 19:05:46 +00:00
You can install `bat` with [Homebrew on MacOS ](https://formulae.brew.sh/formula/bat ) or [Homebrew on Linux ](https://formulae.brew.sh/formula-linux/bat ):
2020-10-03 18:23:58 +00:00
```bash
brew install bat
```
2020-10-03 19:05:46 +00:00
### On macOS via MacPorts
2018-10-11 18:05:17 +00:00
2019-09-29 11:20:36 +00:00
Or install `bat` with [MacPorts ](https://ports.macports.org/port/bat/summary ):
```bash
port install bat
```
2018-10-11 18:05:17 +00:00
### On Windows
2020-03-06 22:37:18 +00:00
There are a few options to install `bat` on Windows. Once you have installed `bat` ,
take a look at the ["Using `bat` on Windows" ](#using-bat-on-windows ) section.
2020-07-05 01:43:04 +00:00
#### Prerequisites
You will need to install the [Visual C++ Redistributable ](https://support.microsoft.com/en-us/help/2977003/the-latest-supported-visual-c-downloads ) package.
2020-03-06 22:37:18 +00:00
#### With Chocolatey
2018-10-11 18:05:17 +00:00
2020-03-06 22:39:17 +00:00
You can install `bat` via [Chocolatey ](https://chocolatey.org/packages/Bat ):
2018-10-11 18:05:17 +00:00
```bash
2020-03-06 22:37:18 +00:00
choco install bat
2018-10-11 18:05:17 +00:00
```
2020-03-06 22:37:18 +00:00
#### With Scoop
You can install `bat` via [scoop ](https://scoop.sh/ ):
2019-04-10 12:23:46 +00:00
```bash
2020-03-06 22:37:18 +00:00
scoop install bat
2019-04-10 12:23:46 +00:00
```
2020-03-06 22:37:18 +00:00
#### From prebuilt binaries:
You can download prebuilt binaries from the [Release page ](https://github.com/sharkdp/bat/releases ),
2020-03-04 09:04:49 +00:00
2020-03-06 22:37:18 +00:00
You will need to install the [Visual C++ Redistributable ](https://support.microsoft.com/en-us/help/2977003/the-latest-supported-visual-c-downloads ) package.
2018-10-11 18:05:17 +00:00
2018-08-28 18:55:15 +00:00
### From binaries
Check out the [Release page ](https://github.com/sharkdp/bat/releases ) for
2018-10-05 21:01:46 +00:00
prebuilt versions of `bat` for many different architectures. Statically-linked
2018-11-11 13:28:18 +00:00
binaries are also available: look for archives with `musl` in the file name.
2018-08-28 18:55:15 +00:00
2018-04-30 13:40:51 +00:00
### From source
2020-04-23 22:46:57 +00:00
If you want to build `bat` from source, you need Rust 1.40 or
2018-05-07 18:06:01 +00:00
higher. You can then use `cargo` to build everything:
2018-04-25 18:49:49 +00:00
2018-05-30 18:40:02 +00:00
```bash
2020-04-27 21:43:18 +00:00
cargo install --locked bat
2018-04-25 22:02:53 +00:00
```
2018-04-30 14:03:33 +00:00
2020-10-01 19:16:10 +00:00
Note that addition files like the man page or shell completion
files can not be installed in this way. They will be generated by `cargo` and should be available in the cargo target folder (under `build` ).
2018-04-30 14:03:33 +00:00
## Customization
2018-05-30 19:32:40 +00:00
### Highlighting theme
Use `bat --list-themes` to get a list of all available themes for syntax
2018-07-23 19:58:06 +00:00
highlighting. To select the `TwoDark` theme, call `bat` with the
`--theme=TwoDark` option or set the `BAT_THEME` environment variable to
2018-09-20 12:50:54 +00:00
`TwoDark` . Use `export BAT_THEME="TwoDark"` in your shell's startup file to
2018-11-11 13:28:18 +00:00
make the change permanent. Alternatively, use `bat` s
[configuration file ](https://github.com/sharkdp/bat#configuration-file ).
2018-10-06 19:12:12 +00:00
If you want to preview the different themes on a custom file, you can use
the following command (you need [`fzf` ](https://github.com/junegunn/fzf ) for this):
2019-09-18 20:43:32 +00:00
```bash
2018-10-06 19:12:12 +00:00
bat --list-themes | fzf --preview="bat --theme={} --color=always /path/to/file"
```
2018-05-30 19:32:40 +00:00
2018-10-11 13:52:35 +00:00
`bat` looks good on a dark background by default. However, if your terminal uses a
2018-11-11 13:28:18 +00:00
light background, some themes like `GitHub` or `OneHalfLight` will work better for you.
You can also use a custom theme by following the
2018-10-11 13:52:35 +00:00
['Adding new themes' section below ](https://github.com/sharkdp/bat#adding-new-themes ).
2020-07-19 20:49:10 +00:00
### 8-bit themes
`bat` has four themes that always use [8-bit colors ](https://en.wikipedia.org/wiki/ANSI_escape_code#Colors ),
even when truecolor support is available:
- `ansi-dark` looks decent on any terminal with a dark background. It uses 3-bit colors: black, red,
green, yellow, blue, magenta, cyan, and white.
- `ansi-light` is like `ansi-dark` , but for terminals with a light background.
- `base16` is designed for [base16 ](https://github.com/chriskempson/base16 ) terminal themes. It uses
4-bit colors (3-bit colors plus bright variants) in accordance with the
[base16 styling guidelines ](https://github.com/chriskempson/base16/blob/master/styling.md ).
- `base16-256` is designed for [base16-shell ](https://github.com/chriskempson/base16-shell ).
It replaces certain bright colors with 8-bit colors from 16 to 21. **Do not** use this simply
because you have a 256-color terminal but are not using base16-shell.
Although these themes are more restricted, they have two advantages over truecolor themes:
- They harmonize better with other terminal software using 3-bit or 4-bit colors.
- When you change your terminal theme, `bat` output already on the screen will update to match.
2018-05-30 19:32:40 +00:00
### Output style
You can use the `--style` option to control the appearance of `bat` s output.
You can use `--style=numbers,changes` , for example, to show only Git changes
2018-11-11 13:28:18 +00:00
and line numbers but no grid and no file header. Set the `BAT_STYLE` environment
variable to make these changes permanent or use `bat` s
[configuration file ](https://github.com/sharkdp/bat#configuration-file ).
2018-05-30 19:32:40 +00:00
2018-08-19 08:49:09 +00:00
### Adding new syntaxes / language definitions
2018-05-30 19:32:40 +00:00
2018-05-07 18:06:01 +00:00
`bat` uses the excellent [`syntect` ](https://github.com/trishume/syntect/ )
library for syntax highlighting. `syntect` can read any
[Sublime Text `.sublime-syntax` file ](https://www.sublimetext.com/docs/3/syntax.html )
2018-08-19 08:49:09 +00:00
and theme. To add new syntax definitions, do the following.
2018-04-30 14:03:33 +00:00
2018-08-19 08:49:09 +00:00
Create a folder with syntax definition files:
2018-05-02 20:21:56 +00:00
2018-05-30 18:40:02 +00:00
```bash
2019-02-07 21:37:12 +00:00
mkdir -p "$(bat --config-dir)/syntaxes"
cd "$(bat --config-dir)/syntaxes"
2018-04-30 14:03:33 +00:00
2018-08-19 08:49:09 +00:00
# Put new '.sublime-syntax' language definition files
# in this folder (or its subdirectories), for example:
git clone https://github.com/tellnobody1/sublime-purescript-syntax
2018-04-30 14:03:33 +00:00
```
2018-08-19 08:49:09 +00:00
Now use the following command to parse these files into a binary cache:
2018-05-02 20:21:56 +00:00
2018-05-30 18:40:02 +00:00
```bash
2019-02-07 21:31:37 +00:00
bat cache --build
2018-05-08 17:48:10 +00:00
```
2018-08-19 08:49:09 +00:00
Finally, use `bat --list-languages` to check if the new languages are available.
2018-05-30 18:40:02 +00:00
2018-05-08 17:48:10 +00:00
If you ever want to go back to the default settings, call:
2018-05-30 18:40:02 +00:00
```bash
2018-05-08 17:48:10 +00:00
bat cache --clear
2018-04-30 14:03:33 +00:00
```
2018-05-20 22:28:30 +00:00
2018-08-19 08:49:09 +00:00
### Adding new themes
This works very similar to how we add new syntax definitions.
First, create a folder with the new syntax highlighting themes:
```bash
2019-02-07 21:37:12 +00:00
mkdir -p "$(bat --config-dir)/themes"
cd "$(bat --config-dir)/themes"
2018-08-19 08:49:09 +00:00
# Download a theme in '.tmTheme' format, for example:
git clone https://github.com/greggb/sublime-snazzy
# Update the binary cache
2019-02-07 21:31:37 +00:00
bat cache --build
2018-08-19 08:49:09 +00:00
```
Finally, use `bat --list-themes` to check if the new themes are available.
2018-08-18 18:22:11 +00:00
### Using a different pager
`bat` uses the pager that is specified in the `PAGER` environment variable. If this variable is not
set, `less` is used by default. If you want to use a different pager, you can either modify the
`PAGER` variable or set the `BAT_PAGER` environment variable to override what is specified in
2018-09-26 16:08:24 +00:00
`PAGER` .
2018-10-20 12:54:44 +00:00
If you want to pass command-line arguments to the pager, you can also set them via the
`PAGER` /`BAT_PAGER` variables:
2018-08-18 18:22:11 +00:00
```bash
2018-10-20 12:54:44 +00:00
export BAT_PAGER="less -RF"
2018-08-18 18:22:11 +00:00
```
2018-11-11 13:28:18 +00:00
Instead of using environment variables, you can also use `bat` s [configuration file ](https://github.com/sharkdp/bat#configuration-file ) to configure the pager (`--pager` option).
2018-11-26 03:01:14 +00:00
**Note**: By default, if the pager is set to `less` (and no command-line options are specified),
2019-12-23 09:00:57 +00:00
`bat` will pass the following command line options to the pager: `-R` /`--RAW-CONTROL-CHARS`,
`-F` /`--quit-if-one-screen` and `-X` /`--no-init`. The last option (`-X`) is only used for `less`
versions older than 530.
The `-R` option is needed to interpret ANSI colors correctly. The second option (`-F`) instructs
2018-09-26 16:03:46 +00:00
less to exit immediately if the output size is smaller than the vertical size of the terminal.
This is convenient for small files because you do not have to press `q` to quit the pager. The
third option (`-X`) is needed to fix a bug with the `--quit-if-one-screen` feature in old versions
2019-12-23 09:00:57 +00:00
of `less` . Unfortunately, it also breaks mouse-wheel support in `less` .
2018-09-26 16:03:46 +00:00
2019-12-23 09:00:57 +00:00
If you want to enable mouse-wheel scrolling on older versions of `less` , you can pass just `-R` (as
in the example above, this will disable the quit-if-one-screen feature). For less 530 or newer,
it should work out of the box.
2018-09-26 16:03:46 +00:00
2020-07-08 15:36:55 +00:00
### Indentation
`bat` expands tabs to 4 spaces by itself, not relying on the pager. To change this, simply add the
`--tabs` argument with the number of spaces you want to be displayed.
**Note**: Defining tab stops for the pager (via the `--pager` argument by `bat` , or via the `LESS`
environment variable for `less` ) won't be taken into account because the pager will already get
expanded spaces instead of tabs. This behaviour is added to avoid indentation issues caused by the
sidebar. Calling `bat` with `--tabs=0` will override it and let tabs be consumed by the pager.
2019-09-15 12:53:34 +00:00
### Dark mode
If you make use of the dark mode feature in macOS, you might want to configure `bat` to use a different
2020-04-21 20:11:07 +00:00
theme based on the OS theme. The following snippet uses the `default` theme when in the _dark mode_
and the `GitHub` theme when in the _light mode_ .
2019-09-15 12:53:34 +00:00
2019-09-15 13:54:34 +00:00
```bash
2019-09-15 12:53:34 +00:00
alias cat="bat --theme=\$(defaults read -globalDomain AppleInterfaceStyle & > /dev/null && echo default || echo GitHub)"
```
2018-11-11 13:28:18 +00:00
## Configuration file
2018-11-04 17:52:03 +00:00
2018-11-11 13:39:04 +00:00
`bat` can also be customized with a configuration file. The location of the file is dependent
on your operating system. To get the default path for your system, call
2018-11-11 10:07:38 +00:00
```
bat --config-file
```
2018-11-04 17:52:03 +00:00
2018-11-11 13:39:04 +00:00
Alternatively, you can use the `BAT_CONFIG_PATH` environment variable to point `bat` to a
non-default location of the configuration file:
2018-11-07 16:31:23 +00:00
```bash
2018-11-11 10:07:38 +00:00
export BAT_CONFIG_PATH="/path/to/bat.conf"
2018-11-07 16:31:23 +00:00
```
2018-11-04 17:52:03 +00:00
2020-03-26 02:05:01 +00:00
A default configuration file can be created with the `--generate-config-file` option.
```bash
bat --generate-config-file
```
2018-11-11 13:28:18 +00:00
### Format
2018-11-04 17:52:03 +00:00
2018-11-11 10:07:38 +00:00
The configuration file is a simple list of command line arguments. Use `bat --help` to see a full list of possible options and values. In addition, you can add comments by prepending a line with the `#` character.
2018-11-04 17:52:03 +00:00
2018-11-11 10:07:38 +00:00
Example configuration file:
2018-11-07 16:31:23 +00:00
```bash
2018-11-04 17:52:03 +00:00
# Set the theme to "TwoDark"
--theme="TwoDark"
2018-11-07 16:31:23 +00:00
# Show line numbers, Git modifications and file header (but no grid)
--style="numbers,changes,header"
2018-11-11 11:17:15 +00:00
# Use italic text on the terminal (not supported on all terminals)
--italic-text=always
2020-03-22 09:37:18 +00:00
# Use C++ syntax for .ino files
--map-syntax "*.ino:C++"
2018-11-07 16:31:23 +00:00
2020-03-22 09:37:18 +00:00
# Use ".gitignore"-style highlighting for ".ignore" files
--map-syntax ".ignore:Git Ignore"
2018-11-04 17:52:03 +00:00
```
2018-09-08 08:31:33 +00:00
## Using `bat` on Windows
2020-03-04 09:04:49 +00:00
`bat` mostly works out-of-the-box on Windows, but a few features may need extra configuration.
2018-09-08 08:31:33 +00:00
2020-07-05 01:43:04 +00:00
### Prerequisites
You will need to install the [Visual C++ Redistributable ](https://support.microsoft.com/en-us/help/2977003/the-latest-supported-visual-c-downloads ) package.
2018-09-08 08:31:33 +00:00
### Paging
Windows only includes a very limited pager in the form of `more` . You can download a Windows binary
for `less` [from its homepage ](http://www.greenwoodsoftware.com/less/download.html ) or [through
Chocolatey](https://chocolatey.org/packages/Less). To use it, place the binary in a directory in
2019-04-10 12:23:46 +00:00
your `PATH` or [define an environment variable ](#using-a-different-pager ). The [Chocolatey package ](#on-windows ) installs `less` automatically.
2018-09-08 08:31:33 +00:00
2018-11-18 11:11:07 +00:00
### Colors
2018-09-08 08:31:33 +00:00
2018-11-18 11:11:07 +00:00
Windows 10 natively supports colors in both `conhost.exe` (Command Prompt) and PowerShell since
2018-09-08 08:31:33 +00:00
[v1511 ](https://en.wikipedia.org/wiki/Windows_10_version_history#Version_1511_(November_Update )), as
well as in newer versions of bash. On earlier versions of Windows, you can use
[Cmder ](http://cmder.net/ ), which includes [ConEmu ](https://conemu.github.io/ ).
2018-11-18 11:11:07 +00:00
**Note:** The Git and MSYS versions of `less` do not correctly interpret colors on Windows. If you
2018-09-08 08:31:33 +00:00
don’ t have any other pagers installed, you can disable paging entirely by passing `--paging=never`
or by setting `BAT_PAGER` to an empty string.
2018-09-14 16:11:40 +00:00
### Cygwin
2018-10-09 15:11:13 +00:00
`bat` on Windows does not natively support Cygwin's unix-style paths (`/cygdrive/*`). When passed an absolute cygwin path as an argument, `bat` will encounter the following error: `The system cannot find the path specified. (os error 3)`
2018-09-14 16:11:40 +00:00
This can be solved by creating a wrapper or adding the following function to your `.bash_profile` file:
2019-09-18 20:43:32 +00:00
```bash
2018-09-14 16:11:40 +00:00
bat() {
local index
local args=("$@")
for index in $(seq 0 ${#args[@]}) ; do
case "${args[index]}" in
-*) continue;;
*) [ -e "${args[index]}" ] & & args[index]="$(cygpath --windows "${args[index]}")";;
esac
done
command bat "${args[@]}"
}
```
2018-08-28 20:08:34 +00:00
## Troubleshooting
### Terminals & colors
2020-07-19 20:49:10 +00:00
`bat` handles terminals *with* and *without* truecolor support. However, the colors in most syntax
highlighting themes are not optimized for 8-bit colors. It is therefore strongly recommended
that you use a terminal with 24-bit truecolor support (`terminator`, `konsole` , `iTerm2` , ...),
or use one of the basic [8-bit themes ](#8-bit-themes ) designed for a restricted set of colors.
2018-08-28 20:08:34 +00:00
See [this article ](https://gist.github.com/XVilka/8346728 ) for more details and a full list of
terminals with truecolor support.
Make sure that your truecolor terminal sets the `COLORTERM` variable to either `truecolor` or
`24bit` . Otherwise, `bat` will not be able to determine whether or not 24-bit escape sequences
are supported (and fall back to 8-bit colors).
2018-09-03 20:12:41 +00:00
### Line numbers and grid are hardly visible
Please try a different theme (see `bat --list-themes` for a list). The `OneHalfDark` and
`OneHalfLight` themes provide grid and line colors that are brighter.
2019-10-11 18:37:08 +00:00
### File encodings
`bat` natively supports UTF-8 as well as UTF-16. For every other file encoding, you may need to
convert to UTF-8 first because the encodings can typically not be auto-detected. You can `iconv`
to do so.
Example: if you have a PHP file in Latin-1 (ISO-8859-1) encoding, you can call:
``` bash
iconv -f ISO-8859-1 -t UTF-8 my-file.php | bat
```
Note: you might have to use the `-l` /`--language` option if the syntax can not be auto-detected
by `bat` .
2018-08-28 19:03:03 +00:00
## Development
```bash
# Recursive clone to retrieve all submodules
git clone --recursive https://github.com/sharkdp/bat
# Build (debug version)
cd bat
2019-10-06 08:03:54 +00:00
cargo build --bins
2018-08-28 19:03:03 +00:00
# Run unit tests and integration tests
cargo test
# Install (release version)
2020-10-04 05:39:17 +00:00
cargo install --path . --locked
2018-08-28 19:03:03 +00:00
# Build a bat binary with modified syntaxes and themes
bash assets/create.sh
2020-10-04 05:39:17 +00:00
cargo install --path . --locked --force
2018-08-28 19:03:03 +00:00
```
2019-09-07 06:57:07 +00:00
## Maintainers
- [sharkdp ](https://github.com/sharkdp )
- [eth-p ](https://github.com/eth-p )
2020-10-05 21:11:10 +00:00
- [keith-hall ](https://github.com/keith-hall )
2019-09-07 06:57:07 +00:00
2018-05-20 22:28:30 +00:00
## Project goals and alternatives
`bat` tries to achieve the following goals:
- Provide beautiful, advanced syntax highlighting
- Integrate with Git to show file modifications
- Be a drop-in replacement for (POSIX) `cat`
- Offer a user-friendly command-line interface
There are a lot of alternatives, if you are looking for similar programs. See
[this document ](doc/alternatives.md ) for a comparison.
2020-01-18 15:00:35 +00:00
## License
Copyright (c) 2018-2020 [bat-developers ](https://github.com/sharkdp/bat ).
2020-08-27 11:51:09 +00:00
`bat` is made available under the terms of either the MIT License or the Apache License 2.0, at your option.
2020-01-18 15:00:35 +00:00
See the [LICENSE-APACHE ](LICENSE-APACHE ) and [LICENSE-MIT ](LICENSE-MIT ) files for license details.