Re: [PATCH] Ignore dirty submodule states during stash

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Stefan,

On Sun, May 15, 2016 at 11:37:20PM -0700, Stefan Beller wrote:
> On Sun, May 15, 2016 at 7:07 PM, Vasily Titskiy <qehgt0@xxxxxxxxx> wrote:
> > Do not save states of submodules as stash should ignore it.
> 
> Can you explain why this is a good idea?
> (It is not obvious to me either way.)
Actually, submodules are already ignored by stash, but not fully (it was introduced in commit 6848d58).
Current behavior is counter-intuitive, for example (if one has a project with a submodule):
 $ cd sub1
 $ edit .. commit .. edit .. commit. Alternatively, just checkout some other commit
 $ cd .. # back to main project
 $ git stash save
   No local changes to save
 $ # so, stash declares there are no changes
 $ edit main.cpp
 $ # For example, I need to update my working tree to latest master
 $ git stash save # save local changes of 'main.cpp'...
 $ git pull --recurse-submodules && git submodule update --recursive # update to latest
 $ git stash pop # I expect to get stashed changes for 'main.cpp', but...
   warning: Failed to merge submodule sub1 (commits don't follow merge-base)
   Auto-merging sub1
   CONFLICT (submodule): Merge conflict in sub1

So, this is the issue. Instead of getting my local changes, I got a conflict (and stash is not 
poped out). The root cause is the 'stash' command does not know how to deal with submodules,
but currently it tries to save the state of submodules, and even tries to re-apply the state
(and it fails of course). The proposed solution fixes this behaviour.

All internal tests work fine with the change.


> 
> Do we need a test/documentation updates for this?
I don't think so, 'stash' have never claimed submodule support.

> 
> >
> > Signed-off-by: Vasily Titskiy <qehgt0@xxxxxxxxx>
> > ---
> >  git-stash.sh | 2 +-
> >  1 file changed, 1 insertion(+), 1 deletion(-)
> >
> > diff --git a/git-stash.sh b/git-stash.sh
> > index c7c65e2..b500c44 100755
> > --- a/git-stash.sh
> > +++ b/git-stash.sh
> > @@ -116,7 +116,7 @@ create_stash () {
> >                         git read-tree --index-output="$TMPindex" -m $i_tree &&
> >                         GIT_INDEX_FILE="$TMPindex" &&
> >                         export GIT_INDEX_FILE &&
> > -                       git diff --name-only -z HEAD -- >"$TMP-stagenames" &&
> > +                       git diff --name-only --ignore-submodules -z HEAD -- >"$TMP-stagenames" &&
> >                         git update-index -z --add --remove --stdin <"$TMP-stagenames" &&
> >                         git write-tree &&
> >                         rm -f "$TMPindex"
> > --
> > 2.1.4
> >
> > --
> > 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
--
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



[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]