From: Eric Abrahamsen <eric@ericabrahamsen.net>
To: emacs-devel@gnu.org
Subject: Something weird with when-let*/if-let*
Date: Sat, 14 Oct 2017 14:10:38 +0200 [thread overview]
Message-ID: <877evy2am9.fsf@ericabrahamsen.net> (raw)
I've seen this in two different contexts now: using the starred versions
of when-let or if-let results in a `invalid-function' error on the first
let-binding, as if something is trying to treat the whole binding form
as a function.
I got one report on EBDB about this function:
(cl-defmethod ebdb-record-uuid ((record ebdb-record))
(if-let* ((uuid-field (slot-value record 'uuid)))
(slot-value uuid-field 'uuid)))
Where the error was:
"(invalid-function (uuid-field (slot-value record (quote uuid))))"
(https://github.com/girzel/ebdb/issues/54#issuecomment-335033393)
And Julien Cubizolles just reported to the Gnus list that this code
chunk from nnimap.el:
(when-let* ((result (eval accept-form)))
(nnimap-change-group group server)
(nnimap-delete-article article)
result)
Was producing a similar error:
"Invalid function: (result (eval accept-form))"
Switching to the un-starred version fixed the problem.
I tried this out on the emacs-26 and master branches, and I can't raise
the error. Julien's on master, with the EBDB reporter it was unclear.
The macroexpansion looks fine, of course.
I guess I should just make a bug report...
Eric
next reply other threads:[~2017-10-14 12:10 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-10-14 12:10 Eric Abrahamsen [this message]
2017-10-14 13:10 ` Something weird with when-let*/if-let* Noam Postavsky
2017-10-14 13:12 ` Eric Abrahamsen
2017-10-14 13:47 ` Noam Postavsky
2017-10-14 13:49 ` Noam Postavsky
2017-10-14 19:13 ` Eric Abrahamsen
2017-10-14 19:55 ` Noam Postavsky
2017-10-14 20:03 ` Eric Abrahamsen
2017-10-14 20:05 ` Eric Abrahamsen
2017-10-14 20:42 ` Stefan Monnier
2017-10-16 3:23 ` Eric Abrahamsen
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
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=877evy2am9.fsf@ericabrahamsen.net \
--to=eric@ericabrahamsen.net \
--cc=emacs-devel@gnu.org \
/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 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.