Skip to content
This repository has been archived by the owner on Feb 20, 2019. It is now read-only.

Latest commit

 

History

History
122 lines (88 loc) · 4.49 KB

CONTRIBUTING.rst

File metadata and controls

122 lines (88 loc) · 4.49 KB

Contributing

Contributing to the documentation requires a Github account. Make sure you are working in the correct branch for your version of ownCloud or client apps. If your edits pertain to multiple manual versions, be prepared to backport as needed.

To edit a document, you can edit the .rst files on your local system, or work directly on Github. The latter is only suitable for small fixes and improvements because substantial editing efforts are easier on your local PC.

The best way is to install a complete Sphinx build environment and work on your local machine. You will be able to make your own local builds, which is the fastest and best way to preview for errors. Sphinx will report syntax errors, missing images, and formatting errors. The Github preview is not complete and misses many mistakes.

For details on how to setup a Sphinx build environment, have a read through the build instructions.

Working On A Patch

We recommend you do each new feature or bugfix in a new branch. This simplifies the task of review as well as the task of merging your changes into the canonical repository.

A typical workflow will then consist of the following:

  1. Create a new local branch based off either your master or develop branch.
  2. Switch to your new local branch. (This step can be combined with the previous step with the use of git checkout -b.)
  3. Do some work, commit, repeat as necessary.
  4. Push the local branch to your remote repository.
  5. Send a pull request.

The mechanics of this process are actually quite trivial. Below, we will create a branch for fixing an issue in the tracker.

$ git checkout -b hotfix/9295
Switched to a new branch 'hotfix/9295'

... do some work ...

$ git commit

... write your log message ...:

$ git push origin hotfix/9295:hotfix/9295
Counting objects: 38, done.
Delta compression using up to 2 threads.
Compression objects: 100% (18/18), done.
Writing objects: 100% (20/20), 8.19KiB, done.
Total 20 (delta 12), reused 0 (delta 0)
To ssh://[email protected]/owncloud/documentation.git
   b5583aa..4f51698  HEAD -> master

To send a pull request when using GitHub, navigate to your repository, select the branch you just created, and then select the "Pull Request" button in the upper right. Select the user/organization "owncloud/documentation" as the recipient.

What Branch To Issue The Pull Request Against?

Which branch should you issue a pull request against?

  • For fixes against the stable release, issue the pull request against the "master" branch.
  • For new features, or fixes that introduce new elements to the public API (such as new public methods or properties), issue the pull request against the "develop" branch.

When creating the Pull Request, please keep the recommendations of this post in mind. To save time, here is a slightly revised version of the core points:

  • Include the purpose of this Pull Request
  • Consider providing an overview of why the change is being made
  • Consider including any relevant links.
  • Please don't assume that anyone has any familiarity with the project's history
  • Remember that anyone in the company could be reading the Pull Request
  • Be explicit about what feedback you want.
  • Be explicit about when you want feedback.
  • @mention individuals that you specifically want in the discussion and why
  • @mention teams that you want to involved in the discussion and why

Branch Cleanup

As you might imagine, if you are a frequent contributor, you'll start to get a ton of branches both locally and on your remote.

Once you know that your changes have been accepted to the master repository, we suggest doing some cleanup of these branches.

Local branch cleanup

$ git branch -d <branchname>

Remote branch removal

$ git push origin :<branchname>

Editing Directly On GitHub

To edit on Github, fork the repository (see top-right of the screen, under your username). You will then be able to make changes easily. Once done, you can create a pull request and get the changes reviewed and back into the official repository.