brp-mangle-shebangs: do not stat / touch files needlessly

Run "stat" to get mtime, and "touch -d $saved_mtime"
only if we indeed modify file's shebang.

Signed-off-by: Denys Vlasenko <dvlasenk@redhat.com>
This commit is contained in:
Denys Vlasenko 2019-11-21 17:05:52 +01:00 committed by Igor Gnatenko
parent 618362d6fb
commit 140ee1de89
No known key found for this signature in database
GPG Key ID: 695714BD1BBC5F4C

View File

@ -92,12 +92,12 @@ while IFS= read -r line; do
echo "$path" | grep -q -E -f "$exclude_files_from" && continue echo "$path" | grep -q -E -f "$exclude_files_from" && continue
fi fi
ts=$(stat -c %y "$f")
read shebang_line < "$f" read shebang_line < "$f"
orig_shebang="${shebang_line#\#!}" orig_shebang="${shebang_line#\#!}"
if [ "$orig_shebang" = "$shebang_line" ]; then if [ "$orig_shebang" = "$shebang_line" ]; then
echo >&2 "*** WARNING: $f is executable but has no shebang, removing executable bit" echo >&2 "*** WARNING: $f is executable but has no shebang, removing executable bit"
ts=$(stat -c %y "$f")
chmod -x "$f" chmod -x "$f"
touch -d "$ts" "$f" touch -d "$ts" "$f"
continue continue
@ -114,6 +114,7 @@ while IFS= read -r line; do
if [ -z "$shebang" ]; then if [ -z "$shebang" ]; then
echo >&2 "*** WARNING: $f is executable but has empty shebang, removing executable bit" echo >&2 "*** WARNING: $f is executable but has empty shebang, removing executable bit"
ts=$(stat -c %y "$f")
chmod -x "$f" chmod -x "$f"
touch -d "$ts" "$f" touch -d "$ts" "$f"
continue continue
@ -145,11 +146,12 @@ while IFS= read -r line; do
echo >&2 "*** ERROR: ambiguous python shebang in $path: #!$orig_shebang. Change it to python3 (or python2) explicitly." echo >&2 "*** ERROR: ambiguous python shebang in $path: #!$orig_shebang. Change it to python3 (or python2) explicitly."
fail=1 fail=1
elif [ "#!$shebang" != "#!$orig_shebang" ]; then elif [ "#!$shebang" != "#!$orig_shebang" ]; then
sed -i -e "1c #!$shebang" "$f"
echo "mangling shebang in $path from $orig_shebang to #!$shebang" echo "mangling shebang in $path from $orig_shebang to #!$shebang"
ts=$(stat -c %y "$f")
sed -i -e "1c #!$shebang" "$f"
touch -d "$ts" "$f"
fi fi
touch -d "$ts" "$f"
done done
exit $fail exit $fail