diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 96db1cd6075..05fc82ece96 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,5 +1,8 @@ 2009-10-24 Chong Yidong + * nxml/nxml-mode.el (nxml-balanced-close-start-tag): Use the value + of xmltok-start before the end tag was inserted (Bug#2840). + * progmodes/sh-script.el (sh-font-lock-paren): Handle case patterns that are preceded by an open-paren (Bug#1320). diff --git a/lisp/nxml/nxml-mode.el b/lisp/nxml/nxml-mode.el index 054ec3c9c2c..b0168069ec9 100644 --- a/lisp/nxml/nxml-mode.el +++ b/lisp/nxml/nxml-mode.el @@ -1254,29 +1254,31 @@ No extra whitespace is inserted." (defun nxml-balanced-close-start-tag (block-or-inline) (let ((token-end (nxml-token-before)) - (pos (1+ (point)))) + (pos (1+ (point))) + (token-start xmltok-start)) (unless (or (eq xmltok-type 'partial-start-tag) (and (memq xmltok-type '(start-tag empty-element partial-empty-element)) (>= token-end pos))) (error "Not in a start-tag")) + ;; Note that this insertion changes xmltok-start. (insert ">") (if (eq block-or-inline 'inline) (goto-char pos) - (goto-char xmltok-start) + (goto-char token-start) (back-to-indentation) - (if (= (point) xmltok-start) + (if (= (point) token-start) (let ((indent (current-column))) - (goto-char pos) - (insert "\n") - (indent-line-to indent) - (goto-char pos) - (insert "\n") - (indent-line-to (+ nxml-child-indent indent))) + (goto-char pos) + (insert "\n") + (indent-line-to indent) + (goto-char pos) + (insert "\n") + (indent-line-to (+ nxml-child-indent indent))) (goto-char pos))))) (defun nxml-finish-element ()