From: Drew Adams <drew.adams@oracle.com>
To: martin rudalics <rudalics@gmx.at>, Lars Ingebrigtsen <larsi@gnus.org>
Cc: "13336@debbugs.gnu.org" <13336@debbugs.gnu.org>
Subject: bug#13336: [External] : Re: bug#13336: `next-frame' should not choose the *Backtrace* frame while debugging
Date: Tue, 24 Aug 2021 20:02:32 +0000 [thread overview]
Message-ID: <SJ0PR10MB54884B4E2FEE61394037BB1BF3C59@SJ0PR10MB5488.namprd10.prod.outlook.com> (raw)
In-Reply-To: <98917a3e-e465-6cfb-ffe6-d977673bf185@gmx.at>
> > (defconst special-display-regexps '("[ ]?[*][^*]+[*]"))
>
> If you insist on using the obsolete `special-display-regexps',
> then why on earth don't you use a buffer name with it
Why does that matter here? I want the frame attributes
to be the same for all buffers whose names match that
regexp. That is, I would want that, except I apparently
need to add a special frame parameter for `*Backtrace*',
since this bug isn't getting fixed.
I could add a `*Backtrace*' entry to my value of
`special-display-buffer-names', yes, and duplicate the
parameters of `special-display-regexps' but also add
the kludge to work around this bug.
Is that necessary? I was guessing it would be OK
(and reasonable) to use `after-make-frame-functions'.
> why on earth don't you use the FRAME-PARAMETERS idiom?
It's not clear to me what idiom you have in mind.
> > Debugging a bit shows that frame parameter `name' for
> > the *Backtrace* frame is indeed "*Backtrace*",
>
> Not at the time `after-make-frame-functions' gets called
> (unless you specified a name for it).
I see. How would I do that? I don't control how or
when the frame gets created.
> > but parameter `no-other-frame' is nil (doesn't get
> > set to `t'). What's more, it looks like (?) function
> > `backtrace-no-other-frame' doesn't even get invoked.
> >
> > What should I be doing instead? I don't explicitly
> > create frame *Backtrace* myself. I presumably need
> > to somehow have its `no-other-frame' frame parameter
> > set to `t' whenever it's created.
>
> If you insist on using `after-make-frame-functions',
> the following should work.
I don't insist. I was trying to interpret what you
suggested. Should I not use `after-make-frame-functions'
for some reason (why)?
> (when (equal (buffer-name
> (window-buffer (frame-selected-window frame)))
> "*Backtrace*")
I see. That makes sense, and it seems to work.
Thank you!
> > Beyond finding a solution for myself: I guess you too
> > consider that this should not be fixed generally, i.e.,
> > that frame *Backtrace* should be allowed to be another
> > frame's `next-frame'. If so, I'm curious as to why.
>
> I see no general rule here. When debugging window management problems,
> a separate frame comes in handy. OTOH when debugging frame management
> problems, a window on an existing frame might be preferable.
OK.
With other things, besides frame parameters, the debugger
keeps separate the local, *Backtrace* context and the
outside context - the overal context minus the *Backtrace*
context. The debugger does its best to keep out of what
is being evaluated/used by Emacs. That can't be done
perfectly, of course.
E.g., you can evaluate a sexp in the context of *Backtrace*
using `M-:' or whatever, or you can evaluate it in the
outside (non-debugger) context using `e'. Frame parameters
seem to "break" that design. But I won't argue the point
further, and I'm no expert on the debugger.
next prev parent reply other threads:[~2021-08-24 20:02 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-01-02 18:13 bug#13336: 24.3.50; `next-frame' should not choose a frame (e.g. *Backtrace*) that did not exist when it was invoked Drew Adams
2017-01-30 6:33 ` npostavs
2017-01-30 14:32 ` Drew Adams
2017-01-31 3:22 ` npostavs
2021-08-23 14:37 ` bug#13336: `next-frame' should not choose the *Backtrace* frame while debugging Lars Ingebrigtsen
2021-08-23 15:20 ` bug#13336: [External] : " Drew Adams
2021-08-23 16:06 ` martin rudalics
2021-08-23 17:41 ` Drew Adams
2021-08-24 9:41 ` martin rudalics
2021-08-24 15:49 ` Drew Adams
2021-08-24 17:41 ` martin rudalics
2021-08-24 20:02 ` Drew Adams [this message]
2021-08-25 7:48 ` martin rudalics
2021-08-25 15:27 ` Drew Adams
2021-08-25 19:41 ` martin rudalics
2021-08-25 20:23 ` Drew Adams
2021-08-26 7:53 ` martin rudalics
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=SJ0PR10MB54884B4E2FEE61394037BB1BF3C59@SJ0PR10MB5488.namprd10.prod.outlook.com \
--to=drew.adams@oracle.com \
--cc=13336@debbugs.gnu.org \
--cc=larsi@gnus.org \
--cc=rudalics@gmx.at \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).