Blame brpcompress.diff

e0a517
--- scripts/brp-compress.orig	2022-04-07 11:13:19.072518377 +0000
e0a517
+++ scripts/brp-compress	2022-12-02 13:12:31.239774558 +0000
Bernhard M. Wiedemann eb41fd
@@ -5,6 +5,9 @@ if [ -z "$RPM_BUILD_ROOT" ] || [ "$RPM_B
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 eb41fd
 PREFIX=${1:-/usr}
Bernhard M. Wiedemann 1250f9
 
Bernhard M. Wiedemann eb41fd
 cd "$RPM_BUILD_ROOT"
ee825d
@@ -13,6 +16,30 @@ cd "$RPM_BUILD_ROOT"
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 ;;
ee825d
+	*.zst|*.zstd) unzstd --rm $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 eb41fd
 for d in .${PREFIX}/man/man* .${PREFIX}/man/*/man* .${PREFIX}/info \
e0a517
     .${PREFIX}/share/man/man* .${PREFIX}/share/man/*/man* \
e0a517
     .${PREFIX}/share/info .${PREFIX}/kerberos/man \
e0a517
@@ -26,10 +53,10 @@ do
e0a517
 		[ -f "$f" ] || continue
Bernhard M. Wiedemann 1250f9
 
e0a517
     case "$f" in
e0a517
-     *.gz|*.Z)    gunzip  -f "$f"; b=`echo "$f" | sed -e 's/\.\(gz\|Z\)$//'`;;
e0a517
-     *.bz2)       bunzip2 -f "$f"; b=`echo "$f" | sed -e 's/\.bz2$//'`;;
e0a517
-     *.xz|*.lzma) unxz    -f "$f"; b=`echo "$f" | sed -e 's/\.\(xz\|lzma\)$//'`;;
e0a517
-     *.zst|*.zstd) unzstd -f --rm $f; b=`echo "$f" | sed -e 's/\.\(zst\|zstd\)$//'`;;
5b17a5
+     *.gz|*.Z)    gunzip  -f "$f" || check_for_hard_link $d "$f"; b=`echo "$f" | sed -e 's/\.\(gz\|Z\)$//'`;;
5b17a5
+     *.bz2)       bunzip2 -f "$f" || check_for_hard_link $d "$f"; b=`echo "$f" | sed -e 's/\.bz2$//'`;;
5b17a5
+     *.xz|*.lzma) unxz    -f "$f" || check_for_hard_link $d "$f"; b=`echo "$f" | sed -e 's/\.\(xz\|lzma\)$//'`;;
5b17a5
+     *.zst|*.zstd) unzstd -f --rm $f || check_for_hard_link $d "$f"; b=`echo "$f" | sed -e 's/\.\(zst\|zstd\)$//'`;;
e0a517
      *) b="$f";;
e0a517
     esac
Bernhard M. Wiedemann 1250f9
 
e0a517
@@ -38,7 +65,7 @@ do
e0a517
 		others="`find $d -type f -inum $inode`"
e0a517
 		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
e0a517
 		$COMPRESS -f "$b"
Bernhard M. Wiedemann 1250f9
 		for afile in $others ; do
e0a517
@@ -52,9 +79,9 @@ do
Bernhard M. Wiedemann 1250f9
 
e0a517
     find $d -type l -print0 |
e0a517
     while IFS= read -r -d '' f; do
e0a517
-    l=`ls -l $f | sed -e 's/.* -> //' -e 's/\.\(gz\|Z\|bz2\|xz\|lzma\|zst\|zstd\)$//'`
e0a517
-    rm -f $f
e0a517
-    b=`echo $f | sed -e 's/\.\(gz\|Z\|bz2\|xz\|lzma\|zst\|zstd\)$//'`
e0a517
+    l=`ls -l "$f" | sed -e 's/.* -> //' -e 's/\.\(gz\|Z\|bz2\|xz\|lzma\|zst\|zstd\)$//'`
e0a517
+    rm -f "$f"
e0a517
+    b=`echo "$f" | sed -e 's/\.\(gz\|Z\|bz2\|xz\|lzma\|zst\|zstd\)$//'`
e0a517
     ln -sf "$l$COMPRESS_EXT" "$b$COMPRESS_EXT"
Bernhard M. Wiedemann 1250f9
     done
Bernhard M. Wiedemann 1250f9
 done