diff options
author | Paul Eggert <eggert@cs.ucla.edu> | 2013-11-04 23:11:24 -0800 |
---|---|---|
committer | Paul Eggert <eggert@cs.ucla.edu> | 2013-11-04 23:11:24 -0800 |
commit | df5b49306e8e82e2f18ed3243700c11ca7835750 (patch) | |
tree | d98fffc7d11d4565b6132e83f54ca3f3c547b1d4 /src/category.c | |
parent | 693698093480628b7438ca0fd1614b00acfd1137 (diff) | |
download | emacs-df5b49306e8e82e2f18ed3243700c11ca7835750.tar.gz |
Simplify and port recent bool vector changes.
* configure.ac (BITSIZEOF_SIZE_T, SIZEOF_SIZE_T):
New symbols to configure.
* src/alloc.c (ROUNDUP): Move here from lisp.h, since it's now used
only in this file. Use a more-efficient implementation if the
second argument is a power of 2.
(ALIGN): Rewrite in terms of ROUNDUP. Make it a function.
Remove no-longer-necessary compile-time checks.
(bool_vector_exact_payload_bytes): New function.
(bool_vector_payload_bytes): Remove 2nd arg; callers that need
exact payload changed to call the new function. Do not assume
that the arg or result fits in ptrdiff_t.
(bool_vector_fill): New function.
(Fmake_bool_vector): Use it. Don't assume bit counts fit
in ptrdiff_t.
(vroundup_ct): Don't assume arg fits in size_t.
* src/category.c (SET_CATEGORY_SET): Remove. All callers now just
invoke set_category_set.
(set_category_set): 2nd arg is now EMACS_INT and 3rd is now bool.
All callers changed. Use bool_vector_set.
* src/category.h (XCATEGORY_SET): Remove; no longer needed.
(CATEGORY_MEMBER): Now a function. Rewrite in terms of
bool_vector_bitref.
* src/data.c (Faref): Use bool_vector_ref.
(Faset): Use bool_vector_set.
(bits_word_to_host_endian): Don't assume you can shift by CHAR_BIT.
(Fbool_vector_not, Fbool_vector_count_matches)
(Fbool_vector_count_matches_at): Don't assume CHAR_BIT == 8.
* src/fns.c (concat): Use bool_vector_ref.
(Ffillarray): Use bool_vector_fill.
(mapcar1): Use bool_vector_ref.
(sxhash_bool_vector): Hash words, not bytes.
* src/lisp.h (BOOL_VECTOR_BITS_PER_CHAR): Now a macro as well as
a constant, since it's now used in #if.
(bits_word, BITS_WORD_MAX, BITS_PER_BITS_WORD): Fall back on
unsigned char on unusual architectures, so that we no longer
assume that the number of bits per bits_word is a power of two or
is a multiple of 8 or of CHAR_BIT.
(Qt): Add forward decl.
(struct Lisp_Bool_Vector): Don't assume EMACS_INT is aligned
at least as strictly as bits_word.
(bool_vector_data, bool_vector_uchar_data): New accessors.
All data structure accesses changed to use them.
(bool_vector_words, bool_vector_bitref, bool_vector_ref)
(bool_vector_set): New functions.
(bool_vector_fill): New decl.
(ROUNDUP): Move to alloc.c as described above.
Diffstat (limited to 'src/category.c')
-rw-r--r-- | src/category.c | 41 |
1 files changed, 13 insertions, 28 deletions
diff --git a/src/category.c b/src/category.c index da5e81e4709..80d8b1ca1a2 100644 --- a/src/category.c +++ b/src/category.c @@ -55,17 +55,9 @@ bset_category_table (struct buffer *b, Lisp_Object val) static int category_table_version; static Lisp_Object Qcategory_table, Qcategoryp, Qcategorysetp, Qcategory_table_p; - -/* Make CATEGORY_SET includes (if VAL is t) or excludes (if VAL is - nil) CATEGORY. */ -#define SET_CATEGORY_SET(category_set, category, val) \ - set_category_set (category_set, category, val) -static void set_category_set (Lisp_Object, Lisp_Object, Lisp_Object); /* Category set staff. */ -static Lisp_Object hash_get_category_set (Lisp_Object, Lisp_Object); - static Lisp_Object hash_get_category_set (Lisp_Object table, Lisp_Object category_set) { @@ -88,6 +80,13 @@ hash_get_category_set (Lisp_Object table, Lisp_Object category_set) return category_set; } +/* Make CATEGORY_SET include (if VAL) or exclude (if !VAL) CATEGORY. */ + +static void +set_category_set (Lisp_Object category_set, EMACS_INT category, bool val) +{ + bool_vector_set (category_set, category, val); +} DEFUN ("make-category-set", Fmake_category_set, Smake_category_set, 1, 1, 0, doc: /* Return a newly created category-set which contains CATEGORIES. @@ -108,11 +107,11 @@ those categories. */) len = SCHARS (categories); while (--len >= 0) { - Lisp_Object category; + unsigned char cat = SREF (categories, len); + Lisp_Object category = make_number (cat); - XSETFASTINT (category, SREF (categories, len)); CHECK_CATEGORY (category); - SET_CATEGORY_SET (val, category, Qt); + set_category_set (val, cat, 1); } return val; } @@ -334,20 +333,6 @@ The return value is a string containing those same categories. */) return build_string (str); } -static void -set_category_set (Lisp_Object category_set, Lisp_Object category, Lisp_Object val) -{ - do { - int idx = XINT (category) / 8; - unsigned char bits = 1 << (XINT (category) % 8); - - if (NILP (val)) - XCATEGORY_SET (category_set)->data[idx] &= ~bits; - else - XCATEGORY_SET (category_set)->data[idx] |= bits; - } while (0); -} - DEFUN ("modify-category-entry", Fmodify_category_entry, Smodify_category_entry, 2, 4, 0, doc: /* Modify the category set of CHARACTER by adding CATEGORY to it. @@ -359,7 +344,7 @@ If optional fourth argument RESET is non-nil, then delete CATEGORY from the category set instead of adding it. */) (Lisp_Object character, Lisp_Object category, Lisp_Object table, Lisp_Object reset) { - Lisp_Object set_value; /* Actual value to be set in category sets. */ + bool set_value; /* Actual value to be set in category sets. */ Lisp_Object category_set; int start, end; int from, to; @@ -384,7 +369,7 @@ then delete CATEGORY from the category set instead of adding it. */) if (NILP (CATEGORY_DOCSTRING (table, XFASTINT (category)))) error ("Undefined category: %c", (int) XFASTINT (category)); - set_value = NILP (reset) ? Qt : Qnil; + set_value = NILP (reset); while (start <= end) { @@ -393,7 +378,7 @@ then delete CATEGORY from the category set instead of adding it. */) if (CATEGORY_MEMBER (XFASTINT (category), category_set) != NILP (reset)) { category_set = Fcopy_sequence (category_set); - SET_CATEGORY_SET (category_set, category, set_value); + set_category_set (category_set, XFASTINT (category), set_value); category_set = hash_get_category_set (table, category_set); char_table_set_range (table, start, to, category_set); } |