* bug#411: 23.0.60; flet and byte-compilation
@ 2008-06-14 15:17 Michael Heerdegen
0 siblings, 0 replies; 12+ messages in thread
From: Michael Heerdegen @ 2008-06-14 15:17 UTC (permalink / raw)
To: emacs-pretest-bug
A much simplified version of the original problem, but still a bug:
Create a file test.el with the following contents:
(defun f (x y)
(flet ((+ (a b) (- a b)))
(+ x y)))
Bytecompile it and load f.elc.
Evaluate the expression (f 1 2). This should yield -1, but the result
will be 3.
In GNU Emacs 23.0.60.2 (i686-pc-linux-gnu, GTK+ Version 2.8.20)
of 2008-05-17 on debian
Windowing system distributor `The X.Org Foundation', version 11.0.70101000
Important settings:
value of $LC_ALL: nil
value of $LC_COLLATE: nil
value of $LC_CTYPE: nil
value of $LC_MESSAGES: nil
value of $LC_MONETARY: nil
value of $LC_NUMERIC: nil
value of $LC_TIME: C
value of $LANG: de_DE.UTF-8
value of $XMODIFIERS: nil
locale-coding-system: utf-8-unix
default-enable-multibyte-characters: t
Major mode: Help
Minor modes in effect:
hl-line-mode: t
minibuffer-indicate-depth-mode: t
shell-dirtrack-mode: t
display-time-mode: t
msb-mode: t
mouse-sel-mode: t
icomplete-mode: t
show-paren-mode: t
recentf-mode: t
auto-image-file-mode: t
partial-completion-mode: t
tooltip-mode: t
mouse-wheel-mode: t
menu-bar-mode: t
file-name-shadow-mode: t
global-font-lock-mode: t
font-lock-mode: t
blink-cursor-mode: t
global-auto-composition-mode: t
auto-composition-mode: t
auto-encryption-mode: t
auto-compression-mode: t
column-number-mode: t
line-number-mode: t
transient-mark-mode: t
view-mode: t
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#411: 23.0.60; flet and byte-compilation
@ 2008-09-15 8:04 Glenn Morris
0 siblings, 0 replies; 12+ messages in thread
From: Glenn Morris @ 2008-09-15 8:04 UTC (permalink / raw)
To: 411
Michael Heerdegen wrote:
> (defun f (x y)
> (flet ((+ (a b) (- a b)))
> (+ x y)))
>
> Bytecompile it [...]
>
> Evaluate the expression (f 1 2). This should yield -1, but the result
> will be 3.
Some (much delayed) observations:
1) it works to use `labels' instead of `flet'
2) it works to comment out the line in bytecomp.el
(byte-defop-compiler (+ byte-plus) byte-compile-associative)
I guess byte-compile-associative mangles the '(+ x y) form without
regard for the redefinition in effect. I don't know if that is
fixable, or should be a documented caveat with regards to primitives.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#411: 23.0.60; flet and byte-compilation
@ 2008-09-25 2:16 Chong Yidong
2008-09-25 17:45 ` Richard M. Stallman
0 siblings, 1 reply; 12+ messages in thread
From: Chong Yidong @ 2008-09-25 2:16 UTC (permalink / raw)
To: Stefan Monnier; +Cc: 411
Glenn Morris <rgm@gnu.org> wrote:
> > (defun f (x y)
> > (flet ((+ (a b) (- a b)))
> > (+ x y)))
> >
> > Bytecompile it [...]
> >
> > Evaluate the expression (f 1 2). This should yield -1, but the result
> > will be 3.
>
> it works to comment out the line in bytecomp.el
>
> (byte-defop-compiler (+ byte-plus) byte-compile-associative)
>
> I guess byte-compile-associative mangles the '(+ x y) form without
> regard for the redefinition in effect. I don't know if that is
> fixable, or should be a documented caveat with regards to primitives.
I don't see how to fix this, and my inclination is to just document this
limitation in the docstring of `flet'. Stefan, WDYT?
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#411: 23.0.60; flet and byte-compilation
2008-09-25 2:16 Chong Yidong
@ 2008-09-25 17:45 ` Richard M. Stallman
2008-09-26 18:48 ` Glenn Morris
0 siblings, 1 reply; 12+ messages in thread
From: Richard M. Stallman @ 2008-09-25 17:45 UTC (permalink / raw)
To: Chong Yidong, 411
> I guess byte-compile-associative mangles the '(+ x y) form without
> regard for the redefinition in effect. I don't know if that is
> fixable, or should be a documented caveat with regards to primitives.
I don't see how to fix this, and my inclination is to just document this
limitation in the docstring of `flet'. Stefan, WDYT?
I am not sure if it is worth fixing, but one possible way
One possible way to fix it is to make the byte compiler check
that the function has a subr definition as usual.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#411: 23.0.60; flet and byte-compilation
2008-09-25 17:45 ` Richard M. Stallman
@ 2008-09-26 18:48 ` Glenn Morris
2008-10-20 1:05 ` Glenn Morris
0 siblings, 1 reply; 12+ messages in thread
From: Glenn Morris @ 2008-09-26 18:48 UTC (permalink / raw)
To: rms; +Cc: 411, Chong Yidong
"Richard M. Stallman" wrote:
> One possible way to fix it is to make the byte compiler check
> that the function has a subr definition as usual.
When I tried to do this naively in byte-compile-associative, it did
not work, because the compiler does not evaluate the (fset '+ ...)
redefinition at compile-time.
Perhaps flet need a byte-compiler handler that looks at the functions
being bound in the flet, and temporarily (while the flet body is being
compiled) removes any special byte-compile properties they might have.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#411: 23.0.60; flet and byte-compilation
2008-09-26 18:48 ` Glenn Morris
@ 2008-10-20 1:05 ` Glenn Morris
2008-10-23 2:41 ` Glenn Morris
0 siblings, 1 reply; 12+ messages in thread
From: Glenn Morris @ 2008-10-20 1:05 UTC (permalink / raw)
To: 411; +Cc: Chong Yidong, rms
Glenn Morris wrote:
> Perhaps flet need a byte-compiler handler that looks at the functions
> being bound in the flet, and temporarily (while the flet body is being
> compiled) removes any special byte-compile properties they might have.
The problem with this is that there doesn't seem to be a way to
specify byte-compile handlers for macros (except macros at top-level).
The compile functions always just call `macroexpand' before doing
anything else.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#411: 23.0.60; flet and byte-compilation
2008-10-20 1:05 ` Glenn Morris
@ 2008-10-23 2:41 ` Glenn Morris
2012-10-31 3:56 ` Glenn Morris
0 siblings, 1 reply; 12+ messages in thread
From: Glenn Morris @ 2008-10-23 2:41 UTC (permalink / raw)
To: 411; +Cc: Chong Yidong, rms
severity 411 wishlist
stop
Well, I can't make it work, so I have made such things throw an error
when byte-compiled. I am leaving making it work open as a wishlist item.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#411: 23.0.60; flet and byte-compilation
2008-10-23 2:41 ` Glenn Morris
@ 2012-10-31 3:56 ` Glenn Morris
2012-10-31 13:58 ` Stefan Monnier
0 siblings, 1 reply; 12+ messages in thread
From: Glenn Morris @ 2012-10-31 3:56 UTC (permalink / raw)
To: 411-done
Version: 24.3
It seems to work (somehow) with the new hotness cl-lib and cl-flet
rather than the old and busted cl and flet.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#411: 23.0.60; flet and byte-compilation
2012-10-31 3:56 ` Glenn Morris
@ 2012-10-31 13:58 ` Stefan Monnier
2012-10-31 15:01 ` Drew Adams
0 siblings, 1 reply; 12+ messages in thread
From: Stefan Monnier @ 2012-10-31 13:58 UTC (permalink / raw)
To: 411
> It seems to work (somehow) with the new hotness cl-lib and cl-flet
> rather than the old and busted cl and flet.
Indeed, because `cl-flet' is a different beast, much more like `labels'
than like CL's `flet' (it is lexically scoped).
Stefan
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#411: 23.0.60; flet and byte-compilation
2012-10-31 13:58 ` Stefan Monnier
@ 2012-10-31 15:01 ` Drew Adams
2012-10-31 16:06 ` Stefan Monnier
0 siblings, 1 reply; 12+ messages in thread
From: Drew Adams @ 2012-10-31 15:01 UTC (permalink / raw)
To: 'Stefan Monnier', 411
> Indeed, because `cl-flet' is a different beast, much more
> like `labels' than like CL's `flet' (it is lexically scoped).
Just out of curiosity (and I haven't followed this thread), why?
Why make `cl-flet' less like CL's `flet'? If you want `labels'-like behavior,
why not define `cl-labels' for that?
Or call this `foobar' or whatever. Calling it `cl-flet' seems the more
misleading the farther the behavior gets from CL's `flet' - no?
Sounds like this is a step backward - in terms of possible confusion, at least.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#411: 23.0.60; flet and byte-compilation
2012-10-31 15:01 ` Drew Adams
@ 2012-10-31 16:06 ` Stefan Monnier
2012-10-31 16:13 ` Drew Adams
0 siblings, 1 reply; 12+ messages in thread
From: Stefan Monnier @ 2012-10-31 16:06 UTC (permalink / raw)
To: Drew Adams; +Cc: 411
>> Indeed, because `cl-flet' is a different beast, much more
>> like `labels' than like CL's `flet' (it is lexically scoped).
> Just out of curiosity (and I haven't followed this thread), why?
Because:
- CL's `flet' is completely unlike Common-Lisp's `flet'.
- CL's `flet' is more like defadvice, except (dynamically) scoped and
without adjusting the docstring to at least mention that something
fishy is going on.
IOW because CL's `flet' does something we generally want to discourage.
Or rather, because CL's `flet' was a mistake, hence its being
marked obsolete.
> Or call this `foobar' or whatever. Calling it `cl-flet' seems the more
> misleading the farther the behavior gets from CL's `flet' - no?
`cl-flet' is a (hopefully) faithful implementation of Common-Lisp's
`flet', so I think it deserves its name.
Stefan
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#411: 23.0.60; flet and byte-compilation
2012-10-31 16:06 ` Stefan Monnier
@ 2012-10-31 16:13 ` Drew Adams
0 siblings, 0 replies; 12+ messages in thread
From: Drew Adams @ 2012-10-31 16:13 UTC (permalink / raw)
To: 'Stefan Monnier'; +Cc: 411
> `cl-flet' is a (hopefully) faithful implementation of Common-Lisp's
> `flet', so I think it deserves its name.
Sorry, I misunderstood your references to "CL" to mean Common Lisp itself,
rather than the cl.el stuff. Sorry for the noise.
^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2012-10-31 16:13 UTC | newest]
Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-06-14 15:17 bug#411: 23.0.60; flet and byte-compilation Michael Heerdegen
-- strict thread matches above, loose matches on Subject: below --
2008-09-15 8:04 Glenn Morris
2008-09-25 2:16 Chong Yidong
2008-09-25 17:45 ` Richard M. Stallman
2008-09-26 18:48 ` Glenn Morris
2008-10-20 1:05 ` Glenn Morris
2008-10-23 2:41 ` Glenn Morris
2012-10-31 3:56 ` Glenn Morris
2012-10-31 13:58 ` Stefan Monnier
2012-10-31 15:01 ` Drew Adams
2012-10-31 16:06 ` Stefan Monnier
2012-10-31 16:13 ` Drew Adams
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.