From 7a3d90dc245c540145b50fadc6d5cb18df095a09 Mon Sep 17 00:00:00 2001 From: Stefan Monnier Date: Tue, 6 May 2008 20:11:13 +0000 Subject: [PATCH] (substitute_object_recurse): Use lower-level primitives. Don't signal errors when traversing sub-char-tables. Don't loop over all the possible characters when traversing char-tables. --- src/ChangeLog | 4 ++++ src/lread.c | 56 ++++++++++++++++++++++++++++++--------------------- 2 files changed, 37 insertions(+), 23 deletions(-) diff --git a/src/ChangeLog b/src/ChangeLog index a7b19f3dfc9..3f31a8ad2f6 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,5 +1,9 @@ 2008-05-06 Stefan Monnier + * lread.c (substitute_object_recurse): Use lower-level primitives. + Don't signal errors when traversing sub-char-tables. + Don't loop over all the possible characters when traversing char-tables. + * print.c (print_preprocess): Add sub-char-tables to the print-table, just like we do in print.c. diff --git a/src/lread.c b/src/lread.c index 77c7a3c875f..1daf991719a 100644 --- a/src/lread.c +++ b/src/lread.c @@ -3057,18 +3057,18 @@ substitute_object_in_subtree (object, placeholder) } /* Feval doesn't get called from here, so no gc protection is needed. */ -#define SUBSTITUTE(get_val, set_val) \ -{ \ - Lisp_Object old_value = get_val; \ - Lisp_Object true_value \ - = substitute_object_recurse (object, placeholder,\ - old_value); \ - \ - if (!EQ (old_value, true_value)) \ - { \ - set_val; \ - } \ -} +#define SUBSTITUTE(get_val, set_val) \ + do { \ + Lisp_Object old_value = get_val; \ + Lisp_Object true_value \ + = substitute_object_recurse (object, placeholder, \ + old_value); \ + \ + if (!EQ (old_value, true_value)) \ + { \ + set_val; \ + } \ + } while (0) static Lisp_Object substitute_object_recurse (object, placeholder, subtree) @@ -3097,23 +3097,33 @@ substitute_object_recurse (object, placeholder, subtree) { case Lisp_Vectorlike: { - int i; - int length = XINT (Flength(subtree)); + int i, length = 0; + if (BOOL_VECTOR_P (subtree)) + return subtree; /* No sub-objects anyway. */ + else if (CHAR_TABLE_P (subtree) || SUB_CHAR_TABLE_P (subtree) + || COMPILEDP (subtree)) + length = ASIZE (subtree) & PSEUDOVECTOR_SIZE_MASK; + else if (VECTORP (subtree)) + length = ASIZE (subtree); + else + /* An unknown pseudovector may contain non-Lisp fields, so we + can't just blindly traverse all its fields. We used to call + `Flength' which signalled `sequencep', so I just preserved this + behavior. */ + wrong_type_argument (Qsequencep, subtree); + for (i = 0; i < length; i++) - { - Lisp_Object idx = make_number (i); - SUBSTITUTE (Faref (subtree, idx), - Faset (subtree, idx, true_value)); - } + SUBSTITUTE (AREF (subtree, i), + ASET (subtree, i, true_value)); return subtree; } case Lisp_Cons: { - SUBSTITUTE (Fcar_safe (subtree), - Fsetcar (subtree, true_value)); - SUBSTITUTE (Fcdr_safe (subtree), - Fsetcdr (subtree, true_value)); + SUBSTITUTE (XCAR (subtree), + XSETCAR (subtree, true_value)); + SUBSTITUTE (XCDR (subtree), + XSETCDR (subtree, true_value)); return subtree; } -- 2.39.5