support documentation for bindings from a hypothetical module, as opposed to a specific module

svn: r8663

original commit: b87d9a986e99eaafc88789125153c0a1e39b5441
This commit is contained in:
Matthew Flatt 2008-02-14 16:59:26 +00:00
parent 1fa2c2dc4d
commit 42daa454b8
2 changed files with 48 additions and 19 deletions

View File

@ -256,13 +256,10 @@
;; String String *-> Element
;; an in-lined image, relative to the current directory
(define (image filename-relative-to-source . alt)
(centerline ;; this doesn't do anything?
(make-element
(make-image-file filename-relative-to-source)
(decode-content alt))))
(make-element
(make-image-file filename-relative-to-source)
(decode-content alt)))
;; MF! -- the centerline is used in the drscheme manual
;; otherwise I'd switch
(define (image/plain filename-relative-to-source . alt)
(make-element
(make-image-file filename-relative-to-source)
@ -376,7 +373,8 @@
checker))))])
(and (checker id)
lib)))
source-libs)
(or source-libs
null))
(and (pair? libs)
(car libs)))])
(and lib
@ -571,10 +569,23 @@
schemegrammar schemegrammar*
var svar void-const undefined-const)
(define-syntax declare-exporting
(syntax-rules ()
[(_ lib ... #:use-sources (plib ...)) (*declare-exporting '(lib ...) '(plib ...))]
[(_ lib ...) (*declare-exporting '(lib ...) '())]))
(define-syntax (declare-exporting stx)
(syntax-case stx ()
[(_ lib ... #:use-sources (plib ...))
(let ([libs (syntax->list #'(lib ... plib ...))])
(for-each (lambda (l)
(unless (module-path? (syntax->datum l))
(raise-syntax-error #f
"not a module path"
stx
l)))
libs)
(when (null? libs)
(raise-syntax-error #f
"need at least one module path"
stx))
#'(*declare-exporting '(lib ...) '(plib ...)))]
[(_ lib ...) #'(*declare-exporting '(lib ...) '())]))
(define-struct (exporting-libraries element) (libs source-libs))
@ -585,9 +596,10 @@
(make-collect-element #f
null
(lambda (ri)
(collect-put! ri '(exporting-libraries #f) libs))))
(collect-put! ri '(exporting-libraries #f)
libs))))
(make-part-collect-decl
(make-exporting-libraries #f null libs source-libs)))))
(make-exporting-libraries #f null (and (pair? libs) libs) source-libs)))))
(define-syntax (quote-syntax/loc stx)
(syntax-case stx ()

View File

@ -209,13 +209,13 @@ Like @scheme[defmodule], but documents @scheme[id] as a module path
suitable for use by either @scheme[require] or @schememodfont{#lang}.}
@defform[(defmodule* (id ...) maybe-sources pre-flow ...)]{
@defform[(defmodule* (id ...+) maybe-sources pre-flow ...)]{
Like @scheme[defmodule], but introduces multiple module paths instead
of just one.}
@defform[(defmodulelang* (id ...) maybe-sources pre-flow ...)]{
@defform[(defmodulelang* (id ...+) maybe-sources pre-flow ...)]{
Like @scheme[defmodulelang], but introduces multiple module paths
instead of just one.}
@ -267,6 +267,13 @@ declaration:
}
The initial @scheme[mod-path]s sequence can be empty if
@scheme[mod-path]s are given with @scheme[#:use-sources]. In that
case, the rendered documentation never reports an exporting module for
identifiers that are documented within the section, but the
@scheme[mod-path]s in @scheme[#:use-sources] provide a binding context
for connecting (via hyperlinks) definitions and uses of identifiers.
The @scheme[declare-exporting] form should be used no more than once
per section, since the declaration applies to the entire section,
although overriding @scheme[declare-exporting] forms can appear in
@ -862,12 +869,22 @@ combination of @scheme[envvar] and @scheme[as-index].}
@; ------------------------------------------------------------------------
@section{Images}
@defproc[(image [filename-relative-to-source string?]) element?]{
creates a centered image, from the given relative source path.}
@defproc[(image [filename-relative-to-source string?]
[pre-element any/c] ...)
flow-element?]{
Creates a centered image from the given relative source path. The
@tech{decode}d @scheme[pre-content] serves as the alternate text for
contexts where the image cannot be displayed.
@defproc[(image/plain [filename-relative-to-source string?]) element?]{
creates an in-lined image, from the given relative source path.}
The path is relative to the current directory, which is set by
@exec{setup-plt} and @exec{scribble} to the directory of the main
document file.}
@defproc[(image/plain [filename-relative-to-source string?]
[pre-element any/c] ...)
element?]{
Like @scheme[image], but the result is an element to appear inline in
a paragraph.}
@; ------------------------------------------------------------------------
@section{Bibliography}