X-Git-Url: https://git.donarmstrong.com/?p=debhelper.git;a=blobdiff_plain;f=dh_auto_install;h=d513f2e223095ac99e4f1ccf5caf54e13f34752c;hp=446470270a19bdd55415e3e9219aa597e678a175;hb=fb8f18f4a98669c3b85e1bd7920fbabfc00b886e;hpb=93c1062bc3ee340fcd7318e91fe9758d86b760f3 diff --git a/dh_auto_install b/dh_auto_install index 4464702..d513f2e 100755 --- a/dh_auto_install +++ b/dh_auto_install @@ -9,6 +9,7 @@ dh_auto_install - automatically runs make install or similar use strict; use Debian::Debhelper::Dh_Lib; use Debian::Debhelper::Dh_Buildsystems; +use File::Spec; use Cwd; =head1 SYNOPSIS @@ -17,54 +18,67 @@ B [S>] [S>] [S is a debhelper program that tries to automatically install built files. It does so by running the appropriate command for the build -system it detects the package uses. For example, if there's a Makefile and -it contains a "install" target, then this is done by running make (or MAKE, -if the environment variable is set). If there is a setup.py or Build.PL, -it is used. - -The files are installed into debian// if there is only one binary -package. In the multiple binary package case, the files are instead -installed into debian/tmp/, and should be moved from there to the -appropriate package build directory using L or -L. - -DESTDIR is used to tell make where to install the files. -If the Makefile was generated by MakeMaker from a Makefile.PL, it will -automatically set PREFIX=/usr too, since such Makefiles need that. +system it detects the package uses. For example, if there's a F and +it contains a B target, then this is done by running B (or B, +if the environment variable is set). If there is a F or F, +it is used. Note that the Ant build system does not support installation, +so B will not install files built using Ant. + +Unless B<--destdir> option is specified, the files are installed into +debian/I/ if there is only one binary package. In the multiple binary +package case, the files are instead installed into F, and should be +moved from there to the appropriate package build directory using +L. + +B is used to tell make where to install the files. +If the Makefile was generated by MakeMaker from a F, it will +automatically set B too, since such Makefiles need that. This is intended to work for about 90% of packages. If it doesn't work, or tries to use the wrong install target, you're encouraged to skip using -dh_auto_install at all, and just run make install manually. +B at all, and just run make install manually. =head1 OPTIONS +See L> for a list of common build +system selection and control options. + =over 4 -See L for a list of common build -system selection and control options. +=item B<--destdir=>I + +Install files into the specified I. If this option is not specified, +destination directory is determined automatically as described in the +L> section. =item B<--> I -Pass "params" to the program that is run. These can be used to supplement -or override the any standard parameters that dh_auto_install passes. +Pass I to the program that is run, after the parameters that +B usually passes. =back =cut -buildsystems_init(); - my $destdir; -my @allpackages=getpackages(); -if (@allpackages > 1) { - $destdir="debian/tmp"; -} -else { - $destdir=tmpdir($dh{MAINPACKAGE}); + +buildsystems_init(options => { + "destdir=s" => \$destdir, +}); + +# If destdir is not specified, determine it automatically +if (!$destdir) { + my @allpackages=getpackages(); + if (@allpackages > 1) { + $destdir="debian/tmp"; + } + else { + $destdir=tmpdir($dh{MAINPACKAGE}); + } } -$destdir=cwd()."/".$destdir; +$destdir = File::Spec->rel2abs($destdir, cwd()); buildsystems_do("install", $destdir);