Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Tempfile is being unlinked in the middle of a program even if I set :!unlink #18

Open
MasterDuke17 opened this issue Aug 21, 2016 · 3 comments

Comments

@MasterDuke17
Copy link

The Perl 6 version of bisectable writes the code to bisect into a temp file created with File::Temp. However, sometimes during the bisection the temp file gets unlinked (even if I set :!unlink). I've straced the bot and I can see it reading the file for each step of the bisection, and then randomly right in the middle is an unlink, so of course the next bisect steps freak out because the file they've been told to run doesn't exist.

@MasterDuke17
Copy link
Author

So it turns out I was disabling unlinking on the wrong tempfile. Correcting that fixes my program, but the documentation for tempfile is incorrect when it says "Automatically unlink files at end of program (this is the default)". According to https://docs.perl6.org/type/Metamodel$COLON$COLONFinalization#index-entry-DESTROY, "[...] DESTROY submethods are called (if they exist) when an object is garbage-collected."

@AlexDaniel
Copy link

This is actually a serious issue.

@MasterDuke17
Copy link
Author

I didn't make it clear in my previous comment. Depending on DESTROY is problematic because there is no requirement for DESTROY to be called during program exit.

https://irclog.perlgeek.de/perl6/2016-09-26#i_13285049
16:11 jnthn jkramer: DESTROY exists, but you have on promises about when it will be called or, if your object lives until close the program exit, if it will be called at all.
16:11 *no promises
16:13 jnthn (To be specific, it gets run shortly after the GC determines the object can be freed.)

https://irclog.perlgeek.de/perl6/2016-03-15#i_12190212
20:08 jnthn MadcapJake`: No, we don't promise to run DESTROY blocks at exit.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants