Provided by: chezscheme_9.5.8+dfsg-1_amd64 
      
    
NAME
       chezscheme - Chez Scheme
       petite - Petite Chez Scheme
SYNOPSIS
       scheme [ options ] file ...
       petite [ options ] file ...
DESCRIPTION
       Chez  Scheme  is  a  programming language, based on R6RS Scheme, and a high-performance implementation of
       that language.  Chez Scheme compiles source expressions incrementally  to  machine  code,  providing  the
       speed of compiled code in an interactive system.
       Petite  Chez  Scheme  is an interpreted version of Chez Scheme that may be used as a run-time environment
       for Chez Scheme applications or as a stand-alone Scheme system.  With the exception that the compiler  is
       not  present, Petite Chez Scheme is 100% compatible with Chez Scheme.  Interpreted code is fast in Petite
       Chez Scheme, but generally not nearly as fast as compiled code.  Debugging and profiling support is  also
       limited for interpreted code.
       Scheme  is  normally used interactively.  The system prompts the user with a right angle bracket (“>”) at
       the beginning of each input line.  Any Scheme expression  may  be  entered.   The  system  evaluates  the
       expression  and  prints  the result.  After printing the result, the system prompts again for more input.
       The user can exit the system by typing Control-D or by using the procedure exit.
COMMAND-LINE OPTIONS
       Chez Scheme recognizes the following command line options:
       -q, --quiet
                 Suppress greeting and prompts.
       --script file
                 Run file as a shell script.
       --program file
                 Run rnrs program in file as a shell script.
       --libdirs dir:...
                 Set library directories to dir:....
       --libexts ext:...
                 Set library extensions to ext:....
       --compile-imported-libraries
                 Compile libraries before loading them.
       --import-notify
                 Enable import search messages.
       --optimize-level 0 | 1 | 2 | 3
                 Set optimize level to 0, 1, 2, or 3.
       --debug-on-exception
                 On uncaught exception, call debug.
       --eedisable
                 Disables the expression editor.
       --eehistory off | file
                 Set expression-editor history file or disable restore and save of history.
       --enable-object-counts
                 Have collector maintain object counts.
       --retain-static-relocation
                 Keep reloc information for compute-size, etc.
       -b file, --boot file
                 Load boot code from file.
       --verbose Trace boot search process.
       --version Print version and exit.
       --help    Print brief command-line help and exit.
       --        Pass all remaining command-line arguments through to Scheme.
       The following options are recognized but cause the system to print an  error  message  and  exit  because
       saved heaps are not presently supported.
       -h file, --heap file
       -s[level] file, --saveheap[level] file
       -c, --compact
       Any  remaining  command-line  arguments are treated as the names of files to be loaded before Chez Scheme
       begins interacting with the user (see COMMAND-LINE FILE ARGUMENTS), unless “--script” or  “--program”  is
       present,  in  which  case  the  remaining arguments are made available to the script via the command-line
       parameter (see SCHEME SCRIPTS).
WAITERS and CAFES
       Interaction of the system with the user is performed by a Scheme program called a waiter,  running  in  a
       program  state  called  a  cafe.   The waiter merely prompts, reads, evaluates, prints and loops back for
       more.  It is possible to open up a chain of Chez Scheme cafes by invoking the new-cafe procedure with  no
       arguments.   New-cafe  is  also one of the options when an interrupt occurs.  Each cafe has its own reset
       and exit procedures.  Exiting from one cafe in the chain returns you to the next one  back,  and  so  on,
       until the entire chain closes and you leave the system altogether.  Sometimes it is useful to interrupt a
       long  computation  by  typing  the interrupt character, enter a new cafe to execute something (perhaps to
       check a status variable set by computation), and exit the cafe back to the old computation.
       You can tell what level you are at by the number of angle brackets in the prompt, one for level one,  two
       for  level  two,  and  so on.  Three angle brackets in the prompt means you would have to exit from three
       cafes to get out of Chez Scheme.  If you wish to abort from Chez Scheme and you are several  cafes  deep,
       the procedure abort leaves the system directly.
       You  can  exit  the  system  by  typing  the  end-of-file  character (normally Control-D) or by using the
       procedure exit.  Typing Control-D is equivalent to (exit), (exit (void)), or (exit 0), each of  which  is
       considered a “normal exit”.
