X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=version.sh;h=774e514c22fcba06e209e979e6ed2a2435d1aae8;hb=d96cd42969964f2b86949e89c0ba138465646bf3;hp=cfed406b26f2bb6296a93b6c81e6e9ea646a34b3;hpb=f1cc88a5d65edb26eb63a032f6835008927a02c0;p=ffmpeg diff --git a/version.sh b/version.sh index cfed406b26f..774e514c22f 100755 --- a/version.sh +++ b/version.sh @@ -1,10 +1,40 @@ #!/bin/sh -svn_revision=`svn info | grep Revision | cut -d' ' -f2 || echo UNKNOWN` -NEW_REVISION="#define FFMPEG_VERSION \"SVN-r$svn_revision\"" -OLD_REVISION=`cat version.h 2> /dev/null` +# check for SVN revision number +revision=$(cd "$1" && cat snapshot_version 2> /dev/null) +test $revision || revision=$(cd "$1" && LC_ALL=C svn info 2> /dev/null | grep "Last Changed Rev" | cut -d' ' -f4) +test $revision || revision=$(cd "$1" && grep committed-rev .svn/entries 2>/dev/null | head -n 1 | cut -d '"' -f2) +test $revision || revision=$(cd "$1" && sed -n -e '/^dir$/{n +p +q +}' .svn/entries 2>/dev/null) +test $revision && revision=SVN-r$revision + +# check for git svn revision number +if ! test $revision; then + revision=$(cd "$1" && git svn find-rev HEAD 2> /dev/null) + test $revision && revision=git-svn-r$revision +fi + +# check for git short hash +if ! test $revision; then + revision=$(cd "$1" && git log -1 --pretty=format:%h 2> /dev/null) + test $revision && revision=git-$revision +fi + +# no revision number found +test $revision || revision=UNKNOWN + +# releases extract the version number from the VERSION file +version=$(cd "$1" && cat VERSION 2> /dev/null) +test $version || version=$revision + +test -n "$3" && version=$version-$3 + +NEW_REVISION="#define FFMPEG_VERSION \"$version\"" +OLD_REVISION=$(cat version.h 2> /dev/null) # Update version.h only on revision changes to avoid spurious rebuilds if test "$NEW_REVISION" != "$OLD_REVISION"; then - echo "$NEW_REVISION" > version.h + echo "$NEW_REVISION" > "$2" fi