NAME

cat-v - 非印刷文字を可視化する

SYNOPSIS

cat-v [ オプション ] args ...

OPTIONS
   -n   --reset         Disable all character conversion
   -c   --visible=#     Specify visualize characters
   -r   --repeat=#      Specify repeat characters
   -R   --replicate     Replicate original line as is
   -t   --expand[=#]    Expand tabs
   -T   --no-expand     Do not expand tabs
  --ts  --tabstyle=#    Set tab style
        --tabstop=#     Set tab width
        --tabhead=#     Set tab-head character
        --tabspace=#    Set tab-space character
   -h   --help          Print this message
   -v   --version       Print version

OPTIONS FOR EACH CHARACTERS
  --esc                 Enable escape
  --esc=c               Show escape in control format
  --esc=+c              Show escape in control format and reproduce
  --nl=0                Disable newline
  --sp=~                Convert spaces to tilde
  --sp='OPEN BOX'       Unicode name
  --esc=+U+035B         Unicode code point

VERSION

Version 1.01

DESCRIPTION

cat -vコマンドは、表示できない文字を表示するためによく使われるが、ASCII以外の文字をすべて変換してしまうため、最新のアプリケーションの出力を表示するには必ずしも適していません。

cat-vコマンドは、表示可能なグラフィック文字の表示を維持したまま、空白文字と制御文字を可視化します。

また、デフォルトではエスケープ文字は変換されないので、ANSIエスケープシーケンスによる装飾は保持されます。

空白文字を可視化することが望ましい場合もあります。cat -tコマンドはタブ文字を視覚化できるが、問題は視覚的な書式を壊してしまうことです。書式を保持したまま、どの部分がタブでどの部分が空白文字なのかを確認したい場合があります。行末の余分な空白文字も、視覚化することで気づくことができます。

cat-vを使うと、タブ文字は表示上のスペースが変わらないように視覚化されます。

制御文字は、制御フォーマットとユニコード記号文字で表示できます。デフォルトでは、改行文字とエスケープ文字以外の制御文字は、対応するユニコード記号として表示されます。

2番目のフィールドはデフォルトの動作です。sは記号、mはUnicodeマーク、0は無変換を表します。

nul   s  \000  \x{2400}  ␀  SYMBOL FOR NULL
soh   s  \001  \x{2401}  ␁  SYMBOL FOR START OF HEADING
stx   s  \002  \x{2402}  ␂  SYMBOL FOR START OF TEXT
etx   s  \003  \x{2403}  ␃  SYMBOL FOR END OF TEXT
eot   s  \004  \x{2404}  ␄  SYMBOL FOR END OF TRANSMISSION
enq   s  \005  \x{2405}  ␅  SYMBOL FOR ENQUIRY
ack   s  \006  \x{2406}  ␆  SYMBOL FOR ACKNOWLEDGE
bel   s  \007  \x{2407}  ␇  SYMBOL FOR BELL
bs    s  \010  \x{2408}  ␈  SYMBOL FOR BACKSPACE
ht    s  \011  \x{2409}  ␉  SYMBOL FOR HORIZONTAL TABULATION
nl    m  \012  \x{240A}  ␊  SYMBOL FOR LINE FEED
vt    s  \013  \x{240B}  ␋  SYMBOL FOR VERTICAL TABULATION
np    m  \014  \x{240C}  ␌  SYMBOL FOR FORM FEED
cr    s  \015  \x{240D}  ␍  SYMBOL FOR CARRIAGE RETURN
so    s  \016  \x{240E}  ␎  SYMBOL FOR SHIFT OUT
si    s  \017  \x{240F}  ␏  SYMBOL FOR SHIFT IN
dle   s  \020  \x{2410}  ␐  SYMBOL FOR DATA LINK ESCAPE
dc1   s  \021  \x{2411}  ␑  SYMBOL FOR DEVICE CONTROL ONE
dc2   s  \022  \x{2412}  ␒  SYMBOL FOR DEVICE CONTROL TWO
dc3   s  \023  \x{2413}  ␓  SYMBOL FOR DEVICE CONTROL THREE
dc4   s  \024  \x{2414}  ␔  SYMBOL FOR DEVICE CONTROL FOUR
nak   s  \025  \x{2415}  ␕  SYMBOL FOR NEGATIVE ACKNOWLEDGE
syn   s  \026  \x{2416}  ␖  SYMBOL FOR SYNCHRONOUS IDLE
etb   s  \027  \x{2417}  ␗  SYMBOL FOR END OF TRANSMISSION BLOCK
can   s  \030  \x{2418}  ␘  SYMBOL FOR CANCEL
em    s  \031  \x{2419}  ␙  SYMBOL FOR END OF MEDIUM
sub   s  \032  \x{241A}  ␚  SYMBOL FOR SUBSTITUTE
esc   0  \033  \x{241B}  ␛  SYMBOL FOR ESCAPE
fs    s  \034  \x{241C}  ␜  SYMBOL FOR FILE SEPARATOR
gs    s  \035  \x{241D}  ␝  SYMBOL FOR GROUP SEPARATOR
rs    s  \036  \x{241E}  ␞  SYMBOL FOR RECORD SEPARATOR
us    s  \037  \x{241F}  ␟  SYMBOL FOR UNIT SEPARATOR
sp    m  \040  \x{2420}  ␠  SYMBOL FOR SPACE
del   s  \177  \x{2421}  ␡  SYMBOL FOR DELETE
nbsp  s  \240  \x{2423}  ␣  OPEN BOX

現時点では、Unicodeマークは以下の文字で利用可能です。

nul   \x{2205}  ∅  EMPTY SET
bel   \x{237E}  ⍾  BELL SYMBOL
nl    \x{23CE}  ⏎  RETURN SYMBOL
np    \x{2398}  ⎘  NEXT PAGE
sp    \x{00B7}  ·  MIDDLE DOT
del   \x{232B}  ⌫  ERASE TO THE LEFT

OPTIONS

-n, --reset

すべての文字変換を無効にし、繰り返し文字をリセットします。

-c, --visible name=flag,...

可視化する文字と変換形式を指定するために、パラメータとして文字タイプとフラグを与えます。

c  control style
s  symbol style
m  Unicode mark (if exists)
0  do not convert
*  non-alphanumeric char is used as a replacement

オプション -c nl=1 は、改行文字を可視化するのにも使えます。改行文字の場合のみ、変換結果を表示した後、元の文字も同時に出力されます。

文字の種類で指定するには、上のリストの名前を使う。タブを変換せずにエスケープを変換したい場合は、次のようにします。

cat-v -c tab=0 -c esc=s

複数の項目を同時に指定することができます。以下の例では、tabbelを0に、escsに設定しています。

cat-v -c tab=bel=0,esc=s

名前に all を指定すると、その値はすべての文字タイプに適用されます。次のコマンドは、すべての文字をsに設定し、nlnlnpspmに設定し、escを無効にします。これがデフォルトの状態です。

cat-v -c all=s,nul=nl=np=sp=m,esc=0
--name[=replacement]

すべての制御文字は、その名前を持つオプションでアクセスすることもできます。例えば、オプション --nl は改行文字のために定義されています。

単独で使用すると、この文字の可視性が有効になります。

cat-v --nl

無効にするには0を指定します。

cat-v --nl=0

アルファベットや数字以外の文字が指定された場合は、その文字に置き換えられます。

cat-v --nl='$'

2文字以上の文字列が指定された場合、Unicode文字名として解釈されます。

cat-v --nl='RETURN SYMBOL' --sp='MIDDLE DOT'

フラグが+で始まる場合、その文字はリピートリストに追加されます。

cat-v --esc=+s

つまり、上記のコマンドは、次のように書いたのと同じ意味になります。

cat-v --esc=s --repeat +esc
--repeat=name[,name...]

変換後の文字と同時に元の文字を出力する文字種を指定します。デフォルトはnl,npです。以下のようにすると、エスケープ文字が可視化された元のANSIシーケンスが正しく出力されます。

cat-v -c esc --repeat esc,nl

name+ で始まる場合は、既存の設定に加えてその文字を追加します。

cat-v -c esc --repeat +esc
-R, --replicate

変換後の文字列を出力する前に、まず元の文字列を出力します。

-t[n], --expand[=n]
-T, --no-expand

タブ文字はデフォルトで展開されます。明示的に無効にするには、-Tまたは--no-expandオプションを使用します。

-tオプションに任意の数字が与えられた場合、それはタブ幅として扱われます。次の2つのコマンドは等価である:

cat-v -t4
cat-v -t --tabstop=4

デフォルトではneedleスタイルが適用され、--tabstyleで変更できます。--tabstyle オプションが引数なしで指定された場合、利用可能なスタイルのリストが表示されます。

~/.cat-vrcファイルに以下の設定を記述することで、デフォルトでタブ展開を無効にすることができます。

option default --no-expand

その場合、-tオプションで一時的にタブ展開を有効にすることができます。

--tabstop=# (DEFAULT: 8)

タブ幅を設定します。

--tabhead=#
--tabspace=#

タブヘッドとそれに続くスペース文字を設定します。オプ シ ョ ン値が 1 文字 よ り 長い場合は、 unicode 名 と し て評価 さ れます。

--tabstyle, --ts
--tabstyle=style, --ts=...
--tabstyle=head-style,space-style --ts=...

タブの展開方法を設定します。例えば、記号またはを選択します。squat-arrow,middle-dotのように2つのスタイル名を組み合わせた場合、タブヘッドにはsquat-arrowを、タブスペースにはmiddle-dotを使用します。

パラメータなしで呼ばれた場合、利用可能なスタイルリストを表示します。スタイルは Text::ANSI::Fold ライブラリで定義されています。

INSTALL

CPANMINUS

CPANアーカイブから:

cpanm App::cat::v

GITリポジトリから

cpanm https://github.com/tecolicom/App-cat-v.git

SEE ALSO

https://github.com/tecolicom/App-cat-v.git

Gitリポジトリ。

App::optex::util::filter

cat-vコマンドの前身は、もともとApp::optexコマンドのフィルタモジュールとして作られたものです。

AUTHOR

Kazumasa Utashiro

LICENSE

Copyright © 2024 Kazumasa Utashiro.

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.