Johannes Sixt <j.sixt@xxxxxxxxxxxxx> writes: > Ingo Brueckl schrieb: > > In a branch, I learned, I have to commit or stash before I return to master > > for push/pull to follow the project. If I forget, I'm screwed, because files > > have changed due to the rewrite (in that branch), I won't get a warning until > > my first commit (in that branch) and commits (in master) will conflict. Errr... if having unknown files in status info when comitting doesn't clue you in that you have spurious uncomitted changes, # On branch master # Changes to be committed: # (use "git reset HEAD <file>..." to unstage) # # modified: somefile and neither commit diff summary n files changed, kk insertions(+), ll deletions(-) doesn't clue you in, then you have more serous problems! Second, you can use git-aware prompt to tell you if you have uncomitted changes, so you will know when switching branches that you have some changes that don't belong to branch you switch from. > > You are obviously of a CVS or SVN mindset, where making a commit is such > an important operation that you don't dare to make it until your work is > *completed*. > > With a git mindset, it won't happen that you "forget" whether you have > anything uncommitted; you simply never have because committing half-baked > stuff is the rule, not the exception. That is, before you get a cup of > coffee, you commit; before you answer a phone call, you commit; before you > turn your attention away, you commit. (That may be exaggerated, perhaps it > even isn't, but you get the point.) > > When you have completed your work, you go back to make your commit history > look nice, comprehensible, and bisectable. ...with "git rebase --interactive" or patch management interface (StGit, Guilt), or topic branch management interface (TopGit). > > And only then comes the heavy operation: You publish your work for > consumption by interested parties. This may be even only you yourself: > "Consumption" would be to merge the work into your release branch. This is > the right time to care about upstream again. -- Jakub Narebski Poland ShadeHawk on #git -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html