]> git.eshelyaron.com Git - emacs.git/commitdiff
More small hack-local-variables tweaks for MODE-ONLY case.
authorGlenn Morris <rgm@gnu.org>
Sun, 22 May 2011 00:04:49 +0000 (17:04 -0700)
committerGlenn Morris <rgm@gnu.org>
Sun, 22 May 2011 00:04:49 +0000 (17:04 -0700)
* lisp/files.el (hack-local-variables-prop-line): Small simplifications.
(hack-local-variables, hack-local-variables-prop-line):
If MODE-ONLY, return the mode, rather than just `t'.

lisp/ChangeLog
lisp/files.el

index a1ec897b2e2c87e92b7a7bb54fbdb1cd33877076..91c51b7925dadf3a63547297e36dfe1635e46efb 100644 (file)
@@ -1,3 +1,9 @@
+2011-05-22  Glenn Morris  <rgm@gnu.org>
+
+       * files.el (hack-local-variables-prop-line): Small simplifications.
+       (hack-local-variables, hack-local-variables-prop-line):
+       If MODE-ONLY, return the mode, rather than just `t'.
+
 2011-05-21  Stefan Monnier  <monnier@iro.umontreal.ca>
 
        * progmodes/grep.el (grep-mode): Fix last change (bug#8684).
index e6f0d93299cfac9462f8bec9e9d89de61e53b51b..f4168c107b1a01206ce35b84730e8e7be5e8c0e7 100644 (file)
@@ -3032,63 +3032,61 @@ n  -- to ignore the local variables list.")
 
 (defun hack-local-variables-prop-line (&optional mode-only)
   "Return local variables specified in the -*- line.
-Ignore any specification for `mode:' and `coding:';
-`set-auto-mode' should already have handled `mode:',
-`set-auto-coding' should already have handled `coding:'.
-
-If MODE-ONLY is non-nil, all we do is check whether the major
-mode is specified, returning t if it is specified.  Otherwise,
-return an alist of elements (VAR . VAL), where VAR is a variable
-and VAL is the specified value."
+Returns an alist of elements (VAR . VAL), where VAR is a variable
+and VAL is the specified value.  Ignores any specification for
+`mode:' and `coding:' (which should have already been handled
+by `set-auto-mode' and `set-auto-coding', respectively).
+Throws an error if the -*- line is malformed.
+
+If MODE-ONLY is non-nil, just returns the symbol specifying the
+mode, if there is one, otherwise nil."
   (save-excursion
     (goto-char (point-min))
     (let ((end (set-auto-mode-1))
-         result mode-specified)
-      ;; Parse the -*- line into the RESULT alist.
-      ;; Also set MODE-SPECIFIED if we see a spec or `mode'.
+         result)
       (cond ((not end)
             nil)
            ((looking-at "[ \t]*\\([^ \t\n\r:;]+\\)\\([ \t]*-\\*-\\)")
-            ;; Simple form: "-*- MODENAME -*-".  Already handled.
-            (setq mode-specified t)
-            nil)
+            ;; Simple form: "-*- MODENAME -*-".
+            (if mode-only
+                (intern (match-string 1))))
            (t
             ;; Hairy form: '-*-' [ <variable> ':' <value> ';' ]* '-*-'
             ;; (last ";" is optional).
-            (while (and (< (point) end)
-                        (or (not mode-only)
-                            (not mode-specified)))
+            ;; If MODE-ONLY, just check for `mode'.
+            ;; Otherwise, parse the -*- line into the RESULT alist.
+            (while (and (or (not mode-only)
+                            (not result))
+                        (< (point) end))
               (or (looking-at "[ \t]*\\([^ \t\n:]+\\)[ \t]*:[ \t]*")
                   (error "Malformed -*- line"))
               (goto-char (match-end 0))
               ;; There used to be a downcase here,
               ;; but the manual didn't say so,
               ;; and people want to set var names that aren't all lc.
-              (let ((key (intern (match-string 1)))
-                    (val (save-restriction
-                           (narrow-to-region (point) end)
-                           (let ((read-circle nil))
-                             (read (current-buffer))))))
-                ;; It is traditional to ignore
-                ;; case when checking for `mode' in set-auto-mode,
-                ;; so we must do that here as well.
-                ;; That is inconsistent, but we're stuck with it.
-                ;; The same can be said for `coding' in set-auto-coding.
-                (or (and (equal (downcase (symbol-name key)) "mode")
-                         (setq mode-specified t))
-                    mode-only
-                    (equal (downcase (symbol-name key)) "coding")
-                    (condition-case nil
-                        (push (cons (if (eq key 'eval)
-                                        'eval
-                                      (indirect-variable key))
-                                    val) result)
-                      (error nil)))
-                (skip-chars-forward " \t;")))))
-
-      (if mode-only
-         mode-specified
-       result))))
+              (let* ((key (intern (match-string 1)))
+                     (val (save-restriction
+                            (narrow-to-region (point) end)
+                            (let ((read-circle nil))
+                              (read (current-buffer)))))
+                     ;; It is traditional to ignore
+                     ;; case when checking for `mode' in set-auto-mode,
+                     ;; so we must do that here as well.
+                     ;; That is inconsistent, but we're stuck with it.
+                     ;; The same can be said for `coding' in set-auto-coding.
+                     (keyname (downcase (symbol-name key))))
+                (if mode-only
+                    (and (equal keyname "mode")
+                         (setq result val))
+                  (or (equal keyname "coding")
+                      (condition-case nil
+                          (push (cons (if (eq key 'eval)
+                                          'eval
+                                        (indirect-variable key))
+                                      val) result)
+                        (error nil))))
+                (skip-chars-forward " \t;")))
+            result)))))
 
 (defun hack-local-variables-filter (variables dir-name)
   "Filter local variable settings, querying the user if necessary.
@@ -3147,8 +3145,8 @@ DIR-NAME is the name of the associated directory.  Otherwise it is nil."
 
 (defun hack-local-variables (&optional mode-only)
   "Parse and put into effect this buffer's local variables spec.
-If MODE-ONLY is non-nil, all we do is check whether the major mode
-is specified, returning t if it is specified."
+If MODE-ONLY is non-nil, all we do is check whether a \"mode:\"
+is specified, and return the corresponding mode symbol, or nil."
   (let ((enable-local-variables
         (and local-enable-local-variables enable-local-variables))
        result)
@@ -3235,7 +3233,7 @@ is specified, returning t if it is specified."
                        (setq val (read (current-buffer))))
                      (if mode-only
                          (if (eq var 'mode)
-                             (setq result t))
+                             (setq result val))
                        (unless (eq var 'coding)
                          (condition-case nil
                              (push (cons (if (eq var 'eval)