20
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
#!/bin/sh
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
#
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
# This is an example of using HGEDITOR to create of diff to review the
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
# changes while commiting.
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
# If you want to pass your favourite editor some other parameters
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
# only for Mercurial, modify this:
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
case "${EDITOR}" in
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
"")
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
EDITOR="sensible-editor"
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
;;
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
emacs)
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
EDITOR="$EDITOR -nw"
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
;;
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
gvim|vim)
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
EDITOR="$EDITOR -f -o"
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
;;
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
esac
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
HGTMP=""
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
cleanup_exit() {
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
rm -rf "$HGTMP"
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
}
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
# Remove temporary files even if we get interrupted
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
trap "cleanup_exit" 0 # normal exit
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
trap "exit 255" HUP INT QUIT ABRT TERM
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
HGTMP=$(mktemp -d ${TMPDIR-/tmp}/hgeditor.XXXXXX)
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
[ x$HGTMP != x -a -d $HGTMP ] || {
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
echo "Could not create temporary directory! Exiting." 1>&2
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
exit 1
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
}
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
(
|
21
Anton Shestakov <engored@ya.ru>
line |
diff
|
grep '^HG: \(changed\|added\)' "$1" | cut -d ' ' -f 3- | while read changed; do
|
20
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
"$HG" diff "$changed" >> "$HGTMP/diff"
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
done
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
)
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
cat "$1" > "$HGTMP/msg"
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
MD5=$(which md5sum 2>/dev/null) || \
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
MD5=$(which md5 2>/dev/null)
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
[ -x "${MD5}" ] && CHECKSUM=`${MD5} "$HGTMP/msg"`
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
if [ -s "$HGTMP/diff" ]; then
|
22
22:e54f8d1eabf4
Use vim as an editor (the hack), but open diff on a side of commit message (the goodie).
Anton Shestakov <engored@ya.ru>
line |
diff
|
vim "+e $HGTMP/diff" '+set buftype=help filetype=diff' "+vsplit $HGTMP/msg" || exit $?
|
20
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
else
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
$EDITOR "$HGTMP/msg" || exit $?
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
fi
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
[ -x "${MD5}" ] && (echo "$CHECKSUM" | ${MD5} -c >/dev/null 2>&1 && exit 13)
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
mv "$HGTMP/msg" "$1"
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
|
Anton Shestakov <engored@ya.ru>
previous changes:
line |
diff
|
exit $?
|