2018-01-28 09:55:23 -05:00
|
|
|
(defmacro array (length)
|
|
|
|
(let* ((this (gensym))
|
|
|
|
(index-prefix (fuse this 'index))
|
|
|
|
(indices (create-indices length))
|
|
|
|
(index-bindings (map (lambda (i) (list (fuse index-prefix i))) indices)))
|
|
|
|
|
|
|
|
`(let ,index-bindings
|
|
|
|
(setq ,this
|
|
|
|
(dlambda
|
|
|
|
(:get (i)
|
|
|
|
(eval (fuse ',index-prefix i)))
|
|
|
|
|
|
|
|
(:set (i value)
|
2018-02-04 09:36:37 -05:00
|
|
|
(if (and (< i ,length) (> i -1))
|
|
|
|
(set (fuse ',index-prefix i) value)
|
|
|
|
(call ,this :get i))) ;; show error
|
2018-01-28 09:55:23 -05:00
|
|
|
|
|
|
|
(:length ()
|
|
|
|
,length)
|
|
|
|
|
|
|
|
(t ()
|
|
|
|
((lambda (indices accumulator)
|
|
|
|
(if (null? indices)
|
|
|
|
accumulator
|
|
|
|
(recur
|
|
|
|
(rest indices)
|
|
|
|
(cons
|
2018-02-04 09:36:37 -05:00
|
|
|
(call ,this :get (first indices))
|
2018-01-28 09:55:23 -05:00
|
|
|
accumulator))))
|
|
|
|
(reverse ',indices)
|
|
|
|
nil)))))))
|
|
|
|
|
|
|
|
|
|
|
|
(defun create-indices (length)
|
|
|
|
(create-indices-tail (- length 1) ()))
|
2018-01-27 20:02:03 -05:00
|
|
|
|
|
|
|
(defun create-indices-tail (index accumulator)
|
|
|
|
(if (< index 0)
|
|
|
|
accumulator
|
|
|
|
(recur (- index 1) (cons index accumulator))))
|