[comp.lang.c++] The Olivetti Modula-3 Distribution

mjj@stl.olivetti.com (Mick Jordan) (06/06/89)

                The Olivetti Modula-3 Distribution
                ---------------------------------- 

Modula-3 [1] is a new programming language that adds objects, threads,
exceptions and garbage collection to Modula-2.  We are developing a set of
tools to support software development in Modula-3.  Our intent is to make the
tools widely available and we plan to distribute them during the third quarter
of this year.

Tools
-----
The Modula-3 tools are built from a collection of packages, written mostly in
Modula-3 but including some C, which are integrated by the use of an abstract
syntax tree (AST) as the intermediate representation of compilation units.
The AST is defined in terms of Modula-3 object types and the majority of the
tools operate directly off this representation.

We are actively developing a variety of tools to support Modula-3 development.
However, in order to make a basic system available quickly, not all of these
tools will be provided in the first distribution.  The initial set will
definitely contain the following:

 *  A compiler that translates from Modula-3 source to object code,
    by way of C source as an intermediate step.  Our use of C is quite
    high-level, hence there is a close similarity between names and types
    in the Modula-3 and C domains.  This makes it possible to debug via the
    generated C code.  The compiler is structured such that it is easy to
    replace the C code-generator with an alternative.

 *  A pre-linker which verifies the consistent compilation rules of
    Modula-3, computes module initialisation order, and builds the program
    with the target machine linker.

 *  A 'makefile' generator for Modula-3 libraries and programs.

Other tools that we are working on and will include in the distribution
if they are solid enough, include the following:

 *  A tool to generate Modula-3 code to save and restore data structures
    from persistent storage in a type-safe manner.

 *  A tool to build skeleton modules from interfaces.

 *  A pretty printer for Modula-3 source.

 *  A Modula-3 interpreter, operating off the AST. 

 *  A tool to build interfaces and modules from a generic specification.

 *  A source-level debugger with a point and show interface.

 *  An interactive compiler tool that monitors changes made to source files
    and performs recompilations automatically.  This replaces the use of
    'make' and provides a fast compilation environment. 

 *  A remote procedure call stub generator.


Run-time Library
----------------- 
The distribution will contain a library suitable for typical systems-
programming applications.  We are taking a simple approach to the basic
run-time environment to avoid creating unnecessary obstacles to portability.
The only significant run-time support is the garbage collector, which is by
Boehm and Weiser [2].  The library will contain a number of modules (30 or
so), some completely portable and some that are operating system dependent.
It includes an IO system, based on an extensible set of stream classes.

Tool Portability
-----------------
We are developing the tools to run on Sun-3 hardware under SunOS 3.5/4.0 and
on DEC VAX running Unix(*) BSD 4.3.  We expect that portability of the tools
to other Unix targets will be straightforward, since we make little or no use
of facilities that pose portability problems.  Porting it to other operating
systems will require more work, but the changes should be well localised. 

References
----------
[1] The Modula-3 Report,
    L. Cardelli, J. Dohnaue, L. Glassman, M. Jordan, B. Kalsow, G. Nelson,
    DEC Systems Research Center, Palo Alto, CA and
    Olivetti Research Center, Menlo Park, CA, Aug 88.

[2] Garbage Collection in an Uncooperative Environment,
    Hans Boehm and Mark Weiser,
    Software, Practice and Experience, Sep 88, pp. 807-820.


How to reach us
---------------
If you would like further information, or would like to receive a copy of the
distribution, please send e-mail to modula-3@stl.olivetti.com (or
modula-3@oli-stl.uucp).  Or write to us at:

Olivetti Software Technology Laboratory
2882 Sand Hill Road, Suite 115
Menlo Park, CA 94025
USA

The Modula-3 Tools Project Team
-------------------------------
The distribution is being developed by David Chase of Olivetti Research Center
and Steve Glassman, Mick Jordan, Trevor Morris and Marion Sturtevant of
Olivetti Software Technology Laboratory.

(*) Unix is a trademark of AT&T Bell Laboratories.