mirror of
https://github.com/github/semantic.git
synced 2025-01-03 04:51:57 +03:00
109 lines
2.9 KiB
Swift
109 lines
2.9 KiB
Swift
import Doubt
|
|
import SourceKittenFramework
|
|
|
|
let arguments = BoundsCheckedArray(array: Process.arguments)
|
|
|
|
public protocol StringConvertible {
|
|
init(string: String)
|
|
}
|
|
|
|
extension String: StringConvertible {
|
|
public init(string: String) {
|
|
self = string
|
|
}
|
|
}
|
|
|
|
extension Info: StringConvertible {
|
|
public init(string: String) {
|
|
self = .Literal(string, [])
|
|
}
|
|
}
|
|
|
|
private struct Bail: ErrorType {}
|
|
|
|
extension Fix where A: StringConvertible {
|
|
/// Constructs a term representing `JSON`.
|
|
init?(JSON: Doubt.JSON) {
|
|
func bail<B>() throws -> B {
|
|
throw Bail()
|
|
}
|
|
do {
|
|
switch JSON {
|
|
case let .Dictionary(d) where d["key.name"] != nil:
|
|
let name = d["key.name"]?.string ?? ""
|
|
let substructure = d["key.substructure"]?.array ?? []
|
|
let kind = d["key.kind"]?.string
|
|
switch kind {
|
|
case
|
|
.Some("source.lang.swift.decl.class"),
|
|
.Some("source.lang.swift.decl.extension"),
|
|
.Some("source.lang.swift.decl.enum"),
|
|
.Some("source.lang.swift.decl.struct"),
|
|
.Some("source.lang.swift.decl.protocol"):
|
|
self = .In(.Indexed([ .In(.Leaf(A(string: name))), .In(.Indexed(try substructure.map { try Fix(JSON: $0) ?? bail() })) ]))
|
|
|
|
case .Some("source.lang.swift.decl.enumelement"):
|
|
fallthrough
|
|
case
|
|
.Some("source.lang.swift.decl.function.method.instance"),
|
|
.Some("source.lang.swift.decl.function.free"):
|
|
self = .In(.Indexed([ .In(.Leaf(A(string: name))), .In(.Indexed(try substructure.map { try Fix(JSON: $0) ?? bail() })) ]))
|
|
|
|
case
|
|
.Some("source.lang.swift.decl.var.instance"),
|
|
.Some("source.lang.swift.decl.var.static"):
|
|
self = .In(.Leaf(A(string: name)))
|
|
|
|
default:
|
|
return nil
|
|
}
|
|
|
|
case let .Dictionary(d) where d["key.kind"]?.string == "source.lang.swift.decl.enumcase" && d["key.substructure"]?.array?.count == 1:
|
|
let substructure = d["key.substructure"]?.array ?? []
|
|
self = try Fix(JSON: substructure[0]) ?? bail()
|
|
|
|
case let .Dictionary(d) where d["key.kind"]?.string == "source.lang.swift.syntaxtype.comment.mark":
|
|
self = .In(.Leaf(A(string: "mark")))
|
|
|
|
default:
|
|
return nil
|
|
}
|
|
} catch _ {
|
|
return nil
|
|
}
|
|
}
|
|
|
|
/// Constructs a term representing the `JSON` in a file at `path`.
|
|
init?(path: String, JSON: Doubt.JSON) {
|
|
func bail<B>() throws -> B {
|
|
throw Bail()
|
|
}
|
|
do {
|
|
switch JSON.dictionary?["key.substructure"] {
|
|
case let .Some(.Array(a)):
|
|
self = .In(.Indexed(try a.map { try Fix(JSON: $0) ?? bail() }))
|
|
default:
|
|
return nil
|
|
}
|
|
} catch _ {
|
|
return nil
|
|
}
|
|
}
|
|
|
|
init?(path: String) {
|
|
guard path != "/dev/null" else {
|
|
return nil
|
|
}
|
|
guard let term = File(path: path)
|
|
.map(Structure.init)
|
|
.map({ $0.dictionary })
|
|
.map(toAnyObject)
|
|
.flatMap({ JSON(object: $0).flatMap { Fix(path: path, JSON: $0) } }) else { return nil }
|
|
self = term
|
|
}
|
|
}
|
|
|
|
if let a = arguments[1].flatMap({ Fix<Info>(path: $0) }), b = arguments[2].flatMap({ Fix<Info>(path: $0) }) {
|
|
print(FreeAlgorithm<Info, Free<Info, Patch<Info>>>(a, b).evaluate())
|
|
}
|