GNU bug report logs -
#40692
28.0.50; Constant list modified inside function
Previous Next
Reported by: Ivan Andrus <darthandrus <at> gmail.com>
Date: Fri, 17 Apr 2020 23:46:02 UTC
Severity: normal
Found in version 28.0.50
Done: Lars Ingebrigtsen <larsi <at> gnus.org>
Bug is archived. No further changes may be made.
Full log
Message #11 received at 40692 <at> debbugs.gnu.org (full text, mbox):
On Fri, 17 Apr 2020 17:45:12 -0600
Ivan Andrus wrote:
> Starting from Emacs -Q (I am building off of trunk, but my brother verified the same behavior in 26.3), if I evaluate the following code I get an error the second time I call withdraw.
>
> (defmacro show (var)
> `(message ,(format "%S %%S" var) ,var))
>
> (defun my-test-fun (amount params)
> (when (memq 'tricked-ya params)
> (error "What happened here?"))
> (show amount)
> (show params)
> (setcdr (cdr params) (list 'tricked-ya))
> (show params))
>
> (defun fun-withdraw (amount)
> (my-test-fun amount
> `((amount . , amount)
> (const . some-constant))))
>
> (fun-withdraw 12)
>
> (fun-withdraw 12) ;; The second time it's called it will error because the "constant" list was modified.
>
>
> I believe this is the root cause of a bug in magit/forge https://github.com/magit/forge/issues/267 in which all subsequent pull requests created have the same name. The maintainer of magit/forge (tarsius) was unable to reproduce that bug, so I tried my hand at creating a minimal test case, and I was able to get it down to this.
>
> Now, I understand reference semantics of lists in general, but it
> seems like this should be different. If this behavior is intentional,
I think it is, although I admit I was confused by it, too, as I've
somehow come to believe that e.g. `(list) macroexpands to (list 'list),
but that's not the case: it expands to '(list).
> what's the best way to for creation of a new list every time so that
> functions using the alist don't have to worry about not changing the
> list?
If you change the backquoted form in `fun-withdraw' to
(list `(amount . ,amount)
'(const . some-constant))
it works as desired.
This bug report was last modified 3 years and 324 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.