Documentation/Library Documentation Template

= Libraries Documentation =

Who should use this template?
This template is suitable for writing any form of library documentation and shouldn't be used for anything else asides that.

= Template = Below is the provided template for this particular genre and is to be duly followed when creating documentation.

Title
The name of the library should be written boldly at the top. For this template, a title is not needed.

Getting Help
The audience needs to know where they could visit when they are stuck or have issues. You should provide a link to the following;


 * FAQs
 * Module Index
 * Bug reporting.

The FAQ as the name implies is a page that contains a list of basic questions that the audience is most likely to have with respective answers to those questions. A separate document should be created for the FAQ, and you can use this template(Link to be added) as a starting point/guide.

The Library index is a list of all methods and APIs that this library provides. It should be added towards the end of this page and a link to it should be provided.

Libraries are bound to have bugs and this the way bugs are reported vary from library to library, you should state how bugs should be reported to your library here and provide all useful links.

The above can be structured as shown below;

Having trouble? We’d like to help!


 * Check the FAQ, it has answers to lots of common questions.
 * Looking for specific information? Check the Library Index or the detailed table of contents above.
 * Found a bug? Report bugs on our GitHub repository here.

Getting Started
This section should explain what the library does in-depth, put the audience through how to install the library, and also introduce them to its basic syntax.

What is library X
This part should answer the following questions;


 * What does this library do?
 * What problem is it trying to solve?
 * Why was it created and who was it created for?
 * Who created it and when was it created?

Installation/setup Guide
The audience needs to know how this library can be appropriately installed or setup, you should walk them through;


 * The prerequisite software needed to for this library to be installed or setup.
 * A step to step process in installing or setting up this library.
 * What version of this library should be installed for specific cases.
 * How to verify that the installation was successful.

Some installation guides might be quite lengthy, for such guides, you should consider creating a QSG and share a link here instead.

Writing your first X
In this section, you'll be introducing the audience to the basic syntax of the library. You will walk the audience through a very small but simplistic code snippet and explain what it does. The idea is to get them to see what the usage of this library looks like and how simple using it can be.

Here is an example taken from the scrapy documentation explaining its basic usage.

Concepts in X
Different libraries are used for different things, and each have their own terminologies and concepts. Here is a good place to explain such concepts in as much detail as is sufficient to get the audience started.

Lets assume, this is a state management library for a front end framework, an example of concepts worth explaining would be state, mutations, getters, actions, etc

Turorials and how-tos
This is where you explain in-depth the usage of this library to the audience. There are two options you could adopt based on that nature of the library


 * Have the tutorials on this page.
 * Create a separate document for each tutorial and provide links here.

The first should be used if this is a minimalistic library and there aren't many tutorials i.e just about 3 short tutorials.

If there are more than 3 tutorials, you should consider moving each to a separate document and providing links to them here. You can use Tutorials & walkthroughs template, or the Quick Start Guide template as a guide for creating these documents.

However, this particular document must contain a guide on how to setup a project with the library.

Setting a project
Here you have to discuss what is required to get a project started with this library and how to set it up.


 * What re the requirements?
 * Whats the recommended folder structure?
 * How can this library be used or imported? Over CDN, or needs to be installed?
 * If both of the above, give examples of each.

Module Index
The module index is a list of all modules, methods, and APIs this library provides and a brief explanation of what they do.g

This can be added as a list here if there aren't too many of them, or a separate document containing these lists can be created with a link to it provided here.

Contributing to X
This is a guide explaining how people can contribute to this library, contributions do not have to be code contributions, it could come in any form. But this guide should cover all the forms in which contributions are welcomed! Additionally, you should consider including the following;

You should have a look at Numpy's contributor guide.
 * Explain the development workflow i.e how codes moves from commit to PR's to being merged
 * Explain the code review process.
 * Explain the coding style/guidelines.
 * Encourage people to help as much as they can in talk forums and places like stack overflow. You could provide links to these forums.

Stewardship
Here, you would share useful information about the following;


 * Who maintains this page.
 * The project is written on.
 * How to contact the author and maintainers of this project(only share public information here, e.g zulip or IRC).
 * Links to discussion pages/threads.