+2005-10-05 Stefan Monnier <monnier@iro.umontreal.ca>
+
+ * progmodes/scheme.el (scheme-mode-syntax-table): Mark ; as being
+ also the second char of a comment-start sequence.
+ (scheme-sexp-comment-syntax-table): New var.
+ (lambda, define): Set their scheme-doc-string-elt property.
+ (scheme-font-lock-syntactic-face-function): Handle sexp-comments.
+ Use lisp-font-lock-syntactic-face-function now that it properly
+ handles |...| symbols.
+ (scheme-mode-variables): Set lisp-doc-string-elt-property,
+ parse-sexp-lookup-properties and font-lock-extra-managed-props.
+
+ * emacs-lisp/lisp-mode.el (lisp-mode-syntax-table): Move the nesting
+ bit from # to |.
+ (lisp-font-lock-syntactic-face-function): Distinguish |...| symbols.
+
+ * emacs-lisp/lisp-mode.el (lambda): Add its doc-string-elt property.
+ (lisp-doc-string-elt-property): New var.
+ (lisp-font-lock-syntactic-face-function): Use it.
+ Rewrite to recognize docstrings even for forms not at toplevel.
+
+ * progmodes/scheme.el (scheme-mode-syntax-table): Put the nested
+ annotation on the | part of #| rather than on the # part.
+ (scheme-font-lock-syntactic-face-function): New function, to
+ distinguish strings from |...| symbols.
+ (scheme-mode-variables): Use it. Also fix up the font-lock-time
+ syntax-table so that #|...|# is properly highlighted.
+
+ * emacs-lisp/lisp-mode.el (lisp-font-lock-syntactic-face-function):
+ Don't mark as docstring the 3rd elem of an unknown toplevel form.
+
2005-10-04 Stefan Monnier <monnier@iro.umontreal.ca>
* bindings.el (global-map): Resync [home] and [end] bindings with C-a
;; Other atom delimiters
(modify-syntax-entry ?\( "() " st)
(modify-syntax-entry ?\) ")( " st)
- (modify-syntax-entry ?\; "< " st)
- (modify-syntax-entry ?\" "\" " st)
+ ;; It's used for single-line comments as well as for #;(...) sexp-comments.
+ (modify-syntax-entry ?\; "< 2 " st)
+ (modify-syntax-entry ?\" "\" " st)
(modify-syntax-entry ?' "' " st)
(modify-syntax-entry ?` "' " st)
(setq imenu-generic-expression scheme-imenu-generic-expression)
(set (make-local-variable 'imenu-syntax-alist)
'(("+-*/.<>=?!$%_&~^:" . "w")))
- (make-local-variable 'font-lock-defaults)
- (setq font-lock-defaults
- '((scheme-font-lock-keywords
- scheme-font-lock-keywords-1 scheme-font-lock-keywords-2)
- nil t (("+-*/.<>=!?$%_&~^:" . "w") (?#. "w 14"))
- beginning-of-defun
- (font-lock-mark-block-function . mark-defun)
- (font-lock-syntactic-face-function
- . scheme-font-lock-syntactic-face-function))))
+ (set (make-local-variable 'font-lock-defaults)
+ '((scheme-font-lock-keywords
+ scheme-font-lock-keywords-1 scheme-font-lock-keywords-2)
+ nil t (("+-*/.<>=!?$%_&~^:" . "w") (?#. "w 14"))
+ beginning-of-defun
+ (font-lock-mark-block-function . mark-defun)
+ (font-lock-syntactic-face-function
+ . scheme-font-lock-syntactic-face-function)
+ (parse-sexp-lookup-properties . t)
+ (font-lock-extra-managed-props syntax-table)))
+ (set (make-local-variable 'lisp-doc-string-elt-property)
+ 'scheme-doc-string-elt))
(defvar scheme-mode-line-process "")
(defvar scheme-font-lock-keywords scheme-font-lock-keywords-1
"Default expressions to highlight in Scheme modes.")
+(defconst scheme-sexp-comment-syntax-table
+ (let ((st (make-syntax-table scheme-mode-syntax-table)))
+ (modify-syntax-entry ?\; "." st)
+ (modify-syntax-entry ?\n " " st)
+ (modify-syntax-entry ?# "'" st)
+ st))
+
+(put 'lambda 'scheme-doc-string-elt 2)
+;; Docstring's pos in a `define' depends on whether it's a var or fun def.
+(put 'define 'scheme-doc-string-elt
+ (lambda ()
+ ;; The function is called with point right after "define".
+ (forward-comment (point-max))
+ (if (eq (char-after) ?\() 2 0)))
+
(defun scheme-font-lock-syntactic-face-function (state)
- (if (nth 3 state)
- ;; In a string.
- (if (eq (char-after (nth 8 state)) ?|)
- ;; This is not a string, but a |...| symbol.
- nil
- font-lock-string-face)
- ;; In a comment.
- font-lock-comment-face))
+ (when (and (null (nth 3 state))
+ (eq (char-after (nth 8 state)) ?#)
+ (eq (char-after (1+ (nth 8 state))) ?\;))
+ ;; It's a sexp-comment. Tell parse-partial-sexp where it ends.
+ (save-excursion
+ (let ((pos (point))
+ (end
+ (condition-case err
+ (let ((parse-sexp-lookup-properties nil))
+ (goto-char (+ 2 (nth 8 state)))
+ ;; FIXME: this doesn't handle the case where the sexp
+ ;; itself contains a #; comment.
+ (forward-sexp 1)
+ (point))
+ (scan-error (nth 2 err)))))
+ (when (< pos (- end 2))
+ (put-text-property pos (- end 2)
+ 'syntax-table scheme-sexp-comment-syntax-table))
+ (put-text-property (- end 1) end 'syntax-table '(12)))))
+ ;; Choose the face to use.
+ (lisp-font-lock-syntactic-face-function state))
;;;###autoload
(define-derived-mode dsssl-mode scheme-mode "DSSSL"