Inspired by the Rust Documentation Style Guide
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 Cairo Book 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
-
Coordinating conjunctions (and, but, for, or, nor).
Generic Types and Traits 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.).
Using Structs to Structure Related Data Components: Under the Hood
Do not capitalize names of functions, commands, packages, websites, etc.
What is
assert
Bringing Paths into Scope with theuse
Keyword
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:
[`scarb`][scarb-github] Scarb bundles the Cairo compiler and the Cairo language server together in an easy-to-install package so that you can start writing Cairo code right away.
[scarb-github]: https://github.com/software-mansion/scarb
The Cairo Book usually uses the following link formatting:
-
Make intra-book links relative, so they work both online and locally.
-
Do NOT turn long phrases into links.
❌ See the Cairo 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.
scarb
might have a section in a book and a github repo. In this case, see thescarb
section andscarb
repo.
See also, the Using monospace
section.
The following types of lists are usually used in documentation:
- Bullet list -- use it if the order of 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 Cairo Book usually uses the following list formatting:
-
Finish an introductory sentence with a dot.
-
Capitalize the first letter of each bullet point.
-
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.
A crate is a subset of a package that is used in the actual Cairo compilation. This includes:
- The package source code, identified by the package name and the crate root, which is the main entry point of the package.
- A subset of the package metadata that identifies crate-level settings of the Cairo compiler, for example, the edition field in the Scarb.toml file.
-
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 Cairo Programming Language book.
- For an example using monospace font, see the Appendix A section in The Cairo Book.
Use monospace font for the following items:
-
Code snippets
- Start the terminal commands with
$
- Output of previous commands should not start with
$
- Use
bash
syntax highlighting
- Start the terminal commands with
-
Cairo declarations: commands, functions, arguments, parameters, flags, variables
-
In-line command line output
Writing a program that prints
Hello, world!
-
Data types:
u8
,u128
, etc -
Names of crates, traits, libraries
-
Command line tools, plugins, packages
Monospace font can also be used in:
-
Links
String
is a string type provided by ... -
Headings
Serializing with
Serde
-
Important information, notes...
Note: This program would not compile without a break condition. For the purpose of the example, we added a
break
statement that will never be reached, but satisfies the compiler.
-
Introduce new terms
Enums, short for "enumerations," are a way to define a custom data type that consists of a fixed set of named values, called variants.
-
Emphasize important concepts or words
we create an instance of that struct by specifying concrete values for each of the fields
-
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 have just created a file called lib.cairo, which contains a module declaration referencing another module named hello_world, as well as the file hello_world.cairo, containing the implementation details of the hello_world module.
-
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. Create a new project using
scarb
scarb new hello_world
2. Go into the hello_world directory with the command cd hello_world
cd hello_world
-
Use the third person (the user, it) when describing how things work from the perspective of hardware or software.
Cairo uses an immutable memory model, meaning that once a memory cell is written to, it can't be overwritten but only read from. To reflect this immutable memory model, variables in Cairo are immutable by default.
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
- Scarb
- Note: always use uppercase S, unless referring to the command
scarb
- Note: always use uppercase S, unless referring to the command
- 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 security risks or actions potentially harmful to users, 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)