-
Notifications
You must be signed in to change notification settings - Fork 30.1k
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
vm module should expose V8::ScriptCompiler::CreateCodeCache #20052
Comments
Note that the vm module already uses CreateCodeCache to emulate the deprecated kProduceCodeCache option. |
|
Now that I think about this, we should not actually need to pass the string. I'll fix this. |
@hashseed i'm finally getting to this 🎉. is the failure of producing a code cache something that can be observed with a TryCatch or should i just make our own "creating code cache failed" error |
We don't throw any exception here. If anything, we'd just return nullptr. Not sure what the best way to report that is. |
@hashseed i found this interesting behaviour while messing with the existing code (node 10.0.0 release): |
@devsnek I observed the same behavior a while ago. My conjecture is that V8 caches the script corresponding to a specific string, and doesn’t bother checking the validity if it doesn’t need to compile it. |
i don't mind v8 caching but it doesn't reflect the c++ api and is causing me great confusion, specially since i never gave it a valid cache which i assume means its just creating a cache anyway? |
Yeah that's because the first time the cache was rejected, V8 compiled it and cached the result in memory. Further compiles simply hit the in-memory cache and V8 does not bother with the provided code cache. |
@hashseed so just to make sure i understand:
assuming the above is accurate, how can node tell v8 not to do that or is there a better way we can expose code caches? maybe |
V8 is not helping out the user. It's just that V8 has two tiers of caches, and the code cache is just the second tier. Is it a big issue that V8 would not reject the same code cache twice? |
@hashseed it just isn't providing a consistent interface. v8 doing fancy cache stuff is fine but it doesn't work with the API we have exposed. |
Is it required that an API returns the same result every time? The flag is not called Also, if V8 does not set the reject flag, it really doesn't break anything if the user provides the same invalid data the next time. I do see where you are coming from, but I don't think it's worth removing the in-memory caching tier (which arguably helps a lot) just to satisfy this requirement. |
it's not the end of the world I suppose, just a difference in opinion (I prefer control over speed). I think for now since I changed the name to "codeCacheUsed" it's a bit less confusing anyway |
You mean the API change of Or did you mean using the new |
Great! Thanks for the review! |
Can this be closed since #20300 was merged? |
Previously, V8 can only create code cache as part of compiling a script. Now V8 can created code cache from an UnboundScript at arbitrary time after compilation.
The advantages are:
The text was updated successfully, but these errors were encountered: