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):