racket/collects/scribblings/htdp-langs/intermediate-lambda.scrbl
2012-06-25 19:15:09 -04:00

126 lines
3.8 KiB
Racket

#lang scribble/doc
@(require "common.rkt" "std-grammar.rkt" "prim-ops.rkt"
(for-label lang/htdp-intermediate-lambda))
@title[#:tag "intermediate-lam"]{Intermediate Student with Lambda}
@declare-exporting[lang/htdp-intermediate-lambda]
@racketgrammar*+qq[
#:literals (define define-struct lambda λ cond else if and or require lib planet
local let let* letrec time check-expect check-within check-member-of check-range check-error)
(check-expect check-within check-member-of check-range check-error require)
[program (code:line def-or-expr ...)]
[def-or-expr definition
expr
test-case
library-require]
[definition (define (name variable variable ...) expr)
(define name expr)
(define-struct name (name ...))]
[expr (lambda (variable variable ...) expr)
(λ (variable variable ...) expr)
(local [definition ...] expr)
(letrec ([name expr] ...) expr)
(let ([name expr] ...) expr)
(let* ([name expr] ...) expr)
(code:line (expr expr expr ...))
(cond [expr expr] ... [expr expr])
(cond [expr expr] ... [else expr])
(if expr expr expr)
(and expr expr expr ...)
(or expr expr expr ...)
(time expr)
(code:line name)
(code:line prim-op)
(code:line @#,elem{@racketvalfont{'}@racket[_quoted]})
(code:line @#,elem{@racketvalfont{`}@racket[_quasiquoted]})
number
boolean
string
character]
]
@prim-nonterms[("intm-w-lambda") define define-struct]
@prim-variables[("intm-w-lambda") empty true false .. ... .... ..... ......]
@; ----------------------------------------------------------------------
@section[#:tag "intm-w-lambda-syntax"]{Syntax for Intermediate with Lambda}
@defform[(lambda (variable variable ...) expression)]{
Creates a function that takes as many arguments as given @racket[variable]s,
and whose body is @racket[expression].}
@defform[(λ (variable variable ...) expression)]{
The Greek letter @racket[λ] is a synonym for @racket[lambda].}
@defform/none[(expression expression expression ...)]{
Calls the function that results from evaluating the first
@racket[expression]. The value of the call is the value of function's body when
every instance of @racket[name]'s variables are replaced by the values of the
corresponding @racket[expression]s.
The function being called must come from either a definition appearing before the
function call, or from a @racket[lambda] expression. The number of argument
@racket[expression]s must be the same as the number of arguments expected by
the function.}
@(intermediate-forms lambda
local
letrec
let*
let
time
define
define-struct)
@; ----------------------------------------------------------------------
@section[#:tag "intm-w-lambda-common-syntax"]{Common Syntaxes}
The following syntaxes behave the same in the @emph{Intermediate with Lambda}
level as they did in the @secref["intermediate"] level.
@(define-forms/normal define)
@(beginner-abbr-forms quote quasiquote unquote unquote-splicing)
@(prim-forms ("intermediate-lam")
define
lambda
define-struct []
define-wish
cond
else
if
and
or
check-expect
check-within
check-error
check-member-of
check-range
require
true false
#:with-beginner-function-call #f)
@section[#:tag "intm-w-lambda-pre-defined"]{Pre-defined Functions}
@(require (submod lang/htdp-intermediate-lambda procedures))
@(render-sections (docs) #'here "htdp-intermediate-lambda")
@;prim-op-defns['(lib "htdp-intermediate-lambda.rkt" "lang") #'here '()]