2005-05-10 23:32:30 +02:00
|
|
|
git-cat-file(1)
|
|
|
|
===============
|
|
|
|
|
|
|
|
NAME
|
|
|
|
----
|
2009-03-23 02:00:15 +01:00
|
|
|
git-cat-file - Provide content or type and size information for repository objects
|
2005-05-10 23:32:30 +02:00
|
|
|
|
|
|
|
|
|
|
|
SYNOPSIS
|
|
|
|
--------
|
2008-06-03 13:06:12 +02:00
|
|
|
[verse]
|
2010-06-24 14:56:55 +02:00
|
|
|
'git cat-file' (-t | -s | -e | -p | <type> | --textconv ) <object>
|
2009-05-25 12:33:15 +02:00
|
|
|
'git cat-file' (--batch | --batch-check) < <list-of-objects>
|
2005-05-10 23:32:30 +02:00
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
-----------
|
2009-03-23 02:00:15 +01:00
|
|
|
In its first form, the command provides the content or the type of an object in
|
|
|
|
the repository. The type is required unless '-t' or '-p' is used to find the
|
2010-06-24 14:56:55 +02:00
|
|
|
object type, or '-s' is used to find the object size, or '--textconv' is used
|
|
|
|
(which implies type "blob").
|
2008-04-23 21:17:46 +02:00
|
|
|
|
2009-03-23 02:00:15 +01:00
|
|
|
In the second form, a list of objects (separated by linefeeds) is provided on
|
2013-04-15 19:49:04 +02:00
|
|
|
stdin, and the SHA-1, type, and size of each object is printed on stdout.
|
2005-05-10 23:32:30 +02:00
|
|
|
|
|
|
|
OPTIONS
|
|
|
|
-------
|
|
|
|
<object>::
|
2007-01-30 08:56:51 +01:00
|
|
|
The name of the object to show.
|
|
|
|
For a more complete list of ways to spell object names, see
|
2010-10-11 18:03:32 +02:00
|
|
|
the "SPECIFYING REVISIONS" section in linkgit:gitrevisions[7].
|
2005-05-10 23:32:30 +02:00
|
|
|
|
|
|
|
-t::
|
|
|
|
Instead of the content, show the object type identified by
|
|
|
|
<object>.
|
|
|
|
|
2005-06-28 08:59:18 +02:00
|
|
|
-s::
|
|
|
|
Instead of the content, show the object size identified by
|
|
|
|
<object>.
|
|
|
|
|
2005-12-04 02:57:48 +01:00
|
|
|
-e::
|
|
|
|
Suppress all output; instead exit with zero status if <object>
|
|
|
|
exists and is a valid object.
|
|
|
|
|
2006-05-25 03:22:32 +02:00
|
|
|
-p::
|
|
|
|
Pretty-print the contents of <object> based on its type.
|
|
|
|
|
2005-05-10 23:32:30 +02:00
|
|
|
<type>::
|
|
|
|
Typically this matches the real type of <object> but asking
|
2005-10-06 00:08:26 +02:00
|
|
|
for a type that can trivially be dereferenced from the given
|
2005-05-10 23:32:30 +02:00
|
|
|
<object> is also permitted. An example is to ask for a
|
|
|
|
"tree" with <object> being a commit object that contains it,
|
|
|
|
or to ask for a "blob" with <object> being a tag object that
|
|
|
|
points at it.
|
|
|
|
|
2010-06-24 14:56:55 +02:00
|
|
|
--textconv::
|
|
|
|
Show the content as transformed by a textconv filter. In this case,
|
|
|
|
<object> has be of the form <treeish>:<path>, or :<path> in order
|
|
|
|
to apply the filter to the content recorded in the index at <path>.
|
|
|
|
|
2008-04-23 21:17:47 +02:00
|
|
|
--batch::
|
2013-07-10 13:45:47 +02:00
|
|
|
--batch=<format>::
|
|
|
|
Print object information and contents for each object provided
|
|
|
|
on stdin. May not be combined with any other options or arguments.
|
|
|
|
See the section `BATCH OUTPUT` below for details.
|
2008-04-23 21:17:47 +02:00
|
|
|
|
2008-04-23 21:17:46 +02:00
|
|
|
--batch-check::
|
2013-07-10 13:45:47 +02:00
|
|
|
--batch-check=<format>::
|
|
|
|
Print object information for each object provided on stdin. May
|
|
|
|
not be combined with any other options or arguments. See the
|
|
|
|
section `BATCH OUTPUT` below for details.
|
2008-04-23 21:17:46 +02:00
|
|
|
|
2005-05-10 23:32:30 +02:00
|
|
|
OUTPUT
|
|
|
|
------
|
2005-12-04 02:57:48 +01:00
|
|
|
If '-t' is specified, one of the <type>.
|
|
|
|
|
|
|
|
If '-s' is specified, the size of the <object> in bytes.
|
|
|
|
|
|
|
|
If '-e' is specified, no output.
|
2005-05-10 23:32:30 +02:00
|
|
|
|
2006-05-25 03:22:32 +02:00
|
|
|
If '-p' is specified, the contents of <object> are pretty-printed.
|
|
|
|
|
2008-04-23 21:17:46 +02:00
|
|
|
If <type> is specified, the raw (though uncompressed) contents of the <object>
|
|
|
|
will be returned.
|
|
|
|
|
2013-07-10 13:45:47 +02:00
|
|
|
BATCH OUTPUT
|
|
|
|
------------
|
|
|
|
|
|
|
|
If `--batch` or `--batch-check` is given, `cat-file` will read objects
|
|
|
|
from stdin, one per line, and print information about them.
|
|
|
|
|
2013-07-11 22:45:59 +02:00
|
|
|
Each line is split at the first whitespace boundary. All characters
|
|
|
|
before that whitespace are considered as a whole object name, and are
|
|
|
|
parsed as if given to linkgit:git-rev-parse[1]. Characters after that
|
|
|
|
whitespace can be accessed using the `%(rest)` atom (see below).
|
2013-07-10 13:45:47 +02:00
|
|
|
|
|
|
|
You can specify the information shown for each object by using a custom
|
|
|
|
`<format>`. The `<format>` is copied literally to stdout for each
|
|
|
|
object, with placeholders of the form `%(atom)` expanded, followed by a
|
|
|
|
newline. The available atoms are:
|
|
|
|
|
|
|
|
`objectname`::
|
|
|
|
The 40-hex object name of the object.
|
|
|
|
|
|
|
|
`objecttype`::
|
|
|
|
The type of of the object (the same as `cat-file -t` reports).
|
|
|
|
|
|
|
|
`objectsize`::
|
|
|
|
The size, in bytes, of the object (the same as `cat-file -s`
|
|
|
|
reports).
|
|
|
|
|
2013-07-10 13:46:25 +02:00
|
|
|
`objectsize:disk`::
|
|
|
|
The size, in bytes, that the object takes up on disk. See the
|
|
|
|
note about on-disk sizes in the `CAVEATS` section below.
|
|
|
|
|
2013-07-11 22:45:59 +02:00
|
|
|
`rest`::
|
|
|
|
The text (if any) found after the first run of whitespace on the
|
|
|
|
input line (i.e., the "rest" of the line).
|
|
|
|
|
2013-07-10 13:45:47 +02:00
|
|
|
If no format is specified, the default format is `%(objectname)
|
|
|
|
%(objecttype) %(objectsize)`.
|
|
|
|
|
|
|
|
If `--batch` is specified, the object information is followed by the
|
|
|
|
object contents (consisting of `%(objectsize)` bytes), followed by a
|
|
|
|
newline.
|
|
|
|
|
|
|
|
For example, `--batch` without a custom format would produce:
|
2008-04-23 21:17:47 +02:00
|
|
|
|
|
|
|
------------
|
|
|
|
<sha1> SP <type> SP <size> LF
|
|
|
|
<contents> LF
|
|
|
|
------------
|
|
|
|
|
2013-07-10 13:45:47 +02:00
|
|
|
Whereas `--batch-check='%(objectname) %(objecttype)'` would produce:
|
2008-04-23 21:17:46 +02:00
|
|
|
|
|
|
|
------------
|
2013-07-10 13:45:47 +02:00
|
|
|
<sha1> SP <type> LF
|
2008-04-23 21:17:46 +02:00
|
|
|
------------
|
|
|
|
|
2013-07-10 13:45:47 +02:00
|
|
|
If a name is specified on stdin that cannot be resolved to an object in
|
|
|
|
the repository, then `cat-file` will ignore any custom format and print:
|
2005-05-10 23:32:30 +02:00
|
|
|
|
2008-04-23 21:17:46 +02:00
|
|
|
------------
|
|
|
|
<object> SP missing LF
|
|
|
|
------------
|
2005-05-10 23:32:30 +02:00
|
|
|
|
2013-07-10 13:46:25 +02:00
|
|
|
|
|
|
|
CAVEATS
|
|
|
|
-------
|
|
|
|
|
|
|
|
Note that the sizes of objects on disk are reported accurately, but care
|
|
|
|
should be taken in drawing conclusions about which refs or objects are
|
|
|
|
responsible for disk usage. The size of a packed non-delta object may be
|
|
|
|
much larger than the size of objects which delta against it, but the
|
|
|
|
choice of which object is the base and which is the delta is arbitrary
|
|
|
|
and is subject to change during a repack. Note also that multiple copies
|
|
|
|
of an object may be present in the object database; in this case, it is
|
|
|
|
undefined which copy's size will be reported.
|
|
|
|
|
|
|
|
|
2005-05-10 23:32:30 +02:00
|
|
|
GIT
|
|
|
|
---
|
2008-06-06 09:07:32 +02:00
|
|
|
Part of the linkgit:git[1] suite
|