2015-09-22 01:32:46 -07:00
|
|
|
= README =
|
2015-09-22 01:02:23 -07:00
|
|
|
|
2016-05-29 09:37:00 -07:00
|
|
|
== Overview
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2011-04-26 05:16:50 -07:00
|
|
|
OCaml is an implementation of the ML language, based on the Caml Light
|
2016-05-29 11:42:02 -07:00
|
|
|
dialect extended with a complete class-based object system and a powerful
|
|
|
|
module system in the style of Standard ML.
|
2011-04-26 05:16:50 -07:00
|
|
|
|
|
|
|
OCaml comprises two compilers. One generates bytecode which is then
|
2016-05-29 11:42:02 -07:00
|
|
|
interpreted by a C program. This compiler runs quickly, generates compact
|
|
|
|
code with moderate memory requirements, and is portable to essentially any
|
|
|
|
32 or 64 bit Unix platform. Performance of generated programs is quite good
|
|
|
|
for a bytecoded implementation. This compiler can be used either as a
|
|
|
|
standalone, batch-oriented compiler that produces standalone programs, or as
|
|
|
|
an interactive, toplevel-based system.
|
|
|
|
|
|
|
|
The other compiler generates high-performance native code for a number of
|
|
|
|
processors. Compilation takes longer and generates bigger code, but the
|
|
|
|
generated programs deliver excellent performance, while retaining the
|
|
|
|
moderate memory requirements of the bytecode compiler. The native-code
|
|
|
|
compiler currently runs on the following platforms:
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2012-02-10 08:15:24 -08:00
|
|
|
Tier 1 (actively used and maintained by the core OCaml team):
|
2004-07-13 05:19:15 -07:00
|
|
|
|
2016-04-07 07:20:04 -07:00
|
|
|
AMD64 (Opteron):: Linux, OS X, MS Windows
|
|
|
|
IA32 (Pentium):: Linux, FreeBSD, OS X, MS Windows
|
|
|
|
PowerPC:: Linux, OS X
|
2015-09-22 01:02:23 -07:00
|
|
|
ARM:: Linux
|
2004-07-13 05:19:15 -07:00
|
|
|
|
2006-09-20 04:14:37 -07:00
|
|
|
Tier 2 (maintained when possible, with help from users):
|
2004-07-13 05:19:15 -07:00
|
|
|
|
2015-09-22 01:02:23 -07:00
|
|
|
AMD64:: FreeBSD, OpenBSD, NetBSD
|
|
|
|
IA32 (Pentium):: NetBSD, OpenBSD, Solaris 9
|
|
|
|
PowerPC:: NetBSD
|
|
|
|
ARM:: NetBSD
|
|
|
|
SPARC:: Solaris, Linux, NetBSD
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2016-05-29 11:42:02 -07:00
|
|
|
Other operating systems for the processors above have not been tested, but
|
|
|
|
the compiler may work under other operating systems with little work.
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2016-05-29 11:42:02 -07:00
|
|
|
Before the introduction of objects, OCaml was known as Caml Special Light.
|
|
|
|
OCaml is almost upwards compatible with Caml Special Light, except for a few
|
|
|
|
additional reserved keywords that have forced some renaming of standard
|
|
|
|
library functions.
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2016-05-29 09:37:00 -07:00
|
|
|
== Contents
|
2015-09-22 01:02:23 -07:00
|
|
|
|
|
|
|
Changes:: what's new with each release
|
2016-05-29 11:39:48 -07:00
|
|
|
configure:: configure script
|
|
|
|
CONTRIBUTING.md:: how to contribute to OCaml
|
2016-04-14 09:47:06 -07:00
|
|
|
INSTALL.adoc:: instructions for installation
|
2015-09-22 01:02:23 -07:00
|
|
|
LICENSE:: license and copyright notice
|
|
|
|
Makefile:: main Makefile
|
2016-05-29 11:39:48 -07:00
|
|
|
Makefile.nt:: MS Windows Makefile
|
|
|
|
Makefile.shared:: common Makefile
|
|
|
|
Makefile.tools:: used by manual/ and testsuite/ Makefiles
|
2015-09-22 01:02:23 -07:00
|
|
|
README.adoc:: this file
|
2016-05-29 09:37:00 -07:00
|
|
|
README.win32.adoc:: info on the MS Windows ports of OCaml
|
2016-05-29 11:39:48 -07:00
|
|
|
VERSION:: version string
|
2015-09-22 01:02:23 -07:00
|
|
|
asmcomp/:: native-code compiler and linker
|
|
|
|
asmrun/:: native-code runtime library
|
|
|
|
boot/:: bootstrap compiler
|
|
|
|
bytecomp/:: bytecode compiler and linker
|
|
|
|
byterun/:: bytecode interpreter and runtime system
|
2016-05-29 11:39:48 -07:00
|
|
|
compilerlibs/:: the OCaml compiler as a library
|
2015-09-22 01:02:23 -07:00
|
|
|
config/:: autoconfiguration stuff
|
|
|
|
debugger/:: source-level replay debugger
|
|
|
|
driver/:: driver code for the compilers
|
2016-02-16 04:23:31 -08:00
|
|
|
emacs/:: editing mode and debugger interface for GNU Emacs
|
2016-05-29 11:39:48 -07:00
|
|
|
experimental/:: experiments not built by default
|
|
|
|
flexdll/:: empty (see README.win32.adoc)
|
2015-09-22 01:02:23 -07:00
|
|
|
lex/:: lexer generator
|
2016-05-29 11:39:48 -07:00
|
|
|
man/:: man pages
|
|
|
|
manual/:: system to generate the manual
|
|
|
|
middle_end/:: the flambda optimisation phase
|
2015-09-22 01:02:23 -07:00
|
|
|
ocamldoc/:: documentation generator
|
|
|
|
otherlibs/:: several external libraries
|
|
|
|
parsing/:: syntax analysis
|
|
|
|
stdlib/:: standard library
|
2016-05-29 11:39:48 -07:00
|
|
|
testsuite/:: tests
|
2015-09-22 01:02:23 -07:00
|
|
|
tools/:: various utilities
|
|
|
|
toplevel/:: interactive system
|
|
|
|
typing/:: typechecking
|
|
|
|
utils/:: utility libraries
|
|
|
|
yacc/:: parser generator
|
|
|
|
|
2016-05-29 09:37:00 -07:00
|
|
|
== Copyright
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2016-05-29 11:42:02 -07:00
|
|
|
All files marked "Copyright INRIA" in this distribution are copyright 1996,
|
|
|
|
1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008,
|
|
|
|
2009, 2010, 2011, 2012, 2013, 2014, 2015, 2016 Institut National de
|
|
|
|
Recherche en Informatique et en Automatique (INRIA) and distributed under
|
|
|
|
the conditions stated in file LICENSE.
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2016-05-29 09:37:00 -07:00
|
|
|
== Installation
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2016-07-21 00:46:49 -07:00
|
|
|
See the file link:INSTALL.adoc[] for installation instructions on machines running Unix,
|
2016-04-08 03:40:51 -07:00
|
|
|
Linux, OS X and Cygwin. For native Microsoft Windows, see
|
|
|
|
link:README.win32.adoc[].
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2016-05-29 09:37:00 -07:00
|
|
|
== Documentation
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2016-05-29 11:42:02 -07:00
|
|
|
The OCaml manual is distributed in HTML, PDF, Postscript, DVI, and Emacs
|
|
|
|
Info files. It is available at
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2015-09-22 01:02:23 -07:00
|
|
|
http://caml.inria.fr/
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2015-09-22 01:32:46 -07:00
|
|
|
The community also maintains the Web site http://ocaml.org, with tutorials
|
2016-06-07 06:07:19 -07:00
|
|
|
and other useful information for OCaml users.
|
2015-09-22 01:32:46 -07:00
|
|
|
|
2016-05-29 09:37:00 -07:00
|
|
|
== Availability
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2011-04-26 05:16:50 -07:00
|
|
|
The complete OCaml distribution can be accessed at
|
2001-02-06 07:24:00 -08:00
|
|
|
|
2015-09-22 01:02:23 -07:00
|
|
|
http://caml.inria.fr/
|
2001-02-06 07:24:00 -08:00
|
|
|
|
2016-05-29 09:37:00 -07:00
|
|
|
== Keeping in Touch with the Caml Community
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2016-05-29 11:42:02 -07:00
|
|
|
There exists a mailing list of users of the OCaml implementations developed
|
|
|
|
at INRIA. The purpose of this list is to share experience, exchange ideas
|
|
|
|
(and even code), and report on applications of the OCaml language. Messages
|
|
|
|
can be written in English or in French. The list has more than 1000
|
|
|
|
subscribers.
|
1995-09-03 08:22:54 -07:00
|
|
|
|
|
|
|
Messages to the list should be sent to:
|
|
|
|
|
2015-09-22 01:02:23 -07:00
|
|
|
mailto:caml-list@inria.fr[]
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2006-09-20 04:14:37 -07:00
|
|
|
You can subscribe to this list via the Web interface at
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2015-09-22 01:02:23 -07:00
|
|
|
https://sympa.inria.fr/sympa/subscribe/caml-list
|
2001-03-30 04:21:32 -08:00
|
|
|
|
2011-12-17 03:12:50 -08:00
|
|
|
Archives of the list are available on the Web site above.
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2016-05-29 11:42:02 -07:00
|
|
|
The Usenet news `groups comp.lang.ml` and `comp.lang.functional` also
|
|
|
|
contains discussions about the ML family of programming languages, including
|
|
|
|
OCaml.
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2015-09-22 01:32:46 -07:00
|
|
|
The IRC channel `#ocaml` on https://freenode.net/[Freenode] also has several
|
|
|
|
hundred users and welcomes questions.
|
|
|
|
|
2016-06-01 11:13:41 -07:00
|
|
|
The OCaml Community website is
|
|
|
|
|
|
|
|
http://ocaml.org/
|
|
|
|
|
2016-05-29 09:37:00 -07:00
|
|
|
== Bug Reports and User Feedback
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2016-05-29 11:42:02 -07:00
|
|
|
Please report bugs using the Web interface to the bug-tracking system at
|
|
|
|
http://caml.inria.fr/bin/caml-bugs
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2016-05-29 11:42:02 -07:00
|
|
|
To be effective, bug reports should include a complete program (preferably
|
|
|
|
small) that exhibits the unexpected behavior, and the configuration you are
|
|
|
|
using (machine type, etc).
|
1995-09-03 08:22:54 -07:00
|
|
|
|
2015-09-22 01:02:23 -07:00
|
|
|
You can also contact the implementors directly at mailto:caml@inria.fr[].
|
2016-05-29 11:49:43 -07:00
|
|
|
|
|
|
|
For information on contributing to OCaml, see the file CONTRIBUTING.md.
|