| diff, diffh, bdiff, vdiff32compare two text files and show differences | Command | 
diff [-befHhimnrsw]
[-C n]
[-c[n]]
[-Difname]
[-Mmark]
path1
path2
diff [-befHhimnrsw]
[-C n]
[-c[n]]
[-Difname]
[-Mmark]
file...
dir
diffh [-befimnrsw]
[-C n]
[-c[n]]
[-Difname]
[-Mmark]
path1
path2
diffh [-befimnrsw]
[-C n]
[-c[n]]
[-Difname]
[-Mmark]
file...
dir
bdiff [-befimnrsw]
[-C n]
[-c[n]]
[-Difname]
[-Mmark]
path1
path2
[n]
bdiff [-befimnrsw]
[-C n]
[-c[n]]
[-Difname]
[-Mmark]
file...
dir
[n]
vdiff32
diff command attempts to determine the minimal set of
changes needed either to convert a file named path1 into path2 or
the group of files indicated by file... into files of the same name found
under the directory dir.
If either (but only one) file name is -, diff
reads that file from the standard input. If only two path names appear on the
command line and one of path1 or path2 is a directory,
diff uses a file in that directory with the same name as the
other file name. If both are directories, diff compares
files with the same file names under the two directories. However,
diff does not compare files in subdirectories unless you
specify the -r option. When comparing two directories,
diff does not compare block special files, character special
files, or FIFO special files to any other files and does not compare regular
files to directories.
If more than two path names appear on the command line, the last path name is
assumed to be a directory and the preceding path names to be files.
diff then compares each file in the list to a file with the
name under the specified directory.
By default, output consists of descriptions of the changes in a style
reminiscent of the ed text editor. A
line indicating the type of change is given. The three types are a
(append), d (delete), and c (change). The output is
symmetric in the sense that a delete in path1 is the counterpart of an
append in path2. diff prefixes each operation with a
line number (or range) in path1 and suffixes each with a line number (or
range) in path2. After the line giving the type of change,
diff displays the deleted or added lines, prefixing lines
from path1 with < and lines from path2 with
>.
When you call the command as diffh, it automatically uses
the -h option.
When you call it as bdiff, diff computes
the differences in chunks of n lines (default 3999). This lets you
process arbitrarily large files and generally produces less output than the
-h option.
The vdiff32 command is a graphical version of
diff, giving you the ability to compare and view files from
a graphical user interface. Complete instructions on using
vdiff32 are available through its online help feature.
-bignores white space at the end of each line (except the newline) and
      treats all consecutive strings of white space elsewhere in a line as
      equivalent (effectively, reducing all strings of white space to a single
      space for the purpose of comparing lines). For example if one file
      contained a string of three spaces and a tab at a given location while the
      other file contained a string of two spaces at the same location,
      diff would not report this as a difference.
-C nshows n lines of context before and after each change.
      diff marks lines removed from path1 with
      -, lines added to path2 with + and lines
      changed in both files with !. This option conflicts with the
      -e and -f options.
-c[n]is equivalent to -C n, but n is
      optional. The default value for n is 3. This option conflicts with
      the -e and -f options.
-Difnamedisplays output that is the appropriate input to the C preprocessor to generate the contents of path2 when ifname is defined, and the contents of path1 when ifname is not defined.
-ewrites out a script of commands for the
      ed text editor that converts
      path1 to path2. diff sends the output to
      the standard output. This option conflicts with the -m,
      -c, and -C options.
-fwrites a script similar to the one produced under -e
      to the standard output, but with the command sequence reversed, the
      command form reversed, and the line-range separator a space, rather than a
      comma. This option conflicts with the -m,
      -c, and -C options.
-Huses the half-hearted (-h) algorithm only if the
      normal algorithm runs out of system resources.
-huses a fast, half-hearted algorithm instead of the normal
      diff algorithm. This algorithm can handle arbitrarily
      large files; however, it is not particularly good at finding a minimal set
      of differences in files with many differences.
