diff options
| author | Ken Raeburn | 2000-03-22 21:44:05 +0000 |
|---|---|---|
| committer | Ken Raeburn | 2000-03-22 21:44:05 +0000 |
| commit | 439d5cb4f7aa541a93c9c5003188918af097b82a (patch) | |
| tree | ad3ce3a953fa8442bd99f71544cf645dd6ecb6a6 /src/alloc.c | |
| parent | 89084293988e60922e51698a441ec71ab0d2363b (diff) | |
| download | emacs-439d5cb4f7aa541a93c9c5003188918af097b82a.tar.gz emacs-439d5cb4f7aa541a93c9c5003188918af097b82a.zip | |
Changes towards better type safety regarding intervals, primarily
regarding the "parent" handle. These just separate out the different
usages based on the type of parent (interval vs lisp object); later
changes will do type checking and enforcement.
* intervals.h (NULL_INTERVAL): Cast to INTERVAL type.
(INT_LISPLIKE): New macro.
(NULL_INTERVAL_P): Use it.
(INTERVAL_HAS_PARENT, INTERVAL_HAS_OBJECT, SET_INTERVAL_PARENT,
SET_INTERVAL_OBJECT, INTERVAL_PARENT, COPY_INTERVAL_PARENT,
GET_INTERVAL_OBJECT, INTERVAL_PARENT_OR_NULL): New macros.
* alloc.c (make_interval, gc_sweep): Use new macros; eliminate all
explicit references to "parent" field of struct interval and
associated unclean type conversions.
* intervals.c (create_root_interval, root_interval, rotate_right,
rotate_left, balance_possible_root_interval, split_interval_right,
split_interval_left, interval_start_pos, find_interval,
next_interval, previous_interval, update_interval,
adjust_intervals_for_insertion, delete_node, delete_interval,
adjust_intervals_for_deletion, merge_interval_right,
merge_interval_left, reproduce_tree, graft_intervals_into_buffer,
copy_intervals_to_string): Likewise.
* intervals.h (AM_LEFT_CHILD, AM_RIGHT_CHILD, RESET_INTERVAL):
Likewise.
* syntax.c (update_syntax_table): Likewise.
* intervals.c (reproduce_tree_obj): New function, like
reproduce_tree but takes a Lisp_Object for the parent. Declare
with prototype.
(graft_intervals_into_buffer): Use it when appropriate.
(reproduce_tree): Declare with prototype.
(balance_possible_root_interval): Check that the parent is a lisp
object before trying to examine its type.
Diffstat (limited to 'src/alloc.c')
| -rw-r--r-- | src/alloc.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/src/alloc.c b/src/alloc.c index ba8b3ffd6ed..3027e08b467 100644 --- a/src/alloc.c +++ b/src/alloc.c | |||
| @@ -711,7 +711,7 @@ make_interval () | |||
| 711 | if (interval_free_list) | 711 | if (interval_free_list) |
| 712 | { | 712 | { |
| 713 | val = interval_free_list; | 713 | val = interval_free_list; |
| 714 | interval_free_list = interval_free_list->parent; | 714 | interval_free_list = INTERVAL_PARENT (interval_free_list); |
| 715 | } | 715 | } |
| 716 | else | 716 | else |
| 717 | { | 717 | { |
| @@ -4215,7 +4215,7 @@ gc_sweep () | |||
| 4215 | { | 4215 | { |
| 4216 | if (! XMARKBIT (iblk->intervals[i].plist)) | 4216 | if (! XMARKBIT (iblk->intervals[i].plist)) |
| 4217 | { | 4217 | { |
| 4218 | iblk->intervals[i].parent = interval_free_list; | 4218 | SET_INTERVAL_PARENT (&iblk->intervals[i], interval_free_list); |
| 4219 | interval_free_list = &iblk->intervals[i]; | 4219 | interval_free_list = &iblk->intervals[i]; |
| 4220 | this_free++; | 4220 | this_free++; |
| 4221 | } | 4221 | } |
| @@ -4233,7 +4233,7 @@ gc_sweep () | |||
| 4233 | { | 4233 | { |
| 4234 | *iprev = iblk->next; | 4234 | *iprev = iblk->next; |
| 4235 | /* Unhook from the free list. */ | 4235 | /* Unhook from the free list. */ |
| 4236 | interval_free_list = iblk->intervals[0].parent; | 4236 | interval_free_list = INTERVAL_PARENT (&iblk->intervals[0]); |
| 4237 | lisp_free (iblk); | 4237 | lisp_free (iblk); |
| 4238 | n_interval_blocks--; | 4238 | n_interval_blocks--; |
| 4239 | } | 4239 | } |