mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2025-01-22 18:35:09 +00:00
* lisp/nxml/nxml-mode.el (nxml-parent-document): Add a variable.
(nxml-parent-document-set): A function to set `nxml-parent-document'. (nxml-mode): Define using `define-derived-mode' instead of `defun'. (nxml-mode-hook): Remove `defcustom' (auto-defined by define-derived-mode'). * lisp/nxml/rng-valid.el (rng-dtd-trivial-p): Add a helper function for users who want to call `nxml-parent-document-set'.
This commit is contained in:
parent
088c8c092b
commit
f7ca27a1ef
@ -1,3 +1,13 @@
|
|||||||
|
2010-11-30 Sam Steingold <sds@gnu.org>
|
||||||
|
|
||||||
|
* nxml/nxml-mode.el (nxml-parent-document): Add a variable.
|
||||||
|
(nxml-parent-document-set): A function to set `nxml-parent-document'.
|
||||||
|
(nxml-mode): Define using `define-derived-mode' instead of `defun'.
|
||||||
|
(nxml-mode-hook): Remove `defcustom' (auto-defined by
|
||||||
|
define-derived-mode').
|
||||||
|
* nxml/rng-valid.el (rng-dtd-trivial-p): Add a helper function for
|
||||||
|
users who want to call `nxml-parent-document-set'.
|
||||||
|
|
||||||
2010-11-27 Chong Yidong <cyd@stupidchicken.com>
|
2010-11-27 Chong Yidong <cyd@stupidchicken.com>
|
||||||
|
|
||||||
* log-edit.el (log-edit-font-lock-keywords): Don't try matching
|
* log-edit.el (log-edit-font-lock-keywords): Don't try matching
|
||||||
|
@ -59,11 +59,6 @@ glyphs are displayed."
|
|||||||
:group 'nxml
|
:group 'nxml
|
||||||
:type 'boolean)
|
:type 'boolean)
|
||||||
|
|
||||||
(defcustom nxml-mode-hook nil
|
|
||||||
"Hook run by command `nxml-mode'."
|
|
||||||
:group 'nxml
|
|
||||||
:type 'hook)
|
|
||||||
|
|
||||||
(defcustom nxml-sexp-element-flag nil
|
(defcustom nxml-sexp-element-flag nil
|
||||||
"*Non-nil means sexp commands treat an element as a single expression."
|
"*Non-nil means sexp commands treat an element as a single expression."
|
||||||
:group 'nxml
|
:group 'nxml
|
||||||
@ -354,6 +349,12 @@ The delimiters are <! and >."
|
|||||||
|
|
||||||
;;; Global variables
|
;;; Global variables
|
||||||
|
|
||||||
|
(defvar nxml-parent-document nil
|
||||||
|
"The parent document for a part of a modular document.
|
||||||
|
Use `nxml-parent-document-set' to set it.")
|
||||||
|
(make-variable-buffer-local 'nxml-parent-document)
|
||||||
|
(put 'nxml-parent-document 'safe-local-variable 'stringp)
|
||||||
|
|
||||||
(defvar nxml-prolog-regions nil
|
(defvar nxml-prolog-regions nil
|
||||||
"List of regions in the prolog to be fontified.
|
"List of regions in the prolog to be fontified.
|
||||||
See the function `xmltok-forward-prolog' for more information.")
|
See the function `xmltok-forward-prolog' for more information.")
|
||||||
@ -430,8 +431,40 @@ reference.")
|
|||||||
(when (and face (< start end))
|
(when (and face (< start end))
|
||||||
(font-lock-append-text-property start end 'face face)))
|
(font-lock-append-text-property start end 'face face)))
|
||||||
|
|
||||||
|
(defun nxml-parent-document-set (parent-document)
|
||||||
|
"Set `nxml-parent-document' and inherit the DTD &c."
|
||||||
|
;; FIXME: this does not work.
|
||||||
|
;; the idea is that by inheriting some variables from the parent,
|
||||||
|
;; `rng-validate-mode' will validate entities declared in the parent.
|
||||||
|
;; alas, the most interesting variables (`rng-compile-table' et al)
|
||||||
|
;; are circular and cannot be printed even with `print-circle'.
|
||||||
|
(interactive "fParent document")
|
||||||
|
(let (dtd current-schema current-schema-file-name compile-table
|
||||||
|
ipattern-table last-ipattern-index)
|
||||||
|
(when (string= (file-truename parent-document)
|
||||||
|
(file-truename buffer-file-name))
|
||||||
|
(error "Parent document cannot be the same as the document"))
|
||||||
|
(with-current-buffer (find-file-noselect parent-document)
|
||||||
|
(setq dtd rng-dtd
|
||||||
|
current-schema rng-current-schema
|
||||||
|
current-schema-file-name rng-current-schema-file-name
|
||||||
|
compile-table rng-compile-table
|
||||||
|
ipattern-table rng-ipattern-table
|
||||||
|
last-ipattern-index rng-last-ipattern-index
|
||||||
|
parent-document buffer-file-name))
|
||||||
|
(setq rng-dtd dtd
|
||||||
|
rng-current-schema current-schema
|
||||||
|
rng-current-schema-file-name current-schema-file-name
|
||||||
|
rng-compile-table compile-table
|
||||||
|
rng-ipattern-table ipattern-table
|
||||||
|
rng-last-ipattern-index last-ipattern-index
|
||||||
|
nxml-parent-document parent-document)
|
||||||
|
(message "Set parent document to %s" parent-document)
|
||||||
|
(when rng-validate-mode
|
||||||
|
(rng-validate-while-idle (current-buffer)))))
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
(defun nxml-mode ()
|
(define-derived-mode nxml-mode text-mode "nXML"
|
||||||
;; We use C-c C-i instead of \\[nxml-balanced-close-start-tag-inline]
|
;; We use C-c C-i instead of \\[nxml-balanced-close-start-tag-inline]
|
||||||
;; because Emacs turns C-c C-i into C-c TAB which is hard to type and
|
;; because Emacs turns C-c C-i into C-c TAB which is hard to type and
|
||||||
;; not mnemonic.
|
;; not mnemonic.
|
||||||
@ -485,10 +518,7 @@ be treated as a single markup item, set the variable
|
|||||||
|
|
||||||
Many aspects this mode can be customized using
|
Many aspects this mode can be customized using
|
||||||
\\[customize-group] nxml RET."
|
\\[customize-group] nxml RET."
|
||||||
(interactive)
|
;; (kill-all-local-variables)
|
||||||
(kill-all-local-variables)
|
|
||||||
(setq major-mode 'nxml-mode)
|
|
||||||
(setq mode-name "nXML")
|
|
||||||
(set (make-local-variable 'mode-line-process) '((nxml-degraded "/degraded")))
|
(set (make-local-variable 'mode-line-process) '((nxml-degraded "/degraded")))
|
||||||
;; We'll determine the fill prefix ourselves
|
;; We'll determine the fill prefix ourselves
|
||||||
(make-local-variable 'adaptive-fill-mode)
|
(make-local-variable 'adaptive-fill-mode)
|
||||||
@ -552,8 +582,7 @@ Many aspects this mode can be customized using
|
|||||||
(font-lock-unfontify-region-function . nxml-unfontify-region)))
|
(font-lock-unfontify-region-function . nxml-unfontify-region)))
|
||||||
|
|
||||||
(rng-nxml-mode-init)
|
(rng-nxml-mode-init)
|
||||||
(nxml-enable-unicode-char-name-sets)
|
(nxml-enable-unicode-char-name-sets))
|
||||||
(run-mode-hooks 'nxml-mode-hook))
|
|
||||||
|
|
||||||
(defun nxml-cleanup ()
|
(defun nxml-cleanup ()
|
||||||
"Clean up after nxml-mode."
|
"Clean up after nxml-mode."
|
||||||
|
@ -518,6 +518,9 @@ Return t if there is work to do, nil otherwise."
|
|||||||
(goto-char pos))
|
(goto-char pos))
|
||||||
(t (rng-set-initial-state))))))))))
|
(t (rng-set-initial-state))))))))))
|
||||||
|
|
||||||
|
(defun rng-dtd-trivial-p (dtd)
|
||||||
|
"Check whether the current dtd is different from the trivial default."
|
||||||
|
(or (null dtd) (eq dtd xmltok-predefined-entity-alist)))
|
||||||
|
|
||||||
(defun rng-do-some-validation-1 (&optional continue-p-function)
|
(defun rng-do-some-validation-1 (&optional continue-p-function)
|
||||||
(let ((limit (+ rng-validate-up-to-date-end
|
(let ((limit (+ rng-validate-up-to-date-end
|
||||||
|
Loading…
Reference in New Issue
Block a user