]> git.donarmstrong.com Git - debhelper.git/blobdiff - dh_installdirs
r424: typo
[debhelper.git] / dh_installdirs
index bab883d779819f5cc1444235c30f436dfeec0504..340c966e4e8fd69e69d914c19beb944992debdcc 100755 (executable)
@@ -1,39 +1,42 @@
-#!/bin/sh -e
+#!/usr/bin/perl -w
 #
-# Reads debian/dirs, creates the directories listed there there
+# Reads debian/dirs, creates the directories listed there
 
-PATH=debian:$PATH:/usr/lib/debhelper
-. dh_lib
+use strict;
+use Debian::Debhelper::Dh_Lib;
+init();
 
-for PACKAGE in $DH_DOPACKAGES; do
-       TMP=`tmpdir $PACKAGE`
-       EXT=`pkgext $PACKAGE`
+foreach my $package (@{$dh{DOPACKAGES}}) {
+       my $tmp=tmpdir($package);
+       my $file=pkgfile($package,"dirs");
 
-       if [ ! -d $TMP/usr/doc/$PACKAGE ]; then
-               doit "install -d $TMP/usr/doc/$PACKAGE"
-       fi
+       if (! -e $tmp) {
+               doit("install","-d",$tmp);
+       }
 
-       dirs=""
+       my @dirs;
 
-       if [ -e debian/${EXT}dirs ]; then
-               dirs=`tr "\n" " " < debian/${EXT}dirs`
-       fi
+       if ($file) {
+               @dirs=filearray($file)
+       }
 
-       if [ "$PACKAGE" = "$MAINPACKAGE" -a "$*" ]; then
-               dirs="$* $dirs"
-       fi
+       if (($package eq $dh{FIRSTPACKAGE} || $dh{PARAMS_ALL}) && @ARGV) {
+               push @dirs, @ARGV;
+       }       
+
+       if (@dirs) {
+               # Stick the $tmp onto the front of all the dirs.
+               # This is necessary, for 2 reasons, one to make them 
+               # be in the right directory, but more importantly, it 
+               # protects against the danger of absolute dirs being
+               # specified.
+               @dirs=map {
+                               $_="$tmp/$_";
+                               tr:/:/:s; # just beautification.
+                               $_
+                         } @dirs;
 
-       if [ "$dirs" ]; then
-               # Check to see if any of the dirs are absolute.
-               for dir in "$dirs" ; do
-                       if expr "$dir" : "/" >/dev/null ; then
-                               error "Absolute directory name \"$dir\" specified."
-                       fi
-               done
                # Create dirs.
-               verbose_echo "cd $TMP && install -d $dirs && cd ../.."
-               cd $TMP
-               install -d $dirs
-               cd ../..
-       fi
-done
+               doit("install","-d",@dirs);
+       }
+}