R5RS discusses how to structure programs. Everything which is defined
in Section 5 of R5RS applies also to STklos. To make things
shorter, this aspects will not be described here (see R5RS for
complete information).
STklos modules can be used to organize a program into separate
environments (or name spaces). Modules provide a clean way to
organize and enforce the barriers between the components of a program.
STklos provides a simple module system which is largely inspired from
the one of Tung and Dybvig exposed in [15]. As their
modules system, STklos modules are defined to be easily used in an
interactive environment. 
| 
| (define-module <name> <expr1> <expr2> ...) | STklos syntax |  
 Define-moduleevaluates the expressions<expr1>,<expr2>... which
constitute the body of the module<name>in the environment of that module.Namemust be a valid symbol. If this symbol has not already been used to
define a module, a new module, namedname, is created.
Otherwise, the expressions<expr1>,<expr2>... are evaluated in
the environment of the (old) module<name>1.
Definitions done in a module are local to the module and do not interact with
the definitions in other modules. Consider the following definitions,Here, two modules are defined and they both bind the symbol
| (define-module M1
   (define a 1))
(define-module M2
  (define a 2)
  (define b (* 2 x)))
 | 
 ato a
value. However, sinceahas been defined in two distinct modules
they denote two different locations.
 The
 STklosmodule, which is predefined, is a special module which
contains all the global variables of a R5RS program.  A symbol
defined in theSTklosmodule, if not hidden by a local definition, is
always visible from inside a module. So, in the previous exemple, thexsymbol refers thexsymbol defined in theSTklosmodule.
 The result of
 define-moduleis void. | 
| 
| (current-module) | STklos procedure |  Returns the current module.
 
| (define-module M
  (display
      (cons (eq? (current-module) (find-module 'M))
            (eq? (current-module) (find-module 'STklos)))))
   -| (#t . #f)
 | 
 | 
| 
| (find-module name) | STklos procedure |  (find-module name default)
 STklos modules are first class objects and
 find-modulereturns the
module associated tonameif it exists. If there is no module
associated toname, an error is signaled if nodefaultis
provided, otherwisefind-modulereturnsdefault. | 
| 
| (module? object) | STklos procedure |  Returns
 #tifobjectis a module and#fotherwise.
| (module? (find-module 'STklos))  ⇒ #t
(module? 'STklos)                ⇒ #f
(module? 123 'no)                ⇒ no
 | 
 | 
| 
| (export <symbol1> <symbol2> ...) | STklos syntax |  Specifies the symbols which are exported (i.e. visible) outside
the current module. By default, symbols defined in a module are not
visible outside this module, excepted if they appear in an
 exportclause.
 If several
 exportclauses appear in a module, the set of
exported symbols is determined by ``unionizing'' symbols exported
in all theexportclauses.
 The result of
 exportis void. | 
| 
| (import <module1> <module2> ...) | STklos syntax |  Specifies the modules which are imported by the current module.
Importing a module makes the symbols it exports visible to the
importer, if not hidden by local definitions. When a symbol
is exported by several of the imported modules, the location denoted by
this symbol in the importer module correspond to the one of the first module
in the list
 which exports it.
| (<module1> <module2> ...)
 | 
 
 If several
 importclauses appear in a module, the set of
imported modules  is determined by appending the various list of modules
in their apparition order.(define-module M4
  (import M2 M1)
  (display (list a b c d)))  -| (M1-a M2-b M2-c M2-d)
| (define-module M1
  (export a b)
  (define a 'M1-a)
  (define b 'M1-b))
(define-module M2
  (export b c d)
  (define b 'M2-b)
  (define c 'M2-c)
  (define d 'M2-d))
(define-module M3
  (import M1 M2)
  (display (list a b c d)))  -| (M1-a M1-b M2-c M2-d)
 | 
 | 
| 
| (select-module <name>) | STklos syntax |  Changes the value of the current module to the module with the given
 name.
The expressions evaluated afterselect-modulewill take place in
modulenameenvironment.  Modulenamemust have been created
previously by adefine-module. The result ofselect-moduleis
void.Select-moduleis particularly useful when debugging since it
allows to place toplevel evaluation in a particular module. The
following transcript shows an usage ofselect-module.
2:
| stklos> (define foo 1)
stklos> (define-module bar
          (define foo 2))
stklos> foo
1
stklos> (select-module bar)
bar> foo
2
bar> (select-module stklos)
stklos>
 | 
 | 
| 
| (symbol-value symbol module) | STklos procedure |  (symbol-value symbol module default)
 Returns the value bound to
 symbolinmodule. Ifsymbolis not bound,
an error is signaled if nodefaultis provided, otherwisesymbol-valuereturnsdefault. | 
| 
| (symbol-value* symbol module) | STklos procedure |  (symbol-value* symbol module default)
 Returns the value bound to
 symbolinmodule. Ifsymbolis not bound,
an error is signaled if nodefaultis provided, otherwisesymbol-valuereturnsdefault.
 Note that this function searches the value of
 symbolinmoduleand all the modules it imports whereassymbol-valuesearches
only inmodule. | 
| 
| (module-name module) | STklos procedure |  Returns the name (a symbol) associated to a
 module. | 
| 
| (module-imports module) | STklos procedure |  Returns the list of modules that
 module(fully) imports. | 
| 
| (module-exports module) | STklos procedure |  Returns the list of symbols exported by
 module. Note that this function
returns the list of symbols given in the moduleexportclause and that
some of these symbols can be not yet defined. | 
| 
| (module-symbols module) | STklos procedure |  Returns the list of symbols already defined in
 module. | 
| 
| (all-modules) | STklos procedure |  Returns the list of all the living modules.
 | 
| 
| (in-module mod s) | STklos syntax |  (in-module mod s default)
 This form returns the value of symbol with name
 sin the module with namemod. If this symbol is not bound,  an error is signaled if nodefaultis
provided, otherwisein-modulereturnsdefault. Note that the value ofsis searched inmodand all the modules it imports.
 This form is in fact a shortcut. In effect,
 
| (in-module my-module foo)
 | 
 
 is equivalent to
 
| (symbol-value* 'foo (find-module 'my-module))
 | 
 |