devscripts

DEVSCRIPTS(1)               General Commands Manual              DEVSCRIPTS(1)

NAME
       devscripts - scripts to ease the lives of Debian developers

DESCRIPTION
       The devscripts package provides a collection of scripts which may be of
       use to Debian developers and others wishing to build  Debian  packages.
       For   a   summary  of  the  available  scripts,  please  see  the  file
       /usr/share/doc/devscripts/README.gz, and for full details,  please  see
       the  individual manpages.  They are contributed by multiple developers;
       for details of the authors, please see the code or manpages.

       Also, the directory /usr/share/doc/devscripts/examples  contains  exam-
       ples  of  procmail and exim scripts for sorting mail arriving to Debian
       mailing lists.

ENVIRONMENT
       Several scripts of the devscripts suite use the  following  environment
       variables.  Check  the man pages of individual scripts for more details
       on how the variables are used.

       DEBEMAIL
           Email of the person acting  on  a  given  Debian  package  via  de-
           vscripts.

       DEBFULLNAME
           Full  name  (first + family) of the person acting on a given Debian
           package via devscripts.

SCRIPTS
       Here is the complete list of available devscripts. See their man  pages
       for additional documentation.

       annotate-output(1)
              run  a  command and prepend time and stream (O for stdout, E for
              stderr) for every line of output.

       archpath(1)
              Prints arch (tla/Bazaar) package names. Also supports  calculat-
              ing the package names for other branches. [tla | bazaar]

       bts(1) A  command-line  tool for accessing the Debian Bug Tracking Sys-
              tem, both to send mails to control@bts.debian.org and to  access
              the  web  pages  and  SOAP  interface  of the BTS. [www-browser,
              libauthen-sasl-perl,    libnet-smtps-perl,    libsoap-lite-perl,
              liburi-perl, libwww-perl, bsd-mailx | mailx]

       build-rdeps(1)
              Searches  for all packages that build-depend on a given package.
              [dctrl-tools, dose-extra, libdpkg-perl]

       chdist(1)
              tool to easily play with several distributions. [dctrl-tools]

       checkbashisms(1)
              check whether a /bin/sh script contains any common bash-specific
              constructs.

       cowpoke(1)
              upload  a  Debian  source package to a cowbuilder host and build
              it, optionally also signing and uploading the result to  an  in-
              coming queue. [ssh-client]

       cvs-debi, cvs-debc(1)
              wrappers around debi and debc respectively (see below) which al-
              low them to be called from  the  CVS  working  directory.  [cvs-
              buildpackage]

       cvs-debrelease(1)
              wrapper  around debrelease which allows it to be called from the
              CVS working directory. [cvs-buildpackage, dupload |  dput,  ssh-
              client]

       cvs-debuild(1)
              A  wrapper  for  cvs-buildpackage  to use debuild as its package
              building program. [cvs-buildpackage,  fakeroot,  lintian,  gnupg
              |gnupg2]

       dcmd(1)
              run  a  given  command  replacing the name of a .changes or .dsc
              file with each of the files referenced therein. *

       dd-list(1)
              given a list of packages, pretty-print it ordered by maintainer.
              *

       debc(1)
              List  contents  of  current package.  Do this after a successful
              "debuild" to see if the package looks all right.

       debchange (abbreviation dch)(1)
              Modifies debian/changelog and manages version numbers  for  you.
              It  will either increment the version number or add an entry for
              the current version, depending upon the  options  given  to  it.
              [libdistro-info-perl, libsoap-lite-perl]*

       debcheckout(1)
              checkout the development repository of a Debian package. *

       debclean(1)
              Clean  a  Debian  source  tree.   Debclean will clean all Debian
              source trees below the current directory, and if requested, also
              remove  all  files  that  were generated from these source trees
              (that is .deb, .dsc and  .changes  files).   It  will  keep  the
              .diffs  and  original  files,  though,  so that the binaries and
              other files can be rebuilt if necessary. [fakeroot]*

       debcommit(1)
              Commits changes to cvs, darcs, svn, svk, tla, bzr, git,  or  hg,
              using  new  entries  in  debian/changelog as the commit message.
              Also supports tagging Debian package releases. [cvs  |  darcs  |
              subversion  |  svk  | tla | bzr | git-core | mercurial, libtime-
              date-perl]

       debdiff(1)
              A program which examines two .deb files or  two  .changes  files
              and reports on any difference found in their file lists.  Useful
              for ensuring that no files were inadvertently lost between  ver-
              sions.   Can  also  examine  two  .dsc  files  and report on the
              changes between source versions. For a deeper comparison one can
              use the diffoscope package. [wdiff, patchutils]*

       debdiff-apply(1)
              Apply unified diffs of two Debian source packages, such as those
              generated by debdiff, to a target  Debian  source  package.  Any
              changes  to  debian/changelog are dealt with specially, to avoid
              the conflicts that changelog diffs typically  produce  when  ap-
              plied naively. May be used to check that old patches still apply
              to  newer   versions   of   those   packages.   [python3-debian,
              python3-unidiff, quilt]

       debi(1)
              Installs  the  current  package  by using the setuid root debpkg
              script described below.  It assumes that the current package has
              just  been built (for example by debuild), and the .deb lives in
              the parent directory, and will effectively run dpkg  -i  on  the
              .deb.  The ability to install the package with a very short com-
              mand is very useful when troubleshooting packages.

       debpkg(1)
              A wrapper for dpkg used by debi to allow convenient  testing  of
              packages.   For debpkg to work, it needs to be made setuid root,
              and this needs to be performed by the sysadmin -- it is not  in-
              stalled as setuid root by default.  (Note that being able to run
              a setuid root debpkg is effectively the same as having root  ac-
              cess  to the system, so this should be done with caution.)  Hav-
              ing debpkg as a wrapper for dpkg can be a Good Thing (TM), as it
              decreases  the  potential  for damage by accidental wrong use of
              commands in superuser mode (e.g., an inadvertent rm -rf * in the
              wrong directory is disastrous as many can attest to).

       debrelease(1)
              A wrapper around dupload or dput which figures out which version
              to upload, and then calls dupload or dput  to  actually  perform
              the upload. [dupload | dput, ssh-client]

       debrepro(1)
              A  script that tests reproducibility of Debian packages. It will
              build a given source directory twice, with a  set  of  variation
              between the first and second build, and compare the binary pack-
              ages produced. If diffoscope is installed, it is used to compare
              non-matching  binaries.  If  disorderfs is installed, it is used
              during the build to inject non-determinism in filesystem listing
              operations. [faketime, diffoscope, disorderfs]

       debrsign(1)
              This  transfers  a  .changes/.dsc  pair  to a remote machine for
              signing, and runs debsign on the remote machine over an SSH con-
              nection. [gnupg | gnupg2, debian-keyring, ssh-client]

       debsign(1)
              Use  GNU  Privacy  Guard  to sign the changes (and possibly dsc)
              files created by running dpkg-buildpackage with no-sign options.
              Useful  if  you  are  building a package on a remote machine and
              wish to sign it on a local one.  This script is capable of auto-
              matically  downloading the .changes and .dsc files from a remote
              machine. [gnupg |gnupg2, debian-keyring, ssh-client]*

       debsnap(1)
              grab  packages  from  https://snapshot.debian.org  [libwww-perl,
              libjson-perl]

       debuild(1)
              A  wrapper  for  building a package (i.e., dpkg-buildpackage) to
              avoid problems with insufficient  permissions  and  wrong  paths
              etc.  Debuild  will set up the proper environment for building a
              package. Debuild will use the  fakeroot  program  to  build  the
              package by default, but can be instructed to use any other gain-
              root command, or can even be installed setuid root.  Debuild can
              also  be used to run various of the debian/rules operations with
              the same root-gaining procedure. Debuild will also  run  lintian
              to  check that the package does not have any major policy viola-
              tions. [fakeroot, lintian, gnupg | gnupg2]*

       deb-reversion(1)
              increases a binary package version number and repacks the  pack-
              age, useful for porters and the like.

       deb-why-removed(1)
              shows  the  reason a package was removed from the archive. [lib-
              dpkg-perl]

       dep3changelog(1)
              generate a changelog entry from a DEP3-style patch header.

       desktop2menu(1)
              given a freedesktop.org desktop file, generate a skeleton for  a
              menu file. [libfile-desktopentry-perl]

       dget(1)
              Downloads Debian source and binary packages. Point at a .changes
              or .dsc to download all references files. Specify a package name
              to download it from the configured apt repository. [wget | curl]

       diff2patches(1)
              extracts patches from a .diff.gz file placing them under debian/
              or, if present, debian/patches. [patchutils]

       dpkg-depcheck, dpkg-genbuilddeps(1)
              Runs a specified command (such as debian/rules build)  or  dpkg-
              buildpackage,  respectively, to determine the packages used dur-
              ing the build process.  This information  can  be  helpful  when
              trying  to  determine  the  packages needed in the Build-Depends
              etc. lines in the debian/control file. [build-essential, strace]

       dscextract(1)
              extract a single file from a Debian source package. [patchutils]

       dscverify(1)
              check the signature and MD5 sums of a dsc file against the  most
              current  Debian keyring on your system. [gnupg | gnupg2, debian-
              keyring]

       edit-patch(1)
              add/edit a patch for a source package and  commit  the  changes.
              [quilt | dpatch | cdbs]

       getbuildlog(1)
              download package build logs from Debian auto-builders. [wget]

       git-deborig(1)
              try  to  produce Debian orig.tar using git-archive(1). [libdpkg-
              perl, libgit-wrapper-perl, liblist-compare-perl, libstring-shel-
              lquote-perl, libtry-tiny-perl]

       grep-excuses(1)
              grep  britney's  excuses  to  find out what is happening to your
              packages. [libdbd-pg-perl, libterm-size-perl, libyaml-syck-perl,
              wget, w3m]

       hardening-check(1)
              report the hardening characteristics of a set of binaries.

       list-unreleased(1)
              searches for packages marked UNRELEASED in their changelog.

       ltnu (Long Time No Upload)(1)
              List all uploads of packages by the given uploader or maintainer
              and display them ordered by the last  upload  of  that  package,
              oldest uploads first.

       manpage-alert(1)
              locate binaries without corresponding manpages. [man-db]

       mass-bug(1)
              mass-file bug reports. [bsd-mailx | mailx]

       mergechanges(1)
              merge  .changes files from the same release but built on differ-
              ent architectures.

       mk-build-deps(1)
              Given a package name and/or  control  file,  generate  a  binary
              package which may be installed to satisfy the build-dependencies
              of the given package. [equivs]

       mk-origtargz(1)
              Rename upstream tarball, optionally changing the compression and
              removing  unwanted  files. [libfile-which-perl, unzip, xz-utils,
              file]

       namecheck(1)
              Check project names are not already taken.

       nmudiff(1)
              prepare a diff of this version (presumably an  NMU  against  the
              previously  released  version  (as per the changelog) and submit
              the diff to the BTS. [patchutils, mutt]

       origtargz(1)
              fetch the orig tarball of a Debian package from various sources,
              and unpack it.

       plotchangelog(1)
              display  information from a changelog graphically using gnuplot.
              [libtimedate-perl, gnuplot]

       pts-subscribe(1)
              subscribe to the PTS (Package Tracking System) for a limited pe-
              riod of time. [bsd-mailx | mailx, at]

       rc-alert(1)
              list  installed packages which have release-critical bugs. [wget
              | curl]

       rmadison(1)
              remotely query  the  Debian  archive  database  about  packages.
              [liburi-perl, wget | curl]

       sadt(1)
              run DEP-8 tests. [python3-debian]

       salsa(1)
              manipulates  salsa.debian.org repositories and users [libgitlab-
              api-v4-perl]

       suspicious-source(1)
              output a list of  files  which  are  not  common  source  files.
              [python3-magic]

       svnpath(1)
              Prints  the  path  to  the Subversion repository of a Subversion
              checkout. Also supports calculating the paths for  branches  and
              tags  in  a repository independent fashion. Used by debcommit to
              generate svn tags. [subversion]

       tagpending(1)
              runs from a Debian source tree and tags  bugs  that  are  to  be
              closed in the latest changelog as pending. [libsoap-lite-perl]

       transition-check(1)
              Check  a  list of source packages for involvement in transitions
              for which uploads to unstable are  currently  blocked.  [libwww-
              perl, libyaml-syck-perl]

       uscan(1)
              Automatically scan for and download upstream updates.  Uscan can
              also call a program such as uupdate to attempt to update the De-
              bianised version based on the new update.  Whilst uscan could be
              used to release the updated version automatically, it is  proba-
              bly better not to without testing it first.  Uscan can also ver-
              ify detached OpenPGP signatures if  upstream's  signing  key  is
              known.  [file, gpgv | gpgv2, gnupg | gnupg2, libfile-which-perl,
              liblwp-protocol-https-perl, libmoo-perl, libwww-perl, unzip, xz-
              utils]*

       uupdate(1)
              Update  the  package with an archive or patches from an upstream
              author.  This will be of help if you have to update  your  pack-
              age.   It will try to apply the latest diffs to your package and
              tell you how successful it was. [patch]

       what-patch(1)
              determine what patch system, if any, a source package is  using.
              [patchutils]

       whodepends(1)
              check which maintainers' packages depend on a package.

       who-permits-upload(1)
              Retrieve  information  about  Debian  Maintainer  access control
              lists. [gnupg | gnupg2, libencode-locale-perl, libwww-perl,  de-
              bian-keyring]

       who-uploads(1)
              determine  the  most recent uploaders of a package to the Debian
              archive. [gnupg |  gnupg2,  debian-keyring,  debian-maintainers,
              wget]

       wnpp-alert(1)
              list  installed  packages which are orphaned or up for adoption.
              [wget | curl]

       wnpp-check(1)
              check whether there is an open request for packaging  or  inten-
              tion to package bug for a package. [wget | curl]

       wrap-and-sort(1)
              wrap  long lines and sort items in packaging files. [python3-de-
              bian]

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