-
Notifications
You must be signed in to change notification settings - Fork 19
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
Adds the ability to attach ad-hoc processors to optimize #71
base: main
Are you sure you want to change the base?
Conversation
Hm... it looks like bundling on windows isn't working but otherwise the PR/approach is ready for discussion. |
@natefaubion I revamped the PR to use the current spago. |
I also got rid of |
I just hit a situation in my work on WebGPU where I needed to trigger a rewrite from a processor. I tweaked the processors to be |
This PR is the start of an exploration into the idea of fusing together deku nodes during a processing step.
To do this, I've reorganized the repo using the new spago, which lends itself well to a setup where there's both a lib and an executable.
The idea is that everything in
lib
would be published to the registry as a library. Then, everything inpostinstall
would run as the npm postinstall step in order to build the optimizer with any processors that are present.It's a bit of a chicken-egg, because the package needs to exist as a lib before external processors can depend on it. But once that's overcome, people can build their processors against the lib and then
backend-es
can be built against those custom processors.Unfortunately the PR looks much bigger than it is because so much stuff is moved around. All it's really doing is swapping in the new spago, adding a step to use the processors, and adding a stub for the postinstall. Once the lib is published, the postinstall stub can be unstubbed.
This PR is just to get the conversation going - while it works, I'm not particularly attached to the approach. So we can either validate the approach, suggest alternative ones, or rule out processors altogether if they seem too onerous. I borrowed the design from Unreal, which makes the engine open source so that folks can pull in libs that mod it.