As The Rust RFC Book states:
One can level some criticisms at having a style guide:
- It is bureaucratic, gives developers more to worry about, and crushes creativity.
- There are edge cases where the style rules make code look worse (e.g., around FFI).
However, these are heavily out-weighed by the benefits.
The style guide is based on the best practices collected from the following books:
- The Rust Programming Language
- The Embedded Rust Book
- The rustup book
- The Cargo Book
- The rustc book
- The Rust on ESP Book
- Heading Titles
- Linking
- Lists
- Using
monospace
- Using Italics
- Mode of Narration
- Terminology
- Admonitions
- Appendix A Existing Style Guides
The books on Rust usually have heading titles based on nouns or gerunds:
Design Patterns
Using Structs to Structure Related Data
In heading titles, capitalize the first letter of every word except for:
-
Articles (a, an, the); unless an article is the first word.
Defining an Enum
A First Attempt at Rust -
Coordinating conjunctions (and, but, for, or, nor).
Packages and Crates
-
Prepositions of four letters or less; unless these prepositions are the first or last words.
- Prepositions of five letters and above should be capitalized (Before, Through, Versus, Among, Under, Between, Without, etc.).
Peripherals as State Machines
Do not capitalize names of functions, commands, packages, websites, etc.
What is
rustc
Publishing on crates.io
See also, the Using monospace
section.
In hyphenated words, do not capitalize the parts following the hyphens.
Built-in Targets
Allowed-by-default Lints
To simplify link maintenance, follow the rules below:
- Use link variables with variable names that give a clue on where the link leads.
- Define link variables right before the end of the section/subsection where they are used.
Example:
[`espup`][espup-github] is a tool that simplifies installing and maintaining the components required to develop Rust applications.
[espup-github]: https://github.com/esp-rs/espup
The books on Rust usually use the following link formatting:
As mentioned in the Environment Variables section, ...
For more details, see the Windows chapter in The rustup book.
The Rust Programming Language book also suggests:
- Make intra-book links relative, so they work both online and locally
Do NOT turn long phrases into links
❌ See the Rust Reference’s section on constant evaluation for more information on what operations can be used when declaring constants.
Also, consider the following:
-
Do not provide a link to the same location repeatedly in the same or adjacent paragraphs without a good reason, especially using different link text.
-
Do not use the same link text to refer to different locations.
espup
might have a section in a book and a github repo. In this case, see theespup
section andespup
repo.
See also, the Using monospace
section.
The following types of lists are usually used in documentation:
- Bullet list -- use it if the order or items is not important
- Numbered list -- use it if the order of items is important, such as when describing a process
- Procedure -- special type of numbered list that gives steps to achieve some goal (to achieve this, do this); for an example of a procedure, see the Usage section in The rustc book.
The books on Rust usually use the following list formatting:
-
Finish an introductory sentence with a colon.
-
Capitalize the first letter of each bullet point.
Using C or C++ inside of a Rust project consists of two major parts:
- Wrapping the exposed C API for use with Rust
- Building your C or C++ code to be integrated with the Rust code
-
If a bullet point is a full sentence, you can end it with a full stop.
- If a list has at least one full stop, end all other list items with a full stop.
To reliably interact with these peripherals:
- Always use
volatile
methods to read or write to peripheral memory, as it can change at any time. - In software, we should be able to share any number of read-only accesses to these peripherals.
- If some software should have read-write access to a peripheral, it should hold the only reference to that peripheral.
-
For longer list items, consider using a summary word of phrase to make content scannable.
If you run Windows on your host machine, make sure ...
- MSVC: Recommended ABI, included in ...
- GNU: ABI used by the GCC toolchain ...
- For an example using bold font, see the list in the Modules Cheat Sheet section in The Rust Programming Language book.
- For an example using monospace font, see the Panicking section in The Embedded Rust Book.
Use monospace font for the following items:
-
Code snippets
The Installation chapter in the Rust Programming Language book suggests:
- Start the terminal commands with
$
- Output of previous commands should not start with
$
- For PowerShell-specific examples, use
>
instead of$
The Rust Programming Language book also suggests:
- Use
bash
syntax highlighting
- Start the terminal commands with
-
Rust declarations: commands, functions, arguments, parameters, flags, variables
-
In-line command line output
Writing a program that prints
Hello, world!
-
Data types:
i8
,u128
-
Names of crates, traits, libraries,
-
Command line tools, plugins, packages
-
Files:
config.toml
-
Images and containers:
idf-rust
-
Architectures and targets
The
RISC-V
andXtensa
architectures.
Monospace font can also be used in:
-
links
String
is a string type provided by ... -
headings
A
no_std
Rust Environment
-
Introduce new terms
Each value in Rust has an owner. A hash map allows you to associate a value with a particular key.
-
Emphasize important concepts or words
When
s
comes into scope, it is valid. It remains valid until it goes out of scope. -
Do NOT use italics with Espressif product names, such as ESP32.
-
Use the first person (we) when introducing a tutorial or explaining how things will be done. The reader will feel like being on the same team with the authors working side by side.
We'll start writing a program for the LM3S6965, a Cortex-M3 microcontroller. We have chosen this as our initial target because it can be emulated using QEMU so you don't need to fiddle with hardware in this section, and we can focus on the tooling and the development process.
-
Use the second person (you) when describing what the reader should do while installing software, following a tutorial or a procedure. However, in most cases you can use imperative mood as if giving orders to the readers. It makes instructions much shorter and clearer.
1. Install
cargo-generate
cargo install cargo-generate
2. Generate a new project
cargo generate --git https://github.com/rust-embedded/cortex-m-quickstart
-
Use the third person (the user, it) when describing how things work from the perspective of hardware or software
A driver has to be initialized with an instance of type that implements a certain
trait
of the embedded-hal which is ensured via trait bound and provides its own type instance with a custom set of methods allowing to interact with the driven device.
This chapter lists the terms that have inconsistencies in spelling, usage, etc.
If you spot other issues with terminology, please add the terms here in alphabetical order using the formatting as follows:
- Recommended term
- Avoid: Add typical phrases in which this term is found
- Use: Add recommended phrases
- Note: Add more information if needed
- Cargo
- Note: always use uppercase C
- ESP-IDF or esp-idf
- Use: esp-idf when writing about the esp-idf repo
- Use: ESP-IDF when writing about the ESP-IDF framework or ESP-IDF programming guide
no_std
- Note: see
std
- Note: see
- Product
- Avoid: Espressif SoCs
- Use: Espressif products
- Note: In the content of running applications, suggested as an umbrella term for Espressif chips, modules, development boards, etc. Otherwise, it might be potentially ambiguous that running an app on an SoC is the same as running it on a module.
- SoC
- Avoid: chip
- Note: see also product
std
/no_std
- Use only if necessary: bare metal development, hosted environment, Standard library, Core library
- Use
std
/no_std
by default in patterns, such as:- write, build, or choose between
std
/no_std
applications - requires
std
for ... - use
std
for ... - compile in an
std
environment - support for
no_std
requires ... (std
support) - using the
std
/no_std
approach std
projects / templates / featuresstd
/no_std
development
- write, build, or choose between
- VS Code
- Use VS Code by default
- Use only if necessary: Visual Studio Code
Use the following formatting for notes and warnings:
-
Note
⚠️ Note: A note covering an important point or idea. Use sparingly or the readers will start ignoring them. -
Warning
🚨 Warning: Use in critical circumstances only, e.g., for irreversible actions or actions potentially harmful to hardware, software, etc.
In markdown:
> ⚠️ **Note**: Write your note.
- Style Guidelines
- The Rust RFC Book, chapter Style Guide
- Rust API Guidelines
- Rust Style Guide (riptutorial.com)
- Rust Style Guide (github.com/rust-lang)