debchange

DEBCHANGE(1)                General Commands Manual               DEBCHANGE(1)

NAME
       debchange  -  Tool  for  maintenance  of the debian/changelog file in a
       source package

SYNOPSIS
       debchange [options] [text ...]
       dch [options] [text ...]

DESCRIPTION
       debchange or its alias dch will add a new comment line  to  the  Debian
       changelog  in  the  current source tree.  This command must be run from
       within that tree.  If the text of the change is given  on  the  command
       line,  debchange  will  run in batch mode and simply add the text, with
       line breaks as necessary, at the appropriate place in  debian/changelog
       (or  the  changelog  specified by options, as described below).  If the
       text given on the command line is a null string, debchange will run  in
       batch  mode  without adding any text.  If the text given on the command
       line is a space string, debchange will run in  batch  mode  and  add  a
       blank changelog entry.  If no text is specified then debchange will run
       the editor as determined by sensible-editor for you to edit  the  file.
       (The  environment variables VISUAL and EDITOR are used in this order to
       determine which editor to use.)  Editors which understand the +n option
       for  starting  the editing on a specified line will use this to move to
       the correct line of the file for editing.  If the editor is quit  with-
       out  modifying the temporary file, debchange will exit without touching
       the existing changelog.  Note that the changelog is assumed to  be  en-
       coded  with  the  UTF-8  encoding.   If  it is not, problems may occur.
       Please see the iconv(1) manpage to find out how to  convert  changelogs
       from  legacy  encodings.  Finally, a changelog or NEWS file can be cre-
       ated from scratch using the --create option described below.

       debchange also supports automatically producing  bug-closing  changelog
       entries,  using  the --closes option.  This will usually query the BTS,
       the Debian Bug Tracking System (see https://bugs.debian.org/) to deter-
       mine the title of the bug and the package in which it occurs.  This be-
       haviour can be stopped by giving a --noquery option or by  setting  the
       configuration  variable  DEBCHANGE_QUERY_BTS to no, as described below.
       In either case, the editor (as described above) will always be  invoked
       to give an opportunity to modify the entries, and the changelog will be
       accepted whether or not modifications are made.  An extra changelog en-
       try can be given on the command line in addition to the closes entries.

       At  most one of --append, --increment, --edit, --release, and --newver-
       sion may be specified as listed below. If no options are specified, de-
       bchange  will  use  heuristics  to guess whether or not the package has
       been successfully released, and behave as if --increment had been spec-
       ified if the package has been released, or otherwise as if --append has
       been specified.

       Two different sets of heuristics can be  used,  as  controlled  by  the
       --release-heuristic  option or the DEBCHANGE_RELEASE_HEURISTIC configu-
       ration variable. The default changelog heuristic  assumes  the  package
       has  been released unless its changelog contains UNRELEASED in the dis-
       tribution field. If this heuristic is  enabled  then  the  distribution
       will  default  to UNRELEASED in new changelog entries, and the --maint-
       trailer option described below will be automatically enabled. This  can
       be  useful if a package can be released by different maintainers, or if
       you do not keep the upload logs. The alternate log heuristic determines
       if a package has been released by looking for an appropriate dupload(1)
       or dput(1) log file in the parent directory.  A warning will be  issued
       if  the log file is found but a successful upload is not recorded. This
       may be because the previous upload was performed with a version of  du-
       pload prior to 2.1 or because the upload failed.

       If  either  --increment or --newversion is used, the name and email for
       the new version will be determined  as  follows.   If  the  environment
       variable  DEBFULLNAME is set, this will be used for the maintainer full
       name; if not, then NAME will be checked.  If the  environment  variable
       DEBEMAIL  is  set,  this  will  be used for the email address.  If this
       variable has the form "name <email>", then  the  maintainer  name  will
       also  be  taken  from  here if neither DEBFULLNAME nor NAME is set.  If
       this variable is not set, the same test is performed on the environment
       variable  EMAIL.  Next, if the full name has still not been determined,
       then use getpwuid(3) to determine the name from the password file.   If
       this  fails,  use the previous changelog entry.  For the email address,
       if it has not been set from DEBEMAIL or EMAIL, then look in  /etc/mail-
       name,  then  attempt  to build it from the username and FQDN, otherwise
       use the email address in the previous changelog entry.  In other words,
       it's  a  good  idea  to  set  DEBEMAIL  and DEBFULLNAME when using this
       script.

       Support is included for changelogs that record changes by multiple  co-
       maintainers  of  a package. If an entry is appended to the current ver-
       sion's entries, and the maintainer is different from the maintainer who
       is listed as having done the previous entries, then lines will be added
       to the changelog to tell which maintainers  made  which  changes.  Cur-
       rently  only  one of the several such styles of recording this informa-
       tion is supported, in which the name of the maintainer who made  a  set
       of  changes  appears on a line before the changes, inside square brack-
       ets. This can be switched on and off using the --[no]multimaint  option
       or  the  DEBCHANGE_MULTIMAINT configuration file option; the default is
       to enable it.  Note that if an entry has already been  marked  in  this
       way, then this option will be silently ignored.

       If  the directory name of the source tree has the form package-version,
       then debchange will also attempt to rename it if the (upstream) version
       number  changes.  This can be prevented by using the --preserve command
       line or configuration file option as described below.

       If --force-bad-version or --allow-lower-version is used, debchange will
       not  stop if the new version is less than the current one.  This is es-
       pecially useful while doing backports.

Directory name checking
       In common with several other scripts in  the  devscripts  package,  de-
       bchange will climb the directory tree until it finds a debian/changelog
       file.  As a safeguard against stray files causing  potential  problems,
       it  will examine the name of the parent directory once it finds the de-
       bian/changelog file, and check that the directory name  corresponds  to
       the package name.  Precisely how it does this is controlled by two con-
       figuration  file  variables  DEVSCRIPTS_CHECK_DIRNAME_LEVEL   and   DE-
       VSCRIPTS_CHECK_DIRNAME_REGEX,  and their corresponding command-line op-
       tions --check-dirname-level and --check-dirname-regex.

       DEVSCRIPTS_CHECK_DIRNAME_LEVEL can take the following values:

       0      Never check the directory name.

       1      Only check the directory name if we have had to change directory
              in  our search for debian/changelog.  This is the default behav-
              iour.

       2      Always check the directory name.

       The directory name is checked by testing whether the current  directory
       name  (as determined by pwd(1)) matches the regex given by the configu-
       ration file option DEVSCRIPTS_CHECK_DIRNAME_REGEX  or  by  the  command
       line  option  --check-dirname-regex  regex.  Here regex is a Perl regex
       (see perlre(3perl)), which will be anchored at the  beginning  and  the
       end.   If  regex  contains a '/', then it must match the full directory
       path.  If not, then it must match the full directory  name.   If  regex
       contains  the  string  'PACKAGE',  this  will be replaced by the source
       package name, as determined from the changelog.  The default value  for
       the  regex  is:  'PACKAGE(-.+)?', thus matching directory names such as
       PACKAGE and PACKAGE-version.

       The default changelog to be edited is debian/changelog;  however,  this
       can be changed using the --changelog or --news options or the CHANGELOG
       environment variable, as described below.

OPTIONS
       --append, -a
              Add a new changelog entry at the end of  the  current  version's
              entries.

       --increment, -i
              Increment  either the final component of the Debian release num-
              ber or, if this is a native Debian package, the version  number.
              On  Ubuntu  or  Tanglu,  this  will  also change the suffix from
              buildX to ubuntu1/tanglu1.  Use -R, --rebuild for  a  no  change
              rebuild  increment.  This creates a new section at the beginning
              of the changelog with appropriate headers and footers.  Also, if
              this  is a new version of a native Debian package, the directory
              name is changed to reflect this.  If DEBCHANGE_RELEASE_HEURISTIC
              is  changelog  (default)  and the current release is UNRELEASED,
              this will only change  the  version  of  the  current  changelog
              stanza.  Otherwise, this will create a new changelog stanza with
              the new version.

       --newversion version, -v version
              This specifies the version number (including the Debian  release
              part)  explicitly and behaves as the --increment option in other
              respects.  It will also change the directory  name  if  the  up-
              stream version number has changed.  If DEBCHANGE_RELEASE_HEURIS-
              TIC is changelog (default) and  the  current  release  is  UNRE-
              LEASED,  this  will  only  change  the  version  of  the current
              changelog stanza.  Otherwise, this will create a  new  changelog
              stanza with the new version.

       --edit, -e
              Edit the changelog in an editor.

       --release, -r
              Finalize  the  changelog  for  a  release.  Update the changelog
              timestamp. If the distribution is set to UNRELEASED,  change  it
              to  the  distribution  from the previous changelog entry (or an-
              other distribution as specified by  --distribution).   If  there
              are  no  previous changelog entries and an explicit distribution
              has not been specified, unstable will be used (or  the  name  of
              the current development release when run under Ubuntu).

       --force-save-on-release
              When  --release is used, an editor is opened to allow inspection
              of the changelog.  The user is required to save the file to  ac-
              cept the modified changelog, otherwise the original will be kept
              (default).

       --no-force-save-on-release
              Do not do so. Note that a dummy changelog entry may be  supplied
              in  order  to achieve the same effect - e.g. debchange --release
              "".  The entry will not be added to the changelog but its  pres-
              ence will suppress the editor.

       --create
              This  will  create  a  new debian/changelog file (or NEWS if the
              --news option is used).  You must be in the top-level  directory
              to  use this; no directory name checking will be performed.  The
              package name and version  can  either  be  specified  using  the
              --package  and  --newversion options, determined from the direc-
              tory name using the --fromdirname  option  or  entered  manually
              into  the  generated changelog file.  The maintainer name is de-
              termined from the environment if this is possible, and the  dis-
              tribution is specified either using the --distribution option or
              in the generated changelog file.

       --empty
              When used in combination with --create, suppress  the  automatic
              addition  of  an  "initial release" changelog entry (so that the
              next invocation of debchange adds the first entry).   Note  that
              this  will cause a dpkg-parsechangelog warning on the next invo-
              cation due to the lack of changes.

       --package package
              This specifies the package name to be used in the new changelog;
              this may only be used in conjunction with the --create, --incre-
              ment and --newversion options.

       --nmu, -n
              Increment the Debian release number for a non-maintainer  upload
              by  either  appending a ".1" to a non-NMU version number (unless
              the package is Debian native, in which case "+nmu1" is appended)
              or  by  incrementing  an  NMU  version  number,  and  add an NMU
              changelog comment.  This happens automatically if  the  packager
              is  neither  in  the  Maintainer  nor the Uploaders field in de-
              bian/control, unless DEBCHANGE_AUTO_NMU is  set  to  no  or  the
              --no-auto-nmu option is used.

       --bin-nmu
              Increment  the Debian release number for a binary non-maintainer
              upload by either appending a "+b1" to a non-binNMU version  num-
              ber or by incrementing a binNMU version number, and add a binNMU
              changelog comment.

       --qa, -q
              Increment the Debian release number for a Debian QA Team upload,
              and add a QA upload changelog comment.

       --rebuild, -R
              Increment  the  Debian release number for a no-change rebuild by
              appending a "build1" or by incrementing a rebuild  version  num-
              ber.

       --security, -s
              Increment  the  Debian release number for a Debian Security Team
              non-maintainer upload, and add a Security Team upload  changelog
              comment.

       --lts  Increment the Debian release number for a LTS Security Team non-
              maintainer upload, and add a LTS Security Team upload  changelog
              comment.

       --team Increment the Debian release number for a team upload, and add a
              Team upload changelog comment.

       --upstream, -U
              Don't append distro-name1 to the version on a derived  distribu-
              tion. Increment the Debian version.

       --bpo  Increment  the  Debian  release  number for an upload to buster-
              backports, and add a backport upload changelog comment.

       --stable
              Increment the Debian release number for an upload to the current
              stable release.

       --local, -lsuffix
               Add a suffix to the Debian version number for a local build.

       --force-bad-version, -b
              Force  a  version  number to be less than the current one (e.g.,
              when backporting).

       --allow-lower-version pattern
              Allow a version number to be less than the current  one  if  the
              new version matches the specified pattern.

       --force-distribution
              Force  the  provided distribution to be used, even if it doesn't
              match the list of known distributions (e.g. for unofficial  dis-
              tributions).

       --auto-nmu
              Attempt  to  automatically  determine  whether  a  change to the
              changelog represents a Non Maintainer Upload.  This is  the  de-
              fault.

       --no-auto-nmu
              Disable  automatic  NMU  detection.   Equivalent  to setting DE-
              BCHANGE_AUTO_NMU to no.

       --fromdirname, -d
              This will take the upstream version number  from  the  directory
              name,  which  should be of the form package-version.  If the up-
              stream  version  number  has  increased  from  the  most  recent
              changelog entry, then a new entry will be made with version num-
              ber version-1 (or version if the package is Debian native), with
              the same epoch as the previous package version.  If the upstream
              version number is the same, this option will behave in the  same
              way as -i.

       --closes nnnnn[,nnnnn ...]
              Add  changelog entries to close the specified bug numbers.  Also
              invoke the editor after adding  these  entries.   Will  generate
              warnings  if  the BTS cannot be contacted (and --noquery has not
              been specified), or if there are problems with  the  bug  report
              located.

       --[no]query
              Should  we  attempt  to query the BTS when generating closes en-
              tries?

       --preserve, -p
              Preserve the source tree directory name if the upstream  version
              number  (or  the  version  number  of  a  Debian native package)
              changes.  See also the configuration variables section below.

        --no-preserve, --nopreserve
              Do not preserve the source tree directory name (default).

       --vendor vendor
              Override the distributor ID over the default returned  by  dpkg-
              vendor.  This name is used for heuristics applied to new package
              versions and for sanity checking of the target distribution.

       --distribution dist, -D dist
              Use the specified distribution  in  the  changelog  entry  being
              edited,  instead of using the previous changelog entry's distri-
              bution for new entries or the existing value  for  existing  en-
              tries.

       --urgency urgency, -u urgency
              Use  the  specified urgency in the changelog entry being edited,
              instead of using the default "medium" for new entries or the ex-
              isting value for existing entries.

       --changelog file, -c file
              This  will  edit  the changelog file instead of the standard de-
              bian/changelog.  This option overrides any CHANGELOG environment
              variable  setting.   Also,  no  directory traversing or checking
              will be performed when this option is used.

       --news [newsfile]
              This will edit newsfile (by default, debian/NEWS) instead of the
              regular  changelog.  Directory searching will be performed.  The
              changelog will be examined in order  to  determine  the  current
              package version.

       --[no]multimaint
              Should  we  indicate  that  parts of a changelog entry have been
              made by different maintainers?  Default is yes; see the  discus-
              sion  above and also the DEBCHANGE_MULTIMAINT configuration file
              option below.

       --[no]multimaint-merge
              Should all changes made by the same author be  merged  into  the
              same changelog section?  Default is no; see the discussion above
              and also the DEBCHANGE_MULTIMAINT_MERGE configuration  file  op-
              tion below.

       --maintmaint, -m
              Do  not  modify  the maintainer details previously listed in the
              changelog.  This is useful particularly for sponsors wanting  to
              automatically  add  a sponsorship message without disrupting the
              other changelog details.  Note that there may be some  interest-
              ing  interactions  if  multi-maintainer mode is in use; you will
              probably wish to check the changelog manually  before  uploading
              it in such cases.

       --controlmaint, -M
              Use  maintainer details from the debian/control Maintainer field
              rather than relevant environment variables  (DEBFULLNAME,  DEBE-
              MAIL,  etc.).  This option might be useful to restore details of
              the main maintainer in the changelog trailer after a bogus  edit
              (e.g. when -m was intended but forgot) or when releasing a pack-
              age in the name of the main maintainer (e.g. the team).

       --[no]mainttrailer, -t
              If mainttrailer is set, it will  avoid  modifying  the  existing
              changelog  trailer  line (i.e. the maintainer and date-stamp de-
              tails), unless used with options that require the trailer to  be
              modified (e.g. --create, --release, -i, --qa, etc.)  This option
              differs from --maintmaint in that it will  use  multi-maintainer
              mode  if appropriate, with the exception of editing the trailer.
              See also the DEBCHANGE_MAINTTRAILER  configuration  file  option
              below.

       --check-dirname-level N
              See  the above section "Directory name checking" for an explana-
              tion of this option.

       --check-dirname-regex regex
              See the above section "Directory name checking" for an  explana-
              tion of this option.

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

       --release-heuristic log|changelog
              Controls how debchange determines if  a  package  has  been  re-
              leased, when deciding whether to create a new changelog entry or
              append to an existing changelog entry.

       --help, -h
              Display a help message and exit successfully.

       --version
              Display version and copyright information and exit successfully.

CONFIGURATION VARIABLES
       The two configuration files /etc/devscripts.conf and ~/.devscripts  are
       sourced in that order to set configuration variables.  Command line op-
       tions can be used to override configuration file settings.  Environment
       variable  settings  are ignored for this purpose.  The currently recog-
       nised variables are:

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

       DEBCHANGE_QUERY_BTS
              If  this is set to no, then it is the same as the --noquery com-
              mand line parameter being used.

       DEVSCRIPTS_CHECK_DIRNAME_LEVEL, DEVSCRIPTS_CHECK_DIRNAME_REGEX
              See the above section "Directory name checking" for an  explana-
              tion  of these variables.  Note that these are package-wide con-
              figuration variables, and will therefore affect  all  devscripts
              scripts  which  check their value, as described in their respec-
              tive manpages and in devscripts.conf(5).

       DEBCHANGE_RELEASE_HEURISTIC
              Controls how debchange determines if  a  package  has  been  re-
              leased, when deciding whether to create a new changelog entry or
              append to an existing changelog entry.  Can  be  either  log  or
              changelog.

       DEBCHANGE_MULTIMAINT
              If  set  to no, debchange will not introduce multiple-maintainer
              distinctions when a different maintainer appends an entry to  an
              existing changelog.  See the discussion above.  Default is yes.

       DEBCHANGE_MULTIMAINT_MERGE
              If  set  to yes, when adding changes in multiple-maintainer mode
              debchange will check whether previous  changes  by  the  current
              maintainer  exist  and add the new changes to the existing block
              rather than creating a new block.  Default is no.

       DEBCHANGE_MAINTTRAILER
              If this is set to no, then it is  the  same  as  the  --nomaint-
              trailer command line parameter being used.

       DEBCHANGE_TZ
              Use  this  timezone  for  changelog  entries.   Default  is  the
              user/system timezone as shown by `date -R` and affected  by  the
              environment variable TZ.

       DEBCHANGE_LOWER_VERSION_PATTERN
              If this is set, then it is the same as the --allow-lower-version
              command line parameter being used.

       DEBCHANGE_AUTO_NMU
              If this is set to no then debchange will not attempt to automat-
              ically determine whether the current changelog stanza represents
              an NMU.  The default is yes.  See the discussion  of  the  --nmu
              option above.

       DEBCHANGE_FORCE_SAVE_ON_RELEASE
              If   this   is   set   to  no,  then  it  is  the  same  as  the
              --no-force-save-on-release command line parameter being used.

       DEBCHANGE_VENDOR
              Use this vendor instead of  the  default  (dpkg-vendor  output).
              See --vendor for details.

ENVIRONMENT
       DEBEMAIL, EMAIL, DEBFULLNAME, NAME
              See  the above description of the use of these environment vari-
              ables.

       CHANGELOG
              This variable specifies the changelog to edit in  place  of  de-
              bian/changelog.  No directory traversal or checking is performed
              when this variable is set.  This variable is overridden  by  the
              --changelog command-line setting.

       VISUAL, EDITOR
              These environment variables (in this order) determine the editor
              used by sensible-editor.

SEE ALSO
       debc(1), debclean(1), dput(1), dupload(1), devscripts.conf(5)

AUTHOR
       The original author was Christoph Lameter <clameter@debian.org>.   Many
       substantial  changes  and  improvements  were  made  by  Julian  Gilbey
       <jdg@debian.org>.

DEBIAN                         Debian Utilities                   DEBCHANGE(1)
Man Pages Copyright Respective Owners. Site Copyright (C) 1994 - 2025 Hurricane Electric. All Rights Reserved.