Skip to content

Latest commit

 

History

History
651 lines (453 loc) · 25.3 KB

README-ja.md

File metadata and controls

651 lines (453 loc) · 25.3 KB

bat - a cat clone with wings
Build Status license Version info
シンタックスハイライトとGitとの連携機能付きの cat(1) クローン。

特徴使い方インストールカスタマイズプロジェクトの目標と既存の類似したOSS
[English] [中文] [日本語] [한국어] [Русский]

シンタックスハイライト

bat は多くのプログラミング言語やマークアップ言語の シンタックスハイライトに対応しています:

Syntax highlighting example

Gitの統合

batgit とも連携しており、差分を表現する記号が表示されます (図の左端):

Git integration example

印刷できない文字の表示

-A/--show-all オプションをつけることで 印刷できない文字を可視化できます:

Non-printable character example

自動ページング

出力が1つの画面に対して大きすぎる場合、bat は自身の出力をページャー(例えば less) にパイプで繋げます。

ファイルの連結

あなたはさらにファイルを連結させるために使うことも可能です:wink:。 bat は非対話型のターミナルを検出すると(すなわち他のプロセスにパイプしたりファイル出力していると)、 batcat の完全互換として振る舞い、 プレーンなファイルを表示します。

使い方

単一のファイルを表示させたい場合

> bat README.md

複数のファイルを一度に表示させたい場合

