Blame brpcompress.diff

Bernhard M. Wiedemann 1250f9
--- ./scripts/brp-compress.orig	2018-01-31 13:07:37.130104408 +0000
Bernhard M. Wiedemann 1250f9
+++ ./scripts/brp-compress	2018-01-31 13:07:16.234159981 +0000
Bernhard M. Wiedemann 1250f9
@@ -5,51 +5,78 @@ if [ -z "$RPM_BUILD_ROOT" -o "$RPM_BUILD
Bernhard M. Wiedemann 1250f9
 	exit 0
Bernhard M. Wiedemann 1250f9
 fi
Bernhard M. Wiedemann 1250f9
 
Bernhard M. Wiedemann 1250f9
+LC_ALL=
Bernhard M. Wiedemann 1250f9
+LANG=
Bernhard M. Wiedemann 1250f9
+LC_TIME=POSIX
Bernhard M. Wiedemann 1250f9
+
Bernhard M. Wiedemann 1250f9
 cd "$RPM_BUILD_ROOT"
Bernhard M. Wiedemann 1250f9
 
Bernhard M. Wiedemann 1250f9
 # Compress man pages
Bernhard M. Wiedemann 1250f9
 COMPRESS=${COMPRESS:-gzip -9 -n}
Bernhard M. Wiedemann 1250f9
 COMPRESS_EXT=${COMPRESS_EXT:-.gz}
Bernhard M. Wiedemann 1250f9
 
Bernhard M. Wiedemann 1250f9
+check_for_hard_link()
Bernhard M. Wiedemann 1250f9
+{
Bernhard M. Wiedemann 1250f9
+    dir=$1
Bernhard M. Wiedemann 1250f9
+    b=$2
Bernhard M. Wiedemann 1250f9
+
Bernhard M. Wiedemann 1250f9
+    inode=`ls -i $b | awk '{ print $1 }'`
Bernhard M. Wiedemann 1250f9
+    others=`find $dir -type f -inum $inode`
Bernhard M. Wiedemann 1250f9
+    for afile in $others ; do
Bernhard M. Wiedemann 1250f9
+	[ "$afile" != "$b" ] && rm -f "$afile"
Bernhard M. Wiedemann 1250f9
+    done
Bernhard M. Wiedemann 1250f9
+
Bernhard M. Wiedemann 1250f9
+    case $b in
Bernhard M. Wiedemann 1250f9
+	*.Z|*.gz)     gunzip  $b ;;
Bernhard M. Wiedemann 1250f9
+	*.bz2)        bunzip2 $b ;;
Bernhard M. Wiedemann 1250f9
+	*.xz|*.lzma)  unxz    $b ;;
Bernhard M. Wiedemann 1250f9
+    esac
Bernhard M. Wiedemann 1250f9
+
Bernhard M. Wiedemann 1250f9
+    type=${b##*.}
Bernhard M. Wiedemann 1250f9
+    for afile in $others ; do
Bernhard M. Wiedemann 1250f9
+	[ "${afile%.$type}" != "${b%.$type}" ] && ln ${b%.$type} ${afile%.$type}
Bernhard M. Wiedemann 1250f9
+    done
Bernhard M. Wiedemann 1250f9
+}
Bernhard M. Wiedemann 1250f9
+
Bernhard M. Wiedemann 1250f9
 for d in ./usr/man/man* ./usr/man/*/man* ./usr/info \
Bernhard M. Wiedemann 1250f9
 	./usr/share/man/man* ./usr/share/man/*/man* ./usr/share/info \
Bernhard M. Wiedemann 1250f9
 	./usr/kerberos/man ./usr/X11R6/man/man* ./usr/lib/perl5/man/man* \
Bernhard M. Wiedemann 1250f9
 	./usr/share/doc/*/man/man* ./usr/lib/*/man/man* ./usr/share/fish/man/man*
Bernhard M. Wiedemann 1250f9
 do
Bernhard M. Wiedemann 1250f9
     [ -d $d ] || continue
Bernhard M. Wiedemann 1250f9
-    for f in `find $d -type f ! -name dir`
Bernhard M. Wiedemann 1250f9
+    find $d -type f ! -name dir | while read f
Bernhard M. Wiedemann 1250f9
     do
Bernhard M. Wiedemann 1250f9
         [ -f "$f" ] || continue
Bernhard M. Wiedemann 1250f9
 
Bernhard M. Wiedemann 1250f9
 	case "$f" in
