X-Git-Url: http://git.chise.org/gitweb/?a=blobdiff_plain;f=src%2Fchar-ucs.h;h=afbda533bd34448760adb7568f1cb59207f259f3;hb=e8399be9819462e4a72526af6eaa9b4ec5d3127d;hp=abfb6f8693be2f789ee22bc2702d8e00e0691a66;hpb=cb73cc7f011b2a258697b9a5f370aaa5c3c4e235;p=chise%2Fxemacs-chise.git- diff --git a/src/char-ucs.h b/src/char-ucs.h index abfb6f8..afbda53 100644 --- a/src/char-ucs.h +++ b/src/char-ucs.h @@ -29,15 +29,23 @@ Boston, MA 02111-1307, USA. */ #define CHAR_ASCII_P(ch) ((ch) <= 0x7F) -typedef struct +DECLARE_LRECORD (char_byte_table, struct Lisp_Char_Byte_Table); +#define XCHAR_BYTE_TABLE(x) \ + XRECORD (x, char_byte_table, struct Lisp_Char_Byte_Table) +#define XSETCHAR_BYTE_TABLE(x, p) XSETRECORD (x, p, char_byte_table) +#define CHAR_BYTE_TABLE_P(x) RECORDP (x, char_byte_table) +#define GC_CHAR_BYTE_TABLE_P(x) GC_RECORDP (x, char_byte_table) +/* #define CHECK_CHAR_BYTE_TABLE(x) CHECK_RECORD (x, char_byte_table) + char table entries should never escape to Lisp */ + +struct Lisp_Char_Byte_Table { - unsigned char *base; - size_t offset; - size_t size; -} Emchar_to_byte_table; + struct lcrecord_header header; + + Lisp_Object property[256]; +}; -unsigned char -get_byte_from_character_table (Emchar ch, Emchar_to_byte_table* table); +Lisp_Object get_char_code_table (Emchar ch, Lisp_Object table); extern Lisp_Object Vcharset_ucs_bmp; @@ -221,8 +229,7 @@ struct Lisp_Charset Lisp_Object decoding_table; /* Character->byte mapping table */ - Emchar_to_byte_table* to_byte1_table; - Emchar_to_byte_table* to_byte2_table; + Lisp_Object encoding_table; /* Range of character code */ Emchar ucs_min, ucs_max; @@ -270,8 +277,7 @@ DECLARE_LRECORD (charset, struct Lisp_Charset); #define CHARSET_CHARS(cs) ((cs)->chars) #define CHARSET_REVERSE_DIRECTION_CHARSET(cs) ((cs)->reverse_direction_charset) #define CHARSET_DECODING_TABLE(cs) ((cs)->decoding_table) -#define CHARSET_TO_BYTE1_TABLE(cs) ((cs)->to_byte1_table) -#define CHARSET_TO_BYTE2_TABLE(cs) ((cs)->to_byte2_table) +#define CHARSET_ENCODING_TABLE(cs) ((cs)->encoding_table) #define CHARSET_UCS_MIN(cs) ((cs)->ucs_min) #define CHARSET_UCS_MAX(cs) ((cs)->ucs_max) #define CHARSET_CODE_OFFSET(cs) ((cs)->code_offset) @@ -295,8 +301,7 @@ DECLARE_LRECORD (charset, struct Lisp_Charset); #define XCHARSET_REVERSE_DIRECTION_CHARSET(cs) \ CHARSET_REVERSE_DIRECTION_CHARSET (XCHARSET (cs)) #define XCHARSET_DECODING_TABLE(cs) CHARSET_DECODING_TABLE(XCHARSET(cs)) -#define XCHARSET_TO_BYTE1_TABLE(cs) CHARSET_TO_BYTE1_TABLE(XCHARSET(cs)) -#define XCHARSET_TO_BYTE2_TABLE(cs) CHARSET_TO_BYTE2_TABLE(XCHARSET(cs)) +#define XCHARSET_ENCODING_TABLE(cs) CHARSET_ENCODING_TABLE(XCHARSET(cs)) #define XCHARSET_UCS_MIN(cs) CHARSET_UCS_MIN(XCHARSET(cs)) #define XCHARSET_UCS_MAX(cs) CHARSET_UCS_MAX(XCHARSET(cs)) #define XCHARSET_CODE_OFFSET(cs) CHARSET_CODE_OFFSET(XCHARSET(cs)) @@ -359,6 +364,9 @@ CHARSET_BY_LEADING_BYTE (Charset_ID lb) #define MIN_CHAR_HALFWIDTH_KATAKANA 0xFF61 #define MAX_CHAR_HALFWIDTH_KATAKANA 0xFF9F +#define MIN_CHAR_OBS_94x94 0xE00000 +#define MAX_CHAR_OBS_94x94 (0xE00000 + 94 * 94 * 14 - 1) + #define MIN_CHAR_94 0xE90940 #define MAX_CHAR_94 (MIN_CHAR_94 + 94 * 80 - 1) #define MIN_CHAR_96 (MIN_CHAR_94 + 94 * 80) @@ -461,7 +469,7 @@ INLINE void breakup_char_1 (Emchar c, Lisp_Object *charset, int *c1, int *c2); INLINE void breakup_char_1 (Emchar c, Lisp_Object *charset, int *c1, int *c2) { - if (c < MIN_CHAR_94) + if (c < MIN_CHAR_OBS_94x94) { Lisp_Object charsets = Vdefault_coded_charset_priority_list; while (!EQ (charsets, Qnil)) @@ -532,6 +540,15 @@ breakup_char_1 (Emchar c, Lisp_Object *charset, int *c1, int *c2) *c2 = c & 0xff; } } + else if (c <= MAX_CHAR_OBS_94x94) + { + *charset + = CHARSET_BY_ATTRIBUTES (CHARSET_TYPE_94X94, + ((c - MIN_CHAR_OBS_94x94) / (94 * 94)) + '@', + CHARSET_LEFT_TO_RIGHT); + *c1 = (((c - MIN_CHAR_OBS_94x94) / 94) % 94) + 33; + *c2 = ((c - MIN_CHAR_OBS_94x94) % 94) + 33; + } else if (c <= MAX_CHAR_94) { *charset