Skip to content

Instantly share code, notes, and snippets.

@JakubOboza
Created December 1, 2008 20:02
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save JakubOboza/30823 to your computer and use it in GitHub Desktop.
Save JakubOboza/30823 to your computer and use it in GitHub Desktop.
(define (pmatch el)
(lambda (parser)
(p-cond parser
((lambda (parser)
(if (eqv? (p-car parser) el)
(p-advance parser)
(p-fail-parser parser)))))))
(define (pmany op)
(lambda (parser)
(letrec ((loop (lambda (cur-stream)
(let ((p-next (op cur-stream)))
(p-cond p-next
(loop
p-succ-parser
p-succ-parser
))))))
(loop parser))))
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment