]> git.jsancho.org Git - gacela.git/blobdiff - src/utils.scm
Defining views
[gacela.git] / src / utils.scm
index 015de6b68b5f52c9f882a518df9ef2f121e7dd81..d63a51148f2a8f590ae1e2a545abc8dc49d5dd16 100644 (file)
@@ -19,7 +19,8 @@
   #:export (use-cache-with
            arguments-calling
            arguments-apply
-           bound?))
+           bound?
+           make-producer))
 
 
 ;;; Cache for procedures
            (optional-arguments-apply args values)
            (keyword-arguments-apply args values)
            (rest-arguments-apply args values))))
+
+
+;;; Continuations and coroutines
+
+(define (make-producer body)
+  (define resume #f)
+  (lambda (real-send)
+    (define send-to real-send)
+    (define (send value-to-send)
+      (set! send-to
+           (call/cc
+            (lambda (k)
+              (set! resume k)
+              (send-to value-to-send)))))
+    (if resume
+        (resume real-send)
+        (body send))))