A pull requests marries the entire branch to the one you're targeting; if you keep making changes here and there, a pull request will include all these new changes, regardless of when you originally opened it. It makes your request basically un-mergeable by upstream repositories, in most cases.
So the real procedure is:
- Fork the upstream repository. Now you have your own master branch. Clone it locally as usual.
- Create a new branch, either via web or (easier) from the command line with git branch FixBugBranch && git checkout -b FixBugBranch.
- Make your changes on this FixBugBranch. Make only the minimum amount of changes necessary to fix a specific issue, then commit and push.
- On GitHub, create a pull request from FixBugBranch towards the original repository
- When/if your pull request is accepted upstream, you can delete FixBugBranch.
If you want to make further changes, you can either create a further branch from FixBugBranch, or create and merge a pull request from FixBugBranch into your master. The important thing is that you don't touch FixBugBranch anymore, so that upstream maintainers won't receive all your extra commits but only ones relevant to the particular bug you raised.
git checkout -b FixBugBranch, thank you very much.
ReplyDeleteThis seems to make sense if you have write access to the repo. What if I don't have write access? Am I missing something?
ReplyDelete(What prevents trolls from branch-bombing?)
What do you mean by "branch-bombing"?
ReplyDeleteOnce you fork, the forked repo is yours -- it's how distributed VCS works, they make whole copies. If you want to create 123456 branches on it, it's your problem, nobody cares. To clarify, the branch is created *on your own repo*, not on the original one.
People are only "affected" when you issue a pull request, but nobody is in any way forced to accept your requests -- more often than not, in fact, they will be either ignored or deleted if you're proposing something the original owner does not agree with. If you issue 123456 pull requests, chances are that you will be flagged and GitHub / Bitbucket will take action and ban you.