How to contribute
This book uses a tool that builds HTML files from markdown files called 'mdbook'. The markdown files are stored on GitHub, in the main
holochain-rust repository. Because they are on GitHub, they have built-in version control, meaning that it's easy for anyone to contribute, and to propose, track and merge changes.
There are two main pathways to contribute. One is by editing files directly in GitHub, and the other is cloning the repository to your computer, running mdbook locally, and then submitting change requests. The following covers both scenarios.
Please do not edit the SUMMARY.md file, which stores the raw chapter structure, without advanced signoff from the documentation team in https://chat.holochain.org/appsup/channels/hc-core.
How the Book Works
Writing is in classic markdown, so a new page is a new markdown file. These files get rendered in the book panel. One markdown file, SUMMARY.md stores the structure of the book as an outline.
The HTML files used in the Book get automatically built from the markdown files. Even though they're auto-generated, static HTML files, one can search within the text.
What to Contribute
For a current list of open documentation issues, check out the 'documentation' label for github issues.
Contributing via GitHub
Log on to your GitHub account
In the Holochain Rust repo, everything is under the
doc/holochain_101/srcfolder. All markdown files are there, and some are nested in subfolders. Navigate to the following link: https://github.com/holochain/holochain-rust/tree/develop/doc/holochain_101/src
Determine whether you are making, editing, or reviewing an article.
If you don't have write access to the repository you need to create a fork to contribute. Forking is easy. Click the "Fork" button in the top right hand corner of the Github UI.
Making a new article
Click "Create New File"
Name this file what you intend to name the article, plus the
Use classic markdown to set up the page title, i.e. "# How to contribute"
Write the rest of your text, checking the "Preview" tab to see how it would look.
Scroll to the bottom of the page and select the option "create a new branch for this commit and start a pull request". You can name a branch, though GitHub will set one automatically. If you know it, mention the issue that the request addresses.
Click "Propose New File". Proceed to the Making Multiple Edits or Opening a Pull Request section.
Editing an article
Navigate to the article you want to edit.
Click the 'pencil' icon to edit the article. There's a built-in text editor in GitHub, where you can write a change and also why you changed it (so that a reviewer can understand the rationale for the change).
Select the branching method for making your change. (See Making Multiple Edits for clarification)
Click "Propose File Change". Proceed to the Making Multiple Edits or Opening a Pull Request section.
Making Multiple Edits On One Branch & Pull Request
A "branch" is a series of divergent changes from the main version. If you want to make multiple edits at once, you will need to make each of those changes on the same branch as you named your original edit. Check which branch you are on by looking for the "Branch: ?" dropdown. Use the dropdown to switch to your branch if you're on the wrong one.
Opening a Pull Request
Once redirected to the "comparing changes" page, prepend your pull request title with "MDBOOK: " and then a very short statement of what changed.
Add a more detailed description of what changes you made and why in the text box.
If there is an open issue related to the article you're submiting or editing, tag it by using the "#" plus the issue number.
Add the "documentation" label.
If appropriate, click "Reviewers" and select one or more people to request reviews from.
Click "Create Pull Request".
Reviewing a Pull Request
Under the Pull Request tab, look for ones starting with "MDBOOK". Go to the Pull Request of your choice, and then click on the "Files Changed" tab.
Start a review by hovering over a line and pressing the blue "add" symbol to add comments to a line
Click the green "Review Changes" button. If you approve of the changes, select "Approve". If you would like further changes to be made before it gets merged, select "Request Changes". If you are just weighing in, select "Comment". Then, click "Submit Review".
Merging a Pull Request
- Under "Conversation" you can merge the pull request, which integrates it into the
developbranch. Changes automatically deploy to https://holochain.github.io/holochain-rust within ~30 minutes. Merge the pull request once it has received two approved reviews.
Contributing by Cloning and Running Mdbook (advanced)
You will need to have cloned
holochain-rust to your computer. You will also need Docker installed.
There is a Docker build that allows local build, serve, watch and live reload for the book.
From the root of the repo, run:
. docker/build-mdbook-image && . docker/run-mdbook
Once the book has built and is serving, visit
http://localhost:3000 in the browser.
You can edit the markdown files in
doc/holochain_101/src and the book will live reload.
To do a one-time build of the files to HTML, run:
Edit the files to your satisfaction, commit them to a branch (or a fork) and then open a pull request on GitHub. Once its on GitHub, the same things as mentioned above apply.
suggest an edit