Mercurial > emacs
comparison src/category.c @ 109423:ae5ef13849d8
Merge from mainline.
author | Katsumi Yamaoka <yamaoka@jpl.org> |
---|---|
date | Sun, 04 Jul 2010 22:11:22 +0000 |
parents | aec1143e8d85 |
children | 8cfee7d2955f |
comparison
equal
deleted
inserted
replaced
109422:bcedeeedc5fb | 109423:ae5ef13849d8 |
---|---|
57 Lisp_Object _temp_category_set; | 57 Lisp_Object _temp_category_set; |
58 | 58 |
59 | 59 |
60 /* Category set staff. */ | 60 /* Category set staff. */ |
61 | 61 |
62 static Lisp_Object hash_get_category_set P_ ((Lisp_Object, Lisp_Object)); | 62 static Lisp_Object hash_get_category_set (Lisp_Object, Lisp_Object); |
63 | 63 |
64 static Lisp_Object | 64 static Lisp_Object |
65 hash_get_category_set (table, category_set) | 65 hash_get_category_set (Lisp_Object table, Lisp_Object category_set) |
66 Lisp_Object table, category_set; | |
67 { | 66 { |
68 Lisp_Object val; | 67 Lisp_Object val; |
69 struct Lisp_Hash_Table *h; | 68 struct Lisp_Hash_Table *h; |
70 int i; | 69 int i; |
71 unsigned hash; | 70 unsigned hash; |
115 } | 114 } |
116 | 115 |
117 | 116 |
118 /* Category staff. */ | 117 /* Category staff. */ |
119 | 118 |
120 Lisp_Object check_category_table (); | 119 Lisp_Object check_category_table (Lisp_Object table); |
121 | 120 |
122 DEFUN ("define-category", Fdefine_category, Sdefine_category, 2, 3, 0, | 121 DEFUN ("define-category", Fdefine_category, Sdefine_category, 2, 3, 0, |
123 doc: /* Define CATEGORY as a category which is described by DOCSTRING. | 122 doc: /* Define CATEGORY as a category which is described by DOCSTRING. |
124 CATEGORY should be an ASCII printing character in the range ` ' to `~'. | 123 CATEGORY should be an ASCII printing character in the range ` ' to `~'. |
125 DOCSTRING is the documentation string of the category. The first line | 124 DOCSTRING is the documentation string of the category. The first line |
194 not nil, check the validity of TABLE as a category table. If | 193 not nil, check the validity of TABLE as a category table. If |
195 valid, return TABLE itself, but if not valid, signal an error of | 194 valid, return TABLE itself, but if not valid, signal an error of |
196 wrong-type-argument. */ | 195 wrong-type-argument. */ |
197 | 196 |
198 Lisp_Object | 197 Lisp_Object |
199 check_category_table (table) | 198 check_category_table (Lisp_Object table) |
200 Lisp_Object table; | |
201 { | 199 { |
202 if (NILP (table)) | 200 if (NILP (table)) |
203 return current_buffer->category_table; | 201 return current_buffer->category_table; |
204 CHECK_TYPE (!NILP (Fcategory_table_p (table)), Qcategory_table_p, table); | 202 CHECK_TYPE (!NILP (Fcategory_table_p (table)), Qcategory_table_p, table); |
205 return table; | 203 return table; |
222 return Vstandard_category_table; | 220 return Vstandard_category_table; |
223 } | 221 } |
224 | 222 |
225 | 223 |
226 static void | 224 static void |
227 copy_category_entry (table, c, val) | 225 copy_category_entry (Lisp_Object table, Lisp_Object c, Lisp_Object val) |
228 Lisp_Object table, c, val; | |
229 { | 226 { |
230 val = Fcopy_sequence (val); | 227 val = Fcopy_sequence (val); |
231 if (CONSP (c)) | 228 if (CONSP (c)) |
232 char_table_set_range (table, XINT (XCAR (c)), XINT (XCDR (c)), val); | 229 char_table_set_range (table, XINT (XCAR (c)), XINT (XCDR (c)), val); |
233 else | 230 else |
238 function copy-sequence because no contents should be shared between | 235 function copy-sequence because no contents should be shared between |
239 the original and the copy. This function is called recursively by | 236 the original and the copy. This function is called recursively by |
240 binding TABLE to a sub char table. */ | 237 binding TABLE to a sub char table. */ |
241 | 238 |
242 Lisp_Object | 239 Lisp_Object |
243 copy_category_table (table) | 240 copy_category_table (Lisp_Object table) |
244 Lisp_Object table; | |
245 { | 241 { |
246 table = copy_char_table (table); | 242 table = copy_char_table (table); |
247 | 243 |
248 if (! NILP (XCHAR_TABLE (table)->defalt)) | 244 if (! NILP (XCHAR_TABLE (table)->defalt)) |
249 XCHAR_TABLE (table)->defalt | 245 XCHAR_TABLE (table)->defalt |
302 return table; | 298 return table; |
303 } | 299 } |
304 | 300 |
305 | 301 |
306 Lisp_Object | 302 Lisp_Object |
307 char_category_set (c) | 303 char_category_set (int c) |
308 int c; | |
309 { | 304 { |
310 return CHAR_TABLE_REF (current_buffer->category_table, c); | 305 return CHAR_TABLE_REF (current_buffer->category_table, c); |
311 } | 306 } |
312 | 307 |
313 DEFUN ("char-category-set", Fchar_category_set, Schar_category_set, 1, 1, 0, | 308 DEFUN ("char-category-set", Fchar_category_set, Schar_category_set, 1, 1, 0, |
342 | 337 |
343 return build_string (str); | 338 return build_string (str); |
344 } | 339 } |
345 | 340 |
346 void | 341 void |
347 set_category_set (category_set, category, val) | 342 set_category_set (Lisp_Object category_set, Lisp_Object category, Lisp_Object val) |
348 Lisp_Object category_set, category, val; | |
349 { | 343 { |
350 do { | 344 do { |
351 int idx = XINT (category) / 8; | 345 int idx = XINT (category) / 8; |
352 unsigned char bits = 1 << (XINT (category) % 8); | 346 unsigned char bits = 1 << (XINT (category) % 8); |
353 | 347 |
418 characters C1 and C2 if they appear in this order, else return 0. | 412 characters C1 and C2 if they appear in this order, else return 0. |
419 Use the macro WORD_BOUNDARY_P instead of calling this function | 413 Use the macro WORD_BOUNDARY_P instead of calling this function |
420 directly. */ | 414 directly. */ |
421 | 415 |
422 int | 416 int |
423 word_boundary_p (c1, c2) | 417 word_boundary_p (int c1, int c2) |
424 int c1, c2; | |
425 { | 418 { |
426 Lisp_Object category_set1, category_set2; | 419 Lisp_Object category_set1, category_set2; |
427 Lisp_Object tail; | 420 Lisp_Object tail; |
428 int default_result; | 421 int default_result; |
429 | 422 |
464 return default_result; | 457 return default_result; |
465 } | 458 } |
466 | 459 |
467 | 460 |
468 void | 461 void |
469 init_category_once () | 462 init_category_once (void) |
470 { | 463 { |
471 /* This has to be done here, before we call Fmake_char_table. */ | 464 /* This has to be done here, before we call Fmake_char_table. */ |
472 Qcategory_table = intern_c_string ("category-table"); | 465 Qcategory_table = intern_c_string ("category-table"); |
473 staticpro (&Qcategory_table); | 466 staticpro (&Qcategory_table); |
474 | 467 |
487 Fset_char_table_extra_slot (Vstandard_category_table, make_number (0), | 480 Fset_char_table_extra_slot (Vstandard_category_table, make_number (0), |
488 Fmake_vector (make_number (95), Qnil)); | 481 Fmake_vector (make_number (95), Qnil)); |
489 } | 482 } |
490 | 483 |
491 void | 484 void |
492 syms_of_category () | 485 syms_of_category (void) |
493 { | 486 { |
494 Qcategoryp = intern_c_string ("categoryp"); | 487 Qcategoryp = intern_c_string ("categoryp"); |
495 staticpro (&Qcategoryp); | 488 staticpro (&Qcategoryp); |
496 Qcategorysetp = intern_c_string ("categorysetp"); | 489 Qcategorysetp = intern_c_string ("categorysetp"); |
497 staticpro (&Qcategorysetp); | 490 staticpro (&Qcategorysetp); |