X-Git-Url: https://thelambdalab.xyz/gitweb/index.cgi?p=jars.git;a=blobdiff_plain;f=mars.scm;h=ae70c886f915516b5dabcf560c70634815a5d253;hp=677d754459360249224fe778e3175d70ac7b29d4;hb=7281b0c1eefce213d11cada1cb9f86a2d8fb0779;hpb=3658516d8dd5cea71cac2a7637f5470b5b87b228;ds=sidebyside diff --git a/mars.scm b/mars.scm index 677d754..ae70c88 100644 --- a/mars.scm +++ b/mars.scm @@ -6,6 +6,7 @@ (make-instr make-prog prog-name + prog-author prog-instrs prog-offset prog->string @@ -212,20 +213,20 @@ ;;; Executive function ;; - (define (run-mars core queues steps-left) - (if (or (<= steps-left 0) - (null? queues) - (= (length queues) 1)) - queues - (let* ((queue (car queues)) - (remaining-queues (cdr queues)) - (ptrs (queue-ptrs queue)) - (new-ptrs (execute-instr core (car ptrs) (queue-owner queue)))) - (if (null? new-ptrs) - (run-mars core remaining-queues (- steps-left 1)) - (begin - (queue-set-ptrs! queue (append (cdr ptrs) new-ptrs)) - (run-mars core (append remaining-queues (list queue)) (- steps-left 1))))))) + (define (run-mars core queues steps-left . rest) + (let ((min-queue-count (if (null? rest) 2 (car rest)))) + (if (or (<= steps-left 0) + (< (length queues) min-queue-count)) + queues + (let* ((queue (car queues)) + (remaining-queues (cdr queues)) + (ptrs (queue-ptrs queue)) + (new-ptrs (execute-instr core (car ptrs) (queue-owner queue)))) + (if (null? new-ptrs) + (run-mars core remaining-queues (- steps-left 1)) + (begin + (queue-set-ptrs! queue (append (cdr ptrs) new-ptrs)) + (run-mars core (append remaining-queues (list queue)) (- steps-left 1)))))))) (define (execute-instr core ptr name) ;; (print ptr "\t" (core ptr '->string) "\t(" name ")")