]> git.ozlabs.org Git - next-scripts/commitdiff
check_fixes: use extglob to avoind some regexp work
authorStephen Rothwell <sfr@canb.auug.org.au>
Thu, 8 Oct 2020 00:52:31 +0000 (11:52 +1100)
committerStephen Rothwell <sfr@canb.auug.org.au>
Thu, 8 Oct 2020 00:52:31 +0000 (11:52 +1100)
also simplify some message creation

check_fixes

index d75e1efc7f8b49e94577ac47f0170a8ca5f825fd..84d72150734715e44c73da727f1f07d0d6658625 100755 (executable)
@@ -1,5 +1,7 @@
 #!/bin/bash
 
+shopt -s extglob
+
 if [ "$#" -lt 1 ]; then
         printf 'Usage: %s <commit range>\n', "$0" 1>&2
         exit 1
@@ -20,32 +22,24 @@ tab=$'\t'
 # Strip the leading and training spaces from a string
 strip_spaces()
 {
-       [[ "$1" =~ ^[[:space:]]*(.*[^[:space:]])[[:space:]]*$ ]]
-       echo "${BASH_REMATCH[1]}"
+       local str="${1##*([[:space:]])}"
+       str="${str%%*([[:space:]])}"
+       echo "$str"
 }
 
 for c in $commits; do
 
-       commit_log=$(git log -1 --format='%h ("%s")' "$c")
-       commit_msg="In commit
-
-  $commit_log
-
-"
-
-       fixes_lines=$(git log -1 --format='%B' "$c" |
-                       grep -i '^[[:space:]]*Fixes:')
-
-       while read -r fline; do
-               [[ "$fline" =~ ^[[:space:]]*[Ff][Ii][Xx][Ee][Ss]:[[:space:]]*(.*)$ ]]
-               f="${BASH_REMATCH[1]}"
-               fixes_msg="Fixes tag
-
-  $fline
+       printf -v commit_msg 'In commit\n\n  %s\n\n' \
+               "$(git log -1 --format='%h ("%s")' "$c")"
 
-has these problem(s):
+       readarray -t fixes_lines < <(git log -1 --format='%B' "$c" |
+                                       grep -i '^[[:space:]]*Fixes:')
+       fixes_lines=( "${fixes_lines[@]##*([[:space:]])}" )
+       fixes_lines=( "${fixes_lines[@]%%*([[:space:]])}" )
 
-"
+       for fline in "${fixes_lines[@]}"; do
+               f="${fline##[Ff][Ii][Xx][Ee][Ss]:*([[:space:]])}"
+               printf -v fixes_msg 'Fixes tag\n\n  %s\n\nhas these problem(s):\n\n' "$fline"
                sha=
                subject=
                msg=
@@ -141,7 +135,7 @@ has these problem(s):
                        printf '%s%s%s\n' "$commit_msg" "$fixes_msg" "$msg"
                        commit_msg=''
                fi
-       done <<< "$fixes_lines"
+       done
 done
 
 exit 0