# HG changeset patch # User mpm@selenic.com # Date 2005-05-28 21:31:49 # Node ID 9a2075c0b9b8b50784f9313027654fdfe0c2b442 # Parent db3aa85b937971a17f2479c28e54b7da7d2cd72a Add $HGEDITOR hook and example script -----BEGIN PGP SIGNED MESSAGE----- Hash: SHA1 Add $HGEDITOR hook and example script This hook makes signing commits easier. manifest hash: ba8723e4b52323528dfa681a58658a5b4b2c02e4 -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.0 (GNU/Linux) iD8DBQFCmONFywK+sNU5EO8RAj87AKCEa5r9EepdYPiYRGo/jAjjwCIcVACfeBPe QDInXr7karo6/P8d2bM/tVU= =rxIQ -----END PGP SIGNATURE----- diff --git a/hgeditor b/hgeditor new file mode 100644 --- /dev/null +++ b/hgeditor @@ -0,0 +1,21 @@ +#!/bin/bash +# +# This is an example of using HGEDITOR to automate the signing of +# commits and so on. + +MANIFEST=`grep '^HG: manifest hash' $1 | cut -b 19-` +if grep -q "^HG: merge resolve" $1 ; then + # we don't sign merges + $EDITOR $1 +else + T=`mktemp` + CHANGED=`grep '^HG: changed' $1 | cut -b 13-` + # show a diff so writing commit comments is easier + hg diff $CHANGED >> $T + echo -e "\n\nmanifest hash: $MANIFEST" > $1 + emacs -nw $T $1 + head -1 $1 > $T + echo >> $T + gpg -a -u $HGUSER -o - --clearsign $1 >> $T + mv $T $1 +fi diff --git a/mercurial/hg.py b/mercurial/hg.py --- a/mercurial/hg.py +++ b/mercurial/hg.py @@ -893,8 +893,9 @@ class ui: f.write(text) f.close() - editor = os.environ.get("EDITOR", "vi") + editor = os.environ.get("HGEDITOR") or os.environ.get("EDITOR", "vi") r = os.system("%s %s" % (editor, name)) + if r: raise "Edit failed!" @@ -902,7 +903,6 @@ class ui: t = re.sub("(?m)^HG:.*\n", "", t) return t - class httprangereader: def __init__(self, url):