.\"O .TH XZ 1 "2020-02-01" "Tukaani" "XZ Utils"
.\"O .
.TH XZ 1 2020\-02\-01 Tukaani "XZ Utils"
.
.\"O ----------------------------------------
.\"O .SH NAME
.\"O xz, unxz, xzcat, lzma, unlzma, lzcat \- Compress or decompress .xz and .lzma files
.\"O .
.SH 名前
xz, unxz, xzcat, lzma, unlzma, lzcat \- .xz, .lzma ファイルの圧縮、伸長を行います。
.
.\"O ----------------------------------------
.\"O .SH SYNOPSIS
.\"O .B xz
.\"O .RI [ option... ]
.\"O .RI [ file... ]
.\"O .
.SH 書式
\fBxz\fP [\fIoption...\fP] [\fIfile...\fP]
.
.\"O ----------------------------------------
.\"O .SH COMMAND ALIASES
.\"O .B unxz
.\"O is equivalent to
.\"O .BR "xz \-\-decompress" .
.\"O .br
.\"O .B xzcat
.\"O is equivalent to
.\"O .BR "xz \-\-decompress \-\-stdout" .
.\"O .br
.\"O .B lzma
.\"O is equivalent to
.\"O .BR "xz \-\-format=lzma" .
.\"O .br
.\"O .B unlzma
.\"O is equivalent to
.\"O .BR "xz \-\-format=lzma \-\-decompress" .
.\"O .br
.\"O .B lzcat
.\"O is equivalent to
.\"O .BR "xz \-\-format=lzma \-\-decompress \-\-stdout" .
.SH コマンドエイリアス
\fBunxz\fP は \fBxz \-\-decompress\fP と同じです。
.br
\fBxzcat\fP は \fBxz \-\-decompress \-\-stdout\fP と同じです。
.br
\fBlzma\fP は \fBxz \-\-format=lzma\fP と同じです。
.br
\fBunlzma\fP は \fBxz \-\-format=lzma \-\-decompress\fP と同じです。
.br
\fBlzcat\fP は \fBxz \-\-format=lzma \-\-decompress \-\-stdout\fP と同じです。
.\"O ----------------------------------------
.\"O .PP
.\"O When writing scripts that need to decompress files,
.\"O it is recommended to always use the name
.\"O .B xz
.\"O with appropriate arguments
.\"O .RB ( "xz \-d"
.\"O or
.\"O .BR "xz \-dc" )
.\"O instead of the names
.\"O .B unxz
.\"O and
.\"O .BR xzcat .
.\"O .
.PP
ファイル圧縮を行うスクリプトを記述する場合は、\fBunxz\fP や \fBxzcat\fP などを用いるのではなく、常に \fBxz\fP コマンドに適切な引数
(\fBxz \-d\fP or \fBxz \-dc\fP) をつけて利用することをお勧めします。
.
.\"O ----------------------------------------
.\"O .SH DESCRIPTION
.\"O .B xz
.\"O is a general-purpose data compression tool with
.\"O command line syntax similar to
.\"O .BR gzip (1)
.\"O and
.\"O .BR bzip2 (1).
.\"O The native file format is the
.\"O .B .xz
.\"O format, but the legacy
.\"O .B .lzma
.\"O format used by LZMA Utils and
.\"O raw compressed streams with no container format headers
.\"O are also supported.
.SH 説明
\fBxz\fP は汎用目的のデータ圧縮ツールです。コマンドラインには \fBgzip\fP(1) や \fBbzip2\fP(1)
と同等の文法が用いられています。ネイティブなファイルフォーマットは \fB.xz\fP です。さらに LZMA Utils が利用しているこれまでの
\&\fB.lzma\fP フォーマットや、コンテナーフォーマットヘッダーを持たない、生の (raw) 圧縮ストリームにも対応しています。
.\"O ----------------------------------------
.\"O .PP
.\"O .B xz
.\"O compresses or decompresses each
.\"O .I file
.\"O according to the selected operation mode.
.\"O If no
.\"O .I files
.\"O are given or
.\"O .I file
.\"O is
.\"O .BR \- ,
.\"O .B xz
.\"O reads from standard input and writes the processed data
.\"O to standard output.
.\"O .B xz
.\"O will refuse (display an error and skip the
.\"O .IR file )
.\"O to write compressed data to standard output if it is a terminal.
.\"O Similarly,
.\"O .B xz
.\"O will refuse to read compressed data
.\"O from standard input if it is a terminal.
.PP
\fBxz\fP は指定されたオペレーションモードに従って、各 \fIfile\fP の圧縮、伸長を行います。\fIfiles\fP が指定されていない、または \fB\-\fP
と指定された場合、\fBxz\fP
は標準入力からデータを読み込んで、処理結果を標準出力へ書き出します。端末上において圧縮データを標準出力に書き出そうとした場合には、\fBxz\fP
は処理停止します (エラーを表示して \fIfile\fP
の処理をスキップします)。同様に端末上において圧縮データを標準入力から読み込もうとした場合も、\fBxz\fP は処理停止します。
.\"O ----------------------------------------
.\"O .PP
.\"O Unless
.\"O .B \-\-stdout
.\"O is specified,
.\"O .I files
.\"O other than
.\"O .B \-
.\"O are written to a new file whose name is derived from the source
.\"O .I file
.\"O name:
.PP
\fB\-\-stdout\fP の指定がなく \fIfiles\fP が \fB\-\fP でない場合は新規のファイル生成となり、そのファイル名は元の \fIfile\fP
から命名されます。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O When compressing, the suffix of the target file format
.\"O .RB ( .xz
.\"O or
.\"O .BR .lzma )
.\"O is appended to the source filename to get the target filename.
.IP \(bu 3
圧縮時は、目的とするファイルフォーマット (\fB.xz\fP または \fB.lzma\fP)
をサフィックスとして、元のファイル名にこれを加えたファイル名とします。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O When decompressing, the
.\"O .B .xz
.\"O or
.\"O .B .lzma
.\"O suffix is removed from the filename to get the target filename.
.\"O .B xz
.\"O also recognizes the suffixes
.\"O .B .txz
.\"O and
.\"O .BR .tlz ,
.\"O and replaces them with the
.\"O .B .tar
.\"O suffix.
.IP \(bu 3
伸長時は、サフィックス \fB.xz\fP または \fB.lzma\fP を取り除いて、目的のファイル名とします。\fBxz\fP はサフィックスとして \fB.txz\fP
と \fB.tlz\fP も識別します。この場合はサフィックスを \fB.tar\fP として置き換えます。
.\"O ----------------------------------------
.\"O .PP
.\"O If the target file already exists, an error is displayed and the
.\"O .I file
.\"O is skipped.
.PP
目的とするファイルがすでに存在している場合、エラーが表示されて \fIfile\fP に対する処理はスキップされます。
.\"O ----------------------------------------
.\"O .PP
.\"O Unless writing to standard output,
.\"O .B xz
.\"O will display a warning and skip the
.\"O .I file
.\"O if any of the following applies:
.PP
出力先が標準出力でなく、以下のいずれかに該当する場合、\fBxz\fP は警告を表示して \fIfile\fP の処理をスキップします。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O .I File
.\"O is not a regular file.
.\"O Symbolic links are not followed,
.\"O and thus they are not considered to be regular files.
.IP \(bu 3
\fIfile\fP が通常の (regular)
ファイルではない場合。シンボリックリンクをたどることはありません。したがってその場合は通常のファイルではないものとして扱われます。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O .I File
.\"O has more than one hard link.
.IP \(bu 3
\fIfile\fP が複数のハードリンクを持つ場合。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O .I File
.\"O has setuid, setgid, or sticky bit set.
.IP \(bu 3
\fIfile\fP に setuid、setgid、スティッキービット (sticky bit) セットがある場合。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O The operation mode is set to compress and the
.\"O .I file
.\"O already has a suffix of the target file format
.\"O .RB ( .xz
.\"O or
.\"O .B .txz
.\"O when compressing to the
.\"O .B .xz
.\"O format, and
.\"O .B .lzma
.\"O or
.\"O .B .tlz
.\"O when compressing to the
.\"O .B .lzma
.\"O format).
.IP \(bu 3
オペレーションモードが圧縮として設定されていて、\fIfile\fP のサフィックスが目的とするファイルフォーマットにすでになっていた場合 (\fB.xz\fP
への圧縮時にすでに \fB.xz\fP や \fB.txz\fP であった場合、また \fB.lzma\fP への圧縮時にすでに \fB.lzma\fP や \fB.tlz\fP
であった場合)。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O The operation mode is set to decompress and the
.\"O .I file
.\"O doesn't have a suffix of any of the supported file formats
.\"O .RB ( .xz ,
.\"O .BR .txz ,
.\"O .BR .lzma ,
.\"O or
.\"O .BR .tlz ).
.IP \(bu 3
オペレーションモードが伸長として設定されていて、\fIfile\fP のサフィックスが対応しているファイルフォーマット (\fB.xz\fP, \fB.txz\fP,
\&\fB.lzma\fP, \fB.tlz\fP) でない場合。
.\"O ----------------------------------------
.\"O .PP
.\"O After successfully compressing or decompressing the
.\"O .IR file ,
.\"O .B xz
.\"O copies the owner, group, permissions, access time,
.\"O and modification time from the source
.\"O .I file
.\"O to the target file.
.\"O If copying the group fails, the permissions are modified
.\"O so that the target file doesn't become accessible to users
.\"O who didn't have permission to access the source
.\"O .IR file .
.\"O .B xz
.\"O doesn't support copying other metadata like access control lists
.\"O or extended attributes yet.
.PP
\fIfile\fP に対する圧縮または伸長が正常に処理された後は、元のソース \fIfile\fP
の所有者、グループ、パーミッション、アクセス時刻、更新時刻を、目的とするファイルにコピーします。グループ情報のコピーに失敗した場合は、パーミッションを修正して、元のソース
\fIfile\fP にアクセス権を有していなかったユーザーが、目的のファイルにアクセスできないようにします。現状の \fBxz\fP
では、アクセスコントロールリストや拡張属性のようなメタデータのコピーには対応していません。
.\"O ----------------------------------------
.\"O .PP
.\"O Once the target file has been successfully closed, the source
.\"O .I file
.\"O is removed unless
.\"O .B \-\-keep
.\"O was specified.
.\"O The source
.\"O .I file
.\"O is never removed if the output is written to standard output.
.PP
目的とするファイルのクローズ処理が正常終了したら、\fB\-\-keep\fP が指定されていない限り、ソース \fIfile\fP は削除されます。このソース
\fIfile\fP は、出力先が標準出力である場合には削除されません。
.\"O ----------------------------------------
.\"O .PP
.\"O Sending
.\"O .B SIGINFO
.\"O or
.\"O .B SIGUSR1
.\"O to the
.\"O .B xz
.\"O process makes it print progress information to standard error.
.\"O This has only limited use since when standard error
.\"O is a terminal, using
.\"O .B \-\-verbose
.\"O will display an automatically updating progress indicator.
.\"O .
.PP
\fBxz\fP に対して \fBSIGINFO\fP や \fBSIGUSR1\fP
を送信すると、標準エラー出力に対して進捗情報を出力します。この用途は限られています。なぜなら標準エラー出力先が端末である場合、\fB\-\-verbose\fP
を利用すれば進捗インジケーターが自動的に更新されるためです。
.
.\"O ----------------------------------------
.\"O .SS "Memory usage"
.\"O The memory usage of
.\"O .B xz
.\"O varies from a few hundred kilobytes to several gigabytes
.\"O depending on the compression settings.
.\"O The settings used when compressing a file determine
.\"O the memory requirements of the decompressor.
.\"O Typically the decompressor needs 5\ % to 20\ % of
.\"O the amount of memory that the compressor needed when
.\"O creating the file.
.\"O For example, decompressing a file created with
.\"O .B xz \-9
.\"O currently requires 65\ MiB of memory.
.\"O Still, it is possible to have
.\"O .B .xz
.\"O files that require several gigabytes of memory to decompress.
.SS メモリ利用
\fBxz\fP が利用するメモリ量は、圧縮の設定により数 100
キロバイトから数ギガバイトまでとさまざまです。ファイル圧縮時に利用される設定は、ファイル伸長時のメモリ利用を決定づけます。通常、伸長処理に要するメモリ容量は、圧縮処理においてファイル生成に必要となるメモリ容量の
5\ % から 20\ % です。たとえば \fBxz \-9\fP によって圧縮されたファイルを伸長するには、今のところ 65\ MiB
のメモリを要します。ただし \fB.xz\fP ファイルの伸長に数ギガバイトを利用することも可能です。
.\"O ----------------------------------------
.\"O .PP
.\"O Especially users of older systems may find
.\"O the possibility of very large memory usage annoying.
.\"O To prevent uncomfortable surprises,
.\"O .B xz
.\"O has a built-in memory usage limiter, which is disabled by default.
.\"O While some operating systems provide ways to limit
.\"O the memory usage of processes, relying on it
.\"O wasn't deemed to be flexible enough (e.g. using
.\"O .BR ulimit (1)
.\"O to limit virtual memory tends to cripple
.\"O .BR mmap (2)).
.PP
特にかつてのシステムを利用してきたユーザーは、あまりにもメモリが大量に消費されるので、好ましく思わないかもしれません。そのような状況を回避するために
\fBxz\fP
にはビルトインのメモリ制限機能があります。これはデフォルトでは無効化されています。オペレーティングシステムの中には、プロセスのメモリ利用を制限する方法を提供するものがありますが、そこに依存するのは、柔軟性に欠けると考えられてきました
(たとえば \fBulimit\fP(1) を利用して仮想メモリを制限すると、\fBmmap\fP(2) が機能しなくなる傾向にあるなどです)。
.\"O ----------------------------------------
.\"O .PP
.\"O The memory usage limiter can be enabled with
.\"O the command line option \fB\-\-memlimit=\fIlimit\fR.
.\"O Often it is more convenient to enable the limiter
.\"O by default by setting the environment variable
.\"O .BR XZ_DEFAULTS ,
.\"O e.g.\&
.\"O .BR XZ_DEFAULTS=\-\-memlimit=150MiB .
.\"O It is possible to set the limits separately
.\"O for compression and decompression
.\"O by using \fB\-\-memlimit\-compress=\fIlimit\fR and
.\"O \fB\-\-memlimit\-decompress=\fIlimit\fR.
.\"O Using these two options outside
.\"O .B XZ_DEFAULTS
.\"O is rarely useful because a single run of
.\"O .B xz
.\"O cannot do both compression and decompression and
.\"O .BI \-\-memlimit= limit
.\"O (or \fB\-M\fR \fIlimit\fR)
.\"O is shorter to type on the command line.
.PP
メモリ制限機能を有効にするには、コマンドラインオプション \fB\-\-memlimit=\fP\fIlimit\fP を指定します。この制限機能は、環境変数
\fBXZ_DEFAULTS\fP を用いて \& \fBXZ_DEFAULTS=\-\-memlimit=150MiB\fP
のようにしてデフォルトで有効にしておくと、利用しやすくなります。この制限機能は、圧縮時と伸長時のそれぞれに対して
\fB\-\-memlimit\-compress=\fP\fIlimit\fP および \fB\-\-memlimit\-decompress=\fP\fIlimit\fP
を使えば、個別に指定することができます。この 2 つのオプションを \fBXZ_DEFAULTS\fP
以外のところで用いるのは、あまり意味がありません。なぜなら \fBxz\fP が圧縮と伸長を同時に処理することはありえず、また
\fB\-\-memlimit=\fP\fIlimit\fP (あるいは \fB\-M\fP \fIlimit\fP)
と設定しておくことの方が、コマンドラインから入力するよりも短くて済むからです。
.\"O ----------------------------------------
.\"O .PP
.\"O If the specified memory usage limit is exceeded when decompressing,
.\"O .B xz
.\"O will display an error and decompressing the file will fail.
.\"O If the limit is exceeded when compressing,
.\"O .B xz
.\"O will try to scale the settings down so that the limit
.\"O is no longer exceeded (except when using \fB\-\-format=raw\fR
.\"O or \fB\-\-no\-adjust\fR).
.\"O This way the operation won't fail unless the limit is very small.
.\"O The scaling of the settings is done in steps that don't
.\"O match the compression level presets, e.g. if the limit is
.\"O only slightly less than the amount required for
.\"O .BR "xz \-9" ,
.\"O the settings will be scaled down only a little,
.\"O not all the way down to
.\"O .BR "xz \-8" .
.\"O .
.PP
伸長時に、指定したメモリ利用制限を超過した場合、\fBxz\fP はエラーを表示し伸長処理は失敗します。圧縮時にその制限が超過した場合、\fBxz\fP
はその制限値を引き下げて、制限を超過しないようにします (ただし \fB\-\-format=raw\fP または \fB\-\-no\-adjust\fP
の指定時は除きます)。このような処理方法により、制限値が極端に小さくない限り、処理は失敗しないようになります。設定値を引き下げいく際には、圧縮レベルを示すプリセット値までには至らない範囲で、徐々に引き下げられていきます。たとえばこの設定値が
\fBxz \-9\fP に必要となる容量よりも少しだけ小さかった場合、設定値の引き下げはほんの少しだけ行われるものであって、\fBxz \-8\fP
に必要となる容量まで一気に引き下げられるわけではありません。
.
.\"O ----------------------------------------
.\"O .SS "Concatenation and padding with .xz files"
.\"O It is possible to concatenate
.\"O .B .xz
.\"O files as is.
.\"O .B xz
.\"O will decompress such files as if they were a single
.\"O .B .xz
.\"O file.
.SS ".xz ファイルの連結とパディング"
複数の \fB.xz\fP ファイルは、その状態のまま連結 (concatenate) することができます。連結されたファイルを \fBxz\fP
が伸長する際には、あたかも 1 つの \fB.xz\fP ファイルであるかのようにして処理します。
.\"O ----------------------------------------
.\"O .PP
.\"O It is possible to insert padding between the concatenated parts
.\"O or after the last part.
.\"O The padding must consist of null bytes and the size
.\"O of the padding must be a multiple of four bytes.
.\"O This can be useful e.g. if the
.\"O .B .xz
.\"O file is stored on a medium that measures file sizes
.\"O in 512-byte blocks.
.PP
連結した間の部分や連結の最後に、パディング (padding)
という追加データを挿入することができます。パディングはヌルバイトによって構成されるものであり、そのサイズは 4
バイトの倍数でなければなりません。これが有用となるのは、たとえば 512 バイト単位のブロックごとにファイルサイズを定めるような媒体に \fB.xz\fP
ファイルを保存する場合です。
.\"O ----------------------------------------
.\"O .PP
.\"O Concatenation and padding are not allowed with
.\"O .B .lzma
.\"O files or raw streams.
.\"O .
.PP
連結とパディングは、\fB.lzma\fP ファイルや生の (raw) ストリームにおいて行うことはできません。
.
.\"O ----------------------------------------
.\"O .SH OPTIONS
.\"O .
.SH オプション
.
.\"O ----------------------------------------
.\"O .SS "Integer suffixes and special values"
.\"O In most places where an integer argument is expected,
.\"O an optional suffix is supported to easily indicate large integers.
.\"O There must be no space between the integer and the suffix.
.SS 整数に対するサフィックスと特別な値
整数引数を必要とする場面の多くにおいては、サフィックスをさらにつけることで多大な数値を簡単に表現できるようにしています。整数値とそのサフィックスの間には空白文字を含めないでください。
.\"O ----------------------------------------
.\"O .TP
.\"O .B KiB
.\"O Multiply the integer by 1,024 (2^10).
.\"O .BR Ki ,
.\"O .BR k ,
.\"O .BR kB ,
.\"O .BR K ,
.\"O and
.\"O .B KB
.\"O are accepted as synonyms for
.\"O .BR KiB .
.TP
\fBKiB\fP
1,024 (2^10) の倍数を表現します。\fBKiB\fP と同じ意味を表す \fBKi\fP, \fBk\fP, \fBkB\fP, \fBK\fP, \fBKB\fP
が利用できます。
.\"O ----------------------------------------
.\"O .TP
.\"O .B MiB
.\"O Multiply the integer by 1,048,576 (2^20).
.\"O .BR Mi ,
.\"O .BR m ,
.\"O .BR M ,
.\"O and
.\"O .B MB
.\"O are accepted as synonyms for
.\"O .BR MiB .
.TP
\fBMiB\fP
1,048,576 (2^20) の倍数を表現します。\fBMiB\fP と同じ意味を表す \fBMi\fP, \fBm\fP, \fBM\fP, \fBMB\fP が利用できます。
.\"O ----------------------------------------
.\"O .TP
.\"O .B GiB
.\"O Multiply the integer by 1,073,741,824 (2^30).
.\"O .BR Gi ,
.\"O .BR g ,
.\"O .BR G ,
.\"O and
.\"O .B GB
.\"O are accepted as synonyms for
.\"O .BR GiB .
.TP
\fBGiB\fP
1,073,741,824 (2^30) の倍数を表現します。\fBGiB\fP と同じ意味を表す \fBGi\fP, \fBg\fP, \fBG\fP, \fBGB\fP
が利用できます。
.\"O ----------------------------------------
.\"O .PP
.\"O The special value
.\"O .B max
.\"O can be used to indicate the maximum integer value
.\"O supported by the option.
.\"O .
.PP
特別な数値指定 \fBmax\fP が利用できます。これはそのオプションにおいてサポートされている最大整数値を表します。
.
.\"O ----------------------------------------
.\"O .SS "Operation mode"
.\"O If multiple operation mode options are given,
.\"O the last one takes effect.
.SS オペレーションモード
オペレーションモードオプションが複数指定された場合は、最後の指定が有効となります。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-z ", " \-\-compress
.\"O Compress.
.\"O This is the default operation mode when no operation mode option
.\"O is specified and no other operation mode is implied from
.\"O the command name (for example,
.\"O .B unxz
.\"O implies
.\"O .BR \-\-decompress ).
.TP
\fB\-z\fP, \fB\-\-compress\fP
圧縮を指示します。これはデフォルトのオペレーションモードです。オペレーションモードオプションが指定されなかった場合、あるいはコマンドラインからの指定において暗にオペレーションモードの指定が含まれていない場合に採用されます
(たとえば \fBunxz\fP には \fB\-\-decompress\fP が暗に含まれています)。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-d ", " \-\-decompress ", " \-\-uncompress
.\"O Decompress.
.TP
\fB\-d\fP, \fB\-\-decompress\fP, \fB\-\-uncompress\fP
伸長を指示します。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-t ", " \-\-test
.\"O Test the integrity of compressed
.\"O .IR files .
.\"O This option is equivalent to
.\"O .B "\-\-decompress \-\-stdout"
.\"O except that the decompressed data is discarded instead of being
.\"O written to standard output.
.\"O No files are created or removed.
.TP
\fB\-t\fP, \fB\-\-test\fP
圧縮された \fIfiles\fP の整合性をテストします。このオプションは \fB\-\-decompress \-\-stdout\fP
とすることと同じです。ただし伸長されるデータが、標準出力へは書き込まれずに捨てられてしまう場合を除きます。このオプションでは、ファイル生成や削除は発生しません。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-l ", " \-\-list
.\"O Print information about compressed
.\"O .IR files .
.\"O No uncompressed output is produced,
.\"O and no files are created or removed.
.\"O In list mode, the program cannot read
.\"O the compressed data from standard
.\"O input or from other unseekable sources.
.TP
\fB\-l\fP, \fB\-\-list\fP
圧縮された \fIfiles\fP
に関する情報を一覧表示します。伸長処理が行われるわけではなく、ファイル生成や削除は発生しません。このリストモードでは、標準入力あるいは他の視認できない入力ソースからの圧縮データは読み込むことができません。
.\"O ----------------------------------------
.\"O .IP ""
.\"O The default listing shows basic information about
.\"O .IR files ,
.\"O one file per line.
.\"O To get more detailed information, use also the
.\"O .B \-\-verbose
.\"O option.
.\"O For even more information, use
.\"O .B \-\-verbose
.\"O twice, but note that this may be slow, because getting all the extra
.\"O information requires many seeks.
.\"O The width of verbose output exceeds
.\"O 80 characters, so piping the output to e.g.\&
.\"O .B "less\ \-S"
.\"O may be convenient if the terminal isn't wide enough.
.IP ""
このオプションによる一覧出力では、\fIfiles\fP に関する基本的な情報が、1 つにつき 1 行ずつ表示されます。さらに詳しい情報を得るには
\fB\-\-verbose\fP オプションも併用します。それ以上に細かい情報を得るには \fB\-\-verbose\fP を 2
回指定します。ただしこれを行うと処理が遅くなるかもしれません。細かい情報を得るためには、数多くの検索処理が必要となるためです。詳細な情報を出力する際の出力幅は
80 文字を超えます。したがって \& \fBless\ \-S\fP
を利用するなどして出力をパイプすれば、横幅が十分に取れない端末であっても問題なく利用できます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O The exact output may vary between
.\"O .B xz
.\"O versions and different locales.
.\"O For machine-readable output,
.\"O .B \-\-robot \-\-list
.\"O should be used.
.\"O .
.IP ""
実際の出力は \fBxz\fP のバージョンやロケール指定により変わります。マシンにとって読み込み可能な出力とするには、\fB\-\-robot \-\-list\fP
を利用してください。
.
.\"O ----------------------------------------
.\"O .SS "Operation modifiers"
.SS "オペレーション修飾子 (operation modifiers)"
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-k ", " \-\-keep
.\"O Don't delete the input files.
.TP
\fB\-k\fP, \fB\-\-keep\fP
入力ファイルを削除しません。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-f ", " \-\-force
.\"O This option has several effects:
.TP
\fB\-f\fP, \fB\-\-force\fP
このオプションには複数の効果があります。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O If the target file already exists,
.\"O delete it before compressing or decompressing.
.IP \(bu 3
目的とするファイルがすでに存在していた場合、そのファイルを削除してから圧縮や伸長を行います。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O Compress or decompress even if the input is
.\"O a symbolic link to a regular file,
.\"O has more than one hard link,
.\"O or has the setuid, setgid, or sticky bit set.
.\"O The setuid, setgid, and sticky bits are not copied
.\"O to the target file.
.IP \(bu 3
入力ファイルが通常ファイルへのシンボリックリンクである場合、ハードリンクを複数持つ場合、setuid, setgid, スティッキービット
(sticky bit) セットを持つ場合であっても、圧縮または伸長を行います。setuid, setgid,
スティッキービットは目的となるファイルにはコピーされません。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O When used with
.\"O .B \-\-decompress
.\"O .BR \-\-stdout
.\"O and
.\"O .B xz
.\"O cannot recognize the type of the source file,
.\"O copy the source file as is to standard output.
.\"O This allows
.\"O .B xzcat
.\"O .B \-\-force
.\"O to be used like
.\"O .BR cat (1)
.\"O for files that have not been compressed with
.\"O .BR xz .
.\"O Note that in future,
.\"O .B xz
.\"O might support new compressed file formats, which may make
.\"O .B xz
.\"O decompress more types of files instead of copying them as is to
.\"O standard output.
.\"O .BI \-\-format= format
.\"O can be used to restrict
.\"O .B xz
.\"O to decompress only a single file format.
.IP \(bu 3
\fB\-\-decompress\fP \fB\-\-stdout\fP が指定された際に \fBxz\fP
がソースファイルの種類を認識できなかった場合は、ソースファイルがそのまま標準出力へコピーされます。これは \fBxzcat\fP \fB\-\-force\fP
を利用した際に、ソースファイルが \fBxz\fP によって圧縮されていないファイルであっても \fBcat\fP(1)
と同じように処理できることになります。将来的に \fBxz\fP
は新たな圧縮ファイルフォーマットをサポートするかもしれないので、単に標準出力へコピーするのではなく、多くのファイルタイプを伸長できるようになるかもしれません。\fB\-\-format=\fP\fIformat\fP
を指定すれば、\fBxz\fP が伸長を行うファイルフォーマットをただ 1 つに限定することができます。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-c ", " \-\-stdout ", " \-\-to\-stdout
.\"O Write the compressed or decompressed data to
.\"O standard output instead of a file.
.\"O This implies
.\"O .BR \-\-keep .
.TP
\fB\-c\fP, \fB\-\-stdout\fP, \fB\-\-to\-stdout\fP
圧縮または伸長する際に、出力先をファイルではなく標準出力とします。このオプションには \fB\-\-keep\fP の指定が暗に含まれます。
.\"O ----------------------------------------
.\"O .TP
.\"O .B \-\-single\-stream
.\"O Decompress only the first
.\"O .B .xz
.\"O stream, and
.\"O silently ignore possible remaining input data following the stream.
.\"O Normally such trailing garbage makes
.\"O .B xz
.\"O display an error.
.TP
\fB\-\-single\-stream\fP
\&\fB.xz\fP の入力ストリームから最初の 1
つだけを伸長します。そしてそのストリームの続きとして入力データが残っていても、そのことを示さずに無視します。ただし通常は、そういったゴミデータが続いていると
\fBxz\fP はエラーを出力します。
.\"O ----------------------------------------
.\"O .IP ""
.\"O .B xz
.\"O never decompresses more than one stream from
.\"O .B .lzma
.\"O files or raw streams, but this option still makes
.\"O .B xz
.\"O ignore the possible trailing data after the
.\"O .B .lzma
.\"O file or raw stream.
.IP ""
\fBxz\fP では \fB.lzma\fP ファイルや生の (raw)
ストリームからの複数ストリームは伸長処理を行いません。そこでこのオプションを利用しておけば、\fB.lzma\fP
ファイルや生のストリームの次にくるゴミデータを無視できます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O This option has no effect if the operation mode is not
.\"O .B \-\-decompress
.\"O or
.\"O .BR \-\-test .
.IP ""
本オプションは、オペレーションモードが \fB\-\-decompress\fP または \fB\-\-test\fP である場合には何も行いません。
.\"O ----------------------------------------
.\"O .TP
.\"O .B \-\-no\-sparse
.\"O Disable creation of sparse files.
.\"O By default, if decompressing into a regular file,
.\"O .B xz
.\"O tries to make the file sparse if the decompressed data contains
.\"O long sequences of binary zeros.
.\"O It also works when writing to standard output
.\"O as long as standard output is connected to a regular file
.\"O and certain additional conditions are met to make it safe.
.\"O Creating sparse files may save disk space and speed up
.\"O the decompression by reducing the amount of disk I/O.
.TP
\fB\-\-no\-sparse\fP
スパース (sparse)
ファイルを生成しないようにします。伸長処理によって通常ファイルを生成する際に、伸長したデータ内にバイナリ値ゼロの並びが長く続く場合、\fBxz\fP
はデフォルトでスパースファイルを生成しようとします。このような処理は、たとえ出力先が標準出力であっても、この標準出力が通常ファイルに結びついていて、かつ所定の条件をいくつか満たすことで安全に処理が進められるのであれば、同様に処理されます。スパースファイルを生成すれば、ディスク容量を節約できます。またディスク
I/O の回数が減るので、伸長処理時間が短縮されます。
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-S\fR \fI.suf\fR, \fB\-\-suffix=\fI.suf
.\"O When compressing, use
.\"O .I .suf
.\"O as the suffix for the target file instead of
.\"O .B .xz
.\"O or
.\"O .BR .lzma .
.\"O If not writing to standard output and
.\"O the source file already has the suffix
.\"O .IR .suf ,
.\"O a warning is displayed and the file is skipped.
.TP
\fB\-S\fP \fI.suf\fP, \fB\-\-suffix=\fP\fI.suf\fP
圧縮処理においては、目的とするファイルのサフィックスを \fB.xz\fP や \fB.lzma\fP ではなく \fI.suf\fP
とします。標準出力への書き出しではなく、ソースファイルがすでにサフィックス \fI.suf\fP
を持っていた場合は、警告メッセージが表示されて、そのファイルの処理はスキップされます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O When decompressing, recognize files with the suffix
.\"O .I .suf
.\"O in addition to files with the
.\"O .BR .xz ,
.\"O .BR .txz ,
.\"O .BR .lzma ,
.\"O or
.\"O .B .tlz
.\"O suffix.
.\"O If the source file has the suffix
.\"O .IR .suf ,
.\"O the suffix is removed to get the target filename.
.IP ""
伸長処理においては、ファイルのサフィックスを \fB.xz\fP, \fB.txz\fP, \fB.lzma\fP, \fB.tlz\fP に加えて \fI.suf\fP
を扱うようにします。ソースファイルのサフィックスが \fI.suf\fP である場合、このサフィックスを取り除いたものを目的のファイル名とします。
.\"O ----------------------------------------
.\"O .IP ""
.\"O When compressing or decompressing raw streams
.\"O .RB ( \-\-format=raw ),
.\"O the suffix must always be specified unless
.\"O writing to standard output,
.\"O because there is no default suffix for raw streams.
.IP ""
生の (raw) ストリームを圧縮または伸長する場合
(\fB\-\-format=raw\fP)、標準出力に書き込む場合を除き、サフィックスは必ずつけなければなりません。生のストリームに対するデフォルトのサフィックスがないためです。
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-\-files\fR[\fB=\fIfile\fR]
.\"O Read the filenames to process from
.\"O .IR file ;
.\"O if
.\"O .I file
.\"O is omitted, filenames are read from standard input.
.\"O Filenames must be terminated with the newline character.
.\"O A dash
.\"O .RB ( \- )
.\"O is taken as a regular filename; it doesn't mean standard input.
.\"O If filenames are given also as command line arguments, they are
.\"O processed before the filenames read from
.\"O .IR file .
.TP
\fB\-\-files\fP[\fB=\fP\fIfile\fP]
処理対象とする \fIfile\fP のファイル名を読み込みます。\fIfile\fP
を省略した場合、ファイル名は標準入力から読み込まれます。ファイル名は改行文字によって終了していなければなりません。ダッシュ (\fB\-\fP)
は通常のファイル名として扱われます。つまり標準入力を意味するものではありません。ファイル名がコマンドライン引数からも指定された場合、\fIfile\fP
からファイル名を読み込む前にその指定が処理されます。
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-\-files0\fR[\fB=\fIfile\fR]
.\"O This is identical to \fB\-\-files\fR[\fB=\fIfile\fR] except
.\"O that each filename must be terminated with the null character.
.\"O .
.TP
\fB\-\-files0\fP[\fB=\fP\fIfile\fP]
これは \fB\-\-files\fP[\fB=\fP\fIfile\fP] と同等です。ただしこれを利用する場合、各ファイル名はヌル文字で区切られていなければなりません。
.
.\"O ----------------------------------------
.\"O .SS "Basic file format and compression options"
.SS 基本的なファイルフォーマットと圧縮オプション
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-F\fR \fIformat\fR, \fB\-\-format=\fIformat
.\"O Specify the file
.\"O .I format
.\"O to compress or decompress:
.TP
\fB\-F\fP \fIformat\fP, \fB\-\-format=\fP\fIformat\fP
圧縮または伸長を行う際のファイルフォーマットを \fIformat\fP に指定します。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .TP
.\"O .B auto
.\"O This is the default.
.\"O When compressing,
.\"O .B auto
.\"O is equivalent to
.\"O .BR xz .
.\"O When decompressing,
.\"O the format of the input file is automatically detected.
.\"O Note that raw streams (created with
.\"O .BR \-\-format=raw )
.\"O cannot be auto-detected.
.TP
\fBauto\fP
これがデフォルトの設定です。圧縮処理の場合、\fBauto\fP は \fBxz\fP
と同じになります。伸長処理の場合、入力ファイルのフォーマットは自動検出されます。ただし生の (raw) ストリーム (\fB\-\-format=raw\fP
により生成される) は自動検出されません。
.\"O ----------------------------------------
.\"O .TP
.\"O .B xz
.\"O Compress to the
.\"O .B .xz
.\"O file format, or accept only
.\"O .B .xz
.\"O files when decompressing.
.TP
\fBxz\fP
ファイルフォーマット \fB.xz\fP として圧縮します。また伸長時には \fB.xz\fP ファイルのみを受けつけます。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR lzma ", " alone
.\"O Compress to the legacy
.\"O .B .lzma
.\"O file format, or accept only
.\"O .B .lzma
.\"O files when decompressing.
.\"O The alternative name
.\"O .B alone
.\"O is provided for backwards compatibility with LZMA Utils.
.TP
\fBlzma\fP, \fBalone\fP
古いファイルフォーマット \fB.lzma\fP として圧縮します。また伸長時には \fB.lzma\fP ファイルのみを受けつけます。別名 \fBalone\fP は
LZMA Utils との後方互換性のために提供されています。
.\"O ----------------------------------------
.\"O .TP
.\"O .B raw
.\"O Compress or uncompress a raw stream (no headers).
.\"O This is meant for advanced users only.
.\"O To decode raw streams, you need use
.\"O .B \-\-format=raw
.\"O and explicitly specify the filter chain,
.\"O which normally would have been stored in the container headers.
.TP
\fBraw\fP
生の (raw) ストリームを (ヘッダーはなしにして)
圧縮または伸長します。これは上級者向けの利用を意図しています。生のストリームをデコードするためには、\fB\-\-format=raw\fP
の指定、および明示的なフィルターチェーン (filter chain) の指定が必要です。フィルターチェーンは通常はコンテナーヘッダー内に保存されます。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-C\fR \fIcheck\fR, \fB\-\-check=\fIcheck
.\"O Specify the type of the integrity check.
.\"O The check is calculated from the uncompressed data and
.\"O stored in the
.\"O .B .xz
.\"O file.
.\"O This option has an effect only when compressing into the
.\"O .B .xz
.\"O format; the
.\"O .B .lzma
.\"O format doesn't support integrity checks.
.\"O The integrity check (if any) is verified when the
.\"O .B .xz
.\"O file is decompressed.
.TP
\fB\-C\fP \fIcheck\fP, \fB\-\-check=\fP\fIcheck\fP
整合性チェックのタイプを指定します。このチェックは伸長データから計算され、\fB.xz\fP ファイル内に保存されます。本オプションは、\fB.xz\fP
フォーマットへの圧縮時にのみ効果があります。つまり \fB.lzma\fP フォーマットでは、整合性チェック機能はサポートされていません。整合性チェックは
(もしあれば) \fB.xz\fP ファイルの伸長時に検証されます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O Supported
.\"O .I check
.\"O types:
.IP ""
サポートされる \fIcheck\fP のタイプは以下です。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .TP
.\"O .B none
.\"O Don't calculate an integrity check at all.
.\"O This is usually a bad idea.
.\"O This can be useful when integrity of the data is verified
.\"O by other means anyway.
.TP
\fBnone\fP
整合性チェックを一切計算しません。通常はあまりよくないことです。別の方法によってデータ整合性が検証されるのであれば、このタイプを利用することができます。
.\"O ----------------------------------------
.\"O .TP
.\"O .B crc32
.\"O Calculate CRC32 using the polynomial from IEEE-802.3 (Ethernet).
.TP
\fBcrc32\fP
IEEE\-802.3 (Ethernet) による多項式を利用して CRC32 を計算します。
.\"O ----------------------------------------
.\"O .TP
.\"O .B crc64
.\"O Calculate CRC64 using the polynomial from ECMA-182.
.\"O This is the default, since it is slightly better than CRC32
.\"O at detecting damaged files and the speed difference is negligible.
.TP
\fBcrc64\fP
ECMA\-182 による多項式を用いて CRC64 を計算します。これがデフォルトです。CRC32
に比べると、破損ファイルの検出に若干有利であり、処理速度の違いは気にならない程度であるからです。
.\"O ----------------------------------------
.\"O .TP
.\"O .B sha256
.\"O Calculate SHA-256.
.\"O This is somewhat slower than CRC32 and CRC64.
.TP
\fBsha256\fP
SHA\-256 を計算します。CRC32 や CRC64 に比べると、処理速度がやや劣ります。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .IP ""
.\"O Integrity of the
.\"O .B .xz
.\"O headers is always verified with CRC32.
.\"O It is not possible to change or disable it.
.IP ""
\&\fB.xz\fP ヘッダーの整合性を、常に CRC32 によって検証します。これを変更したり無効化することはできません。
.\"O ----------------------------------------
.\"O .TP
.\"O .B \-\-ignore\-check
.\"O Don't verify the integrity check of the compressed data when decompressing.
.\"O The CRC32 values in the
.\"O .B .xz
.\"O headers will still be verified normally.
.TP
\fB\-\-ignore\-check\fP
伸長時に圧縮データの整合性チェックを検証しません。\fB.xz\fP ヘッダー内にある CRC32 値は、それでも普通に検証されます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O .B "Do not use this option unless you know what you are doing."
.\"O Possible reasons to use this option:
.IP ""
\fBこのオプションが何を行うのかを理解していない場合は利用しないでください。\fP 本オプションを利用する状況は以下のとおりです。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O Trying to recover data from a corrupt .xz file.
.IP \(bu 3
壊れた .xz ファイルからデータ回復を試みる場合。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O Speeding up decompression.
.\"O This matters mostly with SHA-256 or
.\"O with files that have compressed extremely well.
.\"O It's recommended to not use this option for this purpose
.\"O unless the file integrity is verified externally in some other way.
.IP \(bu 3
伸長処理の速度改善を図る場合。これは特に SHA\-256
を利用する場合、あるいは圧縮性能が極めて高いファイルに対して重要です。ただしこの目的であっても、外部の別手段を利用してファイル整合性の検証を行う場合には推奨されません。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-0 " ... " \-9
.\"O Select a compression preset level.
.\"O The default is
.\"O .BR \-6 .
.\"O If multiple preset levels are specified,
.\"O the last one takes effect.
.\"O If a custom filter chain was already specified, setting
.\"O a compression preset level clears the custom filter chain.
.TP
\fB\-0\fP ... \fB\-9\fP
圧縮プリセットレベル (preset level) を選択します。デフォルトは \fB\-6\fP
です。複数のプリセットレベルが指定された場合、最後に指定されたものが採用されます。カスタムフィルターチェーン (custom filter chain)
がすでに指定されている場合、圧縮プリセットレベルの指定により、そのカスタムフィルターチェーンの指定は解除されます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O The differences between the presets are more significant than with
.\"O .BR gzip (1)
.\"O and
.\"O .BR bzip2 (1).
.\"O The selected compression settings determine
.\"O the memory requirements of the decompressor,
.\"O thus using a too high preset level might make it painful
.\"O to decompress the file on an old system with little RAM.
.\"O Specifically,
.\"O .B "it's not a good idea to blindly use \-9 for everything"
.\"O like it often is with
.\"O .BR gzip (1)
.\"O and
.\"O .BR bzip2 (1).
.IP ""
プリセットの違いは、\fBgzip\fP(1) や \fBbzip2\fP(1)
にはない重要な意味があります。圧縮処理に対するプリセット指定は、伸長時におけるメモリ容量を決定づけます。したがってより高度なプリセットレベルを用いると、小容量の
RAM しかない旧来のシステムでは、伸長時に相当な負荷がかかるかもしれません。特に \fBgzip\fP(1) や \fBbzip2\fP(1) では \-9
をよく指定しますが、\fBxz\fP では \fB何も考えず常に \-9 を用いるのは得策ではありません。\fP
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .TP
.\"O .BR "\-0" " ... " "\-3"
.\"O These are somewhat fast presets.
.\"O .B \-0
.\"O is sometimes faster than
.\"O .B "gzip \-9"
.\"O while compressing much better.
.\"O The higher ones often have speed comparable to
.\"O .BR bzip2 (1)
.\"O with comparable or better compression ratio,
.\"O although the results
.\"O depend a lot on the type of data being compressed.
.TP
\fB\-0\fP ... \fB\-3\fP
比較的速いプリセットです。\fB\-0\fP は \fBgzip \-9\fP
よりも圧縮性能がよく、高速に処理されます。より高いプリセット値では、\fBbzip2\fP(1)
と同等またはそれ以上の圧縮率が得られ、より高速に処理されます。ただしこの結果は、圧縮を行うデータタイプに大きく依存します。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR "\-4" " ... " "\-6"
.\"O Good to very good compression while keeping
.\"O decompressor memory usage reasonable even for old systems.
.\"O .B \-6
.\"O is the default, which is usually a good choice
.\"O e.g. for distributing files that need to be decompressible
.\"O even on systems with only 16\ MiB RAM.
.\"O .RB ( \-5e
.\"O or
.\"O .B \-6e
.\"O may be worth considering too.
.\"O See
.\"O .BR \-\-extreme .)
.TP
\fB\-4\fP ... \fB\-6\fP
古いシステムでの利用時でも伸長処理におけるメモリ利用は妥当なもので、圧縮処理も良好に行われます。\fB\-6\fP がデフォルトです。たとえば、たった 16\ MiB RAM しかないシステム上において伸長処理を行うことになっても、これを選んでおけば間違いはなく、配布を問題なく行うことができます。(\fB\-5e\fP
や \fB\-6e\fP を選ぶことも有効かもしれません。\fB\-\-extreme\fP 参照のこと。)
.\"O ----------------------------------------
.\"O .TP
.\"O .B "\-7 ... \-9"
.\"O These are like
.\"O .B \-6
.\"O but with higher compressor and decompressor memory requirements.
.\"O These are useful only when compressing files bigger than
.\"O 8\ MiB, 16\ MiB, and 32\ MiB, respectively.
.TP
\fB\-7 ... \-9\fP
これらは \fB\-6\fP と同様ですが、より高圧縮になるとともに、伸長時はより多くのメモリを必要とします。これが有効になるのは、圧縮ファイルがそれぞれ 8\ MiB, 16\ MiB, 32\ MiB を超える場合です。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .IP ""
.\"O On the same hardware, the decompression speed is approximately
.\"O a constant number of bytes of compressed data per second.
.\"O In other words, the better the compression,
.\"O the faster the decompression will usually be.
.\"O This also means that the amount of uncompressed output
.\"O produced per second can vary a lot.
.IP ""
同一のハードウェア上であれば、伸長にかかる処理速度は毎秒、データ圧縮に要したバイト数の倍数にほぼ一致します。言い換えると、通常は圧縮率が高ければ伸長処理は速くなります。ということはつまり、単位時間内に生成される伸長処理の出力データ量は、状況によりさまざまであるということです。
.\"O ----------------------------------------
.\"O .IP ""
.\"O The following table summarises the features of the presets:
.IP ""
以下の表はプリセットの特徴をまとめたものです。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .TS
.\"O tab(;);
.\"O c c c c c
.\"O n n n n n.
.\"O Preset;DictSize;CompCPU;CompMem;DecMem
.\"O \-0;256 KiB;0;3 MiB;1 MiB
.\"O \-1;1 MiB;1;9 MiB;2 MiB
.\"O \-2;2 MiB;2;17 MiB;3 MiB
.\"O \-3;4 MiB;3;32 MiB;5 MiB
.\"O \-4;4 MiB;4;48 MiB;5 MiB
.\"O \-5;8 MiB;5;94 MiB;9 MiB
.\"O \-6;8 MiB;6;94 MiB;9 MiB
.\"O \-7;16 MiB;6;186 MiB;17 MiB
.\"O \-8;32 MiB;6;370 MiB;33 MiB
.\"O \-9;64 MiB;6;674 MiB;65 MiB
.\"O .TE
.PP
.TS
tab(;);
c c c c c
n n n n n.
プリセット;DictSize;CompCPU;CompMem;DecMem
\-0;256 KiB;0;3 MiB;1 MiB
\-1;1 MiB;1;9 MiB;2 MiB
\-2;2 MiB;2;17 MiB;3 MiB
\-3;4 MiB;3;32 MiB;5 MiB
\-4;4 MiB;4;48 MiB;5 MiB
\-5;8 MiB;5;94 MiB;9 MiB
\-6;8 MiB;6;94 MiB;9 MiB
\-7;16 MiB;6;186 MiB;17 MiB
\-8;32 MiB;6;370 MiB;33 MiB
\-9;64 MiB;6;674 MiB;65 MiB
.TE
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .IP ""
.\"O Column descriptions:
.IP ""
各カラムは以下のとおりです。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O DictSize is the LZMA2 dictionary size.
.\"O It is waste of memory to use a dictionary bigger than
.\"O the size of the uncompressed file.
.\"O This is why it is good to avoid using the presets
.\"O .BR \-7 " ... " \-9
.\"O when there's no real need for them.
.\"O At
.\"O .B \-6
.\"O and lower, the amount of memory wasted is
.\"O usually low enough to not matter.
.IP \(bu 3
DictSize とは LZMA2 辞書サイズです。辞書を利用すると、伸長するファイルサイズ以上にメモリを消費します。つまり \fB\-7\fP
\&... \fB\-9\fP は、本当に利用する必要がないのであれば、用いるべきでない理由がここにあります。\fB\-6\fP
またはこれ未満において、消費されるメモリ容量は通常は十分に少なく、問題にならない程度です。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O CompCPU is a simplified representation of the LZMA2 settings
.\"O that affect compression speed.
.\"O The dictionary size affects speed too,
.\"O so while CompCPU is the same for levels
.\"O .BR \-6 " ... " \-9 ,
.\"O higher levels still tend to be a little slower.
.\"O To get even slower and thus possibly better compression, see
.\"O .BR \-\-extreme .
.IP \(bu 3
CompCPU とは LZMA2 設定における簡易表現であり、圧縮速度に影響を及ぼすものです。辞書サイズももちろん速度に影響します。したがって
CompCPU が同一である \fB\-6\fP ... \fB\-9\fP
に対しては、プリセット値が高くなるほど、処理速度が低下する傾向にあります。処理が低下するということは、その分、圧縮率が向上する可能性があります。\fB\-\-extreme\fP
を参照してください。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O CompMem contains the compressor memory requirements
.\"O in the single-threaded mode.
.\"O It may vary slightly between
.\"O .B xz
.\"O versions.
.\"O Memory requirements of some of the future multithreaded modes may
.\"O be dramatically higher than that of the single-threaded mode.
.IP \(bu 3
CompMem はシングルスレッドモードにおいて、圧縮処理時のメモリ消費量を表します。これは \fBxz\fP
バージョンが異なることで変化する場合があります。メモリ消費量は、マルチスレッドモードでの機能によっては、シングルスレッドモードよりも急激に高まる場合があります。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O DecMem contains the decompressor memory requirements.
.\"O That is, the compression settings determine
.\"O the memory requirements of the decompressor.
.\"O The exact decompressor memory usage is slightly more than
.\"O the LZMA2 dictionary size, but the values in the table
.\"O have been rounded up to the next full MiB.
.IP \(bu 3
DecMem
は伸長処理時におけるメモリ消費量を表します。つまり圧縮時の設定が、伸長処理時のメモリ消費量を決定づけるものです。実際に伸長処理におけるメモリ消費量は、LZMA2
辞書サイズより若干大きくなります。ただし上の表に示した値は、きれいな MiB 値になるように切り上げています。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-e ", " \-\-extreme
.\"O Use a slower variant of the selected compression preset level
.\"O .RB ( \-0 " ... " \-9 )
.\"O to hopefully get a little bit better compression ratio,
.\"O but with bad luck this can also make it worse.
.\"O Decompressor memory usage is not affected,
.\"O but compressor memory usage increases a little at preset levels
.\"O .BR \-0 " ... " \-3 .
.TP
\fB\-e\fP, \fB\-\-extreme\fP
指定されているプリセットレベル (\fB\-0\fP ... \fB\-9\fP) に比較して、より遅い処理方式 (variant)
を用います。これにより少しでも高圧縮率が得られるようにします。ただし場合によっては、期待に沿わない結果となることもあります。伸長処理時におけるメモリ利用量には影響しません。ただし圧縮処理時のメモリ利用量は、そのときのレベルが
\fB\-0\fP ... \fB\-3\fP である場合には若干増加します。
.\"O ----------------------------------------
.\"O .IP ""
.\"O Since there are two presets with dictionary sizes
.\"O 4\ MiB and 8\ MiB, the presets
.\"O .B \-3e
.\"O and
.\"O .B \-5e
.\"O use slightly faster settings (lower CompCPU) than
.\"O .B \-4e
.\"O and
.\"O .BR \-6e ,
.\"O respectively.
.\"O That way no two presets are identical.
.IP ""
辞書サイズを 4\ MiB、8\ MiB とするプリセットが 2 つずつあり、プリセット \fB\-3e\fP と \fB\-5e\fP はそれぞれ \fB\-4e\fP と
\fB\-6e\fP に比べて若干高速になる (CompCPU は低くなる) 設定です。このようにして 2 つのプリセットが異なることになります。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .TS
.\"O tab(;);
.\"O c c c c c
.\"O n n n n n.
.\"O Preset;DictSize;CompCPU;CompMem;DecMem
.\"O \-0e;256 KiB;8;4 MiB;1 MiB
.\"O \-1e;1 MiB;8;13 MiB;2 MiB
.\"O \-2e;2 MiB;8;25 MiB;3 MiB
.\"O \-3e;4 MiB;7;48 MiB;5 MiB
.\"O \-4e;4 MiB;8;48 MiB;5 MiB
.\"O \-5e;8 MiB;7;94 MiB;9 MiB
.\"O \-6e;8 MiB;8;94 MiB;9 MiB
.\"O \-7e;16 MiB;8;186 MiB;17 MiB
.\"O \-8e;32 MiB;8;370 MiB;33 MiB
.\"O \-9e;64 MiB;8;674 MiB;65 MiB
.\"O .TE
.PP
.TS
tab(;);
c c c c c
n n n n n.
プリセット;DictSize;CompCPU;CompMem;DecMem
\-0e;256 KiB;8;4 MiB;1 MiB
\-1e;1 MiB;8;13 MiB;2 MiB
\-2e;2 MiB;8;25 MiB;3 MiB
\-3e;4 MiB;7;48 MiB;5 MiB
\-4e;4 MiB;8;48 MiB;5 MiB
\-5e;8 MiB;7;94 MiB;9 MiB
\-6e;8 MiB;8;94 MiB;9 MiB
\-7e;16 MiB;8;186 MiB;17 MiB
\-8e;32 MiB;8;370 MiB;33 MiB
\-9e;64 MiB;8;674 MiB;65 MiB
.TE
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .IP ""
.\"O For example, there are a total of four presets that use
.\"O 8\ MiB dictionary, whose order from the fastest to the slowest is
.\"O .BR \-5 ,
.\"O .BR \-6 ,
.\"O .BR \-5e ,
.\"O and
.\"O .BR \-6e .
.IP ""
たとえば 8\ MiB の辞書サイズとなるプリセットは、全部で 4 つあります。これらにおいて処理が高速となる順は \fB\-5\fP, \fB\-6\fP,
\fB\-5e\fP, \fB\-6e\fP です。
.\"O ----------------------------------------
.\"O .TP
.\"O .B \-\-fast
.TP
\fB\-\-fast\fP
.\"O ----------------------------------------
.\"O .PD 0
.PD 0
.\"O ----------------------------------------
.\"O .TP
.\"O .B \-\-best
.TP
\fB\-\-best\fP
.\"O ----------------------------------------
.\"O .PD
.\"O These are somewhat misleading aliases for
.\"O .B \-0
.\"O and
.\"O .BR \-9 ,
.\"O respectively.
.\"O These are provided only for backwards compatibility
.\"O with LZMA Utils.
.\"O Avoid using these options.
.PD
これらはそれぞれ \fB\-0\fP と \fB\-9\fP に対するエイリアスですが、やや誤解を招きやすいものです。これは LZMA Utils
との後方互換性のために提供されています。このオプションを利用することは避けてください。
.\"O ----------------------------------------
.\"O .TP
.\"O .BI \-\-block\-size= size
.\"O When compressing to the
.\"O .B .xz
.\"O format, split the input data into blocks of
.\"O .I size
.\"O bytes.
.\"O The blocks are compressed independently from each other,
.\"O which helps with multi-threading and
.\"O makes limited random-access decompression possible.
.\"O This option is typically used to override the default
.\"O block size in multi-threaded mode,
.\"O but this option can be used in single-threaded mode too.
.TP
\fB\-\-block\-size=\fP\fIsize\fP
\&\fB.xz\fP フォーマットに圧縮する場合に、入力データを \fIsize\fP
バイトごとのブロックに分割します。このブロックは互いに独立して圧縮されます。これはマルチスレッド対応のためであり、圧縮時のランダムアクセスを可能な限り制限する目的があります。このオプションによって、通常はマルチスレッドモードでのデフォルトブロックサイズをオーバーライドします。ただしこのオプションは、シングルスレッドモードでも利用することができます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O In multi-threaded mode about three times
.\"O .I size
.\"O bytes will be allocated in each thread for buffering input and output.
.\"O The default
.\"O .I size
.\"O is three times the LZMA2 dictionary size or 1 MiB,
.\"O whichever is more.
.\"O Typically a good value is 2\-4 times
.\"O the size of the LZMA2 dictionary or at least 1 MiB.
.\"O Using
.\"O .I size
.\"O less than the LZMA2 dictionary size is waste of RAM
.\"O because then the LZMA2 dictionary buffer will never get fully used.
.\"O The sizes of the blocks are stored in the block headers,
.\"O which a future version of
.\"O .B xz
.\"O will use for multi-threaded decompression.
.IP ""
マルチスレッドモードにおいては、\fIsize\fP バイトのおよそ 3 倍分が、各スレッドの入出力バッファとして割り当てられます。デフォルトの
\fIsize\fP は LZMA2 辞書サイズの 3 倍か、1 MiB のいずれか大きい方になります。通常なら、LZMA2 辞書サイズの 2 ~ 4
倍か、最低 1 MiB が適正な値です。\fIsize\fP に LZMA2 辞書サイズよりも小さな値を用いると、RAM を無駄に消費します。LZMA2
辞書のバッファはすべてが十分に利用されることはないためです。ブロックサイズはブロックヘッダー内に保存されます。これは \fBxz\fP
の将来版において、マルチスレッドでの伸長処理に利用される予定です。
.\"O ----------------------------------------
.\"O .IP ""
.\"O In single-threaded mode no block splitting is done by default.
.\"O Setting this option doesn't affect memory usage.
.\"O No size information is stored in block headers,
.\"O thus files created in single-threaded mode
.\"O won't be identical to files created in multi-threaded mode.
.\"O The lack of size information also means that a future version of
.\"O .B xz
.\"O won't be able decompress the files in multi-threaded mode.
.IP ""
シングルスレッドモードでは、デフォルトではブロック分割処理は行われません。本オプションを設定しても、メモリ利用量には影響しません。サイズ情報はブロックヘッダーに保存されないため、シングルモードにおいて生成されたファイルは、マルチスレッドで生成されたファイルと同一にはならなくなります。サイズ情報を含んでいないということは、つまり
\fBxz\fP の将来版において、マルチスレッドモードにおける伸長処理が不能となる場合があることを意味します。
.\"O ----------------------------------------
.\"O .TP
.\"O .BI \-\-block\-list= sizes
.\"O When compressing to the
.\"O .B .xz
.\"O format, start a new block after
.\"O the given intervals of uncompressed data.
.TP
\fB\-\-block\-list=\fP\fIsizes\fP
\&\fB.xz\fP フォーマットに圧縮する場合に、伸長されているデータから指定された間隔分をあけて、新たなブロックを開始します。
.\"O ----------------------------------------
.\"O .IP ""
.\"O The uncompressed
.\"O .I sizes
.\"O of the blocks are specified as a comma-separated list.
.\"O Omitting a size (two or more consecutive commas) is a shorthand
.\"O to use the size of the previous block.
.IP ""
伸長されたブロックの \fIsizes\fP は、カンマ区切りリストとして指定します。サイズを省略する (2 つ以上の連続したカンマのみを記述する)
と、それは省略表記として前ブロックのサイズを利用する指定となります。
.\"O ----------------------------------------
.\"O .IP ""
.\"O If the input file is bigger than the sum of
.\"O .IR sizes ,
.\"O the last value in
.\"O .I sizes
.\"O is repeated until the end of the file.
.\"O A special value of
.\"O .B 0
.\"O may be used as the last value to indicate that
.\"O the rest of the file should be encoded as a single block.
.IP ""
入力ファイルが \fIsize\fP の合計よりも大きかった場合、\fIsizes\fP
の最後に指定された値を用いて、入力ファイルを繰り返し処理します。特別な設定値として \fB0\fP
を用いると、これが最終の値として用いられ、ファイルの残りのデータを単一のブロックとしてエンコード処理を行うことを指示します。
.\"O ----------------------------------------
.\"O .IP ""
.\"O If one specifies
.\"O .I sizes
.\"O that exceed the encoder's block size
.\"O (either the default value in threaded mode or
.\"O the value specified with \fB\-\-block\-size=\fIsize\fR),
.\"O the encoder will create additional blocks while
.\"O keeping the boundaries specified in
.\"O .IR sizes .
.\"O For example, if one specifies
.\"O .B \-\-block\-size=10MiB
.\"O .B \-\-block\-list=5MiB,10MiB,8MiB,12MiB,24MiB
.\"O and the input file is 80 MiB,
.\"O one will get 11 blocks:
.\"O 5, 10, 8, 10, 2, 10, 10, 4, 10, 10, and 1 MiB.
.IP ""
\fIsizes\fP に設定した値が、エンコード処理するブロックサイズ (スレッドモードにおけるデフォルト値、あるいは
\fB\-\-block\-size=\fP\fIsize\fP に指定された値) を超える場合、\fIsizes\fP
に指定されたブロック範囲を超えたところで追加のブロックを生成します。たとえば\fB\-\-block\-size=10MiB\fP
\fB\-\-block\-list=5MiB,10MiB,8MiB,12MiB,24MiB\fP と指定し、入力ファイルが 80 MiB であった場合、合計で
11 ブロック、つまり順番に 5, 10, 8, 10, 2, 10, 10, 4, 10, 10, 1 MiB のブロックとなります。
.\"O ----------------------------------------
.\"O .IP ""
.\"O In multi-threaded mode the sizes of the blocks
.\"O are stored in the block headers.
.\"O This isn't done in single-threaded mode,
.\"O so the encoded output won't be
.\"O identical to that of the multi-threaded mode.
.IP ""
マルチスレッドモードの場合、ブロックサイズはブロックヘッダー内に保存されます。これはシングルスレッドモードでは行われません。したがってエンコード処理結果は、マルチスレッドモードによるものとは同一になりません。
.\"O ----------------------------------------
.\"O .TP
.\"O .BI \-\-flush\-timeout= timeout
.\"O When compressing, if more than
.\"O .I timeout
.\"O milliseconds (a positive integer) has passed since the previous flush and
.\"O reading more input would block,
.\"O all the pending input data is flushed from the encoder and
.\"O made available in the output stream.
.\"O This can be useful if
.\"O .B xz
.\"O is used to compress data that is streamed over a network.
.\"O Small
.\"O .I timeout
.\"O values make the data available at the receiving end
.\"O with a small delay, but large
.\"O .I timeout
.\"O values give better compression ratio.
.TP
\fB\-\-flush\-timeout=\fP\fItimeout\fP
圧縮時に、前回分のフラッシュ処理が行われて次の入力読み込みがブロックされ、\fItimeout\fP
に指定されるミリ秒以上が経過すると、処理中断していた入力データがエンコード処理からフラッシュされて、出力ストリームでの利用が可能になります。こういった処理は、\fBxz\fP
がネットワーク越しにストリームされたデータを圧縮する際に活用されます。\fItimeout\fP
に小さな値を設定しておくと、受信したデータの最終分を利用する際に、わずかな遅延を起こすものとなります。もっともこの \fItimeout\fP
に大きな値を設定しておけば、高圧縮率が得られます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O This feature is disabled by default.
.\"O If this option is specified more than once, the last one takes effect.
.\"O The special
.\"O .I timeout
.\"O value of
.\"O .B 0
.\"O can be used to explicitly disable this feature.
.IP ""
この機能はデフォルトでは無効化されています。本オプションが複数回指定されると、最後の指定が適用されます。特別な値として \fItimeout\fP に
\fB0\fP を設定すると、本機能を明示的に無効にするものとなります。
.\"O ----------------------------------------
.\"O .IP ""
.\"O This feature is not available on non-POSIX systems.
.IP ""
本機能は非 POSIX システム上では利用できません。
.\"O ----------------------------------------
.\"O .IP ""
.\"O .B "This feature is still experimental."
.\"O Currently
.\"O .B xz
.\"O is unsuitable for decompressing the stream in real time due to how
.\"O .B xz
.\"O does buffering.
.IP ""
なお \fB本機能はまだ実験段階のものです。\fP 今のところ \fBxz\fP
のバッファリング方法に問題があるため、ストリームをリアルタイムで伸長する処理には適していません。
.\"O ----------------------------------------
.\"O .TP
.\"O .BI \-\-memlimit\-compress= limit
.\"O Set a memory usage limit for compression.
.\"O If this option is specified multiple times,
.\"O the last one takes effect.
.TP
\fB\-\-memlimit\-compress=\fP\fIlimit\fP
圧縮時のメモリ利用制限を設定します。本オプションが複数回指定された場合、最後の指定が適用されます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O If the compression settings exceed the
.\"O .IR limit ,
.\"O .B xz
.\"O will adjust the settings downwards so that
.\"O the limit is no longer exceeded and display a notice that
.\"O automatic adjustment was done.
.\"O Such adjustments are not made when compressing with
.\"O .B \-\-format=raw
.\"O or if
.\"O .B \-\-no\-adjust
.\"O has been specified.
.\"O In those cases, an error is displayed and
.\"O .B xz
.\"O will exit with exit status 1.
.IP ""
圧縮設定が \fIlimit\fP を超えた場合、\fBxz\fP
はその設定を引き下げて、制限を超えないようにします。そして自動調整がなされたことを出力表示します。このような調整処理は、圧縮処理にあたって
\fB\-\-format=raw\fP や \fB\-\-no\-adjust\fP が指定された場合には行われません。この場合 \fBxz\fP
はエラーを表示して、終了ステータス 1 を返して終了します。
.\"O ----------------------------------------
.\"O .IP ""
.\"O The
.\"O .I limit
.\"O can be specified in multiple ways:
.IP ""
\fIlimit\fP を指定する方法はいくつかあります。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O The
.\"O .I limit
.\"O can be an absolute value in bytes.
.\"O Using an integer suffix like
.\"O .B MiB
.\"O can be useful.
.\"O Example:
.\"O .B "\-\-memlimit\-compress=80MiB"
.IP \(bu 3
\fIlimit\fP にバイト数の絶対値を指定します。この際には \fBMiB\fP のような整数サフィックスを利用するのが便利です。たとえば
\fB\-\-memlimit\-compress=80MiB\fP とします。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O The
.\"O .I limit
.\"O can be specified as a percentage of total physical memory (RAM).
.\"O This can be useful especially when setting the
.\"O .B XZ_DEFAULTS
.\"O environment variable in a shell initialization script
.\"O that is shared between different computers.
.\"O That way the limit is automatically bigger
.\"O on systems with more memory.
.\"O Example:
.\"O .B "\-\-memlimit\-compress=70%"
.IP \(bu 3
\fIlimit\fP に物理メモリ (RAM) の総容量に対するパーセントを指定することができます。環境変数 \fBXZ_DEFAULTS\fP
を用いてさまざまなコンピューター間において、シェル初期化スクリプトを利用するような場合に特に活用することができます。この方法を用いると、よりメモリ容量の多いシステムでは、自動的に制限値が大きくなります。たとえば
\fB\-\-memlimit\-compress=70%\fP とします。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O The
.\"O .I limit
.\"O can be reset back to its default value by setting it to
.\"O .BR 0 .
.\"O This is currently equivalent to setting the
.\"O .I limit
.\"O to
.\"O .B max
.\"O (no memory usage limit).
.\"O Once multithreading support has been implemented,
.\"O there may be a difference between
.\"O .B 0
.\"O and
.\"O .B max
.\"O for the multithreaded case, so it is recommended to use
.\"O .B 0
.\"O instead of
.\"O .B max
.\"O until the details have been decided.
.IP \(bu 3
\fIlimit\fP を \fB0\fP に指定すれば、デフォルト設定に戻すことができます。現時点では \fIlimit\fP に \fBmax\fP (メモリ利用制限なし)
と指定することと同じです。マルチスレッド対応が実装されたら、マルチスレッド処理時の \fB0\fP と \fBmax\fP
の意味が変わるかもしれません。したがって詳細が決定するまでの間は、\fBmax\fP ではなく \fB0\fP を用いておくことをお勧めします。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .IP ""
.\"O For 32-bit
.\"O .BR xz
.\"O there is a special case: if the
.\"O .I limit
.\"O would be over
.\"O .BR "4020\ MiB" ,
.\"O the
.\"O .I limit
.\"O is set to
.\"O .BR "4020\ MiB" .
.\"O (The values
.\"O .B 0
.\"O and
.\"O .B max
.\"O aren't affected by this.
.\"O A similar feature doesn't exist for decompression.)
.\"O This can be helpful when a 32-bit executable has access
.\"O to 4\ GiB address space while hopefully doing no harm in other situations.
.IP ""
32 ビット版 \fBxz\fP には特別なケースがあります。\fIlimit\fP の設定が \fB4020\ MiB\fP を超える場合、\fIlimit\fP は
\fB4020\ MiB\fP に設定されます。(そうなったとしても \fB0\fP と \fBmax\fP
には影響しません。なお伸長処理にこのような機能はありません。) この機能が他に支障を引き起こさない限りは、32 ビット実行モジュールが 4\ GiB
アドレス空間にアクセスするものとして有用です。
.\"O ----------------------------------------
.\"O .IP ""
.\"O See also the section
.\"O .BR "Memory usage" .
.IP ""
\fBメモリ利用\fP のセクションも参照してください。
.\"O ----------------------------------------
.\"O .TP
.\"O .BI \-\-memlimit\-decompress= limit
.\"O Set a memory usage limit for decompression.
.\"O This also affects the
.\"O .B \-\-list
.\"O mode.
.\"O If the operation is not possible without exceeding the
.\"O .IR limit ,
.\"O .B xz
.\"O will display an error and decompressing the file will fail.
.\"O See
.\"O .BI \-\-memlimit\-compress= limit
.\"O for possible ways to specify the
.\"O .IR limit .
.TP
\fB\-\-memlimit\-decompress=\fP\fIlimit\fP
伸長時のメモリ利用制限を設定します。これは \fB\-\-list\fP モードに影響します。\fIlimit\fP を超えなければ処理できなくなった場合、\fBxz\fP
はエラーを表示して伸長処理は失敗します。\fIlimit\fP の設定する別の方法については \fB\-\-memlimit\-compress=\fP\fIlimit\fP
を参照してください。
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-M\fR \fIlimit\fR, \fB\-\-memlimit=\fIlimit\fR, \fB\-\-memory=\fIlimit
.\"O This is equivalent to specifying \fB\-\-memlimit\-compress=\fIlimit
.\"O \fB\-\-memlimit\-decompress=\fIlimit\fR.
.TP
\fB\-M\fP \fIlimit\fP, \fB\-\-memlimit=\fP\fIlimit\fP, \fB\-\-memory=\fP\fIlimit\fP
これは \fB\-\-memlimit\-compress=\fP\fIlimit \fP\fB\-\-memlimit\-decompress=\fP\fIlimit\fP
と指定することと同じです。
.\"O ----------------------------------------
.\"O .TP
.\"O .B \-\-no\-adjust
.\"O Display an error and exit if the compression settings exceed
.\"O the memory usage limit.
.\"O The default is to adjust the settings downwards so
.\"O that the memory usage limit is not exceeded.
.\"O Automatic adjusting is always disabled when creating raw streams
.\"O .RB ( \-\-format=raw ).
.TP
\fB\-\-no\-adjust\fP
圧縮設定がメモリ利用制限を超えた場合、\fBxz\fP
はエラーを表示して終了します。デフォルトでは、設定内容は引き下げられる方向に調整されます。そのようにしてメモリ利用制限を超えないようにします。この自動調整機能は、生の
(raw) ストリーム生成時 (\fB\-\-format=raw\fP 指定時) は常に無効です。
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-T\fR \fIthreads\fR, \fB\-\-threads=\fIthreads
.\"O Specify the number of worker threads to use.
.\"O Setting
.\"O .I threads
.\"O to a special value
.\"O .B 0
.\"O makes
.\"O .B xz
.\"O use as many threads as there are CPU cores on the system.
.\"O The actual number of threads can be less than
.\"O .I threads
.\"O if the input file is not big enough
.\"O for threading with the given settings or
.\"O if using more threads would exceed the memory usage limit.
.TP
\fB\-T\fP \fIthreads\fP, \fB\-\-threads=\fP\fIthreads\fP
ワーカースレッド数を指定します。\fIthreads\fP に対して特別な値 \fB0\fP を指定すると、\fBxz\fP はシステム上の CPU
コア分のスレッドを利用します。実際のスレッド数は \fIthreads\fP
の指定値より小さくなることがあります。それは入力ファイルのサイズが、指定されたスレッドを必要とするほどには大きくない場合や、スレッドを多く利用しすぎることによってメモリ利用制限を超える場合などです。
.\"O ----------------------------------------
.\"O .IP ""
.\"O Currently the only threading method is to split the input into
.\"O blocks and compress them independently from each other.
.\"O The default block size depends on the compression level and
.\"O can be overridden with the
.\"O .BI \-\-block\-size= size
.\"O option.
.IP ""
現在行われているスレッド処理方法は 1
つだけです。入力データをブロック分けして、互いに独立して圧縮を行うという方法です。デフォルトのブロックサイズは、圧縮レベルに依存します。これは
\fB\-\-block\-size=\fP\fIsize\fP オプションによってオーバーライドすることができます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O Threaded decompression hasn't been implemented yet.
.\"O It will only work on files that contain multiple blocks
.\"O with size information in block headers.
.\"O All files compressed in multi-threaded mode meet this condition,
.\"O but files compressed in single-threaded mode don't even if
.\"O .BI \-\-block\-size= size
.\"O is used.
.\"O .
.IP ""
伸長処理時のスレッド化はまだ実装されていません。スレッド化に対応しているのは、入力ファイルに複数ブロックが含まれていて、そのサイズ情報がブロックヘッダーに存在しているファイルのみです。マルチスレッドモードにおいて圧縮されたファイルは、この条件をすべて満たします。しかしシングルスレッドモードにおいて圧縮されたファイルでは、\fB\-\-block\-size=\fP\fIsize\fP
を指定していたとしても、この条件を満たしません。
.
.\"O ----------------------------------------
.\"O .SS "Custom compressor filter chains"
.\"O A custom filter chain allows specifying
.\"O the compression settings in detail instead of relying on
.\"O the settings associated to the presets.
.\"O When a custom filter chain is specified,
.\"O preset options (\fB\-0\fR ... \fB\-9\fR and \fB\-\-extreme\fR)
.\"O earlier on the command line are forgotten.
.\"O If a preset option is specified
.\"O after one or more custom filter chain options,
.\"O the new preset takes effect and
.\"O the custom filter chain options specified earlier are forgotten.
.SS カスタム圧縮フィルターチェーン
カスタムフィルターチェーン (custom filter chain)
を用いると、圧縮設定を細かく設定することができ、プリセット値に関連づいた設定に頼る必要がなくなります。カスタムフィルターチェーンが指定されると、コマンドライン上でプリセットオプション
(\fB\-0\fP ... \fB\-9\fP および \fB\-\-extreme\fP)
が初めに指定されていても無視されます。また複数のカスタムフィルター指定の後ろにプリセットオプションが指定された場合は、新たな意味になるプリセット指定が採用されて、それよりも前に指定されていたカスタムフィルターチェーンは無視されます。
.\"O ----------------------------------------
.\"O .PP
.\"O A filter chain is comparable to piping on the command line.
.\"O When compressing, the uncompressed input goes to the first filter,
.\"O whose output goes to the next filter (if any).
.\"O The output of the last filter gets written to the compressed file.
.\"O The maximum number of filters in the chain is four,
.\"O but typically a filter chain has only one or two filters.
.PP
フィルターチェーンというものは、コマンドライン上のパイプ処理と同じように動作します。圧縮時には、伸長されている入力データが 1
つめのフィルターに受け渡されます。そしてその出力は、次のフィルターがあればそこに受け渡されます。最終のフィルターから出力される結果が、圧縮ファイルとして書き出されます。指定できるフィルターチェーンは最大
4 つまでです。通常、フィルターチェーンを利用するのは、せいぜい 1 つか 2 つまでです。
.\"O ----------------------------------------
.\"O .PP
.\"O Many filters have limitations on where they can be
.\"O in the filter chain:
.\"O some filters can work only as the last filter in the chain,
.\"O some only as a non-last filter, and some work in any position
.\"O in the chain.
.\"O Depending on the filter, this limitation is either inherent to
.\"O the filter design or exists to prevent security issues.
.PP
フィルターの多くは、どこに記述するかという制限があります。たとえばフィルターの中にはチェーン内の最終フィルターとしてしか動作しないものがあります。逆に最終フィルターとしては動作しないものもあります。もちろんどの場所に置いても動作するものも存在します。フィルターにもよりますが、こういった制約はフィルター設計によって発生している場合や、セキュリティ問題を回避するために存在している場合もあります。
.\"O ----------------------------------------
.\"O .PP
.\"O A custom filter chain is specified by using one or more
.\"O filter options in the order they are wanted in the filter chain.
.\"O That is, the order of filter options is significant!
.\"O When decoding raw streams
.\"O .RB ( \-\-format=raw ),
.\"O the filter chain is specified in the same order as
.\"O it was specified when compressing.
.PP
カスタムフィルターチェーンは、フィルターオプションを必要な分だけ、またフィルターチェーンの中で実行させたい順番で指定します。つまりフィルターオプションとして指定する順番が極めて重要です。生の
(raw) ストリーム (\fB\-\-format=raw\fP 指定)
をデコードする際には、それが圧縮された際に指定された順番どおりのフィルターチェーンを指定します。
.\"O ----------------------------------------
.\"O .PP
.\"O Filters take filter-specific
.\"O .I options
.\"O as a comma-separated list.
.\"O Extra commas in
.\"O .I options
.\"O are ignored.
.\"O Every option has a default value, so you need to
.\"O specify only those you want to change.
.PP
フィルターのオプションは、フィルター固有の \fIoptions\fP であり、カンマで区切ったリストにより指定します。\fIoptions\fP
に余計なカンマがあると無視されます。すべてのオプションにはデフォルト値が設定されています。したがってオプションは、変更したいもののみ指定するだけで十分です。
.\"O ----------------------------------------
.\"O .PP
.\"O To see the whole filter chain and
.\"O .IR options ,
.\"O use
.\"O .B "xz \-vv"
.\"O (that is, use
.\"O .B \-\-verbose
.\"O twice).
.\"O This works also for viewing the filter chain options used by presets.
.PP
フィルターチェーンと \fIoptions\fP をすべて見るには \fBxz \-vv\fP を入力します (つまり \fB\-\-verbose\fP を 2
回指定します)。これにより、プリセットが利用するフィルターチェーンオプションも参照することができます。
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-\-lzma1\fR[\fB=\fIoptions\fR]
.TP
\fB\-\-lzma1\fP[\fB=\fP\fIoptions\fP]
.\"O ----------------------------------------
.\"O .PD 0
.PD 0
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-\-lzma2\fR[\fB=\fIoptions\fR]
.TP
\fB\-\-lzma2\fP[\fB=\fP\fIoptions\fP]
.\"O ----------------------------------------
.\"O .PD
.\"O Add LZMA1 or LZMA2 filter to the filter chain.
.\"O These filters can be used only as the last filter in the chain.
.PD
フィルター LZMA1 および LZMA2 をフィルターチェーンに追加します。これらのフィルターは、チェーン内の最終フィルターとしてのみ利用できます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O LZMA1 is a legacy filter,
.\"O which is supported almost solely due to the legacy
.\"O .B .lzma
.\"O file format, which supports only LZMA1.
.\"O LZMA2 is an updated
.\"O version of LZMA1 to fix some practical issues of LZMA1.
.\"O The
.\"O .B .xz
.\"O format uses LZMA2 and doesn't support LZMA1 at all.
.\"O Compression speed and ratios of LZMA1 and LZMA2
.\"O are practically the same.
.IP ""
LZMA1 は古いフィルターです。古い \fB.lzma\fP ファイルフォーマットは LZMA1 のみに対応していて、つまりこのフィルターは
\&\fB.lzma\fP 向けだけにサポートされています。LZMA2 は LZMA1 の更新版であり、LZMA1
が抱えている具体的な問題を修正しています。\fB.xz\fP フォーマットは LZMA2 を利用していて、LZMA1
には一切対応していません。圧縮速度および圧縮率は、LZMA1 と LZMA2 において実質変わりません。
.\"O ----------------------------------------
.\"O .IP ""
.\"O LZMA1 and LZMA2 share the same set of
.\"O .IR options :
.IP ""
LZMA1 と LXMA2 における \fIoptions\fP は共通しています。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .TP
.\"O .BI preset= preset
.\"O Reset all LZMA1 or LZMA2
.\"O .I options
.\"O to
.\"O .IR preset .
.\"O .I Preset
.\"O consist of an integer, which may be followed by single-letter
.\"O preset modifiers.
.\"O The integer can be from
.\"O .B 0
.\"O to
.\"O .BR 9 ,
.\"O matching the command line options \fB\-0\fR ... \fB\-9\fR.
.\"O The only supported modifier is currently
.\"O .BR e ,
.\"O which matches
.\"O .BR \-\-extreme .
.\"O If no
.\"O .B preset
.\"O is specified, the default values of LZMA1 or LZMA2
.\"O .I options
.\"O are taken from the preset
.\"O .BR 6 .
.TP
\fBpreset=\fP\fIpreset\fP
LZMA1 および LZMA2 の \fIoptions\fP をすべて \fIpreset\fP にリセットします。\fIpreset\fP は整数により構成され、英字
1 文字からなるプリセット修飾子をつける場合があります。整数とは \fB0\fP から \fB9\fP までの値であり、コマンドラインオプション \fB\-0\fP
\&... \fB\-9\fP に対応します。プリセット修飾子とは、今のところ \fBe\fP というもののみがサポートされています。これは \fB\-\-extreme\fP
に対応します。\fBpreset\fP の指定がなかった場合、LZMA1 および LZMA2 の \fIoptions\fP はともにプリセット \fB6\fP
に対応する値がデフォルトして採用されます。
.\"O ----------------------------------------
.\"O .TP
.\"O .BI dict= size
.\"O Dictionary (history buffer)
.\"O .I size
.\"O indicates how many bytes of the recently processed
.\"O uncompressed data is kept in memory.
.\"O The algorithm tries to find repeating byte sequences (matches) in
.\"O the uncompressed data, and replace them with references
.\"O to the data currently in the dictionary.
.\"O The bigger the dictionary, the higher is the chance
.\"O to find a match.
.\"O Thus, increasing dictionary
.\"O .I size
.\"O usually improves compression ratio, but
.\"O a dictionary bigger than the uncompressed file is waste of memory.
.TP
\fBdict=\fP\fIsize\fP
辞書の (履歴バッファの) \fIsize\fP
は、直近にメモリ上で処理され保持されている伸長データのバイト量を表します。そのアルゴリズムでは、伸長データの中からバイトシーケンスの繰り返し
(合致するもの)
を探し出そうとします。そしてその時点での辞書内データへの参照に置き換えます。辞書が大きくなれば、それだけ合致する機会は増えることになります。つまり辞書の
\fIsize\fP を増やしておけば、普通は圧縮率が向上します。ただし伸長ファイル以上に辞書サイズが大きいと、メモリを無駄に消費します。
.\"O ----------------------------------------
.\"O .IP ""
.\"O Typical dictionary
.\"O .I size
.\"O is from 64\ KiB to 64\ MiB.
.\"O The minimum is 4\ KiB.
.\"O The maximum for compression is currently 1.5\ GiB (1536\ MiB).
.\"O The decompressor already supports dictionaries up to
.\"O one byte less than 4\ GiB, which is the maximum for
.\"O the LZMA1 and LZMA2 stream formats.
.IP ""
辞書の \fIsize\fP は通常は 64\ KiB から 64\ MiB です。最小でも 4\ KiB です。圧縮用の最大値は、今のところ 1.5\ GiB (1536\ MiB) です。伸長処理においては 4\ GiB 未満、1 バイトまでの辞書がすでにサポートされています。4\ GiB は
LZMA1 および LZMA2 のストリームフォーマットにおける最大値です。
.\"O ----------------------------------------
.\"O .IP ""
.\"O Dictionary
.\"O .I size
.\"O and match finder
.\"O .RI ( mf )
.\"O together determine the memory usage of the LZMA1 or LZMA2 encoder.
.\"O The same (or bigger) dictionary
.\"O .I size
.\"O is required for decompressing that was used when compressing,
.\"O thus the memory usage of the decoder is determined
.\"O by the dictionary size used when compressing.
.\"O The
.\"O .B .xz
.\"O headers store the dictionary
.\"O .I size
.\"O either as
.\"O .RI "2^" n
.\"O or
.\"O .RI "2^" n " + 2^(" n "\-1),"
.\"O so these
.\"O .I sizes
.\"O are somewhat preferred for compression.
.\"O Other
.\"O .I sizes
.\"O will get rounded up when stored in the
.\"O .B .xz
.\"O headers.
.IP ""
辞書の \fIsize\fP とマッチ検索処理 (match finder; \fImf\fP) はともに、LZMA1 または LZMA2
のエンコード処理におけるメモリ利用量を決定づけます。伸長処理においては、圧縮時に用いられた辞書 \fIsize\fP と同じ (あるいはそれよりも大きい)
サイズが必要になります。つまり伸長処理時のメモリ利用量は、圧縮時に用いられた辞書サイズによって決定します。\fB.xz\fP ヘッダーには辞書の
\fIsize\fP が、2^\fIn\fP または 2^\fIn\fP + 2^(\fIn\fP\-1) のいずれかとして保存されます。したがってこの \fIsizes\fP
はどちらかと言うと、圧縮時に適したものです。これ以外の \fIsizes\fP は \fB.xz\fP ヘッダーに保存される際に切り上げられます。
.\"O ----------------------------------------
.\"O .TP
.\"O .BI lc= lc
.\"O Specify the number of literal context bits.
.\"O The minimum is 0 and the maximum is 4; the default is 3.
.\"O In addition, the sum of
.\"O .I lc
.\"O and
.\"O .I lp
.\"O must not exceed 4.
.TP
\fBlc=\fP\fIlc\fP
リテラルコンテキスト (literal context) のビット数を指定します。最小値は 0、最大値は 4、デフォルトは 3 です。また \fIlc\fP
と \fIlp\fP を合計した値は 4 を超えてはなりません。
.\"O ----------------------------------------
.\"O .IP ""
.\"O All bytes that cannot be encoded as matches
.\"O are encoded as literals.
.\"O That is, literals are simply 8-bit bytes
.\"O that are encoded one at a time.
.IP ""
エンコード処理に際して合致しなかったバイトは、すべてリテラルとしてエンコードされます。つまりリテラルとは、1 回に 1 つずつエンコードされる、単純な
8 ビットのバイト列です。
.\"O ----------------------------------------
.\"O .IP ""
.\"O The literal coding makes an assumption that the highest
.\"O .I lc
.\"O bits of the previous uncompressed byte correlate
.\"O with the next byte.
.\"O E.g. in typical English text, an upper-case letter is
.\"O often followed by a lower-case letter, and a lower-case
.\"O letter is usually followed by another lower-case letter.
.\"O In the US-ASCII character set, the highest three bits are 010
.\"O for upper-case letters and 011 for lower-case letters.
.\"O When
.\"O .I lc
.\"O is at least 3, the literal coding can take advantage of
.\"O this property in the uncompressed data.
.IP ""
リテラルの処理では、直前に伸長したバイトの上位 \fIlc\fP
ビットは、次のバイトと相関関係にあるという前提としています。たとえば通常の英文の場合、英大文字の次にはたいていは小文字が続きます。そしてその小文字の次は、たいていは別の小文字が続きます。また
US\-ASCII キャラクターセットの場合、大文字の上位 3 ビットは 010 であり、小文字の場合は 011 です。\fIlc\fP が最低 3
として設定されていれば、リテラル処理は伸長データ内のこの特性を利用することができます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O The default value (3) is usually good.
.\"O If you want maximum compression, test
.\"O .BR lc=4 .
.\"O Sometimes it helps a little, and
.\"O sometimes it makes compression worse.
.\"O If it makes it worse, test e.g.\&
.\"O .B lc=2
.\"O too.
.IP ""
デフォルト値 (3) は通常はうまく動作します。圧縮率を最大にしたい場合は \fBlc=4\fP
を試してみてください。これによって多少はうまくいくことがありますが、場合によっては圧縮率が悪くなることもあります。もし悪くなった場合には \&
\fBlc=2\fP といった指定も試してみてください。
.\"O ----------------------------------------
.\"O .TP
.\"O .BI lp= lp
.\"O Specify the number of literal position bits.
.\"O The minimum is 0 and the maximum is 4; the default is 0.
.TP
\fBlp=\fP\fIlp\fP
リテラルポジション (literal position) のビット数を指定します。最小値は 0、最大値は 4、デフォルトは 0 です。
.\"O ----------------------------------------
.\"O .IP ""
.\"O .I Lp
.\"O affects what kind of alignment in the uncompressed data is
.\"O assumed when encoding literals.
.\"O See
.\"O .I pb
.\"O below for more information about alignment.
.IP ""
\fIlp\fP はリテラルをエンコードする際に、伸長データ内においてどのようなバイトの並び (alignment)
を前提にするのかという点に影響します。バイトの並びに関する詳細は、以下の \fIpb\fP を参照してください。
.\"O ----------------------------------------
.\"O .TP
.\"O .BI pb= pb
.\"O Specify the number of position bits.
.\"O The minimum is 0 and the maximum is 4; the default is 2.
.TP
\fBpb=\fP\fIpb\fP
ポジションのビット数を指定します。最小値は 0、最大値は 4、デフォルトは 2 です。
.\"O ----------------------------------------
.\"O .IP ""
.\"O .I Pb
.\"O affects what kind of alignment in the uncompressed data is
.\"O assumed in general.
.\"O The default means four-byte alignment
.\"O .RI (2^ pb =2^2=4),
.\"O which is often a good choice when there's no better guess.
.IP ""
\fIpb\fP は全般に、伸長データ内においてどのようなバイトの並び (alignment) を前提にするのかという点に影響します。デフォルト値は 4
バイトの並びを意味します (2^\fIpb\fP=2^2=4)。他に類推する手段がない場合には、これがうまく動作します。
.\"O ----------------------------------------
.\"O .IP ""
.\"O When the aligment is known, setting
.\"O .I pb
.\"O accordingly may reduce the file size a little.
.\"O E.g. with text files having one-byte
.\"O alignment (US-ASCII, ISO-8859-*, UTF-8), setting
.\"O .B pb=0
.\"O can improve compression slightly.
.\"O For UTF-16 text,
.\"O .B pb=1
.\"O is a good choice.
.\"O If the alignment is an odd number like 3 bytes,
.\"O .B pb=0
.\"O might be the best choice.
.IP ""
バイトの並び方がわかっている場合、それに応じて \fIpb\fP を設定しておけば、ファイルサイズをやや小さくできる場合があります。たとえば 1
バイト並びのテキストファイル (US\-ASCII, ISO\-8859\-*, UTF\-8) の場合、\fBpb=0\fP
に設定しておくと、圧縮率がやや向上します。UTF\-16 テキストであれば \fBpb=1\fP とするのが最適です。バイトの並びが 3
バイトなどのような奇数である場合、\fBpb=0\fP とするのが最良かもしれません。
.\"O ----------------------------------------
.\"O .IP ""
.\"O Even though the assumed alignment can be adjusted with
.\"O .I pb
.\"O and
.\"O .IR lp ,
.\"O LZMA1 and LZMA2 still slightly favor 16-byte alignment.
.\"O It might be worth taking into account when designing file formats
.\"O that are likely to be often compressed with LZMA1 or LZMA2.
.IP ""
前提となったバイトの並びは \fIpb\fP や \fIlp\fP を使って調整ができますが、それでも LZMA1 や LZMA2 は 16
バイトの並びの方がふさわしいものです。したがって LZMA1 や LZMA2
を使って圧縮することが多いファイル形式を設計する場合には、このことに配慮しておく価値があるかもしれません。
.\"O ----------------------------------------
.\"O .TP
.\"O .BI mf= mf
.\"O Match finder has a major effect on encoder speed,
.\"O memory usage, and compression ratio.
.\"O Usually Hash Chain match finders are faster than Binary Tree
.\"O match finders.
.\"O The default depends on the
.\"O .IR preset :
.\"O 0 uses
.\"O .BR hc3 ,
.\"O 1\-3
.\"O use
.\"O .BR hc4 ,
.\"O and the rest use
.\"O .BR bt4 .
.TP
\fBmf=\fP\fImf\fP
マッチ検索処理 (match finder)
は、エンコード処理速度、メモリ利用量、圧縮率に大きな影響を与えます。通常はバイナリツリーによるマッチ検索処理よりも、ハッシュチェーンによるマッチ検索処理の方が早くなります。デフォルト値は
\fIpreset\fP の値により変わります。0 のときは \fBhc3\fP、1\-3 のときは \fBhc4\fP、それ以外は \fBbt4\fP がデフォルトになります。
.\"O ----------------------------------------
.\"O .IP ""
.\"O The following match finders are supported.
.\"O The memory usage formulas below are rough approximations,
.\"O which are closest to the reality when
.\"O .I dict
.\"O is a power of two.
.IP ""
マッチ検索処理は以下に示すものがサポートされます。以下に示すメモリ利用計算式 (memory usage formulas)
はかなりの概算であり、\fIdict\fP が 2 のべき乗である場合、実際に最も近くなります。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .TP
.\"O .B hc3
.\"O Hash Chain with 2- and 3-byte hashing
.\"O .br
.\"O Minimum value for
.\"O .IR nice :
.\"O 3
.\"O .br
.\"O Memory usage:
.\"O .br
.\"O .I dict
.\"O * 7.5 (if
.\"O .I dict
.\"O <= 16 MiB);
.\"O .br
.\"O .I dict
.\"O * 5.5 + 64 MiB (if
.\"O .I dict
.\"O > 16 MiB)
.TP
\fBhc3\fP
2 バイトまたは 3 バイトハッシング (hashing) を用いたハッシュチェーン (hash chain)。
.br
\fInice\fP の最小値は 3 です。
.br
メモリ利用量:
.br
\fIdict\fP * 7.5 (\fIdict\fP <= 16 MiB である場合);
.br
\fIdict\fP * 5.5 + 64 MiB (\fIdict\fP > 16 MiB である場合)
.\"O ----------------------------------------
.\"O .TP
.\"O .B hc4
.\"O Hash Chain with 2-, 3-, and 4-byte hashing
.\"O .br
.\"O Minimum value for
.\"O .IR nice :
.\"O 4
.\"O .br
.\"O Memory usage:
.\"O .br
.\"O .I dict
.\"O * 7.5 (if
.\"O .I dict
.\"O <= 32 MiB);
.\"O .br
.\"O .I dict
.\"O * 6.5 (if
.\"O .I dict
.\"O > 32 MiB)
.TP
\fBhc4\fP
2 バイト、3 バイト、4 バイトハッシングを用いたハッシュチェーン。
.br
\fInice\fP の最小値は 4 です。
.br
メモリ利用量:
.br
\fIdict\fP * 7.5 (\fIdict\fP <= 32 MiB である場合);
.br
\fIdict\fP * 6.5 (\fIdict\fP > 32 MiB である場合)
.\"O ----------------------------------------
.\"O .TP
.\"O .B bt2
.\"O Binary Tree with 2-byte hashing
.\"O .br
.\"O Minimum value for
.\"O .IR nice :
.\"O 2
.\"O .br
.\"O Memory usage:
.\"O .I dict
.\"O * 9.5
.TP
\fBbt2\fP
2 バイトハッシングを用いたバイナリツリー (binary tree)。
.br
\fInice\fP の最小値は 2 です。
.br
メモリ利用量: \fIdict\fP * 9.5
.\"O ----------------------------------------
.\"O .TP
.\"O .B bt3
.\"O Binary Tree with 2- and 3-byte hashing
.\"O .br
.\"O Minimum value for
.\"O .IR nice :
.\"O 3
.\"O .br
.\"O Memory usage:
.\"O .br
.\"O .I dict
.\"O * 11.5 (if
.\"O .I dict
.\"O <= 16 MiB);
.\"O .br
.\"O .I dict
.\"O * 9.5 + 64 MiB (if
.\"O .I dict
.\"O > 16 MiB)
.TP
\fBbt3\fP
2 バイトと 3 バイトハッシングを用いたバイナリツリー。
.br
\fInice\fP の最小値は 3 です。
.br
メモリ利用量:
.br
\fIdict\fP * 11.5 (\fIdict\fP <= 16 MiB である場合);
.br
\fIdict\fP * 9.5 + 64 MiB (\fIdict\fP > 16 MiB である場合)
.\"O ----------------------------------------
.\"O .TP
.\"O .B bt4
.\"O Binary Tree with 2-, 3-, and 4-byte hashing
.\"O .br
.\"O Minimum value for
.\"O .IR nice :
.\"O 4
.\"O .br
.\"O Memory usage:
.\"O .br
.\"O .I dict
.\"O * 11.5 (if
.\"O .I dict
.\"O <= 32 MiB);
.\"O .br
.\"O .I dict
.\"O * 10.5 (if
.\"O .I dict
.\"O > 32 MiB)
.TP
\fBbt4\fP
2 バイト、3 バイト、4 バイトハッシングを用いたバイナリツリー。
.br
\fInice\fP の最小値は 4 です。
.br
メモリ利用量:
.br
\fIdict\fP * 11.5 (\fIdict\fP <= 32 MiB である場合);
.br
\fIdict\fP * 10.5 (\fIdict\fP > 32 MiB である場合)
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .TP
.\"O .BI mode= mode
.\"O Compression
.\"O .I mode
.\"O specifies the method to analyze
.\"O the data produced by the match finder.
.\"O Supported
.\"O .I modes
.\"O are
.\"O .B fast
.\"O and
.\"O .BR normal .
.\"O The default is
.\"O .B fast
.\"O for
.\"O .I presets
.\"O 0\-3 and
.\"O .B normal
.\"O for
.\"O .I presets
.\"O 4\-9.
.TP
\fBmode=\fP\fImode\fP
圧縮の \fImode\fP は、マッチ検索処理によって生成されるデータの分析手法を指定します。サポートされる \fImodes\fP は \fBfast\fP と
\fBnormal\fP です。デフォルトは \fIpresets\fP が 0\-3 のとき \fBfast\fP、\fIpresets\fP が 4\-9 のとき
\fBnormal\fP です。
.\"O ----------------------------------------
.\"O .IP ""
.\"O Usually
.\"O .B fast
.\"O is used with Hash Chain match finders and
.\"O .B normal
.\"O with Binary Tree match finders.
.\"O This is also what the
.\"O .I presets
.\"O do.
.IP ""
一般的に \fBfast\fP が用いられるのはハッシュチェーンによるマッチ検索処理の場合であり、\fBnormal\fP
はバイナリツリーによるマッチ検索処理の場合です。これは \fIpresets\fP が用いるものと同じです。
.\"O ----------------------------------------
.\"O .TP
.\"O .BI nice= nice
.\"O Specify what is considered to be a nice length for a match.
.\"O Once a match of at least
.\"O .I nice
.\"O bytes is found, the algorithm stops
.\"O looking for possibly better matches.
.TP
\fBnice=\fP\fInice\fP
マッチ処理に対して適切なバイト数と思われる値を指定します。最低 \fInice\fP
バイト分にマッチしたとき、アルゴリズムはそれ以上、マッチする可能性をあきらめて探さないようにします。
.\"O ----------------------------------------
.\"O .IP ""
.\"O .I Nice
.\"O can be 2\-273 bytes.
.\"O Higher values tend to give better compression ratio
.\"O at the expense of speed.
.\"O The default depends on the
.\"O .IR preset .
.IP ""
\fINice\fP は 2 ~ 273 バイトの範囲とします。値を大きくすれば処理速度は低下しますが、より高い圧縮率が得られる傾向にあります。デフォルト値は
\fIpreset\fP の値によって変わります。
.\"O ----------------------------------------
.\"O .TP
.\"O .BI depth= depth
.\"O Specify the maximum search depth in the match finder.
.\"O The default is the special value of 0,
.\"O which makes the compressor determine a reasonable
.\"O .I depth
.\"O from
.\"O .I mf
.\"O and
.\"O .IR nice .
.TP
\fBdepth=\fP\fIdepth\fP
マッチ検索処理において、検索する最大深さを指定します。デフォルトは特別な値 0 です。この値は、圧縮処理において \fImf\fP と \fInice\fP
の値から妥当な値 \fIdepth\fP が決定されることを意味します。
.\"O ----------------------------------------
.\"O .IP ""
.\"O Reasonable
.\"O .I depth
.\"O for Hash Chains is 4\-100 and 16\-1000 for Binary Trees.
.\"O Using very high values for
.\"O .I depth
.\"O can make the encoder extremely slow with some files.
.\"O Avoid setting the
.\"O .I depth
.\"O over 1000 unless you are prepared to interrupt
.\"O the compression in case it is taking far too long.
.IP ""
ハッシュチェーンに対しての妥当な \fIdepth\fP の値は 4 ~ 100 です。バイナリツリーでは 16 ~ 1000 です。\fIdepth\fP
に対して非常に大きな値を設定すると、ファイル内容によってはエンコード処理が極端に遅くなる場合があります。時間が無用に長くなりすぎた際に圧縮を取りやめる段取りが整っていないのであれば、\fIdepth\fP
に 1000 以上の値を設定することは避けてください。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .IP ""
.\"O When decoding raw streams
.\"O .RB ( \-\-format=raw ),
.\"O LZMA2 needs only the dictionary
.\"O .IR size .
.\"O LZMA1 needs also
.\"O .IR lc ,
.\"O .IR lp ,
.\"O and
.\"O .IR pb .
.IP ""
生の (raw) ストリーム (\fB\-\-format=raw\fP 指定) に対するデコード処理の際には、LZMA2 は辞書サイズ \fIsize\fP
だけが必要です。LZMA1 の場合は \fIlc\fP, \fIlp\fP, \fIpb\fP だけあれば十分です。
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-\-x86\fR[\fB=\fIoptions\fR]
.TP
\fB\-\-x86\fP[\fB=\fP\fIoptions\fP]
.\"O ----------------------------------------
.\"O .PD 0
.PD 0
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-\-powerpc\fR[\fB=\fIoptions\fR]
.TP
\fB\-\-powerpc\fP[\fB=\fP\fIoptions\fP]
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-\-ia64\fR[\fB=\fIoptions\fR]
.TP
\fB\-\-ia64\fP[\fB=\fP\fIoptions\fP]
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-\-arm\fR[\fB=\fIoptions\fR]
.TP
\fB\-\-arm\fP[\fB=\fP\fIoptions\fP]
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-\-armthumb\fR[\fB=\fIoptions\fR]
.TP
\fB\-\-armthumb\fP[\fB=\fP\fIoptions\fP]
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-\-sparc\fR[\fB=\fIoptions\fR]
.TP
\fB\-\-sparc\fP[\fB=\fP\fIoptions\fP]
.\"O ----------------------------------------
.\"O .PD
.\"O Add a branch/call/jump (BCJ) filter to the filter chain.
.\"O These filters can be used only as a non-last filter
.\"O in the filter chain.
.PD
branch/call/jump (BCJ)
フィルターをフィルターチェーンに追加します。このフィルターは、フィルターチェーン内の最終フィルターとして利用することはできません。
.\"O ----------------------------------------
.\"O .IP ""
.\"O A BCJ filter converts relative addresses in
.\"O the machine code to their absolute counterparts.
.\"O This doesn't change the size of the data,
.\"O but it increases redundancy,
.\"O which can help LZMA2 to produce 0\-15\ % smaller
.\"O .B .xz
.\"O file.
.\"O The BCJ filters are always reversible,
.\"O so using a BCJ filter for wrong type of data
.\"O doesn't cause any data loss, although it may make
.\"O the compression ratio slightly worse.
.IP ""
BCJ フィルターは、マシンコード内の相対アドレスを絶対アドレスに変換します。これによりデータサイズは変わりません。ただし冗長性は増します。LZMA2
からは 0 ~ 15\ % 小さな \fB.xz\fP ファイルが生成されることになります。BCJ
フィルターはいつでも元に戻すことができます。つまり誤ったデータタイプに対して BCJ
フィルターを用いても、データを失うことはありません。ただし圧縮率がやや低下することがあります。
.\"O ----------------------------------------
.\"O .IP ""
.\"O It is fine to apply a BCJ filter on a whole executable;
.\"O there's no need to apply it only on the executable section.
.\"O Applying a BCJ filter on an archive that contains both executable
.\"O and non-executable files may or may not give good results,
.\"O so it generally isn't good to blindly apply a BCJ filter when
.\"O compressing binary packages for distribution.
.IP ""
BCJ フィルターを 1 つの実行モジュールに適用しても、問題はありません。そしてこのフィルターを実行モジュールの実行セクション (executable
section)
にのみ適用する必要はありません。実行モジュールとそうでないファイルを両方含むアーカイブに対してこのフィルターを適用すると、良い結果が得られる場合もあり、そうでない場合もあります。したがって一般的には、バイナリパッケージを配布向けに圧縮する際にまで、BCJ
フィルターを用いるのは適切ではありません。
.\"O ----------------------------------------
.\"O .IP ""
.\"O These BCJ filters are very fast and
.\"O use insignificant amount of memory.
.\"O If a BCJ filter improves compression ratio of a file,
.\"O it can improve decompression speed at the same time.
.\"O This is because, on the same hardware,
.\"O the decompression speed of LZMA2 is roughly
.\"O a fixed number of bytes of compressed data per second.
.IP ""
この BCJ フィルターは非常に高速であり、目立ったメモリ消費は発生しません。BCJ
フィルターによってファイル圧縮率が向上したとすれば、伸長処理の速度が向上します。なぜなら同一のハードウェア上であれば、伸長にかかる処理速度は毎秒、データ圧縮に要したバイト数の倍数にほぼ一致するからです。
.\"O ----------------------------------------
.\"O .IP ""
.\"O These BCJ filters have known problems related to
.\"O the compression ratio:
.IP ""
この BCJ フィルターには、圧縮率に関して以下のような問題があります。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O Some types of files containing executable code
.\"O (e.g. object files, static libraries, and Linux kernel modules)
.\"O have the addresses in the instructions filled with filler values.
.\"O These BCJ filters will still do the address conversion,
.\"O which will make the compression worse with these files.
.IP \(bu 3
実行コードを含んだファイル (たとえばオブジェクトファイル、スタティックライブラリ、Linux カーネルモジュールなど)
の中には、命令内のアドレスにフィルター値が埋め込まれることになります。この BCJ
フィルターは、それでもアドレス変換を続行しますが、そういったファイルにおいては圧縮率が悪くなる場合があります。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O Applying a BCJ filter on an archive containing multiple similar
.\"O executables can make the compression ratio worse than not using
.\"O a BCJ filter.
.\"O This is because the BCJ filter doesn't detect the boundaries
.\"O of the executable files, and doesn't reset
.\"O the address conversion counter for each executable.
.IP \(bu 3
似通った実行モジュールが複数含まれるアーカイブに対して BCJ フィルターを適用すると、BCJ
フィルターを使わなかった場合に比べて圧縮率が悪くなります。これは BCJ
フィルターが実行モジュール間の境界を検出しないためであり、各実行モジュールに対してアドレス変換のカウンターをリセットしないことから発生します。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .IP ""
.\"O Both of the above problems will be fixed
.\"O in the future in a new filter.
.\"O The old BCJ filters will still be useful in embedded systems,
.\"O because the decoder of the new filter will be bigger
.\"O and use more memory.
.IP ""
今後は新たなフィルターを通じて、上記の 2 つの問題は解消される予定です。従来の BCJ
フィルターは、埋め込みシステムにおいては引き続き有用となるはずです。新たなフィルターによるデコード処理は、より大きくなりメモリ消費も増加するはずだからです。
.\"O ----------------------------------------
.\"O .IP ""
.\"O Different instruction sets have different alignment:
.IP ""
命令セットが異なるとバイトの並びも異なります。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .TS
.\"O tab(;);
.\"O l n l
.\"O l n l.
.\"O Filter;Alignment;Notes
.\"O x86;1;32-bit or 64-bit x86
.\"O PowerPC;4;Big endian only
.\"O ARM;4;Little endian only
.\"O ARM-Thumb;2;Little endian only
.\"O IA-64;16;Big or little endian
.\"O SPARC;4;Big or little endian
.\"O .TE
.PP
.TS
tab(;);
l n l
l n l.
フィルター;並び;説明
x86;1;32 ビット、64 ビット x86
PowerPC;4;ビッグエンディアンのみ
ARM;4;リトルエンディアンのみ
ARM\-Thumb;2;リトルエンディアンのみ
IA\-64;16;ビッグおよびリトルエンディアン
SPARC;4;ビッグおよびリトルエンディアン
.TE
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .IP ""
.\"O Since the BCJ-filtered data is usually compressed with LZMA2,
.\"O the compression ratio may be improved slightly if
.\"O the LZMA2 options are set to match the
.\"O alignment of the selected BCJ filter.
.\"O For example, with the IA-64 filter, it's good to set
.\"O .B pb=4
.\"O with LZMA2 (2^4=16).
.\"O The x86 filter is an exception;
.\"O it's usually good to stick to LZMA2's default
.\"O four-byte alignment when compressing x86 executables.
.IP ""
BCJ フィルターによって処理したデータは、通常は LZMA2 によって圧縮されるので、利用された BCJ フィルターのバイト並びにマッチするように
LZMA2 オプションが設定されていれば、圧縮率はわずかながら改善されます。たとえば IA\-64 フィルターを用いた場合、LZMA2 に対しては
\fBpb=4\fP (2^4=16) とするのが適切です。x86 フィルターの場合は例外として考えてください。x86
実行モジュールを圧縮する場合には、LZMA2 のデフォルトである 4 バイト並びを必ず用いるようにするのが適切です。
.\"O ----------------------------------------
.\"O .IP ""
.\"O All BCJ filters support the same
.\"O .IR options :
.IP ""
BCJ フィルターはすべて同一の \fIoptions\fP をサポートします。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .TP
.\"O .BI start= offset
.\"O Specify the start
.\"O .I offset
.\"O that is used when converting between relative
.\"O and absolute addresses.
.\"O The
.\"O .I offset
.\"O must be a multiple of the alignment of the filter
.\"O (see the table above).
.\"O The default is zero.
.\"O In practice, the default is good; specifying a custom
.\"O .I offset
.\"O is almost never useful.
.TP
\fBstart=\fP\fIoffset\fP
相対および絶対アドレス間の変換の際に用いられる、オフセット値 \fIoffset\fP の開始位置を指定します。\fIoffset\fP
はフィルターのバイト並びの倍数でなければなりません (上表参照)。デフォルトはゼロです。現実にはゼロとすれば十分です。つまり \fIoffset\fP
を独自に設定しても、たいていは役に立ちません。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .TP
.\"O \fB\-\-delta\fR[\fB=\fIoptions\fR]
.\"O Add the Delta filter to the filter chain.
.\"O The Delta filter can be only used as a non-last filter
.\"O in the filter chain.
.TP
\fB\-\-delta\fP[\fB=\fP\fIoptions\fP]
フィルターチェーンにデルタ (delta)
フィルターを追加します。デルタフィルターは、フィルターチェーン内の最終フィルターとして利用することはできません。
.\"O ----------------------------------------
.\"O .IP ""
.\"O Currently only simple byte-wise delta calculation is supported.
.\"O It can be useful when compressing e.g. uncompressed bitmap images
.\"O or uncompressed PCM audio.
.\"O However, special purpose algorithms may give significantly better
.\"O results than Delta + LZMA2.
.\"O This is true especially with audio,
.\"O which compresses faster and better e.g. with
.\"O .BR flac (1).
.IP ""
現時点では、単純にバイト単位によるデルタ計算のみがサポートされています。これはたとえばビットマップイメージあるいは PCM
オーディオを圧縮する際に利用できます。ただし特別に用意されたアルゴリズムを使えば Delta + LZMA2
よりも優れた結果が得られるかもしれません。これはオーディオデータに対しては明らかなことで、\fBflac\fP(1)
などを用いれば、圧縮はより速く適切なものになります。
.\"O ----------------------------------------
.\"O .IP ""
.\"O Supported
.\"O .IR options :
.IP ""
サポートされている \fIoptions\fP:
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .TP
.\"O .BI dist= distance
.\"O Specify the
.\"O .I distance
.\"O of the delta calculation in bytes.
.\"O .I distance
.\"O must be 1\-256.
.\"O The default is 1.
.TP
\fBdist=\fP\fIdistance\fP
デルタ計算の \fIdistance\fP をバイト単位で指定します。\fIdistance\fP は 1 ~ 256 であることが必要です。デフォルトは 1
です。
.\"O ----------------------------------------
.\"O .IP ""
.\"O For example, with
.\"O .B dist=2
.\"O and eight-byte input A1 B1 A2 B3 A3 B5 A4 B7, the output will be
.\"O A1 B1 01 02 01 02 01 02.
.IP ""
たとえば \fBdist=2\fP を指定し、入力が 8 バイト A1 B1 A2 B3 A3 B5 A4 B7 であったとすると、出力は A1 B1 01
02 01 02 01 02 となります。
.\"O ----------------------------------------
.\"O .RE
.\"O .
.RE
.
.\"O ----------------------------------------
.\"O .SS "Other options"
.SS その他のオプション
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-q ", " \-\-quiet
.\"O Suppress warnings and notices.
.\"O Specify this twice to suppress errors too.
.\"O This option has no effect on the exit status.
.\"O That is, even if a warning was suppressed,
.\"O the exit status to indicate a warning is still used.
.TP
\fB\-q\fP, \fB\-\-quiet\fP
警告メッセージや通知メッセージを省略します。この指定を 2
つ重ねると、エラーメッセージも省略します。本オプションは終了ステータスには影響しません。警告メッセージがたとえ省略されていても変わらないことなので、終了ステータスには警告を示す値が返されます。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-v ", " \-\-verbose
.\"O Be verbose.
.\"O If standard error is connected to a terminal,
.\"O .B xz
.\"O will display a progress indicator.
.\"O Specifying
.\"O .B \-\-verbose
.\"O twice will give even more verbose output.
.TP
\fB\-v\fP, \fB\-\-verbose\fP
詳細な出力とします。標準エラー出力が端末に接続されている場合、\fBxz\fP は進捗インジケーターを表示します。\fB\-\-verbose\fP を 2
つ重ねて指定すると、さらに詳細な出力が行われます。
.\"O ----------------------------------------
.\"O .IP ""
.\"O The progress indicator shows the following information:
.IP ""
進捗インジケーターには以下の情報が表示されます。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O Completion percentage is shown
.\"O if the size of the input file is known.
.\"O That is, the percentage cannot be shown in pipes.
.IP \(bu 3
入力ファイルのサイズがわかっている場合は、完了率が表示されます。これはパイプ処理の場合には表示されません。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O Amount of compressed data produced (compressing)
.\"O or consumed (decompressing).
.IP \(bu 3
生成された圧縮データ量 (圧縮時) または消費された圧縮データ量 (伸長時) が表示されます。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O Amount of uncompressed data consumed (compressing)
.\"O or produced (decompressing).
.IP \(bu 3
消費された伸長データ量 (圧縮時) または生成された伸長データ量 (伸長時) が表示されます。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O Compression ratio, which is calculated by dividing
.\"O the amount of compressed data processed so far by
.\"O the amount of uncompressed data processed so far.
.IP \(bu 3
圧縮率が表示されます。これはその時点までに圧縮されたデータ量を、未圧縮のデータ量で割った値として算出されます。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O Compression or decompression speed.
.\"O This is measured as the amount of uncompressed data consumed
.\"O (compression) or produced (decompression) per second.
.\"O It is shown after a few seconds have passed since
.\"O .B xz
.\"O started processing the file.
.IP \(bu 3
圧縮または伸長の処理速度が表示されます。これは消費された伸長データ (圧縮時) または生成された伸長データ (伸長時)
の秒ごとの処理量です。処理量の表示は \fBxz\fP がファイル処理を開始した後、しばらくたってから表示されます。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O Elapsed time in the format M:SS or H:MM:SS.
.IP \(bu 3
経過時間を M:SS または H:MM:SS の書式により表示します。
.\"O ----------------------------------------
.\"O .IP \(bu 3
.\"O Estimated remaining time is shown
.\"O only when the size of the input file is
.\"O known and a couple of seconds have already passed since
.\"O .B xz
.\"O started processing the file.
.\"O The time is shown in a less precise format which
.\"O never has any colons, e.g. 2 min 30 s.
.IP \(bu 3
入力ファイルのサイズがわかっている場合だけ、残り時間の見積もりが表示されます。その場合、\fBxz\fP
がファイル処理を開始してから、数秒が経過した後に表示が始まります。時刻表記は精度を落として、小数点表記を行いません。たとえば 2 min 30 s
とします。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .IP ""
.\"O When standard error is not a terminal,
.\"O .B \-\-verbose
.\"O will make
.\"O .B xz
.\"O print the filename, compressed size, uncompressed size,
.\"O compression ratio, and possibly also the speed and elapsed time
.\"O on a single line to standard error after compressing or
.\"O decompressing the file.
.\"O The speed and elapsed time are included only when
.\"O the operation took at least a few seconds.
.\"O If the operation didn't finish, e.g. due to user interruption,
.\"O also the completion percentage is printed
.\"O if the size of the input file is known.
.IP ""
標準エラー出力先が端末ではない場合、\fB\-\-verbose\fP
によって出力される内容は、ファイル名、圧縮サイズ、伸長サイズ、圧縮率です。また圧縮あるいは伸長が始まると、表示可能であれば処理速度や経過時間を 1
行にまとめて標準エラー出力に書き出します。処理速度や経過時間が表示されるのは、あくまで処理時間が一定秒数以上かかる場合のみです。ユーザーによる処理中断のように処理が完了しなかった場合でも、入力ファイルサイズがわかっていれば、完了率は表示されます。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-Q ", " \-\-no\-warn
.\"O Don't set the exit status to 2
.\"O even if a condition worth a warning was detected.
.\"O This option doesn't affect the verbosity level, thus both
.\"O .B \-\-quiet
.\"O and
.\"O .B \-\-no\-warn
.\"O have to be used to not display warnings and
.\"O to not alter the exit status.
.TP
\fB\-Q\fP, \fB\-\-no\-warn\fP
警告に相当する状況が発生したとしても、終了ステータスは 2 に設定しないでください。本オプションは詳細表示のレベルには影響しません。したがって
\fB\-\-quiet\fP と \fB\-\-no\-warn\fP の 2
つは、警告を非表示とするために利用するものであって、終了ステータスを変更する目的で用いてはなりません。
.\"O ----------------------------------------
.\"O .TP
.\"O .B \-\-robot
.\"O Print messages in a machine-parsable format.
.\"O This is intended to ease writing frontends that want to use
.\"O .B xz
.\"O instead of liblzma, which may be the case with various scripts.
.\"O The output with this option enabled is meant to be stable across
.\"O .B xz
.\"O releases.
.\"O See the section
.\"O .B "ROBOT MODE"
.\"O for details.
.TP
\fB\-\-robot\fP
マシン解析が可能な書式でメッセージ出力を行います。これは liblzma でなく \fBxz\fP
を利用したフロントエンドを容易に構築できるように意図したものです。おそらくは、さまざまなスクリプトを用いることを想定しています。本オプションを使って出力した結果は、\fBxz\fP
の将来のリリースに向けて安定して提供していくつもりです。詳しくは \fBロボットモード\fP セクションを参照してください。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-\-info\-memory
.\"O Display, in human-readable format, how much physical memory (RAM)
.\"O .B xz
.\"O thinks the system has and the memory usage limits for compression
.\"O and decompression, and exit successfully.
.TP
\fB\-\-info\-memory\fP
読みやすい書式で以下の出力を行います。\fBxz\fP が識別している、システム搭載の物理メモリ (RAM)
量。圧縮および伸長におけるメモリ利用制限。これを表示して正常終了します。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-h ", " \-\-help
.\"O Display a help message describing the most commonly used options,
.\"O and exit successfully.
.TP
\fB\-h\fP, \fB\-\-help\fP
よく利用されるオプションに対するヘルプメッセージを表示して、正常終了します。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-H ", " \-\-long\-help
.\"O Display a help message describing all features of
.\"O .BR xz ,
.\"O and exit successfully
.TP
\fB\-H\fP, \fB\-\-long\-help\fP
\fBxz\fP の全機能を説明するヘルプメッセージを表示して、正常終了します。
.\"O ----------------------------------------
.\"O .TP
.\"O .BR \-V ", " \-\-version
.\"O Display the version number of
.\"O .B xz
.\"O and liblzma in human readable format.
.\"O To get machine-parsable output, specify
.\"O .B \-\-robot
.\"O before
.\"O .BR \-\-version .
.\"O .
.TP
\fB\-V\fP, \fB\-\-version\fP
\fBxz\fP と liblzma のバージョン番号を読みやすい書式で表示します。マシンが解析しやすい出力とするには、\fB\-\-version\fP の前に
\fB\-\-robot\fP を指定します。
.
.\"O ----------------------------------------
.\"O .SH "ROBOT MODE"
.\"O The robot mode is activated with the
.\"O .B \-\-robot
.\"O option.
.\"O It makes the output of
.\"O .B xz
.\"O easier to parse by other programs.
.\"O Currently
.\"O .B \-\-robot
.\"O is supported only together with
.\"O .BR \-\-version ,
.\"O .BR \-\-info\-memory ,
.\"O and
.\"O .BR \-\-list .
.\"O It will be supported for compression and
.\"O decompression in the future.
.\"O .
.SH ロボットモード
ロボットモードは \fB\-\-robot\fP オプションを指定することで有効になります。これを指定すると、別プログラムが \fBxz\fP
の出力を解析しやすくなります。今のところ \fB\-\-robot\fP は、\fB\-\-version\fP, \fB\-\-info\-memory\fP, \fB\-\-list\fP
をともに指定したときのみ機能するようになっています。将来は圧縮時、伸長時にも対応する予定です。
.
.\"O ----------------------------------------
.\"O .SS Version
.\"O .B "xz \-\-robot \-\-version"
.\"O will print the version number of
.\"O .B xz
.\"O and liblzma in the following format:
.SS バージョン
\fBxz \-\-robot \-\-version\fP を実行すると、\fBxz\fP と liblzma のバージョンを以下の書式により出力します。
.\"O ----------------------------------------
.\"O .PP
.\"O .BI XZ_VERSION= XYYYZZZS
.\"O .br
.\"O .BI LIBLZMA_VERSION= XYYYZZZS
.PP
\fBXZ_VERSION=\fP\fIXYYYZZZS\fP
.br
\fBLIBLZMA_VERSION=\fP\fIXYYYZZZS\fP
.\"O ----------------------------------------
.\"O .TP
.\"O .I X
.\"O Major version.
.TP
\fIX\fP
メジャーバージョン。
.\"O ----------------------------------------
.\"O .TP
.\"O .I YYY
.\"O Minor version.
.\"O Even numbers are stable.
.\"O Odd numbers are alpha or beta versions.
.TP
\fIYYY\fP
マイナーバージョン。偶数が安定版を意味します。奇数はアルファ版かベータ版を表します。
.\"O ----------------------------------------
.\"O .TP
.\"O .I ZZZ
.\"O Patch level for stable releases or
.\"O just a counter for development releases.
.TP
\fIZZZ\fP
安定版に対するパッチレベル。または単に開発版の割り振り番号。
.\"O ----------------------------------------
.\"O .TP
.\"O .I S
.\"O Stability.
.\"O 0 is alpha, 1 is beta, and 2 is stable.
.\"O .I S
.\"O should be always 2 when
.\"O .I YYY
.\"O is even.
.TP
\fIS\fP
安定度合い。0 はアルファ版、1 はベータ版、2 は安定版をそれぞれ表します。\fIYYY\fP が偶数のとき \fIS\fP は必ず 2 となります。
.\"O ----------------------------------------
.\"O .PP
.\"O .I XYYYZZZS
.\"O are the same on both lines if
.\"O .B xz
.\"O and liblzma are from the same XZ Utils release.
.PP
\fBxz\fP と liblzma が同一 XZ Utils リリースのものである限り、2 行に表示されている \fIXYYYZZZS\fP
の表記は同一になります。
.\"O ----------------------------------------
.\"O .PP
.\"O Examples: 4.999.9beta is
.\"O .B 49990091
.\"O and
.\"O 5.0.0 is
.\"O .BR 50000002 .
.\"O .
.PP
例: 4.999.9beta は \fB49990091\fP、5.0.0 は \fB50000002\fP と表記されます。
.
.\"O ----------------------------------------
.\"O .SS "Memory limit information"
.\"O .B "xz \-\-robot \-\-info\-memory"
.\"O prints a single line with three tab-separated columns:
.SS メモリ制限に関する情報
\fBxz \-\-robot \-\-info\-memory\fP を指定すると、タブで区切った 3 つの情報を 1 行で出力します。
.\"O ----------------------------------------
.\"O .IP 1. 4
.\"O Total amount of physical memory (RAM) in bytes
.IP 1. 4
物理メモリ (RAM) の総容量。バイト単位。
.\"O ----------------------------------------
.\"O .IP 2. 4
.\"O Memory usage limit for compression in bytes.
.\"O A special value of zero indicates the default setting,
.\"O which for single-threaded mode is the same as no limit.
.IP 2. 4
圧縮時のメモリ利用制限。バイト単位。特別な値としてゼロがあります。これはシングルスレッドモードでのデフォルト値であり、無制限を意味します。
.\"O ----------------------------------------
.\"O .IP 3. 4
.\"O Memory usage limit for decompression in bytes.
.\"O A special value of zero indicates the default setting,
.\"O which for single-threaded mode is the same as no limit.
.IP 3. 4
伸長時のメモリ利用制限。バイト単位。特別な値としてゼロがあります。これはシングルスレッドモードでのデフォルト値であり、無制限を意味します。
.\"O ----------------------------------------
.\"O .PP
.\"O In the future, the output of
.\"O .B "xz \-\-robot \-\-info\-memory"
.\"O may have more columns, but never more than a single line.
.\"O .
.PP
\fBxz \-\-robot \-\-info\-memory\fP
の出力項目は、今後追加される可能性があります。ただし複数行にわたって出力するような変更は行いません。
.
.\"O ----------------------------------------
.\"O .SS "List mode"
.\"O .B "xz \-\-robot \-\-list"
.\"O uses tab-separated output.
.\"O The first column of every line has a string
.\"O that indicates the type of the information found on that line:
.SS リストモード
\fBxz \-\-robot \-\-list\fP はタブ区切りによる出力を行います。各行における先頭カラムは、それぞれの行に示される情報の種類を表します。
.\"O ----------------------------------------
.\"O .TP
.\"O .B name
.\"O This is always the first line when starting to list a file.
.\"O The second column on the line is the filename.
.TP
\fBname\fP
ファイルの一覧を示す際にはこれが必ず第 1 行めに置かれます。その行の第 2 カラムにはファイル名が出力されます。
.\"O ----------------------------------------
.\"O .TP
.\"O .B file
.\"O This line contains overall information about the
.\"O .B .xz
.\"O file.
.\"O This line is always printed after the
.\"O .B name
.\"O line.
.TP
\fBfile\fP
この行には \fB.xz\fP ファイルに関する全体的な情報が示されます。この行は必ず \fBname\fP 行の次に表示されます。
.\"O ----------------------------------------
.\"O .TP
.\"O .B stream
.\"O This line type is used only when
.\"O .B \-\-verbose
.\"O was specified.
.\"O There are as many
.\"O .B stream
.\"O lines as there are streams in the
.\"O .B .xz
.\"O file.
.TP
\fBstream\fP
この行タイプは \fB\-\-verbose\fP が指定された場合にのみ表示されます。\fB.xz\fP ファイル内に存在するストリーム分だけ \fBstream\fP
行が出力されます。
.\"O ----------------------------------------
.\"O .TP
.\"O .B block
.\"O This line type is used only when
.\"O .B \-\-verbose
.\"O was specified.
.\"O There are as many
.\"O .B block
.\"O lines as there are blocks in the
.\"O .B .xz
.\"O file.
.\"O The
.\"O .B block
.\"O lines are shown after all the
.\"O .B stream
.\"O lines; different line types are not interleaved.
.TP
\fBblock\fP
この行タイプは \fB\-\-verbose\fP が指定された場合にのみ表示されます。\fB.xz\fP ファイル内に存在するブロック分だけ \fBblock\fP
行が出力されます。\fBblock\fP 行は \fBstream\fP
行の出力がすべて行われた後に出力されます。つまりタイプの異なる両者が混在して出力されることはありません。
.\"O ----------------------------------------
.\"O .TP
.\"O .B summary
.\"O This line type is used only when
.\"O .B \-\-verbose
.\"O was specified twice.
.\"O This line is printed after all
.\"O .B block
.\"O lines.
.\"O Like the
.\"O .B file
.\"O line, the
.\"O .B summary
.\"O line contains overall information about the
.\"O .B .xz
.\"O file.
.TP
\fBsummary\fP
この行タイプは \fB\-\-verbose\fP が 2 重に指定された場合にのみ表示されます。この行は \fBblock\fP 行の次に出力されます。\fBfile\fP
行と同様に \fBsummary\fP 行には \fB.xz\fP ファイルに関する全体的な情報が示されます。
.\"O ----------------------------------------
.\"O .TP
.\"O .B totals
.\"O This line is always the very last line of the list output.
.\"O It shows the total counts and sizes.
.TP
\fBtotals\fP
本行は必ず出力結果の最終行に位置します。ここには総数、総サイズが示されます。
.\"O ----------------------------------------
.\"O .PP
.\"O The columns of the
.\"O .B file
.\"O lines:
.PP
\fBfile\fP 行のカラム:
.\"O ----------------------------------------
.\"O .PD 0
.PD 0
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP 2. 4
.\"O Number of streams in the file
.IP 2. 4
ファイル内のストリーム数。
.\"O ----------------------------------------
.\"O .IP 3. 4
.\"O Total number of blocks in the stream(s)
.IP 3. 4
ストリーム内のブロック総数。
.\"O ----------------------------------------
.\"O .IP 4. 4
.\"O Compressed size of the file
.IP 4. 4
ファイルの圧縮サイズ。
.\"O ----------------------------------------
.\"O .IP 5. 4
.\"O Uncompressed size of the file
.IP 5. 4
ファイルの伸長サイズ。
.\"O ----------------------------------------
.\"O .IP 6. 4
.\"O Compression ratio, for example
.\"O .BR 0.123.
.\"O If ratio is over 9.999, three dashes
.\"O .RB ( \-\-\- )
.\"O are displayed instead of the ratio.
.IP 6. 4
圧縮率。たとえば \fB0.123\fP など。圧縮率が 9.999 を超える場合は、圧縮率は表示せず 3 つのダッシュ (\fB\-\-\-\fP) が表示されます。
.\"O ----------------------------------------
.\"O .IP 7. 4
.\"O Comma-separated list of integrity check names.
.\"O The following strings are used for the known check types:
.\"O .BR None ,
.\"O .BR CRC32 ,
.\"O .BR CRC64 ,
.\"O and
.\"O .BR SHA\-256 .
.\"O For unknown check types,
.\"O .BI Unknown\- N
.\"O is used, where
.\"O .I N
.\"O is the Check ID as a decimal number (one or two digits).
.IP 7. 4
整合性チェックの名称をカンマ区切りで指定したリスト。既知の整合性チェック名として、以下の表記が用いられます。\fBNone\fP, \fBCRC32\fP,
\fBCRC64\fP, \fBSHA\-256\fP。未知のチェックタイプには \fBUnknown\-\fP\fIN\fP が用いられます。ここで \fIN\fP は 10 数値
(1 桁または 2 桁) で表されるチェック ID です。
.\"O ----------------------------------------
.\"O .IP 8. 4
.\"O Total size of stream padding in the file
.IP 8. 4
ファイル内ストリームのパディング (padding) データの総量。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PD
.PD
.\"O ----------------------------------------
.\"O .PP
.\"O The columns of the
.\"O .B stream
.\"O lines:
.PP
\fBstream\fP 行のカラム:
.\"O ----------------------------------------
.\"O .PD 0
.PD 0
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP 2. 4
.\"O Stream number (the first stream is 1)
.IP 2. 4
ストリーム番号 (先頭を 1 とします)。
.\"O ----------------------------------------
.\"O .IP 3. 4
.\"O Number of blocks in the stream
.IP 3. 4
ストリーム内のブロック数。
.\"O ----------------------------------------
.\"O .IP 4. 4
.\"O Compressed start offset
.IP 4. 4
圧縮データの開始オフセット。
.\"O ----------------------------------------
.\"O .IP 5. 4
.\"O Uncompressed start offset
.IP 5. 4
伸長データの開始オフセット。
.\"O ----------------------------------------
.\"O .IP 6. 4
.\"O Compressed size (does not include stream padding)
.IP 6. 4
圧縮サイズ (ストリームパディングを含みません)。
.\"O ----------------------------------------
.\"O .IP 7. 4
.\"O Uncompressed size
.IP 7. 4
伸長サイズ。
.\"O ----------------------------------------
.\"O .IP 8. 4
.\"O Compression ratio
.IP 8. 4
圧縮率。
.\"O ----------------------------------------
.\"O .IP 9. 4
.\"O Name of the integrity check
.IP 9. 4
整合性チェック名。
.\"O ----------------------------------------
.\"O .IP 10. 4
.\"O Size of stream padding
.IP 10. 4
ストリームパディングのサイズ。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PD
.PD
.\"O ----------------------------------------
.\"O .PP
.\"O The columns of the
.\"O .B block
.\"O lines:
.PP
\fBblock\fP 行のカラム:
.\"O ----------------------------------------
.\"O .PD 0
.PD 0
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP 2. 4
.\"O Number of the stream containing this block
.IP 2. 4
当ブロックに含まれるストリーム数。
.\"O ----------------------------------------
.\"O .IP 3. 4
.\"O Block number relative to the beginning of the stream
.\"O (the first block is 1)
.IP 3. 4
ストリーム先頭からの相対的なブロック数 (先頭ブロックを 1 とします)。
.\"O ----------------------------------------
.\"O .IP 4. 4
.\"O Block number relative to the beginning of the file
.IP 4. 4
ファイル先頭からの相対的なブロック数。
.\"O ----------------------------------------
.\"O .IP 5. 4
.\"O Compressed start offset relative to the beginning of the file
.IP 5. 4
ファイル先頭からの相対的な圧縮開始オフセット。
.\"O ----------------------------------------
.\"O .IP 6. 4
.\"O Uncompressed start offset relative to the beginning of the file
.IP 6. 4
ファイル先頭からの相対的な伸長開始オフセット。
.\"O ----------------------------------------
.\"O .IP 7. 4
.\"O Total compressed size of the block (includes headers)
.IP 7. 4
ブロックの総圧縮サイズ (ヘッダーを含みます)。
.\"O ----------------------------------------
.\"O .IP 8. 4
.\"O Uncompressed size
.IP 8. 4
伸長サイズ。
.\"O ----------------------------------------
.\"O .IP 9. 4
.\"O Compression ratio
.IP 9. 4
圧縮率。
.\"O ----------------------------------------
.\"O .IP 10. 4
.\"O Name of the integrity check
.IP 10. 4
整合性チェック名。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PD
.PD
.\"O ----------------------------------------
.\"O .PP
.\"O If
.\"O .B \-\-verbose
.\"O was specified twice, additional columns are included on the
.\"O .B block
.\"O lines.
.\"O These are not displayed with a single
.\"O .BR \-\-verbose ,
.\"O because getting this information requires many seeks
.\"O and can thus be slow:
.PP
\fB\-\-verbose\fP が 2 重に指定された場合、\fBblock\fP 行にはさらに以下のカラムが出力されます。これは \fB\-\-verbose\fP が 1
つだけ指定された際には表示されません。この情報取得にあたってはさらに検索を必要とするため、その分だけ処理が遅くなります。
.\"O ----------------------------------------
.\"O .PD 0
.PD 0
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP 11. 4
.\"O Value of the integrity check in hexadecimal
.IP 11. 4
16 進数表記による整合性チェック値。
.\"O ----------------------------------------
.\"O .IP 12. 4
.\"O Block header size
.IP 12. 4
ブロックヘッダーサイズ。
.\"O ----------------------------------------
.\"O .IP 13. 4
.\"O Block flags:
.\"O .B c
.\"O indicates that compressed size is present, and
.\"O .B u
.\"O indicates that uncompressed size is present.
.\"O If the flag is not set, a dash
.\"O .RB ( \- )
.\"O is shown instead to keep the string length fixed.
.\"O New flags may be added to the end of the string in the future.
.IP 13. 4
ブロックフラグ。\fBc\fP は圧縮サイズが存在することを示します。\fBu\fP
は伸長サイズが存在することを示します。このフラグが設定されていない場合、固定幅の文字出力は行わずにダッシュ (\fB\-\fP)
だけを表示します。将来の版においては、新しいフラグがこの文字列の後ろに追加されるかもしれません。
.\"O ----------------------------------------
.\"O .IP 14. 4
.\"O Size of the actual compressed data in the block (this excludes
.\"O the block header, block padding, and check fields)
.IP 14. 4
ブロック内の実際の圧縮データサイズ (ブロックヘッダー、ブロックパディング、チェック項目は除きます)。
.\"O ----------------------------------------
.\"O .IP 15. 4
.\"O Amount of memory (in bytes) required to decompress
.\"O this block with this
.\"O .B xz
.\"O version
.IP 15. 4
\fBxz\fP の現バージョンを使って、このブロックの伸長を行うために必要となるメモリ利用量。バイト単位。
.\"O ----------------------------------------
.\"O .IP 16. 4
.\"O Filter chain.
.\"O Note that most of the options used at compression time
.\"O cannot be known, because only the options
.\"O that are needed for decompression are stored in the
.\"O .B .xz
.\"O headers.
.IP 16. 4
フィルターチェーン。圧縮時に利用されたオプションは、ほとんど知ることができません。\fB.xz\fP
ヘッダーにオプションが保存されますが、それは伸長時に必要となるオプションだけだからです。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PD
.PD
.\"O ----------------------------------------
.\"O .PP
.\"O The columns of the
.\"O .B summary
.\"O lines:
.PP
\fBsummary\fP 行のカラム:
.\"O ----------------------------------------
.\"O .PD 0
.PD 0
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP 2. 4
.\"O Amount of memory (in bytes) required to decompress
.\"O this file with this
.\"O .B xz
.\"O version
.IP 2. 4
\fBxz\fP の現バージョンを使って、このファイルの伸長を行うために必要となるメモリ利用量。バイト単位。
.\"O ----------------------------------------
.\"O .IP 3. 4
.\"O .B yes
.\"O or
.\"O .B no
.\"O indicating if all block headers have both compressed size and
.\"O uncompressed size stored in them
.IP 3. 4
\fByes\fP または \fBno\fP。全ブロックヘッダー内に、圧縮サイズと伸長サイズがともに保存されているかどうかを表します。
.\"O ----------------------------------------
.\"O .PP
.\"O .I Since
.\"O .B xz
.\"O .I 5.1.2alpha:
.PP
\fBxz\fP \fI5.1.2alpha\fP \fI以降\fP:
.\"O ----------------------------------------
.\"O .IP 4. 4
.\"O Minimum
.\"O .B xz
.\"O version required to decompress the file
.IP 4. 4
ファイル伸長に必要となる \fBxz\fP の最低バージョン。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PD
.PD
.\"O ----------------------------------------
.\"O .PP
.\"O The columns of the
.\"O .B totals
.\"O line:
.PP
\fBtotals\fP 行のカラム:
.\"O ----------------------------------------
.\"O .PD 0
.PD 0
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP 2. 4
.\"O Number of streams
.IP 2. 4
ストリーム数。
.\"O ----------------------------------------
.\"O .IP 3. 4
.\"O Number of blocks
.IP 3. 4
ブロック数。
.\"O ----------------------------------------
.\"O .IP 4. 4
.\"O Compressed size
.IP 4. 4
圧縮サイズ。
.\"O ----------------------------------------
.\"O .IP 5. 4
.\"O Uncompressed size
.IP 5. 4
伸長サイズ。
.\"O ----------------------------------------
.\"O .IP 6. 4
.\"O Average compression ratio
.IP 6. 4
圧縮率の平均。
.\"O ----------------------------------------
.\"O .IP 7. 4
.\"O Comma-separated list of integrity check names
.\"O that were present in the files
.IP 7. 4
ファイル内に存在している整合性チェック名をカンマで区切ったリスト。
.\"O ----------------------------------------
.\"O .IP 8. 4
.\"O Stream padding size
.IP 8. 4
ストリームパディングのサイズ。
.\"O ----------------------------------------
.\"O .IP 9. 4
.\"O Number of files.
.\"O This is here to
.\"O keep the order of the earlier columns the same as on
.\"O .B file
.\"O lines.
.IP 9. 4
ファイル数。ここにこのカラムを設けることで、これ以前のカラムの並びが \fBfile\fP 行と同じになるようにします。
.\"O ----------------------------------------
.\"O .PD
.PD
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O If
.\"O .B \-\-verbose
.\"O was specified twice, additional columns are included on the
.\"O .B totals
.\"O line:
.PP
\fB\-\-verbose\fP が 2 重指定され \fBtotals\fP 行にカラム追加された場合:
.\"O ----------------------------------------
.\"O .PD 0
.PD 0
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .IP 10. 4
.\"O Maximum amount of memory (in bytes) required to decompress
.\"O the files with this
.\"O .B xz
.\"O version
.IP 10. 4
\fBxz\fP の現バージョンを使って、このファイルの伸長を行うために必要となる最大メモリ利用量。バイト単位。
.\"O ----------------------------------------
.\"O .IP 11. 4
.\"O .B yes
.\"O or
.\"O .B no
.\"O indicating if all block headers have both compressed size and
.\"O uncompressed size stored in them
.IP 11. 4
\fByes\fP または \fBno\fP。全ブロックヘッダー内に、圧縮サイズと伸長サイズがともに保存されているかどうかを表します。
.\"O ----------------------------------------
.\"O .PP
.\"O .I Since
.\"O .B xz
.\"O .I 5.1.2alpha:
.PP
\fBxz\fP \fI5.1.2alpha\fP \fI以降\fP:
.\"O ----------------------------------------
.\"O .IP 12. 4
.\"O Minimum
.\"O .B xz
.\"O version required to decompress the file
.IP 12. 4
ファイル伸長に必要となる \fBxz\fP の最低バージョン。
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PD
.PD
.\"O ----------------------------------------
.\"O .PP
.\"O Future versions may add new line types and
.\"O new columns can be added to the existing line types,
.\"O but the existing columns won't be changed.
.\"O .
.PP
将来版において、新たな行タイプの追加、あるいは既存行タイプへのカラム追加があるかもしれません。ただし既存カラムが変更されることはありません。
.
.\"O ----------------------------------------
.\"O .SH "EXIT STATUS"
.SH 終了ステータス
.\"O ----------------------------------------
.\"O .TP
.\"O .B 0
.\"O All is good.
.TP
\fB0\fP
正常終了。
.\"O ----------------------------------------
.\"O .TP
.\"O .B 1
.\"O An error occurred.
.TP
\fB1\fP
エラー発生。
.\"O ----------------------------------------
.\"O .TP
.\"O .B 2
.\"O Something worth a warning occurred,
.\"O but no actual errors occurred.
.TP
\fB2\fP
警告に相当する何かが発生。ただし実際のエラーが発生したわけではない。
.\"O ----------------------------------------
.\"O .PP
.\"O Notices (not warnings or errors) printed on standard error
.\"O don't affect the exit status.
.\"O .
.PP
通知 (警告やエラーではない) が標準エラー出力に表示されても、終了ステータスには影響しません。
.
.\"O ----------------------------------------
.\"O .SH ENVIRONMENT
.\"O .B xz
.\"O parses space-separated lists of options
.\"O from the environment variables
.\"O .B XZ_DEFAULTS
.\"O and
.\"O .BR XZ_OPT ,
.\"O in this order, before parsing the options from the command line.
.\"O Note that only options are parsed from the environment variables;
.\"O all non-options are silently ignored.
.\"O Parsing is done with
.\"O .BR getopt_long (3)
.\"O which is used also for the command line arguments.
.SH 環境変数
\fBxz\fP では環境変数 \fBXZ_DEFAULTS\fP および \fBXZ_OPT\fP
に設定された空白区切りのオプションを読み込みます。これは記述順に、コマンドラインから指定されたオプションよりも前に処理されます。環境変数から読み取られるのはオプションだけです。オプション以外の情報はすべて無視されます。オプションの読み込みは
\fBgetopt_long\fP(3) を使って行われますが、コマンドライン引数の読み込みにも用いられています。
.\"O ----------------------------------------
.\"O .TP
.\"O .B XZ_DEFAULTS
.\"O User-specific or system-wide default options.
.\"O Typically this is set in a shell initialization script to enable
.\"O .BR xz 's
.\"O memory usage limiter by default.
.\"O Excluding shell initialization scripts
.\"O and similar special cases, scripts must never set or unset
.\"O .BR XZ_DEFAULTS .
.TP
\fBXZ_DEFAULTS\fP
ユーザー定義あるいはシステムワイドなデフォルトオプションを指定します。通常はシェル初期化スクリプト内において設定され、デフォルトで利用する \fBxz\fP
のメモリ利用制限処理を有効にします。シェル初期化スクリプトあるいはこれに相当する特別なケースを除くと、スクリプトにおいて \fBXZ_DEFAULTS\fP
を設定したり未設定にしたりしてはなりません。
.\"O ----------------------------------------
.\"O .TP
.\"O .B XZ_OPT
.\"O This is for passing options to
.\"O .B xz
.\"O when it is not possible to set the options directly on the
.\"O .B xz
.\"O command line.
.\"O This is the case e.g. when
.\"O .B xz
.\"O is run by a script or tool, e.g. GNU
.\"O .BR tar (1):
.TP
\fBXZ_OPT\fP
\fBxz\fP コマンドラインからオプション指定ができない場合に、B(xz)
にオプションを受け渡しために用います。これを利用するのは、たとえばスクリプトから、あるいは GNU \fBtar\fP(1) のようなツールから \fBxz\fP
を実行する場合です。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O XZ_OPT=\-2v tar caf foo.tar.xz foo
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWXZ_OPT=\-2v tar caf foo.tar.xz foo\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .IP ""
.\"O Scripts may use
.\"O .B XZ_OPT
.\"O e.g. to set script-specific default compression options.
.\"O It is still recommended to allow users to override
.\"O .B XZ_OPT
.\"O if that is reasonable, e.g. in
.\"O .BR sh (1)
.\"O scripts one may use something like this:
.IP ""
スクリプトにおいてそのスクリプト固有のデフォルト圧縮オプションを設定するために \fBXZ_OPT\fP を用いる場合があります。その場合であっても
\fBXZ_OPT\fP のオーバーライドが認められるのは、たとえば以下に示すように \fBsh\fP(1) スクリプト内にて妥当な利用の仕方をする場合に限ります。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O XZ_OPT=${XZ_OPT\-"\-7e"}
.\"O export XZ_OPT
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWXZ_OPT=${XZ_OPT\-"\-7e"}
export XZ_OPT\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .RE
.\"O .
.RE
.
.\"O ----------------------------------------
.\"O .SH "LZMA UTILS COMPATIBILITY"
.\"O The command line syntax of
.\"O .B xz
.\"O is practically a superset of
.\"O .BR lzma ,
.\"O .BR unlzma ,
.\"O and
.\"O .BR lzcat
.\"O as found from LZMA Utils 4.32.x.
.\"O In most cases, it is possible to replace
.\"O LZMA Utils with XZ Utils without breaking existing scripts.
.\"O There are some incompatibilities though,
.\"O which may sometimes cause problems.
.\"O .
.SH "LZMA Utils との互換性"
\fBxz\fP のコマンドラインの文法は、実質的に LZMA Utils 4.32.x にある \fBlzma\fP, \fBunlzma\fP, \fBlzcat\fP
のスーパーセットになっています。LZMA Utils を用いる既存のスクリプトは、たいていは特に変更することなくそのまま XZ Utils
に置き換えることができます。ただし非互換性も存在しており、中には問題が発生する場合もあります。
.
.\"O ----------------------------------------
.\"O .SS "Compression preset levels"
.\"O The numbering of the compression level presets is not identical in
.\"O .B xz
.\"O and LZMA Utils.
.\"O The most important difference is how dictionary sizes
.\"O are mapped to different presets.
.\"O Dictionary size is roughly equal to the decompressor memory usage.
.SS 圧縮プリセットレベル
圧縮レベルのプリセット値は \fBxz\fP と LZMA Utils
において同一の番号振りにはなっていません。もっとも重要な違いは、さまざまなプリセットに対する辞書サイズがどのように割り振られているか、という点です。辞書サイズは、おおまかに言えば伸長処理時のメモリ利用量に等しくなります。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .TS
.\"O tab(;);
.\"O c c c
.\"O c n n.
.\"O Level;xz;LZMA Utils
.\"O \-0;256 KiB;N/A
.\"O \-1;1 MiB;64 KiB
.\"O \-2;2 MiB;1 MiB
.\"O \-3;4 MiB;512 KiB
.\"O \-4;4 MiB;1 MiB
.\"O \-5;8 MiB;2 MiB
.\"O \-6;8 MiB;4 MiB
.\"O \-7;16 MiB;8 MiB
.\"O \-8;32 MiB;16 MiB
.\"O \-9;64 MiB;32 MiB
.\"O .TE
.PP
.TS
tab(;);
c c c
c n n.
レベル;xz;LZMA Utils
\-0;256 KiB;なし
\-1;1 MiB;64 KiB
\-2;2 MiB;1 MiB
\-3;4 MiB;512 KiB
\-4;4 MiB;1 MiB
\-5;8 MiB;2 MiB
\-6;8 MiB;4 MiB
\-7;16 MiB;8 MiB
\-8;32 MiB;16 MiB
\-9;64 MiB;32 MiB
.TE
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O The dictionary size differences affect
.\"O the compressor memory usage too,
.\"O but there are some other differences between
.\"O LZMA Utils and XZ Utils, which
.\"O make the difference even bigger:
.PP
辞書サイズの違いは、圧縮時でのメモリ利用量にも影響します。ただし LZMA Utils と XZ Utils
の違いは他にあって、その違いの方がより大きなものです。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .TS
.\"O tab(;);
.\"O c c c
.\"O c n n.
.\"O Level;xz;LZMA Utils 4.32.x
.\"O \-0;3 MiB;N/A
.\"O \-1;9 MiB;2 MiB
.\"O \-2;17 MiB;12 MiB
.\"O \-3;32 MiB;12 MiB
.\"O \-4;48 MiB;16 MiB
.\"O \-5;94 MiB;26 MiB
.\"O \-6;94 MiB;45 MiB
.\"O \-7;186 MiB;83 MiB
.\"O \-8;370 MiB;159 MiB
.\"O \-9;674 MiB;311 MiB
.\"O .TE
.PP
.TS
tab(;);
c c c
c n n.
レベル;xz;LZMA Utils 4.32.x
\-0;3 MiB;なし
\-1;9 MiB;2 MiB
\-2;17 MiB;12 MiB
\-3;32 MiB;12 MiB
\-4;48 MiB;16 MiB
\-5;94 MiB;26 MiB
\-6;94 MiB;45 MiB
\-7;186 MiB;83 MiB
\-8;370 MiB;159 MiB
\-9;674 MiB;311 MiB
.TE
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O The default preset level in LZMA Utils is
.\"O .B \-7
.\"O while in XZ Utils it is
.\"O .BR \-6 ,
.\"O so both use an 8 MiB dictionary by default.
.\"O .
.PP
デフォルトのプリセットレベルは LZMA Utils では \fB\-7\fP ですが、XZ Utils では \fB\-6\fP です。ともにデフォルトで 8 MiB
の辞書を利用します。
.
.\"O ----------------------------------------
.\"O .SS "Streamed vs. non-streamed .lzma files"
.\"O The uncompressed size of the file can be stored in the
.\"O .B .lzma
.\"O header.
.\"O LZMA Utils does that when compressing regular files.
.\"O The alternative is to mark that uncompressed size is unknown
.\"O and use end-of-payload marker to indicate
.\"O where the decompressor should stop.
.\"O LZMA Utils uses this method when uncompressed size isn't known,
.\"O which is the case for example in pipes.
.SS "ストリーム化されている/されていない .lzma ファイル"
ファイルの伸長サイズは \fB.lzma\fP ヘッダーに保存されます。LZMA Utils がこれを保存するのは、通常ファイルを圧縮する際です。\fBxz\fP
の場合は、伸長サイズが不明であるとマークしておき、ペイロード終了マーカー (end\-of\-payload marker)
を使って伸長処理の終了位置を示します。LZMA Utils
はこの方法を、伸長サイズが不明なときに利用します。たとえばパイプを使った場合がこの利用にあたります。
.\"O ----------------------------------------
.\"O .PP
.\"O .B xz
.\"O supports decompressing
.\"O .B .lzma
.\"O files with or without end-of-payload marker, but all
.\"O .B .lzma
.\"O files created by
.\"O .B xz
.\"O will use end-of-payload marker and have uncompressed size
.\"O marked as unknown in the
.\"O .B .lzma
.\"O header.
.\"O This may be a problem in some uncommon situations.
.\"O For example, a
.\"O .B .lzma
.\"O decompressor in an embedded device might work
.\"O only with files that have known uncompressed size.
.\"O If you hit this problem, you need to use LZMA Utils
.\"O or LZMA SDK to create
.\"O .B .lzma
.\"O files with known uncompressed size.
.\"O .
.PP
\fBxz\fP では \fB.lzma\fP ファイルを伸長する際に、ペイロード終了マーカーを利用することも利用しないこともできます。しかし \fBxz\fP
から生成された \fB.lzma\fP に対しては、ペイロード終了マーカーを利用して、\fB.lzma\fP
ヘッダー内に伸長サイズが不明であるものとしてマークします。これは特殊なケースで問題となる場合があります。たとえば埋め込みデバイス上での \fB.lzma\fP
伸長処理は、伸長サイズがわかっていないファイルでは動作しないかもしれません。このような問題に遭遇した場合は、LZMA Utils または LZMA
SDK を利用して、伸長サイズが明確となっている \fB.lzma\fP ファイルを生成してください。
.
.\"O ----------------------------------------
.\"O .SS "Unsupported .lzma files"
.\"O The
.\"O .B .lzma
.\"O format allows
.\"O .I lc
.\"O values up to 8, and
.\"O .I lp
.\"O values up to 4.
.\"O LZMA Utils can decompress files with any
.\"O .I lc
.\"O and
.\"O .IR lp ,
.\"O but always creates files with
.\"O .B lc=3
.\"O and
.\"O .BR lp=0 .
.\"O Creating files with other
.\"O .I lc
.\"O and
.\"O .I lp
.\"O is possible with
.\"O .B xz
.\"O and with LZMA SDK.
.SS "サポートされない .lzma ファイル"
\&\fB.lzma\fP フォーマットが用いる \fIlc\fP 値は 8 まで、\fIlp\fP 値は 4 までです。LZMA Utils がファイル伸長する際には
\fIlc\fP と \fIlp\fP の値はどのような値であってもかまいませんが、ただし \fBlc=3\fP かつ \fBlp=0\fP
のファイルが常に生成されます。これ以外の \fIlc\fP や \fIlp\fP を生成するには \fBxz\fP か LZMA SDK を利用してください。
.\"O ----------------------------------------
.\"O .PP
.\"O The implementation of the LZMA1 filter in liblzma
.\"O requires that the sum of
.\"O .I lc
.\"O and
.\"O .I lp
.\"O must not exceed 4.
.\"O Thus,
.\"O .B .lzma
.\"O files, which exceed this limitation, cannot be decompressed with
.\"O .BR xz .
.PP
liblzma 内の LZMA1 フィルターの実装では、\fIlc\fP と \fIlp\fP の合計が 4
を超えてはならないものとなっています。したがってこの制限を超えた \fB.lzma\fP ファイルは \fBxz\fP を使って伸長することはできません。
.\"O ----------------------------------------
.\"O .PP
.\"O LZMA Utils creates only
.\"O .B .lzma
.\"O files which have a dictionary size of
.\"O .RI "2^" n
.\"O (a power of 2) but accepts files with any dictionary size.
.\"O liblzma accepts only
.\"O .B .lzma
.\"O files which have a dictionary size of
.\"O .RI "2^" n
.\"O or
.\"O .RI "2^" n " + 2^(" n "\-1)."
.\"O This is to decrease false positives when detecting
.\"O .B .lzma
.\"O files.
.PP
LZMA Utils が生成する \fB.lzma\fP ファイルは、辞書サイズが 2^\fIn\fP (2 のべき乗)
のものだけです。ただしどのようなサイズであってもファイルにアクセスすることはできます。一方 liblzma がアクセスできるのは、辞書サイズが
2^\fIn\fP または 2^\fIn\fP + 2^(\fIn\fP\-1) であるような \fB.lzma\fP ファイルのみです。これは \fB.lzma\fP
ファイルを検出する際に、誤った検出を回避するためです。
.\"O ----------------------------------------
.\"O .PP
.\"O These limitations shouldn't be a problem in practice,
.\"O since practically all
.\"O .B .lzma
.\"O files have been compressed with settings that liblzma will accept.
.\"O .
.PP
上のような制約は現実に問題となることはありません。事実上 \fB.lzma\fP ファイルは liblzma
が受け入れる設定すべてを使って圧縮されるものとなっているからです。
.
.\"O ----------------------------------------
.\"O .SS "Trailing garbage"
.\"O When decompressing,
.\"O LZMA Utils silently ignore everything after the first
.\"O .B .lzma
.\"O stream.
.\"O In most situations, this is a bug.
.\"O This also means that LZMA Utils
.\"O don't support decompressing concatenated
.\"O .B .lzma
.\"O files.
.SS ゴミデータ
LZMA Utils は伸長時に、最初の \fB.lzma\fP ストリーム以降のデータは完全に無視します。ほとんどの場合、これはバグになります。これはまた
LZMA Utils が、連結された \fB.lzma\fP ファイルを伸長できないことを表しています。
.\"O ----------------------------------------
.\"O .PP
.\"O If there is data left after the first
.\"O .B .lzma
.\"O stream,
.\"O .B xz
.\"O considers the file to be corrupt unless
.\"O .B \-\-single\-stream
.\"O was used.
.\"O This may break obscure scripts which have
.\"O assumed that trailing garbage is ignored.
.\"O .
.PP
\&\fB.lzma\fP の最初のストリーム以降にデータが残っている場合、\fBxz\fP は \fB\-\-single\-stream\fP
が指定されていない限りは、そのファイルが壊れているとみなします。したがって、ゴミデータは無視される扱いである前提で作られているスクリプトは、動作しなくなるかもしれません。
.
.\"O ----------------------------------------
.\"O .SH NOTES
.\"O .
.SH 情報
.
.\"O ----------------------------------------
.\"O .SS "Compressed output may vary"
.\"O The exact compressed output produced from
.\"O the same uncompressed input file
.\"O may vary between XZ Utils versions even if
.\"O compression options are identical.
.\"O This is because the encoder can be improved
.\"O (faster or better compression)
.\"O without affecting the file format.
.\"O The output can vary even between different
.\"O builds of the same XZ Utils version,
.\"O if different build options are used.
.SS 圧縮結果はさまざま
同一の圧縮前ファイルを使って圧縮ファイルを生成したとしても、XZ Utils
バージョンが異なると、その生成結果は異なることになります。それは圧縮オプションが全く同じであっても起こります。ファイルフォーマットに影響を与えることなく、エンコード処理は常に
(より高速に、より高圧縮に) 改善されているためです。XZ Utils
バージョンが同一であっても、ビルド時のオプションが違っていると、生成結果が異なる場合もあります。
.\"O ----------------------------------------
.\"O .PP
.\"O The above means that once
.\"O .B \-\-rsyncable
.\"O has been implemented,
.\"O the resulting files won't necessarily be rsyncable
.\"O unless both old and new files have been compressed
.\"O with the same xz version.
.\"O This problem can be fixed if a part of the encoder
.\"O implementation is frozen to keep rsyncable output
.\"O stable across xz versions.
.\"O .
.PP
このことは \fB\-\-rsyncable\fP が実装された際には問題となります。rsync の機能を用いる際には、古いファイルと新しいファイルを同一の xz
バージョンで圧縮しておかないと、rsync 処理ができないということになります。この問題を解決するには、どちらかのエンコード実装を凍結して、xz
バージョン間において安定して rsync 処理ができるような出力とすることが必要になります。
.
.\"O ----------------------------------------
.\"O .SS "Embedded .xz decompressors"
.\"O Embedded
.\"O .B .xz
.\"O decompressor implementations like XZ Embedded don't necessarily
.\"O support files created with integrity
.\"O .I check
.\"O types other than
.\"O .B none
.\"O and
.\"O .BR crc32 .
.\"O Since the default is
.\"O .BR \-\-check=crc64 ,
.\"O you must use
.\"O .B \-\-check=none
.\"O or
.\"O .B \-\-check=crc32
.\"O when creating files for embedded systems.
.SS "埋め込み .xz の伸長処理"
XZ Embedded のような埋め込み \fB.xz\fP 伸長処理の実装では、整合性チェックのうち \fBnone\fP と \fBcrc32\fP
以外のものを使ったファイル生成には対応する必要がありません。デフォルトは \fB\-\-check=crc64\fP
ですから、埋め込みシステム上でのファイル生成時は \fB\-\-check=none\fP か \fB\-\-check=crc32\fP を指定しなければなりません。
.\"O ----------------------------------------
.\"O .PP
.\"O Outside embedded systems, all
.\"O .B .xz
.\"O format decompressors support all the
.\"O .I check
.\"O types, or at least are able to decompress
.\"O the file without verifying the
.\"O integrity check if the particular
.\"O .I check
.\"O is not supported.
.PP
埋め込みシステムを除くと、\fB.xz\fP フォーマットにおける伸長処理では、\fIcheck\fP タイプすべてに対応しています。あるいは特定の
\fIcheck\fP がサポートされていなかったとしても、最低でも整合性チェックの検証を行わずにファイル伸長処理が可能となっています。
.\"O ----------------------------------------
.\"O .PP
.\"O XZ Embedded supports BCJ filters,
.\"O but only with the default start offset.
.\"O .
.PP
XZ Embedded は BCJ フィルターに対応しています。ただしデフォルトの開始オフセットしか利用できません。
.
.\"O ----------------------------------------
.\"O .SH EXAMPLES
.\"O .
.SH 利用例
.
.\"O ----------------------------------------
.\"O .SS Basics
.\"O Compress the file
.\"O .I foo
.\"O into
.\"O .I foo.xz
.\"O using the default compression level
.\"O .RB ( \-6 ),
.\"O and remove
.\"O .I foo
.\"O if compression is successful:
.SS 基本
ファイル \fIfoo\fP を圧縮して \fIfoo.xz\fP を生成します。利用する圧縮レベルはデフォルト (\fB\-6\fP) です。圧縮が成功したら
\fIfoo\fP を削除します。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O xz foo
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWxz foo\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O Decompress
.\"O .I bar.xz
.\"O into
.\"O .I bar
.\"O and don't remove
.\"O .I bar.xz
.\"O even if decompression is successful:
.PP
\fIbar.xz\fP を伸長して \fIbar\fP を得ます。伸長処理に成功しても \fIbar.xz\fP は削除しません。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O xz \-dk bar.xz
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWxz \-dk bar.xz\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O Create
.\"O .I baz.tar.xz
.\"O with the preset
.\"O .B \-4e
.\"O .RB ( "\-4 \-\-extreme" ),
.\"O which is slower than e.g. the default
.\"O .BR \-6 ,
.\"O but needs less memory for compression and decompression (48\ MiB
.\"O and 5\ MiB, respectively):
.PP
プリセット \fB\-4e\fP (\fB\-4 \-\-extreme\fP) を用いて \fIbaz.tar.xz\fP を生成します。これはたとえばデフォルトの \fB\-6\fP
に比べて処理速度は低下しますが、圧縮時や伸長時のメモリ消費は少なくて済みます (それぞれ 48\ MiB と 5\ MiB)。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O tar cf \- baz | xz \-4e > baz.tar.xz
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWtar cf \- baz | xz \-4e > baz.tar.xz\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O A mix of compressed and uncompressed files can be decompressed
.\"O to standard output with a single command:
.PP
圧縮されたファイルや未圧縮のファイルを混在させ、ただ 1 つのコマンドを使って標準出力を行うことができます。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O xz \-dcf a.txt b.txt.xz c.txt d.txt.lzma > abcd.txt
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWxz \-dcf a.txt b.txt.xz c.txt d.txt.lzma > abcd.txt\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.\"O .
.RE
.
.\"O ----------------------------------------
.\"O .SS "Parallel compression of many files"
.\"O On GNU and *BSD,
.\"O .BR find (1)
.\"O and
.\"O .BR xargs (1)
.\"O can be used to parallelize compression of many files:
.SS 複数ファイルの並行圧縮処理
GNU および *BSD の \fBfind\fP(1) や \fBxargs\fP(1) では、複数ファイルを並行処理により圧縮することができます。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O find . \-type f \e! \-name '*.xz' \-print0 \e
.\"O | xargs \-0r \-P4 \-n16 xz \-T1
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWfind . \-type f \e! \-name '*.xz' \-print0 \e
| xargs \-0r \-P4 \-n16 xz \-T1\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O The
.\"O .B \-P
.\"O option to
.\"O .BR xargs (1)
.\"O sets the number of parallel
.\"O .B xz
.\"O processes.
.\"O The best value for the
.\"O .B \-n
.\"O option depends on how many files there are to be compressed.
.\"O If there are only a couple of files,
.\"O the value should probably be 1;
.\"O with tens of thousands of files,
.\"O 100 or even more may be appropriate to reduce the number of
.\"O .B xz
.\"O processes that
.\"O .BR xargs (1)
.\"O will eventually create.
.PP
\fBxargs\fP(1) に対する \fB\-P\fP オプションが、\fBxz\fP 処理に対する並行処理数を設定しています。\fB\-n\fP
オプションの最適値は、どれだけのファイルを圧縮するかによって変わります。ファイル数がほんの数個である場合、おそらくこの値は 1
が適切です。ファイル数が数万のレベルなら 100 以上が適切であり、これによって \fBxargs\fP(1) が最終的に作り出す \fBxz\fP
プロセスを抑えられます。
.\"O ----------------------------------------
.\"O .PP
.\"O The option
.\"O .B \-T1
.\"O for
.\"O .B xz
.\"O is there to force it to single-threaded mode, because
.\"O .BR xargs (1)
.\"O is used to control the amount of parallelization.
.\"O .
.PP
\fBxz\fP に対してオプション \fB\-T1\fP を指定していますが、これは強制的にシングルスレッドモードにします。\fBxargs\fP(1)
は通常は並行処理数を制御するために利用されているからです。
.
.\"O ----------------------------------------
.\"O .SS "Robot mode"
.\"O Calculate how many bytes have been saved in total
.\"O after compressing multiple files:
.SS ロボットモード
複数ファイルを圧縮したことによって、合計で何バイト分が保存されたかを計算します。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O xz \-\-robot \-\-list *.xz | awk '/^totals/{print $5\-$4}'
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWxz \-\-robot \-\-list *.xz | awk '/^totals/{print $5\-$4}'\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O A script may want to know that it is using new enough
.\"O .BR xz .
.\"O The following
.\"O .BR sh (1)
.\"O script checks that the version number of the
.\"O .B xz
.\"O tool is at least 5.0.0.
.\"O This method is compatible with old beta versions,
.\"O which didn't support the
.\"O .B \-\-robot
.\"O option:
.PP
スクリプト実行の際には、利用している \fBxz\fP が最新版であるかどうかを確認したい場合があります。以下の \fBsh\fP(1) スクリプトでは、\fBxz\fP
ツールのバージョン番号が最低でも 5.0.0 であるかどうかを確認しています。この方法は \fB\-\-robot\fP
オプションに対応していない古いベータ版に対しても利用できます。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O if ! eval "$(xz \-\-robot \-\-version 2> /dev/null)" ||
.\"O [ "$XZ_VERSION" \-lt 50000002 ]; then
.\"O echo "Your xz is too old."
.\"O fi
.\"O unset XZ_VERSION LIBLZMA_VERSION
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWif ! eval "$(xz \-\-robot \-\-version 2> /dev/null)" ||
[ "$XZ_VERSION" \-lt 50000002 ]; then
echo "Your xz is too old."
fi
unset XZ_VERSION LIBLZMA_VERSION\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O Set a memory usage limit for decompression using
.\"O .BR XZ_OPT ,
.\"O but if a limit has already been set, don't increase it:
.PP
\fBXZ_OPT\fP を利用して伸長時のメモリ利用制限を設定します。ただしすでに設定されていた場合、その設定が増えることはありません。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O NEWLIM=$((123 << 20)) # 123 MiB
.\"O OLDLIM=$(xz \-\-robot \-\-info\-memory | cut \-f3)
.\"O if [ $OLDLIM \-eq 0 \-o $OLDLIM \-gt $NEWLIM ]; then
.\"O XZ_OPT="$XZ_OPT \-\-memlimit\-decompress=$NEWLIM"
.\"O export XZ_OPT
.\"O fi
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWNEWLIM=$((123 << 20)) # 123 MiB
OLDLIM=$(xz \-\-robot \-\-info\-memory | cut \-f3)
if [ $OLDLIM \-eq 0 \-o $OLDLIM \-gt $NEWLIM ]; then
XZ_OPT="$XZ_OPT \-\-memlimit\-decompress=$NEWLIM"
export XZ_OPT
fi\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.\"O .
.RE
.
.\"O ----------------------------------------
.\"O .SS "Custom compressor filter chains"
.\"O The simplest use for custom filter chains is
.\"O customizing a LZMA2 preset.
.\"O This can be useful,
.\"O because the presets cover only a subset of the
.\"O potentially useful combinations of compression settings.
.SS カスタム圧縮フィルターチェーン
カスタムフィルターチェーンを利用する一番簡単な方法は LZMA2
プリセットを用いることです。プリセットには、圧縮設定の中から有用な設定を組み合わせて、その一部を割り当てているため、それを使うのが簡単です。
.\"O ----------------------------------------
.\"O .PP
.\"O The CompCPU columns of the tables
.\"O from the descriptions of the options
.\"O .BR "\-0" " ... " "\-9"
.\"O and
.\"O .B \-\-extreme
.\"O are useful when customizing LZMA2 presets.
.\"O Here are the relevant parts collected from those two tables:
.PP
オプション \fB\-0\fP ... \fB\-9\fP, \fB\-\-extreme\fP のところで説明した一覧表内の CompCPU カラムは、LZMA2
プリセット値をカスタマイズする際に活用できます。上で説明済の 2 つの表から、関連するところを抜粋したものが以下です。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .TS
.\"O tab(;);
.\"O c c
.\"O n n.
.\"O Preset;CompCPU
.\"O \-0;0
.\"O \-1;1
.\"O \-2;2
.\"O \-3;3
.\"O \-4;4
.\"O \-5;5
.\"O \-6;6
.\"O \-5e;7
.\"O \-6e;8
.\"O .TE
.PP
.TS
tab(;);
c c
n n.
プリセット;CompCPU
\-0;0
\-1;1
\-2;2
\-3;3
\-4;4
\-5;5
\-6;6
\-5e;7
\-6e;8
.TE
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O If you know that a file requires
.\"O somewhat big dictionary (e.g. 32 MiB) to compress well,
.\"O but you want to compress it quicker than
.\"O .B "xz \-8"
.\"O would do, a preset with a low CompCPU value (e.g. 1)
.\"O can be modified to use a bigger dictionary:
.PP
効率よく圧縮するためには、ある程度大きな (たとえば 32 MiB 程度の) 辞書が必要であることがわかっているとします。一方で \fBxz \-8\fP
の指定時よりも速く処理がしたいとします。その場合は CompCPU 値が低い (たとえば 1 であるような)
プリセットを使えば、より大きな辞書を利用するように調整ができます。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O xz \-\-lzma2=preset=1,dict=32MiB foo.tar
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWxz \-\-lzma2=preset=1,dict=32MiB foo.tar\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O With certain files, the above command may be faster than
.\"O .B "xz \-6"
.\"O while compressing significantly better.
.\"O However, it must be emphasized that only some files benefit from
.\"O a big dictionary while keeping the CompCPU value low.
.\"O The most obvious situation,
.\"O where a big dictionary can help a lot,
.\"O is an archive containing very similar files
.\"O of at least a few megabytes each.
.\"O The dictionary size has to be significantly bigger
.\"O than any individual file to allow LZMA2 to take
.\"O full advantage of the similarities between consecutive files.
.PP
ファイルによっては、上のコマンドの実行により、圧縮効率が著しく改善されて \fBxz \-6\fP よりも高速処理される場合があります。ただし CompCPU
値を低くしたとしても、大きな辞書を使ったことが効果を発揮するようなファイルは限られます。大きな辞書を用いた効果が発揮される状況は、おそらく最低数メガバイトの総量で、似通ったファイルを含むアーカイブである場合です。辞書サイズは、個々のファイルに比べれば十分に大きなサイズにする必要があります。そうしておけば、LZMA2
が並んだファイルの類似性に対して効果を発揮する処理を行ってくれます。
.\"O ----------------------------------------
.\"O .PP
.\"O If very high compressor and decompressor memory usage is fine,
.\"O and the file being compressed is
.\"O at least several hundred megabytes, it may be useful
.\"O to use an even bigger dictionary than the 64 MiB that
.\"O .B "xz \-9"
.\"O would use:
.PP
仮に圧縮時や伸長時のメモリ利用を大きな値とするのが有効であり、また圧縮するファイルが最低でも数 100 メガバイトあるなら、\fBxz \-9\fP
が利用する辞書サイズ 64 MiB よりもさらに大きなサイズを利用するのが効果的かもしれません。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O xz \-vv \-\-lzma2=dict=192MiB big_foo.tar
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWxz \-vv \-\-lzma2=dict=192MiB big_foo.tar\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O Using
.\"O .B \-vv
.\"O .RB ( "\-\-verbose \-\-verbose" )
.\"O like in the above example can be useful
.\"O to see the memory requirements
.\"O of the compressor and decompressor.
.\"O Remember that using a dictionary bigger than
.\"O the size of the uncompressed file is waste of memory,
.\"O so the above command isn't useful for small files.
.PP
上の利用例に示しているように \fB\-vv\fP (\fB\-\-verbose \-\-verbose\fP)
を用いると、圧縮および伸長におけるメモリ必要量が確認できます。なお伸長ファイルサイズよりも大きな辞書を利用すると、メモリを無駄に消費します。したがって上のコマンドは、容量が少ないファイルに対しては効果が期待できません。
.\"O ----------------------------------------
.\"O .PP
.\"O Sometimes the compression time doesn't matter,
.\"O but the decompressor memory usage has to be kept low
.\"O e.g. to make it possible to decompress the file on
.\"O an embedded system.
.\"O The following command uses
.\"O .B \-6e
.\"O .RB ( "\-6 \-\-extreme" )
.\"O as a base and sets the dictionary to only 64\ KiB.
.\"O The resulting file can be decompressed with XZ Embedded
.\"O (that's why there is
.\"O .BR \-\-check=crc32 )
.\"O using about 100\ KiB of memory.
.PP
圧縮時間は問題にならないこともあります。しかし伸長時のメモリ利用量は低く抑えるべきです。たとえば埋め込みシステムでは、ファイル伸長時のメモリ利用は極力低く抑えたいところです。以下のコマンドでは、基本として
\fB\-6e\fP (\fB\-6 \-\-extreme\fP) を利用し、辞書サイズは 64\ KiB と小さくしています。XZ Embedded を利用すると
(だからこそ \fB\-\-check=crc32\fP を用いるのですが)、伸長処理によるファイル生成の際には 100\ KiB のメモリ利用に抑えられます。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O xz \-\-check=crc32 \-\-lzma2=preset=6e,dict=64KiB foo
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWxz \-\-check=crc32 \-\-lzma2=preset=6e,dict=64KiB foo\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O If you want to squeeze out as many bytes as possible,
.\"O adjusting the number of literal context bits
.\"O .RI ( lc )
.\"O and number of position bits
.\"O .RI ( pb )
.\"O can sometimes help.
.\"O Adjusting the number of literal position bits
.\"O .RI ( lp )
.\"O might help too, but usually
.\"O .I lc
.\"O and
.\"O .I pb
.\"O are more important.
.\"O E.g. a source code archive contains mostly US-ASCII text,
.\"O so something like the following might give
.\"O slightly (like 0.1\ %) smaller file than
.\"O .B "xz \-6e"
.\"O (try also without
.\"O .BR lc=4 ):
.PP
できるだけ多くのバイトを圧縮したい場合は、リテラルコンテキスト (\fIlc\fP) ビット値と、ポジションビット (\fIpb\fP)
を調整するのが有効になる場合があります。リテラルポジションビット (\fIlp\fP) の調整も有効かもしれませんが、通常は \fIlc\fP と \fIpb\fP
の方が重要です。たとえばソースコードアーカイブと言えば、ほとんどが US\-ASCII テキストであるため、以下に示すように処理すれば、\fBxz \-6e\fP
の処理よりもほんの少しだけ (0.1\ % 程度) 小さくなります (\fBlc=4\fP を除いた処理も試してください)。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O xz \-\-lzma2=preset=6e,pb=0,lc=4 source_code.tar
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWxz \-\-lzma2=preset=6e,pb=0,lc=4 source_code.tar\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O Using another filter together with LZMA2 can improve
.\"O compression with certain file types.
.\"O E.g. to compress a x86-32 or x86-64 shared library
.\"O using the x86 BCJ filter:
.PP
特定のファイルタイプに対しては、LZMA2 に別のフィルターを加えることで、圧縮処理が改善することがあります。たとえば x86\-32 や x86\-64
の共有ライブラリに対しては x86 BCJ フィルターを使うことがこれにあたります。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O xz \-\-x86 \-\-lzma2 libfoo.so
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWxz \-\-x86 \-\-lzma2 libfoo.so\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O Note that the order of the filter options is significant.
.\"O If
.\"O .B \-\-x86
.\"O is specified after
.\"O .BR \-\-lzma2 ,
.\"O .B xz
.\"O will give an error,
.\"O because there cannot be any filter after LZMA2,
.\"O and also because the x86 BCJ filter cannot be used
.\"O as the last filter in the chain.
.PP
フィルターオプションの並びは重要です。\fB\-\-x86\fP が \fB\-\-lzma2\fP の後ろに指定されると \fBxz\fP はエラーを表示します。この理由は
LZMA2 の後ろにフィルターを置くことはできないためであり、さらに x86 BCJ
フィルターはチェーン内の最終フィルターにすることもできないからです。
.\"O ----------------------------------------
.\"O .PP
.\"O The Delta filter together with LZMA2
.\"O can give good results with bitmap images.
.\"O It should usually beat PNG,
.\"O which has a few more advanced filters than simple
.\"O delta but uses Deflate for the actual compression.
.PP
LZMA2 にデルタフィルターを合わせて利用すると、ビットマップイメージに対しては良好な結果が得られます。この結果は普通 PNG
を上回るはずです。PNG には単純なデルタよりも高度なフィルターをいくつか有していますが、実際の圧縮にあたっては Deflate が用いられています。
.\"O ----------------------------------------
.\"O .PP
.\"O The image has to be saved in uncompressed format,
.\"O e.g. as uncompressed TIFF.
.\"O The distance parameter of the Delta filter is set
.\"O to match the number of bytes per pixel in the image.
.\"O E.g. 24-bit RGB bitmap needs
.\"O .BR dist=3 ,
.\"O and it is also good to pass
.\"O .B pb=0
.\"O to LZMA2 to accommodate the three-byte alignment:
.PP
イメージデータは非圧縮形式で保存する必要があります。たとえば非圧縮の TIFF
データなどです。デルタフィルターの距離パラメーターは、イメージ内におけるピクセルあたりのバイト数にマッチするように設定されています。たとえば 24
ビット RGB ビットマップには \fBdist=3\fP が必要です。また LZMA2 に対しては \fBpb=0\fP を指定して 3
バイト並びに対応させるのが適切です。
.\"O ----------------------------------------
.\"O .RS
.RS
.\"O ----------------------------------------
.\"O .PP
.\"O .nf
.\"O .ft CW
.\"O xz \-\-delta=dist=3 \-\-lzma2=pb=0 foo.tiff
.\"O .ft R
.\"O .fi
.PP
.nf
\f(CWxz \-\-delta=dist=3 \-\-lzma2=pb=0 foo.tiff\fP
.fi
.\"O ----------------------------------------
.\"O .RE
.RE
.\"O ----------------------------------------
.\"O .PP
.\"O If multiple images have been put into a single archive (e.g.\&
.\"O .BR .tar ),
.\"O the Delta filter will work on that too as long as all images
.\"O have the same number of bytes per pixel.
.\"O .
.PP
複数のイメージが 1 つのアーカイブ (たとえば \fB.tar\fP)
にまとめられているときは、個々のイメージのピクセルあたりのバイト数が同一である場合に限って、デルタフィルターは同様に動作します。
.
.\"O ----------------------------------------
.\"O .SH "SEE ALSO"
.\"O .BR xzdec (1),
.\"O .BR xzdiff (1),
.\"O .BR xzgrep (1),
.\"O .BR xzless (1),
.\"O .BR xzmore (1),
.\"O .BR gzip (1),
.\"O .BR bzip2 (1),
.\"O .BR 7z (1)
.SH 関連項目
\fBxzdec\fP(1), \fBxzdiff\fP(1), \fBxzgrep\fP(1), \fBxzless\fP(1), \fBxzmore\fP(1),
\fBgzip\fP(1), \fBbzip2\fP(1), \fB7z\fP(1)
.\"O ----------------------------------------
.\"O .PP
.\"O XZ Utils:
.\"O .br
.\"O XZ Embedded:
.\"O .br
.\"O LZMA SDK:
.PP
XZ Utils:
.br
埋め込み XZ:
.br
LZMA SDK:
.\"O ----------------------------------------