Bernhard M. Wiedemann 1250f9
-	 *.gz|*.Z)    gunzip  -f $f; b=`echo $f | sed -e 's/\.\(gz\|Z\)$//'`;;
Bernhard M. Wiedemann 1250f9
-	 *.bz2)       bunzip2 -f $f; b=`echo $f | sed -e 's/\.bz2$//'`;;
Bernhard M. Wiedemann 1250f9
-	 *.xz|*.lzma) unxz    -f $f; b=`echo $f | sed -e 's/\.\(xz\|lzma\)$//'`;;
Bernhard M. Wiedemann 1250f9
-	 *) b=$f;;
Bernhard M. Wiedemann 1250f9
+	 *.gz|*.Z)    gunzip  "$f" || check_for_hard_link $d "$f"; b=`echo $f | sed -e 's/\.\(gz\|Z\)$//'`;;
Bernhard M. Wiedemann 1250f9
+	 *.bz2)       bunzip2 "$f" || check_for_hard_link $d "$f"; b=`echo $f | sed -e 's/\.bz2$//'`;;
Bernhard M. Wiedemann 1250f9
+	 *.xz|*.lzma) unxz    "$f" || check_for_hard_link $d "$f"; b=`echo $f | sed -e 's/\.\(xz\|lzma\)$//'`;;
Bernhard M. Wiedemann 1250f9
+	 *) b="$f";;
Bernhard M. Wiedemann 1250f9
 	esac
Bernhard M. Wiedemann 1250f9
 
Bernhard M. Wiedemann 1250f9
-	$COMPRESS $b </dev/null 2>/dev/null || {
Bernhard M. Wiedemann 1250f9
+	$COMPRESS "$b" </dev/null 2>/dev/null || {
Bernhard M. Wiedemann 1250f9
 	    inode=`ls -i $b | awk '{ print $1 }'`
Bernhard M. Wiedemann 1250f9
 	    others=`find $d -type f -inum $inode`
Bernhard M. Wiedemann 1250f9
 	    if [ -n "$others" ]; then
Bernhard M. Wiedemann 1250f9
 		for afile in $others ; do
Bernhard M. Wiedemann 1250f9
-		    [ "$afile" != "$b" ] && rm -f $afile
Bernhard M. Wiedemann 1250f9
+		    [ "$afile" != "$b" ] && rm -f "$afile"
Bernhard M. Wiedemann 1250f9
 		done
Bernhard M. Wiedemann 1250f9
-		$COMPRESS -f $b
Bernhard M. Wiedemann 1250f9
+		$COMPRESS -f "$b"
Bernhard M. Wiedemann 1250f9
 		for afile in $others ; do
Bernhard M. Wiedemann 1250f9
-		    [ "$afile" != "$b" ] && ln $b$COMPRESS_EXT $afile$COMPRESS_EXT
Bernhard M. Wiedemann 1250f9
+		    [ "$afile" != "$b" ] && ln "$b$COMPRESS_EXT" "$afile$COMPRESS_EXT"
Bernhard M. Wiedemann 1250f9
 		done
Bernhard M. Wiedemann 1250f9
 	    else
Bernhard M. Wiedemann 1250f9
-		$COMPRESS -f $b
Bernhard M. Wiedemann 1250f9
+		$COMPRESS -f "$b"
Bernhard M. Wiedemann 1250f9
 	    fi
Bernhard M. Wiedemann 1250f9
 	}
Bernhard M. Wiedemann 1250f9
     done
Bernhard M. Wiedemann 1250f9
 
Bernhard M. Wiedemann 1250f9
-    for f in `find $d -type l`
Bernhard M. Wiedemann 1250f9
+    find $d -type l | while read f
Bernhard M. Wiedemann 1250f9
     do
Bernhard M. Wiedemann 1250f9
-	l=`ls -l $f | sed -e 's/.* -> //' -e 's/\.\(gz\|Z\|bz2\|xz\|lzma\)$//'`
Bernhard M. Wiedemann 1250f9
-	rm -f $f
Bernhard M. Wiedemann 1250f9
-	b=`echo $f | sed -e 's/\.\(gz\|Z\|bz2\|xz\|lzma\)$//'`
Bernhard M. Wiedemann 1250f9
-	ln -sf $l$COMPRESS_EXT $b$COMPRESS_EXT
Bernhard M. Wiedemann 1250f9
+	l="`ls -l "$f" | sed -e 's/.* -> //' -e 's/\.\(gz\|Z\|bz2\|xz\|lzma\)$//'`"
Bernhard M. Wiedemann 1250f9
+	rm -f "$f"
Bernhard M. Wiedemann 1250f9
+	b="`echo "$f" | sed -e 's/\.\(gz\|Z\|bz2\|xz\|lzma\)$//'`"
Bernhard M. Wiedemann 1250f9
+	ln -sf "$l$COMPRESS_EXT" "$b$COMPRESS_EXT"
Bernhard M. Wiedemann 1250f9
     done
Bernhard M. Wiedemann 1250f9
 done