]> git.eshelyaron.com Git - emacs.git/commitdiff
* lisp/nxml/nxml-mode.el: Use lexical-binding and syntax-propertize.
authorStefan Monnier <monnier@iro.umontreal.ca>
Mon, 7 Oct 2013 13:54:48 +0000 (09:54 -0400)
committerStefan Monnier <monnier@iro.umontreal.ca>
Mon, 7 Oct 2013 13:54:48 +0000 (09:54 -0400)
(font-lock-beg, font-lock-end): Move before first use.
(nxml-mode): Use syntax-propertize-function.
(nxml-after-change, nxml-after-change1): Adjust accordingly.
(nxml-extend-after-change-region): Remove.
* lisp/nxml/nxml-ns.el: Use lexical-binding.
(nxml-ns-save): Use `declare'.
(nxml-ns-prefixes-for): Avoid add-to-list.
* lisp/nxml/nxml-util.el: Use lexical-binding.
(nxml-with-degradation-on-error, nxml-with-invisible-motion):
Use `declare'.
* lisp/nxml/rng-match.el: Use lexical-binding.
(rng--ipattern): Use cl-defstruct.
(rng-compute-start-tag-open-deriv, rng-compute-start-attribute-deriv)
(rng-cons-group-after, rng-subst-group-after)
(rng-subst-interleave-after, rng-apply-after, rng-compute-data-deriv):
Use closures instead of `(lambda...).
* lisp/nxml/xmltok.el: Use lexical-binding.
(xmltok-save): Use `declare'.
(xmltok-unclosed-reparse-p, xmltok-semi-closed-reparse-p): Remove.

lisp/ChangeLog
lisp/nxml/nxml-mode.el
lisp/nxml/nxml-ns.el
lisp/nxml/nxml-util.el
lisp/nxml/rng-match.el
lisp/nxml/xmltok.el

index 1cad30c0214aaa912a59982d0457c88fb0ce20d1..17ba29fd0aee33c9a6749bed906c0aab99648404 100644 (file)
@@ -1,14 +1,37 @@
+2013-10-07  Stefan Monnier  <monnier@iro.umontreal.ca>
+
+       * nxml/nxml-mode.el: Use lexical-binding and syntax-propertize.
+       (font-lock-beg, font-lock-end): Move before first use.
+       (nxml-mode): Use syntax-propertize-function.
+       (nxml-after-change, nxml-after-change1): Adjust accordingly.
+       (nxml-extend-after-change-region): Remove.
+       * nxml/xmltok.el: Use lexical-binding.
+       (xmltok-save): Use `declare'.
+       (xmltok-unclosed-reparse-p, xmltok-semi-closed-reparse-p): Remove.
+       * nxml/nxml-util.el: Use lexical-binding.
+       (nxml-with-degradation-on-error, nxml-with-invisible-motion):
+       Use `declare'.
+       * nxml/nxml-ns.el: Use lexical-binding.
+       (nxml-ns-save): Use `declare'.
+       (nxml-ns-prefixes-for): Avoid add-to-list.
+       * nxml/rng-match.el: Use lexical-binding.
+       (rng--ipattern): Use cl-defstruct.
+       (rng-compute-start-tag-open-deriv, rng-compute-start-attribute-deriv)
+       (rng-cons-group-after, rng-subst-group-after)
+       (rng-subst-interleave-after, rng-apply-after, rng-compute-data-deriv):
+       Use closures instead of `(lambda...).
+
 2013-10-07  Michael Albinus  <michael.albinus@gmx.de>
 
        * net/tramp.el (tramp-handle-insert-file-contents): Improve handling
        of BEG and END.
 
-       * net/tramp-gvfs.el (tramp-gvfs-file-name-handler-alist): Use
-       `tramp-handle-insert-file-contents'.
+       * net/tramp-gvfs.el (tramp-gvfs-file-name-handler-alist):
+       Use `tramp-handle-insert-file-contents'.
        (tramp-gvfs-handle-insert-file-contents): Remove function.
 
-       * net/tramp-sh.el (tramp-sh-handle-insert-directory): Use
-       `save-restriction' in order to keep markers.
+       * net/tramp-sh.el (tramp-sh-handle-insert-directory):
+       Use `save-restriction' in order to keep markers.
 
        * net/trampver.el: Update release number.
 
@@ -20,7 +43,8 @@
 
        * emacs-lisp/easymenu.el (easy-menu-create-menu): Use closures.
 
-       * emacs-lisp/lisp-mode.el (eval-defun-2): Simplify, using lexical-binding.
+       * emacs-lisp/lisp-mode.el (eval-defun-2): Simplify, using
+       lexical-binding.
 
        * emacs-lisp/tq.el (tq-create): Use a closure instead of `(lambda...).
 
index c45196f0316c4bd5334f8088dbb1cd89260c086e..da3c034b5ff6bf97fc85cc4ff9633cad4cdc91d4 100644 (file)
@@ -1,4 +1,4 @@
-;;; nxml-mode.el --- a new XML mode
+;;; nxml-mode.el --- a new XML mode  -*- lexical-binding:t -*-
 
 ;; Copyright (C) 2003-2004, 2007-2013 Free Software Foundation, Inc.
 
@@ -540,14 +540,14 @@ Many aspects this mode can be customized using
          (nxml-scan-prolog)))))
   (add-hook 'completion-at-point-functions
             #'nxml-completion-at-point-function nil t)
-  (add-hook 'after-change-functions 'nxml-after-change nil t)
+  (setq-local syntax-propertize-function #'nxml-after-change)
   (add-hook 'change-major-mode-hook 'nxml-cleanup nil t)
 
   ;; Emacs 23 handles the encoding attribute on the xml declaration
   ;; transparently to nxml-mode, so there is no longer a need for the below
   ;; hook. The hook also had the drawback of overriding explicit user
   ;; instruction to save as some encoding other than utf-8.
-;;;   (add-hook 'write-contents-hooks 'nxml-prepare-to-save)
+  ;;(add-hook 'write-contents-hooks 'nxml-prepare-to-save)
   (when (not (and (buffer-file-name) (file-exists-p (buffer-file-name))))
     (when (and nxml-default-buffer-file-coding-system
               (not (local-variable-p 'buffer-file-coding-system)))
@@ -561,8 +561,6 @@ Many aspects this mode can be customized using
           nil  ; font-lock-keywords-case-fold-search. XML is case sensitive
           nil  ; no special syntax table
           nil  ; no automatic syntactic fontification
-          (font-lock-extend-after-change-region-function
-           . nxml-extend-after-change-region)
           (font-lock-extend-region-functions . (nxml-extend-region))
           (jit-lock-contextually . t)
           (font-lock-unfontify-region-function . nxml-unfontify-region)))
@@ -597,6 +595,7 @@ Many aspects this mode can be customized using
 
 ;;; Change management
 
+(defvar font-lock-beg) (defvar font-lock-end)
 (defun nxml-debug-region (start end)
   (interactive "r")
   (let ((font-lock-beg start)
@@ -605,22 +604,16 @@ Many aspects this mode can be customized using
     (goto-char font-lock-beg)
     (set-mark font-lock-end)))
 
-(defun nxml-after-change (start end pre-change-length)
-  ; In font-lock mode, nxml-after-change1 is called via
-  ; nxml-extend-after-change-region instead so that the updated
-  ; book-keeping information is available for fontification.
-  (unless (or font-lock-mode nxml-degraded)
+(defun nxml-after-change (start end)
+  ;; Called via syntax-propertize-function.
+  (unless nxml-degraded
     (nxml-with-degradation-on-error 'nxml-after-change
-        (save-excursion
-          (save-restriction
-            (widen)
-            (save-match-data
-              (nxml-with-invisible-motion
-                (with-silent-modifications
-                  (nxml-after-change1
-                   start end pre-change-length)))))))))
-
-(defun nxml-after-change1 (start end pre-change-length)
+      (save-restriction
+        (widen)
+        (nxml-with-invisible-motion
+         (nxml-after-change1 start end))))))
+
+(defun nxml-after-change1 (start end)
   "After-change bookkeeping.
 Returns a cons cell containing a possibly-enlarged change region.
 You must call `nxml-extend-region' on this expanded region to obtain
