changing things around so we auto-create configure when packaging a new release

This commit is contained in:
Bryan Stansell 2019-03-17 21:01:29 -07:00
parent 6cee71850e
commit 51cfe7eb30
4 changed files with 78 additions and 7189 deletions

7189
configure vendored

File diff suppressed because it is too large Load Diff

20
package/README.md Normal file
View File

@ -0,0 +1,20 @@
Creating a new release
----------------------
- Create a new release branch `git checkout -b release-v...`
- Edit `conserver/version.h`
- Run `./package/replicate-version-number`
- Double-check and merge release branch
- Run `./package/make-and-stage-release` to create distribution, pgp sign, tag release, and push to github
Requirements:
- autoconf
- githubrelease (pypi)
- gpg
Publishing a release
--------------------
- Use github to promote from draft or use the command output from `make-and-stage-release`
- Send announcement on mailing lists

43
package/make-and-stage-release Executable file
View File

@ -0,0 +1,43 @@
#!/bin/bash
set -e
[ -f conserver/version.h ] || { echo "you are in the wrong place" ; exit 1; }
maj=`grep MAJOR conserver/version.h | awk '{print $NF; exit}'`
min=`grep MINOR conserver/version.h | awk '{print $NF; exit}'`
rev=`grep REV conserver/version.h | awk '{print $NF; exit}'`
ver="$maj.$min.$rev"
if [ ! -f ../conserver-$ver.tar.gz ]; then
echo "Creating ../conserver-$ver.tar.gz"
(
[ -d build ] && rm -rf build
mkdir build
git archive --format=tar.gz --prefix=conserver-$ver/ v$ver | (cd build; tar zxf -)
cd build/conserver-$ver && autoconf && rm -rf autom4te.cache
)
tar zcf ../conserver-$ver.tar.gz -C build conserver-$ver
rm -rf build
[ -f ../conserver-$ver.tar.gz.asc ] && rm ../conserver-$ver.tar.gz.asc
fi
if [ ! -f ../conserver-$ver.tar.gz.asc ]; then
echo "Signing ../conserver-$ver.tar.gz"
gpg -ab --local-user bryan@conserver.com ../conserver-$ver.tar.gz
fi
body="\`\`\`
`sed -ne '/^ver/,/^$/p' CHANGES | sed -e '/^$/,$d'`
\`\`\`"
ls -l ../conserver-$ver.tar.gz*
echo "Ready to push (y/N)?"
read i
if [ "$i" = "y" ]; then
git tag -a -m "Release $ver" v$ver && git push
githubrelease release conserver/conserver create --name conserver-$ver --body "$body" v$ver ../conserver-$ver.tar.gz*
echo You can publish this release on the website or with:
echo " "githubrelease release conserver/conserver publish v$ver
else
echo Ok, here is the command I would have used:
echo " "git tag -a -m \""Release $ver"\" v$ver \&\& git push
echo " "githubrelease release conserver/conserver create --name conserver-$ver --body \""$body"\" v$ver ../conserver-$ver.tar.gz*
fi

View File

@ -0,0 +1,15 @@
#!/bin/sh
maj=`grep MAJOR conserver/version.h | awk '{print $NF; exit}'`
min=`grep MINOR conserver/version.h | awk '{print $NF; exit}'`
rev=`grep REV conserver/version.h | awk '{print $NF; exit}'`
ver="$maj.$min.$rev"
date=`grep '^version' CHANGES | head -1 | sed -e 's/.*(\(.*\)).*/\1/'`
mandate=`date -j -f '%b %d, %Y' "$date" "+%Y/%m/%d"`
for i in c*/*.man; do
sed -i "" -e "/^\.TH /s|\".*|\"$mandate\" \"conserver-$ver\" \"conserver\"|" "$i"
done
sed -i "" -e "/^%define ver/s| ver .*| ver $ver|" contrib/redhat-rpm/conserver.spec
sed -i "" -e "/^VERSION=/s|.*|VERSION=\"$ver\"|" contrib/solaris-package/pkginfo