Open josephjclark opened 2 months ago
We can remove a lot of docs by doing this you know. We just need an expandable box saying something like "when you reference state at the top level, it will always be lazily evaluated. Here's what the compiler does to your code".
Lazy state is proving a bit hard for people (even people on the team) to understand
The story for new users is:
Cool, but then they open up a callback and it breaks. So now the rule is:
Which I suppose isn't too bad, but does require a certain mindfulness.
Why don't we drop
$
entirely and just treatstate
as a special entity in the compiler? All the rules we apply to$
now just apply to the special variable state. Which means: if we seestate
passed into an operation at the top level, we wrap it up in a lazy function.Reasons for:
Reasons against:
const state = {}
. But that's true anyway, and why would you do that? We could even compiler warn against thisI'm warming to the idea that we go ahead and do this. I think we do still need to document something about what's happening, especially if users look at their compiled code. But it would be heavy advanced stuff.