#!/usr/bin/perl -w =head1 NAME dh_clean - clean up package build directories =cut use strict; use Debian::Debhelper::Dh_Lib; =head1 SYNOPSIS B [S>] [B<-k>] [B<-d>] [B<-X>I] [S>] =head1 DESCRIPTION dh_clean is a debhelper program that is responsible for cleaning up after a package is built. It removes the package build directories, and removes some other files including debian/files, and any detritus left behind by other debhelper commands. It also removes common files that should not appear in a debian diff: #*# *~ DEADJOE *.orig *.rej *.SUMS TAGS .deps/* *.P *-stamp It does not run "make clean" to clean up after the build process. Use L to do things like that. dh_clean (or "dh clean") should be the last debhelper command run in the clean target in debian/rules. =head1 FILES =over 4 =item debian/clean Can list other files to be removed. =back =head1 OPTIONS =over 4 =item B<-k>, B<--keep> This is deprecated, use L instead. =item B<-d>, B<--dirs-only> Only clean the package build directories, do not clean up any other files at all. =item B<-X>I B<--exclude=>I Exclude files that contain "item" anywhere in their filename from being deleted, even if they would normally be deleted. You may use this option multiple times to build up a list of things to exclude. =item I Delete these files too. =back =cut init(options => { "dirs-only" => \$dh{D_FLAG}, }); inhibit_log(); if ($dh{K_FLAG}) { # dh_prep will be emulated (mostly) by the code below. # TODO deprecation warning } foreach my $package (@{$dh{DOPACKAGES}}) { my $tmp=tmpdir($package); my $ext=pkgext($package); if (! $dh{D_FLAG}) { doit("rm","-f","debian/${ext}substvars") unless excludefile("debian/${ext}substvars"); # These are all debhelper temp files, and so it is safe to # wildcard them. complex_doit("rm -f debian/$ext*.debhelper"); if (! $dh{K_FLAG}) { doit("rm","-f","debian/${ext}debhelper.log"); } } doit ("rm","-rf",$tmp."/") unless excludefile($tmp); } if (! $dh{D_FLAG}) { if (@ARGV) { doit("rm","-f","--",@ARGV); } if (! $dh{K_FLAG}) { if (!compat(6) && -e "debian/clean") { my @clean=grep { ! excludefile($_) } filearray("debian/clean", "."); doit("rm","-f","--",@clean) if @clean; } doit("rm","-f","debian/files") unless excludefile("debian/files"); } # See if some files that would normally be deleted are excluded. my $find_options=''; if (defined($dh{EXCLUDE_FIND}) && $dh{EXCLUDE_FIND} ne '') { $find_options="! \\( $dh{EXCLUDE_FIND} \\) -a"; } # Remove other temp files. complex_doit("find . $find_options \\( \\( -type f -a \\ \\( -name '#*#' -o -name '.*~' -o -name '*~' -o -name DEADJOE \\ -o -name '*.orig' -o -name '*.rej' -o -name '*.bak' \\ -o -name '.*.orig' -o -name .*.rej -o -name '.SUMS' \\ -o -name TAGS -o \\( -path '*/.deps/*' -a -name '*.P' \\) \\ \\) -exec rm -f {} \\; \\) -o \\ \\( -type d -a -name autom4te.cache -prune -exec rm -rf {} \\; \\) \\)"); } doit('rm', '-rf', 'debian/tmp') if -x 'debian/tmp' && ! compat(1) && ! excludefile("debian/tmp"); if (!compat(6) && !$dh{K_FLAG}) { complex_doit('rm -f *-stamp'); } =head1 SEE ALSO L This program is a part of debhelper. =head1 AUTHOR Joey Hess =cut