2014-08-01 18:31:22 -05:00
% Rust Documentation
2013-12-22 20:21:45 -06:00
2015-12-23 16:15:13 -06:00
< style >
nav {
display: none;
}
2018-09-16 14:22:32 -05:00
#search-input {
width: calc(100% - 58px);
}
#search-but {
cursor: pointer;
}
#search-but, #search-input {
padding: 4px;
border: 1px solid #ccc ;
border-radius: 3px;
outline: none;
font-size: 0.7em;
background-color: #fff ;
}
#search-but:hover, #search-input:focus {
border-color: #55a9ff ;
}
2018-11-19 15:50:24 -06:00
h2 {
font-size: 18px;
}
2015-12-23 16:15:13 -06:00
< / style >
2014-08-28 13:52:39 -05:00
2018-04-03 11:38:53 -05:00
Welcome to an overview of the documentation provided by the Rust project.
All of these projects are managed by the Docs Team; there are other
unofficial documentation resources as well!
2014-08-28 13:52:39 -05:00
2018-04-03 11:38:53 -05:00
Many of these resources take the form of "books"; we collectively call these
"The Rust Bookshelf." Some are large, some are small.
2015-05-08 15:18:04 -05:00
2018-04-06 14:12:47 -05:00
# Learn Rust
2014-08-28 13:52:39 -05:00
2018-04-03 11:38:53 -05:00
If you'd like to learn Rust, this is the spot for you! All of these resources
assume that you have programmed before, but not in any specific language:
2018-04-06 14:12:47 -05:00
## The Rust Programming Language
2018-04-03 11:38:53 -05:00
Affectionately nicknamed "the book," [The Rust Programming
Language](book/index.html) will give you an overview of the language from
first principles. You'll build a few projects along the way, and by the end,
you'll have a solid grasp of the language.
2018-04-06 14:12:47 -05:00
## Rust By Example
2018-04-03 11:38:53 -05:00
If reading multiple hundreds of pages about a language isn't your style, then
[Rust By Example ](rust-by-example/index.html ) has you covered. While the book talks about code with
a lot of words, RBE shows off a bunch of code, and keeps the talking to a
minimum. It also includes exercises!
2019-02-05 08:32:59 -06:00
## Rustlings
[Rustlings ](https://github.com/rust-lang/rustlings ) guides you through downloading and setting up the Rust toolchain,
and teaches you the basics of reading and writing Rust syntax. It's an
alternative to Rust by Example that works with your own environment.
2018-04-06 14:12:47 -05:00
# Use Rust
2018-04-03 11:38:53 -05:00
2018-08-19 08:30:23 -05:00
Once you've gotten familiar with the language, these resources can help you
2018-04-03 11:38:53 -05:00
when you're actually using it day-to-day.
2018-04-06 14:12:47 -05:00
## The Standard Library
2018-04-03 11:38:53 -05:00
Rust's standard library has [extensive API documentation ](std/index.html ),
with explanations of how to use various things, as well as example code for
accomplishing various tasks.
2018-09-15 01:28:32 -05:00
< div >
< form action = "std/index.html" method = "get" >
2018-09-16 14:22:32 -05:00
< input id = "search-input" type = "search" name = "search"
placeholder="Search through the standard library"/>
< button id = "search-but" > Search< / button >
2018-09-15 01:28:32 -05:00
< / form >
< / div >
2019-01-29 16:30:49 -06:00
## The Edition Guide
[The Edition Guide ](edition-guide/index.html ) describes the Rust editions.
2018-04-05 13:53:58 -05:00
## The Rustc Book
[The Rustc Book ](rustc/index.html ) describes the Rust compiler, `rustc` .
2018-04-06 14:12:47 -05:00
## The Cargo Book
2018-04-03 11:38:53 -05:00
[The Cargo Book ](cargo/index.html ) is a guide to Cargo, Rust's build tool and dependency manager.
2018-04-06 14:12:47 -05:00
## The Rustdoc Book
2018-04-03 11:38:53 -05:00
[The Rustdoc Book ](rustdoc/index.html ) describes our documentation tool, `rustdoc` .
2018-04-06 14:12:47 -05:00
## Extended Error Listing
2016-01-10 16:30:09 -06:00
2017-02-07 12:04:57 -06:00
Many of Rust's errors come with error codes, and you can request extended
2018-04-03 11:38:53 -05:00
diagnostics from the compiler on those errors. You can also [read them
here](error-index.html), if you prefer to read them that way.
2018-04-06 14:12:47 -05:00
# Master Rust
2018-04-03 11:38:53 -05:00
Once you're quite familiar with the language, you may find these advanced
resources useful.
2018-04-06 14:12:47 -05:00
## The Reference
2018-04-03 11:38:53 -05:00
[The Reference ](reference/index.html ) is not a formal spec, but is more detailed and
comprehensive than the book.
2018-04-06 14:12:47 -05:00
## The Rustonomicon
2018-04-03 11:38:53 -05:00
[The Rustonomicon ](nomicon/index.html ) is your guidebook to the dark arts of unsafe
Rust. It's also sometimes called "the 'nomicon."
2018-04-06 14:12:47 -05:00
## The Unstable Book
2015-09-06 07:25:01 -05:00
2018-04-03 11:38:53 -05:00
[The Unstable Book ](unstable-book/index.html ) has documentation for unstable features.
2018-11-19 15:45:19 -06:00
## The `rustc` Contribution Guide
2020-03-09 16:33:04 -05:00
[The `rustc` Guide ](https://rustc-dev-guide.rust-lang.org/ ) documents how
2018-11-19 15:45:19 -06:00
the compiler works and how to contribute to it. This is useful if you want to build
or modify the Rust compiler from source (e.g. to target something non-standard).
2019-01-18 21:52:39 -06:00
# Specialize Rust
When using Rust in specific domain areas, consider using the following resources tailored to each domain.
## Embedded Systems
When developing for Bare Metal or Embedded Linux systems, you may find these resources maintained by the [Embedded Working Group] useful.
[Embedded Working Group]: https://github.com/rust-embedded
### The Embedded Rust Book
[The Embedded Rust Book] is targeted at developers familiar with embedded development and familiar with Rust, but have not used Rust for embedded development.
[The Embedded Rust Book]: embedded-book/index.html