[PATCH 2/2] Optionally check for uncommitted changes before switching branches.

Previous thread: [PATCH 1/2] Allow users to require source branch on git-checkout -b. by Shawn O. Pearce on Thursday, December 7, 2006 - 6:01 am. (12 messages)

Next thread: [PATCH 1/1] Make sure the empty tree exists when needed in merge-recursive. by Shawn O. Pearce on Thursday, December 7, 2006 - 6:17 am. (32 messages)
To: Junio C Hamano <junkio@...>
Cc: <git@...>
Date: Thursday, December 7, 2006 - 6:02 am

Lately I have noticed a number of users are forgetting that they
have uncommitted changes in their working directory when they switch
to another branch. This causes the user to accidentally carry those
changes into the new branch, which is usually not where they wanted
to commit them. A correlation does appear to exist between the user
being interrupted in the middle of their task and the branch switch,
indicating they simply got distracted and forgot what was going on.

Git shouldn't cause the user to make mistakes when it can help to
prevent them. So now users may set checkout.requireCleanDirectory
to true in their config file to have git-checkout verify the working
directory is clean before switching branches.

Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
---
Documentation/config.txt | 8 ++++++++
git-checkout.sh | 10 ++++++++++
t/t3200-branch.sh | 11 +++++++++++
3 files changed, 29 insertions(+), 0 deletions(-)

diff --git a/Documentation/config.txt b/Documentation/config.txt
index 9d754c8..f10e8ac 100644
--- a/Documentation/config.txt
+++ b/Documentation/config.txt
@@ -136,6 +136,14 @@ checkout.requireSourceBranch::
be the source version if only one argument is supplied.
Default is false, to stay compatible with prior behavior.

+checkout.requireCleanDirectory::
+ If true tells git-checkout to verify there are no uncommitted
+ changes still in the index or working directory before
+ switching branches. If uncommitted changes exist the -m
+ flag can be used to skip the check if the user really wanted
+ to carry those onto the new branch. Default is false,
+ to stay compatible with prior behavior.
+
pager.color::
A boolean to enable/disable colored output when the pager is in
use (default is true).
diff --git a/git-checkout.sh b/git-checkout.sh
index 5f9fb6e..c04b8c1 100755
--- a/git-checkout.sh
+++ b/git-checkout.sh
@@ -171,6 +171,16 @@ then
git-read-tree --reset -u $new
else
git-update-index --refr...

To: Shawn O. Pearce <spearce@...>
Cc: <git@...>
Date: Thursday, December 7, 2006 - 3:38 pm

A lot of times the reason to switch branches is because the user
starts to make a trivial change in the worktree and realizes
that the change belongs to another branch. Other times it is
done by mistake and making it easier to notice that mistake is a
laudable goal.

Your patch allows -m to override this, but that destroys one
very useful feature of -m. In the above "ah, this trivial thing
belongs to the other branch, so let's switch to the branch to
commit only that trivial piece and come back to the current
branch to continue what I'm doing" workflow, I usually first say
"git checkout" without -m to switch, and if it does not allow me
to switch, it is an indication that "the trivial thing" I
thought was trivial was not trivial. I take it as a cue that I
should instead do it "the right way" (i.e. finish or stash away
what I am doing, switch to the branch in a clean state and fix
it properly).

Other times, when all (or most of) the changes in the work tree
logically should have started on a different branch, I do force
it with -m (and take the conflict markers in my worktree), but
being able to forbid the worktree merge by not giving -m is
important.

People with this new configuration set and has to override it
with a command line switch will lose this ability if you
overload that on '-m'.

-

To: Junio C Hamano <junkio@...>
Cc: <git@...>
Date: Thursday, December 7, 2006 - 3:43 pm

Yes. That's a problem with this patch.

What about when this option is enabled then -m means do what we
did before, and -m -m (or -mm, or -m2) does what -m does when the
option is false?

--
Shawn.
-

To: Shawn Pearce <spearce@...>
Cc: <git@...>
Date: Thursday, December 7, 2006 - 7:01 pm

Wouldn't --force be more appropriate?

-

Previous thread: [PATCH 1/2] Allow users to require source branch on git-checkout -b. by Shawn O. Pearce on Thursday, December 7, 2006 - 6:01 am. (12 messages)

Next thread: [PATCH 1/1] Make sure the empty tree exists when needed in merge-recursive. by Shawn O. Pearce on Thursday, December 7, 2006 - 6:17 am. (32 messages)