]> git.eshelyaron.com Git - emacs.git/commitdiff
(perl-font-lock-syntactic-keywords): Try to be
authorStefan Monnier <monnier@iro.umontreal.ca>
Tue, 3 Jun 2008 07:18:54 +0000 (07:18 +0000)
committerStefan Monnier <monnier@iro.umontreal.ca>
Tue, 3 Jun 2008 07:18:54 +0000 (07:18 +0000)
yet a bit more clever at distinguishing / from /.

lisp/ChangeLog
lisp/progmodes/perl-mode.el

index de57acf56b69ee5f5f1894d72f9e0ac38cec9b7d..a58fc460289e6d08299fd5e48bd402a97cb50e75 100644 (file)
@@ -1,3 +1,8 @@
+2008-06-03  Stefan Monnier  <monnier@iro.umontreal.ca>
+
+       * progmodes/perl-mode.el (perl-font-lock-syntactic-keywords): Try to be
+       yet a bit more clever at distinguishing / from /.
+
 2008-06-03  Kenichi Handa  <handa@m17n.org>
 
        * Makefile.in (ELCFILES): Add $(lisp)/language/hanja-util.elc.
index 22d9b488cc6ff2a083131ef00a00693fae58d9e5..c92ac4252da0aeb30aad02b6b87010b06c2d0c15 100644 (file)
@@ -252,7 +252,7 @@ The expansion is entirely correct because it uses the C preprocessor."
 ;; <file*glob>
 (defvar perl-font-lock-syntactic-keywords
   ;; TODO: here-documents ("<<\\(\\sw\\|['\"]\\)")
-  '(;; Turn POD into b-style comments
+  `(;; Turn POD into b-style comments
     ("^\\(=\\)\\sw" (1 "< b"))
     ("^=cut[ \t]*\\(\n\\)" (1 "> b"))
     ;; Catch ${ so that ${var} doesn't screw up indentation.
@@ -267,12 +267,27 @@ The expansion is entirely correct because it uses the C preprocessor."
     ;; Be careful not to match "sub { (...) ... }".
     ("\\<sub\\(?:[[:space:]]+[^{}[:punct:][:space:]]+\\)?[[:space:]]*(\\([^)]+\\))"
      1 '(1))
-    ;; Regexp and funny quotes.
-    ("\\(?:[?:.,;=!~({[]\\|\\(^\\)\\)[ \t\n]*\\(/\\)"
+    ;; Regexp and funny quotes.  Distinguishing a / that starts a regexp
+    ;; match from the division operator is ...interesting.
+    ;; Basically, / is a regexp match if it's preceded by an infix operator
+    ;; (or some similar separator), or by one of the special keywords
+    ;; corresponding to builtin functions that can take their first arg
+    ;; without parentheses.  Of course, that presume we're looking at the
+    ;; *opening* slash.  We can mis-match the closing ones, because they are
+    ;; treated separately later in
+    ;; perl-font-lock-special-syntactic-constructs.
+    (,(concat "\\(?:\\(?:\\(?:^\\|[^$@&%[:word:]]\\)"
+              (regexp-opt '("split" "if" "unless" "until" "while" "split"
+                            "grep" "map" "not" "or" "and"))
+              "\\)\\|[?:.,;=!~({[]\\|\\(^\\)\\)[ \t\n]*\\(/\\)")
      (2 (if (and (match-end 1)
                  (save-excursion
                    (goto-char (match-end 1))
-                   (skip-chars-backward " \t\n")
+                   ;; Not 100% correct since we haven't finished setting up
+                   ;; the syntax-table before point, but better than nothing.
+                   (forward-comment (- (point-max)))
+                   (put-text-property (point) (match-end 2)
+                                      'jit-lock-multiline t)
                    (not (memq (char-before)
                               '(?? ?: ?. ?, ?\; ?= ?! ?~ ?\( ?\[)))))
             nil ;; A division sign instead of a regexp-match.