Gonna checkpoint here - got basic fungll working, did a mod to allow strings as terminals, working on getting recursion working.
This commit is contained in:
@@ -1,6 +1,48 @@
|
||||
(with_import "./fungll.kp"
|
||||
(let (
|
||||
just_a_parser (parse (nterm 'A (altOp altStart (seqOp seqStart (term (idx "a" 0))))))
|
||||
parse_result (just_a_parser "a")
|
||||
_ (println "parse result " parse_result)
|
||||
|
||||
_ (println "The a parser")
|
||||
just_a_parser (parse (nterm 'A (altOp altStart (seqOp seqStart (term "a")))))
|
||||
_ (println "parse result for a " (just_a_parser "a"))
|
||||
_ (println "parse result for b " (just_a_parser "b"))
|
||||
_ (println "parse result for aa " (just_a_parser "aa"))
|
||||
_ (println "parse result for ba " (just_a_parser "ba"))
|
||||
_ (println "parse result for ab " (just_a_parser "ab"))
|
||||
|
||||
_ (println "The aa parser")
|
||||
just_aa_parser (parse (nterm 'A (altOp altStart (seqOp seqStart (term "aa")))))
|
||||
_ (println "parse result for a " (just_aa_parser "a"))
|
||||
_ (println "parse result for b " (just_aa_parser "b"))
|
||||
_ (println "parse result for aa " (just_aa_parser "aa"))
|
||||
_ (println "parse result for ba " (just_aa_parser "ba"))
|
||||
_ (println "parse result for ab " (just_aa_parser "ab"))
|
||||
|
||||
_ (println "The a.a parser")
|
||||
just_aa_parser (parse (nterm 'A (altOp altStart (seqOp (seqOp seqStart (term "a")) (term "a")))))
|
||||
_ (println "parse result for a " (just_aa_parser "a"))
|
||||
_ (println "parse result for b " (just_aa_parser "b"))
|
||||
_ (println "parse result for aa " (just_aa_parser "aa"))
|
||||
_ (println "parse result for ba " (just_aa_parser "ba"))
|
||||
_ (println "parse result for ab " (just_aa_parser "ab"))
|
||||
|
||||
_ (println "The b|a.a parser")
|
||||
just_aa_parser (parse (nterm 'A (altOp (altOp altStart (seqOp seqStart (term "b"))) (seqOp (seqOp seqStart (term "a")) (term "a")))))
|
||||
_ (println "parse result for a " (just_aa_parser "a"))
|
||||
_ (println "parse result for b " (just_aa_parser "b"))
|
||||
_ (println "parse result for aa " (just_aa_parser "aa"))
|
||||
_ (println "parse result for ba " (just_aa_parser "ba"))
|
||||
_ (println "parse result for ab " (just_aa_parser "ab"))
|
||||
|
||||
_ (println "The a|a,A parser")
|
||||
just_aa_parser (let-rec (
|
||||
As (nterm 'A (altOp (altOp altStart (seqOp seqStart (term "a"))) (seqOp (seqOp seqStart (term ",")) As)))
|
||||
) (parse As))
|
||||
_ (println "parse result for a " (just_aa_parser "a"))
|
||||
_ (println "parse result for b " (just_aa_parser "b"))
|
||||
_ (println "parse result for aa " (just_aa_parser "aa"))
|
||||
_ (println "parse result for ba " (just_aa_parser "ba"))
|
||||
_ (println "parse result for ab " (just_aa_parser "ab"))
|
||||
_ (println "parse result for a,a " (just_aa_parser "a,a"))
|
||||
_ (println "parse result for a,a,a " (just_aa_parser "a,a,a"))
|
||||
|
||||
) nil))
|
||||
|
||||
Reference in New Issue
Block a user