Add iterate (for ... seed ... then ...) driver
author |
Steve Losh <steve@stevelosh.com> |
date |
Sat, 23 Feb 2019 22:46:27 -0500 (2019-02-24) |
parents |
e844dad54ef3
|
children |
3cf5a5efd686
|
branches/tags |
(none) |
files |
package.lisp src/iterate.lisp |
Changes
--- a/package.lisp Sat Feb 23 22:30:19 2019 -0500
+++ b/package.lisp Sat Feb 23 22:46:27 2019 -0500
@@ -351,6 +351,8 @@
:test
:timing
:within-radius
+ :seed
+ :then
))
--- a/src/iterate.lisp Sat Feb 23 22:30:19 2019 -0500
+++ b/src/iterate.lisp Sat Feb 23 22:46:27 2019 -0500
@@ -665,3 +665,29 @@
(,kwd ,var = ,expr))))
+(defmacro-driver (FOR var SEED seed THEN then)
+ "Bind `var` to `seed` initially, then to `then` on every iteration.
+
+ This differs from `(FOR … FIRST … THEN …)` and `(FOR … INITIALLY … THEN …)`
+ because `then` is evaluated on every iteration, *including* the first.
+
+ Example:
+
+ (iterate
+ (repeat 3)
+ (for x :first 0 :then (1+ x))
+ (for y :initially 0 :then (1+ y))
+ (for z :seed 0 :then (1+ z))
+ (collect (list x y z)))
+ ; =>
+ ((0 0 1)
+ (1 1 2)
+ (2 2 3))
+
+ "
+ (let ((kwd (if generate 'generate 'for)))
+ `(progn
+ (,kwd ,var :next ,then)
+ (initially (setf ,var ,seed)))))
+
+