* bug#40992: 27.0.90; Evaluating a function while using edebug breaks @ 2020-05-01 8:26 Phillip Lord 2020-05-01 15:56 ` Alan Mackenzie 2020-05-04 1:27 ` Pouar Dragon 0 siblings, 2 replies; 16+ messages in thread From: Phillip Lord @ 2020-05-01 8:26 UTC (permalink / raw) To: 40992 Edebug fails while tracing a function, if that function is evaluated during the edebug session. The error reported is: Wrong type argument: listp, #<marker at 4045 in hanoi.el> edebug--display-1: Wrong type argument: listp, #<marker at 4045 in hanoi.el> This is a regression as it works in Emacs-26, but fails in Emacs-27. Reproduction: In clean emacs -q M-x hanoi jump to hanoi function C-u C-M-x M-x hanoi After stepping through into hanoi with point still in C-M-x and step once more. I use this workflow quite a lot when debugging. I may start to debug a function, decided I have seen enough, to un-instrument so I don't see it debugged again. ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-01 8:26 bug#40992: 27.0.90; Evaluating a function while using edebug breaks Phillip Lord @ 2020-05-01 15:56 ` Alan Mackenzie 2020-05-01 17:33 ` Alan Mackenzie 2020-05-04 1:27 ` Pouar Dragon 1 sibling, 1 reply; 16+ messages in thread From: Alan Mackenzie @ 2020-05-01 15:56 UTC (permalink / raw) To: Phillip Lord, Lars Ingebrigtsen; +Cc: 40992 Hello, Phillip and Lars. On Fri, May 01, 2020 at 09:26:44 +0100, Phillip Lord wrote: > Edebug fails while tracing a function, if that function is evaluated > during the edebug session. The error reported is: > Wrong type argument: listp, #<marker at 4045 in hanoi.el> > edebug--display-1: Wrong type argument: listp, #<marker at 4045 in hanoi.el> > This is a regression as it works in Emacs-26, but fails in Emacs-27. Yes. A bit of bisection shows that the commit which introduced this bug is: commit e8b3a15cb6ff187ce08afcb43bd9a0b7907268ca Author: Lars Ingebrigtsen <larsi@gnus.org> Date: Sun Oct 20 12:07:42 2019 +0200 Mark breakpoints in edebug with highlights * lisp/emacs-lisp/edebug.el (edebug--overlay-breakpoints) (edebug--overlay-breakpoints-remove): New functions (bug#23468). (edebug-modify-breakpoint): Use them to highlight breakpoints. (edebug--display-1): Restore breakpoint highlights. (edebug--recursive-edit): Remove highlights on exit. Lars, have you got any comment on this? > Reproduction: > In clean emacs -q > M-x hanoi > jump to hanoi function > C-u C-M-x > M-x hanoi > After stepping through into hanoi with point still in > C-M-x > and step once more. > I use this workflow quite a lot when debugging. I may start to debug a > function, decided I have seen enough, to un-instrument so I don't see it > debugged again. -- Alan Mackenzie (Nuremberg, Germany). ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-01 15:56 ` Alan Mackenzie @ 2020-05-01 17:33 ` Alan Mackenzie 2020-05-01 18:02 ` Eli Zaretskii 2020-05-02 1:43 ` Lars Ingebrigtsen 0 siblings, 2 replies; 16+ messages in thread From: Alan Mackenzie @ 2020-05-01 17:33 UTC (permalink / raw) To: Phillip Lord, Lars Ingebrigtsen; +Cc: 40992 Hello, Phillip and Lars. On Fri, May 01, 2020 at 15:56:30 +0000, Alan Mackenzie wrote: > On Fri, May 01, 2020 at 09:26:44 +0100, Phillip Lord wrote: > > Edebug fails while tracing a function, if that function is evaluated > > during the edebug session. The error reported is: > > Wrong type argument: listp, #<marker at 4045 in hanoi.el> > > edebug--display-1: Wrong type argument: listp, #<marker at 4045 in hanoi.el> > > This is a regression as it works in Emacs-26, but fails in Emacs-27. > Yes. A bit of bisection shows that the commit which introduced this bug > is: > commit e8b3a15cb6ff187ce08afcb43bd9a0b7907268ca > Author: Lars Ingebrigtsen <larsi@gnus.org> > Date: Sun Oct 20 12:07:42 2019 +0200 > Mark breakpoints in edebug with highlights > * lisp/emacs-lisp/edebug.el (edebug--overlay-breakpoints) > (edebug--overlay-breakpoints-remove): New functions (bug#23468). > (edebug-modify-breakpoint): Use them to highlight breakpoints. > (edebug--display-1): Restore breakpoint highlights. > (edebug--recursive-edit): Remove highlights on exit. > Lars, have you got any comment on this? > > Reproduction: > > In clean emacs -q > > M-x hanoi > > jump to hanoi function > > C-u C-M-x > > M-x hanoi > > After stepping through into hanoi with point still in > > C-M-x > > and step once more. The cause is now clear. When you instrument a function, the symbol is given a property 'edebug, whose value is a list of edebug information. It is this list which edebug--overlay-breakpoints is trying to access when it throws the error. When you recompile the function without instrumentation, edebug sets the 'edebug property to the marker #<marker at 4045 in hanoi.el>. This non-list value of the property acts elsewhere as a signal that the function isn't instrumented. This is a fundamental problem, that the edebug information is attached to the symbol `hanoi' rather than to the (instrumented) function which is no longer the symbol-function of `hanoi'. Sadly, there is no way of attaching a property to a function, only to a symbol (or a buffer position). There doesn't appear to be a good way of solving this bug. A workable workaround would be to check that the 'edebug property value is a list in edebug--overlay-breakpoints, and just to remove the breakpoint highlights when it's not a list. When it's not a list, it's a marker pointing to the start of the function, from which the end of the function can be found, to serve as the END argument to edebug--overlay-breakpoints-remove. Or something like that. :-( > > I use this workflow quite a lot when debugging. I may start to debug a > > function, decided I have seen enough, to un-instrument so I don't see it > > debugged again. -- Alan Mackenzie (Nuremberg, Germany). ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-01 17:33 ` Alan Mackenzie @ 2020-05-01 18:02 ` Eli Zaretskii 2020-05-02 1:43 ` Lars Ingebrigtsen 1 sibling, 0 replies; 16+ messages in thread From: Eli Zaretskii @ 2020-05-01 18:02 UTC (permalink / raw) To: Alan Mackenzie; +Cc: larsi, phillip.lord, 40992 > Date: Fri, 1 May 2020 17:33:06 +0000 > From: Alan Mackenzie <acm@muc.de> > Cc: 40992@debbugs.gnu.org > > There doesn't appear to be a good way of solving this bug. A workable > workaround would be to check that the 'edebug property value is a list > in edebug--overlay-breakpoints, and just to remove the breakpoint > highlights when it's not a list. When it's not a list, it's a marker > pointing to the start of the function, from which the end of the > function can be found, to serve as the END argument to > edebug--overlay-breakpoints-remove. > > Or something like that. :-( How about if we revert the offending commit on emacs-27? The feature it adds doesn't sound important enough when compared to the breakage it causes. ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-01 17:33 ` Alan Mackenzie 2020-05-01 18:02 ` Eli Zaretskii @ 2020-05-02 1:43 ` Lars Ingebrigtsen 2020-05-02 3:05 ` Noam Postavsky 1 sibling, 1 reply; 16+ messages in thread From: Lars Ingebrigtsen @ 2020-05-02 1:43 UTC (permalink / raw) To: Alan Mackenzie; +Cc: Phillip Lord, 40992 Alan Mackenzie <acm@muc.de> writes: > There doesn't appear to be a good way of solving this bug. A workable > workaround would be to check that the 'edebug property value is a list > in edebug--overlay-breakpoints, and just to remove the breakpoint > highlights when it's not a list. When it's not a list, it's a marker > pointing to the start of the function, from which the end of the > function can be found, to serve as the END argument to > edebug--overlay-breakpoints-remove. > > Or something like that. :-( I think that sounds like a good solution on master, but the patch that introduced this should probably be reverted on emacs-27 -- it wasn't a bug fix, but a new feature, so reverting it should be safe, I think. -- (domestic pets only, the antidote for overdose, milk.) bloggy blog: http://lars.ingebrigtsen.no ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-02 1:43 ` Lars Ingebrigtsen @ 2020-05-02 3:05 ` Noam Postavsky 2020-05-02 7:10 ` Eli Zaretskii 2020-05-02 13:14 ` Alan Mackenzie 0 siblings, 2 replies; 16+ messages in thread From: Noam Postavsky @ 2020-05-02 3:05 UTC (permalink / raw) To: Lars Ingebrigtsen; +Cc: Alan Mackenzie, 40992, Phillip Lord Lars Ingebrigtsen <larsi@gnus.org> writes: > Alan Mackenzie <acm@muc.de> writes: > >> There doesn't appear to be a good way of solving this bug. A workable >> workaround would be to check that the 'edebug property value is a list >> in edebug--overlay-breakpoints, and just to remove the breakpoint >> highlights when it's not a list. When it's not a list, it's a marker >> pointing to the start of the function, from which the end of the >> function can be found, to serve as the END argument to >> edebug--overlay-breakpoints-remove. >> >> Or something like that. :-( > > I think that sounds like a good solution on master, but the patch that > introduced this should probably be reverted on emacs-27 -- it wasn't a > bug fix, but a new feature, so reverting it should be safe, I think. I don't understand; the fix looks trivial to me (leaving out indentation), and only touches a new function. Surely this is okay for emacs-27? --- i/lisp/emacs-lisp/edebug.el +++ w/lisp/emacs-lisp/edebug.el @@ -3236,8 +3236,9 @@ 'edebug-breakpoint "\x3c\x7e\xff\xff\xff\xff\x7e\x3c") (defun edebug--overlay-breakpoints (function) - (let* ((data (get function 'edebug)) - (start (nth 0 data)) + (let ((data (get function 'edebug))) + (when (listp data) + (let* ((start (nth 0 data)) (breakpoints (nth 1 data)) (offsets (nth 2 data))) ;; First remove all old breakpoint overlays. @@ -3264,6 +3265,7 @@ edebug--overlay-breakpoints (propertize "x" 'display `(left-fringe edebug-breakpoint ,face))))))))) + )) (defun edebug--overlay-breakpoints-remove (start end) (dolist (overlay (overlays-in start end)) ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-02 3:05 ` Noam Postavsky @ 2020-05-02 7:10 ` Eli Zaretskii 2020-05-02 13:34 ` Alan Mackenzie 2020-05-02 21:54 ` Phillip Lord 2020-05-02 13:14 ` Alan Mackenzie 1 sibling, 2 replies; 16+ messages in thread From: Eli Zaretskii @ 2020-05-02 7:10 UTC (permalink / raw) To: Noam Postavsky; +Cc: acm, larsi, 40992, phillip.lord > From: Noam Postavsky <npostavs@gmail.com> > Date: Fri, 01 May 2020 23:05:32 -0400 > Cc: Alan Mackenzie <acm@muc.de>, 40992@debbugs.gnu.org, > Phillip Lord <phillip.lord@russet.org.uk> > > > I think that sounds like a good solution on master, but the patch that > > introduced this should probably be reverted on emacs-27 -- it wasn't a > > bug fix, but a new feature, so reverting it should be safe, I think. > > I don't understand; the fix looks trivial to me (leaving out > indentation), and only touches a new function. Surely this is okay for > emacs-27? If this fixes the problem, it's okay for emacs-27. But then why did Alan say there was no easy solution? ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-02 7:10 ` Eli Zaretskii @ 2020-05-02 13:34 ` Alan Mackenzie 2020-05-02 13:57 ` Eli Zaretskii 2020-05-02 21:54 ` Phillip Lord 1 sibling, 1 reply; 16+ messages in thread From: Alan Mackenzie @ 2020-05-02 13:34 UTC (permalink / raw) To: Eli Zaretskii; +Cc: larsi, 40992, Noam Postavsky, phillip.lord Hello, Eli. On Sat, May 02, 2020 at 10:10:04 +0300, Eli Zaretskii wrote: > > From: Noam Postavsky <npostavs@gmail.com> > > Date: Fri, 01 May 2020 23:05:32 -0400 > > Cc: Alan Mackenzie <acm@muc.de>, 40992@debbugs.gnu.org, > > Phillip Lord <phillip.lord@russet.org.uk> > > > I think that sounds like a good solution on master, but the patch that > > > introduced this should probably be reverted on emacs-27 -- it wasn't a > > > bug fix, but a new feature, so reverting it should be safe, I think. > > I don't understand; the fix looks trivial to me (leaving out > > indentation), and only touches a new function. Surely this is okay for > > emacs-27? > If this fixes the problem, it's okay for emacs-27. But then why did > Alan say there was no easy solution? I think I said "good" rather than "easy". This 'edebug property is essentially associated with a function, but is in a symbol's property list. Noam's fix, I think, will either leave stale highlights on what used to be breakpoints, or won't leave the highlights active whilst the debugging is still in progress. It might be the least bad fix, though. At the time of debugging, there are _two_ functions associated with `hanoi', the one just compiled with C-M-x, and the instrumented one still being debugged (which will soon find its way to the garbage collector). There is no way to attach a property list to a function (and it's too late to add one for Emacs 27 ;-), so prop 'edebug gets on the symbol's plist, and confusion results. Hence this bug. A good solution would fix this confusion. I can't think of a way to do this which doesn't involve deep surgery on Emacs's internals. I think the same mechanism is behind the annoying bug (not yet reported by me) where you do M-x compile-defun on a previously instrumented function, then try to instrument it again by typing I (`edebug-instrument-callee') whilst in Edebug. You get the spurious error message "Already instrumented". -- Alan Mackenzie (Nuremberg, Germany). ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-02 13:34 ` Alan Mackenzie @ 2020-05-02 13:57 ` Eli Zaretskii 2020-05-03 11:55 ` Alan Mackenzie 2020-05-03 12:13 ` Alan Mackenzie 0 siblings, 2 replies; 16+ messages in thread From: Eli Zaretskii @ 2020-05-02 13:57 UTC (permalink / raw) To: Alan Mackenzie; +Cc: larsi, 40992, npostavs, phillip.lord > Date: Sat, 2 May 2020 13:34:47 +0000 > Cc: Noam Postavsky <npostavs@gmail.com>, larsi@gnus.org, > 40992@debbugs.gnu.org, phillip.lord@russet.org.uk > From: Alan Mackenzie <acm@muc.de> > > Noam's fix, I think, will either leave stale highlights on what used to > be breakpoints, or won't leave the highlights active whilst the > debugging is still in progress. It might be the least bad fix, though. If Noam's fix is incomplete, I still think reverting the feature on emacs-27 is a better solution. We should continue working on this on master until we find a better solution. ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-02 13:57 ` Eli Zaretskii @ 2020-05-03 11:55 ` Alan Mackenzie 2020-05-03 12:13 ` Alan Mackenzie 1 sibling, 0 replies; 16+ messages in thread From: Alan Mackenzie @ 2020-05-03 11:55 UTC (permalink / raw) To: Eli Zaretskii; +Cc: larsi, 40992, npostavs, phillip.lord Hello, everybody. On Sat, May 02, 2020 at 16:57:26 +0300, Eli Zaretskii wrote: > > Date: Sat, 2 May 2020 13:34:47 +0000 > > Cc: Noam Postavsky <npostavs@gmail.com>, larsi@gnus.org, > > 40992@debbugs.gnu.org, phillip.lord@russet.org.uk > > From: Alan Mackenzie <acm@muc.de> > > Noam's fix, I think, will either leave stale highlights on what used to > > be breakpoints, or won't leave the highlights active whilst the > > debugging is still in progress. It might be the least bad fix, though. > If Noam's fix is incomplete, I still think reverting the feature on > emacs-27 is a better solution. We should continue working on this on > master until we find a better solution. OK. I've reverted the feature in the emacs-27 branch (with a directive not to merge to master). This should fix the bug in emacs-27. I've had two ideas about fixing this bug in master whilst leaving the breakpoint highlight feature in place: (i): (Please bear in mind it was ~04:30 when I thought this up. ;-) To each type of function (subr, byte-compile, lambda form, closure form) we add an extra field for a @dfn{function property list}, possibly optional. For dumped functions, the contents will be the index into a vector holding lots of function property lists. For functions in r/w storage, we have a property list directly. We will have functions like put-function-property, get-function-property, remove-function-properties. Having got this infrastructure, edebug will now store the 'edebug property on this function-property-list, and the problems we've had with the symbol-plist just evaporate. (ii) We devise a new (symbol-) property called something like 'ghost-edebug. When an instrumented function gets recompiled by C-M-x, etc., the previous contents of 'edebug get moved to 'ghost-edebug, and 'edebug gets a marker, as it currently does. Whilst manipulating the breakpoint highlights, edebug will use 'ghost-edebug when 'edebug holds a marker. The 'ghost-edebug property will be removed when the `hanoi' function is next instrumented. Maybe this will work. -- Alan Mackenzie (Nuremberg, Germany). ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-02 13:57 ` Eli Zaretskii 2020-05-03 11:55 ` Alan Mackenzie @ 2020-05-03 12:13 ` Alan Mackenzie 1 sibling, 0 replies; 16+ messages in thread From: Alan Mackenzie @ 2020-05-03 12:13 UTC (permalink / raw) To: 40992-done Bug fixed in the emacs-27 branch by reverting commit commit e8b3a15cb6ff187ce08afcb43bd9a0b7907268ca Author: Lars Ingebrigtsen <larsi@gnus.org> Date: Sun Oct 20 12:07:42 2019 +0200 Mark breakpoints in edebug with highlights * lisp/emacs-lisp/edebug.el (edebug--overlay-breakpoints) (edebug--overlay-breakpoints-remove): New functions (bug#23468). (edebug-modify-breakpoint): Use them to highlight breakpoints. (edebug--display-1): Restore breakpoint highlights. (edebug--recursive-edit): Remove highlights on exit. -- Alan Mackenzie (Nuremberg, Germany). ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-02 7:10 ` Eli Zaretskii 2020-05-02 13:34 ` Alan Mackenzie @ 2020-05-02 21:54 ` Phillip Lord 2020-05-11 20:16 ` Alan Mackenzie 1 sibling, 1 reply; 16+ messages in thread From: Phillip Lord @ 2020-05-02 21:54 UTC (permalink / raw) To: Eli Zaretskii; +Cc: acm, larsi, Noam Postavsky, 40992 Eli Zaretskii <eliz@gnu.org> writes: >> From: Noam Postavsky <npostavs@gmail.com> >> Date: Fri, 01 May 2020 23:05:32 -0400 >> Cc: Alan Mackenzie <acm@muc.de>, 40992@debbugs.gnu.org, >> Phillip Lord <phillip.lord@russet.org.uk> >> >> > I think that sounds like a good solution on master, but the patch that >> > introduced this should probably be reverted on emacs-27 -- it wasn't a >> > bug fix, but a new feature, so reverting it should be safe, I think. >> >> I don't understand; the fix looks trivial to me (leaving out >> indentation), and only touches a new function. Surely this is okay for >> emacs-27? > > If this fixes the problem, it's okay for emacs-27. But then why did > Alan say there was no easy solution? I guess it's because the edebug should really still be using the overlay information for the function it is still stepping through. When I do this, it's because I do not want the function instrumented any more; I'd probably be just as happy if edebug dropped out at this point (i.e. stopped stepping through and continued). That I can step through a function definition that is no longer instrumented is not really a feature for me. Not having it error, clearly, is a feature! Thanks all for looking at this. Phil ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-02 21:54 ` Phillip Lord @ 2020-05-11 20:16 ` Alan Mackenzie 0 siblings, 0 replies; 16+ messages in thread From: Alan Mackenzie @ 2020-05-11 20:16 UTC (permalink / raw) To: Phillip Lord; +Cc: larsi, 40992, Noam Postavsky Hello, Phillip. On Sat, May 02, 2020 at 22:54:52 +0100, Phillip Lord wrote: > Eli Zaretskii <eliz@gnu.org> writes: > >> From: Noam Postavsky <npostavs@gmail.com> > >> Date: Fri, 01 May 2020 23:05:32 -0400 > >> Cc: Alan Mackenzie <acm@muc.de>, 40992@debbugs.gnu.org, > >> Phillip Lord <phillip.lord@russet.org.uk> > > If this fixes the problem, it's okay for emacs-27. But then why did > > Alan say there was no easy solution? > I guess it's because the edebug should really still be using the overlay > information for the function it is still stepping through. > When I do this, it's because I do not want the function instrumented any > more; I'd probably be just as happy if edebug dropped out at this point > (i.e. stopped stepping through and continued). That I can step through a > function definition that is no longer instrumented is not really a > feature for me. > Not having it error, clearly, is a feature! > Thanks all for looking at this. I've just committed a fix to master, whereby the information in property `edebug' is saved in property `ghost-edebug' when the function is re-evaluated. `ghost-edebug' is used by most of edebug in place of `edebug' when the latter contains a bare marker. Modulo any bugs in this patch, I think it fixes bug #40992 completely. > Phil -- Alan Mackenzie (Nuremberg, Germany). ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-02 3:05 ` Noam Postavsky 2020-05-02 7:10 ` Eli Zaretskii @ 2020-05-02 13:14 ` Alan Mackenzie 1 sibling, 0 replies; 16+ messages in thread From: Alan Mackenzie @ 2020-05-02 13:14 UTC (permalink / raw) To: Noam Postavsky; +Cc: Lars Ingebrigtsen, 40992, Phillip Lord Hello, Noam, Eli, Lars, and Phillip. On Fri, May 01, 2020 at 23:05:32 -0400, Noam Postavsky wrote: > Lars Ingebrigtsen <larsi@gnus.org> writes: > > Alan Mackenzie <acm@muc.de> writes: > >> There doesn't appear to be a good way of solving this bug. A workable > >> workaround would be to check that the 'edebug property value is a list > >> in edebug--overlay-breakpoints, and just to remove the breakpoint > >> highlights when it's not a list. When it's not a list, it's a marker > >> pointing to the start of the function, from which the end of the > >> function can be found, to serve as the END argument to > >> edebug--overlay-breakpoints-remove. > >> Or something like that. :-( > > I think that sounds like a good solution on master, but the patch that > > introduced this should probably be reverted on emacs-27 -- it wasn't a > > bug fix, but a new feature, so reverting it should be safe, I think. > I don't understand; the fix looks trivial to me (leaving out > indentation), and only touches a new function. Surely this is okay for > emacs-27? > --- i/lisp/emacs-lisp/edebug.el > +++ w/lisp/emacs-lisp/edebug.el > @@ -3236,8 +3236,9 @@ 'edebug-breakpoint > "\x3c\x7e\xff\xff\xff\xff\x7e\x3c") > (defun edebug--overlay-breakpoints (function) > - (let* ((data (get function 'edebug)) > - (start (nth 0 data)) > + (let ((data (get function 'edebug))) > + (when (listp data) > + (let* ((start (nth 0 data)) > (breakpoints (nth 1 data)) > (offsets (nth 2 data))) > ;; First remove all old breakpoint overlays. > @@ -3264,6 +3265,7 @@ edebug--overlay-breakpoints > (propertize > "x" 'display > `(left-fringe edebug-breakpoint ,face))))))))) > + )) > (defun edebug--overlay-breakpoints-remove (start end) > (dolist (overlay (overlays-in start end)) That function might not remove any existing breakpoint highlights (which normally would get removed by the call to edebug--overlay-breakpoints-remove, which takes the value of the 'edebug property (indirectly) as an argument. I've tried vaguely to create a situation where the highlights get left in place, but haven't managed it yet. -- Alan Mackenzie (Nuremberg, Germany). ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-01 8:26 bug#40992: 27.0.90; Evaluating a function while using edebug breaks Phillip Lord 2020-05-01 15:56 ` Alan Mackenzie @ 2020-05-04 1:27 ` Pouar Dragon 2020-05-04 18:34 ` Alan Mackenzie 1 sibling, 1 reply; 16+ messages in thread From: Pouar Dragon @ 2020-05-04 1:27 UTC (permalink / raw) To: 40992 There's still some code in edebug.el that calls edebug--overlay-breakpoints-remove and edebug--overlay-breakpoints -- Pouar Dragon My GPG Keys: https://keybase.io/pouar ^ permalink raw reply [flat|nested] 16+ messages in thread
* bug#40992: 27.0.90; Evaluating a function while using edebug breaks 2020-05-04 1:27 ` Pouar Dragon @ 2020-05-04 18:34 ` Alan Mackenzie 0 siblings, 0 replies; 16+ messages in thread From: Alan Mackenzie @ 2020-05-04 18:34 UTC (permalink / raw) To: Pouar Dragon; +Cc: 40992 Hello, Pouar. On Sun, May 03, 2020 at 20:27:16 -0500, Pouar Dragon wrote: > There's still some code in edebug.el that calls > edebug--overlay-breakpoints-remove and edebug--overlay-breakpoints > -- > Pouar Dragon > My GPG Keys: https://keybase.io/pouar Yes, you're right. I'd neglected to compile the file under emacs -Q, so didn't spot the errors. It should be fixed, now. Sorry about the annoyance this must have caused, and thanks for reporting it. -- Alan Mackenzie (Nuremberg, Germany). ^ permalink raw reply [flat|nested] 16+ messages in thread
end of thread, other threads:[~2020-05-11 20:16 UTC | newest] Thread overview: 16+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2020-05-01 8:26 bug#40992: 27.0.90; Evaluating a function while using edebug breaks Phillip Lord 2020-05-01 15:56 ` Alan Mackenzie 2020-05-01 17:33 ` Alan Mackenzie 2020-05-01 18:02 ` Eli Zaretskii 2020-05-02 1:43 ` Lars Ingebrigtsen 2020-05-02 3:05 ` Noam Postavsky 2020-05-02 7:10 ` Eli Zaretskii 2020-05-02 13:34 ` Alan Mackenzie 2020-05-02 13:57 ` Eli Zaretskii 2020-05-03 11:55 ` Alan Mackenzie 2020-05-03 12:13 ` Alan Mackenzie 2020-05-02 21:54 ` Phillip Lord 2020-05-11 20:16 ` Alan Mackenzie 2020-05-02 13:14 ` Alan Mackenzie 2020-05-04 1:27 ` Pouar Dragon 2020-05-04 18:34 ` Alan Mackenzie
Code repositories for project(s) associated with this external index https://git.savannah.gnu.org/cgit/emacs.git https://git.savannah.gnu.org/cgit/emacs/org-mode.git This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.