Print the contents of a depot file revision.
p4 [g-opts] print [-a -A -k -q] [-m max] [-o outfile] file[revRange] ...
p4 [g-opts] print -U unloadfile ...
The p4 print
command writes the contents of a depot
file to standard output. A revision range can be included; in this case,
only the files with revisions in the specified range are printed, and by
default, only the highest revision in that range is listed. (To output
each file at every revision within a specified revision range, use
p4 print -a
.) Multiple file patterns can be included;
all files matching any of the patterns are printed.
Any file in the depot can be printed, subject to permission limitations
as granted by p4
protect
. If the file argument does not map through
the client view, you must provide it in depot syntax.
By default, the file is written with a header that describes the
location of the file in the depot, the revision number of the printed
file, and the number of the changelist that the revision was submitted
under. To suppress the header, use the -q
(quiet)
option.
By default, RCS keywords are expanded. To suppress keyword expansion,
use the -k
(keyword) option.
By default, the local depot is searched for the specified file. If you
specify the -U
option, the unload depot is searched
instead.
|
For each file, print all revisions within a specified revision range, rather than only the highest revision in the range. |
|
Attempt to print a file stored in an archive depot. |
|
Suppress RCS keyword expansion. |
|
Print only the first |
|
Redirect output to the specified output file on the local disk, preserving the same file type, attributes, and/or permission bits as the original file in the depot. |
|
Suppress the one-line file header normally added by Perforce. |
|
Look for the specified file or files in the unload depot. Data about an unloaded client, label, or task stream can be printed. |
|
See Global Options. |
Can File Arguments Use Revision Specifier? | Can File Arguments Use Revision Range? | Minimal Access Level Required |
---|---|---|
Yes |
Yes |
|
Because most terminals are unable to display UTF16 content, the
default behavior of the p4 print
command is to
return UTF8 content. You can override this behavior by bypassing
terminal output entirely and specifying an output file, for
example:
$ p4 print -q -o outputfile //depot/file
If your terminal supports UTF16 output, specify standard output as the output file:
$ p4 print -q -o - //depot/ file
p4 print
's file arguments can take a revision
range. By default, only the highest revision matched by any particular
file is printed (that is, when no range is specified, the implied range
is #1,#head
, and the highest revision is
#head
). To print all files in a specified (or implied)
range, use the -a
option.p4 print
's output can be quite large when
called with highly non-restrictive file arguments (for instance,
p4 print //depot/...
prints the contents of all
files in the depot), it may be subject to a maxresults
limitation as set in p4
group
.In many cases, redirecting p4 print
's output to
a file via your OS shell will suffice.
The -o
option is intended for users who require the
automatic setting of file type and/or permission bits. This is useful
for files such as symbolic links (stored as type
symlink
), files of type apple
,
automatically setting the execute bit on UNIX shell scripts stored as
type text+x
, and so on.
To compare the contents of two depot file revisions |
|
To compare the contents of an opened file in the client workspace to a depot file revision |