racket/collects/htdp/tests/hangman1.rkt
2010-04-27 16:50:15 -06:00

64 lines
2.1 KiB
Racket

;; The first three lines of this file were inserted by DrScheme. They record metadata
;; about the language level of this file in a form that our tools can easily process.
#reader(lib "htdp-beginner-reader.ss" "lang")((modname hangman1) (read-case-sensitive #t) (teachpacks ()) (htdp-settings #(#t constructor repeating-decimal #f #t none #f ())))
(require htdp/hangman)
; (load "tester.ss")
;; by hand, Beginner for plain, Full for errors
(define-struct word (a b c))
;; A word is a structure: (make-word letter letter letter)
;; DEFINITION:
(define (reveal chosen status guess)
(make-word (reveal1 (word-a chosen) (word-a status) guess)
(reveal1 (word-b chosen) (word-b status) guess)
(reveal1 (word-c chosen) (word-c status) guess)))
;; EXAMPLES:
;; reveal1: 'a 'a 'x => 'a
;; reveal1: 'x '_ 'x => 'x
;; reveal1: 'x '_ 'y => '_
;; The inputs are atomic, which means we need domain knowledge.
;; The domain knowledge is given in the problem statement.
;; DEFINITION:
(define (reveal1 ch st gu)
(cond
((eq? ch st) ch)
((eq? ch gu) gu)
(else st)))
#| -------------------------------------------------------------------------
TESTS:
|#
(eq? (reveal1 'a 'a 'x) 'a)
(eq? (reveal1 'x '_ 'x) 'x)
(eq? (reveal1 'x '_ 'y) '_)
(equal? (reveal (make-word 'd 'e 'r) (make-word '_ '_ '_) 'd)
(make-word 'd '_ '_))
(equal? (reveal (make-word 'd 'e 'r) (make-word '_ '_ '_) 'f)
(make-word '_ '_ '_))
;; check errors
#;
(check-error (hangman make-word) "hangman: primitive operator requires 3 arguments")
#;
(check-error (hangman (make-word 'a 'b 'c) reveal draw-next-part)
"hangman: primitive operator hangman expects a defined procedure name (usually `make-word') in this position")
#;
(check-error (hangman make-word (reveal (make-word 'd 'e 'r) (make-word '_ '_ '_) 'd) draw-next-part)
"hangman: primitive operator hangman expects a defined procedure name (usually `reveal') in this position")
#;
(check-error (hangman make-word reveal 100)
"hangman: primitive operator hangman expects a defined procedure name (usually `draw-next') in this position")