]> git.donarmstrong.com Git - debhelper.git/commitdiff
dh_auto_clean: New program, automates running make clean (or distclean, or realclean...
authorJoey Hess <joey@kodama.kitenet.net>
Wed, 23 Apr 2008 18:37:34 +0000 (14:37 -0400)
committerJoey Hess <joey@kodama.kitenet.net>
Wed, 23 Apr 2008 18:37:34 +0000 (14:37 -0400)
debian/changelog
dh_auto_clean [new file with mode: 0755]
dh_auto_test

index 8f832d9e6ea7c23cea93bdd19b100a568858cb8e..573c67cef9348189057663a84500bffdf5172f31 100644 (file)
@@ -12,6 +12,8 @@ debhelper (6.0.13) UNRELEASED; urgency=low
     planned but not yet implemented.)
   * dh_auto_test: New program, automates running make test or make check
     if the Makefile has such a target.
+  * dh_auto_clean: New program, automates running make clean (or distclean,
+    or realclean), or using setup.py to clean up.
 
  -- Joey Hess <joeyh@debian.org>  Tue, 22 Apr 2008 17:54:20 -0400
 
diff --git a/dh_auto_clean b/dh_auto_clean
new file mode 100755 (executable)
index 0000000..8aa6ab7
--- /dev/null
@@ -0,0 +1,73 @@
+#!/usr/bin/perl -w
+
+=head1 NAME
+
+dh_auto_clean - automatically cleans up after a build
+
+=cut
+
+use strict;
+use Debian::Debhelper::Dh_Lib;
+
+=head1 SYNOPSIS
+
+B<dh_auto_clean> [S<I<debhelper options>>] [S<B<--> I<params>>]
+
+=head1 DESCRIPTION
+
+dh_auto_clean is a debhelper program that tries to automatically clean up
+after a package build. If there's a Makefile and it contains a "distclean",
+"realclean", or "clean" target, then this is  done by running make (or MAKE,
+if the environment variable is set). If there is a setup.py, it is run to
+clean the package.
+
+This is intended to work for about 90% of packages. If it doesn't work, or
+tries to use the wrong clean target, you're encoruaged to skip using
+dh_auto_test at all, and just run make clean manually.
+
+=head1 OPTIONS
+
+=over 4
+
+=item B<--> I<params>
+
+Pass "params" to the program that is run. These can be used to suppliment
+or override the any standard parameters that dh_auto_clean passes.
+
+=back
+
+=cut
+
+init();
+
+if (-e "Makefile" || -e "makefile" || -e "GNUmakefile") {
+       $ENV{MAKE}="make" unless exists $ENV{MAKE};
+       foreach my $target (qw{distclean realclean clean}) {
+               # Make --question returns false if the target is
+               # up-to-date. But we still want to run the target in this
+               # case. So ceck if a target exists by seeing if make outputs
+               # "Making target".
+               my $ret=`LANG=C $ENV{MAKE} --question $target 2>/dev/null`;
+               chomp $ret;
+               if ($ret =~ /^Making \Q$target\E/m) {
+                       doit($ENV{MAKE}, $target, @{$dh{U_PARAMS}});
+                       last;
+               }
+       }
+}
+elsif (-e "setup.py") {
+       doit("python setup.py", "clean", "-a", @{$dh{U_PARAMS}});
+}
+
+
+=head1 SEE ALSO
+
+L<debhelper(7)>
+
+This program is a part of debhelper.
+
+=head1 AUTHOR
+
+Joey Hess <joeyh@debian.org>
+
+=cut
index 74a80e8c166f24419cfe7e8888a7c4f09ddccc6d..cf6e58a2ee773085d883baf8184caf089d275fe6 100755 (executable)
@@ -42,11 +42,16 @@ or override the any standard parameters that dh_auto_test passes.
 init();
 
 if (-e "Makefile" || -e "makefile" || -e "GNUmakefile") {
+       $ENV{MAKE}="make" unless exists $ENV{MAKE};
        foreach my $target (qw{test check}) {
-               my $ret=system("make --question $target >/dev/null 2>&1");
-               if ($ret == 0) {
-                       doit(exists $ENV{MAKE} ? $ENV{MAKE} : "make",
-                               $target, @{$dh{U_PARAMS}});
+               # Make --question returns false if the target is
+               # up-to-date. But we still want to run the target in this
+               # case. So ceck if a target exists by seeing if make outputs
+               # "Making target".
+               my $ret=`LANG=C $ENV{MAKE} --question $target 2>/dev/null`;
+               chomp $ret;
+               if ($ret =~ /^Making \Q$target\E/m) {
+                       doit($ENV{MAKE}, $target, @{$dh{U_PARAMS}});
                        last;
                }
        }