Imported hgeditor (from hg repo); .hgrc: use hgeditor
authorTomas Zeman <tzeman@volny.cz>
Mon, 24 Oct 2011 09:35:50 +0200
changeset 19 5b37cf0009bd
parent 18 e4dd40cccc2a
child 20 c61439c91a8a
Imported hgeditor (from hg repo); .hgrc: use hgeditor
config/.hgrc
scripts/hgeditor
--- a/config/.hgrc	Thu May 05 17:30:43 2011 +0200
+++ b/config/.hgrc	Mon Oct 24 09:35:50 2011 +0200
@@ -6,6 +6,7 @@
 
 [ui]
 username = Tomas Zeman <tzeman@volny.cz>
+editor = hgeditor
 
 [diff]
 git = 1
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/scripts/hgeditor	Mon Oct 24 09:35:50 2011 +0200
@@ -0,0 +1,56 @@
+#!/bin/sh
+#
+# This is an example of using HGEDITOR to create of diff to review the
+# changes while commiting.
+
+# If you want to pass your favourite editor some other parameters
+# only for Mercurial, modify this:
+case "${EDITOR}" in
+    "")
+        EDITOR="vi"
+        ;;
+    emacs)
+        EDITOR="$EDITOR -nw"
+        ;;
+    gvim|vim)
+        EDITOR="$EDITOR -f -o"
+        ;;
+esac
+
+
+HGTMP=""
+cleanup_exit() {
+    rm -rf "$HGTMP"
+}
+
+# Remove temporary files even if we get interrupted
+trap "cleanup_exit" 0 # normal exit
+trap "exit 255" HUP INT QUIT ABRT TERM
+
+HGTMP=$(mktemp -d ${TMPDIR-/tmp}/hgeditor.XXXXXX)
+[ x$HGTMP != x -a -d $HGTMP ] || {
+  echo "Could not create temporary directory! Exiting." 1>&2
+  exit 1
+}
+
+(
+    grep '^HG: changed' "$1" | cut -b 13- | while read changed; do
+        "$HG" diff "$changed" >> "$HGTMP/diff"
+    done
+)
+
+cat "$1" > "$HGTMP/msg"
+
+MD5=$(which md5sum 2>/dev/null) || \
+    MD5=$(which md5 2>/dev/null)
+[ -x "${MD5}" ] && CHECKSUM=`${MD5} "$HGTMP/msg"`
+if [ -s "$HGTMP/diff" ]; then
+    $EDITOR "$HGTMP/msg" "$HGTMP/diff" || exit $?
+else
+    $EDITOR "$HGTMP/msg" || exit $?
+fi
+[ -x "${MD5}" ] && (echo "$CHECKSUM" | ${MD5} -c >/dev/null 2>&1 && exit 13)
+
+mv "$HGTMP/msg" "$1"
+
+exit $?