]> git.donarmstrong.com Git - debhelper.git/blobdiff - dh_clean
r458: * Typo, Closes: #92407
[debhelper.git] / dh_clean
index da2c4b2279f5607c8df9e6d1b01e1f398b39a9ce..341d1fbf6b6c140b82da5d8aaa886eb283e9a458 100755 (executable)
--- a/dh_clean
+++ b/dh_clean
-#!/bin/sh -e
-#
-# Clean up debian/tmp and other teporary files generated by the 
-# build process.
-
-PATH=debian:$PATH:/usr/lib/debhelper
-source dh_lib
-
-doit "rm -rf debian/tmp"
-doit "rm -f debian/substvars debian/*.substvars debian/files*"
-
-# Remove other temp files. I don't run this through doit becuase
-# I haven't figured out what I have to esacape to put it in quotes.
-# However, it doesn't modify debian/tmp, so I guess it's ok to not run it 
-# through doit.
-find . \( -name "\#*\#" -o -name "*~" -o -name "DEADJOE" \) -exec rm -f {} \;
+#!/usr/bin/perl -w
+
+=head1 NAME
+
+dh_clean - clean up package build directories
+
+=cut
+
+use strict;
+use Debian::Debhelper::Dh_Lib;
+
+=head1 SYNOPSIS
+
+  dh_clean [debhelper options] [-k] [-d] [file ...] [-Xitem]
+
+=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, such as debian/substvars, 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 core .deps/* *.P
+
+=head1 OPTIONS
+
+=over 4
+
+=item B<-k>, B<--keep>
+
+Do not delete debian/files. When do you want to use this? Anytime you have a
+debian/rules that has 2 binary targets that build different .deb packages;
+for example, one target is binary-arch, and the other is binary-indep, or
+one target builds the shared library, and the other the -dev package. If you
+didn't use -k in these cases, then debian/files would be deleted in the
+middle, and your changes file will only contain the last binary package that
+was built.
+
+=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<item> B<--exclude=>I<item>
+
+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<file ...>
+
+Delete these files too.
+
+=back
+
+=cut
+
+init();
+
+foreach my $package (@{$dh{DOPACKAGES}}) {
+       my $tmp=tmpdir($package);
+       my $ext=pkgext($package);
+
+       if (! $dh{D_FLAG}) {
+               doit("rm","-f","debian/${ext}substvars",
+                       "debian/${ext}postinst.debhelper",
+                       "debian/${ext}postrm.debhelper",
+                       "debian/${ext}preinst.debhelper",
+                       "debian/${ext}prerm.debhelper");
+       }
+       
+       doit ("rm","-rf",$tmp);
+}
+
+if (! $dh{D_FLAG}) {
+       if (@ARGV) {
+               doit("rm","-f","--",@ARGV);
+       }
+
+       if (! $dh{K_FLAG}) {
+               doit("rm","-f","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="-a ! ( $dh{EXCLUDE_FIND} )";
+       }
+
+       # Remove other temp files.
+       # (The \s+ is important, \s won't work because find would get null
+       # parameters). Note that you _don't_ quote wildcards used by find
+       # in here.
+       doit(split(/\s+/,"find . -type f -a
+               ( -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 -name core -o ( -path */.deps/* -a -name *.P )
+               ) $find_options -exec rm -f {} ;"));
+}
+
+doit('rm', '-rf', 'debian/tmp') if -x 'debian/tmp' && ! compat(1);
+
+=head1 SEE ALSO
+
+L<debhelper(1)>
+
+This program is a part of debhelper.
+
+=head1 AUTHOR
+
+Joey Hess <joeyh@debian.org>
+
+=cut