unofficial mirror of help-gnu-emacs@gnu.org
 help / color / mirror / Atom feed
* Function value changes after running function?
@ 2021-02-05  2:41 okamsn+emacs-help
  2021-02-05  3:16 ` Emanuel Berg via Users list for the GNU Emacs text editor
  2021-02-05 15:24 ` Stefan Monnier
  0 siblings, 2 replies; 6+ messages in thread
From: okamsn+emacs-help @ 2021-02-05  2:41 UTC (permalink / raw)
  To: help-gnu-emacs

Hello,

On Emacs 27.1, I've learned that a function using a macro I wrote raises 
an error after running the function a second time.

The function is

     (defun mu4e:other-path ()
       "Return load-path for mu4e.
     This assumes that you're on guix."
       (loopy (with (regexp "Documents")
     	       (base-dir (f-full "~/")))
     	 ((list file (directory-files base-dir))
     	  (expr full-path (f-expand file base-dir)))))

and running it once from my home directory returns nil, as expected. 
However, if run again, it raises an error

     ***  Symbol’s value as variable is void: base-dir

I've found after evaluating the function definition, `symbol-function' 
reports the definition as

     (closure
      (t)
      nil "Return load-path for mu4e.
     This assumes that you're on guix."
      (loopy
       (with
        (regexp "Documents")
        (base-dir
         (f-full "~/")))
       ((list file
              (directory-files base-dir))
        (expr full-path
              (f-expand file base-dir)))))

where `base-dir` is defined, but if I run it again, the function 
definition is reported again as

     (closure
      (t)
      nil "Return load-path for mu4e.
     This assumes that you're on guix."
      (loopy
       (with
        (regexp "Documents"))
       ((list file
              (directory-files base-dir))
        (expr full-path
              (f-expand file base-dir)))))

where `base-dir` is no longer defined.

Why would the function definition be changed after running the function? 
  Is that a known problem with macros, or with Emacs 27.1?  I haven't 
seen this on Emacs 28.

Thank you.




^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Function value changes after running function?
  2021-02-05  2:41 Function value changes after running function? okamsn+emacs-help
@ 2021-02-05  3:16 ` Emanuel Berg via Users list for the GNU Emacs text editor
  2021-02-05 15:34   ` okamsn+emacs-help
  2021-02-05 15:24 ` Stefan Monnier
  1 sibling, 1 reply; 6+ messages in thread
From: Emanuel Berg via Users list for the GNU Emacs text editor @ 2021-02-05  3:16 UTC (permalink / raw)
  To: help-gnu-emacs

okamsn+emacs-help wrote:

>     (defun mu4e:other-path ()
>       "Return load-path for mu4e.
>     This assumes that you're on guix."
>       (loopy (with (regexp "Documents")
>     	       (base-dir (f-full "~/")))
>     	 ((list file (directory-files base-dir))
>     	  (expr full-path (f-expand file base-dir)))))

Uhm, what language is that? You get a new Elisp with Guix
as well?

-- 
underground experts united
http://user.it.uu.se/~embe8573
https://dataswamp.org/~incal




^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Function value changes after running function?
  2021-02-05  2:41 Function value changes after running function? okamsn+emacs-help
  2021-02-05  3:16 ` Emanuel Berg via Users list for the GNU Emacs text editor
@ 2021-02-05 15:24 ` Stefan Monnier
  1 sibling, 0 replies; 6+ messages in thread
From: Stefan Monnier @ 2021-02-05 15:24 UTC (permalink / raw)
  To: help-gnu-emacs

> Why would the function definition be changed after running the function? 

Sounds like a bug in `loopy` (which appears to be a macro and which
probably does something like `nreverse` on some part of its arguments).


        Stefan




^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Function value changes after running function?
  2021-02-05  3:16 ` Emanuel Berg via Users list for the GNU Emacs text editor
@ 2021-02-05 15:34   ` okamsn+emacs-help
  2021-02-05 15:48     ` Stefan Monnier
  0 siblings, 1 reply; 6+ messages in thread
From: okamsn+emacs-help @ 2021-02-05 15:34 UTC (permalink / raw)
  To: help-gnu-emacs