> bat src/*.rs

標準入力から自動的に構文を決定させたい場合(ハイライトされるのは、 たいていは #!/bin/sh のようなシバンを利用して、 ファイルの一行目から構文を決定できる場合のみです)

> curl -s https://sh.rustup.rs | bat

標準入力から明示的に言語を指定したい場合

> yaml2json .travis.yml | json_pp | bat -l json

空白文字を可視化させたい場合:

> bat -A /etc/hosts

cat の代わりに bat を使用する際の例:

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)

bat f - g  # output 'f', then stdin, then 'g'.

他のツールとの統合

fzf

fzf のプレビューウィンドウに bat を使用できます。 その場合、bat--color=always オプションを用いてカラー出力を強制しなければなりません。 また、--line-range オプションを用いることで巨大なファイルの読み込み時間を制限できます:

fzf --preview 'bat --color=always --style=numbers --line-range=:500 {}'

詳しくは fzfREADME を参照してください。

find or fd

find-exec オプションを使用して、bat ですべての検索結果をプレビューできます:

find … -exec bat {} +

fd を使用している場合は、-X /-exec-batch オプションを使用して同じことを行うことができます:

fd … -X bat

ripgrep

batgrep では、ripgrep 検索結果のプリンターとして bat を使用できます。

batgrep needle src/

tail -f

battail -f と組み合わせて、構文強調表示を使用して特定のファイルを継続的に監視できます。

tail -f /var/log/pacman.log | bat --paging=never -l log

注意事項:tail -fと組み合わせるには、ページングをオフにしなければなりません。また、この場合は構文が自動検出されないため、明示的に指定(-l log)しています。

git

batgit show と組み合わせて、 適切な構文強調表示を使用して特定のファイルの古いバージョンを表示できます:

git show v0.6.0:src/main.rs | bat -l rs

差分内の構文強調表示は現在サポートされていないことに注意してください。 これを探しているなら、delta をチェックしてください。

xclip

bat の出力の行番号と Git 変更マーカーにより、ファイルの内容をコピーするのが難しくなる場合があります。 これを防ぐには、-p / -plain オプションを使用して bat を呼び出すか、 単に出力を xclip にパイプします:

bat main.cpp | xclip

bat は出力がリダイレクトされていることを検出し、プレーンファイルの内容を出力します。

man

batMANPAGER 環境変数を設定することにより、 man の色付けページャーとして使用できます:

export MANPAGER="sh -c 'col -bx | bat -l man -p'"
man 2 select

フォーマットの問題が発生した場合は MANROFFOPT="-c" を設定する必要もあります。

これを新しいコマンドにバンドルしたい場合は batman も使用できます。

Manpage syntax はこのリポジトリで開発されており、まだ作業が必要であることに注意してください。

prettier / shfmt / rustfmt

prettybat スクリプトは、コードをフォーマットし、bat で印刷するラッパーです。

インストール

Packaging status

On Ubuntu (apt を使用)

... や他のDebianベースのLinuxディストリビューション

20.04 ("Focal") 以降の Ubuntu または 2021 年 8 月以降の Debian (Debian 11 - "Bullseye") では bat パッケージが利用できます。

apt install bat

apt を使用して bat をインストールした場合、実行可能ファイルの名前が bat ではなく batcat になることがあります(他のパッケージとの名前衝突のため)。bat -> batcat のシンボリックリンクまたはエイリアスを設定することで、実行可能ファイル名が異なることによる問題の発生を防ぎ、他のディストリビューションと一貫性を保てます。

mkdir -p ~/.local/bin
ln -s /usr/bin/batcat ~/.local/bin/bat

On Ubuntu (最新の .deb パッケージを使用)

*... や他のDebianベースのLinuxディストリビューション

batの最新リリースを実行する場合、または Ubuntu/Debian の古いバージョンを使用している場合は、release page から最新の .deb パッケージをダウンロードし、 次の方法でインストールします:

sudo dpkg -i bat_0.18.3_amd64.deb  # adapt version number and architecture

On Alpine Linux

適切なリポジトリが有効になっている場合は、 公式のソースから bat package をインストールできます:

apk add bat

On Arch Linux

Arch Linuxの公式リソース からインストールできます。

pacman -S bat

On Fedora

公式の Fedora Modular リポジトリから the bat package をインストールできます。

dnf install bat

On Gentoo Linux

公式ソースから the bat package をインストールできます。

emerge sys-apps/bat

On Void Linux

xbps-install経由で bat をインストールできます。

xbps-install -S bat

On FreeBSD

pkg を使用してプリコンパイルされた bat package をインストールできます:

pkg install bat

または FreeBSD ポートから自分でビルドすることもできます:

cd /usr/ports/textproc/bat
make install

Via nix

batnix package manager 経由でインストールすることができます:

nix-env -i bat

On openSUSE

bat をzypperでインストールすることができます:

zypper install bat

On macOS

Homebrewbat をインストールできます:

brew install bat

または MacPortsbat をインストールします:

port install bat

On Windows

Windowsにbatをインストールするいくつかのオプションがあります。 batをインストールしたら Windowsでのbatの使用 セクションをご覧ください。

With Chocolatey

Chocolatey から bat をインストールできます:

choco install bat

With Scoop

scoop から bat をインストールできます:

scoop install bat

Visual C ++再頒布可能 パッケージをインストールする必要があります。

From prebuilt binaries:

リリースページ からビルド済みのバイナリをダウンロードできます。

Visual C ++再頒布可能 パッケージをインストールする必要があります。

Via Docker

コンテナ内で bat を使いたい方のために Docker image が用意されています:

docker pull danlynn/bat
alias bat='docker run -it --rm -e BAT_THEME -e BAT_STYLE -e BAT_TABS -v "$(pwd):/myapp" danlynn/bat'

Via Ansible

Ansible でインストールすることができます:

# Install role on local machine
ansible-galaxy install aeimer.install_bat
---
# Playbook to install bat
- host: all
  roles:
    - aeimer.install_bat

これは以下のディストリビューションで動作するはずです:

  • Debian/Ubuntu
  • ARM (eg. Raspberry PI)
  • Arch Linux
  • Void Linux
  • FreeBSD
  • MacOS

From binaries

多くの異なるアーキテクチャのためのプレビルドバージョンをリリースページからチェックしてみてください。静的にリンクされている多くのバイナリも利用できます: ファイル名に musl を含むアーカイブを探してみてください。

From source

bat をソースからビルドしたいならば、Rust 1.64.0 以上の環境が必要です。 cargo を使用してビルドすることができます:

cargo install --locked bat

一部のプラットフォームでは llvm および/または libclang-dev のインストールが必要になる場合があります。

カスタマイズ

ハイライト テーマ

bat --list-themes を使うと現在利用可能なシンタックスハイライトのテーマを入手できます。 TwoDark テーマを選ぶためには --theme=TwoDark オプションをつけるか BAT_THEME という環境変数に TwoDark を代入する必要があります。 シェルの起動ファイルに export BAT_THEME="TwoDark" と定義すればその設定が変わることはないでしょう。あるいは、 bat設定ファイルを利用してください。

カスタムファイルでさまざまなテーマをプレビューする場合は、 次のコマンドを使用できます(これには fzf が必要です)。

bat --list-themes | fzf --preview="bat --theme={} --color=always /path/to/file"

bat はデフォルトだと黒い背景色のターミナルに適しています。 しかし、GitHubOneHalfLight のような白い背景色のテーマでもいい感じにすることができます。 '新しいテーマの追加' セクションに従って カスタムテーマを使用することもできます。

出力のスタイル

--style を使うことで bat の表示の見た目を変更することができます。 例えば、 --style=numbers,changes と入力します。 すると、Gitの差分と行番号だけが表示され、グリッド線とファイルヘッダーは表示されません。 環境変数に BAT_STYLE を定義するとこれらの設定を永続的に使用することができます。 設定ファイル を参考にしても良いでしょう。

新しい構文の追加 / 言語の定義

bat はシンタックスハイライトのための syntect という素晴らしいライブラリを使用しています。syntect は、 Sublime Text の .sublime-syntax ファイル とテーマを読み取ることができます。新しい構文を定義するために以下の手順を行います。

構文定義ファイルを入れておくためのフォルダを作ります:

mkdir -p "$(bat --config-dir)/syntaxes"
cd "$(bat --config-dir)/syntaxes"

# Put new '.sublime-syntax' language definition files
# in this folder (or its subdirectories), for example:
git clone https://github.com/tellnobody1/sublime-purescript-syntax

次のコマンドを使用して、これらのファイルをバイナリキャッシュに解析します:

bat cache --build

最後に bat --list-languages と入力すると新しい言語が利用可能かどうかチェックします。

デフォルトの設定に戻したいときは以下のコマンドを実行します:

bat cache --clear

新しいテーマの追加

これは構文を新しく定義するやり方と非常に似ています。

まず、新しいシンタックスハイライトのテーマのフォルダを作ります:

mkdir -p "$(bat --config-dir)/themes"
cd "$(bat --config-dir)/themes"

# Download a theme in '.tmTheme' format, for example:
git clone https://github.com/greggb/sublime-snazzy

# Update the binary cache
bat cache --build

最後に、 bat --list-themes で新しいテーマが利用可能かチェックします

異なるページャーの使用

bat は環境変数 PAGER に使用するページャーを明記します。 この環境変数が定義されていない場合、デフォルトで less が使用されます。 もし、異なるページャーを使用したい場合は、PAGER を修正してください。 または、PAGER を上書きする環境変数として BAT_PAGER を定義することも可能です。

もし、ページャーにコマンドライン引数を渡したい場合は、 PAGER/BAT_PAGER 環境変数を定義してください:

export BAT_PAGER="less -RF"

環境変数を利用する代わりに、 bat設定ファイル を使用して設定も可能です(--pager オプション)

注意: デフォルトにより、ページャーが less にセットされているならば bat はページャーの以下のコマンドラインオプション を受け付けるでしょう: -R/--RAW-CONTROL-CHARS, -F/--quit-if-one-screen そして -X/--no-init。 最後のオプション(-X)は、530 より古いバージョンにのみ使用されます。

-R オプションは、ANSIカラーを正しく解釈するために必要です。 2番目のオプション(-F)は、出力サイズが端末の垂直サイズよりも小さい場合、すぐに終了するようにlessに指示します。 これは、ページャーを終了するために q を押す必要がないため、小さなファイルに便利です。 3番目のオプション(-X)は、less の古いバージョンの --quit-if-one-screen 機能のバグを修正するために必要です。 残念ながら、less のマウスホイールのサポートも少なくなります。

less の古いバージョンでマウスホイールのスクロールを有効にしたい場合は、 -R だけを渡すことができます(上記の例のように、これは1画面終了機能を無効にします)。 530以下の場合は、そのまま使用できます。

Dark mode

macOSでダークモード機能を使用する場合、OSテーマに基づいて異なるテーマを使用するように bat を構成することができます。 次のスニペットは、ライトモードの場合は デフォルト のテーマを使用し、 ダークモードの場合は GitHub テーマを使用します。

alias cat="bat --theme=\$(defaults read -globalDomain AppleInterfaceStyle &> /dev/null && echo default || echo GitHub)"

設定ファイル

bat は設定ファイルでカスタマイズすることが可能です。ファイルの場所はOSに依存します。 使用しているOSのデフォルトパスを調べるには以下のコマンドを実行してください:

bat --config-file

または、BAT_CONFIG_PATH 環境変数を使用して、bat が 構成ファイルのデフォルト以外の場所を指すようにすることができます:

export BAT_CONFIG_PATH="/path/to/bat.conf"

フォーマット

この設定ファイルはコマンドライン引数の単純なリストです。 bat --help を利用すると、利用可能なオプションとその値を閲覧することができます。さらに、# でコメント文を加えることができます。

設定ファイルの例:

# Set the theme to "TwoDark"
--theme="TwoDark"

# Show line numbers, Git modifications and file header (but no grid)
--style="numbers,changes,header"

# Use italic text on the terminal (not supported on all terminals)
--italic-text=always

# Use C++ syntax for Arduino .ino files
--map-syntax "*.ino:C++"

# Use ".gitignore"-style highlighting for ".ignore" files
--map-syntax ".ignore:Git Ignore"

Windows での bat の利用

Windows 上で bat はほとんど動作しますが、いくつかの機能は設定を必要をする場合があります。

ページング

Windowsには、more 形式の非常に限られたページャーしか含まれていません。 less 用のWindowsバイナリは、ホームページ または Chocolatey からダウンロードできます。 これを使用するには、バイナリを PATH のディレクトリに配置するか、環境変数を定義します。Chocolateyパッケージless を自動的にインストールします。

Windows 10では、conhost.exe (コマンドプロンプト)と v1511 以降の PowerShell の両方、 およびbashの新しいバージョンの色がネイティブにサポートされています。 以前のバージョンのWindowsでは、 ConEmu を含む Cmder を使用できます。

注意: Git と MSYS の less はWindows上で色を正しく解釈しません。 もし、あなたが他のページャーをインストールしていないのであれば、 --paging=never オプションを付け加えるか BAT_PAGER に空文字を設定することでページングを完全に無効にできます。

Cygwin

Windows上の bat は Cygwin のunix風のpath(/cygdrive/*)をネイティブサポートしていません。絶対的なcygwinパスを引数として受けたときに、 bat は以下のエラーを返すでしょう: The system cannot find the path specified. (os error 3)

wrapperを作成するか、以下の関数を .bash_profile に追記することで、この問題を解決することができます:

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[@]}"
}

トラブルシューティング

ターミナルと色

bat はターミナルがトゥルーカラーをサポートしている/していないに関係なくサポートします。 しかし、シンタックスハイライトのテーマの色が8-bitカラーに最適化されていない場合、 24-bitであるトゥルーカラーをサポートしているターミナルを使用することを強く推奨します(terminator, konsole, iTerm2, ...)。 この 記事 には 24-bitカラーがサポートされているターミナルの一覧が掲載されています。

本当の色をターミナルにセットするために、環境変数 COLORTERMtruecolor24bit のどちらかを代入してください。さもなければ、bat はどの色を使うのか決定することができません。または、24-bit エスケープシーケンスがサポートされません (そして、8-bit colorに戻ります)。

行番号とグリッド線がほとんど見えない

異なるテーマを試してみてください(bat --list-themes でテーマを閲覧できます)。 OneHalfDarkOneHalfLight テーマはグリッド線と線の色を明るくします。

ファイルエンコーディング

bat は UTF-16 と同様に UTF-8 をネイティブにサポートします。 他のすべてのファイルエンコーディングでは、エンコーディングは通常自動検出できないため、最初に UTF-8 に変換する必要があります。 これを行うには iconv を使用できます。 例: Latin-1(ISO-8859-1)エンコーディングの PHP ファイルがある場合、次のように呼び出すことができます:

iconv -f ISO-8859-1 -t UTF-8 my-file.php | bat

注: bat が構文を自動検出できない場合は -l / -language オプションを使用する必要がある場合があります。

開発

# Recursive clone to retrieve all submodules
git clone --recursive https://github.com/sharkdp/bat

# Build (debug version)
cd bat
cargo build --bins

# Run unit tests and integration tests
cargo test

# Install (release version)
cargo install --locked

# Build a bat binary with modified syntaxes and themes
bash assets/create.sh
cargo install --locked --force

Maintainers

プロジェクトの目標と既存の類似したOSS

bat は以下の目標を達成しようと試みています:

  • 美しく高度なシンタックスハイライトの提供
  • ファイルの差分を表示するためのGitとの連携
  • (POSIX) cat との完全互換
  • ユーザーフレンドリーなコマンドラインインターフェースの提供

あなたが同様のプログラムを探しているなら、多くの選択肢があります。 比較については このドキュメント を参照してください。

ライセンス

Copyright (c) 2018-2021 bat-developers.

bat は MIT License 及び Apache License 2.0 の両方の条件の下で配布されています。

ライセンスの詳細については LICENSE-APACHE 及び LICENSE-MIT ファイルを参照して下さい。