Skip to main content

Documentation style guide

The following are writing style guidelines for contributing to the ConsenSys documentation. These guidelines aim to keep the documentation consistent, well-organized, and easy to understand.

General guidelines​

  1. Be consistent - Consistency helps users follow and understand the documentation. By being consistent with your word choices, visual formatting, and style of communication, users know what to expect when they read the documentation. For example, use consistent sentence structures when writing step-by-step instructions.

  2. Be simple but technically correct - Avoid technical jargon and assume the user isn't an Ethereum expert. When an understanding of a complex Ethereum concept is required, you can refer users to external resources. For example, to explain how the EVM works, link to a resource such as the Ethereum Wiki.

  3. Be proactive and suggest good practices - Anticipate users' needs and guide them through a process. This often takes the form of notes or tips alongside the main explanation. Put yourself in the user's shoes and consider what questions you'd have when reading the documentation.

    Documenting good practices is also important. For example, instruct users to secure private keys and protect RPC endpoints in production environments.

  4. Be informative but concise - Provide enough information to help users develop a mental model of how the software works without forcing them to read too much text or redundant detail. Cut down your text by using simple words and concise sentences.

  5. Be inclusive - ConsenSys documentation aims to be inclusive to all users. Refer to the Google inclusive documentation guide and the Microsoft bias-free communication guide as starting points.

Writing style guide​

ConsenSys documentation follows the Microsoft Writing Style Guide, which is a straightforward reference for natural and clear writing style. The following are some important style recommendations:

  • Abbreviations - Avoid abbreviations and acronyms unless they're well-known or often repeated in the documentation. Use "for example" instead of "e.g," and "that is" instead of "i.e."
  • Active voice - Use active voice where possible. Use "you" to create a personal tone.
  • Code samples - Provide code samples that can be copied and pasted in a console or editor with minimal editing, and work as expected.
    • When writing code samples in a programming language, refer to the programming language's style guide.
    • Always provide code samples as text in a code block; never use screenshots that would force the user to type it manually.
    • When breaking up lines in a command sample, add line breaks (\) to ensure it can work when pasted.
    • Don't include the console prompt (>,$,#,%, or the full user@mycomputer Develop %) or other characters that would prevent the command to run when pasted.
    • If values must be replaced in a sample, use placeholders such as <your IP address>.
  • Contractions - Use common contractions, such as "it’s" and "you’re," to create a friendly, informal tone.
  • Sentence case for headings - Use sentence case instead of title case for headings.
  • "We recommend" - In general, don't use first person. However, use "we recommend" to introduce a product recommendation. Don't use "ConsenSys recommends" or "it is recommended."
  • GitHub permalinks - When linking to a GitHub file, use the permanent link (permalink) to the file. You can copy the permalink by selecting the ellipses (...) in the upper right corner of the file page, and selecting Copy permalink.

Refer to the Microsoft Guide for any other questions on style.

Documentation categories​

A typical documentation page falls into one of the following four categories:

  1. How to - How-to content provides instructions to achieve a specific outcome. How-to content assumes users already have some basic knowledge or understanding of the product.

  2. Concepts - Conceptual content provides background information and context about a feature. Conceptual content can explain what the feature is, how it works at a high level, why it's needed, and when and where it's used.

  3. Tutorials - Tutorials provide a set of end-to-end steps to complete a project. Tutorials are complete and reproducible. They don't assume users have prior knowledge of the subject or required tools.

  4. Reference - Reference content provides technical descriptions of APIs, command line options, and other elements of code. Reference content is straightforward and doesn't include long explanations or guides.

A page in each category should link to the related pages in the other categories, if they exist.

For more information about these documentation types and the differences between them, refer to the Divio documentation system guide.