X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=dh_auto_install;h=d513f2e223095ac99e4f1ccf5caf54e13f34752c;hb=18a0da8092ea9f3dc48bca92b36f592af25a608d;hp=5c7722454a96c9e67225ac50973bc181366187e9;hpb=596a99831d28a97e0c2c5406ca72e29fc3e4a37f;p=debhelper.git diff --git a/dh_auto_install b/dh_auto_install index 5c77224..d513f2e 100755 --- a/dh_auto_install +++ b/dh_auto_install @@ -2,82 +2,94 @@ =head1 NAME -dh_auto_install - install built files into the temporary directory under debian/ +dh_auto_install - automatically runs make install or similar =cut use strict; use Debian::Debhelper::Dh_Lib; use Debian::Debhelper::Dh_Buildsystems; +use File::Spec; use Cwd; =head1 SYNOPSIS -B [S>] [S>] [S I>] +B [S>] [S>] [S I>] =head1 DESCRIPTION -dh_auto_install is a debhelper program that is responsible for the I -step of the L building process. dh_auto_install tries to run -original package installation routine to install built files into the proper -places of the file system hierarchy recreated under the (temporary) directory -in debian/. +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. -If dh_auto_install does not meet your needs or does not work, it is safe to -skip/override it entirely and just run C or the like manually. +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. -#DH_AUTO SHARED OPTIONS# +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 +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<--> I +=item B<--destdir=>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. +Install files into the specified I. If this option is not specified, +destination directory is determined automatically as described in the +L> section. -=back +=item B<--> I -=head1 SUPPORTED BUILD SYSTEMS +Pass I to the program that is run, after the parameters that +B usually passes. -#SUPPORTED BUILD SYSTEMS INTRO# -#SUPPORTED BUILD SYSTEMS LIST# +=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); =head1 SEE ALSO -L - L -This program is a part of debhelper and its dh_auto package source building -suite. +This program is a part of debhelper. -=head1 AUTHORS +=head1 AUTHOR - Joey Hess - Modestas Vainius +Joey Hess =cut