Add test for PR 10318.

Closes PR 10318.

original commit: 3fd5c491728c720727785fec266d9893e163738b
This commit is contained in:
Sam Tobin-Hochstadt 2010-05-19 11:12:13 -05:00
parent 87ff7915f6
commit 7bc6e2e79e

View File

@ -0,0 +1,35 @@
#lang typed-scheme
(define-struct: rect ((nw : Symbol) (width : Number) (height : Number)))
(define-struct: circ ((cntr : Symbol) (radius : Number)))
(define-struct: over ((top : Shape) (bot : Shape)))
(define-type-alias Shape (Rec Shape (U Plain over [Listof Plain])))
(define-type-alias Plain (U rect circ))
;; (define-type-alias Rect (U (make-rect Posn Number Number)))
;; Circ = (make-circ Posn Number)
(: area (Shape -> Number))
;; the area of all rectangles in this s
(define (area s)
(cond
[(plain? s) (plain-area s)]
[(over? s) (+ (area (over-top s)) (area (over-bot s)))]
[else (apply + (map rect-area (filter rect? s)))]))
(: plain? (Any -> Boolean : Plain))
;; is this p a plain shape?
(define (plain? p)
(or (rect? p) (circ? p)))
(: plain-area (Plain -> Number))
;; the area of this plain shape s
(define (plain-area s)
(cond
[(rect? s) (rect-area s)]
[(circ? s) 0]))
(: rect-area (rect -> Number))
;; the area of this rectangle r
(define (rect-area s)
(* (rect-width s) (rect-height s)))