mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2024-11-27 07:37:33 +00:00
* lisp/case-table.el (case-table-get-table): New function.
* lisp/case-table.el: Use lexical-binding. (case-table-get-table): New function. (get-upcase-table): Use it. Mark as obsolete. Adjust callers. * src/casetab.c (init_casetab_once): Don't abuse the ascii eqv table for the upcase table.
This commit is contained in:
parent
002668e109
commit
f557c1b1a9
2
etc/NEWS
2
etc/NEWS
@ -302,6 +302,8 @@ file using `set-file-extended-attributes'.
|
||||
|
||||
** `dont-compile' is declared obsolete.
|
||||
|
||||
** `get-upcase-table' is obsoleted by the new `case-table-get-table'.
|
||||
|
||||
** Support for filesystem notifications.
|
||||
Emacs now supports notifications of filesystem changes, such as
|
||||
creation, modification, and deletion of files. This requires the
|
||||
|
@ -1,3 +1,12 @@
|
||||
2013-03-27 Stefan Monnier <monnier@iro.umontreal.ca>
|
||||
|
||||
* case-table.el: Use lexical-binding.
|
||||
(case-table-get-table): New function.
|
||||
(get-upcase-table): Use it. Mark as obsolete. Adjust callers.
|
||||
|
||||
* minibuffer.el (completion-pcm--merge-completions): Make sure prefixes
|
||||
and suffixes don't overlap
|
||||
|
||||
2013-03-27 Teodor Zlatanov <tzz@lifelogs.com>
|
||||
|
||||
* progmodes/subword.el: Add `superword-mode' to do word motion
|
||||
|
@ -1,4 +1,4 @@
|
||||
;;; case-table.el --- code to extend the character set and support case tables
|
||||
;;; case-table.el --- code to extend the character set and support case tables -*- lexical-binding: t -*-
|
||||
|
||||
;; Copyright (C) 1988, 1994, 2001-2013 Free Software Foundation, Inc.
|
||||
|
||||
@ -65,18 +65,26 @@
|
||||
(describe-vector description)
|
||||
(help-mode)))))
|
||||
|
||||
(defun case-table-get-table (case-table table)
|
||||
"Return the TABLE of CASE-TABLE.
|
||||
TABLE can be `down', `up', `eqv' or `canon'."
|
||||
(let ((slot-nb (cdr (assq table '((up . 0) (canon . 1) (eqv . 2))))))
|
||||
(or (if (eq table 'down) case-table)
|
||||
(char-table-extra-slot case-table slot-nb)
|
||||
;; Setup all extra slots of CASE-TABLE by temporarily selecting
|
||||
;; it as the standard case table.
|
||||
(let ((old (standard-case-table)))
|
||||
(unwind-protect
|
||||
(progn
|
||||
(set-standard-case-table case-table)
|
||||
(char-table-extra-slot case-table slot-nb))
|
||||
(or (eq case-table old)
|
||||
(set-standard-case-table old)))))))
|
||||
|
||||
(defun get-upcase-table (case-table)
|
||||
"Return the upcase table of CASE-TABLE."
|
||||
(or (char-table-extra-slot case-table 0)
|
||||
;; Setup all extra slots of CASE-TABLE by temporarily selecting
|
||||
;; it as the standard case table.
|
||||
(let ((old (standard-case-table)))
|
||||
(unwind-protect
|
||||
(progn
|
||||
(set-standard-case-table case-table)
|
||||
(char-table-extra-slot case-table 0))
|
||||
(or (eq case-table old)
|
||||
(set-standard-case-table old))))))
|
||||
(case-table-get-table case-table 'up))
|
||||
(make-obsolete 'get-upcase-table 'case-table-get-table "24.4")
|
||||
|
||||
(defun copy-case-table (case-table)
|
||||
(let ((copy (copy-sequence case-table))
|
||||
@ -97,7 +105,7 @@ It also modifies `standard-syntax-table' to
|
||||
indicate left and right delimiters."
|
||||
(aset table l l)
|
||||
(aset table r r)
|
||||
(let ((up (get-upcase-table table)))
|
||||
(let ((up (case-table-get-table table 'up)))
|
||||
(aset up l l)
|
||||
(aset up r r))
|
||||
;; Clear out the extra slots so that they will be
|
||||
@ -117,7 +125,7 @@ It also modifies `standard-syntax-table' to give them the syntax of
|
||||
word constituents."
|
||||
(aset table uc lc)
|
||||
(aset table lc lc)
|
||||
(let ((up (get-upcase-table table)))
|
||||
(let ((up (case-table-get-table table 'up)))
|
||||
(aset up uc uc)
|
||||
(aset up lc uc))
|
||||
;; Clear out the extra slots so that they will be
|
||||
@ -132,7 +140,7 @@ word constituents."
|
||||
It also modifies `standard-syntax-table' to give them the syntax of
|
||||
word constituents."
|
||||
(aset table lc lc)
|
||||
(let ((up (get-upcase-table table)))
|
||||
(let ((up (case-table-get-table table 'up)))
|
||||
(aset up uc uc)
|
||||
(aset up lc uc))
|
||||
;; Clear out the extra slots so that they will be
|
||||
@ -148,7 +156,7 @@ It also modifies `standard-syntax-table' to give them the syntax of
|
||||
word constituents."
|
||||
(aset table uc lc)
|
||||
(aset table lc lc)
|
||||
(let ((up (get-upcase-table table)))
|
||||
(let ((up (case-table-get-table table 'up)))
|
||||
(aset up uc uc))
|
||||
;; Clear out the extra slots so that they will be
|
||||
;; recomputed from the main (downcase) table and upcase table.
|
||||
@ -164,7 +172,7 @@ that will be used as the downcase part of a case table.
|
||||
It also modifies `standard-syntax-table'.
|
||||
SYNTAX should be \" \", \"w\", \".\" or \"_\"."
|
||||
(aset table c c)
|
||||
(let ((up (get-upcase-table table)))
|
||||
(let ((up (case-table-get-table table 'up)))
|
||||
(aset up c c))
|
||||
;; Clear out the extra slots so that they will be
|
||||
;; recomputed from the main (downcase) table and upcase table.
|
||||
|
@ -1,3 +1,8 @@
|
||||
2013-03-27 Stefan Monnier <monnier@iro.umontreal.ca>
|
||||
|
||||
* casetab.c (init_casetab_once): Don't abuse the ascii eqv table for
|
||||
the upcase table.
|
||||
|
||||
2013-03-27 rzl24ozi <rzl24ozi@gmail.com> (tiny changes)
|
||||
|
||||
* image.c [WINDOWSNT]: Fix calls to DEF_IMGLIB_FN for SVG function.
|
||||
|
@ -246,7 +246,7 @@ void
|
||||
init_casetab_once (void)
|
||||
{
|
||||
register int i;
|
||||
Lisp_Object down, up;
|
||||
Lisp_Object down, up, eqv;
|
||||
DEFSYM (Qcase_table, "case-table");
|
||||
|
||||
/* Intern this now in case it isn't already done.
|
||||
@ -275,13 +275,21 @@ init_casetab_once (void)
|
||||
|
||||
for (i = 0; i < 128; i++)
|
||||
{
|
||||
int c = (i >= 'a' && i <= 'z') ? i + ('A' - 'a') : i;
|
||||
CHAR_TABLE_SET (up, i, make_number (c));
|
||||
}
|
||||
|
||||
eqv = Fmake_char_table (Qcase_table, Qnil);
|
||||
|
||||
for (i = 0; i < 128; i++)
|
||||
{
|
||||
int c = ((i >= 'A' && i <= 'Z') ? i + ('a' - 'A')
|
||||
: ((i >= 'a' && i <= 'z') ? i + ('A' - 'a')
|
||||
: i));
|
||||
CHAR_TABLE_SET (up, i, make_number (c));
|
||||
}
|
||||
|
||||
set_char_table_extras (down, 2, Fcopy_sequence (up));
|
||||
set_char_table_extras (down, 2, eqv);
|
||||
|
||||
/* Fill in what isn't filled in. */
|
||||
set_case_table (down, 1);
|
||||
|
Loading…
Reference in New Issue
Block a user