racket/collects/redex/pict.ss
Casey Klein bbc654c69e Typesetting now recognizes carets (^) in the underscore component of a
non-terminal reference, applying the non-terminal-superscript-style to
the text following the caret.

svn: r17801
2010-01-24 11:36:29 +00:00

116 lines
3.8 KiB
Scheme

#lang scheme/base
(require scheme/contract
"private/pict.ss"
"private/core-layout.ss"
"private/loc-wrapper.ss"
"reduction-semantics.ss"
(lib "mred.ss" "mred")
(lib "mrpict.ss" "texpict"))
(define reduction-rule-style/c
(symbols 'compact-vertical
'vertical
'vertical-overlapping-side-conditions
'horizontal-left-align
'horizontal))
(provide reduction-rule-style/c render-term term->pict)
(provide/contract
[render-reduction-relation
(->d ([rel reduction-relation?])
([file (or/c false/c path-string?)]
#:style [style reduction-rule-style/c])
[result (if (path-string? file)
void?
pict?)])]
[reduction-relation->pict (->* (reduction-relation?)
(#:style reduction-rule-style/c)
pict?)]
[render-reduction-relation-rules (parameter/c (or/c false/c (listof (or/c symbol? string?))))]
[language->pict (->* (compiled-lang?)
(#:nts (or/c false/c (listof (or/c string? symbol?))))
pict?)]
[render-language
(->d ([lang compiled-lang?])
([file (or/c false/c path-string?)]
#:nts [nts (or/c false/c (listof (or/c string? symbol?)))])
[result (if (path-string? file)
void?
pict?)])])
; syntax
(provide metafunction->pict
metafunctions->pict
render-metafunction
render-metafunctions)
(provide/contract
[render-language-nts (parameter/c (or/c false/c (listof (or/c string? symbol?))))]
[extend-language-show-union (parameter/c boolean?)]
[current-text (parameter/c (-> string? text-style/c number? pict?))])
(provide/contract
[label-style (parameter/c text-style/c)]
[literal-style (parameter/c text-style/c)]
[metafunction-style (parameter/c text-style/c)]
[default-style (parameter/c text-style/c)]
[non-terminal-style (parameter/c text-style/c)]
[non-terminal-subscript-style (parameter/c text-style/c)]
[non-terminal-superscript-style (parameter/c text-style/c)]
[linebreaks (parameter/c (or/c false/c (listof boolean?)))]
[curly-quotes-for-strings (parameter/c boolean?)]
[white-bracket-sizing (parameter/c
(-> string? number? (values number? number? number? number?)))])
(provide/contract
[rule-pict-style
(parameter/c reduction-rule-style/c)]
[arrow-space (parameter/c natural-number/c)]
[label-space (parameter/c natural-number/c)]
[metafunction-cases (parameter/c (or/c #f (and/c pair? (listof (and/c integer? (or/c zero? positive?))))))]
[metafunction-pict-style
(parameter/c (symbols 'left-right
'left-right/vertical-side-conditions
'left-right/compact-side-conditions
'left-right/beside-side-conditions
'up-down
'up-down/vertical-side-conditions
'up-down/compact-side-conditions))])
(provide/contract
[label-font-size (parameter/c (and/c (between/c 1 255) integer?))]
[default-font-size (parameter/c (and/c (between/c 1 255) integer?))]
[metafunction-font-size (parameter/c (and/c (between/c 1 255) integer?))]
[reduction-relation-rule-separation (parameter/c (and/c integer? positive? exact?))])
(provide
build-lw
lw
lw?
lw-e
lw-line
lw-line-span
lw-column
lw-column-span)
(provide to-lw
(struct-out lw))
(provide/contract
[just-before (-> (or/c pict? string? symbol?) lw? lw?)]
[just-after (-> (or/c pict? string? symbol?) lw? lw?)])
(provide with-unquote-rewriter
with-compound-rewriter
with-atomic-rewriter)
(provide/contract
[set-arrow-pict! (-> symbol? (-> pict?) void?)]
[lw->pict
(-> (or/c (listof symbol?) compiled-lang?) lw? pict?)]
[render-lw
(-> (or/c (listof symbol?) compiled-lang?) lw? pict?)])