Perforce 2005.1 Command Reference
<< Previous Chapter
p4 describe
Table of Contents
Index
Perforce on the Web
Next Chapter >>
p4 diff2

p4 diff

Synopsis

Compare a client workspace file to a revision in the depot.

Syntax

p4 [g-opts] diff [-dflag] [-f] [-sa | -sd | -se | -sr] [-t] [ file[rev#] ...]

Description

p4 diff runs a diff program on the Perforce client, comparing files in the client workspace to revisions in the depot.

This command takes a file argument, which can contain a revision specifier. If a revision specifier is included, the file in the client workspace is diffed against the specified revision. If a revision specifier is not included, the client workspace file is compared against the revision currently being edited (usually the head revision). In either case, the client file must be open for edit, or the comparison must be against a revision other than the one to which the client file was last synced.

If the file argument includes wildcards, all open files that match the file pattern are diffed. If no file argument is provided, all open files are diffed against their depot counterparts.

By default, the diff routine used is the one built into the p4 client program. To change this diff routine to an external diff program, set the P4DIFF environment or registry variable to point to the new program.

Options

-f

Force the diff, even when the client file is not open for edit.

-dflags

Pass flags to the underlying diff routine (see the Usage Notes below for details)

-sa

Show only the names of opened files that are different from the revision in the depot, or are missing.

-sd

Show only the names of unopened files that are missing from the client workspace, but present in the depot.

-se

Show only the names of unopened files in the client workspace that are different than the revision in the depot.

-sr

Show only the names of opened files in the client workspace that are identical to the revision in the depot.

-t

Diff the revisions even if the files are not of type text.

g-opts

See the Global Options section.

Usage Notes

Can File Arguments Use
Revision Specifier?

Can File Arguments Use
Revision Range?

Minimal Access Level Required

Yes

No

read

specifies a unified diff that ignores changes in whitespace.

Examples

p4 diff file#5

Compare the client workspace revision of file file to the fifth depot revision.

p4 diff @1999/05/22

Compare all open files in the client workspace to the revisions in the depot as of midnight on May 22, 1999.

p4 diff -du file

Run the comparison on file file, displaying output in a format suitable for the patch(1) utility.

p4 diff -sr | p4 -x - revert

Revert all open, unchanged files.

This differs from p4 revert -a (revert all unchanged files, where resolving a file, even if no changes are made, counts as a change), in that it reverts files whose workspace content matches the depot content, including resolved files that happen to be identical to those in the depot.

The first command shows all open, unchanged files. The second command (running p4 -x and taking arguments, one per line, from standard input, abbreviated as "-") reverts each file in that list.

(This is the UNIX version of this command; it uses a pipe. Most operating systems have some equivalent way of performing these operations in series).

For more information about the -x option to p4, see the Global Options section.

Related Commands

To compare two depot revisions

p4 diff2

To view the entire contents of a file

p4 print


Perforce 2005.1 Command Reference
<< Previous Chapter
p4 describe
Table of Contents
Index
Perforce on the Web
Next Chapter >>
p4 diff2
Please send comments and questions about this manual to [email protected].
Copyright 1999-2005 Perforce Software. All rights reserved.
Last updated: 05/12/05