Provided by: devscripts_2.23.7_all bug

NAME

       debdiff - compare file lists in two Debian packages

SYNOPSIS

       debdiff [options]
       debdiff [options] ... deb1 deb2
       debdiff [options] ... changes1 changes2
       debdiff [options] ... --from deb1a deb1b ...  --to deb2a deb2b ...
       debdiff [options] ... dsc1 dsc2

DESCRIPTION

       debdiff  takes  the  names of two Debian package files (.debs or .udebs) on the command line and compares
       their contents (considering only the files in the main package, not the maintenance scripts).   It  shows
       which files have been introduced and which removed between the two package files, and is therefore useful
       for  spotting  files  which  may  have been inadvertently lost between revisions of the package.  It also
       checks the file owners and permissions, and compares the control files of  the  two  packages  using  the
       wdiff  program.   If  you want a deeper comparison of two Debian package files you can use the diffoscope
       tool.

       If no arguments are given, debdiff tries to compare the content of the current source directory with  the
       last version of the package.

       debdiff  can  also  handle changes between groups of .deb files in two ways.  The first is to specify two
       .changes files.  In this case, the .deb files listed in the .changes file will be compared, by taking the
       contents of all of the listed .deb files together.  (The .deb files listed are assumed to be in the  same
       directory as the .changes file.)  The second way is to list the .deb files of interest specifically using
       the  --from  ...  --to  syntax.   These both help if a package is broken up into smaller packages and one
       wishes to ensure that nothing is lost in the interim.

       debdiff examines the devscripts configuration files as described below.  Command  line  options  override
       the configuration file settings, though.

       If  debdiff  is  passed  two  source  packages  (.dsc  files)  it will compare the contents of the source
       packages.  If the source packages differ only in Debian revision number (that is, the .orig.tar.gz  files
       are  the  same  in  the two .dsc files), then interdiff(1) will be used to compare the two patch files if
       this program is available on the system, otherwise a diff will be performed between the two source trees.

OPTIONS

       --dirs, -d
              The default mode of operation is to ignore directory names which appear  in  the  file  list,  but
              they, too, will be considered if this option is given.

       --nodirs
              Ignore  directory  names which appear in the file list.  This is the default and it can be used to
              override a configuration file setting.

       --move FROM TO, -m FROM TO
              It sometimes occurs that various files or directories are moved around  between  revisions.   This
              can  be  handled using this option.  There are two arguments, the first giving the location of the
              directory or file in the first package, and the second in the second.   Any  files  in  the  first
              listing  whose  names begin with the first argument are treated as having that substituted for the
              second argument when the file lists are compared.  Any number of --move arguments  may  be  given;
              they are processed in the order in which they appear. This only affects comparing binary packages,
              not source packages.

       --move-regex FROM TO
              This  is  the  same  as  --move,  except that FROM is treated as a regular expression and the perl
              substitution command s/^FROM/TO/ is applied to the files.  In  particular,  TO  can  make  use  of
              backreferences such as $1.

       --nocontrol
              debdiff  will  usually  compare the respective control files of the packages using wdiff(1).  This
              option suppresses this part of the processing.

       --control
              Compare the respective control files; this is the default, and  it  can  be  used  to  override  a
              configuration file setting.

       --controlfiles FILE[,FILE ...]
              Specify  which  control  files  to  compare;  by  default  this is just control, but could include
              postinst, config and so on.  Files will only be compared if they are present in both  .debs  being
              compared.   The  special value ALL compares all control files present in both packages, except for
              md5sums.  This option can be used to override a configuration file setting.

       --wdiff-source-control
              When processing source packages, compare control files using wdiff.  Equivalent to  the  --control
              option for binary packages.

       --no-wdiff-source-control
              Do not compare control files in source packages using wdiff.  This is the default.

       --wp, --wl, --wt
              Pass a -p, -l or -t option to wdiff respectively.  (This yields the whole wdiff output rather than
              just the lines with any changes.)

       --show-moved
              If  multiple  .deb  files  are  specified  on the command line, either using .changes files or the
              --from/--to syntax, then this option will also show  which  files  (if  any)  have  moved  between
              packages.  (The package names are simply determined from the names of the .deb files.)

       --noshow-moved
              The default behaviour; can be used to override a configuration file setting.

       --renamed FROM TO
              If  --show-moved  is  being  used  and  a  package  has  been renamed in the process, this command
              instructs debdiff to treat the package in the first list called FROM as  if  it  were  called  TO.
              Multiple uses of this option are permitted.

       --exclude PATTERN
              Exclude  files  whose  basenames match PATTERN.  Multiple uses of this option are permitted.  Note
              that this option is passed on to diff and has the same behaviour, so only the basename of the file
              is considered: in particular, --exclude='*.patch' will work, but --exclude='debian/patches/*' will
              have no practical effect.

       --diffstat
              Include the result of diffstat before the generated diff.

       --no-diffstat
              The default behaviour; can be used to override a configuration file setting.

       --auto-ver-sort
              When comparing source packages, do so in version order.

       --no-auto-ver-sort
              Compare source packages in the order they were passed on the  command-line,  even  if  that  means
              comparing  a  package with a higher version against one with a lower version.  This is the default
              behaviour.

       --unpack-tarballs
              When comparing source packages, also unpack tarballs found in the top level  source  directory  to
              compare their contents along with the other files.  This is the default behaviour.

       --no-unpack-tarballs
              Do not unpack tarballs inside source packages.

       --apply-patches
              If  the old and/or new package is in 3.0 (quilt) format, apply the quilt patches (and remove .pc/)
              before comparison.

       --no-apply-patches, --noapply-patches
              If the old and/or new package is in 3.0 (quilt) format, do not  apply  the  quilt  patches  before
              comparison. This is the default behaviour.

       --no-conf, --noconf
              Do  not  read  any  configuration  files.   This can only be used as the first option given on the
              command-line.

       --debs-dir directory
              Look for the .dsc files in directory instead of the parent of the source directory.   This  should
              either be an absolute path or relative to the top of the source directory.

       --help, -h
              Show a summary of options.

       --version, -v
              Show version and copyright information.

       --quiet, -q
              Be quiet if no differences were found.

       --ignore-space, -w
              Ignore whitespace in diffs.

