From: Javier Sancho Date: Sat, 16 Jun 2012 07:51:12 +0000 (+0200) Subject: Introducing bricks. X-Git-Url: https://git.jsancho.org/?p=gacela.git;a=commitdiff_plain;h=b467086e2092092f6ca8bab4d4a801e9064d8daa Introducing bricks. --- diff --git a/src/gacela.scm b/src/gacela.scm index 63d6bd3..cf72902 100644 --- a/src/gacela.scm +++ b/src/gacela.scm @@ -18,6 +18,7 @@ (define-module (gacela gacela) #:use-module (gacela events) #:use-module (gacela video) + #:use-module ((gacela video) #:renamer (symbol-prefix-proc 'video:)) #:use-module (gacela audio) #:use-module (ice-9 optargs) #:export (*title* @@ -129,6 +130,7 @@ (lambda () (game-code)) (lambda (key . args) #f))) (run-mobs) + (draw-bricks) (flip-screen) (delay-frame)))) (quit-video)) @@ -349,3 +351,36 @@ (define-macro (define-scene name . body) `(define (,name) ,@body)) + + +;;; Bricks Factory + +(define active-bricks '()) + +(define* (draw-bricks #:optional (bricks active-bricks)) + (cond ((not (null? bricks)) + ((car bricks)) + (draw-bricks (cdr bricks))))) + +(define (show-brick brick) + (set! active-bricks (cons brick active-bricks))) + +(define-macro (simple-brick brick-code) + (let ((name (gensym))) + `(begin + (define (,name) + ,brick-code) + (show-brick ,name) + ,name))) + + +;;; Primitive bricks + +(define (draw-square . args) + (simple-brick (apply video:draw-square args))) + + +(module-map (lambda (sym var) + (if (not (eq? sym '%module-public-interface)) + (module-export! (current-module) (list sym)))) + (current-module))