Skip to content

Latest commit

 

History

History
418 lines (285 loc) · 21.3 KB

HowToReadMe.md

File metadata and controls

418 lines (285 loc) · 21.3 KB

How to Write a README

The README file has a long tradition in software projects. Its purpose is to serve as the entry point for everything you might want to know about the project. You may not necessarily include all information, but you should at least link to it form the README. Even if you are just dumping your code onto GitHub and don't plan to support the project for others, it should include a README file.

Traditionally README files are plain text. Most projects typically use a text-based markup which renders nicely in GitHub. Markdown is the simplest and most readable when viewed as plain text. AsciiDoc and reStructuredText are more powerful and have features such as admonitions and generated table of contents.

The following sections will list and describe the major top-level sections you might find in a README file. You don't need to include every possible section in your read me file.

Table of Contents

Project Name

Every project, no matter how trivial, should include this section.

Choosing a project name can actually be quite difficult. Here are a few considerations to make.

Including the language in the name

This can be a good idea if you plan to have multiple implementations of your project using different languages or if there is already an existing project or common name which you are implementing in another language.

Googleability

Avoid using a generic word or a common combination of words for your project. Selecting a somewhat unique name will make it easier for someone to search for your project.

Shields

Shields are a great way to display important information about your project in a small amount of space. Most shields you see on GitHub are from Shields IO. Shields are commonly displayed directly under the project name heading, sometimes above it.

Build Status

A continuous integration status shield displays the build health of the project from a CI system like Travis CI. The CI system will usually offer you a link you can copy-paste in your favorite format (HTML, Markdown, AsciiDoc, etc...). The color of the shield will correspond to the build health. Green means good, red means failure.

"Build Status"

By putting the license in a shield you make it easy for visitors to quickly determine if this project is compatible with theirs. This shield should link to the license itself, either the official website or your embedded LICENSE file. It's also common to link to Software Licenses in Plain English.

"Build Status"

Let readers know the latest stable release by including this badge. If the project is still young and hasn't had a stable release yet, it's common to make the badge orange or red to indicate that.

Logo/Icon/Banner

💡 Use a tasteful size for your graphic, don't make it so large that you have to scroll far to get to useful information.
💡 Remember to include alt-text on your images for accessibiliy.

A graphic is commonly placed in one of the following locations:

Download Badge

If your project is available for distribution through an app store or package manager they often provide badge assets to visually call out that your project is included.

"Download on the App Store (Apple)"

See App Store Download Badge for details on its use.

Google Play Download Badge

See Google Play Badge Page for details on its use.

Short Description

Every project, no matter how trivial, should include this.
💡 If you are using GitHub then you should set the project description. The description is meta-data that appears in search results. You can re-use your opening sentence for this.

Describe the most relevant high-level information in one short paragraph. Try to get the most important information in the first two sentences. The goal is to save the reader time by explaining the project's purpose.

Example Opening Sentences

  • Alamofire

    Alamofire is an HTTP networking library written in Swift.

  • Apache HTTP Server

    The Apache HTTP Server is a powerful and flexible HTTP/1.1 compliant web server.

  • D3.js

    D3 (or D3.js) is a JavaScript library for visualizing data using web standards.

  • libgit2 README

    libgit2 is a portable, pure C implementation of the Git core methods provided as a re-entrant linkable library with a solid API, allowing you to write native speed custom Git applications in any language with bindings.

Table Of Contents Section

💡 This is optional, but if your README is long, you should include a TOC.

Sometimes called "Contents". If your README is long enough you might consider including a table of contents. AsciiDoc and reStructuredText formats support automatic generation of the table of contents.

Screen Shots

If you include screenshots, set the width or height property to ensure they are not oversized. This is especially important when your screenshots are from a high-dpi device but the README is being read on a low dpi-device.

Feature List

Typically called just "Features". A feature list can be a set of bullet points. If you want to include commentary on each feature you can use sections instead. If your feature list is very long or includes a lot of detail, consider putting it in its own file in the Docs Directory and linking to it from this section.

Requirements

List the requirements for your project. If you require a specific version of something, be sure to include that information.

Installation

Ideally you will distribute your package as part of the appropriate repository. For example, if this is a Perl project you might use CPAN, a Go library, use Go's manager, Node use npm etc...

Configuration

⛔️ ToDo: This section is a stub

If your project is highly configurable consider making this its own document in the <> and linking to it from this section.

Usage/Quick Start

⛔️ ToDo: This section is a stub

Sometimes called "Guide" or "Tutorial" or "Getting Started".

Documentation

If you hope to get people to use your project you will need to take documentation seriously. Some projects are small enough that they can fit all their documentation in the README itself (example). If it gets too long, then move it to the Docs Directory and refer to it from this section.

Examples

⛔️ ToDo: This section is a stub

FAQ

⛔️ ToDo: This section is a stub

Troubleshooting

⛔️ ToDo: This section is a stub

This section is often included in projects whose documentation fits within the README.

Non-Goals

This section is fairly uncommon, though it should be used more. It can be very helpful to list things your project isn't meant for. This can help limit the scope of your project and set expectations. Non-goals can also help keep outside contributions and questions more focused on the project goals.

Changes

Sometimes called "Version History". Typically you would refer to and link the CHANGELOG file or releases section of your project site.

Contributing

Typically this section just refers you to the CONTRIBUTING file. Even if it's already mentioned in the CONTRIBUTING file, it might be a good idea to state whether contributions are welcome.

Contributors/Credits

May be called "Maintainers". List of people who contributed to the project. Yes, sites like GitHub already have a feature that let you see a list of contributors, and you can probably figure it out through the repo history too, but it might still be valuable to have this in the README because it lets you curate the list, order it based on influence or number of contributions, or take out old contributors who are no longer involved.

Security Disclosure

⛔️ ToDo: This section is a stub

Donations

⛔️ ToDo: This section is a stub

Author(s)

Different from the Contributors section in that this lists the original author(s) of the project. You may want to also include links to your blog and Twitter handle.

Support/Help

⛔️ ToDo: This section is a stub

See next section: Community/Communication.

Community/Communication

Depending on what type of community groups exist for your project, you might point users to: stackoverflow, irc, mailing lists, slack, wiki, forums etc...

Commercial Support

Often commercial support is simply mentioned in a sentence in the Community/Communication section, referring to the maintainer's email for details on commercial support.

Sponsors

Sufficiently large projects may receive funding and list their sponsors here. You can also provide details about how to become a sponsor. Sometimes this is name "Backers".

Projects Using X

If your project is being used by other projects or well known entities you can list them here.

Disclaimer

Most software licenses will typically include a disclaimer so this section isn't necessary most of the time. If people might jump to certain conclusions about your project it might be a good idea to call it out in its own section. Another reason to add a disclaimer would be to distance your project from your employer, if it might be easy to draw conclusions about their involvement.

Related Projects

If your project may have plug-ins or extensions it may be a good idea to list some of them here.

Alternatives

Projects rarely include this section, but it could be helpful to the reader. You don't have to exhaustively list every similar library, but mentioning a few common ones can be useful.

About

⛔️ ToDo: This section is a stub

License

You should always include a license with your project.

Although you probably already have a shield with the license, it doesn't hurt to explicitly call it out again here. This is typically the last section of the README. If the license is short you can include the contents, otherwise link to the LICENSE file. Even if it's obvious it does help to actually mention the name of the license instead of just including its contents. For example: say it's "MIT", "2-clause BSD" etc...

Many projects now use FOSSA to track license compliance and attribution.