]> git.donarmstrong.com Git - debhelper.git/blobdiff - dh_fixperms
r767: This commit was manufactured by cvs2svn to create tag
[debhelper.git] / dh_fixperms
index 0e845335cb8f6327cf44142f3c4347df92b1fc2c..ba4e74d643d982b30b534a0bb17069b0befc157f 100755 (executable)
@@ -1,49 +1,42 @@
-#!/bin/sh -e
+#!/usr/bin/perl -w
 #
 # Do some general file permission fixups.
 
-PATH=debian:$PATH:/usr/lib/debhelper
-. dh_lib
+BEGIN { push @INC, "debian", "/usr/share/debhelper" }
+use Dh_Lib;
+init();
 
-for PACKAGE in $DH_DOPACKAGES; do
-       TMP=`tmpdir $PACKAGE`
+foreach $PACKAGE (@{$dh{DOPACKAGES}}) {
+       $TMP=tmpdir($PACKAGE);
 
-       # General permissions fixing.
-       if [ ! "$DH_EXCLUDE_FIND" ]; then
-               # It's much faster to do it this way, but we can only do
-               # this if there is nothing to exclude.
-               if [ -d $TMP ]; then
-                       doit "chown -R root.root $TMP"
-                       doit "chmod -R go=rX $TMP"
-                       doit "chmod -R u+rw $TMP"
-               fi
-
-               FIND_OPTIONS=""
-       else
-               # Do it the hard way.
-               complex_doit "find $TMP ! \( $DH_EXCLUDE_FIND \) -print0 \
-                       2>/dev/null | xargs -0r chown root.root"
-               complex_doit "find $TMP ! \($DH_EXCLUDE_FIND \) -print0 \
-                       2>/dev/null | xargs -0r chmod go=rX"
-               complex_doit "find $TMP ! \( $DH_EXCLUDE_FIND \) -print0 \
-                       2>/dev/null | xargs -0r chmod u+rw"
+       if (! defined($dh{EXCLUDE_FIND}) || $dh{EXCLUDE_FIND} eq '') {
+               $find_options="";
+       }
+       else {
+               $find_options="! \\( $dh{EXCLUDE_FIND} \\)";
+       }
 
-               FIND_OPTIONS="! \( $DH_EXCLUDE_FIND \)"
-       fi
+       # General permissions fixing.
+       complex_doit("find $TMP ! -type l $find_options -print0",
+               "2>/dev/null | xargs -0r chown root.root");
+       complex_doit("find $TMP ! -type l $find_options -print0",
+               "2>/dev/null | xargs -0r chmod go=rX,u+rw,a-s");
+               
 
        # Fix up premissions in usr/doc, setting everything to not exectable
        # by default, but leave examples directories alone.
-       complex_doit "find $TMP/usr/doc -type f $FIND_OPTIONS ! -regex .\*/examples/.\* -print0 \
-               2>/dev/null | xargs -0r chmod 644"
-       complex_doit "find $TMP/usr/doc -type d $FIND_OPTIONS -print0 \
-               2>/dev/null | xargs -0r chmod 755"
+       complex_doit("find $TMP/usr/share/doc $TMP/usr/doc -type f $find_options ! -regex '.*/examples/.*' -print0",
+               "2>/dev/null | xargs -0r chmod 644");
+       complex_doit("find $TMP/usr/share/doc $TMP/usr/doc -type d $find_options -print0",
+               "2>/dev/null | xargs -0r chmod 755");
 
        # Executable man pages are a bad thing..
-       complex_doit "find $TMP/usr/man/ $TMP/usr/X11*/man/ -type f \
-               $FIND_OPTIONS -print0 2>/dev/null | xargs -0r chmod 644"
-
-       # ..and so are executable shared libraries (and .la files from libtool)
-       complex_doit "find $TMP -perm -5 -type f \
-               \( -name "*.so*" -or -name "*.la" \) $FIND_OPTIONS -print0 \
-               2>/dev/null | xargs -0r chmod a-X"
-done
+       complex_doit("find $TMP/usr/share/man $TMP/usr/man/ $TMP/usr/X11*/man/ -type f",
+               "$find_options -print0 2>/dev/null | xargs -0r chmod 644");
+
+       # ..and so are executable shared and static libraries 
+       # (and .la files from libtool)
+       complex_doit("find $TMP -perm -5 -type f",
+               "\\( -name '*.so*' -or -name '*.la' -or -name '*.a' \\) $find_options -print0",
+               "2>/dev/null | xargs -0r chmod a-X");
+}