-
Notifications
You must be signed in to change notification settings - Fork 49
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
feat: optimize compilation through preprocessing and smarter caching #197
Comments
is this a strict requirement for this feature or should we recommend using vm.getCode? |
using
it should not. I don't think we should mess with metadata, so src/ contracts are not touched at all |
Should this be the first use case of sulk @DaniPopes / something to prio? |
A lot of the compilation overhead is coming from the need to compile all project's tests on every change to one of the src/ contracts. Ideally, we should only compile test contracts when interface of contracts they depend on changes, which doesn't happen often.
This can be made possible by avoiding solc mechanism of bytecode linking. Instead of linking bytecode at compile-time, we can link it at runtime, and we already have cheatcodes for that (
deployCode
,getCode
).Basic idea is to add a preprocessor translating all
type(Contract).creationCode
intovm.getCode
invocations, and allnew Contract(...)
intovm.deployCode
.However, preprocessor on its own wouldn't let us skip compilation due to how caching works. We'll mark test file as dirty even if non-interface change is made to a contract. To address this, we would need to customize our caching logic by only marking test contracts as dirty if any of their dependencies had a non-interface change.
Implementation
Proposing an initial simple implementation of this preprocessing. It can be enabled as an opt-in, and improved over time.
Updated compilation pipeline
Before each compiler invocation, if we're compiling any test files, we'll do additional solc invocation to obtain AST for them and replace all
creationCode
/new
keywords withgetCode
anddeployCode
invocations. Compiler will only see this preprocessed source codeUpdated caching
Notes
referencedDeclaration
keys which allow us to detect names of items a specific file/contract depends on which could be useful to do caching smarter by filtering out unused imports.solang_parser
is much cheaper to invoke, but does not provide this.The text was updated successfully, but these errors were encountered: