debclean
DEBCLEAN(1) General Commands Manual DEBCLEAN(1)
NAME
debclean - clean up a sourcecode tree
SYNOPSIS
debclean [options]
DESCRIPTION
debclean walks through the directory tree starting at the directory
tree in which it was invoked, and executes debuild -- clean for each
Debian source directory encountered. These directories are recognised
by containing a debian/changelog file for a package whose name matches
that of the directory. Name matching is described below.
If debclean is invoked from a directory that is already a Debian source
package, it will not descend into its subdirectories.
Also, if the --cleandebs option is given, then in every directory con-
taining a Debian source tree, all files named *.deb, *.changes and
*.build are removed. The .dsc, .diff.gz and the (.orig).tar.gz files
are not touched so that the release can be reconstructed if necessary,
and the .upload files are left so that debchange functions correctly.
The --nocleandebs option prevents this extra cleaning behaviour and the
--cleandebs option forces it. The default is not to clean these files.
debclean uses debuild(1) to clean the source tree.
Directory name checking
In common with several other scripts in the devscripts package, deb-
clean will walk through the directory tree searching for de-
bian/changelog files. As a safeguard against stray files causing po-
tential problems, it will examine the name of the parent directory once
it finds a debian/changelog file, and check that the directory name
corresponds to the package name. Precisely how it does this is con-
trolled 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.
OPTIONS
--cleandebs
Also remove all .deb, .changes and .build files from the parent
directory.
--nocleandebs
Do not remove the .deb, .changes and .build files from the par-
ent directory; this is the default behaviour.
--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.
--no-conf, --noconf
Do not read any configuration files. This can only be used as
the first option given on the command-line.
-d Do not run dpkg-checkbuilddeps to check build dependencies.
--help 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:
DEBCLEAN_CLEANDEBS
If this is set to yes, then it is the same as the --cleandebs
command line parameter being used.
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).
SEE ALSO
debuild(1), devscripts.conf(5)
AUTHOR
Christoph Lameter <clameter@debian.org>; modifications by Julian Gilbey
<jdg@debian.org>.
DEBIAN Debian Utilities DEBCLEAN(1)
Man Pages Copyright Respective Owners. Site Copyright (C) 1994 - 2025
Hurricane Electric.
All Rights Reserved.