GNU bug report logs -
#60450
30.0.50; Strange behavior of compiler macros in *scratch*
Previous Next
Reported by: Gerd Möllmann <gerd.moellmann <at> gmail.com>
Date: Sat, 31 Dec 2022 13:23:01 UTC
Severity: normal
Found in version 30.0.50
Fixed in version 30.1
Done: Gerd Möllmann <gerd.moellmann <at> gmail.com>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
> The doc string of cl-define-compiler-macro says
> "This is like ‘defmacro’, but macro expansion occurs only if the call to
> FUNC is compiled (i.e., not interpreted)."
`cl-define-compiler-macro` is built on top of the "new" ELisp compiler
macro feature. I think that feature is documented vaguely (poorly?)
enough that it does allow expansion (or not) for interpreted code.
> C-j is bound to eval-print-last-sexp, which I wouldn't expect to compile
> anything, and its doc string doesn't mention anything AFAICS. Not sure if
> that's a bug in the code or something missing in the docs.
Trying to distinguish those calls to `macroexpand-all` which come from
the compiler from those that come from elsewhere doesn't seem worth the
trouble, so I'd rather consider it as a doc bug.
The doc should also make it clear that contrary to `defmacro` there is
no guarantee that it will be called (nor *when* it's called).
Stefan
This bug report was last modified 1 year and 97 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.