# Copyright 2005-2007 Kevin Reid, under the terms of the MIT X license # found at http://www.opensource.org/licenses/mit-license.html ................ --- Setup ? def := ; null ? def makeTermBuilder := ; null ? def termBuilder := makeTermBuilder(); null ? def makeTermLexer := ; null --- ? def makeTermParser := ; null ? def makeLexStream() :any { return makeTermLexer(false)("foo".asStream()) }; null ? def genericBuilder { > to doesQuasis() :any { return true } > match [v, a] { [v] + a } } > def gbParser := makeTermParser(genericBuilder) # value: ? gbParser.parse(makeLexStream()) # value: ["start", ["term", ["tag", [["Ident", "foo"]]]]] ? gbParser.parseText("foo".asStream()) # value: ["start", ["term", ["tag", [["Ident", "foo"]]]]] --- Grammar ? def p(tokens) :any { return gbParser.parse(tokens.asStream()) }; null foo() ? p([["Tag", [["Ident", "foo"]]], ["("], [")"]]) # value: ["start", ["term", ["tag", [["Ident", "foo"]]], ["empty"]]] foo(foo) ? p([["Tag", [["Ident", "foo"]]], ["("], ["Tag", [["Ident", "foo"]]], [")"]]) # value: ["start", ["term", ["tag", [["Ident", "foo"]]], ["term", ["tag", [["Ident", "foo"]]]]]] foo(bar, baz) ? p([["Tag", [["Ident", "foo"]]], ["("], ["Tag", [["Ident", "bar"]]], [","], ["Tag", [["Ident", "baz"]]], [")"]]) # value: ["start", ["term", ["tag", [["Ident", "foo"]]], ["seq", ["term", ["tag", [["Ident", "bar"]]]], ["term", ["tag", [["Ident", "baz"]]]]]]] [foo], [] ? p([["["], ["Tag", [["Ident", "foo"]]], ["]"]]) # value: ["start", ["tuple", ["term", ["tag", [["Ident", "foo"]]]]]] ? p([["["], ["]"]]) # value: ["start", ["tuple", ["empty"]]] {foo} ? p([["{"], ["Tag", [["Ident", "foo"]]], ["}"]]) # value: ["start", ["bag", ["term", ["tag", [["Ident", "foo"]]]]]] foo{bar} ? p([["Tag", [["Ident", "foo"]]], ["{"], ["Tag", [["Ident", "bar"]]], ["}"]]) # value: ["start", ["term", ["tag", [["Ident", "foo"]]], ["bag", ["term", ["tag", [["Ident", "bar"]]]]]]] foo:bar ? p([["Tag", [["Ident", "foo"]]], [":"], ["Tag", [["Ident", "bar"]]]]) # value: ["start", ["attr", ["tag", [["Ident", "foo"]]], ["term", ["tag", [["Ident", "bar"]]]]]] Literals ? p([["Integer", 1]]) # value: ["start", ["term", ["leafData", 1, null]]] ? p([["Float64", 1.0]]) # value: ["start", ["term", ["leafData", 1.0, null]]] ? p([["Char", 'a']]) # value: ["start", ["term", ["leafData", 'a', null]]] ? p([["String", "a"]]) # value: ["start", ["term", ["leafData", "a", null]]] Repetition operators Root ? p([["Tag", [["Ident", "foo"]]], ["("], [")"], ["*"]]) # value: ["start", ["some", ["term", ["tag", [["Ident", "foo"]]], ["empty"]], '*']] Arglist ? p([["Tag", [["Ident", "foo"]]], ["("], ["Tag", [["Ident", "bar"]]], ["+"], [")"]]) # value: ["start", ["term", ["tag", [["Ident", "foo"]]], ["some", ["term", ["tag", [["Ident", "bar"]]]], '+']]] Property ? p([["Tag", [["Ident", "foo"]]], [":"], ["Tag", [["Ident", "bar"]]], ["?"]]) # value: ["start", ["attr", ["tag", [["Ident", "foo"]]], ["some", ["term", ["tag", [["Ident", "bar"]]]], '?']]] XXX source span Holes ? p([["Quasi$", 1]]) # value: ["start", ["term", ["valueHole", 1]]] ? p([["Tag", [["Ident", "foo"]]], ["Quasi$", 1]]) # value: ["start", ["term", ["taggedHole", ["tag", [["Ident", "foo"]]], ["valueHole", 1]]]] ? p([["Quasi$", 1], ["("], ["Quasi$", 2], [")"]]) # value: ["start", ["term", ["valueHole", 1], ["term", ["valueHole", 2]]]] ? p([["Quasi@", 1], ["("], ["Quasi@", 2], [")"]]) # value: ["start", ["term", ["patternHole", 1], ["term", ["patternHole", 2]]]] --- Quasi and parsing ? def makeQBuilder := ; null ? def qBuilder := makeQBuilder(termBuilder) # value: ? def qbParser := makeTermParser(qBuilder) # value: ? qbParser.parse(makeLexStream()) # value: qterm`foo` ? qbParser.parseText("foo".asStream()) # value: qterm`foo` XXX all term-language grammar ? makeQBuilder.getTerm__quasiParser().valueMaker("foo").substitute([]) # value: term`foo` XXX substitution on all term trees ? term`foo` # value: term`foo` XXX more tests...