Man Linux: Main Page and Category List

NAME

       texdiff - Compares two (La)TeX documents to create a merged version
       showing changes, similar to that of 'Change Tracking' in some word
       processors.

SYNOPSIS

       texdiff [--nofloats|-n] old.tex new.tex [diff.tex]

DESCRIPTION

       The first two files are compared and a new TeX file is output. When the
       output file is processed with (La)TeX it marks new changes with blue
       and old text with red with a strike-through line. Furthermore, passages
       with changes are marked at the margin with grey bars by the LaTeX
       "changebar" package (although only after running "dvips", in "xdvi" the
       bars are one inch too far left to compensate the one inch offset
       inserted by TeX printer drivers).

       "texdiff" uses and therefore requires the "wdiff" command to insert
       these marks. If LaTeX macros are included in those striked out or
       underlined passages, the latex run will most likely fail. The source of
       most problems lies in "wdiff" tearing apart pairs of braces. Therefore
       "texdiff" is a perl script that calls "wdiff" internally and fixes
       "wdiff"'s output by re-pairing braces again and handling some commonly
       used LaTeX macros.

       For texdiff to work, the following LaTeX code must be inserted in the
       preamble of the LaTeX document:

        \usepackage{xcolor} \usepackage{ulem} \usepackage{changebar}
        \newcommand\TLSins[1]{\cbstart{}\textcolor{ins}{\uline{#1}}\cbend{}}
        \newcommand\TLSdel[1]{\cbdelete{}\textcolor{del}{\sout{#1}}}

       Define editing colors "ins" and "del" with existing "xcolor" color
       names:
        \colorlet{ins}{blue} \colorlet{del}{red}

       Or from scratch:
        \definecolor{ins}{rgb}{0, 0.5, 0}

       These macros are NOT automatically interted at \begin{document} like
       the original scripts did (see the ACKNOWLEDGMENTS section below),
       because this will not work on files of a multi-file document (those
       included by \include or \input).  Furthermore, if you insert the macros
       manually, you can tune them as you like, i. e. change text color or
       position of changebars. Have a look at the documentation of the ulem
       and changebar packages on how to do this!

OPTIONS

       --nofloats, -n
           If given, skips contents of figure environments, but does show
           insertions and deletions in the caption commands. This is done to
           avoid complex messups in subfloat or complex figure environments.

       --debug, -d
           Turns on debugging. Temporary files that contain numbered braces
           are kept and a raw difference file is written as output file name
           appended with '-wdiff.tex'. In addition, several regular expression
           diagnostics are printed. Warning: produces a lot of output.

AUTHOR

       Mark Doll <markdoll<AT>gmx.net>, Cengiz Gunay
       <cengique<AT>users.sf.net>.

ACKNOWLEDGMENTS

       *   Version 0.4, by CG, 2009/09/15. Added use of GetOpt to take an
           optional parameter to skip float (e.g., figure or table) contents.
           Added an optional debug mode. Embedded POD documentation. Fixed
           problem with insertion and deletions appearing in the middle of
           sectioning commands by throwing off LaTeX.

       *   Version 0.3, modified by Cengiz Gunay <cengique@users.sf.net>,
           2009/06/30. Added some Latex commands that should be excluded and
           fixed handling of '\%' characters.

       *   Version 0.2, is a perl implementation of TeXdiff by Mark Doll
           <markdoll@gmx.net>, 2006/08/09. It was derived from the original
           bash and perl scripts created by Robert Maron
           <robmar@mimuw.edu.pl>, available at http://www.robmar.net/TexDiff/.
           This version of texdiff is available at
           http://mark.doll.name/texdiff/.

COPYRIGHT AND LICENSE

       Copyleft 2006-2009, Mark Doll and Cengiz Gunay

       This library is free software; you may redistribute it and/or modify it
       under the same terms as Perl itself.