CONFIGURATION VARIABLES

       The  two  configuration files /etc/devscripts.conf and ~/.devscripts are sourced by a shell in that order
       to set configuration variables.  Command  line  options  can  be  used  to  override  configuration  file
       settings.   Environment  variable  settings  are  ignored  for  this  purpose.   The currently recognised
       variables are:

       DEBDIFF_DIRS
              If this is set to yes, then it is the same as the --dirs command line parameter being used.

       DEBDIFF_CONTROL
              If this is set to no, then it is the same as the --nocontrol command line  parameter  being  used.
              The default is yes.

       DEBDIFF_CONTROLFILES
              Which  control  files  to  compare,  corresponding to the --controlfiles command line option.  The
              default is control.

       DEBDIFF_SHOW_MOVED
              If this is set to yes, then it is the same as the --show-moved command line parameter being used.

       DEBDIFF_WDIFF_OPT
              This option will be passed to wdiff; it should be one of -p, -l or -t.

       DEBDIFF_SHOW_DIFFSTAT
              If this is set to yes, then it is the same as the --diffstat command line parameter being used.

       DEBDIFF_WDIFF_SOURCE_CONTROL
              If this is set to yes, then it is the same as the --wdiff-source-control  command  line  parameter
              being used.

       DEBDIFF_AUTO_VER_SORT
              If  this  is  set  to yes, then it is the same as the --auto-ver-sort command line parameter being
              used.

       DEBDIFF_UNPACK_TARBALLS
              If this is set to no, then it is the same as the --no-unpack-tarballs command line parameter being
              used.

       DEBDIFF_APPLY_PATCHES
              If this is set to yes, then it is the same as the --apply-patches  command  line  parameter  being
              used.  The default is no.

       DEBRELEASE_DEBS_DIR
              This  specifies  the  directory in which to look for the .dsc and files, and is either an absolute
              path or relative to the top of the source tree.  This corresponds to the --debs-dir  command  line
              option.  This directive could be used, for example, if you always use pbuilder or svn-buildpackage
              to  build  your  packages.   Note  that  it  also affects debrelease(1) in the same way, hence the
              strange name of the option.

EXIT VALUES

       Normally the exit value will be 0 if no differences are reported and 1 if any are reported.  If there  is
       some fatal error, the exit code will be 255.

SEE ALSO

       debdiff-apply(1), diffstat(1), dpkg-deb(1), interdiff(1), wdiff(1), devscripts.conf(5), diffoscope(1)

AUTHOR

       debdiff was originally written as a shell script by Yann Dirson <dirson@debian.org> and rewritten in Perl
       with  many  more  features  by  Julian Gilbey <jdg@debian.org>.  The software may be freely redistributed
       under the terms and conditions of the GNU General Public License, version 2.

DEBIAN                                          Debian Utilities                                      DEBDIFF(1)