From 0b31741cdc1014fedcdca9aaed39d0173f847308 Mon Sep 17 00:00:00 2001 From: "Richard M. Stallman" Date: Thu, 2 Dec 2004 23:36:53 +0000 Subject: [PATCH] (Fcalled_interactively_p): Don't check INTERACTIVE. (interactive_p): Skip Scalled_interactively_p frames like Sinteractive_p frames. --- src/eval.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/eval.c b/src/eval.c index 15b292d7d7e..4a63b022fd6 100644 --- a/src/eval.c +++ b/src/eval.c @@ -573,7 +573,7 @@ optional argument, and making the `interactive' spec specify non-nil unconditionally for that argument. (`p' is a good way to do this.) */) () { - return (INTERACTIVE && interactive_p (1)) ? Qt : Qnil; + return interactive_p (1) ? Qt : Qnil; } @@ -595,7 +595,8 @@ interactive_p (exclude_subrs_p) /* If this isn't a byte-compiled function, there may be a frame at the top for Finteractive_p. If so, skip it. */ fun = Findirect_function (*btp->function); - if (SUBRP (fun) && XSUBR (fun) == &Sinteractive_p) + if (SUBRP (fun) && (XSUBR (fun) == &Sinteractive_p + || XSUBR (fun) == &Scalled_interactively_p)) btp = btp->next; /* If we're running an Emacs 18-style byte-compiled function, there @@ -1173,9 +1174,10 @@ unwind_to_catch (catch, value) /* Save the value in the tag. */ catch->val = value; - /* Restore the polling-suppression count. */ + /* Restore certain special C variables. */ set_poll_suppress_count (catch->poll_suppress_count); interrupt_input_blocked = catch->interrupt_input_blocked; + handling_signal = 0; do { -- 2.39.5