1
1
mirror of https://github.com/github/semantic.git synced 2024-12-28 09:21:35 +03:00
semantic/prototype/Doubt/Prelude.swift

32 lines
525 B
Swift
Raw Normal View History

2015-07-18 22:43:49 +03:00
func fix<T, U>(f: (T -> U) -> T -> U) -> T -> U {
return { f(fix(f))($0) }
}
2015-10-06 18:02:22 +03:00
func id<A>(a: A) -> A {
return a
}
2015-07-18 22:43:49 +03:00
func const<A, B>(a: A)(_ b: B) -> A {
return a
}
func >>> <T, U, V> (f: T -> U, g: U -> V) -> T -> V {
return { g(f($0)) }
}
2015-10-02 23:48:44 +03:00
extension Optional {
static func equals(param: (Wrapped, Wrapped) -> Bool)(_ left: Wrapped?, _ right: Wrapped?) -> Bool {
switch (left, right) {
case let (.Some(a), .Some(b)):
return param(a, b)
case (.None, .None):
return true
default:
return false
}
}
}