package note
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=1c627a1745fa17990ebc2dcf9c5928a91132328a97cd55e6eaf3af34b01563d5
md5=ea16940570494d6f2b779bc718685961
Description
Note is an OCaml library for functional reactive programming (FRP). It provides support to program with time varying values: declarative events and signals.
Note is distributed under the ISC license.
README
Note — Declarative events and signals for OCaml
v0.0.1
Note is an OCaml library for functional reactive programming (FRP). It provides support to program with time varying values: declarative events and signals.
Note is distributed under the ISC license.
Homepage: http://erratique.ch/software/note
Installation
Note can be installed with opam
:
opam install note
If you don't use opam
consult the opam
file for build instructions.
Documentation
The documentation and API reference is generated from the source interfaces. It can be consulted online or via odig doc note
.
History
Note is a potential successor to the OCaml React library.
On the plus side:
Uses a simpler push/pull implementation which does not uses weak references. Combinators are easier to implement and understand.
Provides a formal API to interface the outputs of the reactive system rather than rely on effectful events and signals. Enforces life-time management of the output of the reactive system and could provides (dynamic) detection of constant signals and never occuring events.
Provides (hopefully) a better combinator set. Especially with respect to the pain point of signal initialization in React: in Note, due the pull based strategy,
{E,S}.value
is safe and sound to use.
On the minus side:
The life-time of the outputs of the reactive system have to be explicitely managed; but we argue this has to be done anyways in practice especially in browsers due to lack of weak references.
It is easier for code interfacing the outputs of the reactive system to break the FRP denotational semantics and thus equational reasoning. However the discipline needed not to do so is clear and simple: do not reobserve a signal/event that was no longer observed.
The depth first DAG update strategy of Note may be subject to stackoverflows on deep DAGs. We suspect however that this should not be a problem in practice.
On the unknown side:
Memory footprint is likely to be smaller in Note. Nodes of the DAG do not keep track of the nodes that depend on them via weak references. They do keep track of the root nodes of the DAG they depend on, but these sets can be shared among nodes.
Lack of weak references in Note may improve performance.
On updates the number of nodes that have to be visited (not recomputed) is larger in Note. In React this is the minimal number of nodes effectively affected by the update, in Note this is all the nodes thay may be affected by the update. However react also needs a priority queue with weak references for its update, Note does not need this and allows to update the graph at any point where it might be needed. The latter brings API usability improvements, e.g. the sound and safe implementation of
{E,S}.value
in Note.
Dependencies (4)
-
topkg
build & >= "0.9.0"
-
ocamlbuild
build
-
ocamlfind
build
-
ocaml
>= "4.08.0" & < "5.0"
Dev Dependencies
None
Used by (1)
-
brr
< "0.0.6"
Conflicts
None