Can I help fix a bug?

Sure! Have a look at the issue report: if the issue is assigned to someone, they’re on it! Otherwise, add a comment in the issue indicating you’d like to work on resolving the issue and go for it!

Contributing Code

Whether you have a fix for an issue, some improved test cases, or a brand new feature, we welcome your contributions in the form of pull requests.

NOTE: Your contributions are governed by the GitHub TOS section 6 which indicate that your contributions are made under the same license as the project. Furthermore, by making a contribution to the project, you certify that you have the right to submit to the project as detailed in the Developer Certificate of Origin.

Follow this process if you’d like your work considered for inclusion in the project:

  1. Fork the project, clone your fork, and configure the remotes:

    # Clone your fork of the repo into the current directory
    git clone https://github.com/<your-username>/<repo-name>
    
    # Navigate to the newly created directory
    cd <repo-name>
    
    # Assign the repo to a remote called "upstream"
    git remote add upstream https://github.com/<upstream-owner>/<repo-name>
    
  2. If you cloned a while ago, get the latest changes from upstream:

    git checkout <dev-branch>
    git pull upstream <dev-branch>
    
  3. Create a new topic branch (off the main project development branch) to contain your feature, change, or fix:

    git checkout -b <topic-branch-name>
    
  4. Commit your changes in logical chunks. Please adhere to these git commit message guidelines. Use Git’s interactive rebase feature to tidy up your commits before making them public.

  5. Locally merge (or rebase) the upstream development branch into your topic branch:

    git pull [--rebase] upstream <dev-branch>
    
  6. Push your topic branch up to your fork:

    git push origin <topic-branch-name>
    
  7. Open a Pull Request with a clear title and description.

Once submitted, your pull request will be reviewed and you will receive some feedback to make sure that your pull request fits in with:

  • the roadmap for the project
  • the architecture of the project
  • the coding Style Guide of the project

Once your pull request has been accepted, it will be merged into the master branch.