* Git Flow adds various commands into Git to enhance its native functionality, which creates a branching model to separate your stable production code from your unstable development code.
* Never commit directly to the master branch - this is for production code only!
* You can commit directly to the develop branch, but this should be done sparingly.
* Use feature branches as much as possible - one per feature, user story or bug.
* Commit early and often, and push to a remote often to encourage collaboration as well as to provide a backup of your code.
* You can use settings within services like GitHub and Bitbucket to only allow certain users to push to the master and develop branches, and restrict other Developers to only commit and push to feature branches. Changes can then be committed and pushed, then reviewed as part of a peer code review, and merged back into the develop branch.
## Feedback
If you've got any questions, please feel free to <ahref="http://twitter.com/opdavies"title="My Twitter account">tweet at me</a> or fill in the <ahref="http://2014.drupalcamplondon.co.uk/node/add/session-evaluation?nid=86&destination=node/86"title="The session evaluation form to submit feedback">session evaluation form</a> that you can complete on the DrupalCamp London website.
content: '<p><ahref="https://twitter.com/opdavies">@opdavies</a><ahref="https://twitter.com/DrupalCampLDN">@DrupalCampLDN</a> always had trouble with git. Your talk + Git flow has made it all very easy.</p>— James Tombs (@jtombs) <ahref="https://twitter.com/jtombs/statuses/440108072078696449">March 2, 2014</a>'
content: '<p>Great presentation by <ahref="https://twitter.com/opdavies">@opdavies</a> on git flow at <ahref="https://twitter.com/search?q=%23dclondon&src=hash">#dclondon</a> very well prepared and presented. <ahref="http://t.co/tDINp2Nsbn">pic.twitter.com/tDINp2Nsbn</a></p>— Greg Franklin (@gfranklin) <ahref="https://twitter.com/gfranklin/statuses/440104311276969984">March 2, 2014</a>'