DEBUGGER
       Ordinarily,  if  an  exception occurs during interactive use of the system, the default exception handler
       displays the condition with which the exception was raised, saves  it  for  possibly  later  use  by  the
       debugger,  and  prints  the message "type (debug) to enter the debugger."  Once in the debugger, the user
       has the option of inspecting the raise continuation, i.e., the stack frames of the pending  calls.   When
       an  exception occurs in a script or top level program, or when the standard input and/or output ports are
       redirected, the default exception handler does not save the continuation of the exception  and  does  not
       print the "type (debug)" message.
       If the parameter debug-on-exception is set to #t, however, the default exception handler directly invokes
       debug,  whether  running  interactively or not, and even when running a script or top-level program.  The
       “--debug-on-exception” option may be used to set debug-on-exception to #t from the command line, which is
       particularly useful when debugging scripts or top-level programs run via the  “--script”  or  “--program”
       options.
       None  of  this applies to exceptions raised with a non-serious (warning) condition, for which the default
       exception handler simply displays the condition and returns.
KEYBOARD INTERRUPTS
       Running programs may be  interrupted  by  typing  the  interrupt  character  (normally  Control-C).    In
       response,  the  system  enters  a break handler, which prompts for input with a “break>” prompt.  Several
       commands may be issued to the break handler, including “e” to exit from the handler and continue, “r”  to
       reset  to the current cafe, “a” to abort Chez Scheme, “n” to enter a new cafe, “i” to inspect the current
       continuation, and “s” to display statistics about the interrupted program.  While typing an expression to
       the waiter, the interrupt character simply resets to the current cafe.