-iignores the case of letters when doing the comparison.
-Mmarkdescribes the diff mark to be used in place of the vertical line
      character (|) when the -m option is also
      specified. mark can be any
      nroff /
      troff character or string. It
      can be as simple or complex as you like. For example, specifying
      mark as 1 causes the diff mark to be the character
      1. Specifying \(sq causes it to be an open
      square and specifying \s+6\fB\d~\u\fP\s0 causes the diff mark
      to be a bold-faced tilde (~) six points larger in size half a
      line below the current line.
      
      This option does not change the character used to indicate deleted lines.
      It remains the asterisk(*).
-mproduces the contents of path2 with extra formatter request lines interspersed to show which lines were added or changed and which were deleted.
      If you do not also specify the -M option, added, or
      changed lines are indicated by a vertical line character | in
      the right margin. If you do specify the -M option,
      diff uses the
      nroff /
      troff string given as
      mark to indicated additions or changes. Deleted lines are always
      indicated with an asterisk (*) in the right margin.
      
      These are nroff /
      troff requests. This option
      conflicts with the -e and -f
      options.
-ndisplays the differences in a form that is usable by MKS Source Integrity.
-rcompares corresponding files under the directories, and recursively compares corresponding files under corresponding subdirectories. You can use this option when you specify two directory names on the command line.
-scompares two directories, file by file, and prints messages for identical files between the two directories.
-wignores white space (not including newlines) when making the comparison. For example, the following two lines are equivalent:
a b c d abcd
diff
command. The following two files, price1 and price2,
are compared with and without the use of the -c option.
The contents of price1 are as follows:
The contents ofCompany X Price List: $ 0.39 -- Package of Groat Clusters $ 5.00 -- Candy Apple Sampler Pack $ 12.00 -- Box of Crunchy Frog Chocolates $ 15.99 -- Instant Rain (Just Add Water) $ 20.00 -- Asparagus Firmness Meter $ 25.00 -- Package of Seeds for 35 Herbs $ 30.00 -- Child's Riding Hood (Red) $ 35.00 -- Genuine Placebos $ 45.00 -- Case of Simulated Soy Bean Oil $ 75.88 -- No-Name Contact Lenses $ 99.99 -- Kiddie Destructo-Bot $125.00 -- Emperor's New Clothes
price2 are as follows:
The commandCompany X Price List: $ 0.39 -- Package of Groat Clusters $ 5.49 -- Candy Apple Sampler Pack $ 12.00 -- Box of Crunchy Frog Chocolates $ 15.99 -- Instant Rain (Just Add Water) $ 17.00 -- Simulated Naugahyde Cleaner $ 20.00 -- Asparagus Firmness Meter $ 25.00 -- Package of Seeds for 35 Herbs $ 30.00 -- Child's Riding Hood (Red) $ 35.00 -- Genuine Placebos $ 45.00 -- Case of Simulated Soy Bean Oil $ 75.88 -- No-Name Contact Lenses $ 99.99 -- Kiddie Destructo-Bot
results in the following output:diff price1 price2
The addition of the4c4 < $ 5.00 -- Candy Apple Sampler Pack --- > $ 5.49 -- Candy Apple Sampler Pack 6a7 > $ 17.00 -- Simulated Naugahyde Cleaner 14d14 < $125.00 -- Emperor's New Clothes
-c option, as in
results in the following output:diff -c price1 price2
*** price1 Wed Mar 04 10:08:40 1992 --- price2 Wed Mar 04 10:09:10 1992 *************** *** 1,9 **** Company X Price List: $ 0.39 -- Package of Groat Clusters ! $ 5.00 -- Candy Apple Sampler Pack $ 12.00 -- Box of Crunchy Frog Chocolates $ 15.99 -- Instant Rain (Just Add Water) $ 20.00 -- Asparagus Firmness Meter $ 25.00 -- Package of Seeds for 35 Herbs $ 30.00 -- Child's Riding Hood (Red) --- 1,10 ---- Company X Price List: $ 0.39 -- Package of Groat Clusters ! $ 5.49 -- Candy Apple Sampler Pack $ 12.00 -- Box of Crunchy Frog Chocolates $ 15.99 -- Instant Rain (Just Add Water) + $ 17.00 -- Simulated Naugahyde cleaner $ 20.00 -- Asparagus Firmness Meter $ 25.00 -- Package of Seeds for 35 Herbs $ 30.00 -- Child's Riding Hood (Red) *************** *** 11,14 **** $ 45.00 -- Case of Simulated Soy Bean Oil $ 75.88 -- No-Name Contact Lenses $ 99.99 -- Kiddie Destructo-Bot - $125.00 -- Emperor's New Clothes --- 12,14 ----
diff -c marks lines removed from
price1 with -, lines added to price1
with + and lines changed in both files with !. In the
example, diff shows the default 3 lines of context around
each changed line. One line was changed in both files (marked with
!), one line was added to price1 (marked with
+), and one line was removed from price1 (marked with
-).
If there are no marks to be shown in the corresponding lines of the
    file being compared, the lines are not displayed. Lines 12 to 14 of
    price2 are suppressed for this reason.
0No differences between the files compared.
1diff compared the files and found them to be
      different.
2Failure due to any of the following:
LINE_MAX characters between newlines4At least one of the files is a binary file containing embedded NUL
      (\0) bytes.
The specified filename does not exist. filename was
      either typed explicitly, or generated by diff from the
      directory of one file argument and the base name of the other.
The -s option was specified and the two named files
      are identical.
This message appears when diff is comparing the
      contents of directories, but you have not specified -r.
      When diff discovers two subdirectories with the same
      name, it reports that the directories exist, but it does not try to
      compare the contents of the two directories.
diff ran out of memory for generating the data
      structures used in the file differencing algorithm (see
      LIMITS). The -h option of
      diff can handle any size of file without running out
      of memory.
diff was unable to create a working file that it
      needed. Ensure that you either have a /tmp directory or that
      the environment contains a variable TMPDIR that
      names a directory where diff may store temporary files.
      Also, ensure that there is sufficient file space in this directory.
You did not specify a conditional label on the command line after the
      -D option.
Of the two input files normally found on the command line of
      diff, only one can be the standard input.
A file of more than the maximum number of lines (see
      LIMITS) was given to
      diff.
-h,
files are limited to INT_MAX lines.
-D, -H, -h,
-i, -m, -n,
-s, and -w options; the n
argument to the -c option; and the diffh
and bdiff versions of the command are extensions to the
POSIX and x/OPEN standard. The -f option is an
x/OPEN extension to the POSIX standard.