Mercurial > hg
annotate contrib/buildrpm @ 9717:68a1b9d0663e
update: allow branch crossing without -c or -C, with no uncommitted changes
Update will now allow crossing branches within the same named branch,
when given a specific revision, if the working dir is clean, without
requiring the -c or -C option. Abort if no revision is given and
this would cross branches. Minor change to abort message if
uncommitted changes are found.
Modify test-update-branches and output to reflect the altered case. Modify
test-merge5.out to reflect the altered case. Modify
test-up-local-change.out with new message.
author | Stuart W Marks <smarks@smarks.org> |
---|---|
date | Thu, 05 Nov 2009 10:53:59 +0100 |
parents | bb255fe7c27e |
children | ce145bf2ca5e |
rev | line source |
---|---|
564 | 1 #!/bin/sh |
2 # | |
3 # Build a Mercurial RPM in place. | |
4 # | |
5 # Bryan O'Sullivan <bos@serpentine.com> | |
8867
ff817723280a
contrib/buildrpm: Support python 2.4 and 2.6
Mads Kiilerich <mads@kiilerich.com>
parents:
7431
diff
changeset
|
6 # |
ff817723280a
contrib/buildrpm: Support python 2.4 and 2.6
Mads Kiilerich <mads@kiilerich.com>
parents:
7431
diff
changeset
|
7 # Tested on |
ff817723280a
contrib/buildrpm: Support python 2.4 and 2.6
Mads Kiilerich <mads@kiilerich.com>
parents:
7431
diff
changeset
|
8 # - Fedora 10 |
ff817723280a
contrib/buildrpm: Support python 2.4 and 2.6
Mads Kiilerich <mads@kiilerich.com>
parents:
7431
diff
changeset
|
9 # - Fedora 11 |
ff817723280a
contrib/buildrpm: Support python 2.4 and 2.6
Mads Kiilerich <mads@kiilerich.com>
parents:
7431
diff
changeset
|
10 # - Centos 5.3 (with Fedora EPEL repo for asciidoc) |
564 | 11 |
8869
d244ee52ac30
contrib/buildrpm: Don't require installed hg, use local hg with pure extensions
Mads Kiilerich <mads@kiilerich.com>
parents:
8868
diff
changeset
|
12 HG="`dirname $0`/../hg" |
d244ee52ac30
contrib/buildrpm: Don't require installed hg, use local hg with pure extensions
Mads Kiilerich <mads@kiilerich.com>
parents:
8868
diff
changeset
|
13 PYTHONPATH="`dirname $0`/../mercurial/pure" |
d244ee52ac30
contrib/buildrpm: Don't require installed hg, use local hg with pure extensions
Mads Kiilerich <mads@kiilerich.com>
parents:
8868
diff
changeset
|
14 export PYTHONPATH |
7431
3d827cc616b6
buildrpm: complain when hg command isn't available
Mads Kiilerich <mads@kiilerich.com>
parents:
7277
diff
changeset
|
15 |
8869
d244ee52ac30
contrib/buildrpm: Don't require installed hg, use local hg with pure extensions
Mads Kiilerich <mads@kiilerich.com>
parents:
8868
diff
changeset
|
16 root="`$HG root 2>/dev/null`" |
564 | 17 specfile=contrib/mercurial.spec |
18 | |
19 if [ -z "$root" ]; then | |
20 echo 'You are not inside a Mercurial repository!' 1>&2 | |
21 exit 1 | |
22 fi | |
23 | |
7277
3e000e2bf5f6
Make contrib/buildrpm work on Fedora 9.
Mads Kiilerich <mads@kiilerich.com>
parents:
4755
diff
changeset
|
24 rpmdir=/tmp/"`basename $root | sed 's/ /_/'`"-rpm # FIXME: Insecure /tmp handling |
564 | 25 |
26 cd "$root" | |
27 rm -rf $rpmdir | |
28 mkdir -p $rpmdir/RPMS | |
8869
d244ee52ac30
contrib/buildrpm: Don't require installed hg, use local hg with pure extensions
Mads Kiilerich <mads@kiilerich.com>
parents:
8868
diff
changeset
|
29 $HG clone "$root" $rpmdir/BUILD |
564 | 30 |
31 if [ ! -f $specfile ]; then | |
32 echo "Cannot find $specfile!" 1>&2 | |
33 exit 1 | |
34 fi | |
35 | |
7277
3e000e2bf5f6
Make contrib/buildrpm work on Fedora 9.
Mads Kiilerich <mads@kiilerich.com>
parents:
4755
diff
changeset
|
36 tmpspec=/tmp/`basename "$specfile"`.$$ # FIXME: Insecure /tmp handling |
564 | 37 # Use the most recent tag as the version. |
8869
d244ee52ac30
contrib/buildrpm: Don't require installed hg, use local hg with pure extensions
Mads Kiilerich <mads@kiilerich.com>
parents:
8868
diff
changeset
|
38 version=`$HG tags | python -c 'import sys; print [l for l in sys.stdin.readlines() if l[0].isdigit()][0].split()[0]'` |
564 | 39 # Compute the release number as the difference in revision numbers |
40 # between the tip and the most recent tag. | |
8869
d244ee52ac30
contrib/buildrpm: Don't require installed hg, use local hg with pure extensions
Mads Kiilerich <mads@kiilerich.com>
parents:
8868
diff
changeset
|
41 release=`$HG tags | python -c 'import sys; l = sys.stdin.readlines(); print int(l[0].split()[1].split(":")[0]) - int([x for x in l if x[0].isdigit()][0].split()[1].split(":")[0])'` |
d244ee52ac30
contrib/buildrpm: Don't require installed hg, use local hg with pure extensions
Mads Kiilerich <mads@kiilerich.com>
parents:
8868
diff
changeset
|
42 tip=`$HG -q tip` |
564 | 43 |
44 # Beat up the spec file | |
45 sed -e 's,^Source:.*,Source: /dev/null,' \ | |
46 -e "s,^Version:.*,Version: $version," \ | |
47 -e "s,^Release:.*,Release: $release," \ | |
48 -e "s,^%prep.*,Changeset: $tip\n\0," \ | |
49 -e 's,^%setup.*,,' \ | |
50 $specfile > $tmpspec | |
51 | |
4754
e5e6dd8ba6bb
buildrpm: auto-generate %changelog in .spec file
Adam Spiers <hg@adamspiers.org>
parents:
564
diff
changeset
|
52 cat <<EOF >> $tmpspec |
e5e6dd8ba6bb
buildrpm: auto-generate %changelog in .spec file
Adam Spiers <hg@adamspiers.org>
parents:
564
diff
changeset
|
53 %changelog |
8906
bb255fe7c27e
contrib/buildrpm: force en_US locale during changelog's creation
Stefano Tortarolo <stefano.tortarolo@gmail.com>
parents:
8869
diff
changeset
|
54 * `LANG=en_US date +'%a %b %d %Y'` `$HG showconfig ui.username` $version-$release |
4754
e5e6dd8ba6bb
buildrpm: auto-generate %changelog in .spec file
Adam Spiers <hg@adamspiers.org>
parents:
564
diff
changeset
|
55 - Automatically built via $0 |
e5e6dd8ba6bb
buildrpm: auto-generate %changelog in .spec file
Adam Spiers <hg@adamspiers.org>
parents:
564
diff
changeset
|
56 |
e5e6dd8ba6bb
buildrpm: auto-generate %changelog in .spec file
Adam Spiers <hg@adamspiers.org>
parents:
564
diff
changeset
|
57 EOF |
8869
d244ee52ac30
contrib/buildrpm: Don't require installed hg, use local hg with pure extensions
Mads Kiilerich <mads@kiilerich.com>
parents:
8868
diff
changeset
|
58 $HG log \ |
4754
e5e6dd8ba6bb
buildrpm: auto-generate %changelog in .spec file
Adam Spiers <hg@adamspiers.org>
parents:
564
diff
changeset
|
59 --template '* {date|rfc822date} {author}\n- {desc|firstline}\n\n' \ |
e5e6dd8ba6bb
buildrpm: auto-generate %changelog in .spec file
Adam Spiers <hg@adamspiers.org>
parents:
564
diff
changeset
|
60 .hgtags \ |
e5e6dd8ba6bb
buildrpm: auto-generate %changelog in .spec file
Adam Spiers <hg@adamspiers.org>
parents:
564
diff
changeset
|
61 | sed -e 's/^\(\* [MTWFS][a-z][a-z]\), \([0-3][0-9]\) \([A-Z][a-z][a-z]\) /\1 \3 \2 /' \ |
e5e6dd8ba6bb
buildrpm: auto-generate %changelog in .spec file
Adam Spiers <hg@adamspiers.org>
parents:
564
diff
changeset
|
62 -e '/^\* [MTWFS][a-z][a-z] /{s/ [012][0-9]:[0-9][0-9]:[0-9][0-9] [+-][0-9]\{4\}//}' \ |
e5e6dd8ba6bb
buildrpm: auto-generate %changelog in .spec file
Adam Spiers <hg@adamspiers.org>
parents:
564
diff
changeset
|
63 >> $tmpspec |
e5e6dd8ba6bb
buildrpm: auto-generate %changelog in .spec file
Adam Spiers <hg@adamspiers.org>
parents:
564
diff
changeset
|
64 |
564 | 65 rpmbuild --define "_topdir $rpmdir" -bb $tmpspec |
66 if [ $? = 0 ]; then | |
67 rm -rf $tmpspec $rpmdir/BUILD | |
68 mv $rpmdir/RPMS/*/* $rpmdir && rm -r $rpmdir/RPMS | |
69 echo | |
7277
3e000e2bf5f6
Make contrib/buildrpm work on Fedora 9.
Mads Kiilerich <mads@kiilerich.com>
parents:
4755
diff
changeset
|
70 echo "Packages are in $rpmdir:" |
3e000e2bf5f6
Make contrib/buildrpm work on Fedora 9.
Mads Kiilerich <mads@kiilerich.com>
parents:
4755
diff
changeset
|
71 ls -l $rpmdir/*.rpm |
564 | 72 fi |