mirror of
https://github.com/github/semantic.git
synced 2025-01-01 11:46:14 +03:00
Rename TermType.out to TermType.unwrap.
This commit is contained in:
parent
cb5dde7bb1
commit
59947a6581
@ -62,7 +62,7 @@ public enum Algorithm<Term: TermType, B> {
|
||||
// At the moment, there are no restrictions on whether terms are compatible.
|
||||
if equals(a, b) { return f(Diff(b)).evaluate(equals, recur: recur) }
|
||||
|
||||
switch (a.out, b.out) {
|
||||
switch (a.unwrap, b.unwrap) {
|
||||
case let (.Indexed(a), .Indexed(b)) where a.count == b.count:
|
||||
return f(.Indexed(zip(a, b).map(recurOrReplace))).evaluate(equals, recur: recur)
|
||||
|
||||
@ -96,7 +96,7 @@ extension Algorithm where Term: Equatable {
|
||||
extension Algorithm where B: FreeConvertible, B.RollType == Term.LeafType, B.PureType == Algorithm<Term, B>.Patch {
|
||||
/// `Algorithm<Term, Diff>`s can be constructed from a pair of `Term`s using `ByKey` when `Keyed`, `ByIndex` when `Indexed`, and `Recursive` otherwise.
|
||||
public init(_ a: Term, _ b: Term) {
|
||||
switch (a.out, b.out) {
|
||||
switch (a.unwrap, b.unwrap) {
|
||||
case let (.Keyed(a), .Keyed(b)):
|
||||
self = .Roll(.ByKey(a, b, Syntax.Keyed >>> Free.Roll >>> B.init >>> Pure))
|
||||
case let (.Indexed(a), .Indexed(b)):
|
||||
|
@ -13,9 +13,9 @@ public enum Free<A, B>: CustomDebugStringConvertible, SyntaxConvertible {
|
||||
indirect case Roll(Syntax<Free, A>)
|
||||
|
||||
|
||||
/// Recursively copies a `Term: TermType where Term.LeafType == A` into a `Free<A, B>`, essentially mapping `Term.out` onto `Free.Roll`.
|
||||
/// Recursively copies a `Term: TermType where Term.LeafType == A` into a `Free<A, B>`, essentially mapping `Term.unwrap` onto `Free.Roll`.
|
||||
public init<Term: TermType where Term.LeafType == A>(_ term: Term) {
|
||||
self = .Roll(term.out.map(Free.init))
|
||||
self = .Roll(term.unwrap.map(Free.init))
|
||||
}
|
||||
|
||||
|
||||
|
@ -2,21 +2,17 @@
|
||||
public protocol TermType {
|
||||
typealias LeafType
|
||||
|
||||
var out: Syntax<Self, LeafType> { get }
|
||||
var unwrap: Syntax<Self, LeafType> { get }
|
||||
}
|
||||
|
||||
|
||||
extension Cofree: TermType {
|
||||
public var out: Syntax<Cofree, A> {
|
||||
return unwrap
|
||||
}
|
||||
}
|
||||
extension Cofree: TermType {}
|
||||
|
||||
|
||||
// MARK: - Equality
|
||||
|
||||
extension TermType {
|
||||
public static func equals(leaf: (LeafType, LeafType) -> Bool)(_ a: Self, _ b: Self) -> Bool {
|
||||
return Syntax.equals(ifLeaf: leaf, ifRecur: equals(leaf))(a.out, b.out)
|
||||
return Syntax.equals(ifLeaf: leaf, ifRecur: equals(leaf))(a.unwrap, b.unwrap)
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user