The Racket repository
Go to file
Gustavo Massaccesi 6d0780488c cptypes: reduce (if t <error> x) ==> (begin (if t <error> (void)) x)
so the surrounding code can be reduced, for example

(+ 2 (if t <error> 3)) ==> (begin (if t <error> (void)) 5)

original commit: 79f23f2ddb858aa6c69bd1e9314e745145ad2b15
2019-03-29 18:45:58 -03:00
.travis use uuid_generate on unix-like systems for S_unique_id 2018-09-19 10:19:03 -04:00
bintar better packaging support 2019-03-18 22:51:26 -07:00
c make nul act as a stream terminator for LZ4 sequences 2019-03-22 13:52:53 -06:00
csug Merge branch 'lz4' of https://github.com/mflatt/ChezScheme 2019-03-20 15:49:49 -06:00
examples Updated csug socket code to match that in examples folder 2018-06-18 09:28:53 -04:00
lz4@c438548312 Add LZ4 support and use it by default for compressing files 2019-03-20 13:35:04 -06:00
makefiles minor build and new-release updates 2019-03-19 23:23:10 -07:00
mats cptypes: reduce (if t <error> x) ==> (begin (if t <error> (void)) x) 2019-03-29 18:45:58 -03:00
nanopass@1f7e80bcff latest nanopass 2016-06-27 09:45:20 -04:00
pkg better packaging support 2019-03-18 22:51:26 -07:00
release_notes Merge branch 'lz4' of https://github.com/mflatt/ChezScheme 2019-03-20 15:49:49 -06:00
rpm better packaging support 2019-03-18 22:51:26 -07:00
s cptypes: reduce (if t <error> x) ==> (begin (if t <error> (void)) x) 2019-03-29 18:45:58 -03:00
stex@3bd2b86cc5 - compile-whole-program and compile-whole-library now copy the hash-bang 2016-05-04 20:35:38 -04:00
unicode initial upload of open-source release 2016-04-26 10:04:54 -04:00
wininstall add PDB files for Windows 2018-09-07 16:56:33 -04:00
zlib@cacf7f1d4e updated zlib to latest version, version 1.2.11 2017-02-13 22:27:21 -05:00
.gitattributes Adding .gitattributes files to correct language stats 2016-10-12 11:47:53 -04:00
.gitignore Added generated docs and intermediate files to .gitignore 2017-10-14 12:32:44 -04:00
.gitmodules Add LZ4 support and use it by default for compressing files 2019-03-20 13:35:04 -06:00
.travis.yml use uuid_generate on unix-like systems for S_unique_id 2018-09-19 10:19:03 -04:00
BUILDING updated BUILDING to mention the --threads option along with a couple 2019-02-07 14:52:41 -08:00
CHARTER.md initial upload of open-source release 2016-04-26 10:04:54 -04:00
checkin minor build and new-release updates 2019-03-19 23:23:10 -07:00
configure Merge branch 'lz4' of https://github.com/mflatt/ChezScheme 2019-03-20 15:49:49 -06:00
CONTRIBUTING.md - added custom install options. workarea creates an empty config.h, 2016-05-06 18:30:06 -04:00
LICENSE initial upload of open-source release 2016-04-26 10:04:54 -04:00
LOG Merge branch 'lz4' of https://github.com/mflatt/ChezScheme 2019-03-20 15:49:49 -06:00
newrelease minor build and new-release updates 2019-03-19 23:23:10 -07:00
NOTICE - updated version to 9.5.1 2017-10-11 19:57:53 -04:00
README.md Changed the travis-ci monitoring image to match the current brnach (master). 2018-04-09 21:47:03 -04:00
scheme.1.in spelling 2017-12-04 09:35:31 +00:00
workarea Add LZ4 support and use it by default for compressing files 2019-03-20 13:35:04 -06:00

Build Status

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.