diff options
author | Kenichi Handa <handa@m17n.org> | 2003-09-08 12:53:41 +0000 |
---|---|---|
committer | Kenichi Handa <handa@m17n.org> | 2003-09-08 12:53:41 +0000 |
commit | 8f924df7df019cce90537647de2627581043b5c4 (patch) | |
tree | 6c40bd05679425e710d6b2e5649eae3da5e40a52 /src/casetab.c | |
parent | 463f5630a5e7cbe7f042bc1175d1fa1c4e98860f (diff) | |
parent | 9d4807432a01f9b3cc519fcfa3ea92a70ffa7f43 (diff) | |
download | emacs-8f924df7df019cce90537647de2627581043b5c4.tar.gz |
*** empty log message ***
Diffstat (limited to 'src/casetab.c')
-rw-r--r-- | src/casetab.c | 87 |
1 files changed, 59 insertions, 28 deletions
diff --git a/src/casetab.c b/src/casetab.c index 9f9c4f8c5b2..64b0b4cbb29 100644 --- a/src/casetab.c +++ b/src/casetab.c @@ -23,7 +23,7 @@ Boston, MA 02111-1307, USA. */ #include <config.h> #include "lisp.h" #include "buffer.h" -#include "charset.h" +#include "character.h" Lisp_Object Qcase_table_p, Qcase_table; Lisp_Object Vascii_downcase_table, Vascii_upcase_table; @@ -138,8 +138,8 @@ set_case_table (table, standard) if (NILP (up)) { up = Fmake_char_table (Qcase_table, Qnil); - map_char_table (set_identity, Qnil, table, table, up, 0, indices); - map_char_table (shuffle, Qnil, table, table, up, 0, indices); + map_char_table (set_identity, Qnil, table, up); + map_char_table (shuffle, Qnil, table, up); XCHAR_TABLE (table)->extras[0] = up; } @@ -147,14 +147,14 @@ set_case_table (table, standard) { canon = Fmake_char_table (Qcase_table, Qnil); XCHAR_TABLE (table)->extras[1] = canon; - map_char_table (set_canon, Qnil, table, table, table, 0, indices); + map_char_table (set_canon, Qnil, table, table); } if (NILP (eqv)) { eqv = Fmake_char_table (Qcase_table, Qnil); - map_char_table (set_identity, Qnil, canon, canon, eqv, 0, indices); - map_char_table (shuffle, Qnil, canon, canon, eqv, 0, indices); + map_char_table (set_identity, Qnil, canon, eqv); + map_char_table (shuffle, Qnil, canon, eqv); XCHAR_TABLE (table)->extras[2] = eqv; } @@ -176,30 +176,45 @@ set_case_table (table, standard) /* The following functions are called in map_char_table. */ -/* Set CANON char-table element for C to a translated ELT by UP and - DOWN char-tables. This is done only when ELT is a character. The - char-tables CANON, UP, and DOWN are in CASE_TABLE. */ +/* Set CANON char-table element for characters in RANGE to a + translated ELT by UP and DOWN char-tables. This is done only when + ELT is a character. The char-tables CANON, UP, and DOWN are in + CASE_TABLE. */ static void -set_canon (case_table, c, elt) - Lisp_Object case_table, c, elt; +set_canon (case_table, range, elt) + Lisp_Object case_table, range, elt; { Lisp_Object up = XCHAR_TABLE (case_table)->extras[0]; Lisp_Object canon = XCHAR_TABLE (case_table)->extras[1]; if (NATNUMP (elt)) - Faset (canon, c, Faref (case_table, Faref (up, elt))); + Fset_char_table_range (canon, range, Faref (case_table, Faref (up, elt))); } -/* Set elements of char-table TABLE for C to C itself. This is done - only when ELT is a character. This is called in map_char_table. */ +/* Set elements of char-table TABLE for C to C itself. C may be a + cons specifying a character range. In that case, set characters in + that range to themselves. This is done only when ELT is a + character. This is called in map_char_table. */ static void set_identity (table, c, elt) Lisp_Object table, c, elt; { if (NATNUMP (elt)) - Faset (table, c, c); + { + int from, to; + + if (CONSP (c)) + { + from = XINT (XCAR (c)); + to = XINT (XCDR (c)); + } + else + from = to = XINT (c); + for (; from <= to; from++) + CHAR_TABLE_SET (table, from, make_number (from)); + } } /* Permute the elements of TABLE (which is initially an identity @@ -211,11 +226,25 @@ static void shuffle (table, c, elt) Lisp_Object table, c, elt; { - if (NATNUMP (elt) && !EQ (c, elt)) + if (NATNUMP (elt)) { Lisp_Object tem = Faref (table, elt); - Faset (table, elt, c); - Faset (table, c, tem); + int from, to; + + if (CONSP (c)) + { + from = XINT (XCAR (c)); + to = XINT (XCDR (c)); + } + else + from = to = XINT (c); + + for (; from <= to; from++) + if (from != XINT (elt)) + { + Faset (table, elt, make_number (from)); + Faset (table, make_number (from), tem); + } } } @@ -240,22 +269,24 @@ init_casetab_once () Vascii_downcase_table = down; XCHAR_TABLE (down)->purpose = Qcase_table; - for (i = 0; i < CHAR_TABLE_SINGLE_BYTE_SLOTS; i++) - XSETFASTINT (XCHAR_TABLE (down)->contents[i], - (i >= 'A' && i <= 'Z') ? i + ('a' - 'A') : i); + for (i = 0; i < 128; i++) + { + int c = (i >= 'A' && i <= 'Z') ? i + ('a' - 'A') : i; + CHAR_TABLE_SET (down, i, make_number (c)); + } XCHAR_TABLE (down)->extras[1] = Fcopy_sequence (down); up = Fmake_char_table (Qcase_table, Qnil); XCHAR_TABLE (down)->extras[0] = up; - for (i = 0; i < CHAR_TABLE_SINGLE_BYTE_SLOTS; i++) - XSETFASTINT (XCHAR_TABLE (up)->contents[i], - ((i >= 'A' && i <= 'Z') - ? i + ('a' - 'A') - : ((i >= 'a' && i <= 'z') - ? i + ('A' - 'a') - : i))); + 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)); + } XCHAR_TABLE (down)->extras[2] = Fcopy_sequence (up); } |