changeset 2386:ded35864afbe

(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.
author Richard M. Stallman <rms@gnu.org>
date Sat, 27 Mar 1993 06:29:16 +0000
parents 416abb820252
children cb44857cab89
files lisp/case-table.el
diffstat 1 files changed, 14 insertions(+), 26 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/case-table.el	Sat Mar 27 06:19:51 1993 +0000
+++ b/lisp/case-table.el	Sat Mar 27 06:29:16 1993 +0000
@@ -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 @@
 		       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))