annotate lisp/syntax.el @ 5726:179f4a9201b5

Merge.
author Mike Sperber <sperber@deinprogramm.de>
date Tue, 05 Mar 2013 08:55:56 +0100
parents 308d34e9f07d
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1 ;; syntax.el --- Syntax-table hacking stuff, moved from syntax.c
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
2
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
3 ;; Copyright (C) 1993, 1997 Free Software Foundation, Inc.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
4 ;; Copyright (C) 1995 Sun Microsystems.
4945
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
5 ;; Copyright (C) 2005, 2010 Ben Wing.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
6
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
7 ;; This file is part of XEmacs.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
8
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4945
diff changeset
9 ;; XEmacs is free software: you can redistribute it and/or modify it
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4945
diff changeset
10 ;; under the terms of the GNU General Public License as published by the
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4945
diff changeset
11 ;; Free Software Foundation, either version 3 of the License, or (at your
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4945
diff changeset
12 ;; option) any later version.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
13
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4945
diff changeset
14 ;; XEmacs is distributed in the hope that it will be useful, but WITHOUT
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4945
diff changeset
15 ;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4945
diff changeset
16 ;; FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4945
diff changeset
17 ;; for more details.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
18
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
19 ;; You should have received a copy of the GNU General Public License
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4945
diff changeset
20 ;; along with XEmacs. If not, see <http://www.gnu.org/licenses/>.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
21
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
22 ;;; Synched up with: FSF 19.28.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
23
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
24 ;;; Commentary:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
25
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
26 ;; This file is dumped with XEmacs.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
27
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
28 ;; Note: FSF does not have a file syntax.el. This stuff is
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
29 ;; in syntax.c. See comments there about not merging past 19.28.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
30
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
31 ;; Significantly hacked upon by Ben Wing.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
32
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
33 ;;; Code:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
34
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
35 (defun make-syntax-table (&optional oldtable)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
36 "Return a new syntax table.
4945
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
37
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
38 It inherits all characters from the standard syntax table.
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
39
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
40 A syntax table is a char table of type `syntax' (see `make-char-table').
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
41 The valid values are integers (intended to be syntax codes as generated by
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
42 `syntax-string-to-code'), and the default result given by `get-char-table'
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
43 is the syntax code for `word'. (Note: In 21.4 and prior, it was the code
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
44 for `inherit'.)
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
45
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
46 To modify a syntax table, you should normally use `modify-syntax-entry'
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
47 rather than directly modify the table with `put-char-table'.
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
48
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
49 See `modify-syntax-entry' for a description of the character codes used
99e465e2da2e (main branch) Update make-syntax-table doc
Ben Wing <ben@xemacs.org>
parents: 4806
diff changeset
50 to indicate the various syntax classes."
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
51 (make-char-table 'syntax))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
52
4468
a78d697ccd2c Import and extend GNU's descr-text.el, supporting prefix argument for C-x =
Aidan Kehoe <kehoea@parhasard.net>
parents: 3067
diff changeset
53 (defun syntax-after (pos)
a78d697ccd2c Import and extend GNU's descr-text.el, supporting prefix argument for C-x =
Aidan Kehoe <kehoea@parhasard.net>
parents: 3067
diff changeset
54 "Return the raw syntax of the char after POS.
a78d697ccd2c Import and extend GNU's descr-text.el, supporting prefix argument for C-x =
Aidan Kehoe <kehoea@parhasard.net>
parents: 3067
diff changeset
55 If POS is outside the buffer's accessible portion, return nil."
a78d697ccd2c Import and extend GNU's descr-text.el, supporting prefix argument for C-x =
Aidan Kehoe <kehoea@parhasard.net>
parents: 3067
diff changeset
56 (unless (or (< pos (point-min)) (>= pos (point-max)))
a78d697ccd2c Import and extend GNU's descr-text.el, supporting prefix argument for C-x =
Aidan Kehoe <kehoea@parhasard.net>
parents: 3067
diff changeset
57 (let ((st (if lookup-syntax-properties
a78d697ccd2c Import and extend GNU's descr-text.el, supporting prefix argument for C-x =
Aidan Kehoe <kehoea@parhasard.net>
parents: 3067
diff changeset
58 (get-char-property pos 'syntax-table))))
a78d697ccd2c Import and extend GNU's descr-text.el, supporting prefix argument for C-x =
Aidan Kehoe <kehoea@parhasard.net>
parents: 3067
diff changeset
59 (char-syntax (char-after pos) (or st (syntax-table))))))
a78d697ccd2c Import and extend GNU's descr-text.el, supporting prefix argument for C-x =
Aidan Kehoe <kehoea@parhasard.net>
parents: 3067
diff changeset
60
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
61 (defun simple-set-syntax-entry (char spec table)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
62 (put-char-table char spec table))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
63
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
64 (defun char-syntax-from-code (code)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
65 "Extract the syntax designator from the internal syntax code CODE.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
66 CODE is the value actually contained in the syntax table."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
67 (if (consp code)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
68 (setq code (car code)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
69 (aref (syntax-designator-chars) (logand code 127)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
70
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
71 (defun set-char-syntax-in-code (code desig)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
72 "Return a new internal syntax code whose syntax designator is DESIG.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
73 Other characteristics are the same as in CODE."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
74 (let ((newcode (if (consp code) (car code) code)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
75 (setq newcode (logior (string-match
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
76 (regexp-quote (char-to-string desig))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
77 (syntax-designator-chars))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
78 (logand newcode (lognot 127))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
79 (if (consp code) (cons newcode (cdr code))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
80 newcode)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
81
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
82 (defun syntax-code-to-string (code)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
83 "Return a string equivalent to internal syntax code CODE.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
84 The string can be passed to `modify-syntax-entry'.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
85 If CODE is invalid, return nil."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
86 (let ((match (and (consp code) (cdr code)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
87 (codes (syntax-designator-chars)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
88 (if (consp code)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
89 (setq code (car code)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
90 (if (or (not (integerp code))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
91 (> (logand code 127) (length codes)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
92 nil
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
93 (with-output-to-string
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
94 (let* ((spec (elt codes (logand code 127)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
95 (b3 (lsh code -16))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
96 (start1 (/= 0 (logand b3 128))) ;logtest!
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
97 (start1b (/= 0 (logand b3 64)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
98 (start2 (/= 0 (logand b3 32)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
99 (start2b (/= 0 (logand b3 16)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
100 (end1 (/= 0 (logand b3 8)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
101 (end1b (/= 0 (logand b3 4)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
102 (end2 (/= 0 (logand b3 2)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
103 (end2b (/= 0 (logand b3 1)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
104 (prefix (/= 0 (logand code 128)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
105 (single-char-p (or (= spec ?<) (= spec ?>)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
106 )
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
107 (write-char spec)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
108 (write-char (if match match 32))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
109 ;;; (if start1 (if single-char-p (write-char ?a) (write-char ?1)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
110 (if start1 (if single-char-p (write-char ? ) (write-char ?1)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
111 (if start2 (write-char ?2))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
112 ;;; (if end1 (if single-char-p (write-char ?a) (write-char ?3)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
113 (if end1 (if single-char-p (write-char ? ) (write-char ?3)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
114 (if end2 (write-char ?4))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
115 (if start1b (if single-char-p (write-char ?b) (write-char ?5)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
116 (if start2b (write-char ?6))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
117 (if end1b (if single-char-p (write-char ?b) (write-char ?7)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
118 (if end2b (write-char ?8))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
119 (if prefix (write-char ?p)))))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
120
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
121 (defun syntax-string-to-code (string)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
122 "Return the internal syntax code equivalent to STRING.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
123 STRING should be something acceptable as the second argument to
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
124 `modify-syntax-entry'.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
125 If STRING is invalid, signal an error."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
126 (let* ((bflag nil)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
127 (b3 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
128 (ch0 (aref string 0))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
129 (len (length string))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
130 (code (string-match (regexp-quote (char-to-string ch0))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
131 (syntax-designator-chars)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
132 (i 2)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
133 ch)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
134 (or code
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
135 (error "Invalid syntax designator: %S" string))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
136 (while (< i len)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
137 (setq ch (aref string i))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
138 (incf i)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
139 (case ch
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
140 (?1 (setq b3 (logior b3 128)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
141 (?2 (setq b3 (logior b3 32)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
142 (?3 (setq b3 (logior b3 8)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
143 (?4 (setq b3 (logior b3 2)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
144 (?5 (setq b3 (logior b3 64)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
145 (?6 (setq b3 (logior b3 16)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
146 (?7 (setq b3 (logior b3 4)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
147 (?8 (setq b3 (logior b3 1)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
148 (?a (case ch0
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
149 (?< (setq b3 (logior b3 128)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
150 (?> (setq b3 (logior b3 8)))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
151 (?b (case ch0
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
152 (?< (setq b3 (logior b3 64) bflag t))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
153 (?> (setq b3 (logior b3 4) bflag t))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
154 (?p (setq code (logior code (lsh 1 7))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
155 (?\ nil) ;; ignore for compatibility
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
156 (otherwise
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
157 (error "Invalid syntax description flag: %S" string))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
158 ;; default single char style if `b' has not been seen
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
159 (if (not bflag)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
160 (case ch0
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
161 (?< (setq b3 (logior b3 128)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
162 (?> (setq b3 (logior b3 8)))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
163 (setq code (logior code (lsh b3 16)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
164 (if (and (> len 1)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
165 ;; tough luck if you want to make space a paren!
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
166 (/= (aref string 1) ?\ ))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
167 (setq code (cons code (aref string 1))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
168 code))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
169
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 428
diff changeset
170 (defun modify-syntax-entry (char-range spec &optional syntax-table)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
171 "Set syntax for the characters CHAR-RANGE according to string SPEC.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
172 CHAR-RANGE is a single character or a range of characters,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
173 as per `put-char-table'.
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 428
diff changeset
174 The syntax is changed only for SYNTAX-TABLE, which defaults to
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
175 the current buffer's syntax table.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
176 The first character of SPEC should be one of the following:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
177 Space whitespace syntax. w word constituent.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
178 _ symbol constituent. . punctuation.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
179 \( open-parenthesis. \) close-parenthesis.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
180 \" string quote. \\ character-quote.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
181 $ paired delimiter. ' expression quote or prefix operator.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
182 < comment starter. > comment ender.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
183 / character-quote. @ inherit from `standard-syntax-table'.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
184
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
185 Only single-character comment start and end sequences are represented thus.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
186 Two-character sequences are represented as described below.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
187 The second character of SPEC is the matching parenthesis,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
188 used only if the first character is `(' or `)'.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
189 Any additional characters are flags.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
190 Defined flags are the characters 1, 2, 3, 4, 5, 6, 7, 8, p, a, and b.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
191 1 means C is the first of a two-char comment start sequence of style a.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
192 2 means C is the second character of such a sequence.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
193 3 means C is the first of a two-char comment end sequence of style a.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
194 4 means C is the second character of such a sequence.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
195 5 means C is the first of a two-char comment start sequence of style b.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
196 6 means C is the second character of such a sequence.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
197 7 means C is the first of a two-char comment end sequence of style b.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
198 8 means C is the second character of such a sequence.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
199 p means C is a prefix character for `backward-prefix-chars';
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
200 such characters are treated as whitespace when they occur
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
201 between expressions.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
202 a means C is comment starter or comment ender for comment style a (default)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
203 b means C is comment starter or comment ender for comment style b."
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 428
diff changeset
204 (interactive
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
205 ;; I really don't know why this is interactive
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
206 ;; help-form should at least be made useful while reading the second arg
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
207 "cSet syntax for character: \nsSet syntax for %c to: ")
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 428
diff changeset
208 (simple-set-syntax-entry
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 428
diff changeset
209 char-range
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 428
diff changeset
210 (syntax-string-to-code spec)
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 428
diff changeset
211 (cond ((syntax-table-p syntax-table)
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 428
diff changeset
212 syntax-table)
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 428
diff changeset
213 ((null syntax-table)
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 428
diff changeset
214 (syntax-table))
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 428
diff changeset
215 (t
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 428
diff changeset
216 (wrong-type-argument 'syntax-table-p syntax-table))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
217 nil)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
218
4806
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
219 ((macro
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
220 . (lambda (map-syntax-definition)
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
221 "Replace the variable names in MAP-SYNTAX-DEFINITION with uninterned
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
222 symbols, at byte-compile time. This avoids the risk of variable names
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
223 within the functions called from MAP-SYNTAX-DEFINITION being shared with
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
224 MAP-SYNTAX-DEFINITION, and as such subject to modification, one of the
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
225 common downsides of dynamic scope."
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
226 (nsublis
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
227 '((syntax-table . #:syntax-table)
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
228 (m-s-function . #:function)
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
229 (range . #:range)
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
230 (key . #:key)
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
231 (value . #:value))
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
232 map-syntax-definition)))
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
233 (defun map-syntax-table (m-s-function syntax-table &optional range)
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
234 "Map FUNCTION over entries in SYNTAX-TABLE, collapsing inheritance.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
235 This is similar to `map-char-table', but works only on syntax tables, and
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
236 collapses any entries that call for inheritance by invisibly substituting
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
237 the inherited values from the standard syntax table."
4806
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
238 (check-argument-type 'syntax-table-p syntax-table)
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
239 (map-char-table #'(lambda (key value)
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
240 (if (eq ?@ (char-syntax-from-code value))
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
241 (map-char-table
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
242 #'(lambda (key value)
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
243 (funcall m-s-function key value))
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
244 (standard-syntax-table)
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
245 key)
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
246 (funcall m-s-function key value)))
fd36a980d701 Use uninterned symbols in various information-hiding contexts.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4468
diff changeset
247 syntax-table range)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
248
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
249 ;(defun test-xm ()
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
250 ; (let ((o (copy-syntax-table))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
251 ; (n (copy-syntax-table))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
252 ; (codes (syntax-designator-chars))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
253 ; (flags "12345678abp"))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
254 ; (while t
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
255 ; (let ((spec (concat (char-to-string (elt codes
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
256 ; (random (length codes))))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
257 ; (if (= (random 4) 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
258 ; "b"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
259 ; " ")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
260 ; (let* ((n (random 4))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
261 ; (s (make-string n 0)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
262 ; (while (> n 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
263 ; (setq n (1- n))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
264 ; (aset s n (aref flags (random (length flags)))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
265 ; s))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
266 ; (message "%S..." spec)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
267 ; (modify-syntax-entry ?a spec o)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
268 ; (xmodify-syntax-entry ?a spec n)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
269 ; (or (= (aref o ?a) (aref n ?a))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
270 ; (error "%s"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
271 ; (format "fucked with %S: %x %x"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
272 ; spec (aref o ?a) (aref n ?a))))))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
273
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
274
3067
2f31c7aa4e96 [xemacs-hg @ 2005-11-13 10:57:59 by ben]
ben
parents: 502
diff changeset
275 (defun describe-char-table (table mapper describe-value stream)
2f31c7aa4e96 [xemacs-hg @ 2005-11-13 10:57:59 by ben]
ben
parents: 502
diff changeset
276 "Describe char-table TABLE, outputting to STREAM.
2f31c7aa4e96 [xemacs-hg @ 2005-11-13 10:57:59 by ben]
ben
parents: 502
diff changeset
277 MAPPER maps over the table and should be `map-char-table' or
2f31c7aa4e96 [xemacs-hg @ 2005-11-13 10:57:59 by ben]
ben
parents: 502
diff changeset
278 `map-syntax-table'. DESCRIBE-VALUE is a function of two arguments,
2f31c7aa4e96 [xemacs-hg @ 2005-11-13 10:57:59 by ben]
ben
parents: 502
diff changeset
279 VALUE and STREAM, and should output a description of VALUE."
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
280 (let (first-char
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
281 last-char
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
282 prev-val
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
283 (describe-one
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
284 (if (featurep 'mule)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
285 #'(lambda (first last value stream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
286 (if (equal first last)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
287 (cond ((vectorp first)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
288 (princ (format "%s, row %d\t"
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 444
diff changeset
289 (declare-fboundp (charset-name
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 444
diff changeset
290 (aref first 0)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
291 (aref first 1))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
292 stream))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
293 ((symbolp first)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
294 (princ first stream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
295 (princ "\t" stream))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
296 (t
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
297 (princ (text-char-description first) stream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
298 (princ "\t" stream)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
299 (cond ((vectorp first)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
300 (princ (format "%s, rows %d .. %d\t"
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 444
diff changeset
301 (declare-fboundp (charset-name
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 444
diff changeset
302 (aref first 0)))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
303 (aref first 1)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
304 (aref last 1))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
305 stream))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
306 ((symbolp first)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
307 (princ (format "%s .. %s\t" first last) stream))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
308 (t
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
309 (princ (format "%s .. %s\t"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
310 (text-char-description first)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
311 (text-char-description last))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
312 stream))))
3067
2f31c7aa4e96 [xemacs-hg @ 2005-11-13 10:57:59 by ben]
ben
parents: 502
diff changeset
313 (funcall describe-value value stream))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
314 #'(lambda (first last value stream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
315 (let* ((tem (text-char-description first))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
316 (pos (length tem))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
317 ;;(limit (cond ((numberp ctl-arrow) ctl-arrow)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
318 ;; ((memq ctl-arrow '(t nil)) 256)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
319 ;; (t 160)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
320 )
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
321 (princ tem stream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
322 (if (> last first)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
323 (progn
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
324 (princ " .. " stream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
325 (setq tem (text-char-description last))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
326 (princ tem stream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
327 (setq pos (+ pos (length tem) 4))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
328 (while (progn (write-char ?\ stream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
329 (setq pos (1+ pos))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
330 (< pos 16))))
3067
2f31c7aa4e96 [xemacs-hg @ 2005-11-13 10:57:59 by ben]
ben
parents: 502
diff changeset
331 (funcall describe-value value stream)))))
2f31c7aa4e96 [xemacs-hg @ 2005-11-13 10:57:59 by ben]
ben
parents: 502
diff changeset
332 (funcall mapper
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
333 #'(lambda (range value)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
334 (cond
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
335 ((not first-char)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
336 (setq first-char range
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
337 last-char range
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
338 prev-val value))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
339 ((and (equal value prev-val)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
340 (or
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
341 (and (characterp range)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
342 (characterp first-char)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
343 (or (not (featurep 'mule))
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 444
diff changeset
344 (eq (declare-fboundp (char-charset range))
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 444
diff changeset
345 (declare-fboundp (char-charset first-char))))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
346 (= (char-int last-char) (1- (char-int range))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
347 (and (vectorp range)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
348 (vectorp first-char)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
349 (eq (aref range 0) (aref first-char 0))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
350 (= (aref last-char 1) (1- (aref range 1))))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
351 (setq last-char range))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
352 (t
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
353 (funcall describe-one first-char last-char prev-val stream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
354 (setq first-char range
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
355 last-char range
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
356 prev-val value)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
357 nil)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
358 table)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
359 (if first-char
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
360 (funcall describe-one first-char last-char prev-val stream))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
361
3067
2f31c7aa4e96 [xemacs-hg @ 2005-11-13 10:57:59 by ben]
ben
parents: 502
diff changeset
362 (defun describe-syntax-table (table stream)
2f31c7aa4e96 [xemacs-hg @ 2005-11-13 10:57:59 by ben]
ben
parents: 502
diff changeset
363 "Output a description of TABLE (a syntax table) to STREAM."
2f31c7aa4e96 [xemacs-hg @ 2005-11-13 10:57:59 by ben]
ben
parents: 502
diff changeset
364 (describe-char-table table 'map-syntax-table 'describe-syntax-code stream))
2f31c7aa4e96 [xemacs-hg @ 2005-11-13 10:57:59 by ben]
ben
parents: 502
diff changeset
365
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
366 (defun describe-syntax-code (code stream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
367 (let ((match (and (consp code) (cdr code)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
368 (invalid (gettext "**invalid**")) ;(empty "") ;constants
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
369 (standard-output (or stream standard-output))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
370 ;; #### I18N3 should temporarily set buffer to output-translatable
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
371 (in #'(lambda (string)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
372 (princ ",\n\t\t\t\t ")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
373 (princ string)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
374 (syntax-string (syntax-code-to-string code)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
375 (if (consp code)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
376 (setq code (car code)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
377 (if (null syntax-string)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
378 (princ invalid)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
379 (princ syntax-string)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
380 (princ "\tmeaning: ")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
381 (princ (aref ["whitespace" "punctuation" "word-constituent"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
382 "symbol-constituent" "open-paren" "close-paren"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
383 "expression-prefix" "string-quote" "paired-delimiter"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
384 "escape" "character-quote" "comment-begin" "comment-end"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
385 "inherit" "extended-word-constituent"]
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
386 (logand code 127)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
387
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
388 (if match
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
389 (progn
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
390 (princ ", matches ")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
391 (princ (text-char-description match))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
392 (let* ((spec (elt syntax-string 0))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
393 (b3 (lsh code -16))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
394 (start1 (/= 0 (logand b3 128))) ;logtest!
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
395 (start1b (/= 0 (logand b3 64)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
396 (start2 (/= 0 (logand b3 32)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
397 (start2b (/= 0 (logand b3 16)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
398 (end1 (/= 0 (logand b3 8)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
399 (end1b (/= 0 (logand b3 4)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
400 (end2 (/= 0 (logand b3 2)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
401 (end2b (/= 0 (logand b3 1)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
402 (prefix (/= 0 (logand code 128)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
403 (single-char-p (or (= spec ?<) (= spec ?>))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
404 (if start1
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
405 (if single-char-p
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
406 (princ ", style A")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
407 (funcall in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
408 (gettext "first character of comment-start sequence A"))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
409 (if start2
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
410 (funcall in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
411 (gettext "second character of comment-start sequence A")))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
412 (if end1
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
413 (if single-char-p
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
414 (princ ", style A")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
415 (funcall in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
416 (gettext "first character of comment-end sequence A"))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
417 (if end2
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
418 (funcall in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
419 (gettext "second character of comment-end sequence A")))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
420 (if start1b
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
421 (if single-char-p
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
422 (princ ", style B")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
423 (funcall in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
424 (gettext "first character of comment-start sequence B"))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
425 (if start2b
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
426 (funcall in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
427 (gettext "second character of comment-start sequence B")))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
428 (if end1b
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
429 (if single-char-p
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
430 (princ ", style B")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
431 (funcall in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
432 (gettext "first character of comment-end sequence B"))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
433 (if end2b
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
434 (funcall in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
435 (gettext "second character of comment-end sequence B")))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
436 (if prefix
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
437 (funcall in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
438 (gettext "prefix character for `backward-prefix-chars'"))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
439 (terpri stream))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
440
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
441 (defun symbol-near-point ()
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
442 "Return the first textual item to the nearest point."
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
443 (interactive)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
444 ;alg stolen from etag.el
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
445 (save-excursion
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
446 (if (or (bobp) (not (memq (char-syntax (char-before)) '(?w ?_))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
447 (while (not (looking-at "\\sw\\|\\s_\\|\\'"))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
448 (forward-char 1)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
449 (while (looking-at "\\sw\\|\\s_")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
450 (forward-char 1))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
451 (if (re-search-backward "\\sw\\|\\s_" nil t)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
452 (regexp-quote
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
453 (progn (forward-char 1)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
454 (buffer-substring (point)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
455 (progn (forward-sexp -1)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
456 (while (looking-at "\\s'")
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
457 (forward-char 1))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
458 (point)))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
459 nil)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
460
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
461 ;;; syntax.el ends here