racket/collects/syntax/scribblings/toplevel.scrbl
Matthew Flatt bb0da64842 revise syntax scribblings
svn: r8671
2008-02-15 14:06:21 +00:00

57 lines
2.2 KiB
Racket

#lang scribble/doc
@(require "common.ss"
(for-label syntax/toplevel))
@title[#:tag "toplevel"]{Non-Module Compilation And Expansion}
@defmodule[syntax/toplevel]
@defproc[(expand-syntax-top-level-with-compile-time-evals [stx syntax?])
syntax?]{
Expands @scheme[stx] as a top-level expression, and evaluates its
compile-time portion for the benefit of later expansions.
The expander recognizes top-level @scheme[begin] expressions, and
interleaves the evaluation and expansion of of the @scheme[begin]
body, so that compile-time expressions within the @scheme[begin] body
affect later expansions within the body. (In other words, it ensures
that expanding a @scheme[begin] is the same as expanding separate
top-level expressions.)
The @scheme[stx] should have a context already, possibly introduced with
@scheme[namespace-syntax-introduce].}
@defproc[(expand-top-level-with-compile-time-evals [stx syntax?])
syntax?]{
Like @scheme[expand-syntax-top-level-with-compile-time-evals], but
@scheme[stx] is first given context by applying
@scheme[namespace-syntax-introduce] to it.}
@defproc[(expand-syntax-top-level-with-compile-time-evals/flatten [stx syntax?])
(listof syntax?)]{
Like @scheme[expand-syntax-top-level-with-compile-time-evals], except
that it returns a list of syntax objects, none of which have a
@scheme[begin]. These syntax objects are the flattened out contents of
any @scheme[begin]s in the expansion of @scheme[stx].}
@defproc[(eval-compile-time-part-of-top-level [stx syntax?])
void?]{
Evaluates expansion-time code in the fully expanded top-level
expression represented by @scheme[stx] (or a part of it, in the case
of @scheme[begin] expressions). The expansion-time code might affect
the compilation of later top-level expressions. For example, if
@scheme[stx] is a @scheme[require] expression, then
@scheme[namespace-require/expansion-time] is used on each require
specification in the form. Normally, this function is used only by
@scheme[expand-top-level-with-compile-time-evals].}
@defproc[(eval-compile-time-part-of-top-level/compile [stx syntax?])
(listof compiled-expression?)]{
Like @scheme[eval-compile-time-part-of-top-level], but the result is
compiled code.}