Exercise 6.2.4: (back)

;; dimensions of traffic light
(define WIDTH 50)
(define HEIGHT 160)
(define BULB-RADIUS 20)
(define BULB-DISTANCE 10)


;; the positions of the bulb
(define X-BULBS (quotient WIDTH 2))
(define Y-RED (+ BULB-DISTANCE BULB-RADIUS))
(define Y-YELLOW (+ Y-RED BULB-DISTANCE (* 2 BULB-RADIUS)))
(define Y-GREEN (+ Y-YELLOW BULB-DISTANCE (* 2 BULB-RADIUS)))


;; clear-bulb: symbol -> symbol
(define (clear-bulb bulb)
  (cond
    [(symbol=? bulb 'red) (and (hide-disk bulb) 
                               (show-circle bulb))]
    [(symbol=? bulb 'yellow) (and (hide-disk bulb)
                               (show-circle bulb))]
    [(symbol=? bulb 'green) (and (hide-disk bulb)
                               (show-circle bulb))]))

                               
;; draw-bulb: symbol -> symbol                               
(define (draw-bulb bulb)
  (cond
    [(symbol=? bulb 'red) (and (hide-circle bulb) 
                               (show-disk bulb))]
    [(symbol=? bulb 'yellow) (and (hide-circle bulb) 
                               (show-disk bulb))]
    [(symbol=? bulb 'green) (and (hide-circle bulb) 
                               (show-disk bulb))]))                               


;; switch: symbol symbol -> symbol                                 
(define (switch bulb1 bulb2)
  (and (clear-bulb bulb1)
       (draw-bulb bulb2)))
       
                               
;; hide-disk: symbol -> symbol
(define (hide-disk bulb)
  (cond
    [(symbol=? bulb 'red) 
     (clear-solid-disk (make-posn X-BULBS Y-RED) BULB-RADIUS 'red)]
    [(symbol=? bulb 'yellow) 
     (clear-solid-disk (make-posn X-BULBS Y-YELLOW) BULB-RADIUS 'yellow)]
    [(symbol=? bulb 'green)
     (clear-solid-disk (make-posn X-BULBS Y-GREEN) BULB-RADIUS 'green)]))


;; show-circle: symbol -> symbol
(define (show-circle bulb)
  (cond
    [(symbol=? bulb 'red)
     (draw-circle (make-posn X-BULBS Y-RED) BULB-RADIUS 'red)]
    [(symbol=? bulb 'yellow)
     (draw-circle (make-posn X-BULBS Y-YELLOW) BULB-RADIUS 'yellow)]
    [(symbol=? bulb 'green)
     (draw-circle (make-posn X-BULBS Y-GREEN) BULB-RADIUS 'green)]))

     
;; hide-cicle: symbol -> symbol
(define (hide-circle bulb)
  (cond
    [(symbol=? bulb 'red)
     (clear-circle (make-posn X-BULBS Y-RED) BULB-RADIUS 'red)]
    [(symbol=? bulb 'yellow)
     (clear-circle (make-posn X-BULBS Y-YELLOW) BULB-RADIUS 'yellow)]
    [(symbol=? bulb 'green)
     (clear-circle (make-posn X-BULBS Y-GREEN) BULB-RADIUS 'green)]))

     
;; show-circle: symbol -> symbol
(define (show-disk bulb)
  (cond
    [(symbol=? bulb 'red)
     (draw-solid-disk (make-posn X-BULBS Y-RED) BULB-RADIUS 'red)]
    [(symbol=? bulb 'yellow)
     (draw-solid-disk (make-posn X-BULBS Y-YELLOW) BULB-RADIUS 'yellow)]
    [(symbol=? bulb 'green)
     (draw-solid-disk (make-posn X-BULBS Y-GREEN) BULB-RADIUS 'green)]))     

     
;; draw the light with the red bulb turned on
(start WIDTH HEIGHT)
(draw-solid-disk (make-posn X-BULBS Y-RED) BULB-RADIUS 'red)
(draw-circle (make-posn X-BULBS Y-YELLOW) BULB-RADIUS 'yellow)
(draw-circle (make-posn X-BULBS Y-GREEN) BULB-RADIUS 'green)