unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* Something weird with when-let*/if-let*
@ 2017-10-14 12:10 Eric Abrahamsen
  2017-10-14 13:10 ` Noam Postavsky
  0 siblings, 1 reply; 11+ messages in thread
From: Eric Abrahamsen @ 2017-10-14 12:10 UTC (permalink / raw)
  To: emacs-devel

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




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

end of thread, other threads:[~2017-10-16  3:23 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-10-14 12:10 Something weird with when-let*/if-let* Eric Abrahamsen
2017-10-14 13:10 ` 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

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

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