mirror of
https://github.com/github/semantic.git
synced 2025-01-04 21:47:07 +03:00
More thorough documentation of FreeAlgorithm
.
This commit is contained in:
parent
437fbd269f
commit
80ba5fb379
@ -56,9 +56,11 @@ extension Algorithm {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/// The free monad over `Algorithm`.
|
/// The free monad over `Algorithm`, implementing the language of diffing.
|
||||||
///
|
///
|
||||||
/// As with `Free`, this is “free” in the sense of “unconstrained,” i.e. “the monad induced by `Algorithm` without extra assumptions.”
|
/// As with `Free`, this is “free” in the sense of “unconstrained,” i.e. “the monad induced by `Algorithm` without extra assumptions.”
|
||||||
|
///
|
||||||
|
/// Where `Algorithm` models a single diffing strategy, `FreeAlgorithm` models the recursive selection of diffing strategies at each node. Thus, a value in `FreeAlgorithm` models an algorithm for constructing a value in the type `B` from the resulting diffs. By this means, diffing can be adapted not just to the specific grammar, but to specific trees produced by that grammar, and even the values of type `A` encapsulated at each node.
|
||||||
public enum FreeAlgorithm<A, B> {
|
public enum FreeAlgorithm<A, B> {
|
||||||
/// The injection of a value of type `B` into an `Algorithm`.
|
/// The injection of a value of type `B` into an `Algorithm`.
|
||||||
///
|
///
|
||||||
|
Loading…
Reference in New Issue
Block a user