Top Related Projects
The Rust Programming Language
Learn Rust with examples (Live code editor included)
:crab: Small exercises to get you used to reading and writing Rust code!
The Dark Arts of Advanced and Unsafe Rust Programming
RFCs for changes to Rust
Quick Overview
The rust-lang/reference
repository is the official reference for the Rust programming language. It provides a comprehensive guide to the Rust language, covering its syntax, semantics, and various features. The reference serves as a valuable resource for Rust developers, both beginners and experienced, to understand the language in-depth.
Pros
- Comprehensive Coverage: The reference covers a wide range of Rust language features, from basic syntax to advanced concepts, making it a go-to resource for Rust developers.
- Authoritative Source: As the official reference, it is maintained by the Rust core team, ensuring the information is accurate and up-to-date.
- Community Contributions: The reference is open-source, allowing the Rust community to contribute and improve the content, ensuring it remains relevant and helpful.
- Multilingual Support: The reference is available in multiple languages, making it accessible to a global audience of Rust developers.
Cons
- Complexity: The reference can be overwhelming for beginners, as it covers a vast amount of information about the Rust language.
- Maintenance Overhead: Keeping the reference up-to-date with the rapidly evolving Rust language can be a significant challenge for the maintainers.
- Lack of Practical Examples: While the reference provides detailed explanations, it may lack practical examples that developers can use to apply the concepts in their own projects.
- Navigation and Discoverability: The sheer volume of content in the reference can make it challenging for users to quickly find the information they need.
Competitor Comparisons
The Rust Programming Language
Pros of Book
- More beginner-friendly with step-by-step explanations and examples
- Covers practical aspects of Rust programming and project development
- Includes exercises and quizzes to reinforce learning
Cons of Book
- Less comprehensive coverage of advanced language features
- May not always reflect the most up-to-date language specifications
Code Comparison
Book example (simplified error handling):
fn main() -> Result<(), Box<dyn Error>> {
let f = File::open("hello.txt")?;
Ok(())
}
Reference example (detailed error handling):
fn main() -> Result<(), io::Error> {
let f = match File::open("hello.txt") {
Ok(file) => file,
Err(error) => return Err(error),
};
Ok(())
}
The Book example demonstrates a more concise approach using the ?
operator, while the Reference example shows a more explicit error handling pattern.
Summary
Book is ideal for newcomers to Rust, offering a structured learning path with practical examples. Reference serves as a comprehensive language specification, providing in-depth details on Rust's features and behaviors. While Book excels in accessibility and practical application, Reference offers more thorough coverage of language intricacies.
Learn Rust with examples (Live code editor included)
Pros of Rust by Example
- More beginner-friendly with practical, runnable examples
- Interactive learning experience with editable code snippets
- Covers a wide range of Rust concepts through hands-on demonstrations
Cons of Rust by Example
- Less comprehensive and detailed than the Reference
- May not cover advanced topics or language specifications in depth
- Examples might not always reflect best practices or idiomatic Rust
Code Comparison
Reference:
pub trait Iterator {
type Item;
fn next(&mut self) -> Option<Self::Item>;
}
Rust by Example:
fn main() {
let v1 = vec![1, 2, 3];
let v1_iter = v1.iter();
for val in v1_iter {
println!("Got: {}", val);
}
}
The Reference provides a formal definition of the Iterator
trait, while Rust by Example demonstrates its practical usage in a simple program.
Summary
Reference is a comprehensive language specification, ideal for in-depth understanding and advanced users. Rust by Example offers a more hands-on, interactive approach suitable for beginners and those who prefer learning by doing. Both repositories complement each other, catering to different learning styles and depths of Rust knowledge.
:crab: Small exercises to get you used to reading and writing Rust code!
Pros of Rustlings
- Interactive, hands-on learning approach with exercises
- Gradual progression from basic to advanced concepts
- Immediate feedback and automated testing of solutions
Cons of Rustlings
- Less comprehensive coverage of Rust language features
- May not serve as a complete reference for advanced topics
- Requires more time investment for learners
Code Comparison
Rustlings exercise example:
// exercises/variables/variables2.rs
fn main() {
let x;
if x == 10 {
println!("x is ten!");
} else {
println!("x is not ten!");
}
}
Reference documentation example:
// From the Variables and Mutability section
let x = 5;
let mut y = 5;
y = 6;
Summary
Rustlings offers an interactive, hands-on approach to learning Rust through exercises, making it ideal for beginners and those who prefer practical learning. The Reference, on the other hand, provides comprehensive documentation of Rust's language features, serving as a detailed resource for developers at all levels.
Rustlings excels in providing immediate feedback and a structured learning path, while the Reference offers in-depth explanations and serves as a complete language specification. The choice between the two depends on the learner's preferences and needs: Rustlings for practical, guided learning, and the Reference for comprehensive language understanding and advanced topics.
The Dark Arts of Advanced and Unsafe Rust Programming
Pros of nomicon
- Focuses on advanced and unsafe Rust concepts, providing deeper insights
- Offers more detailed explanations of low-level operations and memory management
- Includes practical examples of unsafe code usage and best practices
Cons of nomicon
- Less comprehensive coverage of general Rust language features
- May be overwhelming for beginners or those seeking basic language information
- Updated less frequently compared to the reference
Code comparison
reference:
fn main() {
let x = 5;
println!("The value of x is: {}", x);
}
nomicon:
fn main() {
let mut x = Box::new(5);
let raw = Box::into_raw(x);
unsafe {
println!("The value at raw is: {}", *raw);
}
}
The reference example demonstrates basic Rust syntax, while the nomicon example showcases unsafe operations and raw pointer manipulation.
Summary
The reference serves as a comprehensive guide to Rust's syntax and features, suitable for all skill levels. The nomicon, on the other hand, delves into advanced topics and unsafe Rust, catering to experienced developers seeking in-depth knowledge of the language's inner workings. While the reference provides a broader overview, the nomicon offers specialized insights into low-level operations and memory management.
RFCs for changes to Rust
Pros of rfcs
- Provides a structured process for proposing and discussing language changes
- Offers historical context and rationale for Rust's design decisions
- Allows community participation in shaping the language's future
Cons of rfcs
- Can be more difficult to navigate for specific language details
- May contain outdated information if RFCs are not implemented or superseded
- Requires more time to find relevant information compared to a structured reference
Code comparison
rfcs:
// RFC 2094: Non-lexical lifetimes
fn main() {
let mut x = 5;
let y = &x;
x = 6;
println!("{}", y);
}
reference:
// Lifetime elision rules
fn print(s: &str); // elided
fn print<'a>(s: &'a str); // expanded
fn debug(lvl: usize, s: &str); // elided
fn debug<'a>(lvl: usize, s: &'a str); // expanded
Summary
While rfcs provides valuable insights into Rust's evolution and decision-making process, reference serves as a more structured and up-to-date resource for language specifics. rfcs is better suited for understanding the reasoning behind language features, while reference offers clearer and more concise information for day-to-day programming needs.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
The Rust Language Reference
This document is the primary reference for the Rust programming language.
This document is not normative. It may include details that are specific
to rustc
itself, and should not be taken as a specification for the
Rust language. We intend to produce such a document someday, but this is
what we have for now.
Dependencies
- Nightly Rust
- mdbook
Installing dependencies
First, ensure that you have a recent copy of the nightly Rust compiler installed, as this is needed in order to run the tests:
rustup toolchain install nightly
Now, ensure you have mdbook
installed, as this is needed in order to
build the Reference:
cargo install --locked mdbook
Building
To build the Reference, first clone the project:
git clone https://github.com/rust-lang/reference.git
(Alternatively, if you don't want to use git
, download a ZIP file
of the project, extract it using your preferred tool, and rename the
top-level directory to reference
.)
Now change your current directory to the working directory:
cd reference
To test all of the code examples in the Reference, run:
mdbook test
For authors, consider using the server functionality which supports automatic reload.
To build the Reference locally (in build/
) and open it in a web
browser, run:
SPEC_RELATIVE=0 mdbook build --open
This will open a browser with a websocket live-link to automatically reload whenever the source is updated.
You can also use mdbook's live webserver option, which will automatically rebuild the book and reload your web browser whenever a source file is modified:
SPEC_RELATIVE=0 mdbook serve --open
SPEC_RELATIVE
The SPEC_RELATIVE=0
environment variable makes links to the standard library go to https://doc.rust-lang.org/ instead of being relative, which is useful when viewing locally since you normally don't have a copy of the standard library.
The published site at https://doc.rust-lang.org/reference/ (or local docs using rustup doc
) does not set this, which means it will use relative links which supports offline viewing and links to the correct version (for example, links in https://doc.rust-lang.org/1.81.0/reference/ will stay within the 1.81.0 directory).
SPEC_DENY_WARNINGS
The SPEC_DENY_WARNINGS=1
environment variable will turn all warnings generated by mdbook-spec
to errors. This is used in CI to ensure that there aren't any problems with the book content.
SPEC_RUST_ROOT
The SPEC_RUST_ROOT
can be used to point to the directory of a checkout of https://github.com/rust-lang/rust. This is used by the test-linking feature so that it can find tests linked to reference rules. If this is not set, then the tests won't be linked.
Top Related Projects
The Rust Programming Language
Learn Rust with examples (Live code editor included)
:crab: Small exercises to get you used to reading and writing Rust code!
The Dark Arts of Advanced and Unsafe Rust Programming
RFCs for changes to Rust
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot