![]() - the collector now releases bignum temporaries in the collector rather than relocating them so we don't keep around huge bignum temporaries forever. gc.c - removed the presumably useless vector-handling code from load() which used to be required to handle fasl groups. scheme.c - object files are no longer compressed as a whole, and the parameter compile-compressed is no longer defined. instead, the individual fasl objects within an object file are compressed whenever the new parameter fasl-compressed is set to its default value, #t. this allows the fasl reader to seek past portions of an object file that are not of interest, i.e., visit-only code and data when "revisiting" an object file and revisit-only code and data when "visiting" an object file. the compressed portions are compressed using the format and level specified by the compress-format and compress-level parameters. the C-coded fasl reader and boot-file loader no longer handle compressed files; these are handled, less efficiently, by the Scheme entry point (fasl-read). a warning exception is raised the first time a program attempts to create or read a compressed fasl file. 7.ss, s/Mf-base, back.ss, bytevector.ss, cmacros.ss, compile.ss, fasl-helpers.ss, fasl.ss, primdata.ss, strip.ss, syntax.ss, externs.h, fasl.c, gc.c, scheme.c, thread.c, mats/6.ms, mats/7.ms, mats/bytevector.ms, mats/misc.ms, patch*, root-experr*, intro.stex, use.stex, io.stex, system.stex, release_notes.stex - added begin wrappers around many of the Scheme source files that contained multiple expressions to cut down the number of top-level fasl objects and increase compressibility. also removed the string filenames for debugging at the start of each file that had one---these are best inserted universally by a modified compile-file during a debugging session when desired. also removed unnecessary top-level placeholder definitions for the assignments that follow. 4.ss, 5_1.ss, 5_2.ss, 5_3.ss, 5_7.ss, 6.ss, 7.ss, bytevector.ss, cafe.ss, cback.ss, compile.ss, cp0.ss, cpcommonize.ss, cpletrec.ss, cpnanopass.ss, cprep.ss, cpvalid.ss, date.ss, engine.ss, enum.ss, env.ss, event.ss, exceptions.ss, expeditor.ss, fasl.ss, foreign.ss, format.ss, front.ss, ftype.ss, inspect.ss, interpret.ss, io.ss, library.ss, mathprims.ss, newhash.ss, pdhtml.ss, pretty.ss, prims.ss, primvars.ss, print.ss, read.ss, record.ss, reloc.ss, strnum.ss, syntax.ss, trace.ss original commit: b7f161bf2939dfedce8accbfa82b92dbe011d32a |
||
---|---|---|
.travis | ||
bintar | ||
c | ||
csug | ||
examples | ||
lz4@c438548312 | ||
makefiles | ||
mats | ||
nanopass@1f7e80bcff | ||
pkg | ||
release_notes | ||
rpm | ||
s | ||
stex@3bd2b86cc5 | ||
unicode | ||
wininstall | ||
zlib@cacf7f1d4e | ||
.gitattributes | ||
.gitignore | ||
.gitmodules | ||
.travis.yml | ||
BUILDING | ||
CHARTER.md | ||
checkin | ||
configure | ||
CONTRIBUTING.md | ||
LICENSE | ||
LOG | ||
newrelease | ||
NOTICE | ||
README.md | ||
scheme.1.in | ||
workarea |
Chez Scheme is both a programming language and an implementation of that language, with supporting tools and documentation.
As a superset of the language described in the Revised6 Report on the Algorithmic Language Scheme (R6RS), Chez Scheme supports all standard features of Scheme, including first-class procedures, proper treatment of tail calls, continuations, user-defined records, libraries, exceptions, and hygienic macro expansion.
Chez Scheme also includes extensive support for interfacing with C and other languages, support for multiple threads possibly running on multiple cores, non-blocking I/O, and many other features.
The Chez Scheme implementation consists of a compiler, run-time system, and programming environment. Although an interpreter is available, all code is compiled by default. Source code is compiled on-the-fly when loaded from a source file or entered via the shell. A source file can also be precompiled into a stored binary form and automatically recompiled when its dependencies change. Whether compiling on the fly or precompiling, the compiler produces optimized machine code, with some optimization across separately compiled library boundaries. The compiler can also be directed to perform whole-program compilation, which does full cross-library optimization and also reduces a program and the libraries upon which it depends to a single binary.
The run-time system interfaces with the operating system and supports, among other things, binary and textual (Unicode) I/O, automatic storage management (dynamic memory allocation and generational garbage collection), library management, and exception handling. By default, the compiler is included in the run-time system, allowing programs to be generated and compiled at run time, and storage for dynamically compiled code, just like any other dynamically allocated storage, is automatically reclaimed by the garbage collector.
The programming environment includes a source-level debugger, a mechanism for producing HTML displays of profile counts and program "hot spots" when profiling is enabled during compilation, tools for inspecting memory usage, and an interactive shell interface (the expression editor, or "expeditor" for short) that supports multi-line expression editing.
The R6RS core of the Chez Scheme language is described in The Scheme Programming Language, which also includes an introduction to Scheme and a set of example programs. Chez Scheme's additional language, run-time system, and programming environment features are described in the Chez Scheme User's Guide. The latter includes a shared index and a shared summary of forms, with links where appropriate to the former, so it is often the best starting point.
Get started with Chez Scheme by Building Chez Scheme.
For more information see the Chez Scheme Project Page.