@@ -628,23 +621,14 @@ the full extent of the area needing refontification.
 
 For bookkeeping, call this function even when fontification is
 disabled."
-  (let ((pre-change-end (+ start pre-change-length)))
-    ;; If the prolog might have changed, rescan the prolog
-    (when (<= start
-             ;; Add 2 so as to include the < and following char that
-             ;; start the instance (document element), since changing
-             ;; these can change where the prolog ends.
-             (+ nxml-prolog-end 2))
-      ;; end must be extended to at least the end of the old prolog in
-      ;; case the new prolog is shorter
-      (when (< pre-change-end nxml-prolog-end)
-       (setq end
-             ;; don't let end get out of range even if pre-change-length
-             ;; is bogus
-             (min (point-max)
-                  (+ end (- nxml-prolog-end pre-change-end)))))
-      (nxml-scan-prolog)
-      (setq start (point-min))))
+  ;; If the prolog might have changed, rescan the prolog.
+  (when (<= start
+            ;; Add 2 so as to include the < and following char that
+            ;; start the instance (document element), since changing
+            ;; these can change where the prolog ends.
+            (+ nxml-prolog-end 2))
+    (nxml-scan-prolog)
+    (setq start (point-min)))
 
   (when (> end nxml-prolog-end)
     (goto-char start)
@@ -653,8 +637,7 @@ disabled."
     (setq end (max (nxml-scan-after-change start end)
                    end)))
 
-  (nxml-debug-change "nxml-after-change1" start end)
-  (cons start end))
+  (nxml-debug-change "nxml-after-change1" start end))
 
 ;;; Encodings
 
@@ -845,7 +828,6 @@ The XML declaration will declare an encoding depending on the buffer's
   (font-lock-default-unfontify-region start end)
   (nxml-clear-char-ref-extra-display start end))
 
-(defvar font-lock-beg) (defvar font-lock-end)
 (defun nxml-extend-region ()
   "Extend the region to hold the minimum area we can fontify with nXML.
 Called with `font-lock-beg' and `font-lock-end' dynamically bound."
@@ -887,19 +869,6 @@ Called with `font-lock-beg' and `font-lock-end' dynamically bound."
       (nxml-debug-change "nxml-extend-region" start end)
       t)))
 
-(defun nxml-extend-after-change-region (start end pre-change-length)
-  (unless nxml-degraded
-    (nxml-with-degradation-on-error
-     'nxml-extend-after-change-region
-     (save-excursion
-       (save-restriction
-         (widen)
-         (save-match-data
-           (nxml-with-invisible-motion
-             (with-silent-modifications
-               (nxml-after-change1
-                start end pre-change-length)))))))))
-
 (defun nxml-fontify-matcher (bound)
   "Called as font-lock keyword matcher."
 
index cadb5e6adab7e14df3dfa18f872e9072a807bafa..a3a05c262d8f72514b56ee49fe58ab8c9eb04e7f 100644 (file)
@@ -1,4 +1,4 @@
-;;; nxml-ns.el --- XML namespace processing
+;;; nxml-ns.el --- XML namespace processing  -*- lexical-binding:t -*-
 
 ;; Copyright (C) 2003, 2007-2013 Free Software Foundation, Inc.
 
@@ -56,12 +56,10 @@ namespace bindings (no default namespace and only the xml prefix bound).")
   (equal nxml-ns-state state))
 
 (defmacro nxml-ns-save (&rest body)
+  (declare (indent 0) (debug t))
   `(let ((nxml-ns-state nxml-ns-initial-state))
      ,@body))
 
-(put 'nxml-ns-save 'lisp-indent-function 0)
-(def-edebug-spec nxml-ns-save t)
-
 (defun nxml-ns-init ()
   (setq nxml-ns-state nxml-ns-initial-state))
 
@@ -117,11 +115,12 @@ NS is a symbol or nil."
     (setq current (cdr current))
     (while (let ((binding (rassq ns current)))
             (when binding
-              (when (eq (nxml-ns-get-prefix (car binding)) ns)
-                (add-to-list 'prefixes
-                             (car binding)))
-              (setq current
-                    (cdr (member binding current))))))
+               (let ((prefix (car binding)))
+                 (when (eq (nxml-ns-get-prefix prefix) ns)
+                   (unless (member prefix prefixes)
+                     (push prefix prefixes))))
+               (setq current
+                     (cdr (member binding current))))))
     prefixes))
 
 (defun nxml-ns-prefix-for (ns)
index c410aa12c8329f4f4b19ceace81c38f3b6b79381..6ab425a420e0d0da686464582f8d740917b5fad8 100644 (file)
@@ -1,4 +1,4 @@
-;;; nxml-util.el --- utility functions for nxml-*.el
+;;; nxml-util.el --- utility functions for nxml-*.el  -*- lexical-binding:t -*-
 
 ;; Copyright (C) 2003, 2007-2013 Free Software Foundation, Inc.
 
@@ -70,6 +70,7 @@ This is the inverse of `nxml-make-namespace'."
   (nxml-make-namespace "http://www.w3.org/2000/xmlns/"))
 
 (defmacro nxml-with-degradation-on-error (context &rest body)
+  (declare (indent 1) (debug t))
   (if (not nxml-debug)
       (let ((error-symbol (make-symbol "err")))
         `(condition-case ,error-symbol
@@ -80,12 +81,10 @@ This is the inverse of `nxml-make-namespace'."
 
 (defmacro nxml-with-invisible-motion (&rest body)
   "Evaluate body without calling any point motion hooks."
+  (declare (indent 0) (debug t))
   `(let ((inhibit-point-motion-hooks t))
      ,@body))
 
-(put 'nxml-with-invisible-motion 'lisp-indent-function 0)
-(def-edebug-spec nxml-with-invisible-motion t)
-
 (defun nxml-display-file-parse-error (err)
   (let* ((filename (nth 1 err))
         (buffer (find-file-noselect filename))
index 36bd23b3768204f15737ef2b55ffcb92cab1e40b..10b8f2b0b4c3b7508a14ca2129314d6abae2a83b 100644 (file)
@@ -1,4 +1,4 @@
-;;; rng-match.el --- matching of RELAX NG patterns against XML events
+;;; rng-match.el --- matching of RELAX NG patterns against XML events  -*- lexical-binding:t -*-
 
 ;; Copyright (C) 2003, 2007-2013 Free Software Foundation, Inc.
 
@@ -34,6 +34,7 @@
 (require 'rng-pttrn)
 (require 'rng-util)
 (require 'rng-dt)
+(eval-when-compile (require 'cl-lib))
 
 (defvar rng-not-allowed-ipattern nil)
 (defvar rng-empty-ipattern nil)
@@ -63,38 +64,31 @@ Used to detect invalid recursive references.")
 
 ;;; Interned patterns
 
-(eval-when-compile
-  (defun rng-ipattern-slot-accessor-name (slot-name)
-    (intern (concat "rng-ipattern-get-"
-                   (symbol-name slot-name))))
-
-  (defun rng-ipattern-slot-setter-name (slot-name)
-    (intern (concat "rng-ipattern-set-"
-                   (symbol-name slot-name)))))
-
-(defmacro rng-ipattern-defslot (slot-name index)
-  `(progn
-     (defsubst ,(rng-ipattern-slot-accessor-name slot-name) (ipattern)
-       (aref ipattern ,index))
-     (defsubst ,(rng-ipattern-slot-setter-name slot-name) (ipattern value)
-       (aset ipattern ,index value))))
-
-(rng-ipattern-defslot type 0)
-(rng-ipattern-defslot index 1)
-(rng-ipattern-defslot name-class 2)
-(rng-ipattern-defslot datatype 2)
-(rng-ipattern-defslot after 2)
-(rng-ipattern-defslot child 3)
-(rng-ipattern-defslot value-object 3)
-(rng-ipattern-defslot nullable 4)
-(rng-ipattern-defslot memo-text-typed 5)
-(rng-ipattern-defslot memo-map-start-tag-open-deriv 6)
-(rng-ipattern-defslot memo-map-start-attribute-deriv 7)
-(rng-ipattern-defslot memo-start-tag-close-deriv 8)
-(rng-ipattern-defslot memo-text-only-deriv 9)
-(rng-ipattern-defslot memo-mixed-text-deriv 10)
-(rng-ipattern-defslot memo-map-data-deriv 11)
-(rng-ipattern-defslot memo-end-tag-deriv 12)
+(cl-defstruct (rng--ipattern
+               (:constructor nil)
+               (:type vector)
+               (:copier nil)
+               (:constructor rng-make-ipattern
+                (type index name-class child nullable)))
+  type
+  index
+  name-class ;; Field also known as: `datatype' and `after'.
+  child      ;; Field also known as: `value-object'.
+  nullable
+  (memo-text-typed 'unknown)
+  memo-map-start-tag-open-deriv
+  memo-map-start-attribute-deriv
+  memo-start-tag-close-deriv
+  memo-text-only-deriv
+  memo-mixed-text-deriv
+  memo-map-data-deriv
+  memo-end-tag-deriv)
+
+;; I think depending on the value of `type' the two fields after `index'
+;; are used sometimes for different purposes, hence the aliases here:
+(defalias 'rng--ipattern-datatype 'rng--ipattern-name-class)
+(defalias 'rng--ipattern-after 'rng--ipattern-name-class)
+(defalias 'rng--ipattern-value-object 'rng--ipattern-child)
 
 (defconst rng-memo-map-alist-max 10)
 
@@ -142,25 +136,6 @@ therefore minimal overhead in successful lookups on small lists
                     (cons (cons key value)
                           (cdr mm))))))))
 
