debuild
DEBUILD(1) General Commands Manual DEBUILD(1)
NAME
debuild - build a Debian package
SYNOPSIS
debuild [debuild options] [dpkg-buildpackage options] [--lintian-opts
lintian options]
debuild [debuild options] -- binary|binary-arch|binary-indep|clean ...
DESCRIPTION
debuild creates all the files necessary for uploading a Debian package.
It first runs dpkg-buildpackage, then runs lintian on the .changes file
created (assuming that lintian is installed), and finally signs the ap-
propriate files (using debsign(1) to do this instead of dpkg-buildpack-
age(1) itself; all relevant key-signing options are passed on). Sign-
ing will be skipped if the distribution is UNRELEASED, unless dpkg-
buildpackage's --force-sign option is used. Parameters can be passed
to dpkg-buildpackage and lintian, where the parameters to the latter
are indicated with the --lintian-opts option. The allowable options in
this case are --lintian and --no-lintian to force or skip the lintian
step, respectively. The default is to run lintian. There are also var-
ious options available for setting and preserving environment vari-
ables, as described below in the Environment Variables section. In
this method of running debuild, we also save a build log to the file
../<package>_<version>_<arch>.build.
An alternative way of using debuild is to use one or more of the param-
eters binary, binary-arch, binary-indep and clean, in which case de-
build will attempt to gain root privileges and then run debian/rules
with the given parameters. A --rootcmd=gain-root-command or -rgain-
root-command option may be used to specify a method of gaining root
privileges. The gain-root-command is likely to be one of fakeroot,
sudo or super. See below for further discussion of this point. Again,
the environment preservation options may be used. In this case, de-
build will also attempt to run dpkg-checkbuilddeps first; this can be
explicitly requested or switched off using the options -D and -d re-
spectively. Note also that if either of these or a -r option is speci-
fied in the configuration file option DEBUILD_DPKG_BUILDPACKAGE_OPTS,
then it will be recognised even in this method of invocation of de-
build.
debuild also reads the devscripts configuration files as described be-
low. This allows default options to be given.
Directory name checking
In common with several other scripts in the devscripts package, debuild
will climb the directory tree until it finds a debian/changelog file
before attempting to build the package. As a safeguard against stray
files causing potential problems, it will examine the name of the par-
ent directory once it finds the debian/changelog file, and check that
the directory name corresponds to the package name. Precisely how it
does this is controlled by two configuration file variables DE-
VSCRIPTS_CHECK_DIRNAME_LEVEL and DEVSCRIPTS_CHECK_DIRNAME_REGEX, and
their corresponding command-line options --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.
ENVIRONMENT VARIABLES
As environment variables can affect the building of a package, often
unintentionally, debuild sanitises the environment by removing all en-
vironment variables except for TERM, HOME, LOGNAME, GNUPGHOME, PGPPATH,
GPG_AGENT_INFO, GPG_TTY, DBUS_SESSION_BUS_ADDRESS, FAKEROOTKEY, DEBE-
MAIL, DEB_*, the (C, CPP, CXX, LD and F)FLAGS variables and their _AP-
PEND counterparts and the locale variables LANG and LC_*. TERM is set
to `dumb' if it is unset, and PATH is set to
"/usr/sbin:/usr/bin:/sbin:/bin:/usr/bin/X11".
If a particular environment variable is required to be passed through
untouched to the build process, this may be specified by using a --pre-
serve-envvar envvar (which can also be written as -e envvar option).
The environment may be left untouched by using the --preserve-env op-
tion. However, even in this case, the PATH will be set to the sane
value described above. The only way to prevent PATH from being reset
is to specify a --preserve-envvar PATH option. But you are warned that
using programs from non-standard locations can easily result in the
package being broken, as it will not be able to be built on standard
systems.
Note that one may add directories to the beginning of the sanitised
PATH, using the --prepend-path option. This is useful when one wishes
to use tools such as ccache or distcc for building.
It is also possible to avoid having to type something like FOO=bar de-
build -e FOO by writing debuild -e FOO=bar or the long form debuild
--set-envvar FOO=bar.
SUPERUSER REQUIREMENTS
debuild needs to be run as superuser to function properly. There are
three fundamentally different ways to do this. The first, and prefer-
able, method is to use some root-gaining command. The best one to use
is probably fakeroot(1), since it does not involve granting any genuine
privileges. super(1) and sudo(1) are also possibilities. If no -r (or
--rootcmd) option is given (and recall that dpkg-buildpackage also ac-
cepts a -r option) and neither of the following methods is used, then
-rfakeroot will silently be assumed.
The second method is to use some command such as su(1) to become root,
and then to do everything as root. Note, though, that lintian will
abort if it is run as root or setuid root; this can be overcome using
the --allow-root option of lintian if you know what you are doing.
The third possible method is to have debuild installed as setuid root.
This is not the default method, and will have to be installed as such
by the system administrator. It must also be realised that anyone who
can run debuild as root or setuid root has full access to the whole ma-
chine. This method is therefore not recommended, but will work. de-
build could be installed with mode 4754, so that only members of the
owning group could run it. A disadvantage of this method would be that
other users would then not be able to use the program. There are many
other variants of this option involving multiple copies of debuild, or
the use of programs such as sudo or super to grant root privileges to
users selectively. If the sysadmin wishes to do this, she should use
the dpkg-statoverride program to change the permissions of /usr/bin/de-
build. This will ensure that these permissions are preserved across
upgrades.
HOOKS
debuild supports a number of hooks when running dpkg-buildpackage.
Note that the hooks dpkg-buildpackage to lintian (inclusive) are passed
through to dpkg-buildpackage using its corresponding --hook-name op-
tion. The available hooks are as follows:
dpkg-buildpackage-hook
Run before dpkg-buildpackage begins by calling dpkg-checkbuild-
deps.
Hook is run inside the unpacked source.
Corresponds to dpkg's init hook.
clean-hook
Run before dpkg-buildpackage runs debian/rules clean to clean
the source tree. (Run even if the tree is not being cleaned be-
cause -nc is used.)
Hook is run inside the unpacked source.
Corresponds to dpkg's preclean hook.
dpkg-source-hook
Run after cleaning the tree and before running dpkg-source.
(Run even if dpkg-source is not being called because -b, -B, or
-A is used.)
Hook is run inside the unpacked source.
Corresponds to dpkg's source hook.
dpkg-build-hook
Run after dpkg-source and before calling debian/rules build.
(Run even if this is a source-only build, so debian/rules build
is not being called.)
Hook is run inside the unpacked source.
Corresponds to dpkg's build hook.
dpkg-binary-hook
Run between debian/rules build and debian/rules binary(-arch).
Run only if a binary package is being built.
Hook is run inside the unpacked source.
Corresponds to dpkg's binary hook.
dpkg-genchanges-hook
Run after the binary package is built and before calling dpkg-
genchanges.
Hook is run inside the unpacked source.
Corresponds to dpkg's changes hook.
final-clean-hook
Run after dpkg-genchanges and before the final debian/rules
clean. (Run even if we are not cleaning the tree post-build,
which is the default.)
Hook is run inside the unpacked source.
Corresponds to dpkg's postclean hook.
lintian-hook
Run (once) before calling lintian. (Run even if we are not
calling lintian.)
Hook is run from parent directory of unpacked source.
Corresponds to dpkg's check hook.
signing-hook
Run after calling lintian before any signing takes place. (Run
even if we are not signing anything.)
Hook is run from parent directory of unpacked source.
Corresponds to dpkg's sign hook, but is run by debuild.
post-dpkg-buildpackage-hook
Run after everything has finished.
Hook is run from parent directory of unpacked source.
Corresponds to dpkg's done hook, but is run by debuild.
A hook command can be specified either in the configuration file as,
for example, DEBUILD_SIGNING_HOOK='foo' (note the hyphens change into
underscores!) or as a command line option --signing-hook-foo. The com-
mand will have certain percent substitutions made on it: %% will be re-
placed by a single % sign, %p will be replaced by the package name, %v
by the package version number, %s by the source version number, %u by
the upstream version number. Neither %s nor %u will contain an epoch.
%a will be 1 if the immediately following action is to be performed and
0 if not (for example, in the dpkg-source hook, %a will become 1 if
dpkg-source is to be run and 0 if not). Then it will be handed to the
shell to deal with, so it can include redirections and stuff. For ex-
ample, to only run the dpkg-source hook if dpkg-source is to be run,
the hook could be something like: "if [ %a -eq 1 ]; then ...; fi".
Please take care with hooks, as misuse of them can lead to packages
which FTBFS (fail to build from source). They can be useful for taking
snapshots of things or the like.
OPTIONS
For details, see above.
--no-conf, --noconf
Do not read any configuration files. This can only be used as
the first option given on the command-line.
--rootcmd=gain-root-command, -rgain-root-command
Command to gain root (or fake root) privileges.
--preserve-env
Do not clean the environment, except for PATH.
--preserve-envvar=var, -evar
Do not clean the var variable from the environment.
If var ends in an asterisk ("*") then all variables with names
that match the portion of var before the asterisk will be pre-
served.
--set-envvar=var=value, -evar=value
Set the environment variable var to value and do not remove it
from the environment.
--prepend-path=value
Once the normalized PATH has been set, prepend value to it.
--lintian
Run lintian after dpkg-buildpackage. This is the default behav-
iour, and it overrides any configuration file directive to the
contrary.
--no-lintian
Do not run lintian after dpkg-buildpackage.
--no-tgz-check
Even if we're running dpkg-buildpackage and the version number
has a Debian revision, do not check that the .orig.tar.gz file
or .orig directory exists before starting the build.
--tgz-check
If we're running dpkg-buildpackage and the version number has a
Debian revision, check that the .orig.tar.gz file or .orig di-
rectory exists before starting the build. This is the default
behaviour.
--username username
When signing, use debrsign instead of debsign. username speci-
fies the credentials to be used.
--foo-hook=hook
Set a hook as described above. If hook is blank, this unsets
the hook.
--clear-hooks
Clears all hooks. They may be reinstated by later command line
options.
--check-dirname-level N
See the above section Directory name checking for an explanation
of this option.
--check-dirname-regex regex
See the above section Directory name checking for an explanation
of this option.
-d Do not run dpkg-checkbuilddeps to check build dependencies.
-D Run dpkg-checkbuilddeps to check build dependencies.
CONFIGURATION VARIABLES
The two configuration files /etc/devscripts.conf and ~/.devscripts are
sourced by a shell in that order to set configuration variables. Com-
mand line options can be used to override some of these configuration
file settings, otherwise the --no-conf option can be used to prevent
reading these files. Environment variable settings are ignored when
these configuration files are read. The currently recognised variables
are:
DEBUILD_PRESERVE_ENV
If this is set to yes, then it is the same as the --preserve-env
command line parameter being used.
DEBUILD_PRESERVE_ENVVARS
Which environment variables to preserve. This should be a
comma-separated list of variables. This corresponds to using
possibly multiple --preserve-envvar or -e options.
DEBUILD_SET_ENVVAR_var=value
This corresponds to --set-envvar=var=value.
DEBUILD_PREPEND_PATH
This corresponds to --prepend-path.
DEBUILD_ROOTCMD
Setting this variable to prog is the equivalent of -rprog.
DEBUILD_TGZ_CHECK
Setting this variable to no is the same as the --no-tgz-check
command line option.
DEBUILD_SIGNING_USERNAME
Setting this variable is the same as using the --username com-
mand line option.
DEBUILD_DPKG_BUILDPACKAGE_OPTS
These are options which should be passed to the invocation of
dpkg-buildpackage. They are given before any command-line op-
tions. Due to issues of shell quoting, if a word containing
spaces is required as a single option, extra quotes will be re-
quired. For example, to ensure that your own GPG key is always
used, even for sponsored uploads, the configuration file might
contain the line:
DEBUILD_DPKG_BUILDPACKAGE_OPTS="-k'Julian Gilbey <jdg@debian.org>' -sa"
which gives precisely two options. Without the extra single
quotes, dpkg-buildpackage would reasonably complain that Gilbey
is an unrecognised option (it doesn't start with a - sign).
Also, if this option contains any -r, -d or -D options, these
will always be taken account of by debuild. Note that a -r op-
tion in this variable will override the setting in DE-
BUILD_ROOTCMD.
DEBUILD_FOO_HOOK
The hook variable for the foo hook. See the section on hooks
above for more details. By default, this is empty.
DEBUILD_LINTIAN
Should we run lintian? If this is set to no, then lintian will
not be run.
DEBUILD_LINTIAN_OPTS
These are options which should be passed to the invocation of
lintian. They are given before any command-line options, and
the usage of this variable is as described for the DE-
BUILD_DPKG_BUILDPACKAGE_OPTS variable.
DEVSCRIPTS_CHECK_DIRNAME_LEVEL, DEVSCRIPTS_CHECK_DIRNAME_REGEX
See the above section Directory name checking for an explanation
of these variables. Note that these are package-wide configura-
tion variables, and will therefore affect all devscripts scripts
which check their value, as described in their respective man-
pages and in devscripts.conf(5).
EXAMPLES
To build your own package, simply run debuild from inside the source
tree. dpkg-buildpackage(1) options may be given on the command line.
The typical command line options to build only the binary package(s)
without signing the .changes file (or the non-existent .dsc file):
debuild -i -us -uc -b
Change the -b to -S to build only a source package.
An example using lintian to check the resulting packages and passing
options to it:
debuild --lintian-opts -i
Note the order of options here: the debuild options come first, then
the dpkg-buildpackage ones, then finally the checker options. (And
lintian is called by default.) If you find yourself using the same
dpkg-buildpackage options repeatedly, consider using the DE-
BUILD_DPKG_BUILDPACKAGE_OPTS configuration file option as described
above.
To build a package for a sponsored upload, given foobar_1.0-1.dsc and
the respective source files, run something like the following commands:
dpkg-source -x foobar_1.0-1.dsc
cd foobar-1.0
debuild -k0x12345678
where 0x12345678 is replaced by your GPG key ID or other key identifier
such as your email address. Again, you could also use the DE-
BUILD_DPKG_BUILDPACKAGE_OPTS configuration file option as described
above to avoid having to type the -k option each time you do a spon-
sored upload.
SEE ALSO
chmod(1), debsign(1), dpkg-buildpackage(1), dpkg-checkbuilddeps(1),
fakeroot(1), lintian(1), su(1), sudo(1), super(1), devscripts.conf(5),
dpkg-statoverride(8)
AUTHOR
The original debuild program was written by Christoph Lameter <clame-
ter@debian.org>. The current version has been written by Julian Gilbey
<jdg@debian.org>.
DEBIAN Debian Utilities DEBUILD(1)
Man Pages Copyright Respective Owners. Site Copyright (C) 1994 - 2025
Hurricane Electric.
All Rights Reserved.