Convert Figma logo to code with AI

rust-lang logoreference

The Rust Reference

1,268
499
1,268
301

Top Related Projects

15,083

The Rust Programming Language

Learn Rust with examples (Live code editor included)

53,463

:crab: Small exercises to get you used to reading and writing Rust code!

1,896

The Dark Arts of Advanced and Unsafe Rust Programming

5,921

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

15,083

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.

53,463

: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.

1,896

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.

5,921

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 Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

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

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.