Comments (2)
Another observation on this is that the wasm code emitted right now by the Go compiler uses a loop algorithm http://troubles.md/posts/why-do-we-need-the-relooper-algorithm-again/ to allow the necessary jump/resume functionality to get things like panic/defer/recover/goroutines to work. And although there is not much we can easily do about the runtime performance, this may be a clue to some excellent domain-specific compression ideas. Nested block
s and local.get
/local.set
and a few other instructions consume portions of the generated code. It might be possible to use something as simple as a predefined dictionary with flate to get good compression ratios. Some testing should be done. There are also potentially other repetitive patterns that could lend themselves to compression, like br N ... end ... br N-1 ... end ... br N-2 ... end
and so on.
This sort of compression could prove even more useful than trying to break up and cache different packages.
from vugu.
It would also be really helpful to have an analysis tool which showed what functions and packages were consuming the most space. Disassembling a program and just measuring the byte size of each package would be really helpful. For example the Vugu website binary has loads of syntax highlighting code in it where I only need one of the many included, and the linker seems to have been unable to optimize the others way (probably because of import side-effects/init).
With good domain-specific compression and visibility about what is bloating the code, this might mitigate the binary size situation significantly.
from vugu.
Related Issues (20)
- Using javascript libaries with Vugu HOT 8
- wiring example not working HOT 1
- Consider using GCSS for CSS preprocessing HOT 1
- Panic: index out of range HOT 2
- This fixes the example in examples/fetch-and-display HOT 1
- MDL latest now is updated after many years neglect HOT 2
- Short form of vg-comp tag stops rendering the parent component
- Render server side and client side HOT 3
- webpack loader support and mixed with vue or react HOT 1
- Abandoned? HOT 9
- The Rendered lifecycle of the subcomponent has not been called HOT 1
- Getting Vugu to v1.0 and into production HOT 19
- TailwindCSS and Vugu HOT 2
- Produce a full production example
- State of vgforms package - do we need this for v1.0? HOT 1
- Request for a volunteer: TinyGo support for v1.0 (or shortly after) HOT 2
- Is the library alive? HOT 1
- Vugu v1.0 ToDo List
- Feedback Request: Do you use the generated `main_was.go`? HOT 3
- js Set can not set Function HOT 9
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from vugu.