GNU bug report logs - #78608
31.0.50; Todo mode bug revealed by setq-default change

Previous Next

Package: emacs;

Reported by: Stephen Berman <stephen.berman <at> gmx.net>

Date: Tue, 27 May 2025 15:55:02 UTC

Severity: normal

Found in version 31.0.50

Done: Stephen Berman <stephen.berman <at> gmx.net>

Full log


Message #25 received at 78608 <at> debbugs.gnu.org (full text, mbox):

From: Eli Zaretskii <eliz <at> gnu.org>
To: stephen.berman <at> gmx.net, Stefan Monnier <monnier <at> iro.umontreal.ca>
Cc: 78608 <at> debbugs.gnu.org
Subject: Re: bug#78608: 31.0.50; Todo mode bug revealed by setq-default change
Date: Wed, 28 May 2025 21:28:22 +0300
> From: Stefan Monnier <monnier <at> iro.umontreal.ca>
> Cc: stephen.berman <at> gmx.net,  78608 <at> debbugs.gnu.org
> Date: Wed, 28 May 2025 12:59:52 -0400
> 
> >>  * Incompatible Lisp Changes in Emacs 31.1
> >>  
> >> +** 'setq-local' computes the value before making the variable local.
> >> +The previous code made the variable buffer local before
> >> +computing the value to assign to it.
> >> +This bug fix is a subtle change to the semantics which should make
> >> +no difference to the vast majority of uses but can occasionally affect
> >> +code in surprising ways if the computation of the value refers to the
> >> +variable.
> >
> > I think this should describe the case upon which Stephen stumbled:
> > code which uses setq-local inside a let-binding (perhaps an implicit
> > one, such as the one the various with-SOMETHING macros do), and
> > expects the buffer-local value to stay after the let-binding is
> > exited.
> 
> Maybe you should write it, then because you seem to understand that case
> better than I (I did look at the code to try and figure out what was the
> specific origin of the problem but .. failed).  But note that it's only
> one case that can be affected, there are others.

Stephen, would you mind explaining in more detail what in that commit
caused the regression on the master branch?  I'd like us all to be on
the same page before we decide how (and whether) to document it.

Thanks.




This bug report was last modified 20 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.