bf: group ops
~13s mandelbrot
This commit is contained in:
parent
f4f57a6857
commit
704ff740e0
2 changed files with 42 additions and 35 deletions
58
bf.lisp
58
bf.lisp
|
@ -1,46 +1,52 @@
|
||||||
(load "utils.lisp")
|
(load "utils.lisp")
|
||||||
; i've done this before
|
|
||||||
|
|
||||||
(deftype cell () '(mod 256))
|
|
||||||
|
|
||||||
; TODO: group ops
|
|
||||||
(defun comp-part (&optional (port *standard-input*))
|
(defun comp-part (&optional (port *standard-input*))
|
||||||
(begin
|
(begin
|
||||||
(loop with out
|
(= out nil)
|
||||||
for c = (read-char port nil nil)
|
(= op 'inc)
|
||||||
|
(= val 0)
|
||||||
|
(=f put (&optional (next 'inc))
|
||||||
|
(unless (zerop val) (push (list op val) out))
|
||||||
|
(setf op next)
|
||||||
|
(setf val 0))
|
||||||
|
|
||||||
|
(loop for c = (read-char port nil nil)
|
||||||
while (and c (not (eql c #\])))
|
while (and c (not (eql c #\])))
|
||||||
when (in c #\+ #\- #\> #\< #\. #\, #\[)
|
when (in c #\+ #\- #\> #\< #\. #\, #\[)
|
||||||
do (push
|
do (ecase c
|
||||||
(ecase c
|
((#\+ #\-)
|
||||||
(#\+ '(inc))
|
(unless (eq op 'inc) (put 'inc))
|
||||||
(#\- '(dec))
|
(incf val (if (eql c #\+) 1 -1)))
|
||||||
(#\> '(minc))
|
|
||||||
(#\< '(mdec))
|
((#\> #\<)
|
||||||
; TODO: fix
|
(unless (eq op 'minc) (put 'minc))
|
||||||
(#\. '(put-byte))
|
(incf val (if (eql c #\>) 1 -1)))
|
||||||
(#\, '(get-byte))
|
|
||||||
(#\[ `(loop until (zerop cell) do (progn ,@(comp-part port)))))
|
(#\. (put) (push '(put-byte) out))
|
||||||
out)
|
(#\, (put) (push '(get-byte) out))
|
||||||
finally (return (nreverse out)))))
|
(#\[ (put) (push `(loop until (zerop cell) do (progn ,@(comp-part port))) out)))
|
||||||
|
finally (progn
|
||||||
|
(put)
|
||||||
|
(return (nreverse out))))))
|
||||||
|
|
||||||
(defun comp (&optional (port *standard-input*))
|
(defun comp (&optional (port *standard-input*))
|
||||||
`(begin
|
(eval
|
||||||
|
`(lambda (&key (in *standard-input*) (out *standard-output*))
|
||||||
|
(begin
|
||||||
(declare (optimize (speed 3) (safety 0)))
|
(declare (optimize (speed 3) (safety 0)))
|
||||||
(= mem (make-array '(65536) :element-type 'cell))
|
(= mem (make-array '(65536) :element-type '(unsigned-byte 8)))
|
||||||
(= mp 0)
|
(= mp 0)
|
||||||
(=sm cell (aref mem mp))
|
(=sm cell (aref mem mp))
|
||||||
|
|
||||||
(=f inc (&optional (n 1)) (setf cell (mod (+ cell n) 256)))
|
(=f inc (&optional (n 1)) (setf cell (mod (+ cell n) 256)))
|
||||||
(=f dec () (inc -1))
|
|
||||||
|
|
||||||
(=f minc (&optional (n 1)) (setf mp (mod (+ mp n) 65536)))
|
(=f minc (&optional (n 1)) (setf mp (mod (+ mp n) 65536)))
|
||||||
(=f mdec () (minc -1))
|
|
||||||
|
|
||||||
(=f get-byte () (setf cell (mod (char-code (read-char *standard-input* nil #\null)) 256)))
|
; TODO: fix
|
||||||
(=f put-byte () (write-char (code-char cell)))
|
(=f get-byte () (setf cell (mod (char-code (read-char in nil #\null)) 256)))
|
||||||
|
(=f put-byte () (write-char (code-char cell) out))
|
||||||
|
|
||||||
(=m bf-loop (&body body)
|
(=m bf-loop (&body body)
|
||||||
`(loop until (zerop cell)
|
`(loop until (zerop cell)
|
||||||
do (progn ,@body)))
|
do (progn ,@body)))
|
||||||
,@(comp-part port)
|
,@(comp-part port)
|
||||||
t))
|
t))))
|
||||||
|
|
|
@ -690,6 +690,7 @@
|
||||||
`(let-match1 ,pattern (progn ,@body)
|
`(let-match1 ,pattern (progn ,@body)
|
||||||
(begin ,@rest)))
|
(begin ,@rest)))
|
||||||
|
|
||||||
|
;; consider LABELS
|
||||||
((structure ('=f name args . body))
|
((structure ('=f name args . body))
|
||||||
`(flet ((,name ,args (begin ,@body)))
|
`(flet ((,name ,args (begin ,@body)))
|
||||||
(begin ,@rest)))
|
(begin ,@rest)))
|
||||||
|
|
Loading…
Reference in a new issue