GNU bug report logs -
#62867
segfault in describe_vector
Previous Next
Reported by: Xinyang Chen <chenxy <at> mit.edu>
Date: Sat, 15 Apr 2023 18:31:02 UTC
Severity: normal
Done: Eli Zaretskii <eliz <at> gnu.org>
Bug is archived. No further changes may be made.
Full log
Message #11 received at 62867 <at> debbugs.gnu.org (full text, mbox):
> Stefan, can we do better than the below?
The patch looks about right to me.
Only detail is that `shadowed_by` contains a binding, so it can be
a keymap, but it can also be a lambda expression, or a keyboard macro,
so we shouldn't say "shadowed by a keymap" but just "shadowed" (unless
we go through the extra trouble of checking if it's a keymap, or if it's
a ...).
Stefan
> diff --git a/src/keymap.c b/src/keymap.c
> index efac410..b9950b9 100644
> --- a/src/keymap.c
> +++ b/src/keymap.c
> @@ -3308,13 +3308,18 @@ describe_vector (Lisp_Object vector, Lisp_Object prefix, Lisp_Object args,
> if (this_shadowed)
> {
> SET_PT (PT - 1);
> - static char const fmt[] = " (currently shadowed by `%s')";
> - USE_SAFE_ALLOCA;
> - char *buffer = SAFE_ALLOCA (sizeof fmt +
> - SBYTES (SYMBOL_NAME (shadowed_by)));
> - esprintf (buffer, fmt, SDATA (SYMBOL_NAME (shadowed_by)));
> - insert_string (buffer);
> - SAFE_FREE();
> + if (SYMBOLP (shadowed_by))
> + {
> + static char const fmt[] = " (currently shadowed by `%s')";
> + USE_SAFE_ALLOCA;
> + char *buffer =
> + SAFE_ALLOCA (sizeof fmt + SBYTES (SYMBOL_NAME (shadowed_by)));
> + esprintf (buffer, fmt, SDATA (SYMBOL_NAME (shadowed_by)));
> + insert_string (buffer);
> + SAFE_FREE();
> + }
> + else
> + insert_string (" (binding currently shadowed by a keymap)");
> SET_PT (PT + 1);
> }
> }
This bug report was last modified 2 years and 33 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.