Upgrade diffutils from 2.8.7 to 3.0 on the vendor branch
authorJohn Marino <draco@marino.st>
Sat, 30 Apr 2011 11:56:40 +0000 (13:56 +0200)
committerJohn Marino <draco@marino.st>
Sat, 30 Apr 2011 19:52:00 +0000 (21:52 +0200)
157 files changed:
contrib/diffutils/COPYING
contrib/diffutils/ChangeLog [deleted file]
contrib/diffutils/NEWS [deleted file]
contrib/diffutils/README
contrib/diffutils/doc/diff.info
contrib/diffutils/doc/diff.texi [deleted file]
contrib/diffutils/doc/fdl.texi [deleted file]
contrib/diffutils/doc/stamp-vti [deleted file]
contrib/diffutils/doc/version.texi [deleted file]
contrib/diffutils/lib/basename-lgpl.c [new file with mode: 0644]
contrib/diffutils/lib/basename.c
contrib/diffutils/lib/bitrotate.h [new file with mode: 0644]
contrib/diffutils/lib/c-ctype.c [new file with mode: 0644]
contrib/diffutils/lib/c-ctype.h [new file with mode: 0644]
contrib/diffutils/lib/c-stack.c
contrib/diffutils/lib/c-stack.h
contrib/diffutils/lib/c-strcase.h [new file with mode: 0644]
contrib/diffutils/lib/c-strcasecmp.c [new file with mode: 0644]
contrib/diffutils/lib/c-strncasecmp.c [new file with mode: 0644]
contrib/diffutils/lib/cmpbuf.c
contrib/diffutils/lib/cmpbuf.h
contrib/diffutils/lib/diffseq.h [new file with mode: 0644]
contrib/diffutils/lib/dirname-lgpl.c [new file with mode: 0644]
contrib/diffutils/lib/dirname.c [new file with mode: 0644]
contrib/diffutils/lib/dirname.h
contrib/diffutils/lib/dup2.c [new file with mode: 0644]
contrib/diffutils/lib/error.c
contrib/diffutils/lib/error.h
contrib/diffutils/lib/exclude.c
contrib/diffutils/lib/exclude.h
contrib/diffutils/lib/exit.h [deleted file]
contrib/diffutils/lib/exitfail.c
contrib/diffutils/lib/exitfail.h
contrib/diffutils/lib/fcntl.c [new file with mode: 0644]
contrib/diffutils/lib/file-type.c
contrib/diffutils/lib/file-type.h
contrib/diffutils/lib/fnmatch.c [new file with mode: 0644]
contrib/diffutils/lib/fnmatch_loop.c [new file with mode: 0644]
contrib/diffutils/lib/freopen-safer.c [new file with mode: 0644]
contrib/diffutils/lib/getopt.c [new file with mode: 0644]
contrib/diffutils/lib/getopt1.c [new file with mode: 0644]
contrib/diffutils/lib/getopt_int.h [new file with mode: 0644]
contrib/diffutils/lib/gettext.h
contrib/diffutils/lib/gettime.c [new file with mode: 0644]
contrib/diffutils/lib/hard-locale.c
contrib/diffutils/lib/hard-locale.h
contrib/diffutils/lib/hash.c [new file with mode: 0644]
contrib/diffutils/lib/hash.h [new file with mode: 0644]
contrib/diffutils/lib/ignore-value.h [new file with mode: 0644]
contrib/diffutils/lib/imaxtostr.c [new file with mode: 0644]
contrib/diffutils/lib/intprops.h [new file with mode: 0644]
contrib/diffutils/lib/inttostr.c [new file with mode: 0644]
contrib/diffutils/lib/inttostr.h
contrib/diffutils/lib/localcharset.c [new file with mode: 0644]
contrib/diffutils/lib/localcharset.h [new file with mode: 0644]
contrib/diffutils/lib/lstat.c [new file with mode: 0644]
contrib/diffutils/lib/malloca.c [new file with mode: 0644]
contrib/diffutils/lib/malloca.h [new file with mode: 0644]
contrib/diffutils/lib/malloca.valgrind [new file with mode: 0644]
contrib/diffutils/lib/mbchar.c [new file with mode: 0644]
contrib/diffutils/lib/mbchar.h [new file with mode: 0644]
contrib/diffutils/lib/mbiter.h [new file with mode: 0644]
contrib/diffutils/lib/mbscasecmp.c [new file with mode: 0644]
contrib/diffutils/lib/mbslen.c [new file with mode: 0644]
contrib/diffutils/lib/mbsstr.c [new file with mode: 0644]
contrib/diffutils/lib/mbuiter.h [new file with mode: 0644]
contrib/diffutils/lib/mktime-internal.h [new file with mode: 0644]
contrib/diffutils/lib/mktime.c [new file with mode: 0644]
contrib/diffutils/lib/offtostr.c [new file with mode: 0644]
contrib/diffutils/lib/posixver.c [deleted file]
contrib/diffutils/lib/posixver.h [deleted file]
contrib/diffutils/lib/prepargs.c [new file with mode: 0644]
contrib/diffutils/lib/progname.c [new file with mode: 0644]
contrib/diffutils/lib/progname.h [new file with mode: 0644]
contrib/diffutils/lib/propername.c [new file with mode: 0644]
contrib/diffutils/lib/propername.h [new file with mode: 0644]
contrib/diffutils/lib/quote.c [new file with mode: 0644]
contrib/diffutils/lib/quote.h [new file with mode: 0644]
contrib/diffutils/lib/quotearg.c [new file with mode: 0644]
contrib/diffutils/lib/quotearg.h [new file with mode: 0644]
contrib/diffutils/lib/quotesys.c [deleted file]
contrib/diffutils/lib/quotesys.h [deleted file]
contrib/diffutils/lib/regcomp.c [new file with mode: 0644]
contrib/diffutils/lib/regex.c [new file with mode: 0644]
contrib/diffutils/lib/regex.h [new file with mode: 0644]
contrib/diffutils/lib/regex_internal.c [new file with mode: 0644]
contrib/diffutils/lib/regex_internal.h [new file with mode: 0644]
contrib/diffutils/lib/regexec.c [new file with mode: 0644]
contrib/diffutils/lib/setmode.h [deleted file]
contrib/diffutils/lib/sh-quote.c [new file with mode: 0644]
contrib/diffutils/lib/sh-quote.h [new file with mode: 0644]
contrib/diffutils/lib/sig-handler.h [new file with mode: 0644]
contrib/diffutils/lib/stat-macros.h [new file with mode: 0644]
contrib/diffutils/lib/stat-time.h [new file with mode: 0644]
contrib/diffutils/lib/stdio--.h [new file with mode: 0644]
contrib/diffutils/lib/stdio-safer.h [new file with mode: 0644]
contrib/diffutils/lib/str-kmp.h [new file with mode: 0644]
contrib/diffutils/lib/strcase.h [deleted file]
contrib/diffutils/lib/streq.h [new file with mode: 0644]
contrib/diffutils/lib/strftime.c
contrib/diffutils/lib/strftime.h [new file with mode: 0644]
contrib/diffutils/lib/striconv.c [new file with mode: 0644]
contrib/diffutils/lib/striconv.h [new file with mode: 0644]
contrib/diffutils/lib/stripslash.c [new file with mode: 0644]
contrib/diffutils/lib/strnlen1.c [new file with mode: 0644]
contrib/diffutils/lib/strnlen1.h [new file with mode: 0644]
contrib/diffutils/lib/strtoimax.c [deleted file]
contrib/diffutils/lib/strtoumax.c [deleted file]
contrib/diffutils/lib/tempname.c [new file with mode: 0644]
contrib/diffutils/lib/tempname.h [new file with mode: 0644]
contrib/diffutils/lib/timegm.c [new file with mode: 0644]
contrib/diffutils/lib/timespec.h [new file with mode: 0644]
contrib/diffutils/lib/trim.c [new file with mode: 0644]
contrib/diffutils/lib/trim.h [new file with mode: 0644]
contrib/diffutils/lib/uinttostr.c [new file with mode: 0644]
contrib/diffutils/lib/umaxtostr.c [new file with mode: 0644]
contrib/diffutils/lib/unitypes.h [new file with mode: 0644]
contrib/diffutils/lib/uniwidth.h [new file with mode: 0644]
contrib/diffutils/lib/uniwidth/cjk.h [new file with mode: 0644]
contrib/diffutils/lib/uniwidth/width.c [new file with mode: 0644]
contrib/diffutils/lib/unlocked-io.h
contrib/diffutils/lib/verify.h [new file with mode: 0644]
contrib/diffutils/lib/version-etc-fsf.c [new file with mode: 0644]
contrib/diffutils/lib/version-etc.c
contrib/diffutils/lib/version-etc.h
contrib/diffutils/lib/wcwidth.c [new file with mode: 0644]
contrib/diffutils/lib/xalloc-die.c [new file with mode: 0644]
contrib/diffutils/lib/xalloc.h
contrib/diffutils/lib/xfreopen.c [new file with mode: 0644]
contrib/diffutils/lib/xfreopen.h [new file with mode: 0644]
contrib/diffutils/lib/xmalloc.c
contrib/diffutils/lib/xstriconv.c [new file with mode: 0644]
contrib/diffutils/lib/xstriconv.h [new file with mode: 0644]
contrib/diffutils/lib/xstrndup.c [new file with mode: 0644]
contrib/diffutils/lib/xstrndup.h [new file with mode: 0644]
contrib/diffutils/lib/xstrtol-error.c [new file with mode: 0644]
contrib/diffutils/lib/xstrtol.c [new file with mode: 0644]
contrib/diffutils/lib/xstrtol.h [new file with mode: 0644]
contrib/diffutils/lib/xstrtoul.c [new file with mode: 0644]
contrib/diffutils/lib/xstrtoumax.c [new file with mode: 0644]
contrib/diffutils/man/diff.1
contrib/diffutils/man/diff3.1
contrib/diffutils/man/sdiff.1
contrib/diffutils/src/analyze.c
contrib/diffutils/src/context.c
contrib/diffutils/src/diff.c
contrib/diffutils/src/diff.h
contrib/diffutils/src/diff3.c
contrib/diffutils/src/dir.c
contrib/diffutils/src/ed.c
contrib/diffutils/src/ifdef.c
contrib/diffutils/src/io.c
contrib/diffutils/src/normal.c
contrib/diffutils/src/sdiff.c
contrib/diffutils/src/side.c
contrib/diffutils/src/system.h
contrib/diffutils/src/util.c

index d60c31a..94a9ed0 100644 (file)
-                   GNU GENERAL PUBLIC LICENSE
-                      Version 2, June 1991
+                    GNU GENERAL PUBLIC LICENSE
+                       Version 3, 29 June 2007
 
- Copyright (C) 1989, 1991 Free Software Foundation, Inc.
-     59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
  Everyone is permitted to copy and distribute verbatim copies
  of this license document, but changing it is not allowed.
 
-                           Preamble
+                            Preamble
 
-  The licenses for most software are designed to take away your
-freedom to share and change it.  By contrast, the GNU General Public
-License is intended to guarantee your freedom to share and change free
-software--to make sure the software is free for all its users.  This
-General Public License applies to most of the Free Software
-Foundation's software and to any other program whose authors commit to
-using it.  (Some other Free Software Foundation software is covered by
-the GNU Library General Public License instead.)  You can apply it to
+  The GNU General Public License is a free, copyleft license for
+software and other kinds of works.
+
+  The licenses for most software and other practical works are designed
+to take away your freedom to share and change the works.  By contrast,
+the GNU General Public License is intended to guarantee your freedom to
+share and change all versions of a program--to make sure it remains free
+software for all its users.  We, the Free Software Foundation, use the
+GNU General Public License for most of our software; it applies also to
+any other work released this way by its authors.  You can apply it to
 your programs, too.
 
   When we speak of free software, we are referring to freedom, not
 price.  Our General Public Licenses are designed to make sure that you
 have the freedom to distribute copies of free software (and charge for
-this service if you wish), that you receive source code or can get it
-if you want it, that you can change the software or use pieces of it
-in new free programs; and that you know you can do these things.
+them if you wish), that you receive source code or can get it if you
+want it, that you can change the software or use pieces of it in new
+free programs, and that you know you can do these things.
 
-  To protect your rights, we need to make restrictions that forbid
-anyone to deny you these rights or to ask you to surrender the rights.
-These restrictions translate to certain responsibilities for you if you
-distribute copies of the software, or if you modify it.
+  To protect your rights, we need to prevent others from denying you
+these rights or asking you to surrender the rights.  Therefore, you have
+certain responsibilities if you distribute copies of the software, or if
+you modify it: responsibilities to respect the freedom of others.
 
   For example, if you distribute copies of such a program, whether
-gratis or for a fee, you must give the recipients all the rights that
-you have.  You must make sure that they, too, receive or can get the
-source code.  And you must show them these terms so they know their
-rights.
-
-  We protect your rights with two steps: (1) copyright the software, and
-(2) offer you this license which gives you legal permission to copy,
-distribute and/or modify the software.
-
-  Also, for each author's protection and ours, we want to make certain
-that everyone understands that there is no warranty for this free
-software.  If the software is modified by someone else and passed on, we
-want its recipients to know that what they have is not the original, so
-that any problems introduced by others will not reflect on the original
-authors' reputations.
-
-  Finally, any free program is threatened constantly by software
-patents.  We wish to avoid the danger that redistributors of a free
-program will individually obtain patent licenses, in effect making the
-program proprietary.  To prevent this, we have made it clear that any
-patent must be licensed for everyone's free use or not licensed at all.
+gratis or for a fee, you must pass on to the recipients the same
+freedoms that you received.  You must make sure that they, too, receive
+or can get the source code.  And you must show them these terms so they
+know their rights.
+
+  Developers that use the GNU GPL protect your rights with two steps:
+(1) assert copyright on the software, and (2) offer you this License
+giving you legal permission to copy, distribute and/or modify it.
+
+  For the developers' and authors' protection, the GPL clearly explains
+that there is no warranty for this free software.  For both users' and
+authors' sake, the GPL requires that modified versions be marked as
+changed, so that their problems will not be attributed erroneously to
+authors of previous versions.
+
+  Some devices are designed to deny users access to install or run
+modified versions of the software inside them, although the manufacturer
+can do so.  This is fundamentally incompatible with the aim of
+protecting users' freedom to change the software.  The systematic
+pattern of such abuse occurs in the area of products for individuals to
+use, which is precisely where it is most unacceptable.  Therefore, we
+have designed this version of the GPL to prohibit the practice for those
+products.  If such problems arise substantially in other domains, we
+stand ready to extend this provision to those domains in future versions
+of the GPL, as needed to protect the freedom of users.
+
+  Finally, every program is threatened constantly by software patents.
+States should not allow patents to restrict development and use of
+software on general-purpose computers, but in those that do, we wish to
+avoid the special danger that patents applied to a free program could
+make it effectively proprietary.  To prevent this, the GPL assures that
+patents cannot be used to render the program non-free.
 
   The precise terms and conditions for copying, distribution and
 modification follow.
-\f
-                   GNU GENERAL PUBLIC LICENSE
-   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
-
-  0. This License applies to any program or other work which contains
-a notice placed by the copyright holder saying it may be distributed
-under the terms of this General Public License.  The "Program", below,
-refers to any such program or work, and a "work based on the Program"
-means either the Program or any derivative work under copyright law:
-that is to say, a work containing the Program or a portion of it,
-either verbatim or with modifications and/or translated into another
-language.  (Hereinafter, translation is included without limitation in
-the term "modification".)  Each licensee is addressed as "you".
-
-Activities other than copying, distribution and modification are not
-covered by this License; they are outside its scope.  The act of
-running the Program is not restricted, and the output from the Program
-is covered only if its contents constitute a work based on the
-Program (independent of having been made by running the Program).
-Whether that is true depends on what the Program does.
-
-  1. You may copy and distribute verbatim copies of the Program's
-source code as you receive it, in any medium, provided that you
-conspicuously and appropriately publish on each copy an appropriate
-copyright notice and disclaimer of warranty; keep intact all the
-notices that refer to this License and to the absence of any warranty;
-and give any other recipients of the Program a copy of this License
-along with the Program.
-
-You may charge a fee for the physical act of transferring a copy, and
-you may at your option offer warranty protection in exchange for a fee.
-
-  2. You may modify your copy or copies of the Program or any portion
-of it, thus forming a work based on the Program, and copy and
-distribute such modifications or work under the terms of Section 1
-above, provided that you also meet all of these conditions:
-
-    a) You must cause the modified files to carry prominent notices
-    stating that you changed the files and the date of any change.
-
-    b) You must cause any work that you distribute or publish, that in
-    whole or in part contains or is derived from the Program or any
-    part thereof, to be licensed as a whole at no charge to all third
-    parties under the terms of this License.
-
-    c) If the modified program normally reads commands interactively
-    when run, you must cause it, when started running for such
-    interactive use in the most ordinary way, to print or display an
-    announcement including an appropriate copyright notice and a
-    notice that there is no warranty (or else, saying that you provide
-    a warranty) and that users may redistribute the program under
-    these conditions, and telling the user how to view a copy of this
-    License.  (Exception: if the Program itself is interactive but
-    does not normally print such an announcement, your work based on
-    the Program is not required to print an announcement.)
-\f
-These requirements apply to the modified work as a whole.  If
-identifiable sections of that work are not derived from the Program,
-and can be reasonably considered independent and separate works in
-themselves, then this License, and its terms, do not apply to those
-sections when you distribute them as separate works.  But when you
-distribute the same sections as part of a whole which is a work based
-on the Program, the distribution of the whole must be on the terms of
-this License, whose permissions for other licensees extend to the
-entire whole, and thus to each and every part regardless of who wrote it.
-
-Thus, it is not the intent of this section to claim rights or contest
-your rights to work written entirely by you; rather, the intent is to
-exercise the right to control the distribution of derivative or
-collective works based on the Program.
-
-In addition, mere aggregation of another work not based on the Program
-with the Program (or with a work based on the Program) on a volume of
-a storage or distribution medium does not bring the other work under
-the scope of this License.
-
-  3. You may copy and distribute the Program (or a work based on it,
-under Section 2) in object code or executable form under the terms of
-Sections 1 and 2 above provided that you also do one of the following:
-
-    a) Accompany it with the complete corresponding machine-readable
-    source code, which must be distributed under the terms of Sections
-    1 and 2 above on a medium customarily used for software interchange; or,
-
-    b) Accompany it with a written offer, valid for at least three
-    years, to give any third party, for a charge no more than your
-    cost of physically performing source distribution, a complete
-    machine-readable copy of the corresponding source code, to be
-    distributed under the terms of Sections 1 and 2 above on a medium
-    customarily used for software interchange; or,
-
-    c) Accompany it with the information you received as to the offer
-    to distribute corresponding source code.  (This alternative is
-    allowed only for noncommercial distribution and only if you
-    received the program in object code or executable form with such
-    an offer, in accord with Subsection b above.)
-
-The source code for a work means the preferred form of the work for
-making modifications to it.  For an executable work, complete source
-code means all the source code for all modules it contains, plus any
-associated interface definition files, plus the scripts used to
-control compilation and installation of the executable.  However, as a
-special exception, the source code distributed need not include
-anything that is normally distributed (in either source or binary
-form) with the major components (compiler, kernel, and so on) of the
-operating system on which the executable runs, unless that component
-itself accompanies the executable.
-
-If distribution of executable or object code is made by offering
-access to copy from a designated place, then offering equivalent
-access to copy the source code from the same place counts as
-distribution of the source code, even though third parties are not
-compelled to copy the source along with the object code.
-\f
-  4. You may not copy, modify, sublicense, or distribute the Program
-except as expressly provided under this License.  Any attempt
-otherwise to copy, modify, sublicense or distribute the Program is
-void, and will automatically terminate your rights under this License.
-However, parties who have received copies, or rights, from you under
-this License will not have their licenses terminated so long as such
-parties remain in full compliance.
-
-  5. You are not required to accept this License, since you have not
-signed it.  However, nothing else grants you permission to modify or
-distribute the Program or its derivative works.  These actions are
-prohibited by law if you do not accept this License.  Therefore, by
-modifying or distributing the Program (or any work based on the
-Program), you indicate your acceptance of this License to do so, and
-all its terms and conditions for copying, distributing or modifying
-the Program or works based on it.
-
-  6. Each time you redistribute the Program (or any work based on the
-Program), the recipient automatically receives a license from the
-original licensor to copy, distribute or modify the Program subject to
-these terms and conditions.  You may not impose any further
-restrictions on the recipients' exercise of the rights granted herein.
-You are not responsible for enforcing compliance by third parties to
+
+                       TERMS AND CONDITIONS
+
+  0. Definitions.
+
+  "This License" refers to version 3 of the GNU General Public License.
+
+  "Copyright" also means copyright-like laws that apply to other kinds of
+works, such as semiconductor masks.
+
+  "The Program" refers to any copyrightable work licensed under this
+License.  Each licensee is addressed as "you".  "Licensees" and
+"recipients" may be individuals or organizations.
+
+  To "modify" a work means to copy from or adapt all or part of the work
+in a fashion requiring copyright permission, other than the making of an
+exact copy.  The resulting work is called a "modified version" of the
+earlier work or a work "based on" the earlier work.
+
+  A "covered work" means either the unmodified Program or a work based
+on the Program.
+
+  To "propagate" a work means to do anything with it that, without
+permission, would make you directly or secondarily liable for
+infringement under applicable copyright law, except executing it on a
+computer or modifying a private copy.  Propagation includes copying,
+distribution (with or without modification), making available to the
+public, and in some countries other activities as well.
+
+  To "convey" a work means any kind of propagation that enables other
+parties to make or receive copies.  Mere interaction with a user through
+a computer network, with no transfer of a copy, is not conveying.
+
+  An interactive user interface displays "Appropriate Legal Notices"
+to the extent that it includes a convenient and prominently visible
+feature that (1) displays an appropriate copyright notice, and (2)
+tells the user that there is no warranty for the work (except to the
+extent that warranties are provided), that licensees may convey the
+work under this License, and how to view a copy of this License.  If
+the interface presents a list of user commands or options, such as a
+menu, a prominent item in the list meets this criterion.
+
+  1. Source Code.
+
+  The "source code" for a work means the preferred form of the work
+for making modifications to it.  "Object code" means any non-source
+form of a work.
+
+  A "Standard Interface" means an interface that either is an official
+standard defined by a recognized standards body, or, in the case of
+interfaces specified for a particular programming language, one that
+is widely used among developers working in that language.
+
+  The "System Libraries" of an executable work include anything, other
+than the work as a whole, that (a) is included in the normal form of
+packaging a Major Component, but which is not part of that Major
+Component, and (b) serves only to enable use of the work with that
+Major Component, or to implement a Standard Interface for which an
+implementation is available to the public in source code form.  A
+"Major Component", in this context, means a major essential component
+(kernel, window system, and so on) of the specific operating system
+(if any) on which the executable work runs, or a compiler used to
+produce the work, or an object code interpreter used to run it.
+
+  The "Corresponding Source" for a work in object code form means all
+the source code needed to generate, install, and (for an executable
+work) run the object code and to modify the work, including scripts to
+control those activities.  However, it does not include the work's
+System Libraries, or general-purpose tools or generally available free
+programs which are used unmodified in performing those activities but
+which are not part of the work.  For example, Corresponding Source
+includes interface definition files associated with source files for
+the work, and the source code for shared libraries and dynamically
+linked subprograms that the work is specifically designed to require,
+such as by intimate data communication or control flow between those
+subprograms and other parts of the work.
+
+  The Corresponding Source need not include anything that users
+can regenerate automatically from other parts of the Corresponding
+Source.
+
+  The Corresponding Source for a work in source code form is that
+same work.
+
+  2. Basic Permissions.
+
+  All rights granted under this License are granted for the term of
+copyright on the Program, and are irrevocable provided the stated
+conditions are met.  This License explicitly affirms your unlimited
+permission to run the unmodified Program.  The output from running a
+covered work is covered by this License only if the output, given its
+content, constitutes a covered work.  This License acknowledges your
+rights of fair use or other equivalent, as provided by copyright law.
+
+  You may make, run and propagate covered works that you do not
+convey, without conditions so long as your license otherwise remains
+in force.  You may convey covered works to others for the sole purpose
+of having them make modifications exclusively for you, or provide you
+with facilities for running those works, provided that you comply with
+the terms of this License in conveying all material for which you do
+not control copyright.  Those thus making or running the covered works
+for you must do so exclusively on your behalf, under your direction
+and control, on terms that prohibit them from making any copies of
+your copyrighted material outside their relationship with you.
+
+  Conveying under any other circumstances is permitted solely under
+the conditions stated below.  Sublicensing is not allowed; section 10
+makes it unnecessary.
+
+  3. Protecting Users' Legal Rights From Anti-Circumvention Law.
+
+  No covered work shall be deemed part of an effective technological
+measure under any applicable law fulfilling obligations under article
+11 of the WIPO copyright treaty adopted on 20 December 1996, or
+similar laws prohibiting or restricting circumvention of such
+measures.
+
+  When you convey a covered work, you waive any legal power to forbid
+circumvention of technological measures to the extent such circumvention
+is effected by exercising rights under this License with respect to
+the covered work, and you disclaim any intention to limit operation or
+modification of the work as a means of enforcing, against the work's
+users, your or third parties' legal rights to forbid circumvention of
+technological measures.
+
+  4. Conveying Verbatim Copies.
+
+  You may convey verbatim copies of the Program's source code as you
+receive it, in any medium, provided that you conspicuously and
+appropriately publish on each copy an appropriate copyright notice;
+keep intact all notices stating that this License and any
+non-permissive terms added in accord with section 7 apply to the code;
+keep intact all notices of the absence of any warranty; and give all
+recipients a copy of this License along with the Program.
+
+  You may charge any price or no price for each copy that you convey,
+and you may offer support or warranty protection for a fee.
+
+  5. Conveying Modified Source Versions.
+
+  You may convey a work based on the Program, or the modifications to
+produce it from the Program, in the form of source code under the
+terms of section 4, provided that you also meet all of these conditions:
+
+    a) The work must carry prominent notices stating that you modified
+    it, and giving a relevant date.
+
+    b) The work must carry prominent notices stating that it is
+    released under this License and any conditions added under section
+    7.  This requirement modifies the requirement in section 4 to
+    "keep intact all notices".
+
+    c) You must license the entire work, as a whole, under this
+    License to anyone who comes into possession of a copy.  This
+    License will therefore apply, along with any applicable section 7
+    additional terms, to the whole of the work, and all its parts,
+    regardless of how they are packaged.  This License gives no
+    permission to license the work in any other way, but it does not
+    invalidate such permission if you have separately received it.
+
+    d) If the work has interactive user interfaces, each must display
+    Appropriate Legal Notices; however, if the Program has interactive
+    interfaces that do not display Appropriate Legal Notices, your
+    work need not make them do so.
+
+  A compilation of a covered work with other separate and independent
+works, which are not by their nature extensions of the covered work,
+and which are not combined with it such as to form a larger program,
+in or on a volume of a storage or distribution medium, is called an
+"aggregate" if the compilation and its resulting copyright are not
+used to limit the access or legal rights of the compilation's users
+beyond what the individual works permit.  Inclusion of a covered work
+in an aggregate does not cause this License to apply to the other
+parts of the aggregate.
+
+  6. Conveying Non-Source Forms.
+
+  You may convey a covered work in object code form under the terms
+of sections 4 and 5, provided that you also convey the
+machine-readable Corresponding Source under the terms of this License,
+in one of these ways:
+
+    a) Convey the object code in, or embodied in, a physical product
+    (including a physical distribution medium), accompanied by the
+    Corresponding Source fixed on a durable physical medium
+    customarily used for software interchange.
+
+    b) Convey the object code in, or embodied in, a physical product
+    (including a physical distribution medium), accompanied by a
+    written offer, valid for at least three years and valid for as
+    long as you offer spare parts or customer support for that product
+    model, to give anyone who possesses the object code either (1) a
+    copy of the Corresponding Source for all the software in the
+    product that is covered by this License, on a durable physical
+    medium customarily used for software interchange, for a price no
+    more than your reasonable cost of physically performing this
+    conveying of source, or (2) access to copy the
+    Corresponding Source from a network server at no charge.
+
+    c) Convey individual copies of the object code with a copy of the
+    written offer to provide the Corresponding Source.  This
+    alternative is allowed only occasionally and noncommercially, and
+    only if you received the object code with such an offer, in accord
+    with subsection 6b.
+
+    d) Convey the object code by offering access from a designated
+    place (gratis or for a charge), and offer equivalent access to the
+    Corresponding Source in the same way through the same place at no
+    further charge.  You need not require recipients to copy the
+    Corresponding Source along with the object code.  If the place to
+    copy the object code is a network server, the Corresponding Source
+    may be on a different server (operated by you or a third party)
+    that supports equivalent copying facilities, provided you maintain
+    clear directions next to the object code saying where to find the
+    Corresponding Source.  Regardless of what server hosts the
+    Corresponding Source, you remain obligated to ensure that it is
+    available for as long as needed to satisfy these requirements.
+
+    e) Convey the object code using peer-to-peer transmission, provided
+    you inform other peers where the object code and Corresponding
+    Source of the work are being offered to the general public at no
+    charge under subsection 6d.
+
+  A separable portion of the object code, whose source code is excluded
+from the Corresponding Source as a System Library, need not be
+included in conveying the object code work.
+
+  A "User Product" is either (1) a "consumer product", which means any
+tangible personal property which is normally used for personal, family,
+or household purposes, or (2) anything designed or sold for incorporation
+into a dwelling.  In determining whether a product is a consumer product,
+doubtful cases shall be resolved in favor of coverage.  For a particular
+product received by a particular user, "normally used" refers to a
+typical or common use of that class of product, regardless of the status
+of the particular user or of the way in which the particular user
+actually uses, or expects or is expected to use, the product.  A product
+is a consumer product regardless of whether the product has substantial
+commercial, industrial or non-consumer uses, unless such uses represent
+the only significant mode of use of the product.
+
+  "Installation Information" for a User Product means any methods,
+procedures, authorization keys, or other information required to install
+and execute modified versions of a covered work in that User Product from
+a modified version of its Corresponding Source.  The information must
+suffice to ensure that the continued functioning of the modified object
+code is in no case prevented or interfered with solely because
+modification has been made.
+
+  If you convey an object code work under this section in, or with, or
+specifically for use in, a User Product, and the conveying occurs as
+part of a transaction in which the right of possession and use of the
+User Product is transferred to the recipient in perpetuity or for a
+fixed term (regardless of how the transaction is characterized), the
+Corresponding Source conveyed under this section must be accompanied
+by the Installation Information.  But this requirement does not apply
+if neither you nor any third party retains the ability to install
+modified object code on the User Product (for example, the work has
+been installed in ROM).
+
+  The requirement to provide Installation Information does not include a
+requirement to continue to provide support service, warranty, or updates
+for a work that has been modified or installed by the recipient, or for
+the User Product in which it has been modified or installed.  Access to a
+network may be denied when the modification itself materially and
+adversely affects the operation of the network or violates the rules and
+protocols for communication across the network.
+
+  Corresponding Source conveyed, and Installation Information provided,
+in accord with this section must be in a format that is publicly
+documented (and with an implementation available to the public in
+source code form), and must require no special password or key for
+unpacking, reading or copying.
+
+  7. Additional Terms.
+
+  "Additional permissions" are terms that supplement the terms of this
+License by making exceptions from one or more of its conditions.
+Additional permissions that are applicable to the entire Program shall
+be treated as though they were included in this License, to the extent
+that they are valid under applicable law.  If additional permissions
+apply only to part of the Program, that part may be used separately
+under those permissions, but the entire Program remains governed by
+this License without regard to the additional permissions.
+
+  When you convey a copy of a covered work, you may at your option
+remove any additional permissions from that copy, or from any part of
+it.  (Additional permissions may be written to require their own
+removal in certain cases when you modify the work.)  You may place
+additional permissions on material, added by you to a covered work,
+for which you have or can give appropriate copyright permission.
+
+  Notwithstanding any other provision of this License, for material you
+add to a covered work, you may (if authorized by the copyright holders of
+that material) supplement the terms of this License with terms:
+
+    a) Disclaiming warranty or limiting liability differently from the
+    terms of sections 15 and 16 of this License; or
+
+    b) Requiring preservation of specified reasonable legal notices or
+    author attributions in that material or in the Appropriate Legal
+    Notices displayed by works containing it; or
+
+    c) Prohibiting misrepresentation of the origin of that material, or
+    requiring that modified versions of such material be marked in
+    reasonable ways as different from the original version; or
+
+    d) Limiting the use for publicity purposes of names of licensors or
+    authors of the material; or
+
+    e) Declining to grant rights under trademark law for use of some
+    trade names, trademarks, or service marks; or
+
+    f) Requiring indemnification of licensors and authors of that
+    material by anyone who conveys the material (or modified versions of
+    it) with contractual assumptions of liability to the recipient, for
+    any liability that these contractual assumptions directly impose on
+    those licensors and authors.
+
+  All other non-permissive additional terms are considered "further
+restrictions" within the meaning of section 10.  If the Program as you
+received it, or any part of it, contains a notice stating that it is
+governed by this License along with a term that is a further
+restriction, you may remove that term.  If a license document contains
+a further restriction but permits relicensing or conveying under this
+License, you may add to a covered work material governed by the terms
+of that license document, provided that the further restriction does
+not survive such relicensing or conveying.
+
+  If you add terms to a covered work in accord with this section, you
+must place, in the relevant source files, a statement of the
+additional terms that apply to those files, or a notice indicating
+where to find the applicable terms.
+
+  Additional terms, permissive or non-permissive, may be stated in the
+form of a separately written license, or stated as exceptions;
+the above requirements apply either way.
+
+  8. Termination.
+
+  You may not propagate or modify a covered work except as expressly
+provided under this License.  Any attempt otherwise to propagate or
+modify it is void, and will automatically terminate your rights under
+this License (including any patent licenses granted under the third
+paragraph of section 11).
+
+  However, if you cease all violation of this License, then your
+license from a particular copyright holder is reinstated (a)
+provisionally, unless and until the copyright holder explicitly and
+finally terminates your license, and (b) permanently, if the copyright
+holder fails to notify you of the violation by some reasonable means
+prior to 60 days after the cessation.
+
+  Moreover, your license from a particular copyright holder is
+reinstated permanently if the copyright holder notifies you of the
+violation by some reasonable means, this is the first time you have
+received notice of violation of this License (for any work) from that
+copyright holder, and you cure the violation prior to 30 days after
+your receipt of the notice.
+
+  Termination of your rights under this section does not terminate the
+licenses of parties who have received copies or rights from you under
+this License.  If your rights have been terminated and not permanently
+reinstated, you do not qualify to receive new licenses for the same
+material under section 10.
+
+  9. Acceptance Not Required for Having Copies.
+
+  You are not required to accept this License in order to receive or
+run a copy of the Program.  Ancillary propagation of a covered work
+occurring solely as a consequence of using peer-to-peer transmission
+to receive a copy likewise does not require acceptance.  However,
+nothing other than this License grants you permission to propagate or
+modify any covered work.  These actions infringe copyright if you do
+not accept this License.  Therefore, by modifying or propagating a
+covered work, you indicate your acceptance of this License to do so.
+
+  10. Automatic Licensing of Downstream Recipients.
+
+  Each time you convey a covered work, the recipient automatically
+receives a license from the original licensors, to run, modify and
+propagate that work, subject to this License.  You are not responsible
+for enforcing compliance by third parties with this License.
+
+  An "entity transaction" is a transaction transferring control of an
+organization, or substantially all assets of one, or subdividing an
+organization, or merging organizations.  If propagation of a covered
+work results from an entity transaction, each party to that
+transaction who receives a copy of the work also receives whatever
+licenses to the work the party's predecessor in interest had or could
+give under the previous paragraph, plus a right to possession of the
+Corresponding Source of the work from the predecessor in interest, if
+the predecessor has it or can get it with reasonable efforts.
+
+  You may not impose any further restrictions on the exercise of the
+rights granted or affirmed under this License.  For example, you may
+not impose a license fee, royalty, or other charge for exercise of
+rights granted under this License, and you may not initiate litigation
+(including a cross-claim or counterclaim in a lawsuit) alleging that
+any patent claim is infringed by making, using, selling, offering for
+sale, or importing the Program or any portion of it.
+
+  11. Patents.
+
+  A "contributor" is a copyright holder who authorizes use under this
+License of the Program or a work on which the Program is based.  The
+work thus licensed is called the contributor's "contributor version".
+
+  A contributor's "essential patent claims" are all patent claims
+owned or controlled by the contributor, whether already acquired or
+hereafter acquired, that would be infringed by some manner, permitted
+by this License, of making, using, or selling its contributor version,
+but do not include claims that would be infringed only as a
+consequence of further modification of the contributor version.  For
+purposes of this definition, "control" includes the right to grant
+patent sublicenses in a manner consistent with the requirements of
 this License.
 
-  7. If, as a consequence of a court judgment or allegation of patent
-infringement or for any other reason (not limited to patent issues),
-conditions are imposed on you (whether by court order, agreement or
+  Each contributor grants you a non-exclusive, worldwide, royalty-free
+patent license under the contributor's essential patent claims, to
+make, use, sell, offer for sale, import and otherwise run, modify and
+propagate the contents of its contributor version.
+
+  In the following three paragraphs, a "patent license" is any express
+agreement or commitment, however denominated, not to enforce a patent
+(such as an express permission to practice a patent or covenant not to
+sue for patent infringement).  To "grant" such a patent license to a
+party means to make such an agreement or commitment not to enforce a
+patent against the party.
+
+  If you convey a covered work, knowingly relying on a patent license,
+and the Corresponding Source of the work is not available for anyone
+to copy, free of charge and under the terms of this License, through a
+publicly available network server or other readily accessible means,
+then you must either (1) cause the Corresponding Source to be so
+available, or (2) arrange to deprive yourself of the benefit of the
+patent license for this particular work, or (3) arrange, in a manner
+consistent with the requirements of this License, to extend the patent
+license to downstream recipients.  "Knowingly relying" means you have
+actual knowledge that, but for the patent license, your conveying the
+covered work in a country, or your recipient's use of the covered work
+in a country, would infringe one or more identifiable patents in that
+country that you have reason to believe are valid.
+
+  If, pursuant to or in connection with a single transaction or
+arrangement, you convey, or propagate by procuring conveyance of, a
+covered work, and grant a patent license to some of the parties
+receiving the covered work authorizing them to use, propagate, modify
+or convey a specific copy of the covered work, then the patent license
+you grant is automatically extended to all recipients of the covered
+work and works based on it.
+
+  A patent license is "discriminatory" if it does not include within
+the scope of its coverage, prohibits the exercise of, or is
+conditioned on the non-exercise of one or more of the rights that are
+specifically granted under this License.  You may not convey a covered
+work if you are a party to an arrangement with a third party that is
+in the business of distributing software, under which you make payment
+to the third party based on the extent of your activity of conveying
+the work, and under which the third party grants, to any of the
+parties who would receive the covered work from you, a discriminatory
+patent license (a) in connection with copies of the covered work
+conveyed by you (or copies made from those copies), or (b) primarily
+for and in connection with specific products or compilations that
+contain the covered work, unless you entered into that arrangement,
+or that patent license was granted, prior to 28 March 2007.
+
+  Nothing in this License shall be construed as excluding or limiting
+any implied license or other defenses to infringement that may
+otherwise be available to you under applicable patent law.
+
+  12. No Surrender of Others' Freedom.
+
+  If conditions are imposed on you (whether by court order, agreement or
 otherwise) that contradict the conditions of this License, they do not
-excuse you from the conditions of this License.  If you cannot
-distribute so as to satisfy simultaneously your obligations under this
-License and any other pertinent obligations, then as a consequence you
-may not distribute the Program at all.  For example, if a patent
-license would not permit royalty-free redistribution of the Program by
-all those who receive copies directly or indirectly through you, then
-the only way you could satisfy both it and this License would be to
-refrain entirely from distribution of the Program.
-
-If any portion of this section is held invalid or unenforceable under
-any particular circumstance, the balance of the section is intended to
-apply and the section as a whole is intended to apply in other
-circumstances.
-
-It is not the purpose of this section to induce you to infringe any
-patents or other property right claims or to contest validity of any
-such claims; this section has the sole purpose of protecting the
-integrity of the free software distribution system, which is
-implemented by public license practices.  Many people have made
-generous contributions to the wide range of software distributed
-through that system in reliance on consistent application of that
-system; it is up to the author/donor to decide if he or she is willing
-to distribute software through any other system and a licensee cannot
-impose that choice.
-
-This section is intended to make thoroughly clear what is believed to
-be a consequence of the rest of this License.
-\f
-  8. If the distribution and/or use of the Program is restricted in
-certain countries either by patents or by copyrighted interfaces, the
-original copyright holder who places the Program under this License
-may add an explicit geographical distribution limitation excluding
-those countries, so that distribution is permitted only in or among
-countries not thus excluded.  In such case, this License incorporates
-the limitation as if written in the body of this License.
-
-  9. The Free Software Foundation may publish revised and/or new versions
-of the General Public License from time to time.  Such new versions will
+excuse you from the conditions of this License.  If you cannot convey a
+covered work so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you may
+not convey it at all.  For example, if you agree to terms that obligate you
+to collect a royalty for further conveying from those to whom you convey
+the Program, the only way you could satisfy both those terms and this
+License would be to refrain entirely from conveying the Program.
+
+  13. Use with the GNU Affero General Public License.
+
+  Notwithstanding any other provision of this License, you have
+permission to link or combine any covered work with a work licensed
+under version 3 of the GNU Affero General Public License into a single
+combined work, and to convey the resulting work.  The terms of this
+License will continue to apply to the part which is the covered work,
+but the special requirements of the GNU Affero General Public License,
+section 13, concerning interaction through a network will apply to the
+combination as such.
+
+  14. Revised Versions of this License.
+
+  The Free Software Foundation may publish revised and/or new versions of
+the GNU General Public License from time to time.  Such new versions will
 be similar in spirit to the present version, but may differ in detail to
 address new problems or concerns.
 
-Each version is given a distinguishing version number.  If the Program
-specifies a version number of this License which applies to it and "any
-later version", you have the option of following the terms and conditions
-either of that version or of any later version published by the Free
-Software Foundation.  If the Program does not specify a version number of
-this License, you may choose any version ever published by the Free Software
-Foundation.
-
-  10. If you wish to incorporate parts of the Program into other free
-programs whose distribution conditions are different, write to the author
-to ask for permission.  For software which is copyrighted by the Free
-Software Foundation, write to the Free Software Foundation; we sometimes
-make exceptions for this.  Our decision will be guided by the two goals
-of preserving the free status of all derivatives of our free software and
-of promoting the sharing and reuse of software generally.
-
-                           NO WARRANTY
-
-  11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
-FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW.  EXCEPT WHEN
-OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
-PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
-OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
-MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.  THE ENTIRE RISK AS
-TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.  SHOULD THE
-PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
-REPAIR OR CORRECTION.
-
-  12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
-WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
-REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
-INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
-OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
-TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
-YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
-PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
-POSSIBILITY OF SUCH DAMAGES.
-
-                    END OF TERMS AND CONDITIONS
-\f
-           How to Apply These Terms to Your New Programs
+  Each version is given a distinguishing version number.  If the
+Program specifies that a certain numbered version of the GNU General
+Public License "or any later version" applies to it, you have the
+option of following the terms and conditions either of that numbered
+version or of any later version published by the Free Software
+Foundation.  If the Program does not specify a version number of the
+GNU General Public License, you may choose any version ever published
+by the Free Software Foundation.
+
+  If the Program specifies that a proxy can decide which future
+versions of the GNU General Public License can be used, that proxy's
+public statement of acceptance of a version permanently authorizes you
+to choose that version for the Program.
+
+  Later license versions may give you additional or different
+permissions.  However, no additional obligations are imposed on any
+author or copyright holder as a result of your choosing to follow a
+later version.
+
+  15. Disclaimer of Warranty.
+
+  THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
+APPLICABLE LAW.  EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
+HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
+OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
+THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
+IS WITH YOU.  SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
+ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
+
+  16. Limitation of Liability.
+
+  IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
+THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
+GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
+USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
+DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
+PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
+EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
+SUCH DAMAGES.
+
+  17. Interpretation of Sections 15 and 16.
+
+  If the disclaimer of warranty and limitation of liability provided
+above cannot be given local legal effect according to their terms,
+reviewing courts shall apply local law that most closely approximates
+an absolute waiver of all civil liability in connection with the
+Program, unless a warranty or assumption of liability accompanies a
+copy of the Program in return for a fee.
+
+                     END OF TERMS AND CONDITIONS
+
+            How to Apply These Terms to Your New Programs
 
   If you develop a new program, and you want it to be of the greatest
 possible use to the public, the best way to achieve this is to make it
@@ -287,15 +628,15 @@ free software which everyone can redistribute and change under these terms.
 
   To do so, attach the following notices to the program.  It is safest
 to attach them to the start of each source file to most effectively
-convey the exclusion of warranty; and each file should have at least
+state the exclusion of warranty; and each file should have at least
 the "copyright" line and a pointer to where the full notice is found.
 
     <one line to give the program's name and a brief idea of what it does.>
     Copyright (C) <year>  <name of author>
 
-    This program is free software; you can redistribute it and/or modify
+    This program is free software: you can redistribute it and/or modify
     it under the terms of the GNU General Public License as published by
-    the Free Software Foundation; either version 2 of the License, or
+    the Free Software Foundation, either version 3 of the License, or
     (at your option) any later version.
 
     This program is distributed in the hope that it will be useful,
@@ -304,37 +645,30 @@ the "copyright" line and a pointer to where the full notice is found.
     GNU General Public License for more details.
 
     You should have received a copy of the GNU General Public License
-    along with this program; if not, write to the Free Software
-    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
-
+    along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
 Also add information on how to contact you by electronic and paper mail.
 
-If the program is interactive, make it output a short notice like this
-when it starts in an interactive mode:
+  If the program does terminal interaction, make it output a short
+notice like this when it starts in an interactive mode:
 
-    Gnomovision version 69, Copyright (C) year  name of author
-    Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+    <program>  Copyright (C) <year>  <name of author>
+    This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
     This is free software, and you are welcome to redistribute it
     under certain conditions; type `show c' for details.
 
 The hypothetical commands `show w' and `show c' should show the appropriate
-parts of the General Public License.  Of course, the commands you use may
-be called something other than `show w' and `show c'; they could even be
-mouse-clicks or menu items--whatever suits your program.
-
-You should also get your employer (if you work as a programmer) or your
-school, if any, to sign a "copyright disclaimer" for the program, if
-necessary.  Here is a sample; alter the names:
-
-  Yoyodyne, Inc., hereby disclaims all copyright interest in the program
-  `Gnomovision' (which makes passes at compilers) written by James Hacker.
-
-  <signature of Ty Coon>, 1 April 1989
-  Ty Coon, President of Vice
-
-This General Public License does not permit incorporating your program into
-proprietary programs.  If your program is a subroutine library, you may
-consider it more useful to permit linking proprietary applications with the
-library.  If this is what you want to do, use the GNU Library General
-Public License instead of this License.
+parts of the General Public License.  Of course, your program's commands
+might be different; for a GUI interface, you would use an "about box".
+
+  You should also get your employer (if you work as a programmer) or school,
+if any, to sign a "copyright disclaimer" for the program, if necessary.
+For more information on this, and how to apply and follow the GNU GPL, see
+<http://www.gnu.org/licenses/>.
+
+  The GNU General Public License does not permit incorporating your program
+into proprietary programs.  If your program is a subroutine library, you
+may consider it more useful to permit linking proprietary applications with
+the library.  If this is what you want to do, use the GNU Lesser General
+Public License instead of this License.  But first, please read
+<http://www.gnu.org/philosophy/why-not-lgpl.html>.
diff --git a/contrib/diffutils/ChangeLog b/contrib/diffutils/ChangeLog
deleted file mode 100644 (file)
index 291919d..0000000
+++ /dev/null
@@ -1,3878 +0,0 @@
-2004-04-13  Paul Eggert  <eggert@twinsun.com>
-
-       * NEWS, configure.ac (AC_INIT): Version 2.8.7.
-       * configure.ac (AM_GNU_GETTEXT_VERSION): Add.
-       (XGETTEXT): Restore from pre-2004-04-12 version.  This fixes
-       a bug that lost many msgids in doc/diffutils.pot.
-       * bootstrap: New file.
-       * exgettext: Don't generate a temporary file, as this runs afoul
-       of "make distcheck" which operates with read-only directories.
-       * Makefile.am (EXTRA_DIST): Add bootstrap.
-       Remove config/config.rpath as it is deduced automatically these days.
-
-2004-04-12  Paul Eggert  <eggert@twinsun.com>
-
-       * NEWS, configure.ac (AC_INIT): Version 2.8.6.
-
-       * NEWS: Add news for 2.8.4, 2.8.6.
-
-       * README: Move copyright notice to end.  Defer to "configure
-       --help" for special "configure" options.  Suggest latest libiconv.
-       Update version numbers of Autoconf etc. to current.
-
-       * configure.ac: Quote various arguments better.
-       (AC_CONFIG_MACRO_DIR): Add call, specifying "m4".
-       (AC_CONFIG_HEADER): Replaces AM_CONFIG_HEADER.
-       (gl_USE_SYSTEM_EXTENSIONS): Replaces AC_GNU_SOURCE.
-       (AC_ISC_POSIX): Remove; nobody ports to ancient ISC any more.
-       (AC_PROG_CPP, AC_PROG_INSTALL, AC_C_INLINE,
-       AC_HEADER_STDBOOL, AC_HEADER_STDC, AM_GNU_GETTEXT, XGETTEXT,
-       AC_HEADER_STAT, AC_FUNC_VPRINTF, jm_FUNC_GLIBC_UNLOCKED_IO,
-       jm_FUNC_GNU_STRFTIME, jm_FUNC_MALLOC, jm_FUNC_REALLOC,
-       jm_PREREQ_C_STACK, jm_PREREQ_ERROR, jm_PREREQ_HARD_LOCALE,
-       jm_PREREQ_QUOTEARG, jm_PREREQ_REGEX, AC_FUNC_FNMATCH_GNU, jm_AC_DOS):
-       Remove; not needed here, as our files don't use them directly
-       or we rely on gnulib modules.
-       (AC_C_CONST): Remove; we assume C89 now.
-       (AC_CHECK_HEADERS): Remove libintl.h, limits.h, stdlib.h, string.h,
-       time.h.
-       (AC_CHECK_TYPE): Remove ptrdiff_t, ssize_t.
-       (AC_CHECK_FUNCS): Remove diraccess, strchr, strerror, tmpnam).
-       (AC_REPLACE_FUNCS): Remove memchr, mkstemp, strcasecmp.
-       (GNULIB_AUTOCONF_SNIPPET): Add call.  This replaces much of
-       the above.
-       (AC_CONFIG_FILES): Remove lib/posix/Makefile.
-       (AC_CONFIG_COMMANDS): Remove.
-       
-       * doc/diff.texi (dircategory): Change to "Text creation and
-       manipulation" from "GNU packages".
-       (Translations): New node.
-       (Overview): Improve quality of algorithm citations.
-       (Binary): -q doesn't exactly cause diff to assume files are binary.
-       (Normal): Place after Side by Side, since it's less important.
-       (Detailed Context, Detailed Unified, Detailed ed,
-       Detailed if-then-else, diff3 Hunks, Detailed diff3 Normal):
-       Place at end of menu.
-       (Detailed Unified): Mention that fractional timestamps are
-       omitted on hosts that don't support them.
-       Mention what happens when hunks contain just one line.
-       (Line Group Formats, Reject Names): Fix duplicate-word typos.
-       (Comparing Directories): Trailing white space and empty lines are
-       ignored in the -X file.
-       (diff Options): Add --strip-trailing-cr.
-       (Projects): gnu -> gvc@gnu.org.
-
-       * lib/Makefile.am (SUBDIRS): Remove.
-       (EXTRA_DIST, noinst_HEADERS): Remove most entries.
-       (libdiffutils_a_SOURCES): Now just lib_SOURCES.
-       (lib_SOURCES): New macro.
-       (DISTCLEANFILES, MOSTLYCLEANFILES): Set to empty now.
-       (gnulib.mk): Include: this does most of the work eliminated
-       by the above changes.
-
-       * lib/inttostr.c (inttostr): Protect i < 0 by compile-time
-       test intended to suppress compiler warnings.
-       * lib/inttostr.h: Include limits.h unilaterally.
-       (CHAR_BIT): Remove.
-       (PARAMS): Remove; all uses changed.
-       * lib/setmode.c (__attribute__): New macro.
-       (set_binary_mode): Define only if HAVE_SETMODE_DOS.
-       Otherwise define a dummy static char, as C89 requires
-       that we define something.
-       * lib/setmode.h (set_binary_mode): Return true, not 1.
-
-       * src/analyze.c, src/context.c, src/diff.c, src/io.c, src/util.c:
-       Do not include regex.h, as diff.h does this now.
-
-       * src/cmp.c: Sort includes.  Include <exit.h>, <unlocked-io.h>.
-       (specify_comparison_type): Don't report an error if the comparison
-       type has already been specified the same way as this one.
-
-       * src/cmp.c (usage): Mention exit status.
-       * src/diff.c (option_help_msgid): Likewise.
-       * src/diff3.c (usage): Likewise.
-       * src/sdiff.c (usage): Likewise.
-
-       * src/cmp.c (main): Adjust to latest gnulib c_stack_action
-       calling conventions.
-       * src/diff.c (main): Likewise.
-       * src/diff3.c (main): Likewise.
-       * src/sdiff.c (main): Likewise.
-
-       * src/cmp.c (main): Adjust to latest version_etc calling conventions.
-       * src/diff.c (main): Likewise.
-       * src/diff3.c (main): Likewise.
-       * src/sdiff.c (main): Likewise.
-
-       * src/diff.c: Include <exit.h>.
-       (binary): Define to true if not declared.
-       (longopts): Set tabsize flag to 1.
-       (main): Don't output nanoseconds if platform lacks them.
-       Don't treat files as binary if !binary.
-       (set_mtime_to_now): Use 0, not NULL.
-       (compare_files): Mark files as nonexistent if it looks like
-       'patch' created inaccessible regular empty files to denote
-       nonexistent backups.  Don't compare such files.
-       Clear st_* members of status of nonexistent file.
-       Remove now-unnecessary tests.
-
-       * src/diff.h: Include regex.h, unlocked-io.h.
-       (struct file_data.changed): Now char *, not bool *, to save
-       space on hosts where bool takes more space than char.
-       All uses changed.
-
-       * src/diff3.c: Include unlocked-io.h.
-       (strip_trailing_cr): New var.
-       (STRIP_TRAILING_CR_OPTION): New enum.
-       (longopts, main, option_help_msgid, read_diff):
-       Add --strip-trailing-cr support.
-       (read_diff): Exit with status 126 (not 127) if errno != ENOENT
-       after failed execvp in child.  Report this in parent.
-
-       * src/dir.c: Include <strcase.h>.
-       (failed_locale_specific_sorting): Renamed from failed_strcoll.
-       All uses changed.
-       (compare_names): Don't invoke strcasecmp first thing when
-       ignore_file_name_case; if locale_specific_sorting, we should
-       just use that.
-
-       * src/ifdef.c (next_line): Remove; replace with...
-       (next_line0, next_line1): New vars.
-       (print_ifdef_script, print_ifdef_hunk):
-       Use them to fix line-number computation bug.
-
-       * src/io.c (find_and_hash_each_line): Don't convert char *
-       to unsigned char *; just leave pointers as char *.  This
-       lessens the number of potentially-dangerous casts.
-       * src/util.c (lines_differ): Likewise.
-
-       * src/sdiff.c: Include <unlocked-io.h>, <exit.h>.
-       (check_child_status): Renamed from ck_editor_status, and
-       accept a new arg MAX_OK_STATUS.  All callers changed.
-       Handle status 126/127 as per POSIX.
-       (edit): Likewise.
-       (main): Likewise.  Fix getopt typo: -E wasn't supported.
-
-       * src/system.h (S_IRWXU, S_IRWXG, S_IRWXO): Define if not defined.
-       (S_IXUSR, S_IXGRP, S_IXOTH): Remove.
-       Include <time.h> unconditionally, since we can assume C89 now.
-       Likewise for <stdlib.h>, <string.h>.
-       (getenv, EXIT_SUCCESS, EXIT_FAILURE, SSIZE_MAX, strchr, strrchr,
-       memcmp, memcpy): Remove decl; no longer needed.
-       (strcasecoll, strcasecmp): Define if not built in.
-       (CTYPE_DOMAIN, ISPRINT, ISSPACE, TOLOWER, _tolower, errno): Remove;
-       we now assume C89 or better.  All uses changed.
-       Include <stdbool.h> unconditionally now, since gnulib supports it
-       if the C compiler doesn't.  All boolean uses of 0 and 1 now
-       changed to false and true.
-       (lin_is_printable_as_long_int): Renamed from lin_is_printable_as_long.
-
-       * src/util.c (begin_output): Fix bug: 0 wasn't cast to char * arg,
-       which led to undefined behavior on 64-bit hosts.
-       Use more-standard test for exit status 126 versus 127.
-       (finish_output): Likewise.
-       (analyze_hunk): Do not cast bool to int.
-
-2004-03-15  Paul Eggert  <eggert@twinsun.com>
-
-       * src/cmp.c (main): Don't consider two files with the same name to
-       be the same, if their initial skip values differ.  This fixes a
-       bug reported by Hideki Iwamoto in
-       <http://mail.gnu.org/archive/html/bug-gnu-utils/2004-03/msg00024.html>.
-
-2004-03-11  Paul Eggert  <eggert@twinsun.com>
-
-       * src/analyze.c (diag): Return void, not lin, since the return
-       value wasn't needed.  All callers changed.
-       (diag, diff_2_files):
-       Use 'true' and 'false' instead of '1' and '0', when appropriate.
-       (compareseq): Use lin const * local variables instead of lin *.
-       Don't bother checking diag's return value.
-       (shift_boundaries, build_reverse_script, build_script, diff_2_files):
-       Use char arrays, not bool arrays, since
-       sizeof (bool) might be greater than 1.
-
-2004-02-09  Paul Eggert  <eggert@twinsun.com>
-
-       * m4/setmode.m4 (AC_FUNC_SETMODE_DOS): AC_LIBOBJ(setmode) if
-       we would return true.
-
-2002-10-14  Paul Eggert  <eggert@twinsun.com>
-
-       * src/Makefile.am (diff3.$(OBJEXT), diff.$(OBJEXT),
-       sdiff.$(OBJEXT)): Rename from (misspelled) diff3.$(OBJECT),
-       diff.$(OBJECT), sdiff.$(OBJECT).  Patch by Paul D. Smith in
-       <http://mail.gnu.org/pipermail/bug-gnu-utils/2002-October/003251.html>.
-       Bug reported by Chris Bainbridge.
-
-2002-10-13  Paul Eggert  <eggert@twinsun.com>
-
-       * src/Makefile.am (MOSTLYCLEANFILES): Add paths.ht.
-       (paths.h): Send output to paths.ht first, and then rename to
-       paths.h at the end.  This avoids problems if the disk is full.
-       It also works around what appears to be a bug with GNU make -j
-       (3.79.1); see <http://bugs.gentoo.org/show_bug.cgi?id=8934>.
-
-2002-06-27  Paul Eggert  <eggert@twinsun.com>
-
-       * NEWS, configure.ac (AC_INIT): Version 2.8.4.
-
-       * config/config.sub: Sync with latest version maintained in other
-       packages.
-
-       * lib/file-type.h: Protect against double inclusion.  Detect
-       whether <sys/stat.h> has been included.  Fix from Jim Meyering.
-
-       * src/analyze.c (briefly_report): Don't say "Binary files differ",
-       since one of the files may not be a binary file.
-       Bug reported by Dan Jacobson.
-
-2002-06-22  Paul Eggert  <eggert@twinsun.com>
-
-       * lib/c-stack.c (segv_handler, c_stack_action) [! defined
-       SA_SIGINFO]: Do not assume SA_SIGINFO behavior.
-       Bug reported by Jim Meyering on NetBSD 1.5.2.
-
-2002-06-16  Paul Eggert  <eggert@twinsun.com>
-
-       * NEWS, configure.ac (AC_INIT): Version 2.8.3.
-
-       * config/depcomp, config/missing, README: Update to automake 1.6.2.
-
-       * po/LINGUAS: Add en_US.
-       * po/en_US.po: New file.
-       * po/POTFILES.in: Remove lib/freesoft.c.
-       Add lib/file-type.c, lib/version-etc.c, lib/xmalloc.c.
-
-2002-06-15  Paul Eggert  <eggert@twinsun.com>
-
-       * doc/diff.texi (Special Files): Document behavior of symlink
-       loops.
-
-       * lib/Makefile.am (noinst_HEADERS): Remove freesoft.h.
-       Add version-etc.h.
-       (libdiffutils_a_SOURCES): Remove freesoft.c.  Add version-etc.c.
-       * lib/freesoft.c, lib/freesoft.h: Remove.
-       * lib/version-etc.h (PARAMS): Remove; we now assume C89 at least.
-
-       * lib/version-etc.h (version_etc): Remove package and version args.
-       (version_etc_copyright): Remove.
-       * lib/version-etc.c: Likewise.
-       Do not include unlocked-io.h; no longer needed.
-       Include gettext.h rather than libinto.h.
-       (_): Define unconditionally.
-       (version_etc): Adjust wording to match current GNU coding standards.
-       Translate "(C)" if possible.
-
-       * lib/version-etc.c, lib/version-etc.h: New files, taken from
-       fileutils.
-
-       * src/Makefile.am (cmp_SOURCES, diff3_SOURCES, sdiff_SOURCES,
-       diff_SOURCES): Remove version.c.
-       (MAINTAINERCLEANFILES, $(srcdir)/version.c): Remove.
-
-       * src/cmp.c: Include version-etc.h, not freesoft.h.
-       (copyright_notice): Remove.
-       (main): Use version_etc to print version.
-       * src/diff.c, src/diff3.c, src/sdiff.c: Likewise.
-
-       * src/cmp.c (version_string): Remove decl.
-       * src/diff.h, src/diff3.c, src/sdiff.c: Likewise.
-
-2002-06-11  Paul Eggert  <eggert@twinsun.com>
-
-       * lib/fnmatch.c, lib/fnmatch_loop.c (WIDE_CHAR_SUPPORT):
-       New macro.  Use it uniformly instead of
-       (defined HAVE_WCTYPE_H && defined HAVE_WCHAR_H).
-       It also uses HAVE_BTOWC, to fix a porting bug on Solaris 2.5.1
-       reported by Vin Shelton.
-       * m4/fnmatch.m4 (_AC_LIBOBJ_FNMATCH): Check for btowc.
-
-       * NEWS, configure.ac (AC_INIT): Version 2.8.2.
-
-       * ABOUT-NLS, config/config.guess, config/config.sub,
-       config/depcomp, config/texinfo.tex, lib/posix/regex.h,
-       m4/c-bs-a.m4, m4/gettext.m4, m4/gnu-source.m4, m4/lib-link.m4,
-       m4/malloc.m4:
-       Update to recent version (maintained in other packages).
-       * m4/prereq.m4 (jm_PREREQ_EXCLUSIVE): AC_FUNC_FNMATCH_GNU
-       no longer takes a lib.
-
-       * README: Incorporate contents from INSTALLME.
-       * INSTALLME: Remove.
-       * Makefile.am (EXTRA_DIST): Remove INSTALLME.
-
-       * configure.ac (AC_GNU_SOURCE): Move up, so that it affects
-       later compilations properly.
-       (DEFAULT_DIFF_PROGRAM, AC_TYPE_SIGNAL): Remove.
-       (jm_AC_TYPE_INTMAX_T): Add.
-       (AC_FUNC_FNMATCH_GNU): Use this, instead of AC_FUNC_FNMATCH.
-       (AC_CONFIG_LINKS): regex.hin renamed from regex_.h.
-
-       * doc/diff.texi: Reword "@option{-f} and @option{--foo}" to
-       "@option{-f} or @option{--foo}".
-       Use @acronym instead of @sc where appropriate.
-       (Specified Lines): Renamed from Specified Folding.
-       (Comparison, Blank Lines):
-       Clarify wordings for Blank Lines and Specified Lines nodes.
-       (Binary): Mention --verbose and --print-bytes.
-       (Tabs, sdiff Option Summary, diff Options):
-       New option --tabsize=COLUMNS.
-
-       * lib/Makefile.am (EXTRA_DIST): Add fnmatch_loop.c.
-       (noinst_HEADERS): fnmatch_.h renamed from fnmatch.hin.
-       regex_.h renamed from regex.hin.
-       Add file-type.h.
-       (libdiffutils_a_SOURCES): Add file-type.c.
-       (DISTCLEANFILES): Remove fnmatch.hno, regex.hno.
-
-       * lib/c-stack.c (__attribute__): New macro.
-       (EOVERFLOW): Define if not defined.
-       (stack_t): Define to struct sigaltstack if not defined or declared.
-       Include <sys/resource.h>, <ucontext.h> if available.
-       Include <stdio.h> if DEBUG.
-       Do not include <inttypes.h> or <stdint.h>.
-       (c_stack_die): Remove info and context args.  All uses changed.
-       (segv_action): Likewise.
-       (alternate_signal_stack): Change uintmax_t to long, to ease porting.
-       (get_stack_location, min_address_from_argv, max_address_from_argv,
-       null_action): New functions.
-       (stack_base, stack_size): New vars.
-       (segv_handler): context arg may not be used.
-       Use global stack_base, stack_size if
-       ! HAVE_XSI_STACK_OVERFLOW_HEURISTIC.
-       Add debug code.
-       Invoke die (rather than segv_action) to exit.
-       (c_stack_action): Accept new argv arg, and simpler handler arg.
-       All uses changed.  Move code into new functions above.
-       Allow null action.
-       [! (defined SA_ONSTACK && defined _SC_PAGESIZE)]: Assume all segvs
-       are stack overflows.
-       (main) [DEBUG]: Describe what output should be like.
-
-       * lib/c-stack.h (siginfo_t, c_stack_die): Remove decl.
-
-       * lib/file-type.c, lib/file-type.h: New files.  These contain code
-       that was in src/diff.c, but is now librarified and spiffed up a
-       bit.  Jim Meyering suggested this.
-
-       * lib/fnmatch.c (alloca, __builtin_expect): Define for non-GCC hosts.
-       <strings.h>: Include only if HAVE_STRINGS_H.
-       <stddef.h>: Include if we include stdlib.h.
-       Do not comment out all code if ! HAVE_FNMATCH_GNU.
-       (getenv): Do not declare if HAVE_DECL_GETENV.
-       (__strchrnul, __wcschrnul): Remove; not used.
-       (MEMPCPY): Use mempcpy if not _LIBC; use memcpy if neither _LIBC
-       nor HAVE_MEMPCPY.
-       (FOLD) [HANDLE_MULTIBYTE]: Do not pass wide char to ISUPPER.
-       (STRLEN, STRCAT, MEMPCPY) [HANDLE_MULTIBYTE && !defined _LIBC]:
-       Use wcslen rather than __wcslen, and likewise for wcscat, wmempcpy.
-       (MEMPCPY) [HANDLE_MULTIBYTE]: Use wmempcpy if not _LIBC; use wmemcpy
-       if neither _LIBC nor HAVE_WMEMPCPY.
-       * lib/fnmatch_.h (__const): Do not define to empty, as this breaks
-       Sun cc.  The code doesn't work with K&R anyway.
-       * lib/fnmatch_loop.c (struct patternlist.str): Size 1, not 0,
-       as C89 requires this.
-       (NEW_PATTERN): Use offsetof, not sizeof, since str now has size 1.
-       * lib/fnmatch_.h: Import from glibc fnmatch.h.
-       * lib/fnmatch.c, lib/fnmatch_loop.c: Import from glibc.
-
-       * lib/posixver.c: Include posixver.h.
-
-       * lib/regex_.h: Renamed from lib/regex.hin.
-
-       * m4/c-stack.m4 (jm_PREREQ_C_STACK): Do not AC_REQUIRE
-       jm_AC_TYPE_UINTMAX_T and do not use uintmax_t.
-       Check for sys/resource.h, uccontext.h.
-       Check for decls and existence of getcontext, sigaltstack.
-       Check for stack_t.
-
-       * m4/codeset.m4, m4/glibc21.m4, m4/lcmessage.m4: Remove.
-
-       * m4/fnmatch.m4: Update to latest Autoconf CVS for AC_FUNC_FNMATCH_GNU.
-       * m4/gnu-source.m4: Likewise, for AC_GNU_SOURCE (renamed from
-       AC__GNU_SOURCE).
-
-       * m4/mbstate_t.m4 (AC_TYPE_MBSTATE_T): Renamed from AC_MBSTATE_T.
-       All uses changed.  Upgrade to recent Autoconf CVS.
-
-       * m4/stdbool.m4 (AC_HEADER_STDBOOL): Do not cast pointer to
-       bool in integer constant expression; C99 does not allow it.
-       Reported by Bruno Haible.
-
-       * po/LINGUAS: Add hu, pt_BR.
-       * po/hu.po, po/pt_BR.po: New files.
-
-       * src/Makefile.am (noinst_HEADERS): Remove diff.h.
-       (DEFS): Remove.
-       (diff_sources): Add diff.h.
-       (MOSTLYCLEANFILES): New macro.
-       (cmp.$(OBJEXT) diff3.$(OBJECT) diff.$(OBJECT) sdiff.$(OBJECT)): Depend
-       on paths.h.
-       (paths.h): New rule.
-
-       * src/analyze.c, src/cmp.c, src/diff.c, src/diff3.c, src/io.c,
-       src/sdiff.c: Include <file-type.h>.
-
-       * src/cmp.c: Include paths.h.
-       (copyright_notice): Renamed from copyright_string.
-       Now a msgid, so that copyright symbol can be translated.
-       All uses changed.
-       * src/diff.c, src/diff3.c, src/sdiff.c: Likewise.
-
-       * src/diff.c: Include posixver.h.
-       (TABSIZE_OPTION): New constant.
-       (main): Allow widths up to SIZE_MAX.
-       (filetype): Move to lib/file-type.c and rename to file_type.
-       All uses changed.
-
-       * src/diff.c (longopts, main, usage): New option --tabsize=COLUMNS.
-       * src/io.c (find_and_hash_each_line): Likewise.
-
-       * src/diff.h (TAB_WIDTH): Remove.
-       (tabsize): New decl.
-       (sdiff_half_width, sdiff_column2_offset): Now size_t rather than
-       unsigned int.
-
-       * src/diff3.c (skipwhite, readnum): New functions.
-       (process_diff_control): Use them.
-       (SKIPWHITE, READNUM): Remove.
-       (read_diff): Don't worry about errno == ENOEXEC.
-
-       * src/sdiff.c (catchsig, signal_handler, initial_action): Signal
-       handlers return void, not RETSIGTYPE, since we no longer support
-       K&R.
-       (TABSIZE_OPTION): New constant.
-       (longopts, usage, main): New option --tabsize=COLUMNS.
-       (cleanup): New arg signo.  All uses changed.
-       (ck_editor_status, main, edit): Don't worry about ENOEXEC.
-
-       * src/side.c (tab_from_to, print_half_line, print_1sdiff_line):
-       New option --tabsize=COLUMNS.
-
-       * src/system.h (S_ISBLK, S_ISCHR, S_ISDIR, S_ISFIFO, S_ISREG,
-       S_ISSOCK): Remove; now in lib/file-type.h.
-
-       * src/util.c (finish_output): Check for ENOEXEC.
-       (lines_differ, output_1_line): New option --tabsize=COLUMNS.
-       (analyze_hunk): If -b or -w is also specified, -B now considers
-       lines to be empty if they contain only white space.
-
-2002-04-05  Paul Eggert  <eggert@sic.twinsun.com>
-
-       * NEWS, configure.ac (AC_INIT): Version 2.8.1.
-
-       * configure.ac (AC_HEADER_STDBOOL): Add.
-       (AC_CHECK_HEADERS): Remove stdbool.h.
-       * m4/stdbool.m4: New file.
-       * m4/prereq.m4 (jm_PREREQ_EXCLUDE):
-       Use AC_HEADER_STDBOOL rather than AC_CHECK_HEADERS(stdbool.h).
-       (jm_PREREQ_HASH): Likewise.
-
-       * src/system.h (SSIZE_MAX): Define if limits.h doesn't.
-
-       * src/analyze.c (diff_2_files): Assign PTRDIFF_MAX - 1 to a
-       size_t variable, just in case there's a problem with ptrdiff_t
-       versus size_t.
-
-       * lib/cmpbuf.c (errno): Remove decl; K&R C is no longer supported.
-       Include limits.h.
-       (SIZE_MAX, SSIZE_MAX): Define if standard headers don't.
-       (MIN): New macro.
-       (block_read): Do not attempt to read more than SSIZE_MAX bytes, as the
-       resulting behavior is implementation-defined.  Work around bug in
-       Tru64 5.1, which can't read more than INT_MAX bytes at a time.
-       * src/cmp.c (cmp): Use block_read instead of read, to work
-       around Tru64 5.1 bug.
-       * src/diff3.c (read_diff): Likewise.
-       * src/diff3.c: Include cmpbuf.h.
-
-       * THANKS: Add Ulrich Drepper.
-
-       * INSTALLME: Mention GNU texinfo.
-
-       * doc/diff.texi:
-       Use new @copying directive.
-       Put @contents first, not last, since Texinfo now suggests this.
-       Fix bug in -w documentation noted by Karl Berry.
-       Mention links for speedup.
-       New node "Speedups" for future speedups.
-       Just say "Index", not "Concept Index".
-
-2002-03-26  Paul Eggert  <eggert@twinsun.com>
-
-       * src/Makefile.am:
-       (INCLUDES): Remove this obsolete macro, replacing it with:
-       (AM_CPPFLAGS): New macro.
-
-2002-03-26  Albert Chin-A-Young  <china@thewrittenword.com>
-
-       * src/Makefile.am (datadir): Remove, as it conflicts with --datadir.
-
-2002-03-26  Paul Eggert  <eggert@twinsun.com>
-
-       * doc/diff.texi (dircategory GNU packages): Fix typo: a "* " was
-       missing before the menu entry.  Bug diagnosed by Adam Heath.
-       Also, put this dircategory after the Individual utilities dircategory,
-       to work around a compatibility problem with Debian install-info.
-
-2002-03-24  Eli Zaretskii  <eliz@is.elta.co.il>
-
-       * src/io.c (sip): Do not mishandle buffered count when reverting
-       to text mode.
-
-2002-03-23  Paul Eggert  <eggert@twinsun.com>
-
-       * NEWS, configure.ac (AC_INIT): Version 2.8.
-       * configure.ac (AC_PREREQ): 2.53.
-       * INSTALLME: Upgrade to gettext 0.11.1 and help2man 1.27.
-
-       * doc/diff.texi: Upgrade the description of `patch' to GNU patch
-       2.5.4, and revamp the documentation accordingly.
-
-       * src/diff.c (main): Fix typo that prevented diff -y from working.
-       Bug reported by Mitsuru Chinen.
-
-2002-03-15  Paul Eggert  <eggert@twinsun.com>
-
-       * lib/c-stack.c (c_stack_die) [!HAVE_SIGINFO_T]: Don't use info.
-       Bug reported by Eli Zaretskii.
-
-2002-03-15  Eli Zaretskii  <eliz@is.elta.co.il>
-
-       * ms/config.sed: Tweak editing of install-info-am target.
-
-2002-03-12  Paul Eggert  <eggert@twinsun.com>
-
-       * NEWS, configure.ac (AC_INIT): Version 2.7.10.
-
-       * NEWS: cmp -l -s and cmp -s -l are not allowed.
-       Deprecate diff -h, -H, -L, -P, --inhibit-hunk-merge.
-
-       * configure.ac (jm_PREREQ_HARD_LOCALE): Add.
-       (AM_INIT_AUTOMAKE): Do not distribute shar file.
-
-       * doc/diff.texi (Overview): byte != character.
-       (Detailed Context, Detailed Unified, Alternate Names, diff Options):
-       Do not document diff -L.
-       (Comparing Directories, Making Patches, diff Options):
-       Do not document diff -P.
-       (diff Performance, sdiff Option Summary, diff Options, sdiff Options):
-       Do not document diff -H.
-       (diff Performance, diff Options): Do not document --horizon-lines.
-       (cmp Options): Prefer -b to -c.
-       (cmp Options, diff Options, diff3 Options, patch Options,
-       sdiff Options): Put short options next to the similar long options.
-       Document --help, and use the same wording for --verbose.
-       (diff3 Options): Fix typo in description of -E, which used wrongly used
-       "-e" instead of "-E".
-
-       * lib/hard-locale.c (alloca): Remove.
-       Include stdlib.h if available, for malloc.
-       (hard_locale): Use malloc, not alloca, so that we need not worry about
-       alloca issues.  Test for storage allocation failure.
-
-       * m4/prereq.m4 (jm_PREREQ): Add jm_PREREQ_HARD_LOCALE.
-       (jm_PREREQ_HARD_LOCALE): New macro.
-
-       * src/cmp.c (specify_comparison_type): New function.
-       (check_stdout): "indices and codes" -> "byte numbers and values"
-       (main): Detect clashing options.
-       (cmp): Use "byte" rather than "char" if a translation for "byte"
-       is available, even when in the POSIX locale.
-
-       * src/diff.c (option_help_msgid): Do not document -L, -P,
-       --horizon-lines, --inhibit-hunk-merge, -H.
-       * src/diff.h: -L -> --label
-
-2002-03-11  Paul Eggert  <eggert@twinsun.com>
-
-       * NEWS, configure.ac (AC_INIT): Version 2.7.9.
-
-       * INSTALLME: Update to autoconf 2.53, automake 1.6, help2man
-       1.25 with patch.
-
-       * configure.ac (AC_INIT):
-       Change package name from diff to diffutils.
-       (AM_INIT_AUTOMAKE): Use new form, with option gnits,
-       rather than old from that duplicated AC_INIT.
-       (AM_MISSING_PROG): Add help2man.
-       (REGEX_MALLOC): Define.
-       (AC_CONFIG_FILES): Add man/Makefile.
-
-       * Makefile.am (AUTOMAKE_OPTIONS): Remove.
-       * doc/Makefile.am (AUTOMAKE_OPTIONS): Remove.
-       * lib/Makefile.am (AUTOMAKE_OPTIONS): Likewise.
-       * ms/Makefile.am (AUTOMAKE_OPTIONS): Likewise.
-       * src/Makefile.am (AUTOMAKE_OPTIONS): Likewise.
-
-       * lib/c-stack.c: Include <errno.h>
-       (ENOTSUP): Define if errno.h doesn't.
-       (SA_NODEFER, SA_ONSTACK, SA_RESETHAND, SA_SIGINFO, SIGSTKSZ,
-       _SC_PAGESIZE, ALTERNATE_STACK_SIZE, stack_t, sigaltstack):
-       Remove; we now assume them all when
-       HAVE_XSI_STACK_OVERFLOW_HEURISTIC, so we don't need
-       substitutes.
-       (<ucontext.h>): Include only if HAVE_XSI_STACK_OVERFLOW_HEURISTIC.
-       (alternate_signal_stack): Now of size SIGSTKSZ.
-       (segv_handler): Simplify, under the assumption that
-       HAVE_XSI_STACK_OVERFLOW_HEURISTIC is nonzero.
-       (c_stack_action): Likewise.
-       (exit_failure) [DEBUG]: Initialize to 0, not 1.
-       (recurse, main) [DEBUG]: Remove main args.
-
-       * m4/c-stack.m4 (AC_SYS_XSI_STACK_OVERFLOW_HEURISTIC): Change
-       wording of message.  Do not check for stdbool.h or ucontext.h,
-       or for ucontext_t or sigaction or sigaltstack.
-
-       * po/LINGUAS: Add zh_TW.
-
-       * Makefile.am (SUBDIRS): Add man.
-       * man/Makefile.am: New file.
-       * src/cmp.c (usage): Reword for help2man.
-       * src/diff.c (option_help_msgid): Likewise.
-       * src/diff3.c (option_help_msgid, usage): Likewise.
-       * src/sdiff3.c (option_help_msgid, usage): Likewise.
-       Reword for help2man.
-
-       * THANKS: Add email address for Tower.
-
-       * config/config.guess, config/config.sub, config/depcomp,
-       config/install-sh, config/mdate-sh, config/missing,
-       config/mkinstalldirs, config/texinfo.tex: Update
-       to recent version (maintained in other packages).
-
-2002-03-04  Bruno Haible <haible@ilog.fr>
-
-       * m4/gettext.m4 (AM_GNU_GETTEXT): Set LIBINTL and LTLIBINTL to empty if
-       no preinstalled GNU gettext was found.
-
-2002-03-02  Eli Zaretskii  <eliz@is.elta.co.il>
-
-       * ms/config.sed: Tweak editing of install-info-am and
-       uninstall-info-am targets, to include 8+3-butchered names of Info
-       files.
-
-2002-02-28  Paul Eggert  <eggert@twinsun.com>
-
-       * NEWS, configure.ac (AC_INIT, AM_INIT_AUTOMAKE): Version 2.7.8.
-
-       * doc/diff.texi: Add vr index.
-       Update copyright to 2002.
-       (Standards conformance): New chapter.
-       (Binary): Differing binary files are trouble unless the user asked for
-       brief output.
-       (Detailed Context): Prefer ISO time stamp format in discussion.
-       (Detailed Unified, Pagination): Likewise.
-       (Less Context): Likewise.  Also use short option.
-       (Alternate Names): Separate option from arg.
-       (Making Patches): Mention -U 2.
-       (diff Options): Deprecate -LINES, as POSIX 1003.1-2001 does not
-       allow it.
-
-       * INSTALLME: Update advice for Solaris installation problems.
-       We no longer use a test version of gettext.
-       Autoconf test version updated from 2.52f to 2.52h.
-       POSIX 1003.1-2001 patch for Automake.
-
-       * configure.ac (AC__GNU_SOURCE): Add this,
-       replacing AH_VERBATIM of _GNU_SOURCE.
-       (tempname): Use AC_LIBOBJS, not LIBOBJS=, as now required by autoconf.
-       (jm_PREREQ_C_STACK): Add.
-       (AC_CONFIG_FILES): Remove intl/Makefile.
-       (AM_GNU_GETTEXT): Add external arg, from gettext 0.11.
-
-       * lib/c-stack.c, lib/c-stack.h, lib/exitfail.c, lib/exitfail.h,
-       lib/posixver.c, lib/posixver.h, m4/c-stack.m4, m4/gnu-source.m4,
-       po/cs.po, po/ja.po: New files.
-
-       * intl/ChangeLog, intl/Makefile.in, intl/VERSION,
-       intl/bindtextdom.c, intl/config.charset, intl/dcgettext.c,
-       intl/dcigettext.c, intl/dcngettext.c, intl/dgettext.c,
-       intl/dngettext.c, intl/explodename.c, intl/finddomain.c,
-       intl/gettext.c, intl/gettextP.h, intl/gmo.h, intl/hash-string.h,
-       intl/intl-compat.c, intl/l10nflist.c, intl/libgnuintl.h,
-       intl/loadinfo.h, intl/loadmsgcat.c, intl/localcharset.c,
-       intl/locale.alias, intl/localealias.c, intl/localename.c,
-       intl/ngettext.c, intl/os2compat.c, intl/os2compat.h, intl/osdep.c,
-       intl/plural-eval.c, intl/plural-exp.c, intl/plural-exp.h,
-       intl/plural.c, intl/plural.y, intl/ref-add.sin, intl/ref-del.sin,
-       intl/textdomain.c, m4/isc-posix.m4, m4/libtool.m4: Remove.
-
-       * ABOUT-NLS: Update to Gettext 0.11.
-
-       * Makefile.am (SUBDIRS): Remove intl.
-
-       * config/config.guess, config/config.rpath, config/config.sub,
-       config/texinfo.tex, config/depcomp, config/texinfo.tex,
-       lib/tempname.c: Update to latest version from other packages.
-
-       * lib/xalloc.h (xalloc_exit_failure): Remove; subsumed by exit_failure.
-       * lib/xmalloc.c: Include exitfail.h.
-       (xalloc_exit_failure): Remove; subsumed by exit_failure.
-       All uses changed.
-
-       * lib/Makefile.am (noinst_HEADERS): Add c-stack.h, exitfail.h.
-       (libdiffutils_a_SOURCES): Add c-stack.c, exitfail.c, quotesys.c.
-       (INCLUDES): Remove.
-
-       * lib/cmpbuf.h (buffer_lcm): New arg LCM_MAX.
-       * lib/cmpbuf.c: Include errno.h.
-       (errno): Declare if !STDC_HEADERS.
-       Include signal.h.
-       (SA_RESTART): Define if not already defined.
-       Include <inttypes.h>.
-       (PTRDIFF_MAX): Define if not already defined.
-       (TYPE_SIGNED, TYPE_MINIMUM, TYPE_MAXIMUM): Likewise.
-       (block_read): Accommodate ancient AIX hosts that set errno to EINTR
-       after uncaught SIGCONT.
-       (buffer_lcm): Return a reasonable size if the multiple is too large.
-       New arg LCM_MAX.  All callers changed.
-
-       * lib/hard-locale.c: Include "hard-locale.h".
-       (hard_locale): Ignore ENABLE_NLS, since we want to operate on
-       locales other than LC_MESSAGES.
-
-       * m4/prereq.m4 (jm_PREREQ): Add jm_PREREQ_POSIXVER.
-       (jm_PREREQ_POSIXVER): New macro.
-
-       * m4/setmode.m4 (AC_FUNC_SETMODE_DOS):
-       Check for fcntl.h and unistd.h unconditionally.
-       Suggested by Bruno Haible.
-
-       * po/LINGUAS: Add cs, ja.
-       * po/POTFILES.in: Add lib/c-stack.c, src/dir.c.
-
-       * src/Makefile.am (datadir): @DATADIRNAME@ -> share.
-       (INCLUDES): Remove intl.
-       (LDADD): Change INTLLIBS to LIBINTL.
-       No longer need to link libdiffutils.a twice.
-
-       * src/analyze.c (diff_2_files):
-       Avoid arithmetic overflow in buffer size calculation.
-
-       * src/cmp.c: Include c-stack.h, exitfail.h.
-       (hard_locale_LC_MESSAGES): Depend on ENABLE_NLS.
-       (try_help, check_stdout, main, cmp): 2 -> EXIT_TROUBLE.
-       (main): Check for stack overflow.
-       0 -> EXIT_SUCCESS.
-       1 -> EXIT_FAILURE.
-       (cmp): Likewise.
-       Accommodate ancient AIX hosts that set errno to
-       EINTR after uncaught SIGCONT.
-
-       * src/context.c (pr_context_hunk):
-       Do not dump core if an enormous context causes an
-       arithmetic overflow.
-       (pr_unidiff_hunk): Likewise.
-       (find_hunk): Likewise.
-
-       * src/diff.h: unsigned -> unsigned int.
-       * src/diff.c: Include c-stack.h, exitfail.h.
-       Do not include signal.h.
-       (specify_style, specify_value): Bring these routines back, as POSIX
-       requires that the order of options not matter.
-       (shortopts): New constant.
-       (group_format_option, line_format_option): New constants.
-       (main): 0 -> EXIT_SUCCESS, 1 -> EXIT_FAILURE, 2 -> EXIT_TROUBLE.
-       Ensure that order of options does not matter.
-       Check for stack overflow.
-       If contexts overflow, substitute LIN_MAX, as that's good enough.
-       If multiple contexts are specified, use their maximum.
-       -c is equivalent to -C 3 now, instead of having an implicit context;
-       likewise for -u and -U 3.
-       Use specify_style and specify_value.
-       (SIGCHLD): Do not define; now done in a header.
-       Use new style time stamp format for -u / -U.
-       Reject numeric-string options if operating in POSIX 1003.1-2001 mode.
-       Avoid overflow problems with tab width.
-       Simplify from-file and to-file code.
-       (usage): Do not mention obsolete options.
-       (filetype): Do not mention whether a file is executable.
-       Add typed memory objects.
-       (compare_files): 0 -> EXIT_SUCCESS, 1 -> EXIT_FAILURE, 2 ->
-       EXIT_TROUBLE.
-
-       * src/diff3.c: Include c-stack.h, exitfail.h.
-       (ALLOCATE): Remove.  All uses changed to xmalloc, or to xmalloc plus
-       an overflow check.
-       (myread): Remove.
-       (main): Check for stack overflow.
-       0 -> EXIT_SUCCESS, 1 -> EXIT_FAIULRE, 2 -> EXIT_TROUBLE.
-       (try_help): Likewise.
-       (process_diff): Check for integer overflow, to avoid core dumps.
-       2 -> EXIT_TROUBLE.
-       (read_diff): Exit with status 126 if the file is not executable,
-       for compatibility with POSIX 1003.1-2001.
-       Accommodate ancient AIX hosts that set errno to EINTR after uncaught
-       SIGCONT.
-       Check for integer overflow to avoid core dumps.
-       (fatal, perror_with_exit): 2 -> EXIT_TROUBLE.
-
-       * src/dir.c (dir_read):
-       Ignore st_size of directories: POSIX says it's garbage.
-       Check for integer overflow to avoid core dumps.
-       (diff_dirs): 0 -> EXIT_SUCCESS, 2 -> EXIT_TROUBLE.
-
-       * src/ifdef.c: Include <xalloc.h>.
-       (format_group, print_ifdef_lines): Avoid core dumps with bad formats.
-       (do_printf_spec): Avoid alloca.
-
-       * src/io.c (sip):
-       Avoid integer overflow and core dumps if buffer alignments are
-       preposterously incompatible.
-       (slurp): Do not dump core if the file is growing as we read it.
-       If a regular file grows, keep reading until we catch up with its EOF.
-       (find_and_hash_each_line): Check for integer overflow to avoid cores.
-       (GUESS_LINES): Remove.
-       (guess_lines): New function.  Avoid integer overflow.
-       (find_identical_ends): Use it.
-       Avoid integer overflow and possible core dumps.
-
-       * src/sdiff.c: Include c-stack.h, exitfail.h.  Do not include signal.h.
-       0 -> EXIT_SUCCESS, 1 -> EXIT_FAILURE, 2 -> EXIT_TROUBLE.
-       (ck_editor_status): New function.
-       (main): Check for stack overflow.
-       Adopt POSIX convention for subsidiary programs not found.
-       (diffarg): Check for integer overflow to avoid core dumps.
-       (trapsigs): Remove SA_INTERRUPT special case; now done by header.
-       (SIGCHLD): Likewise.
-       (edit): Adopt POSIX convention for subsidiary programs not found.
-
-       * src/side.c: unsigned -> unsigned int.
-
-       * src/system.h: Don't use alloca or include <alloca.h>.
-       unsigned -> unsigned int
-       (EXIT_SUCCESS, EXIT_FAILURE, EXIT_TROUBLE): Define if not defined.
-       Include signal.h.
-       (SA_RESTART): Define if not defined.
-       (SIGCHLD): Likewise.
-
-       * src/util.c: 2 -> EXIT_TROUBLE.
-       Adopt POSIX convention for ENOEXEC and exit status 126.
-       unsigned -> unsigned int
-
-2002-01-24  Paul Eggert  <eggert@twinsun.com>
-
-       * NEWS, configure.ac (AC_INIT, AM_INIT_AUTOMAKE): Version 2.7.7.
-
-       * intl/plural.c: Regenerate with Bison 1.31.
-
-       * ABOUT-NLS, intl/*: Update to Gettext 0.11-pre5++.
-       * INSTALL: Update to Autoconf 2.52f.
-
-       * INSTALLME: New file.
-       * Makefile.am (EXTRA_DIST): Add config/config.rpath, INSTALLME.
-       (DISTCLEANFILES): Remove.
-       * NEWS: Reformat for imminent 2.8 release.
-       * README: Mention INSTALLME.
-       * README-alpha: Move most of contents to INSTALLME.
-       * THANKS: Add Bruno Haible, Jim Meyering, and Eli Zaretskii.
-
-       * config: New subdirectory, containing the following files from .:
-       config.guess, config.sub, depcomp, missing, install-sh, mkinstalldirs.
-       Move the following files here from doc: texinfo.tex, mdate-sh.
-       * config/config.guess, config/config.sub, config/texinfo.tex:
-       Update to latest version from FSF.
-       * config/config.rpath: New file, from Gettext 0.11-pre5++.
-
-       * configure.ac (AC_INIT): Use new 3-arg form.
-       (AC_CONFIG_SRCDIR): Specify src/diff.c here, not in AC_INIT.
-       (ALL_LINGUAS): Remove: now in po/LINGUAS as per Gettext 0.11.
-       (AC_CONFIG_AUX_DIR): New macro invocation.
-
-       * lib/Makefile.am (noinst_HEADERS): Add gettext.h.
-       * lib/gettext.h: New file, from Gettext 0.11-pre5++.
-       * lib/prepargs.c: Include <string.h>.  Reported by Bruno Haible.
-
-       * m4/codeset.m4, m4/gettext.m4, glibc21.m4, iconv.m4, isc-posix.m4,
-       lcmessage.m4, progtest.m4: Upgrade to Gettext 0.11-pre5++.
-       * m4/lib-ld.m4, m4/lib-link.m4, m4/lib-prefix.m4: New files, from
-       Gettext 0.11-pre5++.
-
-       * po/LINGUAS: New file.
-       * po/Makefile.in.in: Upgrade to Gettext 0.11-pre5++.
-       * po/Makevars, po/Rules-quot, po/boldquot.sed: New files,
-       from Gettext 0.11-pre5++.
-
-       * src/cmp.c (copyright_string): Update to 2002.
-       * src/diff.c (copyright_string): Likewise.
-       * src/diff3.c (copyright_string): Likewise.
-       * src/sdiff.c (copyright_string): Likewise.
-
-       * src/cmp.c (specify_ignore_initial): Renamed from
-       parse_ignore_initial, with different signature, to take the
-       maximum of multiple options rather than the last one.
-       All uses changed.
-
-       * src/cmp.c (bytes, specify_ignore_initial, cmp): Use UINTMAX_MAX
-       instead of (uintmax_t) -1, to avoid warnings on some compilers.
-       * src/io.c (file_block_read): Likewise, for SIZE_MAX.
-
-       * src/cmp.c (usage): Reformat messages to ease translation.
-       * src/diff3.c (usage): Likewise.
-       * src/sdiff.c (usage): Likewise.
-
-       * src/cmp.c (main): Two files with the same name are identical
-       only if the same offset is specified.
-       (block_compare_and_count): Avoid cast to unsigned char.
-
-       * src/diff3.c (main): Remove unused variable.
-
-       * src/dir.c: Include <setjmp.h>
-       (struct dirdata): New member nnames.
-       (locale_specific_sorting, failed_strcoll): New vars.
-       (dir_read): Renamed from dir_sort.  Don't sort the dir.
-       Set new nnames member of struct dirdata.  All callers changed.
-       (compare_names): Don't check for errno after strcasecmp.
-       Use strcoll only if locale_specific_sorting is nonzero.
-       If strcoll fails, longjmp out rather than returning a value
-       that might result in an invalid comparison function that might
-       make qsort dump core.
-       (diff_dirs): Sort the directory ourselves.  Use setjmp to recover
-       from strcoll failure, falling back on native byte comparison.
-       Make local variables volatile if they need to preserve their value
-       after setjmp/longjmp.
-
-       * src/sdiff.c (handler_index_of_SIGINT, handler_index_of_SIGPIPE):
-       New macros.
-       (main): Do not confuse signal numbers with their indices.
-       Bug reported by Bruno Haible.
-       (edit): Cat lin to long before printing with %ld, since lin might
-       be narrow than long.
-
-       * src/system.h (UINTMAX_MAX): New macro.
-       Include gettext.h, not libgettext.h.
-       (N_): Do not wrap arg in parentheses.  Fix from Bruno Haible.
-
-       * src/util.c (finish_output): Ensure that werrno is initialized.
-       (lines_differ): Have an explicit do-nothing case for
-       IGNORE_NO_WHITE_SPACE, to pacify gcc -Wall.
-
-2001-12-29  Eli Zaretskii  <eliz@is.elta.co.il>
-
-       * src/sdiff.c (interact): After extracting rlen from the editor
-       command, test for a terminating null character, not for a newline.
-
-       * ms/config.bat: Allow longer source directory names without
-       overflowing the line length limits.  Create the cache in the
-       build directory, not in the source directory
-       * ms/config.sed: Fix AC_CONFIG_LINKS for when symlinks are
-       unavailable.
-
-2001-12-23  Paul Eggert  <eggert@twinsun.com>
-
-       * NEWS, configure.ac (AM_INIT_AUTOMAKE): Version 2.7.6.
-
-       * configure.ac (ALL_LINGUAS): Add tr.
-
-       * src/util.c (begin_output):
-       Have child exit with status 127 rather than reporting
-       failure on its own.  Set errno to 0 before invoking popen.
-       (finish_output): Report errno on pclose failure.
-       Distinguish between subsidiary program not found, and failure.
-
-       * src/sdiff.c (not_found, execdiff): Remove.
-       (DIFF_PROGRAM_OPTION): New constant.
-       (longopts, option_help_msgid, main): Add --diff-program=PROGRAM.
-       (check_stdout): New function.
-       (main): Remove DIFF_PROGRAM.  Check stdout after printing version.
-       Use check_stdout after printing help.  Use execvp/perror_fatail rather
-       than execdiff.  Set errno to 0 before invoking popen.
-       Check for pclose failure properly.
-       (main, edit): If child exec fails, exit with 127 rather than trying to
-       print diagnostic.
-       Distinguish between subsidiary program failing and not being found.
-       (edit): Handle signals the same way, regardless of whether we're using
-       system or fork+exec.  Check for system returning -1.
-
-       * src/diff3.c (DIFF_PROGRAM_OPTION, HELP_OPTION): New constants.
-       (longopts, main): Use them.
-       (longopts, main, option_help_msgid): New option --diff-option=PROGRAM.
-       (main): Remove DIFF_PROGRAM support.
-       Check stdout after printing version.
-       (check_stdout): Report errno info if fclose fails.
-       (read_diff): Have child exit with status 127 when program is not found,
-       rather than trying to have the child report failure.  Check for
-       pclose returning -1.
-
-       * src/diff.c (DEFAULT_WIDTH): Remove.
-       (main): Use 130 instead of DEFAULT_WIDTH, since it's not really
-       builder-settable.  Do not prepend DIFF_OPTIONS.
-       (check-stdout): If fclose (stdout) fails, print errno info.
-       (option_help_msgid): Default context is 3, not 2.
-       (usage): Work even if ptrdiff_t is wider than int.
-
-       * doc/diff.texi (diff Options): Remove DIFF_OPTIONS.
-       (Invoking diff3, Invoking sdiff): Remove DIFF_PROGRAM.
-       (diff3 Options, sdiff Options): Add --diff-program.
-
-       * src/cmp.c (valid_suffixes):
-       Add '0', to support suffixes like "MB" and "MiB".
-       (check_stdout): Don't assume that the translations of "write failed"
-       and of "standard output" lack '%'.
-       (main): Check stdout after printing version.
-
-       * lib/setmode.c: [HAVE_FCNTL_H && HAVE_SETMODE_DOS]: Include <fcntl.h>.
-       [!HAVE_SETMODE_DOS]: Do not include <unistd.h>.
-       (set_binary_mode): Return mode (not 1) if fd is a tty.
-       Do not assume that O_TEXT is zero.
-
-       * doc/diff.texi (cmp Options):
-       In byte counts, a plain suffix (without any integer)
-       is assumed to modify the integer 1.  Index terms like "kibibyte".
-       Document plain "k".
-
-       (Reporting Bugs): Mention bug-report archive and test version
-       location.  Ask for "diff --version" in bug reports.
-
-2001-12-13  Paul Eggert  <eggert@twinsun.com>
-
-       * src/diff.c (DEFAULT_WIDTH): Remove; couldn't be changed without
-       also changing option_help_msgid.  All uses replaced with 130.
-
-       * lib/setmode.c: Include fcntl.h and unistd.h only if
-       HAVE_SETMODE_DOS.
-       (setmode): Assume a file is binary unless the mode is O_TEXT.
-       * ms/README: Fix minor typos.
-
-2001-12-13  Eli Zaretskii  <eliz@is.elta.co.il>
-
-       * ms/README: New file.
-
-       * lib/setmode.c (set_binary_mode) [HAVE_SETMODE_DOS]: Don't assume
-       O_TEXT has a zero value.  If FD is a terminal device, do nothing
-       and return MODE, thus pretending that it was already in the
-       requested MODE.
-       [HAVE_FCNTL_H]: Include fcntl.h (needed for O_BINARY).
-
-       * ms/config.sed: Remove the split prevention of config.status.
-       Fix Sed commands for converting absolute file names into
-       top_srcdir-relative ones.
-
-       * ms/config.bat: Fix typos.
-
-2001-12-12  Neal H Walfield  <neal@cs.uml.edu>
-
-       * diff.c (option_help_msgid): Correct the default context width
-       from 2 to 3.
-
-2001-12-11  Paul Eggert  <eggert@twinsun.com>
-
-       * m4/Makefile.am.in: Remove jm-glibc-io.m4
-
-       * NEWS, configure.ac (AM_INIT_AUTOMAKE): Version 2.7.5.
-
-       * configure.ac (PR_PROGRAM): Use AC_DEFINE_UNQUOTED, so that
-       $PR_PROGRAM is expanded by sh.
-       (ptrdiff_t, ssize_t): Use AC_CHECK_TYPE with a default of int,
-       not AC_CHECK_TYPES.
-       (jm_AC_DOS, AC_FUNC_SETMODE_DOS): New macros.
-       (AC_CONFIG_FILES): Add ms/Makefile.
-
-       * doc/diff.texi: Add --no-ignore-file-name-case.
-       File name case sensitivity now affects file name exclusion.
-       Fix typos.
-
-       * src/util.c: Include dirname.h.
-       (dir_file_pathname): Use base_name rather than file_name_lastdirchar.
-
-       * src/system.h (S_IXUSR, S_IXGRP, S_IXOTH): New macros.
-       Include <libgettext.h> rather than rolling it ourselves.
-       (file_name_lastdirchar, HAVE_SETMODE, set_binary_mode): Remove.
-
-       * src/sdiff.c: Include <dirname.h>.
-       (expand_name): Use base_name rather than file_name_lastdirchar, for
-       portability to DOS.
-       (main): Initialize xalloc_exit_failure before possibly invoking
-       any memory allocator.
-
-       * src/io.c: Include setmode.h.
-
-       * src/diff3.c (main):
-       Initialize xalloc_exit_failure before possibly invoking any memory
-       allocator.
-
-       * src/diff.c: Include dirname.h, setmode.h.
-
-       (main): Later values and/or styles now silently override earlier.
-       (specify_value, specify_style): Likewise.  All callers changed.
-       Remove.
-       (binary, main, option_help_msgid, compare_files):
-       HAVE_SETMODE -> HAVE_SETMODE_DOS.
-       (NO_IGNORE_FILE_NAME_CASE_OPTION): New constant.
-       (longopts, main, option_help_msgid): Support it.
-       (exclude_options): New function.
-       (main): Use it. Initialize xalloc_exit_failure before potentially
-       allocating memory.
-
-       (filetype): Distinguish executable files from others, as POSIX
-       suggests.
-
-       (compare_files): Use base_name instead of file_name_lastdirchar.
-
-       * src/cmp.c: Include <hard-locale.h>, <setmode.h>.
-       (hard_locale_LC_MESSAGES): New macro.
-       (sprintc): Remove int width arg; it's now the caller's responsibility
-       to pad.  All callers changed.
-       (stat_buf): New static var; was formerly a local var in 'main'.
-       (valid_suffixes): Add 'K', for 'KiB'.
-       (option_help_msgid): Don't confuse bytes with characters.
-       (main): Set xalloc_exit_failure before invoking anything that might
-       allocate memory.  Fix bug: -n was incorrectly ignored when optimizing
-       the case of regular files with different lengths.
-       (cmp): Use an index column wide enough to store this comparison's
-       indexes.  In locales other than the POSIX locale, say "byte"
-       rather than "char".
-
-       * ms/config.bat: pc -> ms
-
-       * ms/Makefile.am, m4/setmode.m4, lib/setmode.c, lib/setmode.h:
-       New file.
-
-       * lib/Makefile.am (noinst_HEADERS): Add dirname.h, setmode.h.
-       (libdiffutils_a_SOURCES): Add basename.c, setmode.c.
-
-       * Makefile.am (SUBDIRS): Add ms.
-
-2001-12-10  Paul Eggert  <eggert@twinsun.com>
-
-       * m4/fnmatch.m4: Test for FNM_CASEFOLD.
-
-2001-12-03  Paul Eggert  <eggert@twinsun.com>
-
-       * lib/posix/regex.h: Fix copyright notice.
-
-2001-12-03  Paul Eggert  <eggert@twinsun.com>
-
-       * NEWS, configure.ac (AM_INIT_AUTOMAKE): Version 2.7.4.
-
-       * diff.texi (direntry, Overview, Comparison, Binary, Invoking cmp):
-       Use "byte" rather than "character" when talking about cmp, since
-       it compares bytes, not character.
-       (Invoking cmp): New trailing operands FROM-SKIP and TO-SKIP.
-       -i or --ignore-initial now accepts FROM-SKIP:TO-SKIP.
-       New option -n or --bytes.
-       Count operands now may be in octal or hex, and may be followed by a
-       size multiplier.
-
-       * configure.ac (DEFAULT_DIFF_PROGRAM):
-       Define to "diff", not "$bindir/diff" (which didn't work anyway).
-       (AC_CHECK_MEMBERS): Add struct stat.st_blksize, struct stat.st_rdev.
-       (AC_STRUCT_ST_BLKSIZE, AC_STRUCT_ST_RDEV): Remove; obsolescent.
-       (AC_FUNC_FORK): Use this, instead of obsolescent AC_FUNC_VFORK.
-       (AC_CONFIG_FILES, AC_CONFIG_COMMANDS): Add.
-       (AC_OUTPUT): Remove args; they were obsolescent.
-
-       * util.c (setup_output, begin_output, finish_output):
-       HAVE_FORK -> HAVE_WORKING_FORK || HAVE_WORKING_VFORK.
-       * sdiff.c (diffpid, cleanup, main, edit): Likewise.
-       * diff3.c (read_diff): Likewise.
-
-       * system.h (STAT_BLOCKSIZE):
-       Use HAVE_STRUCT_STAT_ST_BLKSIZE, not HAVE_ST_BLKSIZE.
-       (vfork): New macro.
-       (HAVE_FORK): Remove.
-       (set_binary_mode): New macro.
-
-       * sdiff.c (main): HAVE_VFORK -> HAVE_WORKING_VFORK.
-       (edit): Reopen the temporary file after the editor has run, in case
-       the editor operates by unlinking the old file and linking a new one.
-       (P_tmpdir): Rename from PVT_tmpdir; this fixes a typo.
-       All uses changed.
-
-       * io.c (sip, read_files):
-       Remove tests for HAVE_SETMODE; use set_binary_mode
-       instead of setmode.
-       (sip): Fix typo in backward lseek when reverting to text mode.
-
-       * config.site, config.sed, config.bat: New file.
-
-       * Makefile.am (EXTRA_DIST): Add xstrtol.c.
-       (noinst_HEADERS): Add xstrtol.h.
-       (libdiffutils_a_SOURCES): Add xstrtoumax.c.
-
-       * cmp.c: <xstrtol.h>: Include.
-       (ignore_initial): Now an array with 2 elements.  All uses changed.
-       (bytes): New var.
-       (HELP_OPTION): New constant.
-       (long_options, main): Use it.
-       (long_options, option_help_msgid, main, cmp):
-       Add support for -n or --bytes.
-       (parse_ignore_initial): New function.
-       (option_help_msgid, main): Add -i M:N.
-       (usage, main): Add two optional trailing operands, a la BSD.
-       (main): setmode -> set_binary_mode.
-       (cmp): Report byte number of what we've seen, not of the entire file.
-       This is to be consistent with the line number, which is always relative
-       with what we've seen.
-
-2001-12-02  Paul Eggert  <eggert@twinsun.com>
-
-       * diff.c (main, compare_files): setmode -> set_binary_mode.
-
-       * xstrtol.c (__xstrtol): Don't accept 'Ki'; require 'KiB'.
-
-       * xstrtol.c (__xstrtol): Add support for IEC 60027-2.
-
-2001-11-25  Paul Eggert  <eggert@twinsun.com>
-
-       * NEWS, configure.ac (AM_INIT_AUTOMAKE): Version 2.7.3.
-
-       * README-alpha: New file.
-
-       * src/Makefile.am (INCLUDES): Add -I../lib, for regex.h.
-
-       * configure.ac:
-       Don't set LIB_CLOCK_GETTIME to 'none required'; set it to
-       the empty string instead.
-
-       * lib/Makefile.am (EXTRA_DIST): Add strtoimax.c, strtol.c.
-
-       * Makefile.am (SUBDIRS): Put intl before lib, so that libintl.h exists.
-
-       * lib/Makefile.am (noinst_HEADERS): Add unlocked-io.h.
-
-       * configure.ac (__EXTENSIONS__): New define, for the unlocked macros.
-
-       * README: Add copyright notice.
-       Remove stuff that doesn't apply any more.
-
-       * doc/diff.texi: offsets -> indices for cmp
-
-       * src/cmp.c (option_help_msgid): offsets -> indices
-
-       * src/diff.c (option_help_msgid):
-       Don't mention --binary on POSIX hosts.
-
-       * src/sdiff.c (STRIP_TRAILING_CR_OPTION): New constant.
-       (longopts, option_help_msgid, main): Add -E, --ignore-tab-expansion,
-       --strip-trailing-cr.
-
-       * doc/diff.texi: Change direcategory from Utilities to GNU Packages.
-       Add individual utilities.
-       Switch to Free Documentation License.
-       @code -> @command
-       @samp -> @option
-       GNU -> @sc{gnu}
-       Expand tabs to spaces, except when in an example that actually
-       uses tabs.
-       Prefer @node with just one arg.
-       Document -E or --ignore-tab-expansion, --strip-trailing-cr,
-       --ignore-file-name-case.
-       Regular expressions are now grep style, not Emacs style.
-       cmp's -c or --print-chars option is now -b or --print-bytes.
-       Time stamps now depend on LC_TIME.
-       -p now implies ^[[:alpha:]$_].
-       Flags now include ' and 0.
-       cmp -i is an alias for --ignore-initial
-       Document --from-file, --to-file.
-       Document DIFF_OPTIONS.
-
-       * configure.ac (AC_CHECK_FUNCS): Add gettimeofday, clock_gettime.
-       (LIB_CLOCK_GETTIME): New subst.
-
-       * src/system.h: Assume C89 or better.
-       (_GNU_SOURCE): Remove; config.h now defines it.
-       (alloca): Declare like coreutils does it.
-       (verify, TYPE_SIGNED, TYPE_MINIMUM, TYPE_MAXIMUM, O_RDWR,
-       S_IRUSR, S_IWUSR): New macros.
-       (STAT_BLOCKSIZE): Parenthesize definiens.
-       <inttypes.h>: Include if HAVE_INTTYPES_H.
-       (CHAR_MAX, INT_MAX): Remove.
-       (PTRDIFF_MAX, SIZE_MAX): New macros.
-       (strtoumax): New decl.
-       Include stddef.h.
-       (bzero): Remove.
-       (bindtextdomain, textdomain, N_): New macros.
-       (ISPRINT, ISSPACE): Remove ifndef wrappers.
-       (ISUPPER, ISDIGIT): Remove.
-       (TOLOWER): New macro.
-       (MIN): Renamed from min; all callers changed.
-       (MAX): Likewise, from max.
-       (lin): New type.
-       (LIN_MAX): New macro.
-       (file_name_cmp): Renamed from filename_cmp.  All callers changed.
-       (file_name_lastdirchar): Renamed from file_name_lastdirchar.
-       All callers changed.
-       (could_be_mvfs_stat_bug, could_be_nfs_stat_bug,
-       dev_may_have_duplicate_ino): Remove.
-       (HAVE_SETMODE, NULL_DEVICE): New macros.
-       (same_file): Do not check attributes.
-       (same_file_attributes): New macro.
-
-       * src/util.c: Assume C89 or better.
-       int -> bool for booleans.
-       int -> lin for line numbers.
-       int -> size_t for sizes.
-       Use angle-brackets when including quotesys.h.
-       Include error.h, regex.h, xalloc.h.
-       (message5): sizeof -> offsetof
-       (begin_output): Invoke pr without -f.
-       (lines_differ): Renamed from line_cmp, and return bool not 3-way int.
-       All callers changed.
-       Add support for IGNORE_TAB_EXPANSION.
-       (change_letter): Now an array rather than a function.  All
-       callers changed.
-       (translate_range): Translate line numbers to long, not lin,
-       for convenience with printf.
-       (analyze_hunk): Return enum changes instead of a count of
-       inserts and deletes.  All callers changed.
-       (zalloc): New function.
-
-       * src/side.c: Assume C89 or better.
-       int -> bool for booleans.
-       int -> lin for line numbers.
-
-       * src/sdiff.c: Assume C89 or better.
-       int -> bool for booleans.
-       int -> lin for line numbers.
-       Use angle-brackets when including getopt.h, quotesys.h.
-       Include error.h, freesoft.h, stdio.h, xalloc.h.
-       (copyright_string): Use only most recent year.
-       (authorship_msgid, option_help_msgid): Wrap in N_().
-
-       (tmpname): Now volatile.
-       (tmpmade): Remove.
-       (tmp): New var.
-       (private_tempnam, exists, letters): Remove.
-       (temporary_file): New function.
-       (edit): Use it.
-       (interact): Use strtoumax, not atoi.
-
-       * src/normal.c: Assume C89 or better.
-       int -> lin for line numbers.
-
-       * src/io.c: Assume C89 or better.
-       int -> bool for booleans.
-       int -> lin for line numbers.
-       int -> size_t for sizes.
-       Use angle-brackets when including cmpbuf.h.
-       Include regex.h, xalloc.h.
-       (word): Remove; now done in system.h.
-       (hash_value): New type; use it instead of 'unsigned' for hash values.
-       (file_block_read): New function.
-       (sip, slurp): Use it.  Now static.
-       (sip): Ensure block size is a multiple of word size.  Clear eof flag.
-       (slurp): Use xalloc_die to report memory exhaustion.
-       (find_and_hash_each_line): Use TOLOWER instead of _tolower.
-       Add support for IGNORE_TAB_EXPANSION.
-       (prepare_text_end): Strip trailing CR if requested.
-       (find_identical_ends): Prepare the text only once,
-       if they're duplicates.
-       Let the compiler take advantage more of the fact that the buffers are
-       word-aligned.
-       (primes): Remove.
-       (prime_offset): New var.
-       (read_var): Use prime_offset instead of primes.
-       Use zalloc instead of xmalloc + bzero.
-
-       * src/ifdef.c: Assume C89 or better.
-       int -> lin for line numbers.
-       (format_group): Use strtoumax to parse line numbers.
-       (format_group, print_ifdef_lines): Use do_printf_spec to
-       handle printf specs.
-       (groups_letter_value): Don't use _tolower; it's locale-dependent.
-       (do_printf_spec): Renamed from scan_printf_spec; now does the printing.
-
-       * src/ed.c: Assume C89 or better.
-       int -> lin for line numbers (or 'long' when that's more convenient).
-       (print_ed_hunk): Fix bug when handling double-dot inserts.
-
-       * src/dir.c: Assume C89 or better.
-       int -> bool for booleans.
-       Include error.h, exclude.h, xalloc.h.
-
-       (dir_sort): Return 0 on error, 1 on success.  All callers changed.
-       compare_names -> compare_names_for_qsort.
-
-       (compare_names): Try strcasecmp if ignore_file_name_case.  Then try
-       strcoll.  Use file_name_cmp only as a last resort.  Warn about
-       strcasecmp or strcoll failure.
-       (compare_names_for_qsort): New function.
-
-       (diff_dirs): Use compare_names rather than filename_cmp.
-
-       * src/diff3.c: Assume C89 or better.
-       int -> bool for booleans.
-       int -> lin for line numbers.
-       Use angle-brackets when including getopt.h, quotesys.h.
-       Include error.h, freesoft.h, inttostr.h, xalloc.h.
-       (copyright_string): Use only most recent year.
-       (authorship_msgid, option_help_msgid): Wrap in N_().
-
-       Rename the following variables for consistency with user-visible
-       option spellings.  All uses changed.
-       (text): Renamed from always_text.
-       (initial_tab): Renamed from tab_align_flag.
-
-       (horizon_lines): Remove.  Remove all uses.
-
-       (main): Invoke bindtextdomain and textdomain after setlocale.
-       Rename "DIFF" to "DIFF_PROGRAM".
-
-       Try to compare file0 to file1, because this is where changes are
-       expected to come from.  Diffing between these pairs of files is more
-       likely to avoid phantom changes from file0 to file1.
-       However, use file2 as the common file if this is a 3-way diff,
-       for backward compatibility.  Suggested by Karl Tomlinson.
-
-       (create_diff3_block): Use xcalloc instead of malloc + bzero.
-
-       (INT_STRLEN_BOUND): Remove; now in system.h.
-
-       (read_diff): Always use --horizon-lines=100 rather than trying
-       to guess it.
-       Do not pass --inhibit-hunk-merge.
-       Minimum chunk size is 1, not 8KiB.
-       Use xalloc_die to report memory exhaustion.
-       (undotlines): Use long for start, not int.
-
-       * src/diff.h: Assume C89 or better.
-       int -> bool for booleans.
-       int -> lin for line numbers.
-       Don't include regex.h.
-       (enum changes): New enum.
-       (enum line_class): Remove; subsumed by enum changes.
-       (enum output_style): New constant OUTPUT_UNSPECIFIED.
-
-       (ignore_space_change_flag, ignore_all_space_flag): Remove.
-       (ignore_white_space): New decl, subsuming the above two.  All
-       uses changed.
-
-       Rename the following decls for consistency with user-visible
-       option spellings.  All uses changed.
-       (text): Renamed from always_text_flag.
-       (ignore_blank_lines): Renamed from ignore_blank_lines_flag.
-       (ignore_case): Renamed from ignore_case_flag.
-       (brief): Renamed from no_details_flag.
-       (initial_tab): Renamed from tab_align_flag.
-       (expand_tabs): Renamed from tab_expand_flag.
-       (starting_file): Renamed from dir_start_file.
-       (paginate): Renamed from paginate_flag.
-       (sdiff_merge_assist): Renamed from sdiff_help_sdiff.
-       (left_column): Renamed from sdiff_left_only.
-       (suppress_common_lines): Renamed from sdiff_skip_common_lines.
-       (speed_large_files): Renamed from heuristic.
-       (minimal): Renamed from no_discards.
-
-       (inhibit_hunk_merge): Remove.
-
-       (strip_trailing_cr, excluded, time_format): New decls.
-
-       (files_can_be_treated_as_binary): Renamed from ignore_some_changes.
-
-       (group_format, line_format): Now char const *[], not char *[].
-
-       (struct file_data): Buffer is now word*, not char*, as it's always
-       aligned and this can help the compiler.  buffered_chars -> buffered
-       (since it's a byte count, not a char count).  All uses changed.
-       New member `eof'.
-
-       (FILE_BUFFER): New macro.
-
-       (excluded_filename, error, free_software_msgid): Remove decls; now in
-       other .h files.
-
-       (sip, slurp): Remove decls.
-       (file_block_read): New decl.
-       (change_letter): Now an array, not a function.
-       (lines_differ): Renamed from line_cmp.
-       (analyze_hunk): Now returns enum changes rather than two change counts.
-
-       * src/Makefile.am (diff_LDADD): New symbol.
-
-       * src/diff.c: Assume C89 or better.
-       int -> bool for booleans.
-       long -> off_t for line numbers.
-       Use angle-brackets when including getopt.h, fnmatch.h, quotesys.h.
-       Include error.h, exclude.h, freesoft.h, hard-locale.h, prepargs.h,
-       regex.h, signal.h, xalloc.h.
-       (copyright_string): Use only most recent year.
-       (authorship_msgid, option_help_msgid): Wrap in N_().
-
-       Rename the following variables for consistency with user-visible
-       option spellings.  All uses changed.
-       (binary): Renamed from binary_flag.
-       (new_file): Renamed from entire_new_file_flag.
-       (unidirectional_new_file): Renamed from unidirectional_new_file_flag.
-       (report_identical_files): Renamed from print_file_same_flag.
-
-       (numeric_arg): Remove.
-
-       (exclude, exclude_alloc, exclude_count, excluded_filename, add_exclude,
-       add_exclude_file):
-       Remove; now done by exclude.h.
-
-       (BINARY_OPTION, FROM_FILE_OPTION, HELP_OPTION, HORIZON_LINES_OPTION,
-       IGNORE_FILE_NAME_CASE_OPTION, INHIBIT_HUNK_MERGE_OPTION,
-       LEFT_COLUMN_OPTION, LINE_FORMAT_OPTION, NORMAL_OPTION,
-       SDIFF_MERGE_ASSIST_OPTION, STRIP_TRAILING_CR_OPTION,
-       SUPPRESS_COMMON_LINES_OPTION, TO_FILE_OPTION,
-       UNCHANGED_LINE_FORMAT_OPTION, OLD_LINE_FORMAT_OPTION,
-       NEW_LINE_FORMAT_OPTION, UNCHANGED_GROUP_FORMAT_OPTION,
-       OLD_GROUP_FORMAT_OPTION, NEW_GROUP_FORMAT_OPTION,
-       CHANGED_GROUP_FORMAT_OPTION): New constants.
-       (longopts, main): Use them.
-
-       (longopts, main, option_help_msgid): Add -E, --from-file, --to-file.
-
-       (main): Invoke bindtextdomain and textdomain after setlocale.
-       Use grep syntax, not Emacs, for regular expressions.
-       Use exclude.h, not our own functions.
-       Use ISO 8601 time format in hard locales.
-       Prepend DIFF_OPTIONS.
-       Don't update ignore_some_changes.
-       Use strtoumax instead of numeric_arg.
-       Use specify_value when appropriate.
-       error -> try_help when appropriate.
-       -p now means ^[[:alpha:]$_], not ^[_a-zA-Z$].
-       Ignore --inhibit-hunk-merge.
-       Prefer changed group formats to unchanged ones.
-       Remove now-unnecessary casts.
-       Set files_can_be_treated_as_binary.
-
-       (specify_value): Renamed from specify_format.  All uses changed.
-
-       (specify_style): Default is now unspecified, not normal.  All
-       uses changed.
-
-       (set_mtime_to_now): New function.
-       (compare_files): Use it.  Use memset, not bzero.
-       Set stdin mtime to current time even when stdin is not a regular file.
-       Check for same file attributes, as well as for same file.
-       Use files_can_be_treated_as_binary.
-       "write failed" -> "standard output on output failure.
-
-       * src/context.c: Assume C89 or better.
-       int -> lin for line numbers.
-       Include inttostr.h, regex.h.
-       (TIMESPEC_NS): New macro.
-       (nstrftime): New decl.
-       (print_context_label): Use nstrftime and time_format to format times.
-       Print numeric time stamp value if localtime fails.
-       (print_context_function): New function.
-       (pr_context_hunk, pr_unidiff_hunk): Use it.
-       (find_function): Use size_t for sizes, not int.
-
-       * src/cmp.c: Assume C89 or better.
-       int -> bool for booleans.
-       long -> off_t for line numbers.
-       Use angle-brackets when including cmpbuf.h, getopt.h.
-       Include error.h, freesoft.h, inttostr.h, xalloc.h.
-       (copyright_string): Use only most recent year.
-       (authorship_msgid): Wrap in N_().
-       (buffer): Now word*, not char*.  All uses changed.
-       (word): Remove macro; now in system.h.
-       (long_options, option_help_msgid, main): -c --print-chars ->
-       -b --print-bytes
-       (check_stdout): "write failed" -> "standard output"
-       (option_help_msgid): Wrap in N_().
-       (main): Invoke bindtextdomain and textdomain after setlocale.
-       Use strtoumax instead of doing the work ourselves.
-       Check for same_file_attributes as well as same_file.
-       (cmp): Use ssize_t for read returns, not size_t.
-       Do not assume that size_t is not narrower than int.
-       Do not assume that line numbers fit in 'long'.
-       (block_compare_and_count, block_compare):
-       Compiler now checks that buffers are word-aligned.
-       (block_compare_and_count): Count sizes with size_t, not long.
-       (sprintc): byte arg is unsigned char, not unsigned.
-
-       * src/analyze.c: Assume C89 or better.
-       int -> lin for line numbers.
-       int -> bool for booleans.
-       unsigned int -> size_t for sizes.
-       Use angle-brackets when including cmpbuf.h.
-       Include error.h, regex.h, xalloc.h.
-       (discard_confusing_lines, diff_2_files): Use zalloc rather
-       than xalloc+bzero.
-       (discard_confusing_lines): unsigned int -> lin for values that
-       are really line numbers.
-       (shift_boundaries): Do not inhibit hunk merges.
-       (build_reverse_script, build_script, diff_2_files): Use |, not ||.
-       (diff_2_files): no_details_flag & ~ignore_some_changes ->
-       files_can_be_treated_as_binary.  Esure that buffer size is a multiple
-       of sizeof (word).  Use file_block_read to read buffers.
-       (diff_2_files): Abort if output style is not one of the
-       expected styles.
-
-2001-11-23  Paul Eggert  <eggert@twinsun.com>
-
-       * src/Makefile.am, m4/vararrays.m4: New file.
-
-       * m4/prereq.m4 (jm_PREREQ_READUTMP):
-       Remove, as it gives autoheader the willies.
-
-       * m4/README, lib/prepargs.h, lib/prepargs.c, lib/offtostr.c,
-       lib/umaxtostr.c, lib/inttostr.c, lib/inttostr.h,
-       lib/imaxtostr.c, lib/freesoft.h: New files.
-
-       * lib/freesoft.c: Include config.h, freesoft.h rather than diff.h.
-       (free_software_msgid): Wrap contents in N_.
-
-       * lib/cmpbuf.h: Use prototypes instead of old-style functions.
-
-       * lib/cmpbuf.c:
-       Don't include system.h; instead, include config.h, unistd.h.
-       Use prototypes instead of old-style functions.
-       (block_read): Don't assume that int is no wider than size_t.
-
-       * lib/Makefile.am, po/POTFILES.in: New file.
-
-2001-11-22  Paul Eggert  <eggert@twinsun.com>
-
-       * pc/config.h:
-       Define filename_cmp as an object-like macro, not as a function-like
-       macro.
-
-       * exgettext: Always operate in the C locale.
-       Set AWK using a method that works even with broken shells.
-
-       * doc/Makefile.am: New file.
-
-       * configure.ac (AC_INIT):
-       Use src/diff.c, not diff.h, as the source files got removed.
-       (AM_CONFIG_HEADER): Switch from AC_CONFIG_HEADER.
-       (AC_ARG_PROGRAM, AC_MINIX): Remove.
-
-       (AC_PREREQ, AM_INIT_AUTOMAKE, ALL_LINGUAS, AC_PROG_AWK,
-       AM_PROG_CC_STDC, AC_PROG_RANLIB, AC_C_INLINE, AC_C_VARARRAYS,
-       DEFAULT_DIFF_PROGRAM, DEFAULT_EDITOR_PROGRAM,
-       AC_STRUCT_ST_MTIM_NSEC): Add.
-
-       (PR_PROGRAM): AC_DEFINE.
-
-       (AC_SYS_LARGEFILE): Use instead of our homebrew version.
-
-       (_GNU_SOURCE): Define if not defined.
-
-       (AC_CHECK_HEADERS): Add stdbool.h, unistd.h.
-       (AC_CHECK_TYPES): Add ptrdiff_t, uintmax_t.
-       (AM_GNU_GETTEXT, XGETTEXT): Add.
-
-       (WITH_MVFS_STAT_BUG, WITH_NFS_STAT_BUG): Remove.
-       (HAVE_MEMCHR): Remove.
-       (AC_CHECK_FUNCS): Add diraccess.
-       (AC_REPLACE_FUNCS): Add memchr, waitpid.
-       (jm_FUNC_GLIBC_UNLOCKED_IO, jm_FUNC_GNU_STRFTIME, jm_FUNC_MALLOC,
-        jm_FUNC_REALLOC, jm_PREREQ_ERROR, jm_PREREQ_QUOTEARG, jm_PREREQ_REGEX,
-        jm_PREREQ_TEMPNAME, jm_AC_PREREQ_XSTRTOUMAX, AC_FUNC_FNMATCH): Add.
-       (fnmatch.h, regex.h): Do not create these files unless we're using
-       our own fnmatch and regex.
-
-       (AC_OUTPUT): Add doc/Makefile, intl/Makefile, lib/Makefile,
-       lib/posix/Makefile, m4/Makefile, po/Makefile.in, src/Makefile.
-
-       * Makefile.am: New file.
-
-       * po/en_GB.po: Don't translate "program" to "programme".
-
-2001-11-20  Paul Eggert  <eggert@twinsun.com>
-
-       * m4/prereq.m4: New file.
-
-2001-03-16  Paul Eggert  <eggert@twinsun.com>
-
-       * lib/tempname.c (uint64_t):
-       Define if not defined, and if UINT64_MAX is not defined.
-
-2001-02-26  Paul Eggert  <eggert@twinsun.com>
-
-       * lib/tempname.c: glibc 1.32
-
-2001-02-17  Paul Eggert  <eggert@twinsun.com>
-
-       * m4/Makefile.am.in: GNU fileutils 4.1
-
-2001-01-09  Paul Eggert  <eggert@twinsun.com>
-
-       * lib/tempname.c (struct_stat64): New macro.
-       (direxists, __gen_tempname): Use it.  This avoids a portability problem
-       with Solaris 8.
-
-       * lib/tempname.c (<config.h>): Include if HAVE_CONFIG_H.
-       (<stddef.h>, <stdint.h>, <string.h>):
-       Include only if STDC_HEADERS || _LIBC.
-       (<fcntl.h>): Include only if HAVE_FCNTL_H || _LIBC.
-       (<unistd.h>): Include only if HAVE_UNISTD_H || _LIBC.
-       (<sys/time.h>): Include only if HAVE_SYS_TIME_H || _LIBC.
-       (__set_errno): Define this macro if <errno.h> doesn't.
-       (P_tmpdir, TMP_MAX, __GT_FILE, __GT_BIGFILE, __GT_DIR, __GT_NOCREATE):
-       Define these macros if <stdio.h> doesn't.
-       (S_ISDIR, S_IRUSR, S_IWUSR, S_IXUSR):
-       Define these macros if <sys/stat.h>
-       doesn't.  Ignore <sys/stat.h> S_ISDIR if STAT_MACROS_BROKEN.
-       (stat64, __getpid, __gettimeofday, __mkdir, __open, __open64, lxstat64,
-       __xstat64): Define if not _LIBC.
-       (__secure_getenv): Define if ! (HAVE___SECURE_GETENV || _LIBC).
-       (__gen_tempname): Invoke gettimeofday only if HAVE_GETTIMEOFDAY
-       || _LIBC; otherwise, fall back on plain "time".
-       Use macros like S_IRUSR | S_IWUSR rather than octal values like 0600.
-
-       * lib/mkstemp.c (__GT_FILE): Define to zero if not defined.
-
-2000-10-25  Paul Eggert  <eggert@twinsun.com>
-
-       * lib/hard-locale.c: New file.
-
-2000-02-05  Paul Eggert  <eggert@twinsun.com>
-
-       * exgettext: From GCC repository
-
-1999-07-06  Paul Eggert  <eggert@twinsun.com>
-
-       * lib/mkstemp.c: glibc 2.2
-
-1998-12-11  Paul Eggert  <eggert@twinsun.com>
-
-       * src/sdiff.c (lf_snarf):
-       Fix bug when help line wrapped around the input buffer.
-
-1998-09-15  Paul Eggert  <eggert@twinsun.com>
-
-       * diff.texi: Add @dircategory and @direntry.
-
-1998-09-14  Paul Eggert  <eggert@twinsun.com>
-
-       * Makefile.in (VERSION): Version 2.7.2.
-       (DEFAULT_DIFF_PROGRAM): Renamed from DIFF_PROGRAM.
-       (PR_PROGRAM): All `configure' to define it.
-       (srcs): Add $(diffutils_srcs), freesoft.c, quotearg.c instead of
-       quote.c, quotearg.h.
-       (distfiles): Add acconfig.h, message/*.
-       (all): Depend on $(destfiles), not info.
-       (version.c): Parenthesize `GNU diffutils'.
-       (common_o): Add freesoft.o
-       (diff_o): quote.o -> quotearg.o
-       (diff3_o, sdiff_o): Likewise.
-       (diff.dvi): Depend on version.texi.
-       (diff.o diff3.o quotearg.o sdiff.o util.o):
-       New dependency on quotearg.h
-       (diff3.o): DIFF_PROGRAM -> DEFAULT_DIFF_PROGRAM.
-       (sdiff.o): Likewise.
-       (messages.po): Remove.
-       (message/msgid.po, message/template.po): New rules.
-       (maintainer-clean): Renamed from realclean.
-       (install): Install from source directory, if applicable.
-       Invoke install-info if needed.
-       (install-strip): New rule.
-       (check): Set DIFF.
-       (stamp-h.in): Don't put the date into the timestamp.
-       (D_dirs): Add $D/message.
-       ($D.tar.gz): Compress with gzip -9.
-       Don't use ln to create distribution; it doesn't work with symlinks.
-       (srcs, distfiles, diff_o, diff3_o, sdiff_o): Rename quotearg.c to
-       quotesys.c and quotearg.h to quotesys.h.
-
-       * configure.in (AC_PATH_PROG): Add PR_PROGRAM.
-       If available, prefer support for large files unless the user specified
-       one of the CPPFLAGS, LDFLAGS, or LIBS variables.
-       (AC_STRUCT_ST_RDEV): Add.
-       (HAVE_ST_FSTYPE_STRING): Add.
-       (--with-mvfs-stat-bug, --with-nfs-stat-bug): New options.
-       (HAVE_MEMCHR): New macro.
-       (AC_CHECK_FUNCS): Add sicprocmask.
-
-       * diff.h (XTERN): Renamed from EXTERN.
-       (struct filedata): Remove dir_p arg.
-       (struct comparison): New type.
-       (diff_2_files, diff_dirs)" Ise ot/
-       (error): Add printf attribute if applicable.
-       (free_software_msgid): New decl.
-       (pr_program): New decl.
-       (fatal): Add noreturn attribute.
-       (pfatal_with_name): Likewise.
-
-       * system.h (__attribute__): New macro.
-       (getenv): Don't declare if HAVE_STDLIB_H.
-       (CHAR_MAX): New macro.
-       (<locale.h>): New include.
-       (<locale.h>): Include before <libintl.h>.
-       (could_be_mvfs_stat_bug, could_be_nfs_stat_bug,
-       dev_may_have_duplicate_ino, same_special_file): New macros.
-       (same_file): Use them.
-
-       * cmp.c (authorship_msgid): New var.
-       (free_software_msgid): New decl.
-       (error): Now has printf attribute.
-       (try_help): Likewise.
-       (long_options): Don't assume ASCII.
-       (try_help): Now accepts operand arg.
-       (main): Check for -1, not EOF, when calling getopt_long.
-       Report --ignore-initial value when complaining about it.
-       Output copyright and free software info with -v.
-       Don't assume ASCII.
-       Report last operand when one is missing.
-       Report text of extra operand.
-       Move block_read into cmpbuf.c.
-
-       * diff.c (authorship_msgid): New var.
-       (quotesys.h): Include.
-       (ck_atoi): Remove.
-       (function_regexp_list, ignore_regexp_list): Now static.
-       (binary_flag): Renamed from binary_I_O.
-       (entire_new_file_flag, unidirectional_new_file_flag,
-       print_file_same_flag): Now static.
-       (numeric_arg): Renamed from ck_atoi.
-       New argument specifying the argument type.
-       (longopts, main): Don't assume ASCII.
-       (longopts): Remove old aliases --file-label, --entire-new-file,
-       --ascii, --print.
-       (main): Check for -1, not EOF, when calling getopt_long.
-       Use numeric_arg to report errors.
-       Report error if -l specified but pagination is not supported.
-       Report error if -S is specified twice with conflicting values.
-       Have --version conform to the new GNU standards.
-       Add new --from-file, --to-file, --inhibit-hun,-merge options.
-       Make the horizon at least as large as the context.
-       Add casts to pacify gcc -Wall.
-       (try_help): Add operand arg.
-       (option_help_msgid): Doc fix to match above.
-       (usage): Indent option_help_msgid.
-       (compare_files): Now takes struct comparison
-       instead of two directory names and a depth.
-       (NONEXISTENT, UNOPENED, ERRNO_ENCODE, ERRNO_DECODE):
-       New macros.
-       (DIR_P): New macro.
-       Report error if fflush does.
-
-       * cmpbuf.c (block_read): Moved here from cmp.c.
-
-       * cmpbuf.h (block_read): New decl.
-
-       * io.c (cmpbuf.h): Include.
-       (slurp): Check for arithmetic overflow when computing buffer size.
-
-       * dir.c (diff_dirs): Check for recursive directory loop.
-       Arg is now struct comparison const *.
-       (dir_loop): New function
-
-       * analyze.c (no_discards): Remove.
-       (inhibit): Remove.
-       (shift_boundaries): Don't inhibit.  If inhibit_hunk_merge is nonzero,
-       don't merge hunks.
-       (briefly_report): Now returns 2 if trouble, CHANGES otherwise.
-       (diff_2_files): Now takes struct comparison.  If briefly_report reports
-       trouble, pass it on to caller.
-
-       * side.c (print_half_line): Add brackets to pacify GCC -Wall.
-
-       * sdiff.c (quotesys.h): Include.
-       (DIFF_PROGRAM, DEFAULT_EDITOR_PROGRAM): Remove.
-       (free_software_msgid, editor_program, not_found): New vars.
-       (diffbin, edbin): Remove.
-       (editor_program): Renamed from edbin.
-       (edit, interact): Now take extra string arg.
-       (exiterr, fatal, perror_fatal, try_help): Add noreturn attribute.
-       (sigset_t, sigemptyset, sigmask, sigaddset, SIG_BLOCK, SIG_SETMASK):
-       (sigprocmask): New macros, if !HAVE_SIGPROCMASK.
-       (error): Now has printf attribute.
-       (longopts, main): Don't assume ASCII.
-       (try_help): New operand arg.
-       (usage): Conform to new GNU standards.
-       (main): Set static vars for editor and diff program.
-       Compare getopt_long result to -1, not EOF.
-       -v conforms to new GNU standard.
-       Complain better about extra and missing operands.
-       If HAVE_VFORK, block SIGINT and SIGPIPE in the parent, since when
-       the child munges its handlers it may somp on the parent.
-       Pass rname to intract.
-       Translate not-found message before forking.
-       (give_help): Just output it all at once.
-       (edit): New args lname, lline, rname, rline.
-       (edit): New command 'd'.
-       (interact): New args lname, rname.
-
-       * util.c (quotesys.h): Include.
-       (PR_PROGRAM): New macro.
-       (pfatal_with_name): Abort if error returns.
-       (fatal): Likewise.
-       (print_message_queue): Free message chain after printing.
-       (currently_recursive): Renamed from current_depth, and now a boolean.
-       (begin_output): Report error if fflush does.
-       Avoid stdio and gettext in child.
-
-       * diff3.c (quotesys.h): Include.
-       (free_software_msgid): New decl.
-       (RANGE_START, RANGE_END): Renamed from START and END.
-       (fatal, perror_with_exit, try_help): Add noreturn attribute.
-       (error): Add printf attribute.
-       (diff_program): Now a ptr, not an array.
-       Initialize to DEFAULT_DIFF_PROGRAM instead of DIFF_PROGRAM.
-       (longopts, main): Don't assume ASCII.
-       (main): Use DIFF environment var to specify name of diff program.
-       Compare getopt_long result to -1, not EOF.
-       -v now reports version according to new GNU standard.
-       Report spelling of extra operand, or last operand before missing one.
-       (try_help): Now takes operand arg.
-       (option_help_ms): Fix typo: missing comma.
-       (usage): Update as per current GNU standards.
-       (environ): Remove decl.
-       (read_diff): Invoke diff with --inhibit-hunk-merge.
-       Translate `not found' message before forking.
-       Quote name of diff program.
-       Pass horizon lines.
-       `memory exhausted' -> `Memory exhausted'
-
-       * pc/makefile (%.exe): Remove.
-       (pc-clean): Remove *.exe
-       * pc/makefile.sed (DEFAULT_DIFF_PROGRAM): Renamed from DIFF_PROGRAM.
-       When editing mkinstalldirs rule, look for exec_prefix and prefix.
-       Add .exe when installing files.
-       * pc/emx/config.h (same_file): Add.
-       * pc/config.h (same_file): Remove.
-       * pc/djgpp/config.h: Adjust to latest patch from eliz.
-       * pc/djgpp/makefile.sed: Don't alter PROGRAMS.
-       * pc/pc.c: Update FSF address.
-       (quote_system_arg): Renamed from system_quote_arg.
-
-       * README: Add --with-mvfs-stat-bug, --with-nfs-stat-bug.
-
-       * getmsgids: Add copyright date and update FSF address.
-
-       * diff.texi: Document recent changes.
-       The patch doc still corresponds to patch 2.2, unfortunately.
-       Update GNU bug reporting address.  Omit Larry Wall's address;
-       it's obsolete and he's busy with perl.
-
-       * context.c: Fix spacing.
-
-       * NEWS: Mention --from-file=FILE, --to-file=FILE, ed.
-
-       * acconfig.h, freesoft.c, message/de.po, message/en_UK.po,
-       message/es.po, message/fr.po, message/pl.po, message/sv.po:
-       New files.
-
-       * ed.c: Remove `#if 0'ed code.
-
-       * normal.c, waitpid.c: Update FSF address.
-
-1998-03-15  Paul Eggert  <eggert@twinsun.com>
-
-       * quotesys.c: Renamed from quotearg.c.
-
-       * quotesys.h: Renamed from quotearg.h
-       (__QUOTESYS_P): Renamed from __QUOTEARG_P.
-
-1997-05-05  Paul Eggert  <eggert@twinsun.com>
-
-       * quotesys.c, quotesys.h: New file.
-
-Mon Nov 14 05:10:56 1994  Paul Eggert  <eggert@twinsun.com>
-
-       Add internationalization support.
-       Several messages have been changed slightly,
-       to make them more consistent and easier to translate.
-       All strings that are messages are passed through gettext once before
-       being used, so that they can be localized.
-       Each function and macro whose first parameter is a gettext msgid
-       has had its first parameter's name changed so it ends in `msgid'.
-       All arrays of msgids have had their names changed to end in `msgid'.
-       `getmsgids' uses this to determine which strings are msgids.
-
-       * pc/COPYING, pc/INSTALL, pc/config.h,
-       pc/djgpp/config.h, pc/djgpp/makefile.sed,
-       pc/emx/config.h, pc/emx/diff.def, pc/emx/gnuregex.def,
-       pc/emx/makefile.sed,
-       pc/makefile, pc/makefile.sed, pc/pc.c: New files, for PC support.
-
-       * getmsgids: New file.
-
-       * Makefile.in (PACKAGE, VERSION, diffutils_srcs, D): New vars.
-       (version.c, version.texi, messages.po): New files.
-       messages.po is built automatically from source files and `getmsgids'.
-       (distfiles): Add them, pc/*, and getmsgids.
-       (diff.info): Now depends on version.texi.
-       (realclean): Clean messages.po, version.*.
-       (dist): Just build $D.tar.gz.
-       ($D.tar.gz): New file, takes over old `dist' function.
-       Don't assume $(distfiles) are all in same directory.
-
-       * configure.in (AC_CHECK_HEADERS): Add libintl.h, locale.h.
-       (AC_CHECK_LIB): Check for -lintl.
-
-       * analyze.c (briefly_report): Rewrite `message (A?"B":"C")' as
-       `if (A) message ("B") : message ("C")'; this is for getmsgids.
-       (briefly_report, diff_2_files): For label, use file_label if set.
-       * diff.c (compare_files): Likewise.
-
-       * system.h (gettext): Declare; use a stub if ! HAVE_LIBINTL_H.
-       (setlocale): Declare; use a stub if ! HAVE_LOCALE_H.
-
-       * cmp.c, diff.c, diff3.c, sdiff.c (main):
-       Invoke setlocale first thing, to tell library we're internationalized.
-       (option_help_msgid): New constant.
-       (usage): Use it, so message is translated one option at a time.
-       * sdiff (help_msgid, give_help): Likewise.
-
-       * cmp.c (sprintc): Renamed from `printc'.
-       Now outputs to a buffer instead of stdout.
-       (cmp): Use new sprintc; it's easier to internationalize.
-
-       * diff.c (main): -D FOO now outputs `/* ! FOO */ instead of
-       `/* not FOO */'.
-
-       * sdiff.c (version_string): Fix decl typo: `const' was missing.
-       (trapsigs): Ignore sigaction failure, to be compatible with `signal'.
-
-       * util.c (struct msg, message5, print_message_queue):
-       Allocate just one block of memory to save a message.
-
-Wed Nov  9 17:42:44 1994  Paul Eggert  <eggert@twinsun.com>
-
-       * sdiff.c (trapsigs): Don't check signal return value, since it's
-       bogus under djgpp.
-
-Mon Oct 31 07:27:27 1994  Paul Eggert  <eggert@twinsun.com>
-
-       * Makefile.in (srcs, diff_o, diff3_o, sdiff_o):
-       New files quote.c, quote.o.
-
-       * diff.h (function_regexp, ignore_regexp): Replace lists of compiled
-       regexps with these single compiled regexps.  All users changed.
-       (regexp_list,function_regexp_list,ignore_regexp_list): Move to diff.c.
-       * diff.c (add_regexp): Build one big regexp instead of a regexp list.
-       (summarize_regexp_list): New function.
-       (regexp_list): Redesigned struct; moved here from diff.h.
-       (function_regexp_list, ignore_regexp_list): Likewise, for vars.
-
-       * context.c (find_function): Simplify interface:
-       don't return size of function line.  All callers changed.
-       (print_context_script, find_function): INT_MAX now denotes no
-       previous match; this is simpler than `- file->prefix_lines - 1'.
-
-       * diff3.c (read_diff): Quote arguments with system_quote_arg.
-       * sdiff.c (main): Use system_quote_arg to compute command.
-       * diff.c (option_list): Quote options with system_quote_arg.
-       * util.c (begin_output): Use system_quote_arg to compute command.
-
-       * util.c (pr_program): New var.
-       (analyze_hunk): Fix off-by-1 line length bug.
-       Match with one big regexp instead of a list of regexps.
-       Use new `trivial_length' local instead of comparing first byte to `\n'.
-       Help the compiler with linbuf local vars.
-
-       * system.h (system_quote_arg):
-       New function; replaces SYSTEM_QUOTE_ARG macro.
-
-Sat Oct 15 20:09:12 1994  Paul Eggert  <eggert@twinsun.com>
-
-       * system.h (_tolower): Define if not already defined.
-       * io.c (find_and_hash_each_line): Change tolower to _tolower; this
-       speeds up diff -i considerably on some hosts (e.g. Solaris 2.3).
-       * util.c (line_cmp): Likewise.
-       * ifdef.c (groups_letter_value): Likewise.
-
-       * diff.h (ignore_some_line_changes): Remove.  All users changed.
-       * io.c (find_and_hash_each_line): Don't invoke line_cmp if the length
-       differs and -i is in force.  Don't assume ISSPACE ('\n') is nonzero.
-
-       * diff.h (xmalloc_exit_failure): New variable.
-       All `main' programs set this variable at the start.
-       xmalloc and xrealloc are now taken from GNU library.
-       * cmp.c (main): Align buffer size to word size; some mallocs care.
-       * io.c (slurp): Likewise.
-       * diff.c (add_exclude): Can now assume xrealloc (0, ...) works.
-       (add_regexp): Free storage on failure.  Allocate storage all at one go.
-       * system.h (malloc, realloc): Remove unused declarations.
-       * diff3.c, sdiff.c, util.c (xmalloc, xrealloc): Remove.
-       * sdiff.c (diffarg): Take advantage of cleaner xrealloc semantics.
-
-       * io.c (ROL): Use sizeof to make it more generic.
-
-       * Makefile.in (common_o): New variable.
-       Link error.o and xmalloc.o into all programs.
-       (check): Depend on $(PROGRAMS).
-
-       * diff.h (error): Change to GNU library standard.  All callers changed.
-       * diff3.c (main): Use strerror (EISDIR) instead of "Is a directory".
-       (fatal, perror_with_exit): Use `error'.
-       * util.c (perror_with_name, fatal): Use GNU `error'.
-       (error): Remove.
-
-Wed Oct 12 17:04:40 1994  David J. MacKenzie  (djm@duality.gnu.ai.mit.edu)
-
-       * cmp.c (main): Set xmalloc_exit_failure.
-
-Sat Oct  1 05:24:19 1994  Paul Eggert  <eggert@twinsun.com>
-
-       * Version 2.7 released.
-
-       * configure.in (AC_HEADER_SYS_WAIT): Add.
-       (AC_CHECK_HEADERS): Remove sys/wait.h.
-       (AC_CHECK_FUNCS): Add tmpnam.
-       * system.h (<sys/wait.h>, WEXITSTATUS): Use simpler scheme
-       now that HAVE_SYS_WAIT_H is not set on hosts
-       that are incompatible with Posix applications.
-
-       * util.c (dir_file_pathname): Use filename_lastdirchar not strrchr.
-       * sdiff.c (expand_name): Likewise.
-       (private_tempnam): Use tmpnam if HAVE_TMPNAM; this simplifies porting.
-       (exists, letters): Omit if HAVE_TMPNAM.
-
-       * diff3.c (read_diff): If STAT_BLOCKSIZE yields zero,
-       adjust it to a more reasonable value.
-
-Sat Sep 24 20:36:40 1994  Paul Eggert  <eggert@twinsun.com>
-
-       * sdiff.c (exists, private_tempname): Adopt latest GNU libc algorithm.
-       (private_tempnam): Specialize for sdiff to avoid portability problems.
-
-Thu Sep 22 16:47:00 1994  Paul Eggert  <eggert@twinsun.com>
-
-       * configure.in (AC_ARG_PROGRAM): Added.
-       (AC_OUTPUT): Add [date > stamp-h].
-
-       * Makefile.in (DEFAULT_EDITOR_PROGRAM, DIFF_PROGRAM, LIBOBJS,
-       NULL_DEVICE, PR_PROGRAM, PROGRAMS): New variables.
-       (check, stamp-h.in, cmp.o, util.o): New targets.
-       (edit_program_name): New variable; replaces old binprefix method.
-       (install, uninstall): Use it.
-       (binprefix): Removed.
-       (distfiles): Add stamp-h.in.
-       (clean): Clean stamp-h.
-       (config.hin, config.h): Use time stamp files.
-       (cmp_o): Add $(LIBOBJS).
-       (install): Install info files from srcdir if they're not in `.'.
-
-       * cmp.c, io.c (word): Don't define if already defined.
-
-       * comp.c (main): Use setmode, not open(..., O_BINARY); this gets stdin.
-       Use NULL_DEVICE instead of "/dev/null".
-       (cmp): Use %lu instead of %ld when it is more likely to be right.
-
-       * diff.h (PR_FILE_NAME): Rename to PR_PROGRAM and move to Makefile.in,
-       util.c.
-
-       * diff3.c (main): Give proper diagnostic if too many labels were given.
-       (read_diff): Use SYSTEM_QUOTE_ARG.
-
-       * system.h: <string.h>: Include if HAVE_STRING_H, too.
-       <ctype.h>: Include here.  All includers changed.
-       (CTYPE_DOMAIN, ISDIGIT, ISPRINT, ISSPACE, ISUPPER): New macros that
-       work around common <ctype.h> problems.
-       (O_BINARY): Remove.
-       (SYSTEM_QUOTE_ARG): New macros.
-
-       * diff.c: Add comment.
-
-       * util.c (PR_PROGRAM): Moved here from diff.h.
-       (begin_output): Use SYSTEM_QUOTE_ARG.
-
-       * io.c (read_files): Set mode to binary before returning 1.
-
-       * sdiff.c (TMPDIR_ENV): New macro.
-       (DEFAULT_EDITOR_PROGRAM): Renamed from DEFAULT_EDITOR for consistency.
-       (expand_name): Change `isdir' to `is_dir' to avoid theoretical ctype
-       namespace contamination.
-       (main): Use SYSTEM_QUOTE_ARG.
-       (private_tempnam): Don't access "/tmp" directly; use PVT_tmpdir.
-
-Tue Sep 13 18:46:43 1994  Paul Eggert  <eggert@twinsun.com>
-
-       * configure.in (AC_FUNC_MEMCHR): Remove.  Autoconf didn't adopt this,
-       since we need not worry about an old experimental library
-       where memchr didn't work.
-       (AC_FUNC_MEMCMP): Not needed, since we only test for equality.
-       (AC_REPLACE_FUNCS): Add test for memchr.
-       (AC_CHECK_FUNCS): Check for memchr, not memcpy, since it'll be cached.
-       (AC_CHECK_HEADERS): Add string.h; regex.c uses on some old hosts.
-
-       * system.h (memcmp): Define in terms of bcmp.
-       Use HAVE_MEMCHR to test for all mem* routines.
-
-       * Makefile.in (srcs): Remove memcmp.c.
-       We use bcmp if memcmp doesn't work, since we only test for equality.
-
-Mon Sep 12 15:52:22 1994  Paul Eggert  <eggert@twinsun.com>
-
-       * configure.in (AC_CONFIG_HEADER): Rename config.h.in to config.hin.
-       (AC_ISC_POSIX, AC_MINIX): Go back to these old names for Autoconf 2.
-       (AC_CHECK_HEADERS): Remove now-redundant check for <string.h>.
-       (AC_CHECK_FUNCS): Check for strchr.
-       (AC_FUNC_MEMCHR, AC_FUNC_MEMCMP, AC_CHECK_FUNCS): Use special-purpose
-       macros when suitable.
-       * memcmp.c: New file.
-       * Makefile.in (CPPFLAGS, DEFS, CFLAGS, LDFLAGS, prefix, exec_prefix):
-       Default to autoconf-specified strings.
-       (COMPILE): Use the defaults.
-       (srcs): Add memcmp.c.
-       (distfiles): Rename config.h.in->config.hin, install.sh->install-sh.
-       (Makefile, config.h, config.hin, config.status): Rework for
-       compatibility with Autoconf 2.
-       * io.c (binary_file_p): Assume non-broken memchr.
-       * memchr.c: Assume compiler understands void *; otherwise
-       we don't match GCC's internal declaration of memchr.
-       * system.h: Use more modern autoconf approach to standard C headers.
-       * version.c: Include <config.h>, not "config.h".
-
-       * diff.c, diff.h (ignore_some_line_changes):
-       New variable; replaces `length_varies'.
-       (line_end_char): Replace with '\n'; it wasn't being used consistently.
-
-       * io.c (find_and_hash_each_line): Fix inconsistencies with -b -w -i and
-       incomplete lines.  Put incomplete lines into their own bucket.
-       This means line_cmp no longer needs line length arguments,
-       and equivalence classes' line lengths no longer need to include \n.
-       Invoke line_cmp only if ignore_some_line_changes.
-       (prepare_text_end): -B no longer ignores missing newlines.
-       (read_files): Allocate another bucket for incomplete lines.
-
-       * util.c (line_cmp): Now takes just two arguments.  No longer
-       optimizes for common case of exact equality; the caller does that
-       optimization now.  The caller is changed accordingly.
-       Optimize for the common case of mostly equality.
-       Use isupper+tolower instead of islower+toupper, for consistency.
-
-       * waitpid.c (waitpid): Fix typo with internal scoping.
-
-Thu Sep  8 08:23:15 1994  Paul Eggert  <eggert@twinsun.com>
-
-       * configure.in: Revamp for Autoconf 2.
-       * memchr.c, waitpid.c: New source files for substitute functions.
-       * Makefile.in (diff_o, diff3_o, sdiff_o): Add $(LIBOBJS).
-       (srcs): Add memchr.c, waitpid.c.
-       (distfiles): Add install.sh, memchr.c, waitpid.c, install.sh.
-       * system.h: Use Autoconf 2 style HAVE_DIRENT_H etc. macros for dirs.
-       * dir.c (dir_sort): Prefer NAMLEN (p) to strlen (p->d_name).
-       Change VOID_CLOSEDIR to CLOSEDIR_VOID for Autoconf 2.
-       * sdiff.c, util.c (memchr, waitpid): Remove; use new substitutes.
-       * diff3.c (read_diff): Use new waitpid substitute.
-
-       * cmp.c, diff.c, diff3.c, sdiff.c (check_stdout, try_help): New fns.
-       (usage): Just print more detailed usage message; let caller exit.
-       * diff.c (option_help): New variable.
-       (filetype): Add Posix.1b file types.
-
-Fri Sep  2 16:01:49 1994  Paul Eggert  <eggert@twinsun.com>
-
-       * configure.in: Switch to new autoconf names.  Add sys/file.h test.
-       * Makefile.in (distclean): Clean config.cache, config.log
-       (used by new autoconf).
-
-       * diff.c, diff3.c, (main), sdiff.c (trapsigs): If we'll have children,
-       make sure SIGCHLD isn't ignored.
-
-       * diff3.c (DIFF_CHUNK_SIZE): Removed.  Get size from STAT_BLOCKSIZE.
-       (INT_STRLEN_BOUND): New macro.
-
-       * ifdef.c (format_group, groups_letter_value):
-       Use * instead of [] in prototypes.
-
-       * system.h: Include <sys/file.h> only if HAVE_SYS_FILE_H.
-       (S_IXGRP, S_IXOTH, S_IXUSR): Remove unused macros.
-
-       * util.c (begin_output): Check fdopen result.
-
-       The following changes simplify porting to non-Posix environments.
-       * cmp.c, diff.c, diff3.c, sdiff.c, (main): Call initialize_main first.
-       * diff.c (binary_I_O): New variable for --binary option.
-       (main, usage, compare_files): Support --binary option.
-       (compare_files): Use filename_lastdirchar to find last
-       directory char in a file name.
-       * cmp.c (main), diff.c (compare_files), dir.c (compare_names,
-       diff_dirs): Use filename_cmp to compare file names.
-       Use same_file to determine whether two files are the same.
-       * context.c (print_context_label): Check whether ctime yields 0.
-       * diff3.c (read_diff), sdiff.c (cleanup, main, waitpid),
-       util.c (begin_output): Use popen+pclose if !HAVE_FORK.
-       * io.c (sip): If HAVE_SETMODE, test for binary files in O_BINARY mode.
-       * sdiff.c (ck_fdopen): Function removed.
-       (edit): Use system if !HAVE_FORK.
-       (execdiff): Now assumes caller has pushed all args, plus trailing 0.
-       All callers changed.
-       (private_tempnam): Try TMP if TMPDIR isn't defined.
-       Fit temporary filenames into 8.3 limit.
-       * system.h (STAT_BLOCKSIZE): Don't define if already defined.
-       (min, max): Undef if already defined.
-       (filename_cmp, filename_lastdirchar, HAVE_FORK, HAVE_SETMODE,
-       initialize_main, O_BINARY, same_file): New macros.
-
-Fri Jun 17 11:23:53 1994  David J. MacKenzie  (djm@geech.gnu.ai.mit.edu)
-
-       * Makefile.in (info, dvi, diff.dvi): New targets.
-       (clean): Remove TeX output files.
-
-Fri Jun 17 05:37:52 1994  Paul Eggert  (eggert@twinsun.com)
-
-       * cmp.c, io.c (word): Change from typedef to #define, to avoid
-       collision with Unicos 8.0 <sys/types.h>, which also typedefs `word'.
-
-Thu Apr 15 00:53:01 1994  Paul Eggert  (eggert@twinsun.com)
-
-       * diff3.c (scan_diff_line), util.c (print_number_range): Don't
-       rely on promotion to make the old-style parameter type agree
-       with the prototype parameter type; this doesn't work on
-       Apollos running bsd4.3.
-
-Mon Jan  3 02:05:51 1994  Paul Eggert  (eggert@twinsun.com)
-
-       * Makefile.in (LDFLAGS): Remove -g.  Change all link commands
-       to use both $(CFLAGS) and $(LDFLAGS).
-
-Mon Dec 13 12:23:27 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * system.h: Don't assume dirent.h exists just because
-       _POSIX_VERSION is defined.
-
-Fri Dec  3 18:39:39 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * diff.c (main): allow -pu.
-
-Tue Nov 23 03:51:08 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * Makefile.in (distclean): Remove config.h.
-
-Wed Nov 10 00:28:27 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * Version 2.6 released.
-
-       * analyze.c (too_expensive): New variable, for heuristic to
-       limit the worst-case cost to O(N**1.5 log N) at the price of
-       producing suboptimal output for large inputs with many differences.
-       (diff_2_files): Initialize it.
-       (struct partition): New type.
-       (SNAKE_LIMIT): New macro; merely documents already-used number 20.
-       (diag): New `minimal' arg; all callers changed.  Put results into
-       struct partition.  Apply `too_expensive' heuristic.  Tune.
-       (compareseq): New `minimal' arg; all callers changed.  Tune.
-       (shift_boundaries): Improve heuristic to also coalesce adjacent runs
-       of changes more often.
-
-       * diff.c (long_options, main, usage): Add `--help'.
-       (main): Send version number to stdout, not stderr.
-       (usage): Send usage to stdout, not stderr.
-       (compare_files): Initialize `inf' properly.
-
-       * io.c (word): Change to `int'; it makes a big difference on x86.
-       (sip, slurp): Put off allocating room to hold the whole file until we
-       have to read the whole file.  This wins if the file turns out
-       to be binary.
-
-       * util.c (xmalloc, xrealloc): "virtual memory" -> "memory"
-       (primes): Omit large primes if INT_MAX is small.
-
-       * sdiff.c (usage): Send usage to stdout, not stderr.
-       (long_options, main, usage): Add `--help'.
-       (main): Send version number to stdout, not stderr.  Exit afterwards.
-
-       * diff3.c (usage): Send usage to stdout, not stderr.
-       (long_options, main, usage): Add `--help'.
-       (read_diff): Detect integer overflow in buffer size calculations.
-
-       * cmp.c (word): New type.  All uses of `long' for
-       word-at-a-time comparisons changed to `word'.
-       (long_options, main, usage): Add `--help'.
-       (usage): Send usage to stdout, not stderr.
-       (main): Add `-v'.  Send version number to stdout, not stderr.
-
-       * configure.in (AC_HAVE_HEADERS): Add unistd.h; remove AC_UNISTD_H.
-
-Mon Sep 27 07:20:24 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * diff.c (add_exclude_file): Cast memchr to (char *)
-       to suppress bogus warnings on some nonstandard hosts.
-
-       * Makefile.in (cmp): Add version.o.
-
-       * analyze.c (diff_2_files): Work around memcmp bug with size=0.
-
-       * cmp.c (main, usage, version_string): Add --version option.
-
-       * system.h (malloc, realloc): Declare only if !HAVE_STDLIB_H.
-       (memchr): Declare only if !HAVE_MEMCHR.  These changes are
-       needed to keep some nonstandard hosts happy.
-
-       * util.c (memchr): Make first arg char const *
-       to match standard.
-       (xmalloc, xrealloc): Cast malloc, realloc
-       to (VOID *) to suppress bogus warnings on some nonstandard hosts.
-
-       * diff3.c (xmalloc, xrealloc): Cast malloc, realloc
-       to (VOID *) to suppress bogus warnings on some nonstandard hosts.
-
-       * sdiff.c (xmalloc, xrealloc): Cast malloc, realloc
-       to (VOID *) to suppress bogus warnings on some nonstandard hosts.
-       (lf_copy, lf_skip, lf_snarf): Cast memchr to (char *)
-       to suppress bogus warnings on some nonstandard hosts.
-       (memchr): Make first arg char const *
-       to match standard.
-
-Mon Sep 27 00:23:37 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * Version 2.5 released.
-
-       * analyze.c (diff_2_files): Work around memcmp bug with size=0.
-
-       * cmp.c (main, usage, version_string): Add --version option.
-       * Makefile.in (cmp): Add version.o.
-
-       * diff.c (add_exclude_file): Cast memchr to (char *)
-       to suppress bogus warnings on some nonstandard hosts.
-       * sdiff.c (lf_copy, lf_skip, lf_snarf): Likewise.
-
-       * diff3.c, sdiff.c, util.c (xmalloc, xrealloc): Cast malloc, realloc
-       to (VOID *) to suppress bogus warnings on some nonstandard hosts.
-
-       * sdiff.c, util.c (memchr): Make first arg char const *
-       to match standard.
-
-       * system.h (malloc, realloc): Declare only if !HAVE_STDLIB_H.
-       (memchr): Declare only if !HAVE_MEMCHR.  These changes are
-       needed to keep some nonstandard hosts happy.
-
-       * xmalloc.c: Include <sys/types.h> always; some nonstandard hosts
-       need it for size_t even if STDC_HEADERS.
-
-Sat Sep 18 01:33:07 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * configure.in (AC_STAT_MACROS_BROKEN): Add.
-       * system.h (S_IS{BLK,CHR,DIR,FIFO,REG,SOCK}): Fix defns if
-       STAT_MACROS_BROKEN.
-
-       * Makefile.in (diff3, sdiff, cmp): Do not link $(ALLOCA).
-
-       * analyze.c (discard_confusing_lines): Make defn static, like decl.
-       * sdiff.c (xmalloc): Likewise.
-
-       * ifdef.c (format_group): Ensure isdigit argument isn't < 0.
-
-       * side.c (print_half_line): Use isprint, since some hosts lack isgraph.
-       * util.c (output_1_line): Likewise.  Ensure its argument isn't < 0.
-       (xmalloc, xrealloc): Remove needless casts.
-
-       * system.h (volatile, const):
-       Define these before including any system headers,
-       so that they're used consistently in all system includes.
-       (getenv, malloc, realloc): Declare even if HAVE_STDLIB_H, since some
-       <stdlib.h>s don't declare them.
-       (memchr): Likewise for <string.h>.
-
-       * cmp.c, diff3.c, diff.h, sdiff.c: Include "system.h" first.
-       * diff.c: Remove redundant "system.h" inclusion.
-
-       * diff3.c (xmalloc): Now static.
-       (xmalloc, realloc): Remove needless casts.
-       (READNUM): Ensure isdigit argument isn't negative.
-
-Wed Sep 14 07:14:15 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * Version 2.4 released.
-
-       * ifdef.c (scan_char_literal): New function, for new %c'x' and
-       %c'\ooo' format specs.
-       (format_group, print_ifdef_lines): Use it.  Remove %0 format spec.
-
-       * cmp.c (cmp): Don't try to read past end of file; this doesn't
-       work on ttys.
-
-       * system.h, version.c: #include <config.h>, not "config.h", to allow
-       configuring in a separate directory when the source directory has
-       already been configured.
-       * Makefile.in (COMPILE): New defn, with proper -I options so that
-       `#include <config.h>' works.
-       (.c.o, diff3.o, sdiff.o): Use it.
-
-Mon Sep 13 06:45:43 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * diff.c (main, longopts): Add --line-format=FORMAT option.
-       (specify_format): Args no longer const pointers.  All callers changed.
-
-       * ifdef.c: Add support for %?c, %(A=B?T:E), PRINTF_SPECn formats.
-       (struct group): New struct.
-       (print_ifdef_lines): Use it to simplify argument passing.
-       Remove the convention that last arg -1 signifies that the lines
-       from file 2 are the same as the lines from file 1; this
-       convention no longer works, now that line numbers might be
-       printed out, since the line numbers may differ.
-       Add first FILE * argument to output to.  All callers changed.
-       Use a faster test for the single-fwrite optimization.
-       (format_group, scan_printf_spec, groups_letter_value): New functions.
-
-       * diff.h (group_format, line_format): No longer const pointers.
-       (format_ifdef): 1st arg is no longer const pointer.
-
-       * configure.in: Configure HAVE_LIMITS_H, HAVE_STDLIB_H.
-       * system.h <limits.h>, <stdlib.h>, <string.h>:
-       Include only if HAVE_LIMITS_H etc.
-
-       * system.h (memcmp, memcpy, strchr, strrchr, struct dirent): Prefer
-       these standard names to the traditional names (bcmp, bcpy, index,
-       rindex, struct direct).  All callers changed.
-
-       * system.h (PARAMS, VOID):
-       Define earlier so that malloc decl can use VOID.
-       (STAT_BLOCKSIZE): Simplify ersatz defn; just use 8K.
-
-Fri Sep  3 00:21:02 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * diff.c (compare_files): Two files with the same name must be
-       the same file; avoid a needless `stat' in that case.
-
-Fri Aug 27 06:59:03 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * Pervasive changes for portability to 64-bit hosts:
-       Add prototypes to function declarations.
-       Use size_t, not int, when needed.
-
-       * Other pervasive changes:
-       Use `const' more often.
-       Use STD{IN,OUT,ERR}_FILENO instead of [012].
-       Use 0, not NULL, for portability to broken hosts.
-
-       * Makefile.in: (srcs, objs, distfiles, cmp): New files cmpbuf.[ch].
-       (distfiles): New files config.h.in, mkinstalldirs.
-       (.c.o): Add -DHAVE_CONFIG_H.
-
-       * analyze.c: (diag): Pacify `gcc -Wall' with a useless assignment.
-       (diff_2_files): Use l.c.m., not max, of files' buffer sizes.
-
-       * cmp.c: Make globals static when possible.
-
-       (file): Now a 2-element array; replaces `file1' and `file2'.
-       (file_desc, buffer): Likewise, for file[12]_desc and buf[12].
-       (main): Likewise, for stat_buf[12].  Index these variables with `i'.
-
-       (ignore_initial): New var.
-       (long_options): Now const.  Add `--ignore-initial'.
-       (usage): Sort options and add `--ignore-initial'.
-       (main, cmp): Add `--ignore-initial' support.
-
-       (main): `cmp - -' now succeeds.
-       When comparing standard input to a file, and using a shortcut (e.g.
-       looking at file sizes or inode numbers), take the lseek offset into
-       account before deciding whether the files are identical.
-       Avoid mentioning `dev_t', `ino_t' for portability to nonstandard hosts.
-       Use l.c.m. of files' buffer sizes, not 8 * 1024.
-       ferror (stdout) does not imply errno has a useful value.
-       If 2nd file is "-", treat it first, in case stdin is closed.
-
-       (cmp): Always compute `char_number', `smaller' for speed and simplicity.
-       Say `cmp: EOF on input', not `/usr/gnu/bin/cmp: EOF on input',
-       as per Posix.2.
-
-       (block_compare_and_count): Increment line_number argument.
-       Remove end_char argument; it's always '\n'.  All callers changed.
-       Do not assume sizeof(long) == 4; this isn't true on some 64-bit hosts.
-       (block_compare): Minimize differences with block_compare_and_count.
-
-       (block_read): Coalesce `bp += nread's.
-
-       (printc): Remove `FILE *' arg; output to stdout.  All callers changed.
-
-       * configure.in: Configure HAVE_SIGACTION, RETSIGTYPE, HAVE_VPRINTF.
-       Configure into config.h.
-
-       * context.c (print_context_label):
-       Standard input's st_mtime is no longer a special case
-       here, since `compare_files' now sets it to the current time.
-
-       * diff.c (usage): Sort options.
-       (filetype): New function.
-       (compare_files): Set stdin's st_mtime to be the current time.
-       Leave its name "-" instead of changing it to "Standard Input";
-       to test whether a file is stdin, we must compare its name to "-" instead
-       of its desc to 0, since if it's closed other file descs may be 0.
-       When comparing standard input to a file, and using a shortcut (e.g.
-       looking at file sizes or inode numbers), take the lseek offset into
-       account before deciding whether the files are identical.
-       Pretend that nonexistent files have the same filetype as existing files.
-       Rename `errorcount' to `failed', since it's boolean.
-       In directory comparisons, if a file is neither a regular file nor a
-       directory, just print its type and the other file's type.
-
-       * diff.h (Is_space, textchar): Remove.
-       (struct msg, msg_chain, msg_chain_end): Move to util.c.
-       (VOID): Move to system.h.
-       (line_cmp, version_string, change_letter, print_number_range,
-       find_change): New decls.
-
-       * diff.texi:
-       whitespace -> white space.  It now stands for whatever isspace yields.
-       Add --ignore-initial.
-
-       * diff3.c (VOID): Move to system.h.
-       (version_string): Now char[].
-       (usage): Sort options.
-       (process_diff): Pacify `gcc -Wall' with a useless assignment.
-       (read_diff): pid is of type pid_t, not int.  Use waitpid if available.
-       (output_diff3): Simplify test for `\ No newline at end of file' message.
-
-       * dir.c (struct dirdata): Rename `files' to `names' to avoid confusion
-       with external struct file_data `files'.
-
-       * io.c (line_cmp): Move declaration to diff.h.
-       (textchar): Remove.
-       (find_and_hash_each_line): Use locale's definition of white space
-       instead of using one hardwired defn for -b and another for -w.
-
-       * normal.c (change_letter, print_number_range, find_change):
-       Move decls to diff.h.
-       (print_normal_hunk): Now static.
-
-       * sdiff.c (SEEK_SET): Move to system.h.
-       (version_string): Now char[], not char*.
-       (private_tempnam): Remove hardcoded limit on temporary file names.
-       (exiterr, perror_fatal, main): When exiting because of a signal,
-       exit with that signal's status.
-       (lf_refill, main, skip_white, edit, interact): Check for signal.
-       (ignore_SIGINT): Renamed from `ignore_signals'.
-       (NUM_SIGS, initial_handler): New macros.
-       (initial_action, signal_received, sigs_trapped): New vars.
-       (catchsig, trapsigs): Use sigaction if possible, since this closes the
-       windows of vulnerability that `signal' has.  Use RETSIGTYPE not void.
-       When a signal comes in, just set a global variable; this is safer.
-       (checksigs, untrapsig): New functions.
-       (edit): Pacify `gcc -Wall' with a useless assignment.
-       Respond to each empty line with help, not to every other empty line.
-       (private_tempnam): Remove hardcoded limit on temporary file name length.
-       Don't assume sizeof (pid_t) <= sizeof (int).
-
-       * system.h: (S_IXOTH, S_IXGRP, S_IXUSR,
-       SEEK_SET, SEEK_CUR,
-       STDIN_FILENO, STDOUT_FILENO, STDERR_FILENO):
-       New macros, if system doesn't define them.
-       (volatile): Don't define if already defined.
-       (PARAMS): New macro.
-       (VOID): Move here from diff.h.
-
-       * util.c (struct msg, msg_chain, msg_chain_end): Moved here from diff.h.
-       (message5): New function.
-       (pr_pid): New var.
-       (begin_output): Allocate `name' more precisely.
-       Put child pid into pr_pid, so that we can wait for it later.
-       Don't check execl's return value, since any return must be an error.
-       (finish_output): Detect and report output errors.
-       Use waitpid if available.  Check pr exit status.
-       (line_cmp): Use locale's definition of white space
-       instead of using one hardwired defn for -b and another for -w.
-       (analyze_cmp): Avoid double negation with `! nontrivial'.
-       Pacify `gcc -Wall' be rewriting for-loop into do-while-loop.
-       (dir_file_pathname): New function.
-
-       * version.c (version_string): Now char[], not char*.
-
-Thu Jul 29 20:44:30 1993  David J. MacKenzie  (djm@wookumz.gnu.ai.mit.edu)
-
-       * Makefile.in (config.status): Run config.status --recheck, not
-       configure, to get the right args passed.
-
-Thu Jul 22 10:46:30 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * Makefile.in (dist): Replace `if [ ! TEST ]; then ACTION; fi'
-       with `[ TEST ] || ACTION || exit' so that the containing for-loop exits
-       with proper status for `make'.
-
-Thu Jul  8 19:47:22 1993  David J. MacKenzie  (djm@goldman.gnu.ai.mit.edu)
-
-       * Makefile.in (installdirs): New target.
-       (install): Use it.
-       (Makefile, config.status, configure): New targets.
-
-Sat Jun  5 23:10:40 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * Makefile.in (dist): Switch from .z to .gz.
-
-Wed May 26 17:16:02 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * diff.c (main): Cast args to compare_files, for traditional C.
-       * side.c (print_sdiff_common_lines, print_sdiff_hunk): Likewise.
-       * analyze.c, diff3.c, sdiff.c, util.c: Don't assume NULL is defined
-       properly.
-
-Tue May 25 14:54:05 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * analyze.c (diff_2_files):  With -q, do not report that files differ
-       if all their differences are ignored.
-       (briefly_report): New function.
-       * diff.h (ignore_some_changes): New variable.
-       * diff.c (compare_files): Don't use the file size shortcut if
-       ignore_some_changes is nonzero, since the file size may differ
-       merely due to ignored changes.
-       (main):  Set ignore_some_changes if we might ignore some changes.
-       Remove unsystematic assignment of 0 to static vars.
-       * io.c (read_files): New argument PRETEND_BINARY says whether to
-       pretend the files are binary.
-
-       * diff3.c (tab_align_flag): New variable, for new -T option.
-       (main, usage, output_diff3): Add support for -T.
-
-Sun May 23 15:25:29 1993  Richard Stallman  (rms@mole.gnu.ai.mit.edu)
-
-       * dir.c (dir_sort): Always init `data' to avoid GCC warning.
-
-Sat May 22 15:35:02 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * Makefile.in (dist): Change name of package from diff to diffutils.
-       Don't bother to build .Z dist; .z suffices.
-
-Fri May 21 16:35:22 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * diff.c: Include "system.h" to get memchr declaration.
-       * system.h (memchr): Declare if !HAVE_MEMCHR, not if
-       !HAVE_MEMCHR && !STDC_HEADERS.
-
-Wed May 19 17:43:55 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * Version 2.3 released.
-
-Fri Apr 23 17:18:44 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * io.c (find_identical_ends): Do not discard the last HORIZON_LINES
-       lines of the prefix, or the first HORIZON_LINES lines of the suffix.
-       * diff.c (main, longopts, usage): Add --horizon-lines option.
-       * diff3.c (main, process_diff, read_diff): Invoke second diff
-       with --horizon-lines determined by the first diff.
-       * diff.h, diff3.c (horizon_lines): New variable.
-
-Mon Mar 22 16:16:00 1993  Roland McGrath  (roland@churchy.gnu.ai.mit.edu)
-
-       * system.h [HAVE_STRING_H || STDC_HEADERS] (bcopy, bcmp, bzero):
-       Don't define if already defined.
-
-Fri Mar  5 00:20:16 1993  Richard Stallman  (rms@mole.gnu.ai.mit.edu)
-
-       * diff.c (main): Use NULL in arg to compare_files.
-
-Thu Feb 25 15:26:01 1993  Roland McGrath  (roland@churchy.gnu.ai.mit.edu)
-
-       * system.h: Declare memchr #if !HAVE_MEMCHR && !STDC_HEADERS,
-       not #if !HAVE_MEMCHR || !STDC_HEADERS.
-
-Mon Feb 22 15:04:46 1993  Richard Stallman  (rms@geech.gnu.ai.mit.edu)
-
-       * io.c (find_identical_ends): Move complicated arg outside GUESS_LINES.
-
-Mon Feb 22 12:56:12 1993  Roland McGrath  (roland@churchy.gnu.ai.mit.edu)
-
-       * Makefile.in (.c.o): Add -I$(srcdir); put $(CFLAGS) last before $<.
-
-Sat Feb 20 19:18:56 1993  Richard Stallman  (rms@mole.gnu.ai.mit.edu)
-
-       * io.c (binary_file_p): Return zero if file size is zero.
-
-Fri Feb 19 17:31:32 1993  Roland McGrath  (roland@geech.gnu.ai.mit.edu)
-
-       * Version 2.2 released.
-
-       * system.h [HAVE_STRING_H || STDC_HEADERS] (index, rindex): Don't
-       define if already defined.
-
-Wed Feb 17 17:08:00 1993  Roland McGrath  (roland@churchy.gnu.ai.mit.edu)
-
-       * Makefile.in (srcs): Remove limits.h.
-
-Thu Feb 11 03:36:00 1993  Richard Stallman  (rms@mole.gnu.ai.mit.edu)
-
-       * diff3.c (xmalloc): No longer static.
-
-       * sdiff.c (edit): Allocate buf dynamically.
-
-       * dir.c (dir_sort): Handle VOID_CLOSEDIR.
-
-Wed Feb 10 00:15:54 1993  Richard Stallman  (rms@mole.gnu.ai.mit.edu)
-
-       * limits.h: File deleted (should never have been there).
-
-Tue Feb  9 03:53:22 1993  Richard Stallman  (rms@mole.gnu.ai.mit.edu)
-
-       * Makefile.in (.c.o, diff3.o, sdiff.o): Put $(CFLAGS) last.
-
-Wed Feb  3 15:42:10 1993  David J. MacKenzie  (djm@goldman.gnu.ai.mit.edu)
-
-       * system.h: Don't #define const; let configure do it.
-
-Mon Feb  1 02:13:23 1993  Paul Eggert  (eggert@hal.gnu.ai.mit.edu)
-
-       * Version 2.1 released.
-
-       * Makefile.in (dist): Survive ln failures.  Create .tar.z
-       (gzipped tar) file as well as .tar.Z (compressed tar) file.
-
-Fri Jan  8 22:31:41 1993  Paul Eggert  (eggert@twinsun.com)
-
-       * side.c (print_half_line): When the input position falls
-       outside the column, do not output a tab even if the output
-       position still falls within the column.
-
-Mon Dec 21 13:54:36 1992  David J. MacKenzie  (djm@kropotkin.gnu.ai.mit.edu)
-
-       * Makefile.in (.c.o): Add -I.
-
-Fri Dec 18 14:08:20 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * configure.in: Add HAVE_FCNTL_H, since system.h uses it.
-
-Tue Nov 24 10:06:48 1992  David J. MacKenzie  (djm@goldman.gnu.ai.mit.edu)
-
-       * Makefile.in: Note change from USG to HAVE_STRING_H.
-
-Mon Nov 23 18:44:00 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * io.c (find_and_hash_each_line): When running out of lines,
-       double the number of allocated lines, instead of just doubling
-       that number minus the prefix lines.  This is more likely to
-       avoid the need for further memory allocation.
-
-Wed Nov 18 20:40:28 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * dir.c (dir_sort): Plug memory leak: space holding directory
-       contents was not being reclaimed.  Get directory size from
-       struct file_data for initial guess at memory needed.
-       Detect errors when reading and closing directory.
-       (diff_dirs): Pass struct file_data to dir_sort.  Finish plugging leak.
-       * diff.c (compare_files): Pass struct file_data to diff_dirs.
-
-       * io.c (find_and_hash_each_line): Don't assume alloc_lines is
-       nonzero when allocating more lines.
-
-Thu Nov 12 16:02:18 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * diff.c (main): Add `-U lines' as an alias for `--unified=lines'.
-
-       * diff3.c (usage): Add third --label option in example.
-
-       * util.c (analyze_hunk): Fix test for ignoring blank lines.
-
-       * configure.in, system.h: Avoid USG; use HAVE_TIME_H etc. instead.
-
-Mon Nov  9 05:13:25 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * diff3.c (main, usage): Add -A or --show-all.
-       -m now defaults to -A, not -E.  Allow up to three -L options.
-       (output_diff3_edscript, output_diff3_merge):
-       Remove spurious differences between these two functions.
-       Output ||||||| for -A.  Distinguish between conflicts and overlaps.
-       (dotlines, undotlines): New functions that output `Ns', not `N,Ns'.
-       (output_diff3_edscript, output_diff3_merge): Use them.
-
-       * io.c (find_identical_ends): shift_boundaries needs an extra
-       identical line at the end, not at the beginning.
-
-       * sdiff.c (edit): execvp wants char **, not const char **.
-
-Mon Oct 19 04:39:32 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * context.c (print_context_script, find_function): Context
-       line numbers start with - file->prefix_lines, not 0.
-
-       * io.c (binary_file_p): Undo last change; it was a library bug.
-
-Sun Oct 18 00:17:29 1992  Richard Stallman  (rms@mole.gnu.ai.mit.edu)
-
-       * io.c (binary_file_p): Consider empty file as non-binary.
-
-Mon Oct  5 05:18:46 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * diff3.c (main, make_3way_diff, using_to_diff3_block): Don't
-       report bogus differences (for one of -mexEX3) just because the
-       file0-file1 diffs don't line up with the file0-file2 diffs.
-       (This is entirely possible since we don't use diff's -n
-       option.)  Always compare file1 to file2, so that diff3 sees
-       those changes directly.  Typically, file2 is now the common
-       file, not file0.
-       (output_diff3_merge): The input file is file 0, not the common file.
-
-       (FC, FO): New macros; they replace FILE1, FILE0 for two-way diffs,
-       to distinguish them from three-way diffs.
-
-       * diff3.c (using_to_diff3_block): Fold repeated code into loops.
-
-       * diff3.c (make_3way_diff, process_diff): Have the *_end
-       variable point to the next field to be changed, not to the last
-       object allocated; this saves an if-then-else.
-
-       * diff3.c (process_diff): Use D_NUMLINES instead of its definiens.
-
-       * diff3.c: Make fns and vars static unless they must be external.
-
-Wed Sep 30 09:21:59 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * analyze.c (diff_2_files): OUTPUT_IFDEF is now robust.
-       * diff.h (ROBUST_OUTPUT_STYLE): Likewise.
-       (default_line_format): Remove.  All refs removed.
-
-       * ifdef.c (print_ifdef_lines): Add %L.  Optimize %l\n even if user
-       specified it, as opposed to its being the default.
-
-Tue Sep 29 19:01:28 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * diff.c (longopts, main): --{old,new,unchanged,changed}--group-format
-       are new options, so that -D is no longer overloaded.  Set
-       no_diff_means_no_output if --unchanged-{line,group}-format allows it.
-       * diff.h (enum line_class): New type.
-       (group_format, line_format): Use it to regularize option flags.
-       All refs changed.
-
-       * ifdef.c (format_ifdef, print_ifdef_lines): %n is no longer a format.
-
-Mon Sep 28 04:51:42 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * diff.c (main, usage): Replace --line-prefix with the more general
-       --{old,new,unchanged}-line-format options.
-       * ifdef.c (format_ifdef, print_ifdef_lines): Likewise.
-       * diff.h (line_format): Renamed from line_prefix.  All refs changed.
-       * diff.h, ifdef.c (default_line_format): New variable.
-       * util.c (output_1_line): New function.
-       (print_1_line): Use it.
-
-       * ifdef.c: (format_ifdef, print_ifdef_lines): Add %0 format.
-
-Sun Sep 27 05:38:13 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * diff.c (main): Add -E or --line-prefix option.  Add -D'=xxx'
-       for common lines.  Change default -D< format from copy of -D>
-       format to to -D<%<; similarly for default -D> format.
-       * diff.h (common_format, line_prefix): New variables.
-       * ifdef.c (format_ifdef): New function.
-       (print_ifdef_script, print_ifdef_hunk, print_ifdef_lines):
-       Use it for -D'=xxx', -E.
-
-       * context.c (find_hunk): Glue together two non-ignorable changes that
-       are exactly CONTEXT * 2 lines apart.  This shortens output, removes
-       a behavioral discontinuity at CONTEXT = 0, and is more compatible
-       with traditional diff.
-
-       * io.c (find_identical_ends): Slurp stdin at most once.
-
-       * util.c (print_line_line): line_flag is const char *.
-
-Thu Sep 24 15:18:07 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * ifdef.c (print_ifdef_lines): New function, which fwrites a sequence
-       of lines all at once for speed.
-       (print_ifdef_script, print_ifdef_hunk): Use it.
-
-Thu Sep 24 05:54:14 1992  Paul Eggert  (eggert@twinsun.com)
-
-       * diff.c (main): Support new -D options for if-then-else formats.
-       (specify_format): New function.
-       * diff.h (ifndef_format, ifdef_format, ifnelse_format): New variables.
-       * ifdef.c (print_ifdef_hunk): Use the new variables instead of
-       a hardwired format.
-
-       * side.c (print_1sdiff_line): Represent incomplete lines on output.
-       (print_sdiff_script): Likewise.  Don't print 'q' at end,
-       since that doesn't work with incomplete lines.
-       * sdiff.c (interact): Don't assume diff output ends with 'q' line.
-       * diff.h (ROBUST_OUTPUT_STYLE): OUTPUT_SDIFF is now robust.
-
-       * sdiff.c (lf_copy, lf_snarf): Use memchr instead of index,
-       to avoid dumping core when files contain null characters.
-       (memchr): New function (if memchr is missing).
-
-       * io.c (sip): New arg SKIP_TEST to skip test for binary file.
-       (read_files): Don't bother testing second file if first is binary.
-
-Thu Sep 17 21:17:49 1992  David J. MacKenzie  (djm@nutrimat.gnu.ai.mit.edu)
-
-       * system.h [!USG && !_POSIX_VERSION]: Protect from conflicting
-       prototype for wait in sys/wait.h.
-
-Wed Sep 16 12:32:18 1992  David J. MacKenzie  (djm@nutrimat.gnu.ai.mit.edu)
-
-       * Makefile.in: Include binprefix in -DDIFF_PROGRAM.
-
-Tue Sep 15 14:27:25 1992  David J. MacKenzie  (djm@nutrimat.gnu.ai.mit.edu)
-
-       * Version 2.0.
-
-Sat Sep 12 01:31:19 1992  David J. MacKenzie  (djm@nutrimat.gnu.ai.mit.edu)
-
-       * util.c, diff.h, system.h [!HAVE_MEMCHR]: Don't use void *
-       and const when declaring memchr replacement.  Declare memchr
-       if !STDC_HEADERS && !USG.
-
-Thu Sep 10 15:17:32 1992  David J. MacKenzie  (djm@nutrimat.gnu.ai.mit.edu)
-
-       * Makefile.in (uninstall): New target.
-
-       * diff.c (excluded_filename): Use fnmatch, not wildmat.
-       (usage): Document -x, -X, --exclude, --exclude-from.
-       Makefile.in: Use fnmatch.c, not wildmat.c.
-
-Sun Sep  6 23:46:25 1992  Paul Eggert (eggert@twinsun.com)
-
-       * configure.in: Add HAVE_MEMCHR.
-       * diff.h, util.c: Use it instead of MEMCHR_MISSING.
-
-Sun Sep  6 07:25:49 1992  Paul Eggert (eggert@twinsun.com)
-
-       * diff.h: (struct line_def): Replace this 3-word struct with char *.
-       This uses less memory, particularly for large files with short lines.
-       (struct file_data): New member linbuf_base counts number of lines
-       in common prefix that are not recorded in linbuf;
-       this uses less memory if files are identical or differ only at end.
-       New member buffered_lines counts possibly differing lines.
-       New member valid_lines counts valid data.
-       New member alloc_lines - linbuf_base replaces old linbufsize.
-       linbuf[0] now always points at first differing line.
-       Remove unused members ltran, suffix_lines.
-       Add const where appropriate.
-       (Is_space): New macro, for consistent definition of `white space'.
-       (excluded_filename, memchr, sip, slurp): New declarations.
-       * ed.c (print_ed_hunk): Adjust to diff.h's struct changes.
-       * context.c (pr_context_hunk): Likewise.
-       * ifdef.c (print_ifdef_script): Likewise.
-       * side.c (print_sdiff_script, print_half_line): Likewise.
-       * util.c (analyze_hunk, line_cmp, print_1_line): Likewise.
-
-       * analyze.c (shift_boundaries): Remove unneeded variable `end' and
-       unnecessary comparisons of `preceding' and `other_preceding' against 0.
-       (diff_2_files): When comparing files byte-by-byte for equality,
-       don't slurp them all in at once; just compare them a buffer at a time.
-       This can win big if they differ early on.
-       Move some code to compare_files to enable this change.
-       Use only one buffer for stdin with `diff - -'.
-       (discard_confusing_lines, diff_2_files): Coalesce malloc/free calls.
-       (build_script): Remove obsolete OUTPUT_RCS code.
-
-       * diff.c (add_exclude, add_exclude_file, excluded_filename): New fns.
-       (main): Use them for the new --exclude and --exclude-from options.
-       (compare_files): Don't open a file unless it must be read.
-       Treat `diff file file' and `diff file dir' similarly.
-       Move some code here from diff_2_files to enable this.
-       Simplify file vs dir warning.
-
-       * dir.c (dir_sort): Support new --exclude* options.
-
-       * io.c (struct equivclass): Put hash code and line length here instead
-       of struct line_def, so that they can be shared.
-       (find_and_hash_each_line): Compute equivalence class as we go,
-       instead of doing it in a separate pass; this thrashes memory less.
-       Make buckets realloc-able, since we can't preallocate them.
-       Record one more line start than there are lines, so that we can compute
-       any line's length by subtracting its start from the next line's,
-       instead of storing the length explicitly.  This saves memory.
-       Move prefix-handling code to find_identical_ends;
-       this wins with large prefixes.
-       Use Is_space, not is_space, for consistent treatment of white space.
-       (prepare_text_end): New function.
-       (find_identical_ends): Move slurping here, so it's only done when
-       needed.  Work even if the buffers are the same (because of `diff - -').
-       Compare prefixes a word at a time for speed.
-       (find_equiv_class): Delete; now done by find_and_hash_each_line.
-       (read_files): Don't slurp unless needed.
-       find_equiv_class's work is now folded into find_and_hash_each_line.
-       Don't copy stdin buffer if `diff - -'.
-       Check for running out of primes.
-       (sip, slurp): Split first part of `slurp' into another function `sip'.
-       `sip' sets things up and perhaps reads the first ST_BLKSIZE buffer to
-       see whether the file is binary; `slurp' now just finishes the job.
-       This lets diff_2_files compare binary files lazily.
-       Allocate a one-word sentinel to allow word-at-a-time prefix comparison.
-       Count prefix lines only if needed, only count the first file's prefix.
-       Don't bother to count suffix lines; it's never needed.
-       Set up linbuf[0] to point at first differing line.
-       (binary_file_p): Change test for binary files:
-       if it has a null byte in its first buffer, it's binary.
-       (primes): Add more primes.
-
-       * util.c (line_cmp): Use bcmp for speed.
-       Use Is_space, not is_space, for consistent treatment of white space.
-       (translate_line_number): Internal line numbers now count from 0
-       starting after the prefix.
-       (memchr): New function (if memchr is missing).
-
-       * Makefile.in: Document HAVE_ST_BLKSIZE.  Link with wildmat.o.
-       * system.h (STAT_BLOCKSIZE): New macro based on HAVE_ST_BLKSIZE.
-       * configure.in: Add AC_ST_BLKSIZE.
-       * wildmat.c: New file.
-
-Fri Sep  4 01:28:51 1992  Richard Stallman  (rms@mole.gnu.ai.mit.edu)
-
-       * sdiff.c (xmalloc): Renamed from ck_malloc.  Callers changed.
-
-Thu Sep  3 15:28:59 1992  David J. MacKenzie  (djm@nutrimat.gnu.ai.mit.edu)
-
-       * diff.h: Don't declare free, index, rindex.
-
-Tue Aug 11 22:18:06 1992  John Gilmore  (gnu at cygnus.com)
-
-       * io.c (binary_file_p):  Use heuristic to avoid declaring info
-       files as binary files.  Allow about 1.5% non-printing
-       characters (in info's case, ^_).
-
-Tue Jul  7 01:09:26 1992  David J. MacKenzie  (djm@nutrimat.gnu.ai.mit.edu)
-
-       * diff.h: Replace function_regexp and ignore_regexp with lists
-       of compiled regexps.
-       * analyze.c, context.c, util.c: Test whether the lists, not
-       the old variables, are empty.
-       * util.c (analyze_hunk), context.c (find_function): Compare
-       lines with the lists of regexps.
-       * diff.c (add_regexp): New function.
-       (main): Use it.
-
-       * diff3: Add -v --version option.
-       * Makefile.in: Link with version.o.
-
-       * system.h: New file.
-       * diff.h, cmp.c, diff3.c, sdiff.c: Use it.
-
-       * diff.h, diff3.c: Include string.h or strings.h, as appropriate.
-       Declare malloc and realloc.
-
-       * diff3.c (perror_with_exit): Include program name in message.
-
-       * diff3.c: Lowercase error messages for GNU standards.
-
-       * sdiff.c [USG || STDC_HEADERS]: Define bcopy in terms of memcpy.
-
-       * sdiff.c: Use the version number from version.c.
-       * Makefile.in: Link with version.o.
-
-       * cmp.c error.c xmalloc.c: New files from textutils.
-       * Makefile.in: Add rules for them.
-
-       * diff.c (longopts): --unidirectional-new-file is like -P, not -N.
-       Rename --file-label to --label (leave old name, but undocumented).
-
-       * sdiff.c, diff.c (usage): Condense messages and fix some errors.
-
-       * diff3.c (main, usage): Add long-named options.
-
-Fri Jul  3 14:31:18 1992  David J. MacKenzie  (djm@nutrimat.gnu.ai.mit.edu)
-
-       * diff.h, diff3.c, sdiff.c: Change FOO_MISSING macros to HAVE_FOO.
-
-Thu Jun 25 16:59:47 1992  David J. MacKenzie  (djm@apple-gunkies.gnu.ai.mit.edu)
-
-       * diff.c: --reversed-ed -> --forward-ed.
-
-Wed Feb 26 12:17:32 1992  Paul Eggert  (eggert@yata.uucp)
-
-       * analyze.c, diff.c, diff.h, io.c: For -y, compare even if same file.
-
-Fri Feb 14 22:46:38 1992  Richard Stallman  (rms@mole.gnu.ai.mit.edu)
-
-       * io.c, diff3.c, analyze.c: Add extra parentheses.
-
-Sun Feb  9 00:22:42 1992  Richard Stallman  (rms@mole.gnu.ai.mit.edu)
-
-       * diff.h (unidirectional_new_file_flag): New variable.
-       * diff.c (main): Set that for -P.
-       (compare_files): Support -P, somewhat like -N.
-       (longopts): Support long name for -P.
-
-Sat Jan  4 20:10:34 1992  Paul Eggert (eggert at yata.uucp)
-
-       * Makefile.in: Distribute diff.info-* too.
-
-       * README, sdiff.c: version number now matches version.c.
-
-       * configure: Fix and document vfork test.
-
-       * ifdef.c: Don't dump core if `diff -Dx f f'.
-
-Mon Dec 23 23:36:08 1991  David J. MacKenzie  (djm at wookumz.gnu.ai.mit.edu)
-
-       * diff.h, diff3.c, sdiff.c: Change POSIX ifdefs to
-       HAVE_UNISTD_H and _POSIX_VERSION.
-
-Wed Dec 18 17:00:31 1991  David J. MacKenzie  (djm at wookumz.gnu.ai.mit.edu)
-
-       * Makefile.in (srcs): Add sdiff.c.
-       (tapefiles): Add diff.texi and diff.info.
-
-       * diff.h, diff3.c, sdiff.c: Use HAVE_VFORK_H instead of
-       VFORK_HEADER and VFORK_WORKS.
-
-Tue Dec 17 00:02:59 1991  Paul Eggert  (eggert at yata.uucp)
-
-       * Makefile.in (all): Add diff.info, sdiff.
-
-       * configure, diff.c, sdiff.c:
-       Prefix long options with `--', not `+'.
-       * diff.c: Regularize option names.
-
-       * configure: Fix check for vfork.
-       * configure, diff.c, diff.h, diff3.c, sdiff.c:
-       Use Posix definitions when possible.
-
-       * context.c: Align context with tab if -T is given.  Tune.
-       * diff.c, diff.h, side.c: Calculate column widths so that tabs line up.
-       * io.c: Add distinction between white space and printing chars.
-       * side.c: Don't expand tabs unless -t is given.
-       * side.c, util.c: Tab expansion now knows about '\b', '\f', '\r', '\v'.
-       * util.c: -w skips all white space.  Remove lint.  Tune.
-
-       * sdiff.c: Support many more diff options, e.g. `-', `sdiff file dir'.
-       Ignore interrupts while the subsidiary editor is in control.
-       Clean up temporary file and kill subsidiary diff if interrupted.
-       Ensure subsidiary diff doesn't ignore SIGPIPE.
-       Don't get confused while waiting for two subprocesses.
-       Don't let buffers overflow.  Check for I/O errors.
-       Convert to GNU style.  Tune.
-
-       * sdiff.c, util.c: Don't lose errno.
-       Don't confuse sdiff with messages like `Binary files differ'.
-       * sdiff.c, side.c: Don't assume that common lines are identical.
-       Simplify --sdiff-merge-assist format.
-
-Mon Sep 16 16:42:01 1991  Tom Lord  (lord at churchy.gnu.ai.mit.edu)
-
-       * Makefile.in, sdiff.c: introduced sdiff front end to diff.
-
-       * Makefile.in, analyze.c, diff.c, diff.h, io.c, side.c: Added
-       sdiff-style output format to diff.
-
-Mon Aug 26 16:44:55 1991  David J. MacKenzie  (djm at pogo.gnu.ai.mit.edu)
-
-       * Makefile.in, configure: Only put $< in Makefile if using VPATH,
-       because older makes don't understand it.
-
-Fri Aug  2 12:22:30 1991  David J. MacKenzie  (djm at apple-gunkies)
-
-       * configure: Create config.status.  Remove it and Makefile if
-       interrupted while creating them.
-
-Thu Aug  1 22:24:31 1991  David J. MacKenzie  (djm at apple-gunkies)
-
-       * configure: Check for +srcdir etc. arg and look for
-       Makefile.in in that directory.  Set VPATH if srcdir is not `.'.
-       * Makefile.in: Get rid of $(archpfx).
-
-Tue Jul 30 21:28:44 1991  Richard Stallman  (rms at mole.gnu.ai.mit.edu)
-
-       * Makefile.in (prefix): Renamed from DESTDIR.
-
-Wed Jul 24 23:08:56 1991  David J. MacKenzie  (djm at wookumz.gnu.ai.mit.edu)
-
-       * diff.h, diff3.c: Rearrange ifdefs to use POSIX,
-       STDC_HEADERS, VFORK_MISSING, DIRENT.  This way it works on
-       more systems that aren't pure USG or BSD.
-       Don't not define const if __GNUC__ is defined -- that would
-       break with -traditional.
-       * configure: Check for those features.
-
-Wed Jul 10 01:39:23 1991  David J. MacKenzie  (djm at wookumz.gnu.ai.mit.edu)
-
-       * configure, Makefile.in: $(INSTALLPROG) -> $(INSTALL).
-
-Sat Jul  6 16:39:04 1991  David J. MacKenzie  (djm at geech.gnu.ai.mit.edu)
-
-       * Replace Makefile with configure and Makefile.in.
-       Update README with current compilation instructions.
-
-Sat Jul  6 14:03:29 1991  Richard Stallman  (rms at mole.gnu.ai.mit.edu)
-
-       * util.c (setup_output): Just save the args for later use.
-       (begin_output): Do the real work, with the values that were saved.
-       It's safe to call begin_output more than once.
-       Print the special headers for context format here.
-       * analyze.c (diff_2_files): Don't print special headers here.
-       * context.c (pr_context_hunk, pr_unidiff_hunk): Call begin_output.
-       * ed.c (print_ed_hunk, print_forward_ed_hunk, print_rcs_hunk):
-       * normal.c (print_normal_hunk): Likewise.
-       * ifdef.c (print_ifdef_hunk): Likewise.
-       * util.c (finish_output): Don't die if begin_output was not called.
-
-Thu Jun 20 23:10:01 1991  David J. MacKenzie  (djm at geech.gnu.ai.mit.edu)
-
-       * Makefile: Add TAGS, distclean, and realclean targets.
-       Set SHELL.
-
-Tue Apr 30 13:54:36 1991  Richard Stallman  (rms at mole.gnu.ai.mit.edu)
-
-       * diff.h (TRUE, FALSE): Undefine these before defining.
-
-Thu Mar 14 18:27:27 1991  Richard Stallman  (rms@mole.ai.mit.edu)
-
-       * Makefile (objs): Include $(ALLOCA).
-
-Sat Mar  9 22:34:03 1991  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * diff.h: Include regex.h.
-
-Thu Feb 28 18:59:53 1991  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * Makefile (diff3): Link with GNU getopt.
-
-Sat Feb 23 12:49:43 1991  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * io.c (find_equiv_class): Make hash code unsigned before mod.
-
-       * diff.h (files): Add EXTERN.
-
-Sun Jan 13 21:33:01 1991  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * diff.c: +print option renamed +paginate.  Remove +all-text.
-
-Mon Jan  7 06:18:01 1991  David J. MacKenzie  (djm at geech.ai.mit.edu)
-
-       * Makefile (dist): New target, replacing diff.tar and
-       diff.tar.Z, to encode version number in distribution directory
-       and tar file names.
-
-Sun Jan  6 18:42:23 1991  Michael I Bushnell  (mib at geech.ai.mit.edu)
-
-       * Version 1.15 released.
-
-       * version.c: Updated from 1.15 alpha to 1.15
-
-       * context.c (print_context_number_range,
-       print_unidiff_number_range): Don't print N,M when N=M, print
-       just N instead.
-
-       * README: Updated for version 1.15.
-       Makefile: Updated for version 1.15.
-
-       * diff3.c (main): Don't get confused if one of the arguments
-       is a directory.
-
-       * diff.c (compare_files): Don't get confused if comparing
-       standard input to a directory; print error instead.
-
-       * analyze.c (diff_2_files), context.c (print_context_header,
-       print_context_script), diff.c (main), diff.h (enum
-       output_style): Tread unidiff as an output style in its own
-       right.  This also generates an error when both -u and -c are
-       given.
-
-       * diff.c (main): Better error messages when regexps are bad.
-
-       * diff.c (compare_files): Don't assume stdin is opened.
-
-       * diff3.c (read_diff): Don't assume things about the order of
-       descriptor assignment and closes.
-
-       * util.c (setup_output): Don't assume things about the order
-       of descriptor assignment and closes.
-
-       * diff.c (compare_files): Set a flag so that closes don't
-       happen more than once.
-
-       * diff.c (main): Don't just flush stdout, do a close.  That
-       way on broken systems we can still get errors.
-
-Mon Dec 24 16:24:17 1990  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * diff.c (usage): Use = for args of long options.
-
-Mon Dec 17 18:19:20 1990  Michael I Bushnell  (mib at geech.ai.mit.edu)
-
-       * context.c (print_context_label): Labels were interchanged badly.
-
-       * context.c (pr_unidiff_hunk): Changes to deal with files
-       ending in incomplete lines.
-       * util.c (print_1_line): Other half of the changes.
-
-Mon Dec  3 14:23:55 1990  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * diff.c (longopts, usage): unidiff => unified.
-
-Wed Nov  7 17:13:08 1990  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * analyze.c (diff_2_files): No warnings about newlines for -D.
-
-       * diff.c (pr_unidiff_hunk): Remove ref to output_patch_flag.
-
-Tue Oct 23 23:19:18 1990  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * diff.c (compare_files): For -D, compare even args are same file.
-       * analyze.c (diff_2_files): Likewise.
-       Also, output even if files have no differences.
-
-       * analyze.c (diff_2_files): Print missing newline messages last.
-       Return 2 if a newline is missing.
-       Print them even if files end with identical text.
-
-Mon Oct 22 19:40:09 1990  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * diff.c (usage): Return 2.
-
-Wed Oct 10 20:54:04 1990  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * diff.c (longopts): Add +new-files.
-
-Sun Sep 23 22:49:29 1990  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * context.c (print_context_script): Handle unidiff_flag.
-       (print_context_header): Likewise.
-       (print_unidiff_number_range, pr_unidiff_hunk): New functions.
-       * diff.c (longopts): Add element for +unidiff.
-       (main): Handle +unidiff and -u.
-       (usage): Mention them.
-
-Wed Sep  5 16:33:22 1990  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * io.c (find_and_hash_each_line): Deal with missing final newline
-       after buffering necessary context lines.
-
-Sat Sep  1 16:32:32 1990  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * io.c (find_identical_ends): ROBUST_OUTPUT_FORMAT test was backward.
-
-Thu Aug 23 17:17:20 1990  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * diff3.c (WIFEXITED): Undef it if WEXITSTATUS is not defined.
-       * context.c (find_function): Don't try to return values.
-
-Wed Aug 22 11:54:39 1990  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * diff.h (O_RDONLY): Define if not defined.
-
-Tue Aug 21 13:49:26 1990  Richard Stallman  (rms at mole.ai.mit.edu)
-
-       * Handle -L option.
-       * context.c (print_context_label): New function.
-       (print_context_header): Use that.
-       * diff.c (main): Recognize the option.
-       (usage): Updated.
-       * diff.h (file_label): New variable.
-       * diff3.c (main): Recognize -L instead of -t.
-
-       * diff3.c (main): Support -m without other option.
-
-       * diff3.c (WEXITSTATUS, WIFEXITED): Define whenever not defined.
-
-       * diff3.c (bcopy, index, rindex): Delete definitions; not used.
-       (D_LINENUM, D_LINELEN): Likewise.
-       (struct diff_block): lengths includes newlines.
-       (struct diff3_block): Likewise.
-       (always_text, merge): New variables.
-       (read_diff): Return address of end, not size read.  Calls changed.
-       Pass -a to diff if given to diff3.
-       current_chunk_size now an int.  Detect error in `pipe'.
-       Check for incomplete line of output here.
-       (scan_diff_line): Don't make scan_ptr + 2 before knowing it is valid.
-       No need to check validity of diff output here.
-       Include newline in length of line.
-       (main): Compute rev_mapping here.  Handle -a and -m.
-       Error message if excess -t operands.  Error for incompatible options.
-       Error if `-' given more than once.
-       Fix error storing in tag_strings.
-       (output_diff3): REV_MAPPING is now an arg.  Call changed.
-       Change syntax of "missing newline" message.
-       Expect length of line to include newline.
-       (output_diff3_edscript): Return just 0 or 1.
-       REV_MAPPING is now an arg.  Call changed.
-       (output_diff3_merge): New function.
-       (process_diff): Better error message for bad diff format.
-       (fatal, perror_with_exit): Return status 2.
-
-       * analyze.c (diff_2_files): Report missing newline in either
-       or both files, if not robust output style.
-
-       * util.c (setup_output): Detect error from pipe.
-       No need to close stdin.
-
-       * util.c (print_1_line): Change format of missing-newline msg.
-       Change if statements to switch.
-
-       * io.c (slurp): Don't mention differences in final newline if -B.
-
-       * io.c (binary_file_p): Use ISO char set as criterion, not ASCII.
-
-       * io.c (find_identical_ends): Increase value of BEG0 by 1.
-       Other changes in backwards scan to avoid decrementing pointers
-       before start of array, and set LINES properly.
-
-       * diff.h (ROBUST_OUTPUT_STYLE): New macro.
-       * io.c (find_identical_ends, find_and_hash_each_line): Use that macro.
-
-       * diff.h (dup2): Don't define if XENIX.
-
-       * diff.c (main): Check for write error at end.
-
-       * context.c (find_function): Don't return a value.
-       Use argument FILE rather than global files.
-
-       * analyze.c: Add external function declarations.
-       * analyze.c (build_script): Turn off explicit check for final newline.
-
-       * analyze.c (discard_confusing_lines): Make integers unsigned.
-
-Tue Jul 31 21:37:16 1990  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * io.c (find_and_hash_each_line): Correct the criterion
-       for leaving out the newline from the end of the line.
-
-Tue May 29 21:28:16 1990  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * dir.c (diff_dirs): Free things only if nonzero.
-
-Mon Apr 16 18:31:05 1990  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff.h (NDIR_IN_SYS): New macro controls location of ndir.h.
-
-       * diff3.c (xmalloc, xrealloc): Don't die if size == 0 returns 0.
-
-Sun Mar 25 15:58:42 1990  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * analyze.c (discard_confusing_lines):
-       `many' wasn't being used; use it.
-       Canceling provisionals near start of run must handle already
-       canceled provisionals.
-       Canceling subruns of provisionals was canceling last nonprovisional.
-
-Sat Mar 24 14:02:51 1990  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * analyze.c (discard_confusing_lines):
-       Threshold for line occurring many times scales by square root
-       of total lines.
-       Within each run, cancel any long subrun of provisionals.
-       Don't update `provisional' while canceling provisionals.
-       In big outer loop, handle provisional and nonprovisional separately.
-
-Thu Mar 22 16:35:33 1990  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * analyze.c (discard_confusing_lines):
-       The first loops to discard provisionals from ends failed to step.
-       In second such loops, keep discarding all consecutive provisionals.
-       Increase threshold for stopping discarding, and also check for
-       consecutive nondiscardables as separate threshold.
-
-Fri Mar 16 00:33:08 1990  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff3.c (read_diff): Pass -- as first arg to diff.
-
-       * diff3.c: Include wait.h or define equivalent macros.
-       (read_diff): Don't use stdio printing error in the inferior.
-       Remember the pid and wait for it.  Report failing status.
-       Report failure of vfork.
-
-Sun Mar 11 17:10:32 1990  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff3.c (main): Accept -t options and pass to output_diff3_edscript.
-       (usage): Mention -t.
-       (read_diff): Use vfork.
-       (vfork): Don't use it on Sparc.
-
-       * diff.h (vfork): Don't use it on Sparc.
-
-Tue Mar  6 22:37:20 1990  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff3.c (dup2): Don't define on Xenix.
-
-       * Makefile: Comments for Xenix.
-
-Thu Mar  1 17:19:23 1990  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * analyze.c (diff_2_files): `message' requires three args.
-
-Fri Feb 23 10:56:50 1990  David J. MacKenzie  (djm at albert.ai.mit.edu)
-
-       * diff.h, util.c, diff3.c: Change 'void *' to 'VOID *', with
-       VOID defined as void if __STDC__, char if not.
-
-Sun Feb 18 20:31:58 1990  David J. MacKenzie  (djm at albert.ai.mit.edu)
-
-       * Makefile: Add rules for getopt.c, getopt1.c, getopt.h.
-
-       * getopt.c, getopt.h, getopt1.c: New files.
-
-       * main.c (main, usage): Add long options.
-
-       * analyze.c (shift_boundaries): Remove unused var 'j_end'.
-
-Thu Feb  8 02:43:16 1990  Jim Kingdon  (kingdon at pogo.ai.mit.edu)
-
-       * GNUmakefile: include ../Makerules before Makefile.
-
-Fri Feb  2 23:21:38 1990  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * analyze.c (diff_2_files): If -B or -I, don't return 1
-       if all changes were ignored.
-
-Wed Jan 24 20:43:57 1990  Richard Stallman  (rms at albert.ai.mit.edu)
-
-       * diff3.c (fatal): Output to stderr.
-
-Thu Jan 11 00:25:56 1990  David J. MacKenzie  (djm at hobbes.ai.mit.edu)
-
-       * diff.c (usage): Mention -v.
-
-Wed Jan 10 16:06:38 1990  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff3.c (output_diff3_edscript): Return number of overlaps.
-       (main): If have overlaps, exit with status 1.
-
-Sun Dec 24 10:29:20 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * io.c (find_equiv_class): Fix typo that came from changing init of B
-       to an assignment.
-
-       * version.c: New file.
-       * diff.c (main): -v prints version number.
-
-       * io.c (binary_file_p): Null char implies binary file.
-
-Fri Nov 17 23:44:55 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * util.c (print_1_line): Fix off by 1 error.
-
-Thu Nov 16 13:51:10 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * util.c (xcalloc): Function deleted.
-
-       * io.c (slurp): Null-terminate the buffer.
-
-       * io.c (read_files): Delete unused vars.
-
-       * io.c (find_equiv_class): Don't index by N if too low.
-
-       * dir.c (dir_sort): Delete the extra declaration of compare_names.
-
-       * diff.h: Don't declare xcalloc.  Declare some other functions.
-
-       * analyze.c (shift_boundaries):
-       Test for END at end of range before indexing by it.
-       Fix misspelling of `preceding' in var names.
-
-Sat Nov 11 14:04:16 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff3.c (using_to_diff3_block): Delete unused vars.
-       (make_3way_diff, process_diff_control, read_diff, output_diff3): Likewise.
-
-Mon Nov  6 18:15:50 EST 1989 Jay Fenlason (hack@ai.mit.edu)
-
-       * README Fix typo.
-
-Fri Nov  3 15:27:47 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff.c (usage): Mention -D.
-
-       * ifdef.c (print_ifdef_hunk): Write comments on #else and #endif.
-
-Sun Oct 29 16:41:07 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff.c (compare_files): Don't fflush for identical files.
-
-Wed Oct 25 17:57:12 1989  Randy Smith  (randy at apple-gunkies.ai.mit.edu)
-
-       * diff3.c (using_to_diff3_block): When defaulting lines from
-       FILE0, only copy up to just under the *lowest* line mentioned
-       in the next diff.
-
-       * diff3.c (fatal): Add \n to error messages.
-
-Wed Oct 25 15:05:49 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * Makefile (tapefiles): Add ChangeLog.
-
-Tue Oct  3 00:51:17 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff3.c (process_diff, create_diff3_block): Init ->next field.
-
-Fri Sep 29 08:16:45 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * util.c (line_cmp): Alter end char of line 2, not line 1.
-
-Wed Sep 20 00:12:37 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * Makefile (diff.tar): Expect ln to fail on some files;
-       copy them with cp.
-
-Mon Sep 18 02:54:29 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * Handle -D option:
-       * io.c (find_and_hash_each_line): Keep all lines of 1st file.
-       * diff.c (main): Handle -D option.
-       (compare_files): Reject -D if files spec'd are directories.
-       * analyze.c (diff_2_files): Handle OUTPUT_IFDEF case.
-
-Fri Sep  1 20:15:50 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff.c (option_list): Rename arg VECTOR as OPTIONVEC.
-
-Mon Aug 28 17:58:27 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff.c (compare_files): Clear entire inf[i].stat.
-
-Wed Aug 23 17:48:47 1989  Richard Stallman  (rms at apple-gunkies.ai.mit.edu)
-
-       * io.c (find_identical_ends): Sign was backward
-       determining where to bound the scan for the suffix.
-
-Wed Aug 16 12:49:16 1989  Richard Stallman  (rms at hobbes.ai.mit.edu)
-
-       * analyze.c (diff_2_files): If -q, treat all files as binary.
-       * diff.c (main): Detect -q, record in no_details_flag.
-
-Sun Jul 30 23:12:00 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff.c (usage): New function.
-       (main): Call it.
-
-Wed Jul 26 02:02:19 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff.c (main): Make -C imply -c.
-
-Thu Jul 20 17:57:51 1989  Chris Hanson  (cph at kleph)
-
-       * io.c (find_and_hash_each_line): Bug fix in context handling,
-       introduced by last change.
-
-Fri Jul 14 17:39:20 1989  Chris Hanson  (cph at kleph)
-
-       * analyze.c: To make RCS work correctly on files that don't
-       necessarily end in newline, introduce some changes that cause
-       diffs to be sensitive to missing final newline.  Because
-       non-RCS modes don't want to be affected by these changes, they
-       are conditional on `output_style == OUTPUT_RCS'.
-       (diff_2_files) [OUTPUT_RCS]: Suppress the "File X missing
-       newline" message.
-       (build_script) [OUTPUT_RCS]: Cause the last line to compare as
-       different if exactly one of the files is missing its final
-       newline.
-
-       * io.c (find_and_hash_each_line): Bug fix in
-       ignore_space_change mode.  Change line's length to include the
-       newline.  For OUTPUT_RCS, decrement last line's length if
-       there is no final newline.
-       (find_identical_ends) [OUTPUT_RCS]: If one of the files is
-       missing a final newline, make sure it's not included in either
-       the prefix or suffix.
-
-       * util.c (print_1_line): Change line output routine to account
-       for line length including the newline.
-
-Tue Jun 27 02:35:28 1989  Roland McGrath  (roland at hobbes.ai.mit.edu)
-
-       * Makefile: Inserted $(archpfx) where appropriate.
-
-Wed May 17 20:18:43 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff3.c [USG]: Include fcntl.h.
-
-       * diff.h [USG]: New compilation flags HAVE_NDIR, HAVE_DIRECT.
-
-Wed Apr 26 15:35:57 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * dir.c (diff_dirs): Two new args, NONEX1 and NONEX2, say to pretend
-       nonex dirs are empty.
-       (dir_sort): New arg NONEX, likewise.
-       * diff.c (compare_files): Pass those args.
-       Sometimes call diff_dirs if subdir exists in just one place.
-
-Wed Apr 12 01:10:27 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * io.c (find_identical_ends): Set END0 *after* last char
-       during backward scan for suffix.
-
-Sat Apr  8 15:49:49 1989  Randall Smith  (randy at apple-gunkies.ai.mit.edu)
-
-       * diff3.c (using_to_diff3_block): Now find high marks in files 1
-       and 2 through mapping off of the last difference instead of the
-       first.
-
-       * diff3.c: Many trivial changes to spelling inside comments.
-
-Fri Feb 24 12:38:03 1989  Randall Smith  (randy at gluteus.ai.mit.edu)
-
-       * util.c, normal.c, io.c, ed.c, dir.c, diff.h, diff.c, context.c,
-       analyze.c, Makefile: Changed copyright header to conform with new
-       GNU General Public license.
-       * diff3.c: Changed copyright header to conform with new GNU
-       General Public license.
-       * COPYING: Made a hard link to /gp/rms/COPYING.
-
-Fri Feb 24 10:01:58 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * io.c (slurp): Leave 2 chars space at end of buffer, not one.
-       (find_identical_ends): Special case if either file is empty;
-       don't try to make a sentinel since could crash.
-
-Wed Feb 15 14:24:48 1989  Jay Fenlason  (hack at apple-gunkies.ai.mit.edu)
-
-       * diff3.c (message)  Re-wrote routine to avoid using alloca()
-
-Wed Feb 15 06:19:14 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * io.c (find_identical_ends): Delete the variable `bytes'.
-
-Sun Feb 12 11:50:36 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * io.c (slurp): ->bufsize is nominal amount we have room for;
-       add room for sentinel when calling xmalloc or xrealloc.
-
-       * io.c (find_identical_ends): Do need overrun check in finding suffix.
-
-Fri Feb 10 01:28:15 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff.c (main): -C now takes arg to specify context length.
-       Now -p to show C function name--Damned IEEE!
-       Fatal error if context length spec'd twice.
-
-       * ed.c (print_ed_hunk): Now special treatment only for lines containing
-       precisely a dot and nothing else.  Output `..', end the insert,
-       substitute that one line, then resume the insert if nec.
-
-       * io.c (find_and_hash_lines): When backing up over starting context,
-       don't move past buffer-beg.
-
-       * io.c (find_identical_ends): Use sentinels to make the loops faster.
-       If files are identical, skip the 2nd loop and return quickly.
-       (slurp): Leave 1 char extra space after each buffer.
-
-       * analyze.c (diff_2_files): Mention difference in final newlines.
-
-Wed Jan 25 22:44:44 1989  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * dir.c (diff_dirs): Use * when calling fcn ptr variable.
-
-Sat Dec 17 14:12:06 1988  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * Makefile: New vars INSTALL and LIBS used in some rules;
-       provide default defns plus commented-put defns for sysV.
-
-Thu Nov 17 16:42:53 1988  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * dir.c (dir_sort): Open-trouble not fatal; just say # files is -1.
-       (diff_dirs): If dir_sort does that, give up and return 2.
-
-       * diff.c (compare_files): Don't open directories.
-       Don't close them specially either.
-       Cross-propagate inf[i].dir_p sooner.
-
-Sun Nov 13 11:19:36 1988  Richard Stallman  (rms at sugar-bombs.ai.mit.edu)
-
-       * diff.h: Declare index, rindex.
-
-       * diff.c (compare_files): If comparing foodir with b/f,
-       use foodir/f, not foodir/b/f.
-
-       * diff.c (compare_files): Don't print "are identical" msg for 2 dirs.
-       Status now 1 if one file is a dir and the other isn't, etc.
-
-Thu Nov  3 16:30:24 1988  Randall Smith  (randy at gluteus.ai.mit.edu)
-
-       * Makefile: Added a define for diff3 to define DIFF_PROGRAM.
-
-       * util.c: Added hack to make sure that perror was not called with
-       a null pointer.
-
-       * diff.c: Changed S_IFDIR to S_IFMT in masking type of file bits
-       out.
-
-       * diff3.c: Included USG compatibility defines.
-
-       * diff.h: Moved sys/file.h into #else USG section (not needed or
-       wanted on System V).
-
-       * ed.c, analyze.c, context.c: Shortened names to 12 characters for
-       the sake of System V (too simple not to do).
-
-
-Copyright (C) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1997, 1998, 1999,
-2000, 2001, 2002 Free Software Foundation, Inc.
-
-This file is part of GNU Diffutils.
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation; either version 2, or (at your option)
-any later version.
-
-This program is distributed in the hope that they will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-
-You should have received a copy of the GNU General Public License
-along with this program; see the file COPYING.  If not, write to
-the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
-Boston, MA 02111-1307, USA.
diff --git a/contrib/diffutils/NEWS b/contrib/diffutils/NEWS
deleted file mode 100644 (file)
index 3854f8b..0000000
+++ /dev/null
@@ -1,244 +0,0 @@
-Version 2.8.7 contains no user-visible changes.
-
-User-visible changes in version 2.8.6:
-
-* New diff3 option --strip-trailing-cr.
-
-* With -N and -P, inaccessible empty regular files (the kind of files
-  that 'patch' creates to indicate nonexistent backups) are now
-  treated as nonexistent when they are in the 'backup' file position.
-
-* If multiple SKIP values are given to cmp, e.g., `cmp -i 10 -i 20',
-  cmp now uses the maximal value instead of the last one.
-
-* diff now omits the ".000000000" on hosts that do not support
-  fractional time stamps.
-
-Version 2.8.5 was not publicly released.
-
-User-visible changes in version 2.8.4:
-
-* Diff now simply prints "Files A and B differ" instead of "Binary
-  files A and B differ".  The message is output if either A or B
-  appears to be a binary file, and the old wording was misleading
-  because it implied that both files are binary, which is not
-  necessarily the case.
-
-User-visible changes in version 2.8.3:
-
-* New locale: en_US.
-
-User-visible changes in version 2.8.2:
-
-* New diff and sdiff option:
-  --tabsize=COLUMNS
-* If --ignore-space-change or --ignore-all-space is also specified,
-  --ignore-blank-lines now considers lines to be empty if they contain
-  only white space.
-* More platforms now handle multibyte characters correctly when
-  excluding files by name (diff -x and -X).
-* New locales: hu, pt_BR.
-
-User-visible changes in version 2.8.1:
-
-* Documentation fixes.
-
-User-visible changes in version 2.8:
-
-* cmp and diff now conform to POSIX 1003.1-2001 (IEEE Std 1003.1-2001)
-  if the underlying system conforms to POSIX and if the _POSIX2_VERSION
-  environment variable is set to 200112.  Conformance removes support
-  for `diff -NUM', where NUM is a number.  Use -C NUM or -U NUM instead.
-* cmp now supports trailing operands SKIP1 and SKIP2, like BSD cmp.
-* cmp -i or --ignore-initial now accepts SKIP1:SKIP2 option value.
-* New cmp option: -n or --bytes.
-* cmp's old -c or --print-chars option has been renamed;
-  use -b or --print-bytes instead.
-* cmp now outputs "byte" rather than "char" outside the POSIX locale.
-* cmp -l's index column width now adjusts to fit larger (or smaller) files.
-* cmp -l -s and cmp -s -l are not allowed.  Use cmp -s or cmp -l instead.
-* diff uses ISO 8601 style time stamps for output times (e.g. "2001-11-23
-  16:44:36.875702460 -0800") unless in the C or POSIX locale and the
-  -c style is specified.
-* diff's -I and -F options use the regexp syntax of grep, not of Emacs.
-* diff now accepts multiple context arguments, and uses their maximum value.
-* New diff and sdiff options:
-  -E  --ignore-tab-expansion
-  --strip-trailing-cr
-* New diff options:
-  --from-file=FILE, --to-file=FILE
-  --ignore-file-name-case
-  --no-ignore-file-name-case
-* New diff3 and sdiff option:
-  --diff-program=PROGRAM
-* The following diff options are still accepted, but are no longer documented.
-  They may be withdrawn in future releases.
-  -h (omit; it has no effect)
-  -H (use --speed-large-files instead)
-  -L (use --label instead)
-  -P (use --unidirectional-new-file instead)
-  --inhibit-hunk-merge (omit; it has no effect)
-* Recursive diffs now sort file names according to the LC_COLLATE locale
-  category if possible, instead of using native byte comparison.
-* Recursive diffs now detect and report directory loops.
-* Diff printf specs can now use the "0" and "'" flags.
-* The new sdiff interactive command `ed' precedes each version with a header.
-* On 64-bit hosts, files larger than 2 GB can be compared.
-* Some internationalization support has been added, but multibyte locales
-  are still not completely supported yet.
-* Some diagnostics have been reworded slightly for consistency.
-  Also, `diff -D FOO' now outputs `/* ! FOO */' instead of `/* not FOO */'.
-* The `patch' part of the manual now describes `patch' version 2.5.4.
-* Man pages are now distributed and installed.
-* There is support for DJGPP; see the 'ms' subdirectory and the files
-  m4/dos.m4 and */setmode.*.
-
-
-User-visible changes in version 2.7:
-
-* New diff option: --binary (useful only on non-POSIX hosts)
-* diff -b and -w now ignore line incompleteness; -B no longer does this.
-* cmp -c now uses locale to decide which output characters to quote.
-* Help and version messages are reorganized.
-
-
-User-visible changes in version 2.6:
-
-* New cmp, diff, diff3, sdiff option: --help
-* A new heuristic for diff greatly reduces the time needed to compare
-  large input files that contain many differences.
-* Partly as a result, GNU diff's output is not exactly the same as before.
-  Usually it is a bit smaller, but sometimes it is a bit larger.
-
-
-User-visible changes in version 2.5:
-
-* New cmp option: -v --version
-
-
-User-visible changes in version 2.4:
-
-* New cmp option: --ignore-initial=BYTES
-* New diff3 option: -T --initial-tab
-* New diff option: --line-format=FORMAT
-* New diff group format specifications:
-  <PRINTF_SPEC>[eflmnEFLMN]
-      A printf spec followed by one of the following letters
-      causes the integer corresponding to that letter to be
-      printed according to the printf specification.
-      E.g. `%5df' prints the number of the first line in the
-      group in the old file using the "%5d" format.
-       e: line number just before the group in old file; equals f - 1
-       f: first line number in group in the old file
-       l: last line number in group in the old file
-       m: line number just after the group in old file; equals l + 1
-       n: number of lines in group in the old file; equals l - f + 1
-       E, F, L, M, N: likewise, for lines in the new file
-  %(A=B?T:E)
-      If A equals B then T else E.  A and B are each either a decimal
-      constant or a single letter interpreted as above.  T and E are
-      arbitrary format strings.  This format spec is equivalent to T if
-      A's value equals B's; otherwise it is equivalent to E.  For
-      example, `%(N=0?no:%dN) line%(N=1?:s)' is equivalent to `no lines'
-      if N (the number of lines in the group in the the new file) is 0,
-      to `1 line' if N is 1, and to `%dN lines' otherwise.
-  %c'C'
-      where C is a single character, stands for the character C.  C may not
-      be a backslash or an apostrophe.  E.g. %c':' stands for a colon.
-  %c'\O'
-      where O is a string of 1, 2, or 3 octal digits, stands for the
-      character with octal code O.  E.g. %c'\0' stands for a null character.
-* New diff line format specifications:
-  <PRINTF_SPEC>n
-      The line number, printed with <PRINTF_SPEC>.
-      E.g. `%5dn' prints the line number with a "%5d" format.
-  %c'C'
-  %c'\O'
-      The character C, or with octal code O, as above.
-* Supported <PRINTF_SPEC>s have the same meaning as with printf, but must
-  match the extended regular expression %-*[0-9]*(\.[0-9]*)?[doxX].
-* The format spec %0 introduced in version 2.1 has been removed, since it
-  is incompatible with printf specs like %02d.  To represent a null char,
-  use %c'\0' instead.
-* cmp and diff now conform to POSIX 1003.2-1992 (ISO/IEC 9945-2:1993)
-  if the underlying system conforms to POSIX:
-  - Some messages' wordings are changed in minor ways.
-  - ``White space'' is now whatever C's `isspace' says it is.
-  - When comparing directories, if `diff' finds a file that is not a regular
-    file or a directory, it reports the file's type instead of diffing it.
-    (As usual, it follows symbolic links first.)
-  - When signaled, sdiff exits with the signal's status, not with status 2.
-* Now portable to hosts where int, long, pointer, etc. are not all the same
-  size.
-* `cmp - -' now works like `diff - -'.
-
-
-User-visible changes in version 2.3:
-
-* New diff option: --horizon-lines=lines
-
-
-User-visible changes in version 2.1:
-
-* New diff options:
-  --{old,new,unchanged}-line-format='format'
-  --{old,new,unchanged,changed}-group-format='format'
-  -U
-* New diff3 option:
-  -A --show-all
-* diff3 -m now defaults to -A, not -E.
-* diff3 now takes up to three -L or --label options, not just two.
-  If just two options are given, they refer to the first two input files,
-  not the first and third input files.
-* sdiff and diff -y handle incomplete lines.
-
-
-User-visible changes in version 2.0:
-
-* Add sdiff and cmp programs.
-* Add Texinfo documentation.
-* Add configure script.
-* Improve diff performance.
-* New diff options:
--x --exclude
--X --exclude-from
--P --unidirectional-new-file
--W --width
--y --side-by-side
---left-column
---sdiff-merge-assist
---suppress-common-lines
-* diff options renamed:
---label renamed from --file-label
---forward-ed renamed from --reversed-ed
---paginate renamed from --print
---entire-new-file renamed from --entire-new-files
---new-file renamed from --new-files
---all-text removed
-* New diff3 options:
--v --version
-* Add long-named equivalents for other diff3 options.
-* diff options -F (--show-function-line) and -I (--ignore-matching-lines)
-  can now be given more than once.
-
-\f
-
-Copyright (C) 1993, 1994, 1998, 2001, 2002, 2004 Free Software
-Foundation, Inc.
-
-This file is part of GNU Diffutils.
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation; either version 2, or (at your option)
-any later version.
-
-This program is distributed in the hope that they will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-
-You should have received a copy of the GNU General Public License
-along with this program; see the file COPYING.  If not, write to
-the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
-Boston, MA 02111-1307, USA.
index 0c37230..061ec8a 100644 (file)
@@ -48,15 +48,15 @@ Please report bugs to <bug-gnu-utils@gnu.org>.
 
 -----
 
-Copyright (C) 1992, 1998, 2001, 2002, 2004 Free Software Foundation,
+Copyright (C) 1992, 1998, 2001-2002, 2004, 2009-2010 Free Software Foundation,
 Inc.
 
 This file is part of GNU Diffutils.
 
-This program is free software; you can redistribute it and/or modify
+This program is free software: you can redistribute it and/or modify
 it under the terms of the GNU General Public License as published by
-the Free Software Foundation; either version 2, or (at your option)
-any later version.
+the Free Software Foundation, either version 3 of the License, or
+(at your option) any later version.
 
 This program is distributed in the hope that it will be useful,
 but WITHOUT ANY WARRANTY; without even the implied warranty of
@@ -64,6 +64,4 @@ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 GNU General Public License for more details.
 
 You should have received a copy of the GNU General Public License
-along with this program; see the file COPYING.  If not, write to
-the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
-Boston, MA 02111-1307, USA.
+along with this program.  If not, see <http://www.gnu.org/licenses/>.
index ca36345..540d4a1 100644 (file)
@@ -1,24 +1,24 @@
-This is diff.info, produced by makeinfo version 4.7 from diff.texi.
+This is diff.info, produced by makeinfo version 4.13 from diff.texi.
 
-   This manual is for GNU Diffutils (version 2.8.7, 12 April 2004), and
+This manual is for GNU Diffutils (version 3.0, 15 April 2010), and
 documents the GNU `diff', `diff3', `sdiff', and `cmp' commands for
 showing the differences between files and the GNU `patch' command for
 using their output to update files.
 
-   Copyright (C) 1992, 1993, 1994, 1998, 2001, 2002, 2004 Free Software
-Foundation, Inc.
+   Copyright (C) 1992-1994, 1998, 2001-2002, 2004, 2006, 2009-2010 Free
+Software Foundation, Inc.
 
      Permission is granted to copy, distribute and/or modify this
      document under the terms of the GNU Free Documentation License,
-     Version 1.1 or any later version published by the Free Software
+     Version 1.3 or any later version published by the Free Software
      Foundation; with no Invariant Sections, with the Front-Cover texts
      being "A GNU Manual," and with the Back-Cover Texts as in (a)
      below.  A copy of the license is included in the section entitled
      "GNU Free Documentation License."
 
-     (a) The FSF's Back-Cover Text is: "You have freedom to copy and
-     modify this GNU Manual, like GNU software.  Copies published by
-     the Free Software Foundation raise funds for GNU development."
+     (a) The FSF's Back-Cover Text is: "You have the freedom to copy
+     and modify this GNU manual.  Buying copies from the FSF supports
+     it in developing GNU and promoting software freedom."
 
 INFO-DIR-SECTION Individual utilities
 START-INFO-DIR-ENTRY
@@ -40,25 +40,25 @@ File: diff.info,  Node: Top,  Next: Overview,  Up: (dir)
 Comparing and Merging Files
 ***************************
 
-This manual is for GNU Diffutils (version 2.8.7, 12 April 2004), and
+This manual is for GNU Diffutils (version 3.0, 15 April 2010), and
 documents the GNU `diff', `diff3', `sdiff', and `cmp' commands for
 showing the differences between files and the GNU `patch' command for
 using their output to update files.
 
-   Copyright (C) 1992, 1993, 1994, 1998, 2001, 2002, 2004 Free Software
-Foundation, Inc.
+   Copyright (C) 1992-1994, 1998, 2001-2002, 2004, 2006, 2009-2010 Free
+Software Foundation, Inc.
 
      Permission is granted to copy, distribute and/or modify this
      document under the terms of the GNU Free Documentation License,
-     Version 1.1 or any later version published by the Free Software
+     Version 1.3 or any later version published by the Free Software
      Foundation; with no Invariant Sections, with the Front-Cover texts
      being "A GNU Manual," and with the Back-Cover Texts as in (a)
      below.  A copy of the license is included in the section entitled
      "GNU Free Documentation License."
 
-     (a) The FSF's Back-Cover Text is: "You have freedom to copy and
-     modify this GNU Manual, like GNU software.  Copies published by
-     the Free Software Foundation raise funds for GNU development."
+     (a) The FSF's Back-Cover Text is: "You have the freedom to copy
+     and modify this GNU manual.  Buying copies from the FSF supports
+     it in developing GNU and promoting software freedom."
 
 * Menu:
 
@@ -283,8 +283,8 @@ where `$' denotes the line end:
 
    The `-w' or `--ignore-all-space' option is stronger still.  It
 ignores differences even if one line has white space where the other
-line has none.  "White space" characters include tab, newline, vertical
-tab, form feed, carriage return, and space; some locales may define
+line has none.  "White space" characters include tab, vertical tab,
+form feed, carriage return, and space; some locales may define
 additional characters to be white space.  With this option, `diff'
 considers the following two lines to be equivalent, where `$' denotes
 the line end and `^M' denotes a carriage return:
@@ -292,6 +292,11 @@ the line end and `^M' denotes a carriage return:
      Here lyeth  muche  rychnesse in lytell space.--  John Heywood$
        He relyeth much erychnes  seinly tells pace.  --John Heywood   ^M$
 
+   For many other programs newline is also a white space character, but
+`diff' is a line-oriented program and a newline character always ends a
+line.  Hence the `-w' or `--ignore-all-space' option does not ignore
+newline-related changes; it ignores only other white space changes.
+
 \1f
 File: diff.info,  Node: Blank Lines,  Next: Specified Lines,  Prev: White Space,  Up: Comparison
 
@@ -667,7 +672,7 @@ a traditional time stamp like `Thu Feb 21 23:30:39 2002' is used if the
 `LC_TIME' locale category is either `C' or `POSIX'.
 
    You can change the header's content with the `--label=LABEL' option;
-see *Note Alternate Names::.
+see *note Alternate Names::.
 
    Next come one or more hunks of differences; each hunk shows one area
 where the files differ.  Context format hunks look like this:
@@ -1779,11 +1784,12 @@ These adjustments can be applied to any output format.
 
 * Menu:
 
-* Tabs::       Preserving the alignment of tab stops.
-* Pagination:: Page numbering and time-stamping `diff' output.
+* Tabs::            Preserving the alignment of tab stops.
+* Trailing Blanks:: Suppressing blanks before empty output lines.
+* Pagination::      Page numbering and time-stamping `diff' output.
 
 \1f
-File: diff.info,  Node: Tabs,  Next: Pagination,  Up: Adjusting Output
+File: diff.info,  Node: Tabs,  Next: Trailing Blanks,  Up: Adjusting Output
 
 5.1 Preserving Tab Stop Alignment
 =================================
@@ -1815,9 +1821,33 @@ type indicator character.  Select this method with the `-T' or
 `--initial-tab' option.
 
 \1f
-File: diff.info,  Node: Pagination,  Prev: Tabs,  Up: Adjusting Output
+File: diff.info,  Node: Trailing Blanks,  Next: Pagination,  Prev: Tabs,  Up: Adjusting Output
 
-5.2 Paginating `diff' Output
+5.2 Omitting trailing blanks
+============================
+
+When outputting lines in normal or context format, or outputting an
+unchanged line in unified format, `diff' normally outputs a blank just
+before each line.  If the line is empty, the output of `diff' therefore
+contains trailing blanks even though the input does not contain them.
+For example, when outputting an unchanged empty line in context format,
+`diff' normally outputs a line with two leading spaces.
+
+   Some text editors and email agents routinely delete trailing blanks,
+so it can be a problem to deal with diff output files that contain
+them.  You can avoid this problem with the `--suppress-blank-empty'
+option.  It causes `diff' to omit trailing blanks at the end of output
+lines in normal, context, and unified format, unless the trailing
+blanks were already present in the input.  This changes the output
+format slightly, so that output lines are guaranteed to never end in a
+blank unless an input line ends in a blank.  This format is less likely
+to be munged by text editors or by transmission via email.  It is
+accepted by GNU `patch' as well.
+
+\1f
+File: diff.info,  Node: Pagination,  Prev: Trailing Blanks,  Up: Adjusting Output
+
+5.3 Paginating `diff' Output
 ============================
 
 It can be convenient to have long output page-numbered and time-stamped.
@@ -1893,7 +1923,7 @@ File: diff.info,  Node: Comparing Three Files,  Next: diff3 Merging,  Prev: diff
 ***********************
 
 Use the program `diff3' to compare three files and show any differences
-among them.  (`diff3' can also merge files; see *Note diff3 Merging::).
+among them.  (`diff3' can also merge files; see *note diff3 Merging::).
 
    The "normal" `diff3' output format shows each hunk of differences
 without surrounding context.  Hunks are labeled depending on whether
@@ -2003,7 +2033,7 @@ correctly.  *Note Tabs::, for more information.
 `FILE:Rc'
      This hunk contains the lines in the range R of file FILE.  The
      range R is a comma-separated pair of line numbers, or just one
-     number if the range is a singleton.  To edit this file to yield the
+     number if there is only one line.  To edit this file to yield the
      other files, one must change the specified lines to be the lines
      taken from the other files.  For example, `2:11,13c' means that
      the hunk contains lines 11 through 13 from the second file.
@@ -2363,20 +2393,24 @@ Follow each command with <RET>.
      what file and lines the version came from.
 
 `el'
+`e1'
      Edit a copy of the left version, then copy the result to the
      output.
 
 `er'
+`e2'
      Edit a copy of the right version, then copy the result to the
      output.
 
 `l'
+`1'
      Copy the left version to the output.
 
 `q'
      Quit.
 
 `r'
+`2'
      Copy the right version to the output.
 
 `s'
@@ -3349,7 +3383,8 @@ can be combined into a single command line word: `-bl' is equivalent to
 `-l'
 `--verbose'
      Output the (decimal) byte numbers and (octal) values of all
-     differing bytes, instead of the default standard output.
+     differing bytes, instead of the default standard output.  Also,
+     output the EOF message if one file is shorter than the other.
 
 `-n COUNT'
 `--bytes=COUNT'
@@ -3531,10 +3566,9 @@ optional argument.
      For proper operation, `patch' typically needs at least two lines of
      context.
 
-     On older systems, `diff' supports an obsolete option `-LINES' that
-     has effect when combined with `-c' or `-p'.  POSIX 1003.1-2001
-     (*note Standards conformance::) does not allow this; use `-C LINES'
-     instead.
+     For compatibility `diff' also supports an obsolete option syntax
+     `-LINES' that has effect when combined with `-c', `-p', or `-u'.
+     New scripts should use `-C LINES' or `-U LINES' instead.
 
 `--changed-group-format=FORMAT'
      Use FORMAT to output a line group containing differing lines from
@@ -3690,6 +3724,11 @@ optional argument.
      Assume that tab stops are set every COLUMNS (default 8) print
      columns.  *Note Tabs::.
 
+`--suppress-blank-empty'
+     Suppress any blanks before newlines when printing the
+     representation of an empty line, when outputting normal, context,
+     or unified format.  *Note Trailing Blanks::.
+
 `--to-file=FILE'
      Compare each operand to FILE; FILE may be a directory.
 
@@ -4453,20 +4492,10 @@ File: diff.info,  Node: Copying This Manual,  Next: Translations,  Prev: Project
 Appendix A Copying This Manual
 ******************************
 
-* Menu:
+                     Version 1.3, 3 November 2008
 
-* GNU Free Documentation License::  License for copying this manual.
-
-\1f
-File: diff.info,  Node: GNU Free Documentation License,  Up: Copying This Manual
-
-A.1 GNU Free Documentation License
-==================================
-
-                      Version 1.2, November 2002
-
-     Copyright (C) 2000,2001,2002 Free Software Foundation, Inc.
-     59 Temple Place, Suite 330, Boston, MA  02111-1307, USA
+     Copyright (C) 2000, 2001, 2002, 2007, 2008 Free Software Foundation, Inc.
+     `http://fsf.org/'
 
      Everyone is permitted to copy and distribute verbatim copies
      of this license document, but changing it is not allowed.
@@ -4568,6 +4597,9 @@ A.1 GNU Free Documentation License
      Page" means the text near the most prominent appearance of the
      work's title, preceding the beginning of the body of the text.
 
+     The "publisher" means any person or entity that distributes copies
+     of the Document to the public.
+
      A section "Entitled XYZ" means a named subunit of the Document
      whose title either is precisely XYZ or contains XYZ in parentheses
      following text that translates XYZ in another language.  (Here XYZ
@@ -4833,12 +4865,29 @@ A.1 GNU Free Documentation License
   9. TERMINATION
 
      You may not copy, modify, sublicense, or distribute the Document
-     except as expressly provided for under this License.  Any other
-     attempt to copy, modify, sublicense or distribute the Document is
-     void, and will automatically terminate your rights under this
-     License.  However, parties who have received copies, or rights,
-     from you under this License will not have their licenses
-     terminated so long as such parties remain in full compliance.
+     except as expressly provided under this License.  Any attempt
+     otherwise to copy, modify, sublicense, or distribute it is void,
+     and will automatically terminate your rights under this License.
+
+     However, if you cease all violation of this License, then your
+     license from a particular copyright holder is reinstated (a)
+     provisionally, unless and until the copyright holder explicitly
+     and finally terminates your license, and (b) permanently, if the
+     copyright holder fails to notify you of the violation by some
+     reasonable means prior to 60 days after the cessation.
+
+     Moreover, your license from a particular copyright holder is
+     reinstated permanently if the copyright holder notifies you of the
+     violation by some reasonable means, this is the first time you have
+     received notice of violation of this License (for any work) from
+     that copyright holder, and you cure the violation prior to 30 days
+     after your receipt of the notice.
+
+     Termination of your rights under this section does not terminate
+     the licenses of parties who have received copies or rights from
+     you under this License.  If your rights have been terminated and
+     not permanently reinstated, receipt of a copy of some or all of
+     the same material does not give you any rights to use it.
 
  10. FUTURE REVISIONS OF THIS LICENSE
 
@@ -4856,10 +4905,44 @@ A.1 GNU Free Documentation License
      published (not as a draft) by the Free Software Foundation.  If
      the Document does not specify a version number of this License,
      you may choose any version ever published (not as a draft) by the
-     Free Software Foundation.
-
-A.1.1 ADDENDUM: How to use this License for your documents
-----------------------------------------------------------
+     Free Software Foundation.  If the Document specifies that a proxy
+     can decide which future versions of this License can be used, that
+     proxy's public statement of acceptance of a version permanently
+     authorizes you to choose that version for the Document.
+
+ 11. RELICENSING
+
+     "Massive Multiauthor Collaboration Site" (or "MMC Site") means any
+     World Wide Web server that publishes copyrightable works and also
+     provides prominent facilities for anybody to edit those works.  A
+     public wiki that anybody can edit is an example of such a server.
+     A "Massive Multiauthor Collaboration" (or "MMC") contained in the
+     site means any set of copyrightable works thus published on the MMC
+     site.
+
+     "CC-BY-SA" means the Creative Commons Attribution-Share Alike 3.0
+     license published by Creative Commons Corporation, a not-for-profit
+     corporation with a principal place of business in San Francisco,
+     California, as well as future copyleft versions of that license
+     published by that same organization.
+
+     "Incorporate" means to publish or republish a Document, in whole or
+     in part, as part of another Document.
+
+     An MMC is "eligible for relicensing" if it is licensed under this
+     License, and if all works that were first published under this
+     License somewhere other than this MMC, and subsequently
+     incorporated in whole or in part into the MMC, (1) had no cover
+     texts or invariant sections, and (2) were thus incorporated prior
+     to November 1, 2008.
+
+     The operator of an MMC Site may republish an MMC contained in the
+     site under CC-BY-SA on the same site at any time before August 1,
+     2009, provided the MMC is eligible for relicensing.
+
+
+ADDENDUM: How to use this License for your documents
+====================================================
 
 To use this License in a document you have written, include a copy of
 the License in the document and put the following copyright and license
@@ -4867,7 +4950,7 @@ notices just after the title page:
 
        Copyright (C)  YEAR  YOUR NAME.
        Permission is granted to copy, distribute and/or modify this document
-       under the terms of the GNU Free Documentation License, Version 1.2
+       under the terms of the GNU Free Documentation License, Version 1.3
        or any later version published by the Free Software Foundation;
        with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
        Texts.  A copy of the license is included in the section entitled ``GNU
@@ -4952,13 +5035,11 @@ Appendix C Index
 * directory structure changes:           Changing Structure.  (line   6)
 * dry runs for patch:                    Dry Runs.            (line   6)
 * ed script output format:               ed Scripts.          (line   6)
-* EDITOR:                                Merge Commands.      (line  46)
+* EDITOR:                                Merge Commands.      (line  50)
 * empty files, removing:                 Creating and Removing.
                                                               (line   6)
-* exabyte, definition of:                cmp Options.         (line 105)
-* exbibyte, definition of:               cmp Options.         (line 109)
-* FDL, GNU Free Documentation License:   GNU Free Documentation License.
-                                                              (line   6)
+* exabyte, definition of:                cmp Options.         (line 106)
+* exbibyte, definition of:               cmp Options.         (line 110)
 * file name alternates:                  Alternate Names.     (line   6)
 * file names with unusual characters:    Unusual File Names.  (line   6)
 * format of diff output:                 Output Formats.      (line   6)
@@ -4969,8 +5050,8 @@ Appendix C Index
 * full lines:                            Incomplete Lines.    (line   6)
 * function headings, C:                  C Function Headings. (line   6)
 * fuzz factor when patching:             Inexact.             (line   6)
-* gibibyte, definition of:               cmp Options.         (line  88)
-* gigabyte, definition of:               cmp Options.         (line  84)
+* gibibyte, definition of:               cmp Options.         (line  89)
+* gigabyte, definition of:               cmp Options.         (line  85)
 * headings:                              Sections.            (line   6)
 * hunks:                                 Hunks.               (line   6)
 * hunks for diff3:                       diff3 Hunks.         (line   6)
@@ -4993,16 +5074,16 @@ Appendix C Index
 * invoking sdiff:                        Invoking sdiff.      (line   6)
 * keyboard input to patch:               patch and Keyboard Input.
                                                               (line   6)
-* kibibyte, definition of:               cmp Options.         (line  72)
-* kilobyte, definition of:               cmp Options.         (line  67)
+* kibibyte, definition of:               cmp Options.         (line  73)
+* kilobyte, definition of:               cmp Options.         (line  68)
 * LC_COLLATE:                            Comparing Directories.
                                                               (line   6)
 * LC_NUMERIC:                            Line Group Formats.  (line 144)
 * LC_TIME:                               Detailed Context.    (line  12)
 * line formats:                          Line Formats.        (line   6)
 * line group formats:                    Line Group Formats.  (line   6)
-* mebibyte, definition of:               cmp Options.         (line  81)
-* megabyte, definition of:               cmp Options.         (line  77)
+* mebibyte, definition of:               cmp Options.         (line  82)
+* megabyte, definition of:               cmp Options.         (line  78)
 * merge commands:                        Merge Commands.      (line   6)
 * merged diff3 format:                   Bypassing ed.        (line   6)
 * merged output format:                  If-then-else.        (line   6)
@@ -5039,15 +5120,15 @@ Appendix C Index
 * patches, shrinking:                    Generating Smaller Patches.
                                                               (line   6)
 * patching directories:                  patch Directories.   (line   6)
-* pebibyte, definition of:               cmp Options.         (line 102)
+* pebibyte, definition of:               cmp Options.         (line 103)
 * performance of diff:                   diff Performance.    (line   6)
-* petabyte, definition of:               cmp Options.         (line  98)
+* petabyte, definition of:               cmp Options.         (line  99)
 * POSIX <1>:                             Standards conformance.
                                                               (line   6)
 * POSIX:                                 patch and POSIX.     (line   6)
-* POSIXLY_CORRECT <1>:                   patch and POSIX.     (line   6)
-* POSIXLY_CORRECT:                       Standards conformance.
+* POSIXLY_CORRECT <1>:                   Standards conformance.
                                                               (line   6)
+* POSIXLY_CORRECT:                       patch and POSIX.     (line   6)
 * projects for directories:              Shortcomings.        (line   6)
 * quoting style:                         patch Quoting Style. (line   6)
 * QUOTING_STYLE:                         patch Quoting Style. (line  30)
@@ -5080,8 +5161,8 @@ Appendix C Index
                                                               (line   6)
 * tab and blank difference suppression:  White Space.         (line   6)
 * tab stop alignment:                    Tabs.                (line   6)
-* tebibyte, definition of:               cmp Options.         (line  95)
-* terabyte, definition of:               cmp Options.         (line  91)
+* tebibyte, definition of:               cmp Options.         (line  96)
+* terabyte, definition of:               cmp Options.         (line  92)
 * testing patch:                         Dry Runs.            (line   6)
 * text versus binary diff:               Binary.              (line   6)
 * time stamp format, context diffs:      Detailed Context.    (line  12)
@@ -5089,6 +5170,7 @@ Appendix C Index
 * time stamps on patched files:          Patching Time Stamps.
                                                               (line   6)
 * traditional patch:                     patch and Tradition. (line   6)
+* trailing blanks:                       Trailing Blanks.     (line   6)
 * two-column output:                     Side by Side.        (line   6)
 * unified output format:                 Unified Format.      (line   6)
 * unmerged change:                       Which Changes.       (line   6)
@@ -5097,127 +5179,127 @@ Appendix C Index
 * verbose messages from patch:           More or Fewer Messages.
                                                               (line   6)
 * version control:                       Revision Control.    (line   6)
-* VERSION_CONTROL <1>:                   Revision Control.    (line  22)
-* VERSION_CONTROL:                       Backup Names.        (line  21)
+* VERSION_CONTROL <1>:                   Backup Names.        (line  21)
+* VERSION_CONTROL:                       Revision Control.    (line  22)
 * white space in patches:                Changed White Space. (line   6)
-* yottabyte, definition of:              cmp Options.         (line 120)
-* zettabyte, definition of:              cmp Options.         (line 112)
+* yottabyte, definition of:              cmp Options.         (line 121)
+* zettabyte, definition of:              cmp Options.         (line 113)
 
 
 \1f
 Tag Table:
-Node: Top\7f1678
-Node: Overview\7f4139
-Node: Comparison\7f7763
-Node: Hunks\7f10461
-Node: White Space\7f11899
-Node: Blank Lines\7f13354
-Node: Specified Lines\7f14384
-Node: Case Folding\7f15506
-Node: Brief\7f15918
-Node: Binary\7f17237
-Node: Output Formats\7f21322
-Node: Sample diff Input\7f22042
-Node: Context\7f23536
-Node: Context Format\7f25108
-Node: Example Context\7f25895
-Node: Less Context\7f27397
-Node: Detailed Context\7f28581
-Node: Unified Format\7f30774
-Node: Example Unified\7f31565
-Node: Detailed Unified\7f32598
-Node: Sections\7f34240
-Node: Specified Headings\7f34994
-Node: C Function Headings\7f36543
-Node: Alternate Names\7f37385
-Node: Side by Side\7f38294
-Node: Side by Side Format\7f40438
-Node: Example Side by Side\7f41336
-Node: Normal\7f42671
-Node: Example Normal\7f43666
-Node: Detailed Normal\7f44397
-Node: Scripts\7f46131
-Node: ed Scripts\7f46531
-Node: Example ed\7f47733
-Node: Detailed ed\7f48178
-Node: Forward ed\7f49932
-Node: RCS\7f50703
-Node: If-then-else\7f51915
-Node: Line Group Formats\7f53588
-Node: Line Formats\7f59459
-Node: Example If-then-else\7f62724
-Node: Detailed If-then-else\7f63798
-Node: Incomplete Lines\7f65676
-Node: Comparing Directories\7f67308
-Node: Adjusting Output\7f71352
-Node: Tabs\7f71778
-Node: Pagination\7f73383
-Node: diff Performance\7f73836
-Node: Comparing Three Files\7f76919
-Node: Sample diff3 Input\7f77792
-Node: Example diff3 Normal\7f78735
-Node: Detailed diff3 Normal\7f79780
-Node: diff3 Hunks\7f81537
-Node: diff3 Merging\7f82828
-Node: Which Changes\7f85067
-Node: Marking Conflicts\7f86466
-Node: Bypassing ed\7f88920
-Node: Merging Incomplete Lines\7f90259
-Node: Saving the Changed File\7f90980
-Node: Interactive Merging\7f91591
-Node: sdiff Option Summary\7f92296
-Node: Merge Commands\7f93467
-Node: Merging with patch\7f94733
-Node: patch Input\7f97100
-Node: Revision Control\7f97777
-Node: Imperfect\7f98943
-Node: Changed White Space\7f100086
-Node: Reversed Patches\7f100878
-Node: Inexact\7f102338
-Node: Dry Runs\7f105892
-Node: Creating and Removing\7f106751
-Node: Patching Time Stamps\7f107797
-Node: Multiple Patches\7f109995
-Node: patch Directories\7f112653
-Node: Backups\7f114274
-Node: Backup Names\7f115335
-Ref: Backup Names-Footnote-1\7f118299
-Node: Reject Names\7f118426
-Node: patch Messages\7f119010
-Node: More or Fewer Messages\7f120065
-Node: patch and Keyboard Input\7f120691
-Node: patch Quoting Style\7f121717
-Node: patch and POSIX\7f122862
-Node: patch and Tradition\7f123697
-Node: Making Patches\7f127149
-Node: Tips for Patch Producers\7f127970
-Node: Tips for Patch Consumers\7f129221
-Node: Avoiding Common Mistakes\7f129853
-Node: Generating Smaller Patches\7f132373
-Node: Invoking cmp\7f134129
-Node: cmp Options\7f135547
-Node: Invoking diff\7f138960
-Node: diff Options\7f140813
-Node: Invoking diff3\7f149059
-Node: diff3 Options\7f149692
-Node: Invoking patch\7f152720
-Node: patch Options\7f153923
-Node: Invoking sdiff\7f159145
-Node: sdiff Options\7f160287
-Node: Standards conformance\7f163162
-Node: Projects\7f164903
-Node: Shortcomings\7f165609
-Node: Internationalization\7f166706
-Node: Changing Structure\7f167867
-Node: Special Files\7f168966
-Node: Unusual File Names\7f170073
-Node: Time Stamp Order\7f170707
-Node: Ignoring Changes\7f171345
-Node: Speedups\7f172110
-Node: Bugs\7f172569
-Node: Copying This Manual\7f173417
-Node: GNU Free Documentation License\7f173654
-Node: Translations\7f196061
-Node: Index\7f196428
+Node: Top\7f1675
+Node: Overview\7f4135
+Node: Comparison\7f7759
+Node: Hunks\7f10457
+Node: White Space\7f11895
+Node: Blank Lines\7f13623
+Node: Specified Lines\7f14653
+Node: Case Folding\7f15775
+Node: Brief\7f16187
+Node: Binary\7f17506
+Node: Output Formats\7f21591
+Node: Sample diff Input\7f22311
+Node: Context\7f23805
+Node: Context Format\7f25377
+Node: Example Context\7f26164
+Node: Less Context\7f27666
+Node: Detailed Context\7f28850
+Node: Unified Format\7f31043
+Node: Example Unified\7f31834
+Node: Detailed Unified\7f32867
+Node: Sections\7f34509
+Node: Specified Headings\7f35263
+Node: C Function Headings\7f36812
+Node: Alternate Names\7f37654
+Node: Side by Side\7f38563
+Node: Side by Side Format\7f40707
+Node: Example Side by Side\7f41605
+Node: Normal\7f42940
+Node: Example Normal\7f43935
+Node: Detailed Normal\7f44666
+Node: Scripts\7f46400
+Node: ed Scripts\7f46800
+Node: Example ed\7f48002
+Node: Detailed ed\7f48447
+Node: Forward ed\7f50201
+Node: RCS\7f50972
+Node: If-then-else\7f52184
+Node: Line Group Formats\7f53857
+Node: Line Formats\7f59728
+Node: Example If-then-else\7f62993
+Node: Detailed If-then-else\7f64067
+Node: Incomplete Lines\7f65945
+Node: Comparing Directories\7f67577
+Node: Adjusting Output\7f71621
+Node: Tabs\7f72123
+Node: Trailing Blanks\7f73733
+Node: Pagination\7f74954
+Node: diff Performance\7f75418
+Node: Comparing Three Files\7f78501
+Node: Sample diff3 Input\7f79374
+Node: Example diff3 Normal\7f80317
+Node: Detailed diff3 Normal\7f81362
+Node: diff3 Hunks\7f83117
+Node: diff3 Merging\7f84408
+Node: Which Changes\7f86647
+Node: Marking Conflicts\7f88046
+Node: Bypassing ed\7f90500
+Node: Merging Incomplete Lines\7f91839
+Node: Saving the Changed File\7f92560
+Node: Interactive Merging\7f93171
+Node: sdiff Option Summary\7f93876
+Node: Merge Commands\7f95047
+Node: Merging with patch\7f96331
+Node: patch Input\7f98698
+Node: Revision Control\7f99375
+Node: Imperfect\7f100541
+Node: Changed White Space\7f101684
+Node: Reversed Patches\7f102476
+Node: Inexact\7f103936
+Node: Dry Runs\7f107490
+Node: Creating and Removing\7f108349
+Node: Patching Time Stamps\7f109395
+Node: Multiple Patches\7f111593
+Node: patch Directories\7f114251
+Node: Backups\7f115872
+Node: Backup Names\7f116933
+Ref: Backup Names-Footnote-1\7f119897
+Node: Reject Names\7f120024
+Node: patch Messages\7f120608
+Node: More or Fewer Messages\7f121663
+Node: patch and Keyboard Input\7f122289
+Node: patch Quoting Style\7f123315
+Node: patch and POSIX\7f124460
+Node: patch and Tradition\7f125295
+Node: Making Patches\7f128747
+Node: Tips for Patch Producers\7f129568
+Node: Tips for Patch Consumers\7f130819
+Node: Avoiding Common Mistakes\7f131451
+Node: Generating Smaller Patches\7f133971
+Node: Invoking cmp\7f135727
+Node: cmp Options\7f137145
+Node: Invoking diff\7f140632
+Node: diff Options\7f142485
+Node: Invoking diff3\7f150912
+Node: diff3 Options\7f151545
+Node: Invoking patch\7f154573
+Node: patch Options\7f155776
+Node: Invoking sdiff\7f160998
+Node: sdiff Options\7f162140
+Node: Standards conformance\7f165015
+Node: Projects\7f166756
+Node: Shortcomings\7f167462
+Node: Internationalization\7f168559
+Node: Changing Structure\7f169720
+Node: Special Files\7f170819
+Node: Unusual File Names\7f171926
+Node: Time Stamp Order\7f172560
+Node: Ignoring Changes\7f173198
+Node: Speedups\7f173963
+Node: Bugs\7f174422
+Node: Copying This Manual\7f175270
+Node: Translations\7f200404
+Node: Index\7f200771
 \1f
 End Tag Table
diff --git a/contrib/diffutils/doc/diff.texi b/contrib/diffutils/doc/diff.texi
deleted file mode 100644 (file)
index a8724f4..0000000
+++ /dev/null
@@ -1,4649 +0,0 @@
-\input texinfo @c -*-texinfo-*-
-@comment $Id: diff.texi,v 1.25 2004/04/12 07:44:35 eggert Exp $
-@comment %**start of header
-@setfilename diff.info
-@include version.texi
-@settitle Comparing and Merging Files
-@syncodeindex vr cp
-@setchapternewpage odd
-@comment %**end of header
-@copying
-This manual is for GNU Diffutils
-(version @value{VERSION}, @value{UPDATED}),
-and documents the @acronym{GNU} @command{diff}, @command{diff3},
-@command{sdiff}, and @command{cmp} commands for showing the
-differences between files and the @acronym{GNU} @command{patch} command for
-using their output to update files.
-
-Copyright @copyright{} 1992, 1993, 1994, 1998, 2001, 2002, 2004 Free
-Software Foundation, Inc.
-
-@quotation
-Permission is granted to copy, distribute and/or modify this document
-under the terms of the GNU Free Documentation License, Version 1.1 or
-any later version published by the Free Software Foundation; with no
-Invariant Sections, with the Front-Cover texts being ``A GNU Manual,''
-and with the Back-Cover Texts as in (a) below.  A copy of the
-license is included in the section entitled ``GNU Free Documentation
-License.''
-
-(a) The FSF's Back-Cover Text is: ``You have freedom to copy and modify
-this GNU Manual, like GNU software.  Copies published by the Free
-Software Foundation raise funds for GNU development.''
-@end quotation
-@end copying
-
-@c Debian install-info (up through at least version 1.9.20) uses only the
-@c first dircategory.  Put this one first, as it is more useful in practice.
-@dircategory Individual utilities
-@direntry
-* cmp: (diff)Invoking cmp.                      Compare 2 files byte by byte.
-* diff: (diff)Invoking diff.                    Compare 2 files line by line.
-* diff3: (diff)Invoking diff3.                  Compare 3 files line by line.
-* patch: (diff)Invoking patch.                  Apply a patch to a file.
-* sdiff: (diff)Invoking sdiff.                  Merge 2 files side-by-side.
-@end direntry
-
-@dircategory Text creation and manipulation
-@direntry
-* Diff: (diff).                 Comparing and merging files.
-@end direntry
-
-@titlepage
-@title Comparing and Merging Files
-@subtitle for Diffutils @value{VERSION} and @code{patch} 2.5.4
-@subtitle @value{UPDATED}
-@author David MacKenzie, Paul Eggert, and Richard Stallman
-@page
-@vskip 0pt plus 1filll
-@insertcopying
-@end titlepage
-
-@shortcontents
-@contents
-
-@ifnottex
-@node Top
-@top Comparing and Merging Files
-
-@insertcopying
-@end ifnottex
-
-@menu
-* Overview::              Preliminary information.
-* Comparison::            What file comparison means.
-
-* Output Formats::        Formats for two-way difference reports.
-* Incomplete Lines::      Lines that lack trailing newlines.
-* Comparing Directories:: Comparing files and directories.
-* Adjusting Output::      Making @command{diff} output prettier.
-* diff Performance::      Making @command{diff} smarter or faster.
-
-* Comparing Three Files:: Formats for three-way difference reports.
-* diff3 Merging::         Merging from a common ancestor.
-
-* Interactive Merging::   Interactive merging with @command{sdiff}.
-
-* Merging with patch::    Using @command{patch} to change old files into new ones.
-* Making Patches::        Tips for making and using patch distributions.
-
-* Invoking cmp::          Compare two files byte by byte.
-* Invoking diff::         Compare two files line by line.
-* Invoking diff3::        Compare three files line by line.
-* Invoking patch::        Apply a diff file to an original.
-* Invoking sdiff::        Side-by-side merge of file differences.
-
-* Standards conformance:: Conformance to the @acronym{POSIX} standard.
-* Projects::              If you've found a bug or other shortcoming.
-
-* Copying This Manual::   How to make copies of this manual.
-* Translations::          Available translations of this manual.
-* Index::                 Index.
-@end menu
-
-@node Overview
-@unnumbered Overview
-@cindex overview of @command{diff} and @command{patch}
-
-Computer users often find occasion to ask how two files differ.  Perhaps
-one file is a newer version of the other file.  Or maybe the two files
-started out as identical copies but were changed by different people.
-
-You can use the @command{diff} command to show differences between two
-files, or each corresponding file in two directories.  @command{diff}
-outputs differences between files line by line in any of several
-formats, selectable by command line options.  This set of differences is
-often called a @dfn{diff} or @dfn{patch}.  For files that are identical,
-@command{diff} normally produces no output; for binary (non-text) files,
-@command{diff} normally reports only that they are different.
-
-You can use the @command{cmp} command to show the byte and line numbers
-where two files differ.  @command{cmp} can also show all the bytes
-that differ between the two files, side by side.  A way to compare
-two files character by character is the Emacs command @kbd{M-x
-compare-windows}.  @xref{Other Window, , Other Window, emacs, The @acronym{GNU}
-Emacs Manual}, for more information on that command.
-
-You can use the @command{diff3} command to show differences among three
-files.  When two people have made independent changes to a common
-original, @command{diff3} can report the differences between the original
-and the two changed versions, and can produce a merged file that
-contains both persons' changes together with warnings about conflicts.
-
-You can use the @command{sdiff} command to merge two files interactively.
-
-You can use the set of differences produced by @command{diff} to distribute
-updates to text files (such as program source code) to other people.
-This method is especially useful when the differences are small compared
-to the complete files.  Given @command{diff} output, you can use the
-@command{patch} program to update, or @dfn{patch}, a copy of the file.  If you
-think of @command{diff} as subtracting one file from another to produce
-their difference, you can think of @command{patch} as adding the difference
-to one file to reproduce the other.
-
-This manual first concentrates on making diffs, and later shows how to
-use diffs to update files.
-
-@acronym{GNU} @command{diff} was written by Paul Eggert, Mike Haertel,
-David Hayes, Richard Stallman, and Len Tower.  Wayne Davison designed and
-implemented the unified output format.  The basic algorithm is described
-by Eugene W. Myers in ``An O(ND) Difference Algorithm and its Variations'',
-@cite{Algorithmica} Vol.@: 1 No.@: 2, 1986, pp.@: 251--266; and in ``A File
-Comparison Program'', Webb Miller and Eugene W. Myers,
-@cite{Software---Practice and Experience} Vol.@: 15 No.@: 11, 1985,
-pp.@: 1025--1040.
-@c From: "Gene Myers" <gene@cs.arizona.edu>
-@c They are about the same basic algorithm; the Algorithmica
-@c paper gives a rigorous treatment and the sub-algorithm for
-@c delivering scripts and should be the primary reference, but
-@c both should be mentioned.
-The algorithm was independently discovered as described by E. Ukkonen in
-``Algorithms for Approximate String Matching'',
-@cite{Information and Control} Vol.@: 64, 1985, pp.@: 100--118.
-@c From: "Gene Myers" <gene@cs.arizona.edu>
-@c Date: Wed, 29 Sep 1993 08:27:55 MST
-@c Ukkonen should be given credit for also discovering the algorithm used
-@c in GNU diff.
-Unless the @option{--minimal} option is used, @command{diff} uses a
-heuristic by Paul Eggert that limits the cost to @math{O(N^1.5 log N)}
-at the price of producing suboptimal output for large inputs with many
-differences.  Related algorithms are surveyed by Alfred V. Aho in
-section 6.3 of ``Algorithms for Finding Patterns in Strings'',
-@cite{Handbook of Theoretical Computer Science} (Jan Van Leeuwen,
-ed.), Vol.@: A, @cite{Algorithms and Complexity}, Elsevier/MIT Press,
-1990, pp.@: 255--300.
-
-@acronym{GNU} @command{diff3} was written by Randy Smith.  @acronym{GNU}
-@command{sdiff} was written by Thomas Lord.  @acronym{GNU} @command{cmp}
-was written by Torbj@"orn Granlund and David MacKenzie.
-
-@acronym{GNU} @command{patch} was written mainly by Larry Wall and Paul Eggert;
-several @acronym{GNU} enhancements were contributed by Wayne Davison and
-David MacKenzie.  Parts of this manual are adapted from a manual page
-written by Larry Wall, with his permission.
-
-@node Comparison
-@chapter What Comparison Means
-@cindex introduction
-
-There are several ways to think about the differences between two files.
-One way to think of the differences is as a series of lines that were
-deleted from, inserted in, or changed in one file to produce the other
-file.  @command{diff} compares two files line by line, finds groups of
-lines that differ, and reports each group of differing lines.  It can
-report the differing lines in several formats, which have different
-purposes.
-
-@acronym{GNU} @command{diff} can show whether files are different
-without detailing the differences.  It also provides ways to suppress
-certain kinds of differences that are not important to you.  Most
-commonly, such differences are changes in the amount of white space
-between words or lines.  @command{diff} also provides ways to suppress
-differences in alphabetic case or in lines that match a regular
-expression that you provide.  These options can accumulate; for
-example, you can ignore changes in both white space and alphabetic
-case.
-
-Another way to think of the differences between two files is as a
-sequence of pairs of bytes that can be either identical or
-different.  @command{cmp} reports the differences between two files
-byte by byte, instead of line by line.  As a result, it is often
-more useful than @command{diff} for comparing binary files.  For text
-files, @command{cmp} is useful mainly when you want to know only whether
-two files are identical, or whether one file is a prefix of the other.
-
-To illustrate the effect that considering changes byte by byte
-can have compared with considering them line by line, think of what
-happens if a single newline character is added to the beginning of a
-file.  If that file is then compared with an otherwise identical file
-that lacks the newline at the beginning, @command{diff} will report that a
-blank line has been added to the file, while @command{cmp} will report that
-almost every byte of the two files differs.
-
-@command{diff3} normally compares three input files line by line, finds
-groups of lines that differ, and reports each group of differing lines.
-Its output is designed to make it easy to inspect two different sets of
-changes to the same file.
-
-@menu
-* Hunks::             Groups of differing lines.
-* White Space::       Suppressing differences in white space.
-* Blank Lines::       Suppressing differences whose lines are all blank.
-* Specified Lines::   Suppressing differences whose lines all match a pattern.
-* Case Folding::      Suppressing differences in alphabetic case.
-* Brief::             Summarizing which files are different.
-* Binary::            Comparing binary files or forcing text comparisons.
-@end menu
-
-@node Hunks
-@section Hunks
-@cindex hunks
-
-When comparing two files, @command{diff} finds sequences of lines common to
-both files, interspersed with groups of differing lines called
-@dfn{hunks}.  Comparing two identical files yields one sequence of
-common lines and no hunks, because no lines differ.  Comparing two
-entirely different files yields no common lines and one large hunk that
-contains all lines of both files.  In general, there are many ways to
-match up lines between two given files.  @command{diff} tries to minimize
-the total hunk size by finding large sequences of common lines
-interspersed with small hunks of differing lines.
-
-For example, suppose the file @file{F} contains the three lines
-@samp{a}, @samp{b}, @samp{c}, and the file @file{G} contains the same
-three lines in reverse order @samp{c}, @samp{b}, @samp{a}.  If
-@command{diff} finds the line @samp{c} as common, then the command
-@samp{diff F G} produces this output:
-
-@example
-1,2d0
-< a
-< b
-3a2,3
-> b
-> a
-@end example
-
-@noindent
-But if @command{diff} notices the common line @samp{b} instead, it produces
-this output:
-
-@example
-1c1
-< a
----
-> c
-3c3
-< c
----
-> a
-@end example
-
-@noindent
-It is also possible to find @samp{a} as the common line.  @command{diff}
-does not always find an optimal matching between the files; it takes
-shortcuts to run faster.  But its output is usually close to the
-shortest possible.  You can adjust this tradeoff with the
-@option{-d} or @option{--minimal} option (@pxref{diff Performance}).
-
-@node White Space
-@section Suppressing Differences in Blank and Tab Spacing
-@cindex blank and tab difference suppression
-@cindex tab and blank difference suppression
-
-The @option{-E} or @option{--ignore-tab-expansion} option ignores the
-distinction between tabs and spaces on input.  A tab is considered to be
-equivalent to the number of spaces to the next tab stop (@pxref{Tabs}).
-
-The @option{-b} or @option{--ignore-space-change} option is stronger.
-It ignores white space at line end, and considers all other sequences of
-one or more white space characters within a line to be equivalent.  With this
-option, @command{diff} considers the following two lines to be equivalent,
-where @samp{$} denotes the line end:
-
-@example
-Here lyeth  muche rychnesse  in lytell space.   -- John Heywood$
-Here lyeth muche rychnesse in lytell space. -- John Heywood   $
-@end example
-
-The @option{-w} or @option{--ignore-all-space} option is stronger still.
-It ignores differences even if one line has white space where
-the other line has none.  @dfn{White space} characters include
-tab, newline, vertical tab, form feed, carriage return, and space;
-some locales may define additional characters to be white space.
-With this option, @command{diff} considers the
-following two lines to be equivalent, where @samp{$} denotes the line
-end and @samp{^M} denotes a carriage return:
-
-@example
-Here lyeth  muche  rychnesse in lytell space.--  John Heywood$
-  He relyeth much erychnes  seinly tells pace.  --John Heywood   ^M$
-@end example
-
-@node Blank Lines
-@section Suppressing Differences Whose Lines Are All Blank
-@cindex blank line difference suppression
-
-The @option{-B} or @option{--ignore-blank-lines} option ignores changes
-that consist entirely of blank lines.  With this option, for example, a
-file containing
-@example
-1.  A point is that which has no part.
-
-2.  A line is breadthless length.
--- Euclid, The Elements, I
-@end example
-@noindent
-is considered identical to a file containing
-@example
-1.  A point is that which has no part.
-2.  A line is breadthless length.
-
-
--- Euclid, The Elements, I
-@end example
-
-Normally this option affects only lines that are completely empty, but
-if you also specify the @option{-b} or @option{--ignore-space-change}
-option, or the @option{-w} or @option{--ignore-all-space} option,
-lines are also affected if they look empty but contain white space.
-In other words, @option{-B} is equivalent to @samp{-I '^$'} by
-default, but it is equivalent to @option{-I '^[[:space:]]*$'} if
-@option{-b} or @option{-w} is also specified.
-
-@node Specified Lines
-@section Suppressing Differences Whose Lines All Match a Regular Expression
-@cindex regular expression suppression
-
-To ignore insertions and deletions of lines that match a
-@command{grep}-style regular expression, use the @option{-I
-@var{regexp}} or @option{--ignore-matching-lines=@var{regexp}} option.
-You should escape
-regular expressions that contain shell metacharacters to prevent the
-shell from expanding them.  For example, @samp{diff -I '^[[:digit:]]'} ignores
-all changes to lines beginning with a digit.
-
-However, @option{-I} only ignores the insertion or deletion of lines that
-contain the regular expression if every changed line in the hunk---every
-insertion and every deletion---matches the regular expression.  In other
-words, for each nonignorable change, @command{diff} prints the complete set
-of changes in its vicinity, including the ignorable ones.
-
-You can specify more than one regular expression for lines to ignore by
-using more than one @option{-I} option.  @command{diff} tries to match each
-line against each regular expression.
-
-@node Case Folding
-@section Suppressing Case Differences
-@cindex case difference suppression
-
-@acronym{GNU} @command{diff} can treat lower case letters as
-equivalent to their upper case counterparts, so that, for example, it
-considers @samp{Funky Stuff}, @samp{funky STUFF}, and @samp{fUNKy
-stuFf} to all be the same.  To request this, use the @option{-i} or
-@option{--ignore-case} option.
-
-@node Brief
-@section Summarizing Which Files Differ
-@cindex summarizing which files differ
-@cindex brief difference reports
-
-When you only want to find out whether files are different, and you
-don't care what the differences are, you can use the summary output
-format.  In this format, instead of showing the differences between the
-files, @command{diff} simply reports whether files differ.  The @option{-q}
-or @option{--brief} option selects this output format.
-
-This format is especially useful when comparing the contents of two
-directories.  It is also much faster than doing the normal line by line
-comparisons, because @command{diff} can stop analyzing the files as soon as
-it knows that there are any differences.
-
-You can also get a brief indication of whether two files differ by using
-@command{cmp}.  For files that are identical, @command{cmp} produces no
-output.  When the files differ, by default, @command{cmp} outputs the byte
-and line number where the first difference occurs, or reports that one
-file is a prefix of the other.  You can use
-the @option{-s}, @option{--quiet}, or @option{--silent} option to
-suppress that information, so that @command{cmp}
-produces no output and reports whether the files differ using only its
-exit status (@pxref{Invoking cmp}).
-
-@c Fix this.
-Unlike @command{diff}, @command{cmp} cannot compare directories; it can only
-compare two files.
-
-@node Binary
-@section Binary Files and Forcing Text Comparisons
-@cindex binary file diff
-@cindex text versus binary diff
-
-If @command{diff} thinks that either of the two files it is comparing is
-binary (a non-text file), it normally treats that pair of files much as
-if the summary output format had been selected (@pxref{Brief}), and
-reports only that the binary files are different.  This is because line
-by line comparisons are usually not meaningful for binary files.
-
-@command{diff} determines whether a file is text or binary by checking the
-first few bytes in the file; the exact number of bytes is system
-dependent, but it is typically several thousand.  If every byte in
-that part of the file is non-null, @command{diff} considers the file to be
-text; otherwise it considers the file to be binary.
-
-Sometimes you might want to force @command{diff} to consider files to be
-text.  For example, you might be comparing text files that contain
-null characters; @command{diff} would erroneously decide that those are
-non-text files.  Or you might be comparing documents that are in a
-format used by a word processing system that uses null characters to
-indicate special formatting.  You can force @command{diff} to consider all
-files to be text files, and compare them line by line, by using the
-@option{-a} or @option{--text} option.  If the files you compare using this
-option do not in fact contain text, they will probably contain few
-newline characters, and the @command{diff} output will consist of hunks
-showing differences between long lines of whatever characters the files
-contain.
-
-You can also force @command{diff} to report only whether files differ
-(but not how).  Use the @option{-q} or @option{--brief} option for
-this.
-
-Normally, differing binary files count as trouble because the
-resulting @command{diff} output does not capture all the differences.
-This trouble causes @command{diff} to exit with status 2.  However,
-this trouble cannot occur with the @option{-a} or @option{--text}
-option, or with the @option{-q} or @option{--brief} option, as these
-options both cause @command{diff} to generate a form of output that
-represents differences as requested.
-
-In operating systems that distinguish between text and binary files,
-@command{diff} normally reads and writes all data as text.  Use the
-@option{--binary} option to force @command{diff} to read and write binary
-data instead.  This option has no effect on a @acronym{POSIX}-compliant system
-like @acronym{GNU} or traditional Unix.  However, many personal computer
-operating systems represent the end of a line with a carriage return
-followed by a newline.  On such systems, @command{diff} normally ignores
-these carriage returns on input and generates them at the end of each
-output line, but with the @option{--binary} option @command{diff} treats
-each carriage return as just another input character, and does not
-generate a carriage return at the end of each output line.  This can be
-useful when dealing with non-text files that are meant to be
-interchanged with @acronym{POSIX}-compliant systems.
-
-The @option{--strip-trailing-cr} causes @command{diff} to treat input
-lines that end in carriage return followed by newline as if they end
-in plain newline.  This can be useful when comparing text that is
-imperfectly imported from many personal computer operating systems.
-This option affects how lines are read, which in turn affects how they
-are compared and output.
-
-If you want to compare two files byte by byte, you can use the
-@command{cmp} program with the @option{-l} or @option{--verbose}
-option to show the values of each differing byte in the two files.
-With @acronym{GNU} @command{cmp}, you can also use the @option{-b} or
-@option{--print-bytes} option to show the @acronym{ASCII} representation of
-those bytes.  @xref{Invoking cmp}, for more information.
-
-If @command{diff3} thinks that any of the files it is comparing is binary
-(a non-text file), it normally reports an error, because such
-comparisons are usually not useful.  @command{diff3} uses the same test as
-@command{diff} to decide whether a file is binary.  As with @command{diff}, if
-the input files contain a few non-text bytes but otherwise are like
-text files, you can force @command{diff3} to consider all files to be text
-files and compare them line by line by using the @option{-a} or
-@option{--text} option.
-
-@node Output Formats
-@chapter @command{diff} Output Formats
-@cindex output formats
-@cindex format of @command{diff} output
-
-@command{diff} has several mutually exclusive options for output format.
-The following sections describe each format, illustrating how
-@command{diff} reports the differences between two sample input files.
-
-@menu
-* Sample diff Input:: Sample @command{diff} input files for examples.
-* Context::           Showing differences with the surrounding text.
-* Side by Side::      Showing differences in two columns.
-* Normal::            Showing differences without surrounding text.
-* Scripts::           Generating scripts for other programs.
-* If-then-else::      Merging files with if-then-else.
-@end menu
-
-@node Sample diff Input
-@section Two Sample Input Files
-@cindex @command{diff} sample input
-@cindex sample input for @command{diff}
-
-Here are two sample files that we will use in numerous examples to
-illustrate the output of @command{diff} and how various options can change
-it.
-
-This is the file @file{lao}:
-
-@example
-The Way that can be told of is not the eternal Way;
-The name that can be named is not the eternal name.
-The Nameless is the origin of Heaven and Earth;
-The Named is the mother of all things.
-Therefore let there always be non-being,
-  so we may see their subtlety,
-And let there always be being,
-  so we may see their outcome.
-The two are the same,
-But after they are produced,
-  they have different names.
-@end example
-
-This is the file @file{tzu}:
-
-@example
-The Nameless is the origin of Heaven and Earth;
-The named is the mother of all things.
-
-Therefore let there always be non-being,
-  so we may see their subtlety,
-And let there always be being,
-  so we may see their outcome.
-The two are the same,
-But after they are produced,
-  they have different names.
-They both may be called deep and profound.
-Deeper and more profound,
-The door of all subtleties!
-@end example
-
-In this example, the first hunk contains just the first two lines of
-@file{lao}, the second hunk contains the fourth line of @file{lao}
-opposing the second and third lines of @file{tzu}, and the last hunk
-contains just the last three lines of @file{tzu}.
-
-@node Context
-@section Showing Differences in Their Context
-@cindex context output format
-@cindex @samp{!} output format
-
-Usually, when you are looking at the differences between files, you will
-also want to see the parts of the files near the lines that differ, to
-help you understand exactly what has changed.  These nearby parts of the
-files are called the @dfn{context}.
-
-@acronym{GNU} @command{diff} provides two output formats that show context
-around the differing lines: @dfn{context format} and @dfn{unified
-format}.  It can optionally show in which function or section of the
-file the differing lines are found.
-
-If you are distributing new versions of files to other people in the
-form of @command{diff} output, you should use one of the output formats
-that show context so that they can apply the diffs even if they have
-made small changes of their own to the files.  @command{patch} can apply
-the diffs in this case by searching in the files for the lines of
-context around the differing lines; if those lines are actually a few
-lines away from where the diff says they are, @command{patch} can adjust
-the line numbers accordingly and still apply the diff correctly.
-@xref{Imperfect}, for more information on using @command{patch} to apply
-imperfect diffs.
-
-@menu
-* Context Format::  An output format that shows surrounding lines.
-* Unified Format::  A more compact output format that shows context.
-* Sections::        Showing which sections of the files differences are in.
-* Alternate Names:: Showing alternate file names in context headers.
-@end menu
-
-@node Context Format
-@subsection Context Format
-
-The context output format shows several lines of context around the
-lines that differ.  It is the standard format for distributing updates
-to source code.
-
-To select this output format, use the @option{-C @var{lines}},
-@option{--context@r{[}=@var{lines}@r{]}}, or @option{-c} option.  The
-argument @var{lines} that some of these options take is the number of
-lines of context to show.  If you do not specify @var{lines}, it
-defaults to three.  For proper operation, @command{patch} typically needs
-at least two lines of context.
-
-@menu
-* Example Context::  Sample output in context format.
-* Less Context::     Another sample with less context.
-* Detailed Context:: A detailed description of the context output format.
-@end menu
-
-@node Example Context
-@subsubsection An Example of Context Format
-
-Here is the output of @samp{diff -c lao tzu} (@pxref{Sample diff Input},
-for the complete contents of the two files).  Notice that up to three
-lines that are not different are shown around each line that is
-different; they are the context lines.  Also notice that the first two
-hunks have run together, because their contents overlap.
-
-@example
-*** lao        2002-02-21 23:30:39.942229878 -0800
---- tzu        2002-02-21 23:30:50.442260588 -0800
-***************
-*** 1,7 ****
-- The Way that can be told of is not the eternal Way;
-- The name that can be named is not the eternal name.
-  The Nameless is the origin of Heaven and Earth;
-! The Named is the mother of all things.
-  Therefore let there always be non-being,
-    so we may see their subtlety,
-  And let there always be being,
---- 1,6 ----
-  The Nameless is the origin of Heaven and Earth;
-! The named is the mother of all things.
-! 
-  Therefore let there always be non-being,
-    so we may see their subtlety,
-  And let there always be being,
-***************
-*** 9,11 ****
---- 8,13 ----
-  The two are the same,
-  But after they are produced,
-    they have different names.
-+ They both may be called deep and profound.
-+ Deeper and more profound,
-+ The door of all subtleties!
-@end example
-
-@node Less Context
-@subsubsection An Example of Context Format with Less Context
-
-Here is the output of @samp{diff -C 1 lao tzu} (@pxref{Sample diff
-Input}, for the complete contents of the two files).  Notice that at
-most one context line is reported here.
-
-@example
-*** lao        2002-02-21 23:30:39.942229878 -0800
---- tzu        2002-02-21 23:30:50.442260588 -0800
-***************
-*** 1,5 ****
-- The Way that can be told of is not the eternal Way;
-- The name that can be named is not the eternal name.
-  The Nameless is the origin of Heaven and Earth;
-! The Named is the mother of all things.
-  Therefore let there always be non-being,
---- 1,4 ----
-  The Nameless is the origin of Heaven and Earth;
-! The named is the mother of all things.
-! 
-  Therefore let there always be non-being,
-***************
-*** 11 ****
---- 10,13 ----
-    they have different names.
-+ They both may be called deep and profound.
-+ Deeper and more profound,
-+ The door of all subtleties!
-@end example
-
-@node Detailed Context
-@subsubsection Detailed Description of Context Format
-
-The context output format starts with a two-line header, which looks
-like this:
-
-@example
-*** @var{from-file} @var{from-file-modification-time}
---- @var{to-file} @var{to-file-modification time}
-@end example
-
-@noindent
-@vindex LC_TIME
-@cindex time stamp format, context diffs
-The time stamp normally looks like @samp{2002-02-21 23:30:39.942229878
--0800} to indicate the date, time with fractional seconds, and time
-zone in @uref{ftp://ftp.isi.edu/in-notes/rfc2822.txt, Internet RFC
-2822 format}.  (The fractional seconds are omitted on hosts that do
-not support fractional time stamps.)  However, a traditional time
-stamp like @samp{Thu Feb 21 23:30:39 2002} is used if the
-@env{LC_TIME} locale category is either @samp{C} or @samp{POSIX}.
-
-You can change the header's content with the
-@option{--label=@var{label}} option; see @ref{Alternate Names}.
-
-Next come one or more hunks of differences; each hunk shows one area
-where the files differ.  Context format hunks look like this:
-
-@example
-***************
-*** @var{from-file-line-numbers} ****
-  @var{from-file-line}
-  @var{from-file-line}@dots{}
---- @var{to-file-line-numbers} ----
-  @var{to-file-line}
-  @var{to-file-line}@dots{}
-@end example
-
-If a hunk contains two or more lines, its line numbers look like
-@samp{@var{start},@var{end}}.  Otherwise only its end line number
-appears.  An empty hunk is considered to end at the line that precedes
-the hunk.
-
-The lines of context around the lines that differ start with two space
-characters.  The lines that differ between the two files start with one
-of the following indicator characters, followed by a space character:
-
-@table @samp
-@item !
-A line that is part of a group of one or more lines that changed between
-the two files.  There is a corresponding group of lines marked with
-@samp{!} in the part of this hunk for the other file.
-
-@item +
-An ``inserted'' line in the second file that corresponds to nothing in
-the first file.
-
-@item -
-A ``deleted'' line in the first file that corresponds to nothing in the
-second file.
-@end table
-
-If all of the changes in a hunk are insertions, the lines of
-@var{from-file} are omitted.  If all of the changes are deletions, the
-lines of @var{to-file} are omitted.
-
-@node Unified Format
-@subsection Unified Format
-@cindex unified output format
-@cindex @samp{+-} output format
-
-The unified output format is a variation on the context format that is
-more compact because it omits redundant context lines.  To select this
-output format, use the @option{-U @var{lines}},
-@option{--unified@r{[}=@var{lines}@r{]}}, or @option{-u}
-option.  The argument @var{lines} is the number of lines of context to
-show.  When it is not given, it defaults to three.
-
-At present, only @acronym{GNU} @command{diff} can produce this format and
-only @acronym{GNU} @command{patch} can automatically apply diffs in this
-format.  For proper operation, @command{patch} typically needs at
-least three lines of context.
-
-@menu
-* Example Unified::  Sample output in unified format.
-* Detailed Unified:: A detailed description of unified format.
-@end menu
-
-@node Example Unified
-@subsubsection An Example of Unified Format
-
-Here is the output of the command @samp{diff -u lao tzu}
-(@pxref{Sample diff Input}, for the complete contents of the two files):
-
-@example
---- lao        2002-02-21 23:30:39.942229878 -0800
-+++ tzu        2002-02-21 23:30:50.442260588 -0800
-@@@@ -1,7 +1,6 @@@@
--The Way that can be told of is not the eternal Way;
--The name that can be named is not the eternal name.
- The Nameless is the origin of Heaven and Earth;
--The Named is the mother of all things.
-+The named is the mother of all things.
-+
- Therefore let there always be non-being,
-   so we may see their subtlety,
- And let there always be being,
-@@@@ -9,3 +8,6 @@@@
- The two are the same,
- But after they are produced,
-   they have different names.
-+They both may be called deep and profound.
-+Deeper and more profound,
-+The door of all subtleties!
-@end example
-
-@node Detailed Unified
-@subsubsection Detailed Description of Unified Format
-
-The unified output format starts with a two-line header, which looks
-like this:
-
-@example
---- @var{from-file} @var{from-file-modification-time}
-+++ @var{to-file} @var{to-file-modification-time}
-@end example
-
-@noindent
-@cindex time stamp format, unified diffs
-The time stamp looks like @samp{2002-02-21 23:30:39.942229878 -0800}
-to indicate the date, time with fractional seconds, and time zone.
-The fractional seconds are omitted on hosts that do not support
-fractional time stamps.
-
-You can change the header's content with the
-@option{--label=@var{label}} option; see @xref{Alternate Names}.
-
-Next come one or more hunks of differences; each hunk shows one area
-where the files differ.  Unified format hunks look like this:
-
-@example
-@@@@ @var{from-file-line-numbers} @var{to-file-line-numbers} @@@@
- @var{line-from-either-file}
- @var{line-from-either-file}@dots{}
-@end example
-
-If a hunk contains just one line, only its start line number appears.
-Otherwise its line numbers look like @samp{@var{start},@var{count}}.
-An empty hunk is considered to start at the line that follows the hunk.
-
-If a hunk and its context contain two or more lines, its
-line numbers look like @samp{@var{start},@var{count}}.  Otherwise only
-its end line number appears.  An empty hunk is considered to end at
-the line that precedes the hunk.
-
-The lines common to both files begin with a space character.  The lines
-that actually differ between the two files have one of the following
-indicator characters in the left print column:
-
-@table @samp
-@item +
-A line was added here to the first file.
-
-@item -
-A line was removed here from the first file.
-@end table
-
-@node Sections
-@subsection Showing Which Sections Differences Are in
-@cindex headings
-@cindex section headings
-
-Sometimes you might want to know which part of the files each change
-falls in.  If the files are source code, this could mean which
-function was changed.  If the files are documents, it could mean which
-chapter or appendix was changed.  @acronym{GNU} @command{diff} can
-show this by displaying the nearest section heading line that precedes
-the differing lines.  Which lines are ``section headings'' is
-determined by a regular expression.
-
-@menu
-* Specified Headings::  Showing headings that match regular expressions.
-* C Function Headings:: Showing headings of C functions.
-@end menu
-
-@node Specified Headings
-@subsubsection Showing Lines That Match Regular Expressions
-@cindex specified headings
-@cindex regular expression matching headings
-
-To show in which sections differences occur for files that are not
-source code for C or similar languages, use the @option{-F @var{regexp}}
-or @option{--show-function-line=@var{regexp}} option.  @command{diff}
-considers lines that match the @command{grep}-style regular expression
-@var{regexp} to be the beginning
-of a section of the file.  Here are suggested regular expressions for
-some common languages:
-
-@c Please add to this list, e.g. Fortran, Pascal, Perl, Python.
-@table @samp
-@item ^[[:alpha:]$_]
-C, C++, Prolog
-@item ^(
-Lisp
-@item ^@@node
-Texinfo
-@end table
-
-This option does not automatically select an output format; in order to
-use it, you must select the context format (@pxref{Context Format}) or
-unified format (@pxref{Unified Format}).  In other output formats it
-has no effect.
-
-The @option{-F} or @option{--show-function-line} option finds the nearest
-unchanged line that precedes each hunk of differences and matches the
-given regular expression.  Then it adds that line to the end of the
-line of asterisks in the context format, or to the @samp{@@@@} line in
-unified format.  If no matching line exists, this option leaves the output for
-that hunk unchanged.  If that line is more than 40 characters long, it
-outputs only the first 40 characters.  You can specify more than one
-regular expression for such lines; @command{diff} tries to match each line
-against each regular expression, starting with the last one given.  This
-means that you can use @option{-p} and @option{-F} together, if you wish.
-
-@node C Function Headings
-@subsubsection Showing C Function Headings
-@cindex C function headings
-@cindex function headings, C
-
-To show in which functions differences occur for C and similar
-languages, you can use the @option{-p} or @option{--show-c-function} option.
-This option automatically defaults to the context output format
-(@pxref{Context Format}), with the default number of lines of context.
-You can override that number with @option{-C @var{lines}} elsewhere in the
-command line.  You can override both the format and the number with
-@option{-U @var{lines}} elsewhere in the command line.
-
-The @option{-p} or @option{--show-c-function} option is equivalent to
-@option{-F '^[[:alpha:]$_]'} if the unified format is specified, otherwise
-@option{-c -F '^[[:alpha:]$_]'} (@pxref{Specified Headings}).  @acronym{GNU}
-@command{diff} provides this option for the sake of convenience.
-
-@node Alternate Names
-@subsection Showing Alternate File Names
-@cindex alternate file names
-@cindex file name alternates
-
-If you are comparing two files that have meaningless or uninformative
-names, you might want @command{diff} to show alternate names in the header
-of the context and unified output formats.  To do this, use the
-@option{--label=@var{label}} option.  The first time
-you give this option, its argument replaces the name and date of the
-first file in the header; the second time, its argument replaces the
-name and date of the second file.  If you give this option more than
-twice, @command{diff} reports an error.  The @option{--label} option does not
-affect the file names in the @command{pr} header when the @option{-l} or
-@option{--paginate} option is used (@pxref{Pagination}).
-
-Here are the first two lines of the output from @samp{diff -C 2
---label=original --label=modified lao tzu}:
-
-@example
-*** original
---- modified
-@end example
-
-@node Side by Side
-@section Showing Differences Side by Side
-@cindex side by side
-@cindex two-column output
-@cindex columnar output
-
-@command{diff} can produce a side by side difference listing of two files.
-The files are listed in two columns with a gutter between them.  The
-gutter contains one of the following markers:
-
-@table @asis
-@item white space
-The corresponding lines are in common.  That is, either the lines are
-identical, or the difference is ignored because of one of the
-@option{--ignore} options (@pxref{White Space}).
-
-@item @samp{|}
-The corresponding lines differ, and they are either both complete
-or both incomplete.
-
-@item @samp{<}
-The files differ and only the first file contains the line.
-
-@item @samp{>}
-The files differ and only the second file contains the line.
-
-@item @samp{(}
-Only the first file contains the line, but the difference is ignored.
-
-@item @samp{)}
-Only the second file contains the line, but the difference is ignored.
-
-@item @samp{\}
-The corresponding lines differ, and only the first line is incomplete.
-
-@item @samp{/}
-The corresponding lines differ, and only the second line is incomplete.
-@end table
-
-Normally, an output line is incomplete if and only if the lines that it
-contains are incomplete; @xref{Incomplete Lines}.  However, when an
-output line represents two differing lines, one might be incomplete
-while the other is not.  In this case, the output line is complete,
-but its the gutter is marked @samp{\} if the first line is incomplete,
-@samp{/} if the second line is.
-
-Side by side format is sometimes easiest to read, but it has limitations.
-It generates much wider output than usual, and truncates lines that are
-too long to fit.  Also, it relies on lining up output more heavily than
-usual, so its output looks particularly bad if you use varying
-width fonts, nonstandard tab stops, or nonprinting characters.
-
-You can use the @command{sdiff} command to interactively merge side by side
-differences.  @xref{Interactive Merging}, for more information on merging files.
-
-@menu
-* Side by Side Format::  Controlling side by side output format.
-* Example Side by Side:: Sample side by side output.
-@end menu
-
-@node Side by Side Format
-@subsection Controlling Side by Side Format
-@cindex side by side format
-
-The @option{-y} or @option{--side-by-side} option selects side by side
-format.  Because side by side output lines contain two input lines, the
-output is wider than usual: normally 130 print columns, which can fit
-onto a traditional printer line.  You can set the width of the output
-with the @option{-W @var{columns}} or @option{--width=@var{columns}}
-option.  The output is split into two halves of equal width, separated by a
-small gutter to mark differences; the right half is aligned to a tab
-stop so that tabs line up.  Input lines that are too long to fit in half
-of an output line are truncated for output.
-
-The @option{--left-column} option prints only the left column of two
-common lines.  The @option{--suppress-common-lines} option suppresses
-common lines entirely.
-
-@node Example Side by Side
-@subsection An Example of Side by Side Format
-
-Here is the output of the command @samp{diff -y -W 72 lao tzu}
-(@pxref{Sample diff Input}, for the complete contents of the two files).
-
-@example
-The Way that can be told of is n   <
-The name that can be named is no   <
-The Nameless is the origin of He        The Nameless is the origin of He
-The Named is the mother of all t   |    The named is the mother of all t
-                                   >
-Therefore let there always be no        Therefore let there always be no
-  so we may see their subtlety,           so we may see their subtlety,
-And let there always be being,          And let there always be being,
-  so we may see their outcome.            so we may see their outcome.
-The two are the same,                   The two are the same,
-But after they are produced,            But after they are produced,
-  they have different names.              they have different names.
-                                   >    They both may be called deep and
-                                   >    Deeper and more profound,
-                                   >    The door of all subtleties!
-@end example
-
-@node Normal
-@section Showing Differences Without Context
-@cindex normal output format
-@cindex @samp{<} output format
-
-The ``normal'' @command{diff} output format shows each hunk of differences
-without any surrounding context.  Sometimes such output is the clearest
-way to see how lines have changed, without the clutter of nearby
-unchanged lines (although you can get similar results with the context
-or unified formats by using 0 lines of context).  However, this format
-is no longer widely used for sending out patches; for that purpose, the
-context format (@pxref{Context Format}) and the unified format
-(@pxref{Unified Format}) are superior.  Normal format is the default for
-compatibility with older versions of @command{diff} and the @acronym{POSIX}
-standard.  Use the @option{--normal} option to select this output
-format explicitly.
-
-@menu
-* Example Normal::  Sample output in the normal format.
-* Detailed Normal:: A detailed description of normal output format.
-@end menu
-
-@node Example Normal
-@subsection An Example of Normal Format
-
-Here is the output of the command @samp{diff lao tzu}
-(@pxref{Sample diff Input}, for the complete contents of the two files).
-Notice that it shows only the lines that are different between the two
-files.
-
-@example
-1,2d0
-< The Way that can be told of is not the eternal Way;
-< The name that can be named is not the eternal name.
-4c2,3
-< The Named is the mother of all things.
----
-> The named is the mother of all things.
-> 
-11a11,13
-> They both may be called deep and profound.
-> Deeper and more profound,
-> The door of all subtleties!
-@end example
-
-@node Detailed Normal
-@subsection Detailed Description of Normal Format
-
-The normal output format consists of one or more hunks of differences;
-each hunk shows one area where the files differ.  Normal format hunks
-look like this:
-
-@example
-@var{change-command}
-< @var{from-file-line}
-< @var{from-file-line}@dots{}
----
-> @var{to-file-line}
-> @var{to-file-line}@dots{}
-@end example
-
-There are three types of change commands.  Each consists of a line
-number or comma-separated range of lines in the first file, a single
-character indicating the kind of change to make, and a line number or
-comma-separated range of lines in the second file.  All line numbers are
-the original line numbers in each file.  The types of change commands
-are:
-
-@table @samp
-@item @var{l}a@var{r}
-Add the lines in range @var{r} of the second file after line @var{l} of
-the first file.  For example, @samp{8a12,15} means append lines 12--15
-of file 2 after line 8 of file 1; or, if changing file 2 into file 1,
-delete lines 12--15 of file 2.
-
-@item @var{f}c@var{t}
-Replace the lines in range @var{f} of the first file with lines in range
-@var{t} of the second file.  This is like a combined add and delete, but
-more compact.  For example, @samp{5,7c8,10} means change lines 5--7 of
-file 1 to read as lines 8--10 of file 2; or, if changing file 2 into
-file 1, change lines 8--10 of file 2 to read as lines 5--7 of file 1.
-
-@item @var{r}d@var{l}
-Delete the lines in range @var{r} from the first file; line @var{l} is where
-they would have appeared in the second file had they not been deleted.
-For example, @samp{5,7d3} means delete lines 5--7 of file 1; or, if
-changing file 2 into file 1, append lines 5--7 of file 1 after line 3 of
-file 2.
-@end table
-
-@node Scripts
-@section Making Edit Scripts
-@cindex script output formats
-
-Several output modes produce command scripts for editing @var{from-file}
-to produce @var{to-file}.
-
-@menu
-* ed Scripts:: Using @command{diff} to produce commands for @command{ed}.
-* Forward ed:: Making forward @command{ed} scripts.
-* RCS::        A special @command{diff} output format used by @acronym{RCS}.
-@end menu
-
-@node ed Scripts
-@subsection @command{ed} Scripts
-@cindex @command{ed} script output format
-
-@command{diff} can produce commands that direct the @command{ed} text editor
-to change the first file into the second file.  Long ago, this was the
-only output mode that was suitable for editing one file into another
-automatically; today, with @command{patch}, it is almost obsolete.  Use the
-@option{-e} or @option{--ed} option to select this output format.
-
-Like the normal format (@pxref{Normal}), this output format does not
-show any context; unlike the normal format, it does not include the
-information necessary to apply the diff in reverse (to produce the first
-file if all you have is the second file and the diff).
-
-If the file @file{d} contains the output of @samp{diff -e old new}, then
-the command @samp{(cat d && echo w) | ed - old} edits @file{old} to make
-it a copy of @file{new}.  More generally, if @file{d1}, @file{d2},
-@dots{}, @file{dN} contain the outputs of @samp{diff -e old new1},
-@samp{diff -e new1 new2}, @dots{}, @samp{diff -e newN-1 newN},
-respectively, then the command @samp{(cat d1 d2 @dots{} dN && echo w) |
-ed - old} edits @file{old} to make it a copy of @file{newN}.
-
-@menu
-* Example ed::  A sample @command{ed} script.
-* Detailed ed:: A detailed description of @command{ed} format.
-@end menu
-
-@node Example ed
-@subsubsection Example @command{ed} Script
-
-Here is the output of @samp{diff -e lao tzu} (@pxref{Sample
-diff Input}, for the complete contents of the two files):
-
-@example
-11a
-They both may be called deep and profound.
-Deeper and more profound,
-The door of all subtleties!
-.
-4c
-The named is the mother of all things.
-
-.
-1,2d
-@end example
-
-@node Detailed ed
-@subsubsection Detailed Description of @command{ed} Format
-
-The @command{ed} output format consists of one or more hunks of
-differences.  The changes closest to the ends of the files come first so
-that commands that change the number of lines do not affect how
-@command{ed} interprets line numbers in succeeding commands.  @command{ed}
-format hunks look like this:
-
-@example
-@var{change-command}
-@var{to-file-line}
-@var{to-file-line}@dots{}
-.
-@end example
-
-Because @command{ed} uses a single period on a line to indicate the
-end of input, @acronym{GNU} @command{diff} protects lines of changes
-that contain a single period on a line by writing two periods instead,
-then writing a subsequent @command{ed} command to change the two
-periods into one.  The @command{ed} format cannot represent an
-incomplete line, so if the second file ends in a changed incomplete
-line, @command{diff} reports an error and then pretends that a newline
-was appended.
-
-There are three types of change commands.  Each consists of a line
-number or comma-separated range of lines in the first file and a single
-character indicating the kind of change to make.  All line numbers are
-the original line numbers in the file.  The types of change commands
-are:
-
-@table @samp
-@item @var{l}a
-Add text from the second file after line @var{l} in the first file.  For
-example, @samp{8a} means to add the following lines after line 8 of file
-1.
-
-@item @var{r}c
-Replace the lines in range @var{r} in the first file with the following
-lines.  Like a combined add and delete, but more compact.  For example,
-@samp{5,7c} means change lines 5--7 of file 1 to read as the text file
-2.
-
-@item @var{r}d
-Delete the lines in range @var{r} from the first file.  For example,
-@samp{5,7d} means delete lines 5--7 of file 1.
-@end table
-
-@node Forward ed
-@subsection Forward @command{ed} Scripts
-@cindex forward @command{ed} script output format
-
-@command{diff} can produce output that is like an @command{ed} script, but
-with hunks in forward (front to back) order.  The format of the commands
-is also changed slightly: command characters precede the lines they
-modify, spaces separate line numbers in ranges, and no attempt is made
-to disambiguate hunk lines consisting of a single period.  Like
-@command{ed} format, forward @command{ed} format cannot represent incomplete
-lines.
-
-Forward @command{ed} format is not very useful, because neither @command{ed}
-nor @command{patch} can apply diffs in this format.  It exists mainly for
-compatibility with older versions of @command{diff}.  Use the @option{-f} or
-@option{--forward-ed} option to select it.
-
-@node RCS
-@subsection @acronym{RCS} Scripts
-@cindex @acronym{RCS} script output format
-
-The @acronym{RCS} output format is designed specifically for use by
-the Revision Control System, which is a set of free programs used for
-organizing different versions and systems of files.  Use the
-@option{-n} or @option{--rcs} option to select this output format.  It
-is like the forward @command{ed} format (@pxref{Forward ed}), but it
-can represent arbitrary changes to the contents of a file because it
-avoids the forward @command{ed} format's problems with lines
-consisting of a single period and with incomplete lines.  Instead of
-ending text sections with a line consisting of a single period, each
-command specifies the number of lines it affects; a combination of the
-@samp{a} and @samp{d} commands are used instead of @samp{c}.  Also, if
-the second file ends in a changed incomplete line, then the output
-also ends in an incomplete line.
-
-Here is the output of @samp{diff -n lao tzu} (@pxref{Sample
-diff Input}, for the complete contents of the two files):
-
-@example
-d1 2
-d4 1
-a4 2
-The named is the mother of all things.
-
-a11 3
-They both may be called deep and profound.
-Deeper and more profound,
-The door of all subtleties!
-@end example
-
-@node If-then-else
-@section Merging Files with If-then-else
-@cindex merged output format
-@cindex if-then-else output format
-@cindex C if-then-else output format
-@cindex @command{ifdef} output format
-
-You can use @command{diff} to merge two files of C source code.  The output
-of @command{diff} in this format contains all the lines of both files.
-Lines common to both files are output just once; the differing parts are
-separated by the C preprocessor directives @code{#ifdef @var{name}} or
-@code{#ifndef @var{name}}, @code{#else}, and @code{#endif}.  When
-compiling the output, you select which version to use by either defining
-or leaving undefined the macro @var{name}.
-
-To merge two files, use @command{diff} with the @option{-D @var{name}} or
-@option{--ifdef=@var{name}} option.  The argument @var{name} is the C
-preprocessor identifier to use in the @code{#ifdef} and @code{#ifndef}
-directives.
-
-For example, if you change an instance of @code{wait (&s)} to
-@code{waitpid (-1, &s, 0)} and then merge the old and new files with
-the @option{--ifdef=HAVE_WAITPID} option, then the affected part of your code
-might look like this:
-
-@example
-    do @{
-#ifndef HAVE_WAITPID
-        if ((w = wait (&s)) < 0  &&  errno != EINTR)
-#else /* HAVE_WAITPID */
-        if ((w = waitpid (-1, &s, 0)) < 0  &&  errno != EINTR)
-#endif /* HAVE_WAITPID */
-            return w;
-    @} while (w != child);
-@end example
-
-You can specify formats for languages other than C by using line group
-formats and line formats, as described in the next sections.
-
-@menu
-* Line Group Formats::    Formats for general if-then-else line groups.
-* Line Formats::          Formats for each line in a line group.
-* Example If-then-else::  Sample if-then-else format output.
-* Detailed If-then-else:: A detailed description of if-then-else format.
-@end menu
-
-@node Line Group Formats
-@subsection Line Group Formats
-@cindex line group formats
-@cindex formats for if-then-else line groups
-
-Line group formats let you specify formats suitable for many
-applications that allow if-then-else input, including programming
-languages and text formatting languages.  A line group format specifies
-the output format for a contiguous group of similar lines.
-
-For example, the following command compares the TeX files @file{old}
-and @file{new}, and outputs a merged file in which old regions are
-surrounded by @samp{\begin@{em@}}-@samp{\end@{em@}} lines, and new
-regions are surrounded by @samp{\begin@{bf@}}-@samp{\end@{bf@}} lines.
-
-@example
-diff \
-   --old-group-format='\begin@{em@}
-%<\end@{em@}
-' \
-   --new-group-format='\begin@{bf@}
-%>\end@{bf@}
-' \
-   old new
-@end example
-
-The following command is equivalent to the above example, but it is a
-little more verbose, because it spells out the default line group formats.
-
-@example
-diff \
-   --old-group-format='\begin@{em@}
-%<\end@{em@}
-' \
-   --new-group-format='\begin@{bf@}
-%>\end@{bf@}
-' \
-   --unchanged-group-format='%=' \
-   --changed-group-format='\begin@{em@}
-%<\end@{em@}
-\begin@{bf@}
-%>\end@{bf@}
-' \
-   old new
-@end example
-
-Here is a more advanced example, which outputs a diff listing with
-headers containing line numbers in a ``plain English'' style.
-
-@example
-diff \
-   --unchanged-group-format='' \
-   --old-group-format='-------- %dn line%(n=1?:s) deleted at %df:
-%<' \
-   --new-group-format='-------- %dN line%(N=1?:s) added after %de:
-%>' \
-   --changed-group-format='-------- %dn line%(n=1?:s) changed at %df:
-%<-------- to:
-%>' \
-   old new
-@end example
-
-To specify a line group format, use @command{diff} with one of the options
-listed below.  You can specify up to four line group formats, one for
-each kind of line group.  You should quote @var{format}, because it
-typically contains shell metacharacters.
-
-@table @option
-@item --old-group-format=@var{format}
-These line groups are hunks containing only lines from the first file.
-The default old group format is the same as the changed group format if
-it is specified; otherwise it is a format that outputs the line group as-is.
-
-@item --new-group-format=@var{format}
-These line groups are hunks containing only lines from the second
-file.  The default new group format is same as the changed group
-format if it is specified; otherwise it is a format that outputs the
-line group as-is.
-
-@item --changed-group-format=@var{format}
-These line groups are hunks containing lines from both files.  The
-default changed group format is the concatenation of the old and new
-group formats.
-
-@item --unchanged-group-format=@var{format}
-These line groups contain lines common to both files.  The default
-unchanged group format is a format that outputs the line group as-is.
-@end table
-
-In a line group format, ordinary characters represent themselves;
-conversion specifications start with @samp{%} and have one of the
-following forms.
-
-@table @samp
-@item %<
-stands for the lines from the first file, including the trailing newline.
-Each line is formatted according to the old line format (@pxref{Line Formats}).
-
-@item %>
-stands for the lines from the second file, including the trailing newline.
-Each line is formatted according to the new line format.
-
-@item %=
-stands for the lines common to both files, including the trailing newline.
-Each line is formatted according to the unchanged line format.
-
-@item %%
-stands for @samp{%}.
-
-@item %c'@var{C}'
-where @var{C} is a single character, stands for @var{C}.
-@var{C} may not be a backslash or an apostrophe.
-For example, @samp{%c':'} stands for a colon, even inside
-the then-part of an if-then-else format, which a colon would
-normally terminate.
-
-@item %c'\@var{O}'
-where @var{O} is a string of 1, 2, or 3 octal digits,
-stands for the character with octal code @var{O}.
-For example, @samp{%c'\0'} stands for a null character.
-
-@item @var{F}@var{n}
-where @var{F} is a @code{printf} conversion specification and @var{n} is one
-of the following letters, stands for @var{n}'s value formatted with @var{F}.
-
-@table @samp
-@item e
-The line number of the line just before the group in the old file.
-
-@item f
-The line number of the first line in the group in the old file;
-equals @var{e} + 1.
-
-@item l
-The line number of the last line in the group in the old file.
-
-@item m
-The line number of the line just after the group in the old file;
-equals @var{l} + 1.
-
-@item n
-The number of lines in the group in the old file; equals @var{l} - @var{f} + 1.
-
-@item E, F, L, M, N
-Likewise, for lines in the new file.
-
-@end table
-
-@vindex LC_NUMERIC
-The @code{printf} conversion specification can be @samp{%d},
-@samp{%o}, @samp{%x}, or @samp{%X}, specifying decimal, octal,
-lower case hexadecimal, or upper case hexadecimal output
-respectively.  After the @samp{%} the following options can appear in
-sequence: a series of zero or more flags; an integer
-specifying the minimum field width; and a period followed by an
-optional integer specifying the minimum number of digits.
-The flags are @samp{-} for left-justification, @samp{'} for separating
-the digit into groups as specified by the @env{LC_NUMERIC} locale category,
-and @samp{0} for padding with zeros instead of spaces.
-For example, @samp{%5dN} prints the number of new lines in the group
-in a field of width 5 characters, using the @code{printf} format @code{"%5d"}.
-
-@item (@var{A}=@var{B}?@var{T}:@var{E})
-If @var{A} equals @var{B} then @var{T} else @var{E}.
-@var{A} and @var{B} are each either a decimal constant
-or a single letter interpreted as above.
-This format spec is equivalent to @var{T} if
-@var{A}'s value equals @var{B}'s; otherwise it is equivalent to @var{E}.
-
-For example, @samp{%(N=0?no:%dN) line%(N=1?:s)} is equivalent to
-@samp{no lines} if @var{N} (the number of lines in the group in the
-new file) is 0, to @samp{1 line} if @var{N} is 1, and to @samp{%dN lines}
-otherwise.
-@end table
-
-@node Line Formats
-@subsection Line Formats
-@cindex line formats
-
-Line formats control how each line taken from an input file is
-output as part of a line group in if-then-else format.
-
-For example, the following command outputs text with a one-character
-change indicator to the left of the text.  The first character of output
-is @samp{-} for deleted lines, @samp{|} for added lines, and a space for
-unchanged lines.  The formats contain newline characters where newlines
-are desired on output.
-
-@example
-diff \
-   --old-line-format='-%l
-' \
-   --new-line-format='|%l
-' \
-   --unchanged-line-format=' %l
-' \
-   old new
-@end example
-
-To specify a line format, use one of the following options.  You should
-quote @var{format}, since it often contains shell metacharacters.
-
-@table @option
-@item --old-line-format=@var{format}
-formats lines just from the first file.
-
-@item --new-line-format=@var{format}
-formats lines just from the second file.
-
-@item --unchanged-line-format=@var{format}
-formats lines common to both files.
-
-@item --line-format=@var{format}
-formats all lines; in effect, it sets all three above options simultaneously.
-@end table
-
-In a line format, ordinary characters represent themselves;
-conversion specifications start with @samp{%} and have one of the
-following forms.
-
-@table @samp
-@item %l
-stands for the contents of the line, not counting its trailing
-newline (if any).  This format ignores whether the line is incomplete;
-@xref{Incomplete Lines}.
-
-@item %L
-stands for the contents of the line, including its trailing newline
-(if any).  If a line is incomplete, this format preserves its
-incompleteness.
-
-@item %%
-stands for @samp{%}.
-
-@item %c'@var{C}'
-where @var{C} is a single character, stands for @var{C}.
-@var{C} may not be a backslash or an apostrophe.
-For example, @samp{%c':'} stands for a colon.
-
-@item %c'\@var{O}'
-where @var{O} is a string of 1, 2, or 3 octal digits,
-stands for the character with octal code @var{O}.
-For example, @samp{%c'\0'} stands for a null character.
-
-@item @var{F}n
-where @var{F} is a @code{printf} conversion specification,
-stands for the line number formatted with @var{F}.
-For example, @samp{%.5dn} prints the line number using the
-@code{printf} format @code{"%.5d"}.  @xref{Line Group Formats}, for
-more about printf conversion specifications.
-
-@end table
-
-The default line format is @samp{%l} followed by a newline character.
-
-If the input contains tab characters and it is important that they line
-up on output, you should ensure that @samp{%l} or @samp{%L} in a line
-format is just after a tab stop (e.g.@: by preceding @samp{%l} or
-@samp{%L} with a tab character), or you should use the @option{-t} or
-@option{--expand-tabs} option.
-
-Taken together, the line and line group formats let you specify many
-different formats.  For example, the following command uses a format
-similar to normal @command{diff} format.  You can tailor this command
-to get fine control over @command{diff} output.
-
-@example
-diff \
-   --old-line-format='< %l
-' \
-   --new-line-format='> %l
-' \
-   --old-group-format='%df%(f=l?:,%dl)d%dE
-%<' \
-   --new-group-format='%dea%dF%(F=L?:,%dL)
-%>' \
-   --changed-group-format='%df%(f=l?:,%dl)c%dF%(F=L?:,%dL)
-%<---
-%>' \
-   --unchanged-group-format='' \
-   old new
-@end example
-
-@node Example If-then-else
-@subsection An Example of If-then-else Format
-
-Here is the output of @samp{diff -DTWO lao tzu} (@pxref{Sample
-diff Input}, for the complete contents of the two files):
-
-@example
-#ifndef TWO
-The Way that can be told of is not the eternal Way;
-The name that can be named is not the eternal name.
-#endif /* ! TWO */
-The Nameless is the origin of Heaven and Earth;
-#ifndef TWO
-The Named is the mother of all things.
-#else /* TWO */
-The named is the mother of all things.
-
-#endif /* TWO */
-Therefore let there always be non-being,
-  so we may see their subtlety,
-And let there always be being,
-  so we may see their outcome.
-The two are the same,
-But after they are produced,
-  they have different names.
-#ifdef TWO
-They both may be called deep and profound.
-Deeper and more profound,
-The door of all subtleties!
-#endif /* TWO */
-@end example
-
-@node Detailed If-then-else
-@subsection Detailed Description of If-then-else Format
-
-For lines common to both files, @command{diff} uses the unchanged line
-group format.  For each hunk of differences in the merged output
-format, if the hunk contains only lines from the first file,
-@command{diff} uses the old line group format; if the hunk contains only
-lines from the second file, @command{diff} uses the new group format;
-otherwise, @command{diff} uses the changed group format.
-
-The old, new, and unchanged line formats specify the output format of
-lines from the first file, lines from the second file, and lines common
-to both files, respectively.
-
-The option @option{--ifdef=@var{name}} is equivalent to
-the following sequence of options using shell syntax:
-
-@example
---old-group-format='#ifndef @var{name}
-%<#endif /* ! @var{name} */
-' \
---new-group-format='#ifdef @var{name}
-%>#endif /* @var{name} */
-' \
---unchanged-group-format='%=' \
---changed-group-format='#ifndef @var{name}
-%<#else /* @var{name} */
-%>#endif /* @var{name} */
-'
-@end example
-
-You should carefully check the @command{diff} output for proper nesting.
-For example, when using the @option{-D @var{name}} or
-@option{--ifdef=@var{name}} option, you should check that if the
-differing lines contain any of the C preprocessor directives
-@samp{#ifdef}, @samp{#ifndef}, @samp{#else}, @samp{#elif}, or
-@samp{#endif}, they are nested properly and match.  If they don't, you
-must make corrections manually.  It is a good idea to carefully check
-the resulting code anyway to make sure that it really does what you
-want it to; depending on how the input files were produced, the output
-might contain duplicate or otherwise incorrect code.
-
-The @command{patch} @option{-D @var{name}} option behaves like
-the @command{diff} @option{-D @var{name}} option, except it operates on
-a file and a diff to produce a merged file; @xref{patch Options}.
-
-@node Incomplete Lines
-@chapter Incomplete Lines
-@cindex incomplete lines
-@cindex full lines
-@cindex newline treatment by @command{diff}
-
-When an input file ends in a non-newline character, its last line is
-called an @dfn{incomplete line} because its last character is not a
-newline.  All other lines are called @dfn{full lines} and end in a
-newline character.  Incomplete lines do not match full lines unless
-differences in white space are ignored (@pxref{White Space}).
-
-An incomplete line is normally distinguished on output from a full
-line by a following line that starts with @samp{\}.  However, the
-@acronym{RCS} format (@pxref{RCS}) outputs the incomplete line as-is,
-without any trailing newline or following line.  The side by side
-format normally represents incomplete lines as-is, but in some cases
-uses a @samp{\} or @samp{/} gutter marker; @xref{Side by Side}.  The
-if-then-else line format preserves a line's incompleteness with
-@samp{%L}, and discards the newline with @samp{%l}; @xref{Line
-Formats}.  Finally, with the @command{ed} and forward @command{ed}
-output formats (@pxref{Output Formats}) @command{diff} cannot
-represent an incomplete line, so it pretends there was a newline and
-reports an error.
-
-For example, suppose @file{F} and @file{G} are one-byte files that
-contain just @samp{f} and @samp{g}, respectively.  Then @samp{diff F G}
-outputs
-
-@example
-1c1
-< f
-\ No newline at end of file
----
-> g
-\ No newline at end of file
-@end example
-
-@noindent
-(The exact message may differ in non-English locales.)
-@samp{diff -n F G} outputs the following without a trailing newline:
-
-@example
-d1 1
-a1 1
-g
-@end example
-
-@noindent
-@samp{diff -e F G} reports two errors and outputs the following:
-
-@example
-1c
-g
-.
-@end example
-
-@node Comparing Directories
-@chapter Comparing Directories
-
-@vindex LC_COLLATE
-You can use @command{diff} to compare some or all of the files in two
-directory trees.  When both file name arguments to @command{diff} are
-directories, it compares each file that is contained in both
-directories, examining file names in alphabetical order as specified by
-the @env{LC_COLLATE} locale category.  Normally
-@command{diff} is silent about pairs of files that contain no differences,
-but if you use the @option{-s} or @option{--report-identical-files} option,
-it reports pairs of identical files.  Normally @command{diff} reports
-subdirectories common to both directories without comparing
-subdirectories' files, but if you use the @option{-r} or
-@option{--recursive} option, it compares every corresponding pair of files
-in the directory trees, as many levels deep as they go.
-
-For file names that are in only one of the directories, @command{diff}
-normally does not show the contents of the file that exists; it reports
-only that the file exists in that directory and not in the other.  You
-can make @command{diff} act as though the file existed but was empty in the
-other directory, so that it outputs the entire contents of the file that
-actually exists.  (It is output as either an insertion or a
-deletion, depending on whether it is in the first or the second
-directory given.)  To do this, use the @option{-N} or @option{--new-file}
-option.
-
-If the older directory contains one or more large files that are not in
-the newer directory, you can make the patch smaller by using the
-@option{--unidirectional-new-file} option instead of @option{-N}.
-This option is like @option{-N} except that it only inserts the contents
-of files that appear in the second directory but not the first (that is,
-files that were added).  At the top of the patch, write instructions for
-the user applying the patch to remove the files that were deleted before
-applying the patch.  @xref{Making Patches}, for more discussion of
-making patches for distribution.
-
-To ignore some files while comparing directories, use the @option{-x
-@var{pattern}} or @option{--exclude=@var{pattern}} option.  This option
-ignores any files or subdirectories whose base names match the shell
-pattern @var{pattern}.  Unlike in the shell, a period at the start of
-the base of a file name matches a wildcard at the start of a pattern.
-You should enclose @var{pattern} in quotes so that the shell does not
-expand it.  For example, the option @option{-x '*.[ao]'} ignores any file
-whose name ends with @samp{.a} or @samp{.o}.
-
-This option accumulates if you specify it more than once.  For example,
-using the options @option{-x 'RCS' -x '*,v'} ignores any file or
-subdirectory whose base name is @samp{RCS} or ends with @samp{,v}.
-
-If you need to give this option many times, you can instead put the
-patterns in a file, one pattern per line, and use the @option{-X
-@var{file}} or @option{--exclude-from=@var{file}} option.  Trailing
-white space and empty lines are ignored in the pattern file.
-
-If you have been comparing two directories and stopped partway through,
-later you might want to continue where you left off.  You can do this by
-using the @option{-S @var{file}} or @option{--starting-file=@var{file}}
-option.  This compares only the file @var{file} and all alphabetically
-later files in the topmost directory level.
-
-If two directories differ only in that file names are lower case in
-one directory and upper case in the upper, @command{diff} normally
-reports many differences because it compares file names in a
-case sensitive way.  With the @option{--ignore-file-name-case} option,
-@command{diff} ignores case differences in file names, so that for example
-the contents of the file @file{Tao} in one directory are compared to
-the contents of the file @file{TAO} in the other.  The
-@option{--no-ignore-file-name-case} option cancels the effect of the
-@option{--ignore-file-name-case} option, reverting to the default
-behavior.
-
-If an @option{-x @var{pattern}} or @option{--exclude=@var{pattern}}
-option, or an @option{-X @var{file}} or
-@option{--exclude-from=@var{file}} option,
-is specified while the @option{--ignore-file-name-case} option is in
-effect, case is ignored when excluding file names matching the
-specified patterns.
-
-@node Adjusting Output
-@chapter Making @command{diff} Output Prettier
-
-@command{diff} provides several ways to adjust the appearance of its output.
-These adjustments can be applied to any output format.
-
-@menu
-* Tabs::       Preserving the alignment of tab stops.
-* Pagination:: Page numbering and time-stamping @command{diff} output.
-@end menu
-
-@node Tabs
-@section Preserving Tab Stop Alignment
-@cindex tab stop alignment
-@cindex aligning tab stops
-
-The lines of text in some of the @command{diff} output formats are
-preceded by one or two characters that indicate whether the text is
-inserted, deleted, or changed.  The addition of those characters can
-cause tabs to move to the next tab stop, throwing off the alignment of
-columns in the line.  @acronym{GNU} @command{diff} provides two ways
-to make tab-aligned columns line up correctly.
-
-The first way is to have @command{diff} convert all tabs into the correct
-number of spaces before outputting them; select this method with the
-@option{-t} or @option{--expand-tabs} option.  To use this form of output with
-@command{patch}, you must give @command{patch} the @option{-l} or
-@option{--ignore-white-space} option (@pxref{Changed White Space}, for more
-information).  @command{diff} normally assumes that tab stops are set
-every 8 print columns, but this can be altered by the
-@option{--tabsize=@var{columns}} option.
-
-The other method for making tabs line up correctly is to add a tab
-character instead of a space after the indicator character at the
-beginning of the line.  This ensures that all following tab characters
-are in the same position relative to tab stops that they were in the
-original files, so that the output is aligned correctly.  Its
-disadvantage is that it can make long lines too long to fit on one line
-of the screen or the paper.  It also does not work with the unified
-output format, which does not have a space character after the change
-type indicator character.  Select this method with the @option{-T} or
-@option{--initial-tab} option.
-
-@node Pagination
-@section Paginating @command{diff} Output
-@cindex paginating @command{diff} output
-
-It can be convenient to have long output page-numbered and time-stamped.
-The @option{-l} or @option{--paginate} option does this by sending the
-@command{diff} output through the @command{pr} program.  Here is what the page
-header might look like for @samp{diff -lc lao tzu}:
-
-@example
-2002-02-22 14:20                 diff -lc lao tzu                 Page 1
-@end example
-
-@node diff Performance
-@chapter @command{diff} Performance Tradeoffs
-@cindex performance of @command{diff}
-
-@acronym{GNU} @command{diff} runs quite efficiently; however, in some
-circumstances you can cause it to run faster or produce a more compact
-set of changes.
-
-One way to improve @command{diff} performance is to use hard or
-symbolic links to files instead of copies.  This improves performance
-because @command{diff} normally does not need to read two hard or
-symbolic links to the same file, since their contents must be
-identical.  For example, suppose you copy a large directory hierarchy,
-make a few changes to the copy, and then often use @samp{diff -r} to
-compare the original to the copy.  If the original files are
-read-only, you can greatly improve performance by creating the copy
-using hard or symbolic links (e.g., with @acronym{GNU} @samp{cp -lR} or
-@samp{cp -sR}).  Before editing a file in the copy for the first time,
-you should break the link and replace it with a regular copy.
-
-You can also affect the performance of @acronym{GNU} @command{diff} by
-giving it options that change the way it compares files.
-Performance has more than one dimension.  These options improve one
-aspect of performance at the cost of another, or they improve
-performance in some cases while hurting it in others.
-
-The way that @acronym{GNU} @command{diff} determines which lines have
-changed always comes up with a near-minimal set of differences.
-Usually it is good enough for practical purposes.  If the
-@command{diff} output is large, you might want @command{diff} to use a
-modified algorithm that sometimes produces a smaller set of
-differences.  The @option{-d} or @option{--minimal} option does this;
-however, it can also cause @command{diff} to run more slowly than
-usual, so it is not the default behavior.
-
-When the files you are comparing are large and have small groups of
-changes scattered throughout them, you can use the
-@option{--speed-large-files} option to make a different modification to
-the algorithm that @command{diff} uses.  If the input files have a constant
-small density of changes, this option speeds up the comparisons without
-changing the output.  If not, @command{diff} might produce a larger set of
-differences; however, the output will still be correct.
-
-Normally @command{diff} discards the prefix and suffix that is common to
-both files before it attempts to find a minimal set of differences.
-This makes @command{diff} run faster, but occasionally it may produce
-non-minimal output.  The @option{--horizon-lines=@var{lines}} option
-prevents @command{diff} from discarding the last @var{lines} lines of the
-prefix and the first @var{lines} lines of the suffix.  This gives
-@command{diff} further opportunities to find a minimal output.
-
-Suppose a run of changed lines includes a sequence of lines at one end
-and there is an identical sequence of lines just outside the other end.
-The @command{diff} command is free to choose which identical sequence is
-included in the hunk.  In this case, @command{diff} normally shifts the
-hunk's boundaries when this merges adjacent hunks, or shifts a hunk's
-lines towards the end of the file.  Merging hunks can make the output
-look nicer in some cases.
-
-@node Comparing Three Files
-@chapter Comparing Three Files
-@cindex comparing three files
-@cindex format of @command{diff3} output
-
-Use the program @command{diff3} to compare three files and show any
-differences among them.  (@command{diff3} can also merge files; see
-@ref{diff3 Merging}).
-
-The ``normal'' @command{diff3} output format shows each hunk of
-differences without surrounding context.  Hunks are labeled depending
-on whether they are two-way or three-way, and lines are annotated by
-their location in the input files.
-
-@xref{Invoking diff3}, for more information on how to run @command{diff3}.
-
-@menu
-* Sample diff3 Input::    Sample @command{diff3} input for examples.
-* Example diff3 Normal::  Sample output in the normal format.
-* diff3 Hunks::           The format of normal output format.
-* Detailed diff3 Normal:: A detailed description of normal output format.
-@end menu
-
-@node Sample diff3 Input
-@section A Third Sample Input File
-@cindex @command{diff3} sample input
-@cindex sample input for @command{diff3}
-
-Here is a third sample file that will be used in examples to illustrate
-the output of @command{diff3} and how various options can change it.  The
-first two files are the same that we used for @command{diff} (@pxref{Sample
-diff Input}).  This is the third sample file, called @file{tao}:
-
-@example
-The Way that can be told of is not the eternal Way;
-The name that can be named is not the eternal name.
-The Nameless is the origin of Heaven and Earth;
-The named is the mother of all things.
-
-Therefore let there always be non-being,
-  so we may see their subtlety,
-And let there always be being,
-  so we may see their result.
-The two are the same,
-But after they are produced,
-  they have different names.
-
-  -- The Way of Lao-Tzu, tr. Wing-tsit Chan
-@end example
-
-@node Example diff3 Normal
-@section An Example of @command{diff3} Normal Format
-
-Here is the output of the command @samp{diff3 lao tzu tao}
-(@pxref{Sample diff3 Input}, for the complete contents of the files).
-Notice that it shows only the lines that are different among the three
-files.
-
-@example
-====2
-1:1,2c
-3:1,2c
-  The Way that can be told of is not the eternal Way;
-  The name that can be named is not the eternal name.
-2:0a
-====1
-1:4c
-  The Named is the mother of all things.
-2:2,3c
-3:4,5c
-  The named is the mother of all things.
-  
-====3
-1:8c
-2:7c
-    so we may see their outcome.
-3:9c
-    so we may see their result.
-====
-1:11a
-2:11,13c
-  They both may be called deep and profound.
-  Deeper and more profound,
-  The door of all subtleties!
-3:13,14c
-  
-    -- The Way of Lao-Tzu, tr. Wing-tsit Chan
-@end example
-
-@node Detailed diff3 Normal
-@section Detailed Description of @command{diff3} Normal Format
-
-Each hunk begins with a line marked @samp{====}.  Three-way hunks have
-plain @samp{====} lines, and two-way hunks have @samp{1}, @samp{2}, or
-@samp{3} appended to specify which of the three input files differ in
-that hunk.  The hunks contain copies of two or three sets of input
-lines each preceded by one or two commands identifying where the lines
-came from.
-
-Normally, two spaces precede each copy of an input line to distinguish
-it from the commands.  But with the @option{-T} or @option{--initial-tab}
-option, @command{diff3} uses a tab instead of two spaces; this lines up
-tabs correctly.  @xref{Tabs}, for more information.
-
-Commands take the following forms:
-
-@table @samp
-@item @var{file}:@var{l}a
-This hunk appears after line @var{l} of file @var{file}, and
-contains no lines in that file.  To edit this file to yield the other
-files, one must append hunk lines taken from the other files.  For
-example, @samp{1:11a} means that the hunk follows line 11 in the first
-file and contains no lines from that file.
-
-@item @var{file}:@var{r}c
-This hunk contains the lines in the range @var{r} of file @var{file}.
-The range @var{r} is a comma-separated pair of line numbers, or just one
-number if the range is a singleton.  To edit this file to yield the
-other files, one must change the specified lines to be the lines taken
-from the other files.  For example, @samp{2:11,13c} means that the hunk
-contains lines 11 through 13 from the second file.
-@end table
-
-If the last line in a set of input lines is incomplete
-(@pxref{Incomplete Lines}), it is distinguished on output from a full
-line by a following line that starts with @samp{\}.
-
-@node diff3 Hunks
-@section @command{diff3} Hunks
-@cindex hunks for @command{diff3}
-@cindex @command{diff3} hunks
-
-Groups of lines that differ in two or three of the input files are
-called @dfn{diff3 hunks}, by analogy with @command{diff} hunks
-(@pxref{Hunks}).  If all three input files differ in a @command{diff3}
-hunk, the hunk is called a @dfn{three-way hunk}; if just two input files
-differ, it is a @dfn{two-way hunk}.
-
-As with @command{diff}, several solutions are possible.  When comparing the
-files @samp{A}, @samp{B}, and @samp{C}, @command{diff3} normally finds
-@command{diff3} hunks by merging the two-way hunks output by the two
-commands @samp{diff A B} and @samp{diff A C}.  This does not necessarily
-minimize the size of the output, but exceptions should be rare.
-
-For example, suppose @file{F} contains the three lines @samp{a},
-@samp{b}, @samp{f}, @file{G} contains the lines @samp{g}, @samp{b},
-@samp{g}, and @file{H} contains the lines @samp{a}, @samp{b},
-@samp{h}.  @samp{diff3 F G H} might output the following:
-
-@example
-====2
-1:1c
-3:1c
-  a
-2:1c
-  g
-====
-1:3c
-  f
-2:3c
-  g
-3:3c
-  h
-@end example
-
-@noindent
-because it found a two-way hunk containing @samp{a} in the first and
-third files and @samp{g} in the second file, then the single line
-@samp{b} common to all three files, then a three-way hunk containing
-the last line of each file.
-
-@node diff3 Merging
-@chapter Merging From a Common Ancestor
-@cindex merging from a common ancestor
-
-When two people have made changes to copies of the same file,
-@command{diff3} can produce a merged output that contains both sets of
-changes together with warnings about conflicts.
-
-One might imagine programs with names like @command{diff4} and @command{diff5}
-to compare more than three files simultaneously, but in practice the
-need rarely arises.  You can use @command{diff3} to merge three or more
-sets of changes to a file by merging two change sets at a time.
-
-@command{diff3} can incorporate changes from two modified versions into a
-common preceding version.  This lets you merge the sets of changes
-represented by the two newer files.  Specify the common ancestor version
-as the second argument and the two newer versions as the first and third
-arguments, like this:
-
-@example
-diff3 @var{mine} @var{older} @var{yours}
-@end example
-
-@noindent
-You can remember the order of the arguments by noting that they are in
-alphabetical order.
-
-@cindex conflict
-@cindex overlap
-You can think of this as subtracting @var{older} from @var{yours} and
-adding the result to @var{mine}, or as merging into @var{mine} the
-changes that would turn @var{older} into @var{yours}.  This merging is
-well-defined as long as @var{mine} and @var{older} match in the
-neighborhood of each such change.  This fails to be true when all three
-input files differ or when only @var{older} differs; we call this
-a @dfn{conflict}.  When all three input files differ, we call the
-conflict an @dfn{overlap}.
-
-@command{diff3} gives you several ways to handle overlaps and conflicts.
-You can omit overlaps or conflicts, or select only overlaps,
-or mark conflicts with special @samp{<<<<<<<} and @samp{>>>>>>>} lines.
-
-@command{diff3} can output the merge results as an @command{ed} script that
-that can be applied to the first file to yield the merged output.
-However, it is usually better to have @command{diff3} generate the merged
-output directly; this bypasses some problems with @command{ed}.
-
-@menu
-* Which Changes::            Selecting changes to incorporate.
-* Marking Conflicts::        Marking conflicts.
-* Bypassing ed::             Generating merged output directly.
-* Merging Incomplete Lines:: How @command{diff3} merges incomplete lines.
-* Saving the Changed File::  Emulating System V behavior.
-@end menu
-
-@node Which Changes
-@section Selecting Which Changes to Incorporate
-@cindex overlapping change, selection of
-@cindex unmerged change
-
-You can select all unmerged changes from @var{older} to @var{yours} for merging
-into @var{mine} with the @option{-e} or @option{--ed} option.  You can
-select only the nonoverlapping unmerged changes with @option{-3} or
-@option{--easy-only}, and you can select only the overlapping changes with
-@option{-x} or @option{--overlap-only}.
-
-The @option{-e}, @option{-3} and @option{-x} options select only
-@dfn{unmerged changes}, i.e.@: changes where @var{mine} and @var{yours}
-differ; they ignore changes from @var{older} to @var{yours} where
-@var{mine} and @var{yours} are identical, because they assume that such
-changes have already been merged.  If this assumption is not a safe
-one, you can use the @option{-A} or @option{--show-all} option
-(@pxref{Marking Conflicts}).
-
-Here is the output of the command @command{diff3} with each of these three
-options (@pxref{Sample diff3 Input}, for the complete contents of the files).
-Notice that @option{-e} outputs the union of the disjoint sets of changes
-output by @option{-3} and @option{-x}.
-
-Output of @samp{diff3 -e lao tzu tao}:
-@example
-11a
-
-  -- The Way of Lao-Tzu, tr. Wing-tsit Chan
-.
-8c
-  so we may see their result.
-.
-@end example
-
-Output of @samp{diff3 -3 lao tzu tao}:
-@example
-8c
-  so we may see their result.
-.
-@end example
-
-Output of @samp{diff3 -x lao tzu tao}:
-@example
-11a
-
-  -- The Way of Lao-Tzu, tr. Wing-tsit Chan
-.
-@end example
-
-@node Marking Conflicts
-@section Marking Conflicts
-@cindex conflict marking
-@cindex @samp{<<<<<<<} for marking conflicts
-
-@command{diff3} can mark conflicts in the merged output by
-bracketing them with special marker lines.  A conflict
-that comes from two files @var{A} and @var{B} is marked as follows:
-
-@example
-<<<<<<< @var{A}
-@r{lines from @var{A}}
-=======
-@r{lines from @var{B}}
->>>>>>> @var{B}
-@end example
-
-A conflict that comes from three files @var{A}, @var{B} and @var{C} is
-marked as follows:
-
-@example
-<<<<<<< @var{A}
-@r{lines from @var{A}}
-||||||| @var{B}
-@r{lines from @var{B}}
-=======
-@r{lines from @var{C}}
->>>>>>> @var{C}
-@end example
-
-The @option{-A} or @option{--show-all} option acts like the @option{-e}
-option, except that it brackets conflicts, and it outputs all changes
-from @var{older} to @var{yours}, not just the unmerged changes.  Thus,
-given the sample input files (@pxref{Sample diff3 Input}), @samp{diff3
--A lao tzu tao} puts brackets around the conflict where only @file{tzu}
-differs:
-
-@example
-<<<<<<< tzu
-=======
-The Way that can be told of is not the eternal Way;
-The name that can be named is not the eternal name.
->>>>>>> tao
-@end example
-
-And it outputs the three-way conflict as follows:
-
-@example
-<<<<<<< lao
-||||||| tzu
-They both may be called deep and profound.
-Deeper and more profound,
-The door of all subtleties!
-=======
-
-  -- The Way of Lao-Tzu, tr. Wing-tsit Chan
->>>>>>> tao
-@end example
-
-The @option{-E} or @option{--show-overlap} option outputs less information
-than the @option{-A} or @option{--show-all} option, because it outputs only
-unmerged changes, and it never outputs the contents of the second
-file.  Thus the @option{-E} option acts like the @option{-e} option,
-except that it brackets the first and third files from three-way
-overlapping changes.  Similarly, @option{-X} acts like @option{-x}, except
-it brackets all its (necessarily overlapping) changes.  For example,
-for the three-way overlapping change above, the @option{-E} and @option{-X}
-options output the following:
-
-@example
-<<<<<<< lao
-=======
-
-  -- The Way of Lao-Tzu, tr. Wing-tsit Chan
->>>>>>> tao
-@end example
-
-If you are comparing files that have meaningless or uninformative names,
-you can use the @option{--label=@var{label}}
-option to show alternate names in the @samp{<<<<<<<}, @samp{|||||||}
-and @samp{>>>>>>>} brackets.  This option can be given up to three
-times, once for each input file.  Thus @samp{diff3 -A --label X
---label Y --label Z A
-B C} acts like @samp{diff3 -A A B C}, except that the output looks like
-it came from files named @samp{X}, @samp{Y} and @samp{Z} rather than
-from files named @samp{A}, @samp{B} and @samp{C}.
-
-@node Bypassing ed
-@section Generating the Merged Output Directly
-@cindex merged @command{diff3} format
-
-With the @option{-m} or @option{--merge} option, @command{diff3} outputs the
-merged file directly.  This is more efficient than using @command{ed} to
-generate it, and works even with non-text files that @command{ed} would
-reject.  If you specify @option{-m} without an @command{ed} script option,
-@option{-A} is assumed.
-
-For example, the command @samp{diff3 -m lao tzu tao}
-(@pxref{Sample diff3 Input} for a copy of the input files) would output
-the following:
-
-@example
-<<<<<<< tzu
-=======
-The Way that can be told of is not the eternal Way;
-The name that can be named is not the eternal name.
->>>>>>> tao
-The Nameless is the origin of Heaven and Earth;
-The Named is the mother of all things.
-Therefore let there always be non-being,
-  so we may see their subtlety,
-And let there always be being,
-  so we may see their result.
-The two are the same,
-But after they are produced,
-  they have different names.
-<<<<<<< lao
-||||||| tzu
-They both may be called deep and profound.
-Deeper and more profound,
-The door of all subtleties!
-=======
-
-  -- The Way of Lao-Tzu, tr. Wing-tsit Chan
->>>>>>> tao
-@end example
-
-@node Merging Incomplete Lines
-@section How @command{diff3} Merges Incomplete Lines
-@cindex incomplete line merging
-
-With @option{-m}, incomplete lines (@pxref{Incomplete Lines}) are simply
-copied to the output as they are found; if the merged output ends in an
-conflict and one of the input files ends in an incomplete
-line, succeeding @samp{|||||||}, @samp{=======} or @samp{>>>>>>>}
-brackets appear somewhere other than the start of a line because
-they are appended to the incomplete line.
-
-Without @option{-m}, if an @command{ed} script option is specified and an
-incomplete line is found, @command{diff3} generates a warning and acts as
-if a newline had been present.
-
-@node Saving the Changed File
-@section Saving the Changed File
-@cindex System V @command{diff3} compatibility
-
-Traditional Unix @command{diff3} generates an @command{ed} script without the
-trailing @samp{w} and @samp{q} commands that save the changes.
-System V @command{diff3} generates these extra commands.  @acronym{GNU}
-@command{diff3} normally behaves like traditional Unix
-@command{diff3}, but with the @option{-i} option it behaves like
-System V @command{diff3} and appends the @samp{w} and @samp{q}
-commands.
-
-The @option{-i} option requires one of the @command{ed} script options
-@option{-AeExX3}, and is incompatible with the merged output option
-@option{-m}.
-
-@node Interactive Merging
-@chapter Interactive Merging with @command{sdiff}
-@cindex diff merging
-@cindex interactive merging
-
-With @command{sdiff}, you can merge two files interactively based on a
-side-by-side @option{-y} format comparison (@pxref{Side by Side}).  Use
-@option{-o @var{file}} or @option{--output=@var{file}} to specify where to
-put the merged text.  @xref{Invoking sdiff}, for more details on the
-options to @command{sdiff}.
-
-Another way to merge files interactively is to use the Emacs Lisp
-package @command{emerge}.  @xref{emerge, , emerge, emacs, The
-@acronym{GNU} Emacs Manual}, for more information.
-
-@menu
-* sdiff Option Summary:: Summary of @command{sdiff} options.
-* Merge Commands::       Merging two files interactively.
-@end menu
-
-@node sdiff Option Summary
-@section Specifying @command{diff} Options to @command{sdiff}
-@cindex @command{sdiff} output format
-
-The following @command{sdiff} options have the same meaning as for
-@command{diff}.  @xref{diff Options}, for the use of these options.
-
-@example
--a -b -d -i -t -v
--B -E -I @var{regexp}
-
---expand-tabs
---ignore-blank-lines  --ignore-case
---ignore-matching-lines=@var{regexp}  --ignore-space-change
---ignore-tab-expansion
---left-column  --minimal  --speed-large-files
---strip-trailing-cr  --suppress-common-lines
---tabsize=@var{columns}  --text  --version  --width=@var{columns}
-@end example
-
-For historical reasons, @command{sdiff} has alternate names for some
-options.  The @option{-l} option is equivalent to the
-@option{--left-column} option, and similarly @option{-s} is equivalent
-to @option{--suppress-common-lines}.  The meaning of the @command{sdiff}
-@option{-w} and @option{-W} options is interchanged from that of
-@command{diff}:&nbs