-
Notifications
You must be signed in to change notification settings - Fork 69
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
Better documentation (esp. regarding dependency management) #5
Comments
Yep, you've got that correct. It may be helpful to think that computations don't have dependencies, the values of computations have dependencies. Even more specific is to say that the values of computations have invalidators. If any of those invalidators changes, then the value is now invalid, and the computation needs to re-run to produce a new value with its own (potentially different) set of invalidators. S is perfectly happy with code like: let a = S.data(true),
b = S(() => a() ? 1 : c()),
c = S(() => a() ? b() : 2); That looks like a circular dependency, but if we think in terms of values, it's not. There are two possible scenarios:
(Anybody who wrote such code other than to prove a point should be shot, of course 😄 ). I've got a series of three articles in mind to try and explain more of the reasoning behind S. Standard API documentation doesn't really cut it, because it's not just what the functions are and what their signatures are, it's how they work together. When I get that together, would you be willing to give it a read and give feedback? |
@adamhaile Thanks for your through and quick reply! Sorry I wasn't able to reply, got caught straight in the middle of some projects. Yes, I would love to give you feedback! I appreciate your work a lot. |
@adamhaile Any idea when your articles might be published? |
Please define exactly(maybe more verbose) the difference between
|
If you look at the tests, you can see that freeze literally freezes the time during the closure, and flow resumes after the closure, wheras subclock creates a new time context, where multiple iterations in the inner clock are completed within the same instant from the outside. But yes, I totally agree the documentation kinda sucks here as well. I scratched my head around this for a while as well. |
By the way (off topic), I stumbled upon this library today, that actually seems to do something similar to S. |
Yep, ferreal. My priority has been getting Surplus 0.5 out the door, which happened yesterday. Working on a much longer README at the moment. |
I found cellx [2] in the past, also looks similar [1] https://github.com/ds300/derivablejs |
Just pushed up a large rough draft expansion to the README. All feedback welcome. I want to add a few break out sections on core concepts, like what it means to program on a unified global timeline of immutable instants, probably something more about computation lifecycles too. But this provides a lot more discussion about the API. |
BTW, thanks for the pointers to similar projects -- as you might guess I like looking at how others have approached the same/similar problem. At a quick glance, derivableJS and cellx look a little more simplistic than S (but hey, obviously I'm biased :)). They don't appear to be glitchless or have any strategy for automatic computation disposal or idempotent side-effects. They look like the same reactive semantics as, say, Knockout.js. I might be wrong though, looking forward to looking closer. If nothing else, I'd like to bench them against S, since they both claim speed as a virtue. |
Thanks @adamhaile for taking the time and effort to document. BTW I think your copyright notice is wrong, should at least show the first year of publication [1], which seems to be 2013 if I look through the git history. I would mark it as "© 2013-present ..." I am still looking forward to your answer to adamhaile/surplus#57 (improve quantification of advantages). |
@adamhaile Looks like derivableJS had existing benchmarks comparing itself favorably to MobX. Someone added S.js implementations here: ds300/derivablejs#119 S.js at the top of 2, derivableJS at the top of 3. I have no idea how meaningful these benchmarks are. I'd be interested to hear your opinion, Adam. What would be a meaningful benchmark? Results here:
|
As of now, I do so believe that S is probably the most well thought through stream/reactivity library of all. Still, I find the documentation/readme somewhat lacking. I feel that because the way S works is so unique, it needs some more detailed explanation to let people understand how exactly S works, to see that S is not making horses*** claims. One of the points I feel might really need improvement is the part about:
This really does sound too good/magical to be true, especially in this kind of library, if no further explanation is provided. I feel the documentation about:
is insufficient to convince a casual reader that this actually works, its not a crackpot claim. Another part of the reason why I'm asking here is that even I myself am somewhat confused, and want a confirmation from you that my understanding is correct:
If I am correct, I think it is important for the reader to understand the (reasonable) assumptions S has put on the code given to S computations, and how it actually works. If there was anything I could help with, I'd be glad to as well!
The text was updated successfully, but these errors were encountered: