diff -r c92ac5a56f69 -r dd2c95fc4fe5 contrib/buildrpm --- a/contrib/buildrpm Fri Nov 06 09:35:38 2009 +0100 +++ b/contrib/buildrpm Fri Nov 06 09:53:23 2009 +0100 @@ -2,22 +2,23 @@ # # Build a Mercurial RPM in place. # -# Bryan O'Sullivan -# # Tested on -# - Fedora 10 +# - Fedora 8 (with docutils 0.5) # - Fedora 11 -# - Centos 5.3 (with Fedora EPEL repo for asciidoc) +# - OpenSuse 11.2 cd "`dirname $0`/.." HG="$PWD/hg" PYTHONPATH="$PWD/mercurial/pure" export PYTHONPATH -root="`$HG root 2>/dev/null`" specfile=contrib/mercurial.spec +if [ ! -f $specfile ]; then + echo "Cannot find $specfile!" 1>&2 + exit 1 +fi -if [ -z "$root" ]; then +if [ ! -d .hg ]; then echo 'You are not inside a Mercurial repository!' 1>&2 exit 1 fi @@ -30,17 +31,11 @@ fi fi -rpmdir=/tmp/"`basename $root | sed 's/ /_/'`"-rpm # FIXME: Insecure /tmp handling +rpmdir="$PWD/rpmbuild" -cd "$root" rm -rf $rpmdir mkdir -p $rpmdir/RPMS -$HG clone -u . "$root" $rpmdir/BUILD - -if [ ! -f $specfile ]; then - echo "Cannot find $specfile!" 1>&2 - exit 1 -fi +$HG clone -u . . $rpmdir/BUILD tmpspec=/tmp/`basename "$specfile"`.$$ # FIXME: Insecure /tmp handling # make setup.py build the version string @@ -56,13 +51,10 @@ version=`echo $hgversion | sed -e 's/+.*//'` release='0' fi -tip=`$HG -q tip` -# Beat up the spec file -sed -e 's,^Source:.*,Source: /dev/null,' \ - -e "s,^Version:.*,Version: $version," \ +sed -e "s,^Version:.*,Version: $version," \ -e "s,^Release:.*,Release: $release," \ - -e "s,^%prep.*,Changeset: $tip\n\0," \ + -e "s,^%prep.*,\n\0," \ -e 's,^%setup.*,,' \ $specfile > $tmpspec @@ -79,9 +71,8 @@ -e '/^\* [MTWFS][a-z][a-z] /{s/ [012][0-9]:[0-9][0-9]:[0-9][0-9] [+-][0-9]\{4\}//}' \ >> $tmpspec -rpmbuild --define "_topdir $rpmdir" -bb $tmpspec +rpmbuild --define "_topdir $rpmdir" -bb $tmpspec --clean if [ $? = 0 ]; then - rm -rf $tmpspec $rpmdir/BUILD mv $rpmdir/RPMS/*/* $rpmdir && rm -r $rpmdir/RPMS echo echo "Packages are in $rpmdir:"