summaryrefslogtreecommitdiff
path: root/lisp/case-table.el
diff options
context:
space:
mode:
authorRichard M. Stallman <rms@gnu.org>1993-03-27 06:29:16 +0000
committerRichard M. Stallman <rms@gnu.org>1993-03-27 06:29:16 +0000
commit8db3f421f42d7a6f58bb2f453faf8b7e8e1dd9e8 (patch)
tree3f42fb1df79bbd4215003f32989f1e594179670a /lisp/case-table.el
parent3f5ed7e4374378921328093c7625720f74ea5351 (diff)
downloademacs-8db3f421f42d7a6f58bb2f453faf8b7e8e1dd9e8.tar.gz
(set-case-syntax-delims, set-case-syntax-pair, set-case-syntax):
Do not set the standard case table. Reintroduce arg (now named TABLE) which gives a downcase string to set.
Diffstat (limited to 'lisp/case-table.el')
-rw-r--r--lisp/case-table.el40
1 files changed, 14 insertions, 26 deletions
diff --git a/lisp/case-table.el b/lisp/case-table.el
index f355f0da0cb..ad6fbfa3963 100644
--- a/lisp/case-table.el
+++ b/lisp/case-table.el
@@ -54,17 +54,14 @@
(describe-vector vector))))
;;;###autoload
-(defun set-case-syntax-delims (l r)
+(defun set-case-syntax-delims (l r table)
"Make characters L and R a matching pair of non-case-converting delimiters.
-This sets the entries for L and R in the standard case table.
+This sets the entries for L and R in TABLE, which is a string
+that will be used as the downcase part of a case table.
It also modifies `standard-syntax-table', and `text-mode-syntax-table' to
indicate left and right delimiters."
- (aset (car (cdr (standard-case-table))) l l)
- (aset (car (cdr (standard-case-table))) r r)
- ;; Recompute the equivalence and canonicalize tables.
- (set-standard-case-table (list (car (standard-case-table))
- (nth 1 (standard-case-table))
- nil nil))
+ (aset table l l)
+ (aset table r r)
(modify-syntax-entry l (concat "(" (char-to-string r) " ")
(standard-syntax-table))
(modify-syntax-entry l (concat "(" (char-to-string r) " ")
@@ -75,36 +72,27 @@ indicate left and right delimiters."
text-mode-syntax-table))
;;;###autoload
-(defun set-case-syntax-pair (uc lc)
+(defun set-case-syntax-pair (uc lc table)
"Make characters UC and LC a pair of inter-case-converting letters.
-This sets the entries for characters UC and LC in the standard case table.
+This sets the entries for characters UC and LC in TABLE, which is a string
+that will be used as the downcase part of a case table.
It also modifies `standard-syntax-table' and `text-mode-syntax-table'
to indicate an (uppercase, lowercase) pair of letters."
- (aset (car (cdr (standard-case-table))) lc uc)
- (aset (car (cdr (standard-case-table))) uc uc)
- (aset (car (standard-case-table)) uc lc)
- (aset (car (standard-case-table)) lc lc)
- ;; Recompute the equivalence and canonicalize tables.
- (set-standard-case-table (list (car (standard-case-table))
- (nth 1 (standard-case-table))
- nil nil))
+ (aset table uc lc)
+ (aset table lc lc)
(modify-syntax-entry lc "w " (standard-syntax-table))
(modify-syntax-entry lc "w " text-mode-syntax-table)
(modify-syntax-entry uc "w " (standard-syntax-table))
(modify-syntax-entry uc "w " text-mode-syntax-table))
;;;###autoload
-(defun set-case-syntax (c syntax)
+(defun set-case-syntax (c syntax table)
"Make characters C case-invariant with syntax SYNTAX.
-This sets the entries for character C in the standard case table.
+This sets the entries for character C in TABLE, which is a string
+that will be used as the downcase part of a case table.
It also modifies `standard-syntax-table' and `text-mode-syntax-table'.
SYNTAX should be \" \", \"w\", \".\" or \"_\"."
- (aset (car (cdr (standard-case-table))) c c)
- (aset (car (standard-case-table)) c c)
- ;; Recompute the equivalence and canonicalize tables.
- (set-standard-case-table (list (car (standard-case-table))
- (nth 1 (standard-case-table))
- nil nil))
+ (aset table c c)
(modify-syntax-entry c syntax (standard-syntax-table))
(modify-syntax-entry c syntax text-mode-syntax-table))