2012-07-10 07:18:37 +02:00
|
|
|
# The Rust Programming Language
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2012-07-10 07:13:48 +02:00
|
|
|
This is a compiler for Rust, including standard libraries, tools and
|
|
|
|
documentation.
|
|
|
|
|
|
|
|
|
|
|
|
## Installation
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2012-10-11 02:56:38 +02:00
|
|
|
The Rust compiler currently must be built from a [tarball], unless you
|
|
|
|
are on Windows, in which case using the [installer][win-exe] is
|
|
|
|
recommended.
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2012-10-11 02:56:38 +02:00
|
|
|
Since the Rust compiler is written in Rust, it must be built by
|
|
|
|
a precompiled "snapshot" version of itself (made in an earlier state
|
|
|
|
of development). As such, source builds require a connection to
|
|
|
|
the Internet, to fetch snapshots, and an OS that can execute the
|
|
|
|
available snapshot binaries.
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2012-10-11 02:56:38 +02:00
|
|
|
Snapshot binaries are currently built and tested on several platforms:
|
2012-07-10 07:20:32 +02:00
|
|
|
|
2012-10-11 02:56:38 +02:00
|
|
|
* Windows (7, Server 2008 R2), x86 only
|
|
|
|
* Linux (various distributions), x86 and x86-64
|
|
|
|
* OSX 10.6 ("Snow Leopard") or greater, x86 and x86-64
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2012-10-11 02:56:38 +02:00
|
|
|
You may find that other platforms work, but these are our "tier 1"
|
|
|
|
supported build environments that are most likely to work.
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2012-10-11 02:56:38 +02:00
|
|
|
> ***Note:*** Windows users should read the detailed
|
|
|
|
> [getting started][wiki-start] notes on the wiki. Even when using
|
|
|
|
> the binary installer the Windows build requires a MinGW installation,
|
|
|
|
> the precise details of which are not discussed here.
|
|
|
|
|
|
|
|
To build from source you will also need the following prerequisite
|
|
|
|
packages:
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2012-07-10 07:20:32 +02:00
|
|
|
* g++ 4.4 or clang++ 3.x
|
2012-10-11 02:56:38 +02:00
|
|
|
* python 2.6 or later (but not 3.x)
|
2012-07-10 07:20:32 +02:00
|
|
|
* perl 5.0 or later
|
|
|
|
* gnu make 3.81 or later
|
|
|
|
* curl
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2012-10-11 02:56:38 +02:00
|
|
|
Assuming you're on a relatively modern *nix system and have met the
|
|
|
|
prerequisites, something along these lines should work.
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2013-07-01 06:08:48 +02:00
|
|
|
$ curl -O http://static.rust-lang.org/dist/rust-0.7.tar.gz
|
|
|
|
$ tar -xzf rust-0.7.tar.gz
|
|
|
|
$ cd rust-0.7
|
2012-01-23 22:53:12 +01:00
|
|
|
$ ./configure
|
|
|
|
$ make && make install
|
|
|
|
|
2012-10-11 02:56:38 +02:00
|
|
|
You may need to use `sudo make install` if you do not normally have
|
|
|
|
permission to modify the destination directory. The install locations
|
|
|
|
can be adjusted by passing a `--prefix` argument to
|
|
|
|
`configure`. Various other options are also supported, pass `--help`
|
|
|
|
for more information on them.
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2012-10-11 02:56:38 +02:00
|
|
|
When complete, `make install` will place several programs into
|
|
|
|
`/usr/local/bin`: `rustc`, the Rust compiler; `rustdoc`, the
|
2013-01-14 11:55:47 +01:00
|
|
|
API-documentation tool, and `rustpkg`, the Rust package manager and build system.
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2012-10-11 02:56:38 +02:00
|
|
|
[wiki-start]: https://github.com/mozilla/rust/wiki/Note-getting-started-developing-Rust
|
2013-07-01 06:08:48 +02:00
|
|
|
[tarball]: http://static.rust-lang.org/dist/rust-0.7.tar.gz
|
|
|
|
[win-exe]: http://static.rust-lang.org/dist/rust-0.7-install.exe
|
2012-01-23 22:53:12 +01:00
|
|
|
|
|
|
|
|
2012-07-10 07:13:48 +02:00
|
|
|
## License
|
|
|
|
|
2012-12-28 22:40:33 +01:00
|
|
|
Rust is primarily distributed under the terms of both the MIT license
|
|
|
|
and the Apache License (Version 2.0), with portions covered by various
|
|
|
|
BSD-like licenses.
|
2012-07-10 07:13:48 +02:00
|
|
|
|
2012-12-28 22:40:33 +01:00
|
|
|
See LICENSE-APACHE, LICENSE-MIT, and COPYRIGHT for details.
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2012-07-10 07:13:48 +02:00
|
|
|
## More help
|
2012-01-23 22:53:12 +01:00
|
|
|
|
2012-09-20 10:08:11 +02:00
|
|
|
The [tutorial] is a good starting point.
|
|
|
|
|
2012-12-22 00:35:15 +01:00
|
|
|
[tutorial]: http://static.rust-lang.org/doc/tutorial.html
|