X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=dh_movefiles;h=3f59d9e5dfddbc5929e2dfc8dea80fca22867186;hb=fb8f18f4a98669c3b85e1bd7920fbabfc00b886e;hp=499baf6d2e62a66e8b711c5a97f4c84ea520e619;hpb=23ed23599d8f231166357766d4bea10d12aa363a;p=debhelper.git diff --git a/dh_movefiles b/dh_movefiles index 499baf6..3f59d9e 100755 --- a/dh_movefiles +++ b/dh_movefiles @@ -11,20 +11,29 @@ use Debian::Debhelper::Dh_Lib; =head1 SYNOPSIS -B [S>] [B<--sourcedir=>I] [S>] +B [S>] [B<--sourcedir=>I] [B<-X>I] S ...>] =head1 DESCRIPTION -dh_movefiles is a debhelper program that is responsible for moving files -out of debian/tmp or some other directory and into other package build -directories. This may be useful if your package has a Makefile that installs -everything into debian/tmp, and you need to break that up into subpackages. +B is a debhelper program that is responsible for moving files +out of F or some other directory and into other package build +directories. This may be useful if your package has a F that installs +everything into F, and you need to break that up into subpackages. -Files named debian/package.files list the files to be moved, separated by -whitespace. The filenames listed should be relative to debian/tmp/. You can -also list directory names, and the whole directory will be moved. If you -prefer, you can list the files to move on the command line and this will -apply to the first package dh_movefiles is told to act on. +Note: B is a much better program, and you are recommended to use +it instead of B. + +=head1 FILES + +=over 4 + +=item debian/I.files + +Lists the files to be moved into a package, separated by whitespace. The +filenames listed should be relative to F. You can also list +directory names, and the whole directory will be moved. + +=back =head1 OPTIONS @@ -32,34 +41,41 @@ apply to the first package dh_movefiles is told to act on. =item B<--sourcedir=>I -Instead of moving files out of debian/tmp (the default), this option makes +Instead of moving files out of F (the default), this option makes it move files out of some other directory. Since the entire contents of -the sourcedir is moved, specifiying something like --sourcedir=/ is very +the sourcedir is moved, specifying something like B<--sourcedir=/> is very unsafe, so to prevent mistakes, the sourcedir must be a relative filename; -it cannot begin with a `/'. +it cannot begin with a `B'. + +=item B<-Xitem>, B<--exclude=item> -=item I +Exclude files that contain B anywhere in their filename from +being installed. + +=item I ... Lists files to move. The filenames listed should be relative to -debian/tmp/. You can also list directory names, and the whole directory will -be moved. It is an error to list files here unless you use -p, -i, or -a to -tell dh_movefiles which subpackage to put them in. +F. You can also list directory names, and the whole directory will +be moved. It is an error to list files here unless you use B<-p>, B<-i>, or B<-a> to +tell B which subpackage to put them in. =back =head1 NOTES -Note that files are always moved out of debian/tmp by default (even if you +Note that files are always moved out of F by default (even if you have instructed debhelper to use a compatibility level higher than one, which does not otherwise use debian/tmp for anything at all). The idea behind this is that the package that is being built can be told to install -into debian/tmp, and then files can be moved by dh_movefiles from that +into F, and then files can be moved by B from that directory. Any files or directories that remain are ignored, and get -deleted by dh_clean later. +deleted by B later. =cut -init(); +init(options => { + "sourcedir=s" => \$dh{SOURCEDIR}, +}); my $ret=0; @@ -118,16 +134,26 @@ foreach my $package (@{$dh{DOPACKAGES}}) { doit("rm","-f","debian/movelist"); foreach (@tomove) { my $file=$_; - if (! -e $file && ! -l $file) { + if (! -e $file && ! -l $file && ! $dh{NO_ACT}) { $ret=1; warning("$file not found (supposed to put it in $package)"); } - $file=~s:^\Q$sourcedir\E/+::; - complex_doit("(cd $sourcedir >/dev/null ; find $file ! -type d -print || true) >> debian/movelist"); + else { + $file=~s:^\Q$sourcedir\E/+::; + my $cmd="(cd $sourcedir >/dev/null ; find $file ! -type d "; + if ($dh{EXCLUDE_FIND}) { + $cmd.="-a ! \\( $dh{EXCLUDE_FIND} \\) "; + } + $cmd.="-print || true) >> debian/movelist"; + complex_doit($cmd); + } } my $pwd=`pwd`; chomp $pwd; - complex_doit("(cd $sourcedir >/dev/null ; tar --create --remove-files --files-from=$pwd/debian/movelist --file -) | (cd $tmp >/dev/null ;tar xpf -)"); + complex_doit("(cd $sourcedir >/dev/null ; tar --create --files-from=$pwd/debian/movelist --file -) | (cd $tmp >/dev/null ;tar xpf -)"); + # --remove-files is not used above because tar then doesn't + # preserve hard links + complex_doit("(cd $sourcedir >/dev/null ; tr '\\n' '\\0' < $pwd/debian/movelist | xargs -0 rm -f)"); doit("rm","-f","debian/movelist"); } } @@ -143,7 +169,7 @@ exit $ret; =head1 SEE ALSO -L +L This program is a part of debhelper.