Skip to content
Paul Ray edited this page Oct 15, 2019 · 11 revisions

The basic git workflow is that developers should fork the repository and develop in feature branches, then send pull requests to the main nanograv/PINT github repository. This works best if your feature branches are kept relatively small and are deleted after a pull request, as described below.

This page is outdated. See the updated instructions in the documentation


Set up forked repository

  • Fork the nanograv/PINT repository with the github web interface and check it out to your local machine with git clone
  • Set up upstream tracking of the main repo with this command (the upstream repo will be called nanograv):
  • git remote add nanograv https://github.com/nanograv/PINT.git

To update local master with nanograv/master

  • git fetch nanograv
  • git checkout master
  • git merge nanograv/master

Add a feature branch

  • git branch my_feature
  • git checkout my_feature
  • [edit files]
  • git commit # Make sure you use useful commit messages.
  • Repeat, keeping each commit as a relatively small and atomic change, in case individual commits need to be adjusted or rejected by the maintainer during the merge process.
  • Do not commit local (i.e. user-specific) changes to setup.py. Stash those if needed.

When you are ready to merge your changes with nanograv/PINT

  • First, make sure that the test suite make test runs without error. Fix any issues.
  • Make sure to check the coverage report (view tests/datafile/coverage/index.html). Your new code should be covered by tests!
  • Update your master with nanograv/master as described above
  • Rebase your feature onto the master, and resolve any conflicts. This way the person contributing a feature is responsible for making sure it works with the main branch. If, as recommended, you have not pushed your branch to github, this all happens locally and will result in a nice linear commit history.
  • git checkout my_feature
  • git rebase master
  • If you have pushed your feature branch earlier, then it may not be good to rebase, so just merge it:
  • git checkout my_feature
  • git merge nanograv/master
  • Edit the CHANGELOG to briefly describe new features or API changes included in your branch
  • Then push to github and set the local and remote branches to track one another
  • git push -u origin my_feature
  • At this point, you can do a pull request
  • Travis-ci will automatically run on the PR and you will be able to see the status of the build
  • If any changes are requested by the nanograv maintainer, make additional commits and git push. These will get added to the pull request
  • When the pull request is merged by the maintainer, delete your feature branch locally and on github
  • git branch -d my_feature
  • git push origin --delete my_feature