X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=bin%2Fget-fixes-pick-list.sh;h=047ea3bec1056ff9889a2a98fb08ad240fa19d24;hb=6b1836aabeab3cd4d7d318214d7d2c59386ba7ee;hp=59bcae4f2dde42009c6157a8465b8ab3608ad522;hpb=32be87852b06aae4618505aa0f26586436a8c927;p=mesa.git diff --git a/bin/get-fixes-pick-list.sh b/bin/get-fixes-pick-list.sh index 59bcae4f2dd..047ea3bec10 100755 --- a/bin/get-fixes-pick-list.sh +++ b/bin/get-fixes-pick-list.sh @@ -16,7 +16,7 @@ latest_branchpoint=`git merge-base origin/master HEAD` git log --reverse --pretty=%H $latest_branchpoint > already_landed # ... and the ones cherry-picked. -git log --reverse --grep="cherry picked from commit" $latest_branchpoint..HEAD |\ +git log --reverse --pretty=medium --grep="cherry picked from commit" $latest_branchpoint..HEAD |\ grep "cherry picked from commit" |\ sed -e 's/^[[:space:]]*(cherry picked from commit[[:space:]]*//' -e 's/)//' > already_picked @@ -24,35 +24,55 @@ git log --reverse --grep="cherry picked from commit" $latest_branchpoint..HEAD | git log --reverse --pretty=%H -i --grep="fixes:" $latest_branchpoint..origin/master |\ while read sha do - # For each one try to extract the tag - fixes_count=`git show $sha | grep -i "fixes:" | wc -l` - if [ "x$fixes_count" != x1 ] ; then - echo WARNING: Commit $sha has nore than one Fixes tag + # Check to see whether the patch is on the ignore list ... + if [ -f bin/.cherry-ignore ] ; then + if grep -q ^$sha bin/.cherry-ignore ; then + continue + fi fi - fixes=`git show $sha | grep -i "fixes:" | head -n 1` - # The following sed/cut combination is borrowed from GregKH - id=`echo ${fixes} | sed -e 's/^[ \t]*//' | cut -f 2 -d ':' | sed -e 's/^[ \t]*//' | cut -f 1 -d ' '` - - # Bail out if we cannot find suitable id. - # Any specific validation the $id is valid and not some junk, is - # implied with the follow up code - if [ "x$id" = x ] ; then + + # Skip if it has been already cherry-picked. + if grep -q ^$sha already_picked ; then continue fi - # Check if the offending commit is in branch. + # Place every "fixes:" tag on its own line and join with the next word + # on its line or a later one. + fixes=`git show --pretty=medium -s $sha | tr -d "\n" | sed -e 's/fixes:[[:space:]]*/\nfixes:/Ig' | grep "fixes:" | sed -e 's/\(fixes:[a-zA-Z0-9]*\).*$/\1/'` - # Be that cherry-picked ... - # ... or landed before the branchpoint. - if grep -q ^$id already_picked || - grep -q ^$id already_landed ; then + # For each one try to extract the tag + fixes_count=`echo "$fixes" | wc -l` + warn=`(test $fixes_count -gt 1 && echo $fixes_count) || echo 0` + while [ $fixes_count -gt 0 ] ; do + # Treat only the current line + id=`echo "$fixes" | tail -n $fixes_count | head -n 1 | cut -d : -f 2` + fixes_count=$(($fixes_count-1)) - # Finally nominate the fix if it hasn't landed yet. - if grep -q ^$sha already_picked ; then + # Bail out if we cannot find suitable id. + # Any specific validation the $id is valid and not some junk, is + # implied with the follow up code + if [ "x$id" = x ] ; then continue fi - echo Commit $sha fixes $id + # Check if the offending commit is in branch. + + # Be that cherry-picked ... + # ... or landed before the branchpoint. + if grep -q ^$id already_picked || + grep -q ^$id already_landed ; then + + printf "Commit \"%s\" fixes %s\n" \ + "`git log -n1 --pretty=oneline $sha`" \ + "$id" + warn=$(($warn-1)) + fi + + done + + if [ $warn -gt 0 ] ; then + printf "WARNING: Commit \"%s\" has more than one Fixes tag\n" \ + "`git log -n1 --pretty=oneline $sha`" fi done