On 2/4/21 10:16 PM, Emanuel Berg via Users list for the GNU Emacs text 
editor wrote:
> 
> okamsn+emacs-help wrote:
> 
>>      (defun mu4e:other-path ()
>>        "Return load-path for mu4e.
>>      This assumes that you're on guix."
>>        (loopy (with (regexp "Documents")
>>      	       (base-dir (f-full "~/")))
>>      	 ((list file (directory-files base-dir))
>>      	  (expr full-path (f-expand file base-dir)))))
> 
> Uhm, what language is that? You get a new Elisp with Guix
> as well?
> 
> --
> underground experts united
> http://user.it.uu.se/~embe8573
> https://dataswamp.org/~incal
> 
> 

No, I wrote a macro like `cl-loop` here:

https://github.com/okamsn/loopy

I received a bug report that said that the above function would raise an 
error after running a second time here:

https://github.com/okamsn/loopy/issues/17

For some reason, the value returned by `symbol-function` changes after 
the function is invoked the first time. Just using the macro itself does 
not signal an error.




^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Function value changes after running function?
  2021-02-05 15:34   ` okamsn+emacs-help
@ 2021-02-05 15:48     ` Stefan Monnier
  2021-02-05 17:27       ` Okam
  0 siblings, 1 reply; 6+ messages in thread
From: Stefan Monnier @ 2021-02-05 15:48 UTC (permalink / raw)
  To: help-gnu-emacs

> No, I wrote a macro like `cl-loop` here:
>
> https://github.com/okamsn/loopy
>
> I received a bug report that said that the above function would raise an 
> error after running a second time here:

In the current situation, the problem is:

    (setq loopy--main-body (nreverse loopy--main-body)
          loopy--with-vars (nreverse loopy--with-vars))

which reverses the "with vars" received as arguments.
If you replace `nreverse` with `reverse` here, this particular problem
should disappear.

This said, this `nreverse` reverses the order of the bindings in (with ....)
which maybe isn't what you intended (I suspect that the `nreverse` here
is meant to reverse the bindings added to `loopy--with-vars` via
`push`).
So maybe a better solution is to replace

        (setq loopy--with-vars (cdr arg)))

with

        (setq loopy--with-vars (reverse (cdr arg))))

so that the subsequent `nreverse` puts them back in the original order.


        Stefan




^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Function value changes after running function?
  2021-02-05 15:48     ` Stefan Monnier
@ 2021-02-05 17:27       ` Okam
  0 siblings, 0 replies; 6+ messages in thread
From: Okam @ 2021-02-05 17:27 UTC (permalink / raw)
  To: help-gnu-emacs

On 2/5/21 10:48 AM, Stefan Monnier wrote:
> 
>> No, I wrote a macro like `cl-loop` here:
>>
>> https://github.com/okamsn/loopy
>>
>> I received a bug report that said that the above function would raise an
>> error after running a second time here:
> 
> In the current situation, the problem is:
> 
>      (setq loopy--main-body (nreverse loopy--main-body)
>            loopy--with-vars (nreverse loopy--with-vars))
> 
> which reverses the "with vars" received as arguments.
> If you replace `nreverse` with `reverse` here, this particular problem
> should disappear.
> 
> This said, this `nreverse` reverses the order of the bindings in (with ....)
> which maybe isn't what you intended (I suspect that the `nreverse` here
> is meant to reverse the bindings added to `loopy--with-vars` via
> `push`).
> So maybe a better solution is to replace
> 
>          (setq loopy--with-vars (cdr arg)))
> 
> with
> 
>          (setq loopy--with-vars (reverse (cdr arg))))
> 
> so that the subsequent `nreverse` puts them back in the original order.
> 
> 
>          Stefan
> 
> 

Thank you.  That does prevent the error, but would you please explain 
(or point me to where I could learn) how `nreverse` causes this error?

Why would invoking the function a second time change what the function 
does? The return value of `symbol-function` makes it look like the 
function passes different arguments to the macro after the first 
invocation. Is that a misleading return value, or is that actually 
happening? If that is what happens, why does that happen?




^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2021-02-05 17:27 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2021-02-05  2:41 Function value changes after running function? okamsn+emacs-help
2021-02-05  3:16 ` Emanuel Berg via Users list for the GNU Emacs text editor
2021-02-05 15:34   ` okamsn+emacs-help
2021-02-05 15:48     ` Stefan Monnier
2021-02-05 17:27       ` Okam
2021-02-05 15:24 ` Stefan Monnier

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).