EXPRESSION EDITOR
       When Chez Scheme is used interactively in a shell  window,  the  waiter's  “prompt  and  read”  procedure
       employs  an  expression  editor  that permits entry and editing of single- and multiple-line expressions,
       automatically indents expressions as  they  are  entered,  and  supports  name-completion  based  on  the
       identifiers  defined  in  the interactive environment.  The expression editor also maintains a history of
       expressions typed during and across sessions  and  supports  tcsh(1)-like  history  movement  and  search
       commands.   Other  editing commands include simple cursor movement via arrow keys, deletion of characters
       via backspace and delete, and movement, deletion, and other commands using mostly emacs key bindings.
       The expression editor does not run if the TERM environment variable is not set, if the standard input  or
       output  files have been redirected, or if the --eedisable command-line option has been used.  The history
       is saved across sessions, by default, in the file “$HOME/.chezscheme_history”.  The --eehistory  command-
       line option can be used to specify a different location for the history file or to disable the saving and
       restoring of the history file.
       Keys for nearly all printing characters (letters, digits, and special characters) are “self inserting” by
       default.   The  open  parenthesis,  close  parenthesis,  open  bracket,  and  close bracket keys are self
       inserting as well, but also cause the editor to “flash” to the matching delimiter, if any.   Furthermore,
       when  a  close  parenthesis  or  close  bracket  is  typed,  it  is  automatically corrected to match the
       corresponding open delimiter, if any.
       Key bindings for other keys and key sequences initially recognized by the  expression  editor  are  given
       below,  organized  into  groups  by  function.   Some  keys  or key sequences serve more than one purpose
       depending upon context.  For example, tab is used both for identifier  completion  and  for  indentation.
       Such bindings are shown in each applicable functional group.
       Multiple-key  sequences  are  displayed with hyphens between the keys of the sequences, but these hyphens
       should not be entered.  When two or more key sequences perform the  same  operation,  the  sequences  are
       shown separated by commas.
       Newlines, acceptance, exiting, and redisplay:
       enter, ^M         accept balanced entry if used at end of entry;
                         else add a newline before the cursor and indent
       ^J                accept entry unconditionally
       ^O                insert newline after the cursor and indent
       ^D                exit from the waiter if entry is empty;
                         else delete character under cursor
       ^Z                suspend to shell if shell supports job control
       ^L                redisplay entry
       ^L-^L             clear screen and redisplay entry
       Basic movement and deletion:
       left, ^B          move cursor left
       right, ^F         move cursor right
       up, ^P            move cursor up; from top of unmodified entry,
                         move to preceding history entry.
       down, ^N          move cursor down; from bottom of unmodified entry,
                         move to next history entry.
       ^D                delete character under cursor if entry not empty;
                         else exit from the waiter.
       backspace, ^H     delete character before cursor
       delete            delete character under cursor
       Line movement and deletion:
       home, ^A          move cursor to beginning of line
       end, ^E           move cursor to end of line
       ^K, esc-k         delete to end of line or, if cursor is at the end
                         of a line, join with next line
       ^U                delete contents of current line
       When  used  on  the  first  line  of  a  multiline entry of which only the first line is displayed, i.e.,
       immediately after history movement, ^U deletes the contents of  the  entire  entry,  like  ^G  (described
       below).
       Expression movement and deletion:
       esc-^F            move cursor to next expression
       esc-^B            move cursor to preceding expression
       esc-]             move cursor to matching delimiter
       ^]                flash cursor to matching delimiter
       esc-^K, esc-delete delete next expression
       esc-backspace, esc-^H delete preceding expression
       Entry movement and deletion:
       esc-<             move cursor to beginning of entry
       esc->             move cursor to end of entry
       ^G                delete current entry contents
       ^C                delete current entry contents; reset to end of history
       Indentation:
       tab               re-indent current line if identifier prefix not
                         just entered; else insert identifier completion
       esc-tab           re-indent current line unconditionally
       esc-q, esc-Q, esc-^Q re-indent each line of entry
       Identifier completion:
       tab               insert identifier completion if just entered
                         identifier prefix; else re-indent current line
       tab-tab           show possible identifier completions at end of
                         identifier just typed, else re-indent
       ^R                insert next identifier completion
       If  at  end  of  existing  identifier, i.e., not one just typed, the first tab re-indents, the second tab
       inserts identifier completion, and the third shows possible completions.
       History movement:
       up, ^P            move to preceding entry if at top of unmodified
                         entry; else move up within entry
       down, ^N          move to next entry if at bottom of unmodified
                         entry; else move down within entry
       esc-up, esc-^P    move to preceding entry from unmodified entry
       esc-down, esc-^N  move to next entry from unmodified entry
       esc-p             search backward through history for given prefix
       esc-n             search forward through history for given prefix
       esc-P             search backward through history for given string
       esc-N             search forward through history for given string
       To search, enter a prefix or string followed by one of the search key sequences.  Follow with  additional
       search  key sequences to search further backward or forward in the history.  For example, enter “(define”
       followed by one or more esc-p key sequences to search backward  for  entries  that  are  definitions,  or
       “(define” followed by one or more esc-P key sequences for entries that contain definitions.
       Word and page movement:
       esc-f, esc-F      move cursor to end of next word
       esc-b, esc-B      move cursor to start of preceding word
       ^X-[              move cursor up one screen page
       ^X-]              move cursor down one screen page
       Inserting saved text:
       ^Y                insert most recently deleted text
       ^V                insert contents of window selection/paste buffer
       Mark operations:
       ^@, ^space, ^^    set mark to current cursor position
       ^X-^X             move cursor to mark, leave mark at old cursor
       ^W                delete between current cursor position and mark
       Command repetition:
       esc-^U            repeat next command four times
       esc-^U-n          repeat next command n times
TOP-LEVEL ENVIRONMENT SEMANTICS
       Upon  startup,  the  “interaction  environment”  used  to  hold  the  top-level bindings for user-defined
       variables and other identifiers contains an initial set of bindings, some standard and some  specific  to
       Chez  Scheme.   Any initial identifier binding may be replaced by redefining the identifier with a normal
       top-level definition.  For example, the initial binding for cons can be replaced with one that performs a
       "reverse cons" as follows.
       (define cons (lambda (x y) (import scheme) (cons y x)))
       Code entered into the REPL or loaded from a file prior to this point will still use the original  binding
       for  cons.  If you want it to use the new binding, you must reenter or reload the code.  Furthermore, the
       initial bindings for variables like cons are immutable, so you cannot  assign  one  (e.g.,  via  set!  or
       trace)  without first defining it.  This allows the system to check to make sure it receives the expected
       two arguments at compile time and generate inline code to allocate the pair.  This is  not  the  case  if
       cons  is  redefined, even if redefined to have the same value, since its value can be changed via set! at
       any time during a program run.
COMMAND-LINE FILE ARGUMENTS
       In the normal mode of operation, the file names on the command line (except  for  the  arguments  to  the
       various  command-line  options)  are loaded before Chez Scheme begins interacting with the user.  Each of
       the expressions in the loaded files is executed just as if it were typed by the user  in  response  to  a
       prompt.   If  you wish to load a set of definitions each time, consider setting up a shell script to load
       the file “.schemerc” from your home directory:
            scheme ${HOME}/.schemerc $*
       If you have a substantial number of definitions to load each time, it might be worthwhile to compile  the
       .schemerc file (that is, compile the definitions and name the resulting object file .schemerc).
       Typically,  a  Scheme  programmer  creates  a  source file of definitions and other Scheme forms using an
       editor such as vi(1) or emacs(1) and loads the file into Scheme to test them.  The conventional  filename
       extension  for  Chez  Scheme  source  files is .ss.  Such a file may be loaded during a session by typing
       (load “filename”), or by specifying the filename on the command line as mentioned above.  Any  expression
       that may be typed interactively may be placed in a file to be loaded.
SCHEME SCRIPTS
       When  the  “--script”  option is used, the named file is treated as a Scheme shell script, and the script
       name and remaining command-line arguments are  made  available  via  the  parameter  “command-line”.   To
       support  executable shell scripts, the system ignores the first line of a loaded script if it begins with
       #! followed by a space or forward slash.  For example,  the  following  script  prints  its  command-line
       arguments.
       #! /usr/bin/scheme --script
       (for-each
         (lambda (x) (display x) (newline))
         (cdr (command-line)))
RNRS TOP-LEVEL PROGRAMS
       The  “--program”  option  is like the “--script” option except that the script file is treated as an RNRS
       top-level program.  The following RNRS top-level program prints its command-line arguments, as  with  the
       script above.
       #! /usr/bin/scheme --program
       (import (rnrs))
       (for-each
         (lambda (x) (display x) (newline))
         (cdr (command-line)))
       “scheme-script”  may  be  used  in  place  of  “scheme --program”, possibly prefixed by “/usr/bin/env” as
       suggested in the nonnormative R6RS appendix on running top-level programs as  scripts,  i.e.,  the  first
       line of the top-level program may be replaced with the following.
       #! /usr/bin/env scheme-script
       If  a  top-level  program  depends  on libraries other than those built into Chez Scheme, the “--libdirs”
       option can be used to specify which source and object directories to search.   Similarly,  if  a  library
       upon  which  a  top-level program depends has an extension other than one of the standard extensions, the
       “--libexts” option can be used to specify additional extensions to search.
       These options set the corresponding Chez Scheme parameters  library-directories  and  library-extensions.
       The  values  of  both  parameters  are  lists  of  pairs  of  strings.  The first string in each library-
       directories pair identifies a source-file root directory, and the  second  identifies  the  corresponding
       object-file  root  directory.   Similarly,  the first string in each library-extensions pair identifies a
       source-file extension, and the second identifies the corresponding object-file extension.  The full  path
       of  a  library  source or object file consists of the source or object root followed by the components of
       the library name prefixed by slashes, with the library extension added on the end.  For example, for root
       /usr/lib/scheme,   library   name   (app   lib1),   and   extension    .sls,    the    full    path    is
       /usr/lib/scheme/app/lib1.sls.
       The  format  of  the  arguments  to  “--libdirs”  and  “--libexts”  is the same: a sequence of substrings
       separated by a single separator character.  The separator character is a colon (:), except under  Windows
       where  it  is  a  semi-colon  (;).  Between single separators, the source and object strings, if both are
       specified, are separated by two separator characters.  If a single separator character appears at the end
       of the string, the specified pairs are added to the existing list; otherwise, the specified pairs replace
       the existing list.  The parameters are set after all boot files have been loaded.
       If multiple “--libdirs” options appear, all but the final one are ignored, and if If multiple “--libexts”
       options  appear,  all  but  the  final  are  ignored.   If  no  “--libdirs”  option   appears   and   the
       CHEZSCHEMELIBDIRS  environment variable is set, the string value of CHEZSCHEMELIBDIRS is treated as if it
       were  specified  by  a  “--libdirs”  option.   Similarly,  if  no  “--libexts”  option  appears  and  the
       CHEZSCHEMELIBEXTS  environment variable is set, the string value of CHEZSCHEMELIBEXTS is treated as if it
       were specified by a “--libexts” option.
       The library-directories and library-extensions parameters set by  these  options  are  consulted  by  the
       expander  when it encounters an import for a library that has not previously been defined or loaded.  The
       expander first constructs a partial name from the list of components in the library name, e.g., “a/b” for
       library (a b).  It then searches for the partial name in each pair of root directories, in order,  trying
       each of the source extensions then each of the object extensions in turn before moving onto the next pair
       of  root  directories.   If  the partial name is an absolute pathname, e.g., “~/.myappinit” for a library
       named (~/.myappinit), only the specified absolute path is searched, first  with  each  source  extension,
       then  with  each object extension.  If the expander finds both a source file and its corresponding object
       file, and the object file is not older than the source file, the expander loads the object file.  If  the
       object  file  does  not  exist,  if  the  object  file is older, or if after loading the object file, the
       expander determines it was built using a library or include file that has changed,  the  source  file  is
       loaded  or  compiled,  depending  on  the value of the parameter compile-imported-libraries.  If compile-
       imported-libraries is set to #t,  the  expander  compiles  the  library  via  compile-library  (which  is
       described  below).   Otherwise,  the  expander  loads the source file.  (Loading the source file actually
       causes the code to be compiled, assuming the default value of current-eval, but the compiled code is  not
       saved  to  an object file.)  An exception is raised during this process if a source or object file exists
       but is not readable or if an object file cannot be created.
       The search process used by the expander when processing an import for a library that  has  not  yet  been
       loaded can be monitored by setting the parameter import-notify to #t.  This parameter can be set from the
       command line via the “--import-notify” command-line option.
OPTIMIZE LEVELS
       The “--optimize-level” option sets the initial value of the Chez Scheme optimize-level parameter to 0, 1,
       2, or 3.  The value is 0 by default.
       At  optimize-levels  0,  1,  and 2, code generated by the compiler is safe, i.e., generates full type and
       bounds checks.  At optimize-level 3, code generated by the compiler  is  unsafe,  i.e.,  may  omit  these
       checks.   Unsafe  code  is  usually faster, but optimize-level 3 should be used only for well-tested code
       since the absence of type and bounds checks may result in invalid memory references,  corruption  of  the
       Scheme  heap  (which  may cause seemingly unrelated problems later), system crashes, or other undesirable
       behaviors.
       At present, there is no direct difference other than safety among optimize levels.
COMPILING FILES
       Chez Scheme compiles source expressions as it sees them.  In order to speed loading of a large file,  the
       file  may  be  compiled  with  the  output  placed  in an object file.  (compile-file “foo”) compiles the
       expressions in the file “foo.ss” and places the resulting object code on the file  “foo.so”.   Loading  a
       pre-compiled  file  is  no  different  from  loading the source file, except that loading is faster since
       compilation is already done.
       To compile a program to be run with --program, use compile-program  instead  of  compile-file.   compile-
       program  preserves  the  first line unchanged, if it begins with #! followed by a forward slash or space.
       Also, while compile-file compresses the resulting object file, compile-program does not do so if  the  #!
       line  is  present,  so it can be recognized by the shell's script executor.  Any libraries upon which the
       top-level program depends, other than built-in libraries, must be  compiled  first  via  compile-file  or
       compile-library.   This can be done manually or by setting the parameter compile-imported-libraries to #t
       before compiling the program.
       To compile a script to be run with --script, use compile-script instead of compile-file.   compile-script
       is  like  compile-program,  but, like compile-file, implements the interactive top-level semantics rather
       than the RNRS top-level program semantics.
BOOT and HEAP FILES
       When Chez Scheme is run, it looks for one or more boot files to load.  Boot files  contain  the  compiled
       Scheme  code  that  implements  most  of the Scheme system, including the interpreter, compiler, and most
       libraries.  Boot files may be specified explicitly on the command line via “-b”  options  or  implicitly.
       In  the  simplest  case,  no “-b” options are given and the necessary boot files are loaded automatically
       based on the name of the executable.  For example, if the executable name is “myapp”,  the  system  looks
       for  “myapp.boot”  in  a  set  of standard directories.  It also looks for and loads any subordinate boot
       files required by “myapp.boot”.  Subordinate boot files are also loaded automatically for the first  boot
       file  explicitly  specified via the command line.  When multiple boot files are specified via the command
       line and boot each file must be listed before those that depend upon it.
       The “--verbose” option may be used to trace the boot file searching process and must  appear  before  any
       boot arguments for which search tracing is desired.
       Ordinarily,  the  search for boot files is limited to a set of default installation directories, but this
       may be overridden by setting the environment variable SCHEMEHEAPDIRS.  SCHEMEHEAPDIRS should be a  colon-
       separated  list  of  directories,  listed  in  the  order  in which they should be searched.  Within each
       directory, the two-character escape sequence “%v” is replaced  by  the  current  version,  and  the  two-
       character  escape  sequence  “%m”  is  replaced  by  the  machine  type.  A percent followed by any other
       character is replaced by the second character; in particular, “%%”  is  replaced  by  “%”,  and  “%:”  is
       replaced  by  “:”.   If  SCHEMEHEAPDIRS ends in a non-escaped colon, the default directories are searched
       after those in SCHEMEHEAPDIRS; otherwise, only  those  listed  in  SCHEMEHEAPDIRS  are  searched.   Under
       Windows, semi-colons are used in place of colons.
       Boot files consist of a header followed by ordinary compiled code and may be created with make-boot-file.
       For example,
         (make-boot-file "myapp.boot" '("petite")
           "myapp1.so" "myapp2.so")
       creates  a  boot  file  containing  the  code  from  myapp1.so  and  myapp2.so  with a header identifying
       petite.boot as a boot file upon which the new boot file depends.  Source files can be  provided  as  well
       and are compiled on-the-fly by make-boot-header.
       Multiple alternatives for the boot file upon which the new boot file depends can be listed, e.g.:
         (make-boot-file "myapp.boot" '("petite" "scheme")
           "myapp1.so" "myapp2.so")
       When  possible,  both  “scheme“  and  “petite“  should  be  specified  when  creating  a boot file for an
       application, as shown above, so that the application can run in either Petite Chez Scheme or Chez Scheme.
       If the application requires the use of the compiler, just “scheme“ should be specified.
       If the new boot file is to be a base boot file, i.e., one that does not  depend  on  another  boot  file,
       petite.boot  (or  some  other  boot file created from petite.boot) should be listed first among the input
       files.
         (make-boot-file "myapp.boot" '() "petite.boot"
           "myapp1.so" "myapp2.so")
DOCUMENTATION
       Complete documentation for Chez Scheme is available in two parts: The Scheme  Programming  Language,  4th
       Edition,  and  The  Chez  Scheme Version 9 User's Guide.  The first document is available in printed form
       from   MIT   Press,   and   links   to   online   versions   of   both   documents   are   available   at
       https://cisco.github.io/ChezScheme/.
       Several  example  Scheme  programs,  ranging  from  a  simple  factorial  procedure to a somewhat complex
       unification algorithm, are in the examples directory (see  FILES  below).   Looking  at  and  trying  out
       example programs is a good way to start learning Scheme.
ENVIRONMENT
       The  environment  variable  SCHEMEHEAPDIRS  (see above) may be set to a colon-separated (semi-colon under
       Windows) list of directories in which to search for boot files.
FILES
       /usr/bin/scheme             executable file
       /usr/bin/petite             executable file
       /usr/bin/scheme-script      executable file
       /usr/lib/csv9.5.8/examples  example program library
       /usr/lib/csv9.5.8/ta6le     boot and include files
SEE ALSO
       R.   Kent   Dybvig,   The   Scheme   Programming   Language,   4th    Edition,    MIT    Press    (2009),
            http://www.scheme.com/tspl4/.
       Chez Scheme Version 9 User's Guide, Cisco Systems, Inc.
       Michael  Sperber,  R.  Kent Dybvig, Matthew Flatt, and Anton van Straaten, eds., “Revised^6 Report on the
            Algorithmic Language Scheme,” (2007), http://www.r6rs.org/.
       Daniel P. Friedman and Matthias Felleisen, The Little Schemer, fourth edition, MIT Press (1996).
       Harold Abelson and Gerald J. Sussman with  Julie  Sussman,  Structure  and  Interpretation   of  Computer
            Programs, Second Edition, MIT press (1996).
AUTHOR
       Copyright    2022   Cisco   Systems,   Inc.    Licensed   under   the   Apache   License,   Version   2.0
       (http://www.apache.org/licenses/LICENSE-2.0)
                                      Chez Scheme Version 9.5.8 April 2022                             SCHEME(1)