mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-04-30 03:40:34 +02:00
Support for renaming bindings on module export.
* module/ice-9/boot-9.scm (module-export!, module-replace!) (module-re-export!): Allow members of export list to be pairs, mapping internal names to external ones. * doc/ref/api-modules.texi (Creating Guile Modules): Update documentation for `#:export', `#:export-syntax', `#:replace', `#:re-export', `#:re-export-syntax', `export', and `re-export' to reflect new format for arguments.
This commit is contained in:
parent
820f33aaed
commit
78c22f5edc
2 changed files with 43 additions and 31 deletions
|
@ -416,40 +416,42 @@ the module is used.
|
|||
|
||||
@item #:export @var{list}
|
||||
@cindex export
|
||||
Export all identifiers in @var{list} which must be a list of symbols.
|
||||
This is equivalent to @code{(export @var{list})} in the module body.
|
||||
Export all identifiers in @var{list} which must be a list of symbols
|
||||
or pairs of symbols. This is equivalent to @code{(export @var{list})}
|
||||
in the module body.
|
||||
|
||||
@item #:re-export @var{list}
|
||||
@cindex re-export
|
||||
Re-export all identifiers in @var{list} which must be a list of
|
||||
symbols. The symbols in @var{list} must be imported by the current
|
||||
module from other modules. This is equivalent to @code{re-export}
|
||||
below.
|
||||
symbols or pairs of symbols. The symbols in @var{list} must be
|
||||
imported by the current module from other modules. This is equivalent
|
||||
to @code{re-export} below.
|
||||
|
||||
@item #:export-syntax @var{list}
|
||||
@cindex export-syntax
|
||||
Export all identifiers in @var{list} which must be a list of symbols.
|
||||
The identifiers in @var{list} must refer to macros (@pxref{Macros})
|
||||
defined in the current module. This is equivalent to
|
||||
@code{(export-syntax @var{list})} in the module body.
|
||||
Export all identifiers in @var{list} which must be a list of symbols
|
||||
or pairs of symbols. The identifiers in @var{list} must refer to
|
||||
macros (@pxref{Macros}) defined in the current module. This is
|
||||
equivalent to @code{(export-syntax @var{list})} in the module body.
|
||||
|
||||
@item #:re-export-syntax @var{list}
|
||||
@cindex re-export-syntax
|
||||
Re-export all identifiers in @var{list} which must be a list of
|
||||
symbols. The symbols in @var{list} must refer to macros imported by
|
||||
the current module from other modules. This is equivalent to
|
||||
@code{(re-export-syntax @var{list})} in the module body.
|
||||
symbols or pairs of symbols. The symbols in @var{list} must refer to
|
||||
macros imported by the current module from other modules. This is
|
||||
equivalent to @code{(re-export-syntax @var{list})} in the module body.
|
||||
|
||||
@item #:replace @var{list}
|
||||
@cindex replace
|
||||
@cindex replacing binding
|
||||
@cindex overriding binding
|
||||
@cindex duplicate binding
|
||||
Export all identifiers in @var{list} (a list of symbols) and mark them
|
||||
as @dfn{replacing bindings}. In the module user's name space, this
|
||||
will have the effect of replacing any binding with the same name that
|
||||
is not also ``replacing''. Normally a replacement results in an
|
||||
``override'' warning message, @code{#:replace} avoids that.
|
||||
Export all identifiers in @var{list} (a list of symbols or pairs of
|
||||
symbols) and mark them as @dfn{replacing bindings}. In the module
|
||||
user's name space, this will have the effect of replacing any binding
|
||||
with the same name that is not also ``replacing''. Normally a
|
||||
replacement results in an ``override'' warning message,
|
||||
@code{#:replace} avoids that.
|
||||
|
||||
This is useful for modules that export bindings that have the same
|
||||
name as core bindings. @code{#:replace}, in a sense, lets Guile know
|
||||
|
@ -557,8 +559,11 @@ do not know anything about dangerous procedures.
|
|||
@c end
|
||||
|
||||
@deffn syntax export variable @dots{}
|
||||
Add all @var{variable}s (which must be symbols) to the list of exported
|
||||
bindings of the current module.
|
||||
Add all @var{variable}s (which must be symbols or pairs of symbols) to
|
||||
the list of exported bindings of the current module. If @var{variable}
|
||||
is a pair, its @code{car} gives the name of the variable as seen by the
|
||||
current module and its @code{cdr} specifies a name for the binding in
|
||||
the current module's public interface.
|
||||
@end deffn
|
||||
|
||||
@c begin (scm-doc-string "boot-9.scm" "define-public")
|
||||
|
@ -568,9 +573,10 @@ Equivalent to @code{(begin (define foo ...) (export foo))}.
|
|||
@c end
|
||||
|
||||
@deffn syntax re-export variable @dots{}
|
||||
Add all @var{variable}s (which must be symbols) to the list of
|
||||
re-exported bindings of the current module. Re-exported bindings must
|
||||
be imported by the current module from some other module.
|
||||
Add all @var{variable}s (which must be symbols or pairs of symbols) to
|
||||
the list of re-exported bindings of the current module. Pairs of
|
||||
symbols are handled as in @code{export}. Re-exported bindings must be
|
||||
imported by the current module from some other module.
|
||||
@end deffn
|
||||
|
||||
@node Module System Reflection
|
||||
|
|
|
@ -2968,16 +2968,20 @@ module '(ice-9 q) '(make-q q-length))}."
|
|||
(define (module-export! m names)
|
||||
(let ((public-i (module-public-interface m)))
|
||||
(for-each (lambda (name)
|
||||
(let ((var (module-ensure-local-variable! m name)))
|
||||
(module-add! public-i name var)))
|
||||
(let* ((internal-name (if (pair? name) (car name) name))
|
||||
(external-name (if (pair? name) (cdr name) name))
|
||||
(var (module-ensure-local-variable! m internal-name)))
|
||||
(module-add! public-i external-name var)))
|
||||
names)))
|
||||
|
||||
(define (module-replace! m names)
|
||||
(let ((public-i (module-public-interface m)))
|
||||
(for-each (lambda (name)
|
||||
(let ((var (module-ensure-local-variable! m name)))
|
||||
(let* ((internal-name (if (pair? name) (car name) name))
|
||||
(external-name (if (pair? name) (cdr name) name))
|
||||
(var (module-ensure-local-variable! m internal-name)))
|
||||
(set-object-property! var 'replace #t)
|
||||
(module-add! public-i name var)))
|
||||
(module-add! public-i external-name var)))
|
||||
names)))
|
||||
|
||||
;; Re-export a imported variable
|
||||
|
@ -2985,13 +2989,15 @@ module '(ice-9 q) '(make-q q-length))}."
|
|||
(define (module-re-export! m names)
|
||||
(let ((public-i (module-public-interface m)))
|
||||
(for-each (lambda (name)
|
||||
(let ((var (module-variable m name)))
|
||||
(let* ((internal-name (if (pair? name) (car name) name))
|
||||
(external-name (if (pair? name) (cdr name) name))
|
||||
(var (module-variable m internal-name)))
|
||||
(cond ((not var)
|
||||
(error "Undefined variable:" name))
|
||||
((eq? var (module-local-variable m name))
|
||||
(error "re-exporting local variable:" name))
|
||||
(error "Undefined variable:" internal-name))
|
||||
((eq? var (module-local-variable m internal-name))
|
||||
(error "re-exporting local variable:" internal-name))
|
||||
(else
|
||||
(module-add! public-i name var)))))
|
||||
(module-add! public-i external-name var)))))
|
||||
names)))
|
||||
|
||||
(defmacro export names
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue