xref: /netbsd-src/external/gpl3/gcc/dist/contrib/git-descr.sh (revision b1e838363e3c6fc78a55519254d99869742dd33c)
1#!/bin/sh
2
3# Script to describe a GCC revision based on git hash
4
5short=no
6long=no
7c=master
8
9for arg in "$@"
10do
11    case "$arg" in
12      --short) short=yes long=no
13	;;
14      --long|--full) long=yes short=no
15	;;
16      *) c=$arg
17    esac
18done
19
20if test x$short = xyes; then
21    r=$(git describe --all --match 'basepoints/gcc-[0-9]*' $c | sed -n 's,^tags/,,;s,^basepoints/gcc-\([0-9][0-9]*\)-\([0-9][0-9]*\)-g[0-9a-f]*$,r\1-\2,p;s,^basepoints/gcc-\([0-9][0-9]*\)$,r\1-0,p');
22elif test x$long = xyes; then
23    r=$(git describe --all --abbrev=40 --match 'basepoints/gcc-[0-9]*' $c | sed -n 's,^tags/,,;s,^basepoints/gcc-,r,p')
24else
25    r=$(git describe --all --abbrev=14 --match 'basepoints/gcc-[0-9]*' $c | sed -n 's,^tags/,,;s,^basepoints/gcc-,r,p')
26    expr ${r:-no} : 'r[0-9]\+$' >/dev/null && r=${r}-0-g$(git rev-parse $c);
27fi;
28if test -n $r; then
29    o=$(git config --get gcc-config.upstream);
30    rr=$(echo $r | sed -n 's,^r\([0-9]\+\)-[0-9]\+\(-g[0-9a-f]\+\)\?$,\1,p');
31    if git rev-parse --verify --quiet ${o:-origin}/releases/gcc-$rr >/dev/null; then
32	m=releases/gcc-$rr;
33    else
34	m=master;
35    fi;
36    git merge-base --is-ancestor $c ${o:-origin}/$m && echo ${r};
37fi;
38