all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
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




             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.