debdiff(1)



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 that match PATTERN.  Multiple uses of this  option
          are permitted.

   --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.

   --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.

   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

   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.




Free and Open Source Software


Free Software Video

Useful Programs

Free Online Courses

Open Opportunity

Open Business