Blame return_disttag.sh

4d96e5
#!/bin/bash -u
4d96e5
#
4d96e5
# Extracts what appears to be the value of %{dist} from the commit message
4d96e5
#
4d96e5
# Might want to drop this in ~/bin/ and chmod u+x it
4d96e5
4d96e5
#####################################################################
4d96e5
usage() {
4d96e5
    echo ''                                               >&2
4d96e5
    echo "$0 [-hr]"                                       >&2
4d96e5
    echo ''                                               >&2
4d96e5
    echo ' -h: This help message'                         >&2
4d96e5
    echo ' -r: Use the Redhat tag rather than centos tag' >&2
e5597e
    echo ' -q: Suppress warnings'                         >&2
4d96e5
    echo ''                                               >&2
4d96e5
    echo '  Attempt to extract what appears to be the value of %{dist}' >&2
4d96e5
    echo '  from the git.centos.org commit message'       >&2
4d96e5
    exit 1
4d96e5
}
4d96e5
4d96e5
4d96e5
#####################################################################
4d96e5
# setup args in the right order for making getopt evaluation
4d96e5
# nice and easy.  You'll need to read the manpages for more info
e5597e
args=$(getopt -o hrq -- "$@")
4d96e5
if [[ $? -ne 0 ]]; then
4d96e5
    usage
4d96e5
fi
4d96e5
eval set -- "$args"
4d96e5
4d96e5
RHELTAG=0
e5597e
QUIET=0
e5597e
for arg in "$@"; do
4d96e5
    case $1 in
4d96e5
        -- )
4d96e5
            # end of getopt args, shift off the -- and get out of the loop
4d96e5
            shift
4d96e5
            break 2
4d96e5
           ;;
4d96e5
         -r )
4d96e5
            # skip any package with 'centos' in the dist area
4d96e5
            RHELTAG=1
4d96e5
           ;;
e5597e
         -q )
e5597e
            # suppress warnings
e5597e
            QUIET=1
e5597e
           ;;
4d96e5
         -h )
4d96e5
            # get help
4d96e5
            usage
4d96e5
           ;;
4d96e5
    esac
4d96e5
done
4d96e5
e5597e
warn () {
e5597e
    [[ ${QUIET} -eq 1 ]] && return
e5597e
    echo 1>&2 "$@"
e5597e
}
4d96e5
e5597e
if [[ ! -d .git ]] || [[ ! -d SPECS ]]; then
4d96e5
    echo 'You need to run this from inside a sources git repo'
4d96e5
    exit 1
4d96e5
fi
4d96e5
e5597e
# check metadata file and extract package name
e5597e
packagename=""
e5597e
shopt -s nullglob
e5597e
for fn in .*.metadata
e5597e
do
e5597e
    pn=${fn%.metadata}
e5597e
    pn=${pn#.}
e5597e
    if [ -e "SPECS/$pn.spec" ]
e5597e
    then
e5597e
        packagename="$pn"
e5597e
        break
e5597e
    fi
e5597e
done
e5597e
if [ -z "$packagename" ]
e5597e
then
e5597e
    echo 'Missing metadata or spec. Please run from inside a sources git repo'
4d96e5
    exit 1
4d96e5
fi
4d96e5
e5597e
filter () {
e5597e
    # filter used for log messages
e5597e
    if [[ ${RHELTAG} -eq 1 ]]
e5597e
    then
e5597e
        grep -v centos | grep import
e5597e
    else
e5597e
        grep import
e5597e
    fi
e5597e
}
e5597e
e5597e
# extract nvr from commit message of last import
e5597e
msg=$(git log --pretty=format:"%s" | filter | head -n 1)
e5597e
set -- $msg
e5597e
pkg="$2"
e5597e
a6a9e5
# strip .src.rpm if present
a6a9e5
nvr1="${pkg%.src.rpm}"
4d96e5
a6a9e5
#now get nvr from spec with placeholder dist
a6a9e5
mydist="XXXjsdf9ur7qlkasdh4gygXXX"
a6a9e5
nvr2=$(rpm --define "dist $mydist" -q --specfile "SPECS/$packagename.spec" --qf '%{n}-%{v}-%{r}\n' 2>/dev/null | head -n 1)
a6a9e5
a6a9e5
#use our placeholder dist to split the nvr
a6a9e5
head=${nvr2%$mydist*}
a6a9e5
a6a9e5
if [ ".$head" = ".$nvr2" ]
a6a9e5
then
a6a9e5
    #no dist tag
a6a9e5
    echo ""
a6a9e5
    exit
a6a9e5
fi
a6a9e5
a6a9e5
tail=${nvr2#*$mydist}
a6a9e5
a6a9e5
frag=${nvr1#$head}
a6a9e5
dist=${frag%$tail}
a6a9e5
e5597e
# sanity check
e5597e
nvr3=$(rpm --define "dist $dist" -q --specfile "SPECS/$packagename.spec" --qf '%{n}-%{v}-%{r}\n' 2>/dev/null | head -n 1)
e5597e
if [ ".$nvr3" != ".$nvr1" ]
e5597e
then
e5597e
    warn "Warning: $nvr3 != $nvr1"
e5597e
    warn "Warning: check failed. The %{dist} value may be incorrect"
e5597e
fi
e5597e
a6a9e5
echo "$dist"