X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=dh_auto_install;h=d513f2e223095ac99e4f1ccf5caf54e13f34752c;hb=e2a6d4cec4a7ee952cf6a7f250d80f1d75a38f95;hp=c115a184aa791d278fcb1e2500bbd354b9518eac;hpb=776abbb23a899ebba954774c8b3740706a21f72b;p=debhelper.git diff --git a/dh_auto_install b/dh_auto_install index c115a18..d513f2e 100755 --- a/dh_auto_install +++ b/dh_auto_install @@ -9,60 +9,78 @@ 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 -B [S>] [S I>] +B [S>] [S>] [S I>] =head1 DESCRIPTION -dh_auto_install is a debhelper program that tries to automatically install -built files. 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. +B 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 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. -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. +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. -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. +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 +=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 -my $manager = new Debian::Debhelper::Dh_Buildsystems; -$manager->init_dh_auto_tool(); - 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()); -$manager->run_dh_auto_tool($destdir); +buildsystems_do("install", $destdir); =head1 SEE ALSO