-(defsubst rng-make-ipattern (type index name-class child nullable)
-  (vector type index name-class child nullable
-         ;; 5 memo-text-typed
-         'unknown
-         ;; 6 memo-map-start-tag-open-deriv
-         nil
-         ;; 7 memo-map-start-attribute-deriv
-         nil
-         ;; 8 memo-start-tag-close-deriv
-         nil
-         ;; 9 memo-text-only-deriv
-         nil
-         ;; 10 memo-mixed-text-deriv
-         nil
-         ;; 11 memo-map-data-deriv
-         nil
-         ;; 12 memo-end-tag-deriv
-         nil))
-
 (defun rng-ipattern-maybe-init ()
   (unless rng-ipattern-table
     (setq rng-ipattern-table (make-hash-table :test 'equal))
@@ -208,8 +183,8 @@ therefore minimal overhead in successful lookups on small lists
   (if (eq child rng-not-allowed-ipattern)
       rng-not-allowed-ipattern
     (let ((key (list 'after
-                    (rng-ipattern-get-index child)
-                    (rng-ipattern-get-index after))))
+                    (rng--ipattern-index child)
+                    (rng--ipattern-index after))))
       (or (rng-get-ipattern key)
          (rng-put-ipattern key
                            'after
@@ -222,7 +197,7 @@ therefore minimal overhead in successful lookups on small lists
       rng-not-allowed-ipattern
     (let ((key (list 'attribute
                     name-class
-                    (rng-ipattern-get-index ipattern))))
+                    (rng--ipattern-index ipattern))))
       (or (rng-get-ipattern key)
          (rng-put-ipattern key
                            'attribute
@@ -238,8 +213,8 @@ therefore minimal overhead in successful lookups on small lists
                                          dt
                                          nil
                                          matches-anything)))
-         (rng-ipattern-set-memo-text-typed ipattern
-                                           (not matches-anything))
+         (setf (rng--ipattern-memo-text-typed ipattern)
+                (not matches-anything))
          ipattern))))
 
 (defun rng-intern-data-except (dt ipattern)
@@ -263,20 +238,20 @@ therefore minimal overhead in successful lookups on small lists
 (defun rng-intern-one-or-more (ipattern)
   (or (rng-intern-one-or-more-shortcut ipattern)
       (let ((key (cons 'one-or-more
-                      (list (rng-ipattern-get-index ipattern)))))
+                      (list (rng--ipattern-index ipattern)))))
        (or (rng-get-ipattern key)
            (rng-put-ipattern key
                              'one-or-more
                              nil
                              ipattern
-                             (rng-ipattern-get-nullable ipattern))))))
+                             (rng--ipattern-nullable ipattern))))))
 
 (defun rng-intern-one-or-more-shortcut (ipattern)
   (cond ((eq ipattern rng-not-allowed-ipattern)
         rng-not-allowed-ipattern)
        ((eq ipattern rng-empty-ipattern)
         rng-empty-ipattern)
-       ((eq (rng-ipattern-get-type ipattern) 'one-or-more)
+       ((eq (rng--ipattern-type ipattern) 'one-or-more)
         ipattern)
        (t nil)))
 
@@ -284,7 +259,7 @@ therefore minimal overhead in successful lookups on small lists
   (if (eq ipattern rng-not-allowed-ipattern)
       rng-not-allowed-ipattern
     (let ((key (cons 'list
-                    (list (rng-ipattern-get-index ipattern)))))
+                    (list (rng--ipattern-index ipattern)))))
       (or (rng-get-ipattern key)
          (rng-put-ipattern key
                            'list
@@ -299,7 +274,7 @@ therefore minimal overhead in successful lookups on small lists
             (normalized (cdr tem)))
        (or (rng-intern-group-shortcut normalized)
            (let ((key (cons 'group
-                            (mapcar 'rng-ipattern-get-index normalized))))
+                            (mapcar #'rng--ipattern-index normalized))))
              (or (rng-get-ipattern key)
                  (rng-put-ipattern key
                                    'group
@@ -345,10 +320,10 @@ cdr is the normalized list."
       (setq member (car ipatterns))
       (setq ipatterns (cdr ipatterns))
       (when nullable
-       (setq nullable (rng-ipattern-get-nullable member)))
-      (cond ((eq (rng-ipattern-get-type member) 'group)
+       (setq nullable (rng--ipattern-nullable member)))
+      (cond ((eq (rng--ipattern-type member) 'group)
             (setq result
-                  (nconc (reverse (rng-ipattern-get-child member))
+                  (nconc (reverse (rng--ipattern-child member))
                          result)))
            ((eq member rng-not-allowed-ipattern)
             (setq result (list rng-not-allowed-ipattern))
@@ -363,7 +338,7 @@ cdr is the normalized list."
             (normalized (cdr tem)))
        (or (rng-intern-group-shortcut normalized)
            (let ((key (cons 'interleave
-                            (mapcar 'rng-ipattern-get-index normalized))))
+                            (mapcar #'rng--ipattern-index normalized))))
              (or (rng-get-ipattern key)
                  (rng-put-ipattern key
                                    'interleave
@@ -383,10 +358,10 @@ cdr is the normalized list."
       (setq member (car ipatterns))
       (setq ipatterns (cdr ipatterns))
       (when nullable
-       (setq nullable (rng-ipattern-get-nullable member)))
-      (cond ((eq (rng-ipattern-get-type member) 'interleave)
+       (setq nullable (rng--ipattern-nullable member)))
+      (cond ((eq (rng--ipattern-type member) 'interleave)
             (setq result
-                  (append (rng-ipattern-get-child member)
+                  (append (rng--ipattern-child member)
                            result)))
            ((eq member rng-not-allowed-ipattern)
             (setq result (list rng-not-allowed-ipattern))
@@ -407,7 +382,7 @@ May alter IPATTERNS."
            (rng-intern-choice1 normalized (car tem))))))
 
 (defun rng-intern-optional (ipattern)
-  (cond ((rng-ipattern-get-nullable ipattern) ipattern)
+  (cond ((rng--ipattern-nullable ipattern) ipattern)
        ((eq ipattern rng-not-allowed-ipattern) rng-empty-ipattern)
        (t (rng-intern-choice1
            ;; This is sorted since the empty pattern
@@ -415,15 +390,15 @@ May alter IPATTERNS."
            ;; It cannot have a duplicate empty pattern,
            ;; since it is not nullable.
            (cons rng-empty-ipattern
-                 (if (eq (rng-ipattern-get-type ipattern) 'choice)
-                     (rng-ipattern-get-child ipattern)
+                 (if (eq (rng--ipattern-type ipattern) 'choice)
+                     (rng--ipattern-child ipattern)
                    (list ipattern)))
            t))))
 
 
 (defun rng-intern-choice1 (normalized nullable)
   (let ((key (cons 'choice
-                  (mapcar 'rng-ipattern-get-index normalized))))
+                  (mapcar #'rng--ipattern-index normalized))))
     (or (rng-get-ipattern key)
        (rng-put-ipattern key
                          'choice
@@ -466,10 +441,10 @@ list is nullable and whose cdr is the normalized list."
       (while cur
        (setq member (car cur))
        (or nullable
-           (setq nullable (rng-ipattern-get-nullable member)))
-       (cond ((eq (rng-ipattern-get-type member) 'choice)
+           (setq nullable (rng--ipattern-nullable member)))
+       (cond ((eq (rng--ipattern-type member) 'choice)
               (setq final-tail
-                    (append (rng-ipattern-get-child member)
+                    (append (rng--ipattern-child member)
                             final-tail))
               (setq cur (cdr cur))
               (setq sorted nil)
@@ -479,7 +454,7 @@ list is nullable and whose cdr is the normalized list."
               (setcdr tail cur))
              (t
               (if (and sorted
-                       (let ((cur-index (rng-ipattern-get-index member)))
+                       (let ((cur-index (rng--ipattern-index member)))
                          (if (>= prev-index cur-index)
                              (or (= prev-index cur-index) ; will remove it
                                  (setq sorted nil)) ; won't remove it
@@ -501,8 +476,8 @@ list is nullable and whose cdr is the normalized list."
            (rng-uniquify-eq (sort head 'rng-compare-ipattern))))))
 
 (defun rng-compare-ipattern (p1 p2)
-  (< (rng-ipattern-get-index p1)
-     (rng-ipattern-get-index p2)))
+  (< (rng--ipattern-index p1)
+     (rng--ipattern-index p2)))
 
 ;;; Name classes
 
@@ -557,50 +532,50 @@ list may contain duplicates."
 ;;; Debugging utilities
 
 (defun rng-ipattern-to-string (ipattern)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'after)
           (concat (rng-ipattern-to-string
-                   (rng-ipattern-get-child ipattern))
+                   (rng--ipattern-child ipattern))
                   " </> "
                   (rng-ipattern-to-string
-                   (rng-ipattern-get-after ipattern))))
+                   (rng--ipattern-after ipattern))))
          ((eq type 'element)
           (concat "element "
                   (rng-name-class-to-string
-                   (rng-ipattern-get-name-class ipattern))
+                   (rng--ipattern-name-class ipattern))
                   ;; we can get cycles with elements so don't print it out
                   " {...}"))
          ((eq type 'attribute)
           (concat "attribute "
                   (rng-name-class-to-string
-                   (rng-ipattern-get-name-class ipattern))
+                   (rng--ipattern-name-class ipattern))
                   " { "
                   (rng-ipattern-to-string
-                   (rng-ipattern-get-child ipattern))
+                   (rng--ipattern-child ipattern))
                   " } "))
          ((eq type 'empty) "empty")
          ((eq type 'text) "text")
          ((eq type 'not-allowed) "notAllowed")
          ((eq type 'one-or-more)
           (concat (rng-ipattern-to-string
-                   (rng-ipattern-get-child ipattern))
+                   (rng--ipattern-child ipattern))
                   "+"))
          ((eq type 'choice)
           (concat "("
                   (mapconcat 'rng-ipattern-to-string
-                             (rng-ipattern-get-child ipattern)
+                             (rng--ipattern-child ipattern)
                              " | ")
                   ")"))
          ((eq type 'group)
           (concat "("
                   (mapconcat 'rng-ipattern-to-string
-                             (rng-ipattern-get-child ipattern)
+                             (rng--ipattern-child ipattern)
                              ", ")
                   ")"))
          ((eq type 'interleave)
           (concat "("
                   (mapconcat 'rng-ipattern-to-string
-                             (rng-ipattern-get-child ipattern)
+                             (rng--ipattern-child ipattern)
                              " & ")
                   ")"))
          (t (symbol-name type)))))
@@ -664,10 +639,10 @@ list may contain duplicates."
                     nil))
 
 (defun rng-element-get-child (element)
-  (let ((tem (rng-ipattern-get-child element)))
+  (let ((tem (rng--ipattern-child element)))
     (if (vectorp tem)
        tem
-      (rng-ipattern-set-child element (rng-compile tem)))))
+      (setf (rng--ipattern-child element) (rng-compile tem)))))
 
 (defun rng-compile-attribute (name-class pattern)
   (rng-intern-attribute (rng-compile-name-class name-class)
@@ -839,17 +814,16 @@ list may contain duplicates."
 ;;; Derivatives
 
 (defun rng-ipattern-text-typed-p (ipattern)
-  (let ((memo (rng-ipattern-get-memo-text-typed ipattern)))
+  (let ((memo (rng--ipattern-memo-text-typed ipattern)))
     (if (eq memo 'unknown)
-       (rng-ipattern-set-memo-text-typed
-        ipattern
-        (rng-ipattern-compute-text-typed-p ipattern))
+       (setf (rng--ipattern-memo-text-typed ipattern)
+              (rng-ipattern-compute-text-typed-p ipattern))
       memo)))
 
 (defun rng-ipattern-compute-text-typed-p (ipattern)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'choice)
-          (let ((cur (rng-ipattern-get-child ipattern))
+          (let ((cur (rng--ipattern-child ipattern))
                 (ret nil))
             (while (and cur (not ret))
               (if (rng-ipattern-text-typed-p (car cur))
@@ -857,7 +831,7 @@ list may contain duplicates."
                 (setq cur (cdr cur))))
             ret))
          ((eq type 'group)
-          (let ((cur (rng-ipattern-get-child ipattern))
+          (let ((cur (rng--ipattern-child ipattern))
                 (ret nil)
                 member)
             (while (and cur (not ret))
@@ -865,17 +839,17 @@ list may contain duplicates."
               (if (rng-ipattern-text-typed-p member)
                   (setq ret t))
               (setq cur
-                    (and (rng-ipattern-get-nullable member)
+                    (and (rng--ipattern-nullable member)
                          (cdr cur))))
             ret))
          ((eq type 'after)
-          (rng-ipattern-text-typed-p (rng-ipattern-get-child ipattern)))
+          (rng-ipattern-text-typed-p (rng--ipattern-child ipattern)))
          (t (and (memq type '(value list data data-except)) t)))))
 
 (defun rng-start-tag-open-deriv (ipattern nm)
   (or (rng-memo-map-get
        nm
-       (rng-ipattern-get-memo-map-start-tag-open-deriv ipattern))
+       (rng--ipattern-memo-map-start-tag-open-deriv ipattern))
       (rng-ipattern-memo-start-tag-open-deriv
        ipattern
        nm
@@ -883,56 +857,54 @@ list may contain duplicates."
 
 (defun rng-ipattern-memo-start-tag-open-deriv (ipattern nm deriv)
   (or (memq ipattern rng-const-ipatterns)
-      (rng-ipattern-set-memo-map-start-tag-open-deriv
-       ipattern
-       (rng-memo-map-add nm
-                        deriv
-                        (rng-ipattern-get-memo-map-start-tag-open-deriv
-                         ipattern))))
+      (setf (rng--ipattern-memo-map-start-tag-open-deriv ipattern)
+            (rng-memo-map-add nm
+                              deriv
+                              (rng--ipattern-memo-map-start-tag-open-deriv
+                               ipattern))))
   deriv)
 
 (defun rng-compute-start-tag-open-deriv (ipattern nm)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'choice)
-          (rng-transform-choice `(lambda (p)
-                                   (rng-start-tag-open-deriv p ',nm))
+          (rng-transform-choice (lambda (p)
+                                   (rng-start-tag-open-deriv p nm))
                                 ipattern))
          ((eq type 'element)
           (if (rng-name-class-contains
-               (rng-ipattern-get-name-class ipattern)
+               (rng--ipattern-name-class ipattern)
                nm)
               (rng-intern-after (rng-element-get-child ipattern)
                                 rng-empty-ipattern)
             rng-not-allowed-ipattern))
          ((eq type 'group)
           (rng-transform-group-nullable
-           `(lambda (p) (rng-start-tag-open-deriv p ',nm))
+           (lambda (p) (rng-start-tag-open-deriv p nm))
            'rng-cons-group-after
            ipattern))
          ((eq type 'interleave)
           (rng-transform-interleave-single
-           `(lambda (p) (rng-start-tag-open-deriv p ',nm))
+           (lambda (p) (rng-start-tag-open-deriv p nm))
            'rng-subst-interleave-after
            ipattern))
          ((eq type 'one-or-more)
-          (rng-apply-after
-           `(lambda (p)
-              (rng-intern-group (list p ,(rng-intern-optional ipattern))))
-           (rng-start-tag-open-deriv (rng-ipattern-get-child ipattern)
-                                     nm)))
+           (let ((ip (rng-intern-optional ipattern)))
+             (rng-apply-after
+              (lambda (p) (rng-intern-group (list p ip)))
+              (rng-start-tag-open-deriv (rng--ipattern-child ipattern)
+                                        nm))))
          ((eq type 'after)
-          (rng-apply-after
-           `(lambda (p)
-              (rng-intern-after p
-                                ,(rng-ipattern-get-after ipattern)))
-           (rng-start-tag-open-deriv (rng-ipattern-get-child ipattern)
-                                     nm)))
+           (let ((nip (rng--ipattern-after ipattern)))
+             (rng-apply-after
+              (lambda (p) (rng-intern-after p nip))
+              (rng-start-tag-open-deriv (rng--ipattern-child ipattern)
+                                        nm))))
          (t rng-not-allowed-ipattern))))
 
 (defun rng-start-attribute-deriv (ipattern nm)
   (or (rng-memo-map-get
        nm
-       (rng-ipattern-get-memo-map-start-attribute-deriv ipattern))
+       (rng--ipattern-memo-map-start-attribute-deriv ipattern))
       (rng-ipattern-memo-start-attribute-deriv
        ipattern
        nm
@@ -940,82 +912,79 @@ list may contain duplicates."
 
 (defun rng-ipattern-memo-start-attribute-deriv (ipattern nm deriv)
   (or (memq ipattern rng-const-ipatterns)
-      (rng-ipattern-set-memo-map-start-attribute-deriv
-       ipattern
-       (rng-memo-map-add
-       nm
-       deriv
-       (rng-ipattern-get-memo-map-start-attribute-deriv ipattern))))
+      (setf (rng--ipattern-memo-map-start-attribute-deriv ipattern)
+            (rng-memo-map-add
+             nm
+             deriv
+             (rng--ipattern-memo-map-start-attribute-deriv ipattern))))
   deriv)
 
 (defun rng-compute-start-attribute-deriv (ipattern nm)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'choice)
-          (rng-transform-choice `(lambda (p)
-                                   (rng-start-attribute-deriv p ',nm))
+          (rng-transform-choice (lambda (p)
+                                   (rng-start-attribute-deriv p nm))
                                 ipattern))
          ((eq type 'attribute)
           (if (rng-name-class-contains
-               (rng-ipattern-get-name-class ipattern)
+               (rng--ipattern-name-class ipattern)
                nm)
-              (rng-intern-after (rng-ipattern-get-child ipattern)
+              (rng-intern-after (rng--ipattern-child ipattern)
                                 rng-empty-ipattern)
             rng-not-allowed-ipattern))
          ((eq type 'group)
           (rng-transform-interleave-single
-           `(lambda (p) (rng-start-attribute-deriv p ',nm))
+           (lambda (p) (rng-start-attribute-deriv p nm))
            'rng-subst-group-after
            ipattern))
          ((eq type 'interleave)
           (rng-transform-interleave-single
-           `(lambda (p) (rng-start-attribute-deriv p ',nm))
+           (lambda (p) (rng-start-attribute-deriv p nm))
            'rng-subst-interleave-after
            ipattern))
          ((eq type 'one-or-more)
-          (rng-apply-after
-           `(lambda (p)
-              (rng-intern-group (list p ,(rng-intern-optional ipattern))))
-           (rng-start-attribute-deriv (rng-ipattern-get-child ipattern)
-                                      nm)))
+           (let ((ip (rng-intern-optional ipattern)))
+             (rng-apply-after
+              (lambda (p) (rng-intern-group (list p ip)))
+              (rng-start-attribute-deriv (rng--ipattern-child ipattern)
+                                         nm))))
          ((eq type 'after)
-          (rng-apply-after
-           `(lambda (p)
-              (rng-intern-after p ,(rng-ipattern-get-after ipattern)))
-           (rng-start-attribute-deriv (rng-ipattern-get-child ipattern)
-                                      nm)))
+           (let ((nip (rng--ipattern-after ipattern)))
+             (rng-apply-after
+              (lambda (p) (rng-intern-after p nip))
+              (rng-start-attribute-deriv (rng--ipattern-child ipattern)
+                                         nm))))
          (t rng-not-allowed-ipattern))))
 
 (defun rng-cons-group-after (x y)
-  (rng-apply-after `(lambda (p) (rng-intern-group (cons p ',y)))
+  (rng-apply-after (lambda (p) (rng-intern-group (cons p y)))
                   x))
 
 (defun rng-subst-group-after (new old list)
-  (rng-apply-after `(lambda (p)
-                     (rng-intern-group (rng-substq p ,old ',list)))
+  (rng-apply-after (lambda (p)
+                     (rng-intern-group (rng-substq p old list)))
                   new))
 
 (defun rng-subst-interleave-after (new old list)
-  (rng-apply-after `(lambda (p)
-                     (rng-intern-interleave (rng-substq p ,old ',list)))
+  (rng-apply-after (lambda (p)
+                     (rng-intern-interleave (rng-substq p old list)))
                   new))
 
 (defun rng-apply-after (f ipattern)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'after)
           (rng-intern-after
-           (rng-ipattern-get-child ipattern)
-           (funcall f
-                    (rng-ipattern-get-after ipattern))))
+           (rng--ipattern-child ipattern)
+           (funcall f (rng--ipattern-after ipattern))))
          ((eq type 'choice)
-          (rng-transform-choice `(lambda (x) (rng-apply-after ,f x))
+          (rng-transform-choice (lambda (x) (rng-apply-after f x))
                                 ipattern))
          (t rng-not-allowed-ipattern))))
 
 (defun rng-start-tag-close-deriv (ipattern)
-  (or (rng-ipattern-get-memo-start-tag-close-deriv ipattern)
-      (rng-ipattern-set-memo-start-tag-close-deriv
-       ipattern
-       (rng-compute-start-tag-close-deriv ipattern))))
+  (or (rng--ipattern-memo-start-tag-close-deriv ipattern)
+      (setf (rng--ipattern-memo-start-tag-close-deriv ipattern)
+            (rng-compute-start-tag-close-deriv ipattern))))
 
 (defconst rng-transform-map
   '((choice . rng-transform-choice)
@@ -1025,7 +994,7 @@ list may contain duplicates."
     (after . rng-transform-after-child)))
 
 (defun rng-compute-start-tag-close-deriv (ipattern)
-  (let* ((type (rng-ipattern-get-type ipattern)))
+  (let* ((type (rng--ipattern-type ipattern)))
     (if (eq type 'attribute)
        rng-not-allowed-ipattern
       (let ((transform (assq type rng-transform-map)))
@@ -1036,7 +1005,7 @@ list may contain duplicates."
          ipattern)))))
 
 (defun rng-ignore-attributes-deriv (ipattern)
-  (let* ((type (rng-ipattern-get-type ipattern)))
+  (let* ((type (rng--ipattern-type ipattern)))
     (if (eq type 'attribute)
        rng-empty-ipattern
       (let ((transform (assq type rng-transform-map)))
@@ -1047,13 +1016,12 @@ list may contain duplicates."
          ipattern)))))
 
 (defun rng-text-only-deriv (ipattern)
-  (or (rng-ipattern-get-memo-text-only-deriv ipattern)
-      (rng-ipattern-set-memo-text-only-deriv
-       ipattern
-       (rng-compute-text-only-deriv ipattern))))
+  (or (rng--ipattern-memo-text-only-deriv ipattern)
+      (setf (rng--ipattern-memo-text-only-deriv ipattern)
+            (rng-compute-text-only-deriv ipattern))))
 
 (defun rng-compute-text-only-deriv (ipattern)
-  (let* ((type (rng-ipattern-get-type ipattern)))
+  (let* ((type (rng--ipattern-type ipattern)))
     (if (eq type 'element)
        rng-not-allowed-ipattern
       (let ((transform (assq type
@@ -1069,13 +1037,12 @@ list may contain duplicates."
          ipattern)))))
 
 (defun rng-mixed-text-deriv (ipattern)
-  (or (rng-ipattern-get-memo-mixed-text-deriv ipattern)
-      (rng-ipattern-set-memo-mixed-text-deriv
-       ipattern
-       (rng-compute-mixed-text-deriv ipattern))))
+  (or (rng--ipattern-memo-mixed-text-deriv ipattern)
+      (setf (rng--ipattern-memo-mixed-text-deriv ipattern)
+            (rng-compute-mixed-text-deriv ipattern))))
 
 (defun rng-compute-mixed-text-deriv (ipattern)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'text) ipattern)
          ((eq type 'after)
           (rng-transform-after-child 'rng-mixed-text-deriv
@@ -1086,7 +1053,7 @@ list may contain duplicates."
          ((eq type 'one-or-more)
           (rng-intern-group
            (list (rng-mixed-text-deriv
-                  (rng-ipattern-get-child ipattern))
+                  (rng--ipattern-child ipattern))
                  (rng-intern-optional ipattern))))
          ((eq type 'group)
           (rng-transform-group-nullable
@@ -1100,39 +1067,38 @@ list may contain duplicates."
                                    (rng-substq new old list)))
            ipattern))
          ((and (eq type 'data)
-               (not (rng-ipattern-get-memo-text-typed ipattern)))
+               (not (rng--ipattern-memo-text-typed ipattern)))
           ipattern)
          (t rng-not-allowed-ipattern))))
 
 (defun rng-end-tag-deriv (ipattern)
-  (or (rng-ipattern-get-memo-end-tag-deriv ipattern)
-      (rng-ipattern-set-memo-end-tag-deriv
-       ipattern
-       (rng-compute-end-tag-deriv ipattern))))
+  (or (rng--ipattern-memo-end-tag-deriv ipattern)
+      (setf (rng--ipattern-memo-end-tag-deriv ipattern)
+            (rng-compute-end-tag-deriv ipattern))))
 
 (defun rng-compute-end-tag-deriv (ipattern)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'choice)
           (rng-intern-choice
            (mapcar 'rng-end-tag-deriv
-                   (rng-ipattern-get-child ipattern))))
+                   (rng--ipattern-child ipattern))))
          ((eq type 'after)
-          (if (rng-ipattern-get-nullable
-               (rng-ipattern-get-child ipattern))
-              (rng-ipattern-get-after ipattern)
+          (if (rng--ipattern-nullable
+               (rng--ipattern-child ipattern))
+              (rng--ipattern-after ipattern)
             rng-not-allowed-ipattern))
          (t rng-not-allowed-ipattern))))
 
 (defun rng-data-deriv (ipattern value)
   (or (rng-memo-map-get value
-                       (rng-ipattern-get-memo-map-data-deriv ipattern))
+                       (rng--ipattern-memo-map-data-deriv ipattern))
       (and (rng-memo-map-get
            (cons value (rng-namespace-context-get-no-trace))
-           (rng-ipattern-get-memo-map-data-deriv ipattern))
+           (rng--ipattern-memo-map-data-deriv ipattern))
           (rng-memo-map-get
            (cons value (apply (car rng-dt-namespace-context-getter)
                               (cdr rng-dt-namespace-context-getter)))
-           (rng-ipattern-get-memo-map-data-deriv ipattern)))
+           (rng--ipattern-memo-map-data-deriv ipattern)))
       (let* ((used-context (vector nil))
             (rng-dt-namespace-context-getter
              (cons 'rng-namespace-context-tracer
@@ -1161,66 +1127,65 @@ list may contain duplicates."
 (defun rng-ipattern-memo-data-deriv (ipattern value context deriv)
   (or (memq ipattern rng-const-ipatterns)
       (> (length value) rng-memo-data-deriv-max-length)
-      (rng-ipattern-set-memo-map-data-deriv
-       ipattern
-       (rng-memo-map-add (if context (cons value context) value)
-                        deriv
-                        (rng-ipattern-get-memo-map-data-deriv ipattern)
-                        t)))
+      (setf (rng--ipattern-memo-map-data-deriv ipattern)
+            (rng-memo-map-add (if context (cons value context) value)
+                              deriv
+                              (rng--ipattern-memo-map-data-deriv ipattern)
+                              t)))
   deriv)
 
 (defun rng-compute-data-deriv (ipattern value)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'text) ipattern)
          ((eq type 'choice)
-          (rng-transform-choice `(lambda (p) (rng-data-deriv p ,value))
+          (rng-transform-choice (lambda (p) (rng-data-deriv p value))
                                 ipattern))
          ((eq type 'group)
           (rng-transform-group-nullable
-           `(lambda (p) (rng-data-deriv p ,value))
+           (lambda (p) (rng-data-deriv p value))
            (lambda (x y) (rng-intern-group (cons x y)))
            ipattern))
          ((eq type 'one-or-more)
           (rng-intern-group (list (rng-data-deriv
-                                   (rng-ipattern-get-child ipattern)
+                                   (rng--ipattern-child ipattern)
                                    value)
                                   (rng-intern-optional ipattern))))
          ((eq type 'after)
-          (let ((child (rng-ipattern-get-child ipattern)))
-            (if (or (rng-ipattern-get-nullable
+          (let ((child (rng--ipattern-child ipattern)))
+            (if (or (rng--ipattern-nullable
                      (rng-data-deriv child value))
-                    (and (rng-ipattern-get-nullable child)
+                    (and (rng--ipattern-nullable child)
                          (rng-blank-p value)))
-                (rng-ipattern-get-after ipattern)
+                (rng--ipattern-after ipattern)
               rng-not-allowed-ipattern)))
          ((eq type 'data)
-          (if (rng-dt-make-value (rng-ipattern-get-datatype ipattern)
+          (if (rng-dt-make-value (rng--ipattern-datatype ipattern)
                                  value)
               rng-empty-ipattern
             rng-not-allowed-ipattern))
          ((eq type 'data-except)
-          (if (and (rng-dt-make-value (rng-ipattern-get-datatype ipattern)
+          (if (and (rng-dt-make-value (rng--ipattern-datatype ipattern)
                                       value)
-                   (not (rng-ipattern-get-nullable
+                   (not (rng--ipattern-nullable
                          (rng-data-deriv
-                          (rng-ipattern-get-child ipattern)
+                          (rng--ipattern-child ipattern)
                           value))))
               rng-empty-ipattern
             rng-not-allowed-ipattern))
          ((eq type 'value)
-          (if (equal (rng-dt-make-value (rng-ipattern-get-datatype ipattern)
+          (if (equal (rng-dt-make-value (rng--ipattern-datatype ipattern)
                                         value)
-                     (rng-ipattern-get-value-object ipattern))
+                     (rng--ipattern-value-object ipattern))
               rng-empty-ipattern
             rng-not-allowed-ipattern))
          ((eq type 'list)
           (let ((tokens (split-string value))
-                (state (rng-ipattern-get-child ipattern)))
+                (state (rng--ipattern-child ipattern)))
             (while (and tokens
                         (not (eq state rng-not-allowed-ipattern)))
               (setq state (rng-data-deriv state (car tokens)))
               (setq tokens (cdr tokens)))
-            (if (rng-ipattern-get-nullable state)
+            (if (rng--ipattern-nullable state)
                 rng-empty-ipattern
               rng-not-allowed-ipattern)))
          ;; don't think interleave can occur
@@ -1228,7 +1193,7 @@ list may contain duplicates."
          (t rng-not-allowed-ipattern))))
 
 (defun rng-transform-multi (f ipattern interner)
-  (let* ((members (rng-ipattern-get-child ipattern))
+  (let* ((members (rng--ipattern-child ipattern))
         (transformed (mapcar f members)))
     (if (rng-members-eq members transformed)
        ipattern
@@ -1244,22 +1209,22 @@ list may contain duplicates."
   (rng-transform-multi f ipattern 'rng-intern-interleave))
 
 (defun rng-transform-one-or-more (f ipattern)
-  (let* ((child (rng-ipattern-get-child ipattern))
+  (let* ((child (rng--ipattern-child ipattern))
         (transformed (funcall f child)))
     (if (eq child transformed)
        ipattern
       (rng-intern-one-or-more transformed))))
 
 (defun rng-transform-after-child (f ipattern)
-  (let* ((child (rng-ipattern-get-child ipattern))
+  (let* ((child (rng--ipattern-child ipattern))
         (transformed (funcall f child)))
     (if (eq child transformed)
        ipattern
       (rng-intern-after transformed
-                       (rng-ipattern-get-after ipattern)))))
+                       (rng--ipattern-after ipattern)))))
 
 (defun rng-transform-interleave-single (f subster ipattern)
-  (let ((children (rng-ipattern-get-child ipattern))
+  (let ((children (rng--ipattern-child ipattern))
        found)
     (while (and children (not found))
       (let* ((child (car children))
@@ -1270,7 +1235,7 @@ list may contain duplicates."
                (funcall subster
                         transformed
                         child
-                        (rng-ipattern-get-child ipattern))))))
+                        (rng--ipattern-child ipattern))))))
     (or found
        rng-not-allowed-ipattern)))
 
@@ -1286,14 +1251,14 @@ nullable and y1 isn't, return a choice
    (rng-transform-group-nullable-gen-choices
     f
     conser
-    (rng-ipattern-get-child ipattern))))
+    (rng--ipattern-child ipattern))))
 
 (defun rng-transform-group-nullable-gen-choices (f conser members)
   (let ((head (car members))
        (tail (cdr members)))
     (if tail
        (cons (funcall conser (funcall f head) tail)
-             (if (rng-ipattern-get-nullable head)
+             (if (rng--ipattern-nullable head)
                  (rng-transform-group-nullable-gen-choices f conser tail)
                nil))
       (list (funcall f head)))))
@@ -1308,11 +1273,11 @@ nullable and y1 isn't, return a choice
 
 
 (defun rng-ipattern-after (ipattern)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'choice)
           (rng-transform-choice 'rng-ipattern-after ipattern))
          ((eq type 'after)
-          (rng-ipattern-get-after ipattern))
+          (rng--ipattern-after ipattern))
          ((eq  type 'not-allowed)
           ipattern)
          (t (error "Internal error in rng-ipattern-after: unexpected type %s" type)))))
@@ -1321,7 +1286,7 @@ nullable and y1 isn't, return a choice
   (rng-intern-after (rng-compile rng-any-content) ipattern))
 
 (defun rng-ipattern-optionalize-elements (ipattern)
-  (let* ((type (rng-ipattern-get-type ipattern))
+  (let* ((type (rng--ipattern-type ipattern))
         (transform (assq type rng-transform-map)))
     (cond (transform
           (funcall (cdr transform)
@@ -1332,11 +1297,11 @@ nullable and y1 isn't, return a choice
          (t ipattern))))
 
 (defun rng-ipattern-empty-before-p (ipattern)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'after)
-          (eq (rng-ipattern-get-child ipattern) rng-empty-ipattern))
+          (eq (rng--ipattern-child ipattern) rng-empty-ipattern))
          ((eq type 'choice)
-          (let ((members (rng-ipattern-get-child ipattern))
+          (let ((members (rng--ipattern-child ipattern))
                 (ret t))
             (while (and members ret)
               (or (rng-ipattern-empty-before-p (car members))
@@ -1346,13 +1311,13 @@ nullable and y1 isn't, return a choice
          (t nil))))
 
 (defun rng-ipattern-possible-start-tags (ipattern accum)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'after)
           (rng-ipattern-possible-start-tags
-           (rng-ipattern-get-child ipattern)
+           (rng--ipattern-child ipattern)
            accum))
          ((memq type '(choice interleave))
-          (let ((members (rng-ipattern-get-child ipattern)))
+          (let ((members (rng--ipattern-child ipattern)))
             (while members
               (setq accum
                     (rng-ipattern-possible-start-tags (car members)
@@ -1360,34 +1325,34 @@ nullable and y1 isn't, return a choice
               (setq members (cdr members))))
           accum)
          ((eq type 'group)
-          (let ((members (rng-ipattern-get-child ipattern)))
+          (let ((members (rng--ipattern-child ipattern)))
             (while members
               (setq accum
                     (rng-ipattern-possible-start-tags (car members)
                                                       accum))
               (setq members
-                    (and (rng-ipattern-get-nullable (car members))
+                    (and (rng--ipattern-nullable (car members))
                          (cdr members)))))
           accum)
          ((eq type 'element)
           (if (eq (rng-element-get-child ipattern) rng-not-allowed-ipattern)
               accum
             (rng-name-class-possible-names
-             (rng-ipattern-get-name-class ipattern)
+             (rng--ipattern-name-class ipattern)
              accum)))
          ((eq type 'one-or-more)
           (rng-ipattern-possible-start-tags
-           (rng-ipattern-get-child ipattern)
+           (rng--ipattern-child ipattern)
            accum))
          (t accum))))
 
 (defun rng-ipattern-start-tag-possible-p (ipattern)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((memq type '(after one-or-more))
           (rng-ipattern-start-tag-possible-p
-           (rng-ipattern-get-child ipattern)))
+           (rng--ipattern-child ipattern)))
          ((memq type '(choice interleave))
-          (let ((members (rng-ipattern-get-child ipattern))
+          (let ((members (rng--ipattern-child ipattern))
                 (possible nil))
             (while (and members (not possible))
               (setq possible
@@ -1395,13 +1360,13 @@ nullable and y1 isn't, return a choice
               (setq members (cdr members)))
             possible))
          ((eq type 'group)
-          (let ((members (rng-ipattern-get-child ipattern))
+          (let ((members (rng--ipattern-child ipattern))
                 (possible nil))
             (while (and members (not possible))
               (setq possible
                     (rng-ipattern-start-tag-possible-p (car members)))
               (setq members
-                    (and (rng-ipattern-get-nullable (car members))
+                    (and (rng--ipattern-nullable (car members))
                          (cdr members))))
             possible))
          ((eq type 'element)
@@ -1410,12 +1375,12 @@ nullable and y1 isn't, return a choice
          (t nil))))
 
 (defun rng-ipattern-possible-attributes (ipattern accum)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'after)
-          (rng-ipattern-possible-attributes (rng-ipattern-get-child ipattern)
+          (rng-ipattern-possible-attributes (rng--ipattern-child ipattern)
                                             accum))
          ((memq type '(choice interleave group))
-          (let ((members (rng-ipattern-get-child ipattern)))
+          (let ((members (rng--ipattern-child ipattern)))
             (while members
               (setq accum
                     (rng-ipattern-possible-attributes (car members)
@@ -1424,21 +1389,21 @@ nullable and y1 isn't, return a choice
           accum)
          ((eq type 'attribute)
           (rng-name-class-possible-names
-           (rng-ipattern-get-name-class ipattern)
+           (rng--ipattern-name-class ipattern)
            accum))
          ((eq type 'one-or-more)
           (rng-ipattern-possible-attributes
-           (rng-ipattern-get-child ipattern)
+           (rng--ipattern-child ipattern)
            accum))
          (t accum))))
 
 (defun rng-ipattern-possible-values (ipattern accum)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'after)
-          (rng-ipattern-possible-values (rng-ipattern-get-child ipattern)
+          (rng-ipattern-possible-values (rng--ipattern-child ipattern)
                                         accum))
          ((eq type 'choice)
-          (let ((members (rng-ipattern-get-child ipattern)))
+          (let ((members (rng--ipattern-child ipattern)))
             (while members
               (setq accum
                     (rng-ipattern-possible-values (car members)
@@ -1446,18 +1411,18 @@ nullable and y1 isn't, return a choice
               (setq members (cdr members))))
           accum)
          ((eq type 'value)
-          (let ((value-object (rng-ipattern-get-value-object ipattern)))
+          (let ((value-object (rng--ipattern-value-object ipattern)))
             (if (stringp value-object)
                 (cons value-object accum)
               accum)))
          (t accum))))
 
 (defun rng-ipattern-required-element (ipattern)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((memq type '(after one-or-more))
-          (rng-ipattern-required-element (rng-ipattern-get-child ipattern)))
+          (rng-ipattern-required-element (rng--ipattern-child ipattern)))
          ((eq type 'choice)
-          (let* ((members (rng-ipattern-get-child ipattern))
+          (let* ((members (rng--ipattern-child ipattern))
                  (required (rng-ipattern-required-element (car members))))
             (while (and required
                         (setq members (cdr members)))
@@ -1466,16 +1431,16 @@ nullable and y1 isn't, return a choice
                   (setq required nil)))
             required))
          ((eq type 'group)
-          (let ((members (rng-ipattern-get-child ipattern))
+          (let ((members (rng--ipattern-child ipattern))
                 required)
             (while (and (not (setq required
                                    (rng-ipattern-required-element
                                     (car members))))
-                        (rng-ipattern-get-nullable (car members))
+                        (rng--ipattern-nullable (car members))
                         (setq members (cdr members))))
             required))
          ((eq type 'interleave)
-          (let ((members (rng-ipattern-get-child ipattern))
+          (let ((members (rng--ipattern-child ipattern))
                 required)
             (while members
               (let ((tem (rng-ipattern-required-element (car members))))
@@ -1491,19 +1456,19 @@ nullable and y1 isn't, return a choice
                        (setq members nil)))))
             required))
          ((eq type 'element)
-          (let ((nc (rng-ipattern-get-name-class ipattern)))
+          (let ((nc (rng--ipattern-name-class ipattern)))
             (and (consp nc)
                  (not (eq (rng-element-get-child ipattern)
                           rng-not-allowed-ipattern))
                  nc))))))
 
 (defun rng-ipattern-required-attributes (ipattern accum)
-  (let ((type (rng-ipattern-get-type ipattern)))
+  (let ((type (rng--ipattern-type ipattern)))
     (cond ((eq type 'after)
-          (rng-ipattern-required-attributes (rng-ipattern-get-child ipattern)
+          (rng-ipattern-required-attributes (rng--ipattern-child ipattern)
                                             accum))
          ((memq type '(interleave group))
-          (let ((members (rng-ipattern-get-child ipattern)))
+          (let ((members (rng--ipattern-child ipattern)))
             (while members
               (setq accum
                     (rng-ipattern-required-attributes (car members)
@@ -1511,7 +1476,7 @@ nullable and y1 isn't, return a choice
               (setq members (cdr members))))
           accum)
          ((eq type 'choice)
-          (let ((members (rng-ipattern-get-child ipattern))
+          (let ((members (rng--ipattern-child ipattern))
                 in-all in-this new-in-all)
             (setq in-all
                   (rng-ipattern-required-attributes (car members)
@@ -1528,12 +1493,12 @@ nullable and y1 isn't, return a choice
               (setq in-all new-in-all))
             (append in-all accum)))
          ((eq type 'attribute)
-          (let ((nc (rng-ipattern-get-name-class ipattern)))
+          (let ((nc (rng--ipattern-name-class ipattern)))
             (if (consp nc)
                 (cons nc accum)
               accum)))
          ((eq type 'one-or-more)
-          (rng-ipattern-required-attributes (rng-ipattern-get-child ipattern)
+          (rng-ipattern-required-attributes (rng--ipattern-child ipattern)
                                             accum))
          (t accum))))
 
@@ -1667,7 +1632,7 @@ for an end-tag is equivalent to empty."
     ns))
 
 (defun rng-match-nullable-p ()
-  (rng-ipattern-get-nullable rng-match-state))
+  (rng--ipattern-nullable rng-match-state))
 
 (defun rng-match-possible-start-tag-names ()
   "Return a list of possible names that would be valid for start-tags.
@@ -1704,16 +1669,15 @@ be exhaustive."
   (rng-ipattern-required-attributes rng-match-state nil))
 
 (defmacro rng-match-save (&rest body)
+  (declare (indent 0) (debug t))
   (let ((state (make-symbol "state")))
     `(let ((,state rng-match-state))
        (unwind-protect
           (progn ,@body)
         (setq rng-match-state ,state)))))
 
-(put 'rng-match-save 'lisp-indent-function 0)
-(def-edebug-spec rng-match-save t)
-
 (defmacro rng-match-with-schema (schema &rest body)
+  (declare (indent 1) (debug t))
   `(let ((rng-current-schema ,schema)
         rng-match-state
         rng-compile-table
@@ -1724,9 +1688,6 @@ be exhaustive."
      (setq rng-match-state (rng-compile rng-current-schema))
      ,@body))
 
-(put 'rng-match-with-schema 'lisp-indent-function 1)
-(def-edebug-spec rng-match-with-schema t)
-
 (provide 'rng-match)
 
 ;;; rng-match.el ends here
index 9bfcd21618d8c1536b9f0cc64f8a991575d6aba2..a4ad0de853ecffdf071e33451df03b345e40ef05 100644 (file)
@@ -1,4 +1,4 @@
-;;; xmltok.el --- XML tokenization
+;;; xmltok.el --- XML tokenization  -*- lexical-binding:t -*-
 
 ;; Copyright (C) 2003, 2007-2013 Free Software Foundation, Inc.
 
@@ -142,6 +142,7 @@ string giving the error message and START and END are integers
 indicating the position of the error.")
 
 (defmacro xmltok-save (&rest body)
+  (declare (indent 0) (debug t))
   `(let (xmltok-type
         xmltok-start
         xmltok-name-colon
@@ -152,9 +153,6 @@ indicating the position of the error.")
         xmltok-errors)
      ,@body))
 
-(put 'xmltok-save 'lisp-indent-function 0)
-(def-edebug-spec xmltok-save t)
-
 (defsubst xmltok-attribute-name-start (att)
   (aref att 0))
 
@@ -411,7 +409,6 @@ Return the type of the token."
 (eval-when-compile
   (let* ((or "\\|")
         (open "\\(?:")
-        (gopen "\\(")
         (close "\\)")
         (name-start-char "[_[:alpha:]]")
         (name-continue-not-start-char "[-.[:digit:]]")
@@ -988,33 +985,6 @@ Return the type of the token."
         (xmltok-valid-char-p n)
         n)))
 
-(defun xmltok-unclosed-reparse-p (change-start
-                                 change-end
-                                 pre-change-length
-                                 start
-                                 end
-                                 delimiter)
-  (let ((len-1 (1- (length delimiter))))
-    (goto-char (max start (- change-start len-1)))
-    (search-forward delimiter (min end (+ change-end len-1)) t)))
-
-;; Handles a <!-- with the next -- not followed by >
-
-(defun xmltok-semi-closed-reparse-p (change-start
-                                    change-end
-                                    pre-change-length
-                                    start
-                                    end
-                                    delimiter
-                                    delimiter-length)
-  (or (<= (- end delimiter-length) change-end)
-      (xmltok-unclosed-reparse-p change-start
-                                change-end
-                                pre-change-length
-                                start
-                                end
-                                delimiter)))
-
 (defun xmltok-valid-char-p (n)
   "Return non-nil if N is the Unicode code of a valid XML character."
   (cond ((< n #x20) (memq n '(#xA #xD #x9)))
@@ -1072,7 +1042,7 @@ Adds to `xmltok-errors' as appropriate."
     (setq xmltok-dtd xmltok-predefined-entity-alist)
     (xmltok-scan-xml-declaration)
     (xmltok-next-prolog-token)
-    (while (condition-case err
+    (while (condition-case nil
               (when (xmltok-parse-prolog-item)
                 (xmltok-next-prolog-token))
             (xmltok-markup-declaration-parse-error
@@ -1371,7 +1341,7 @@ If LIMIT is non-nil, then do not consider characters beyond LIMIT."
                       (t
                        (let ((xmltok-start (1- (point)))
                               xmltok-type xmltok-replacement)
-                         (xmltok-scan-after-amp (lambda (start end)))
+                         (xmltok-scan-after-amp (lambda (_start _end)))
                          (cond ((eq xmltok-type 'char-ref)
                                 (setq value-parts
                                       (cons (buffer-substring-no-properties