Scribble docs: split preprocessor variants into a separate manual
original commit: ce31b5965c4680ca53cb85d6ec6731e2f949878f
This commit is contained in:
parent
b23fb873f5
commit
e7adecfd59
|
@ -577,7 +577,8 @@ the @hash-lang[] line that starts the document. The
|
||||||
@racket[decode] operation. The @racketmodname[scribble/text] language,
|
@racket[decode] operation. The @racketmodname[scribble/text] language,
|
||||||
however, acts more like a plain-text generator and preprocessor, and it
|
however, acts more like a plain-text generator and preprocessor, and it
|
||||||
does not perform any such decoding rules. (For more on
|
does not perform any such decoding rules. (For more on
|
||||||
@racketmodname[scribble/text], see @secref["text"].)
|
@racketmodname[scribble/text], see @other-doc['(lib
|
||||||
|
"scribblings/scribble/scribble-pp.scrbl")].)
|
||||||
|
|
||||||
@margin-note{More precisely, languages like
|
@margin-note{More precisely, languages like
|
||||||
@racketmodname[scribble/base] apply @racket[decode] only after
|
@racketmodname[scribble/base] apply @racket[decode] only after
|
||||||
|
@ -677,4 +678,5 @@ Racket, continue with @secref["reader"] and then
|
||||||
need more power.
|
need more power.
|
||||||
|
|
||||||
If you are interested in text generation and preprocessing, continue
|
If you are interested in text generation and preprocessing, continue
|
||||||
with @secref["reader"], but then skip to @secref["text"].
|
with @secref["reader"], but then switch to
|
||||||
|
@other-doc['(lib "scribblings/scribble/scribble-pp.scrbl")].
|
|
@ -1,6 +1,7 @@
|
||||||
#lang info
|
#lang info
|
||||||
|
|
||||||
(define scribblings '(("scribble.scrbl" (multi-page) (racket-core -24))
|
(define scribblings '(("scribble.scrbl" (multi-page) (racket-core -24))
|
||||||
|
("scribble-pp.scrbl" (multi-page) (tool))
|
||||||
|
|
||||||
("demo-s1.scrbl" (keep-style no-search) (omit-start))
|
("demo-s1.scrbl" (keep-style no-search) (omit-start))
|
||||||
("demo-m1.scrbl" (multi-page keep-style no-search) (omit-start))
|
("demo-m1.scrbl" (multi-page keep-style no-search) (omit-start))
|
||||||
|
|
|
@ -0,0 +1,26 @@
|
||||||
|
#lang scribble/manual
|
||||||
|
@(require "utils.rkt")
|
||||||
|
|
||||||
|
@title{Scribble as Preprocessor}
|
||||||
|
|
||||||
|
@author["Matthew Flatt" "Eli Barzilay"]
|
||||||
|
|
||||||
|
@section-index["Preprocessor"]
|
||||||
|
|
||||||
|
The @racketmodname[scribble/text] and @racketmodname[scribble/html]
|
||||||
|
languages act as ``preprocessor'' languages for generating text or
|
||||||
|
HTML. These preprocessor languages use the same @"@" syntax as the
|
||||||
|
main Scribble tool (see @other-doc['(lib
|
||||||
|
"scribblings/scribble/scribble.scrbl")]), but instead of working in
|
||||||
|
terms of a document abstraction that can be rendered to text and HTML
|
||||||
|
(and other formats), the preprocessor languages work in a way that is
|
||||||
|
more specific to the target formats.
|
||||||
|
|
||||||
|
@table-of-contents[]
|
||||||
|
|
||||||
|
@; ------------------------------------------------------------------------
|
||||||
|
|
||||||
|
@include-section["text.scrbl"]
|
||||||
|
@include-section["html.scrbl"]
|
||||||
|
|
||||||
|
@index-section[]
|
|
@ -1,5 +1,5 @@
|
||||||
#lang scribble/manual
|
#lang scribble/manual
|
||||||
@(require scribble/bnf "utils.rkt")
|
@(require "utils.rkt")
|
||||||
|
|
||||||
@title{Scribble: The Racket Documentation Tool}
|
@title{Scribble: The Racket Documentation Tool}
|
||||||
|
|
||||||
|
@ -26,8 +26,6 @@ starting with the @filepath{scribble.scrbl} file.
|
||||||
@include-section["generic.scrbl"]
|
@include-section["generic.scrbl"]
|
||||||
@include-section["plt.scrbl"]
|
@include-section["plt.scrbl"]
|
||||||
@include-section["lp.scrbl"]
|
@include-section["lp.scrbl"]
|
||||||
@include-section["text.scrbl"]
|
|
||||||
@include-section["html.scrbl"]
|
|
||||||
@include-section["internals.scrbl"]
|
@include-section["internals.scrbl"]
|
||||||
@include-section["running.scrbl"]
|
@include-section["running.scrbl"]
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,8 @@
|
||||||
@initialize-tests
|
@initialize-tests
|
||||||
|
|
||||||
@(define (tech/r s) @tech[s #:doc '(lib "scribblings/reference/reference.scrbl")])
|
@(define (tech/r s) @tech[s #:doc '(lib "scribblings/reference/reference.scrbl")])
|
||||||
|
@(define scribble-doc '(lib "scribblings/scribble/scribble.scrbl"))
|
||||||
|
@(define @-form @tech[#:doc scribble-doc]{@"@"-forms})
|
||||||
|
|
||||||
@(define-syntax-rule (def-rkt t-id)
|
@(define-syntax-rule (def-rkt t-id)
|
||||||
(begin
|
(begin
|
||||||
|
@ -21,7 +23,6 @@
|
||||||
#:style (make-style #f (list (make-tex-addition "shaded.tex")
|
#:style (make-style #f (list (make-tex-addition "shaded.tex")
|
||||||
(make-css-addition "shaded.css")))
|
(make-css-addition "shaded.css")))
|
||||||
]{Text Generation}
|
]{Text Generation}
|
||||||
@section-index["Preprocessor"]
|
|
||||||
|
|
||||||
@defmodulelang[scribble/text]{The @racketmodname[scribble/text]
|
@defmodulelang[scribble/text]{The @racketmodname[scribble/text]
|
||||||
language provides everything from @racket[racket/base],
|
language provides everything from @racket[racket/base],
|
||||||
|
@ -33,9 +34,9 @@ preprocessor language:
|
||||||
@itemize[
|
@itemize[
|
||||||
|
|
||||||
@item{The language uses @racket[read-syntax-inside] to read the body
|
@item{The language uses @racket[read-syntax-inside] to read the body
|
||||||
of the module, similar to @secref["docreader"]. This means that
|
of the module, similar to @secref[#:doc scribble-doc "docreader"]. This means that
|
||||||
by default, all text is read in as Racket strings; and
|
by default, all text is read in as Racket strings; and
|
||||||
@seclink["reader"]|{@-forms}| can be used to use Racket
|
@seclink[#:doc scribble-doc "reader"]|{@-forms}| can be used to use Racket
|
||||||
functions and expression escapes.}
|
functions and expression escapes.}
|
||||||
|
|
||||||
@item{Values of expressions are printed with a custom @racket[output]
|
@item{Values of expressions are printed with a custom @racket[output]
|
||||||
|
@ -77,7 +78,7 @@ part shows the source input, and the right part the printed result.)
|
||||||
feature on top of feature, but
|
feature on top of feature, but
|
||||||
blah blah blah.}-|
|
blah blah blah.}-|
|
||||||
|
|
||||||
Using @seclink["reader"]|{@-forms}|, we can define and use Racket
|
Using @seclink[#:doc scribble-doc "reader"]|{@-forms}|, we can define and use Racket
|
||||||
functions.
|
functions.
|
||||||
|
|
||||||
@example|-{#lang scribble/text
|
@example|-{#lang scribble/text
|
||||||
|
@ -114,7 +115,7 @@ convenient conditional output.
|
||||||
You have 3 errors in your code,
|
You have 3 errors in your code,
|
||||||
I fixed 1 error.}-|
|
I fixed 1 error.}-|
|
||||||
|
|
||||||
Using the scribble @seclink["reader"]|{@-forms}| syntax, you can write
|
Using the scribble @seclink[#:doc scribble-doc "reader"]|{@-forms}| syntax, you can write
|
||||||
functions more conveniently too.
|
functions more conveniently too.
|
||||||
|
|
||||||
@example|-{#lang scribble/text
|
@example|-{#lang scribble/text
|
||||||
|
@ -277,14 +278,14 @@ The separator can be set to any value.
|
||||||
@section{Defining Functions and More}
|
@section{Defining Functions and More}
|
||||||
|
|
||||||
(Note: most of the tips in this section are applicable to any code
|
(Note: most of the tips in this section are applicable to any code
|
||||||
that uses the Scribble @tech{@"@"-form} syntax.)
|
that uses the Scribble @|@-form| syntax.)
|
||||||
|
|
||||||
Because the Scribble reader is uniform, you can use it in place of any
|
Because the Scribble reader is uniform, you can use it in place of any
|
||||||
expression where it is more convenient. (By convention, we use a
|
expression where it is more convenient. (By convention, we use a
|
||||||
plain S-expression syntax when we want a Racket expression escape, and
|
plain S-expression syntax when we want a Racket expression escape, and
|
||||||
an @tech{@"@"-form} for expressions that render as text, which, in the
|
an @|@-form| for expressions that render as text, which, in the
|
||||||
@racket[scribble/text] language, is any value-producing expression.)
|
@racket[scribble/text] language, is any value-producing expression.)
|
||||||
For example, you can use an @tech{@"@"-form} for a function that you define.
|
For example, you can use an @|@-form| for a function that you define.
|
||||||
|
|
||||||
@example|-{#lang scribble/text
|
@example|-{#lang scribble/text
|
||||||
@(define @bold[text] @list{*@|text|*})
|
@(define @bold[text] @list{*@|text|*})
|
||||||
|
@ -298,7 +299,7 @@ will need to accept a variable number of arguments. In fact, this
|
||||||
leads to a common problem: what if we want to write a function that
|
leads to a common problem: what if we want to write a function that
|
||||||
consumes a number of ``text arguments'' rathen than a single
|
consumes a number of ``text arguments'' rathen than a single
|
||||||
``rest-like'' body? The common solution for this is to provide the
|
``rest-like'' body? The common solution for this is to provide the
|
||||||
separate text arguments in the S-expression part of an @tech{@"@"-form}.
|
separate text arguments in the S-expression part of an @|@-form|.
|
||||||
|
|
||||||
@example|-{#lang scribble/text
|
@example|-{#lang scribble/text
|
||||||
@(define (choose 1st 2nd)
|
@(define (choose 1st 2nd)
|
||||||
|
@ -310,7 +311,7 @@ separate text arguments in the S-expression part of an @tech{@"@"-form}.
|
||||||
Either you're with us, or against us.
|
Either you're with us, or against us.
|
||||||
}-|
|
}-|
|
||||||
|
|
||||||
You can even use @tech{@"@"-forms} with a Racket quote or quasiquote as the
|
You can even use @|@-form|s with a Racket quote or quasiquote as the
|
||||||
``head'' part to make it shorter, or use a macro to get grouping of
|
``head'' part to make it shorter, or use a macro to get grouping of
|
||||||
sub-parts without dealing with quotes.
|
sub-parts without dealing with quotes.
|
||||||
|
|
||||||
|
@ -337,7 +338,7 @@ sub-parts without dealing with quotes.
|
||||||
|
|
||||||
Yet another solution is to look at the text values and split the input
|
Yet another solution is to look at the text values and split the input
|
||||||
arguments based on a specific token. Using @racket[match] can make it
|
arguments based on a specific token. Using @racket[match] can make it
|
||||||
convenient --- you can even specify the patterns with @tech{@"@"-forms}.
|
convenient --- you can even specify the patterns with @|@-form|s.
|
||||||
|
|
||||||
@example|-{#lang scribble/text
|
@example|-{#lang scribble/text
|
||||||
@(require racket/match)
|
@(require racket/match)
|
||||||
|
@ -487,7 +488,7 @@ is the indentation of the output. This can be crucial in some cases, if
|
||||||
you're generating code for an indentation-sensitive language (e.g.,
|
you're generating code for an indentation-sensitive language (e.g.,
|
||||||
Haskell, Python, or C preprocessor directives). To get a better
|
Haskell, Python, or C preprocessor directives). To get a better
|
||||||
understanding of how the pieces interact, you may want to review how the
|
understanding of how the pieces interact, you may want to review how the
|
||||||
@seclink["reader"]|{Scribble reader}| section, but also remember that
|
@seclink[#:doc scribble-doc "reader"]|{Scribble reader}| section, but also remember that
|
||||||
you can use quoted forms to see how some form is read.
|
you can use quoted forms to see how some form is read.
|
||||||
|
|
||||||
@example|-{#lang scribble/text
|
@example|-{#lang scribble/text
|
||||||
|
@ -983,7 +984,7 @@ trivial: the source text is still source code in a module, so you can
|
||||||
more
|
more
|
||||||
}-|
|
}-|
|
||||||
|
|
||||||
Note that the @seclink["at-exp-lang"]{@racket[at-exp] language} can
|
Note that the @seclink[#:doc scribble-doc "at-exp-lang"]{@racket[at-exp] language} can
|
||||||
often be useful here, since such files need to deal with texts. Using
|
often be useful here, since such files need to deal with texts. Using
|
||||||
it, it is easy to include a lot of textual content.
|
it, it is easy to include a lot of textual content.
|
||||||
|
|
||||||
|
@ -1018,7 +1019,7 @@ it, it is easy to include a lot of textual content.
|
||||||
}-|
|
}-|
|
||||||
|
|
||||||
Of course, the extreme side of this will be to put all of your content
|
Of course, the extreme side of this will be to put all of your content
|
||||||
in a plain Racket module, using @tech{@"@"-forms} for convenience. However,
|
in a plain Racket module, using @|@-form|s for convenience. However,
|
||||||
there is no need to use the text language in this case; instead, you can
|
there is no need to use the text language in this case; instead, you can
|
||||||
@racket[(require scribble/text)], which will get all of the bindings
|
@racket[(require scribble/text)], which will get all of the bindings
|
||||||
that are available in the @racket[scribble/text] language. Using
|
that are available in the @racket[scribble/text] language. Using
|
||||||
|
|
Loading…
Reference in New Issue
Block a user