diff options
author | Juan Manuel Tomás <jtomas1815@gmail.com> | 2025-06-06 01:13:23 -0300 |
---|---|---|
committer | Juan Manuel Tomás <jtomas1815@gmail.com> | 2025-06-06 01:13:23 -0300 |
commit | 053deeeb7ed42cd6cde5c3959c3a446fd1fd4674 (patch) | |
tree | ec7c580256eec8ce8e5140a9bb1733bf9e202b03 | |
parent | 2e8323c2af42e817e98eb931eb733dc42c832448 (diff) | |
download | monparser-053deeeb7ed42cd6cde5c3959c3a446fd1fd4674.tar.gz monparser-053deeeb7ed42cd6cde5c3959c3a446fd1fd4674.zip |
Optimize code generation by defining bind as function
-rw-r--r-- | base.lisp | 30 |
1 files changed, 15 insertions, 15 deletions
@@ -13,18 +13,18 @@ (declare (ignore lazy)) (make-parsing :tree tree :left input))) -(defmacro bind (parser f) - `(lambda (input &key lazy) - (let ((r (funcall ,parser input))) - (cond ((parsing-p r) - (if lazy - (lambda (ignored-input &key lazy) - (declare (ignore ignored-input)) - (funcall (funcall ,f (parsing-tree r) input) - (parsing-left r) - :lazy lazy)) - (funcall (funcall ,f (parsing-tree r) input) - (parsing-left r)))) - ((failure-p r) - r) - (t (error (format nil "Invalid return value: ~a" r))))))) +(defun bind (parser f) + (lambda (input &key lazy) + (let ((r (funcall parser input))) + (cond ((parsing-p r) + (if lazy + (lambda (ignored-input &key lazy) + (declare (ignore ignored-input)) + (funcall (funcall f (parsing-tree r) input) + (parsing-left r) + :lazy lazy)) + (funcall (funcall f (parsing-tree r) input) + (parsing-left r)))) + ((failure-p r) + r) + (t (error (format nil "Invalid return value: ~a" r))))))) |