- 
                Notifications
    You must be signed in to change notification settings 
- Fork 928
SubmittingPullRequests
In the Open MPI project, we track three main things:
- 
Bugs and enhancement requests: These tracked in the Github Issues tracker in the ompirepository.
- 
Requests to get code into the release branches: These are tracked in the Pull Requests to release branches in ompirepository.
- 
RFCs (i.e., "hey, I've got an idea -- what do people think about this?"): These are typically tracked in the Pull Requests in the ompirepository.
You must have a Github account to submit bugs or pull requests.
Pull Requests for the Open MPI release branches are filed via developer's personal Github repositories, against one or more release branches in the  ompi repository Pull Requests listing.
Generally, an Open MPI developer writes new code and pushes it to the master branch on the main ompi repo.  To get that code into a release branch, the developer must submit a Pull Request against a particular release branch to get it pulled in to that release branch.
NOTE: Pull requests on release branch must include a hash reference in the body/comments corresponding to the commit(s) on ompi:master from which it is derived, OR indicate that this is solely a release branch bug (i.e., there's no corresponding commit on ompi:master because the bug doesn't/didn't exist on ompi:master).  Specifically: the intent is that code only goes in to a release branch after it has been committed to the ompi:master development branch.
The general scheme of how this works is:
- Developer writes/commits code in the masterbranch of their localompiclone.
- Developer pushes this code up to the ompirepo on Github.
- Developer creates a topic branch in their local repo from the desired release branch in their local repo.
- Developer cherry-picks the changes from masterto their local topic branch.
- Developer pushes their topic branch to their personal Github repo (NOT the main ompirepo!).
- Developer files a Pull Request to bring the code to the relevant release branch in the ompirepo.
Once the Pull Request is filed, there can be discussion on the PR. It is critical that any changes resulting from the discussion be first committed to the master branch in the ompi repo on Github so they can be tested by the community prior to moving them to the release branch. Once the changes have been pushed to the ompi repo, the Pull Request should be updated and a commit message containing the revision's master hash added. This should be done at the time the changes are pushed to the ompi repo so tracking is maintained.
Finally, when the PR is merged into the target branch on ompi, the PR is closed and the topic branch at Github and in the developer's local repo can be deleted.
An example of this developer process -- and its associated git commands -- is shown on this wiki page.