GNU bug report logs -
#60996
29.0.60; Native compile fails to remove temp file for trampoline
Previous Next
Reported by: Andy Moreton <andrewjmoreton <at> gmail.com>
Date: Sat, 21 Jan 2023 22:13:02 UTC
Severity: normal
Found in version 29.0.60
Done: Eli Zaretskii <eliz <at> gnu.org>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
On Fri 27 Jan 2023, Andrea Corallo wrote:
> Eli Zaretskii <eliz <at> gnu.org> writes:
>
>>> Cc: andrewjmoreton <at> gmail.com, 60996 <at> debbugs.gnu.org
>>> Date: Thu, 26 Jan 2023 20:38:45 +0200
>>> From: Eli Zaretskii <eliz <at> gnu.org>
>>>
>>> > The only case where we might do that AFAIR is when
>>> > `inhibit-automatic-native-compilation' is used. This was the infamous
>>> > mechanism that was installed by Lars where, if I'm not wrong, we are
>>> > supposed to compile a trampoline, load it, and remove it to pretend we
>>> > didn't compiled anything :x
>>>
>>> OK, this seems to be what is happening here, because we compile the
>>> trampoline to a temporary directory. Otherwise, I don't see why we
>>> would do that, and why we would delete a trampoline we just compiled.
Sorry that this bug report has consumed so much of everyone's time.
After a while where I could not reproduce the problem, a new rebuild on
master provoked it again.
From more experimentation, the recipe seems to be:
1) Delete the "subr-trampoline-*.eln" files from the eln-cache dir
2) Start emacs with inhibit-automatic-native-compilation non-nil
>> Actually, I don't think I see where we delete the trampoline that we
>> generated when inhibit-automatic-native-compilation is non-nil. Can
>> you point me to the code which does that?
>
> Sure, the code behind this mechanism is not straightforward and took me
> a bit to decipher it as well yesterday.
Perhaps an opportunity to refactor it at some point, to make it easier
for future maintainers to reason about this code.
> In `comp-trampoline-compile' when `inhibit-automatic-native-compilation'
> is not nil we invoke `comp--native-compile' with the `output' parameter
> set to null.
>
> `comp--native-compile' after compiling does two things:
>
> 1- If the compilation input was a file returns the .eln filename
>
> 2- If the input was a lambda (the case for trampolines) it does return
> the compiled subr. To do that it preforms a load of the eln before
> returning.
>
> So in general what `comp--native-compile' returns is:
>
> (if (stringp function-or-file)
> data
> ;; So we return the compiled function.
> (native-elisp-load data)))
>
> But at the end of `comp--native-compile' this when was added
>
> (when (and (not (stringp function-or-file))
> (not output)
> comp-ctxt
> (comp-ctxt-output comp-ctxt)
> (file-exists-p (comp-ctxt-output comp-ctxt)))
> (delete-file (comp-ctxt-output comp-ctxt)))
>
>
> Took me a while to actually realize this is the unwindform of an
> enormous `unwind-protect'. Anyway this is the code that when `output'
> is null (the case for trampolines) tries to performs the file
> deletetion.
I think you have identified the cause of this issue - as the .eln has
been loaded, the delete-file will never succeed on Windows.
I know Eli is not a fan of inhibit-automatic-native-compilation, but I
think there is a place for it. Users may want to use precompiled .eln
files but not waste effort on native compiling other code.
If this error can be suppressed such that the only effect is for a temp
file to be left around, that is a reasonable solution to this.
AndyM
This bug report was last modified 2 years and 112 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.