zsh-workers
 help / color / mirror / code / Atom feed
* [PATCH] vcs_info: use `--ignore-submodules=dirty` with diff/diff-index
@ 2014-09-22 14:37 Daniel Hahler
  2014-09-22 21:23 ` Frank Terbeck
  0 siblings, 1 reply; 2+ messages in thread
From: Daniel Hahler @ 2014-09-22 14:37 UTC (permalink / raw)
  To: Zsh Hackers' List

This will detect changes to submodules from the superproject's
perspective, e.g. after `git rm submodule`.

>From GIT-DIFF-INDEX(1)/GIT-DIFF(1):

    Using "dirty" ignores all changes to the work tree of submodules,
    only changes to the commits stored in the superproject are shown
    (this was the behavior until 1.7.0).
---
 Functions/VCS_Info/Backends/VCS_INFO_get_data_git | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)

diff --git a/Functions/VCS_Info/Backends/VCS_INFO_get_data_git b/Functions/VCS_Info/Backends/VCS_INFO_get_data_git
index c243bf7..ee50be6 100644
--- a/Functions/VCS_Info/Backends/VCS_INFO_get_data_git
+++ b/Functions/VCS_Info/Backends/VCS_INFO_get_data_git
@@ -176,17 +176,17 @@ if (( querystaged || queryunstaged )) && \
    [[ "$(${vcs_comm[cmd]} rev-parse --is-inside-work-tree 2> /dev/null)" == 'true' ]] ; then
     # Default: off - these are potentially expensive on big repositories
     if (( queryunstaged )) ; then
-        ${vcs_comm[cmd]} diff --no-ext-diff --ignore-submodules --quiet --exit-code ||
+        ${vcs_comm[cmd]} diff --no-ext-diff --ignore-submodules=dirty --quiet --exit-code ||
             gitunstaged=1
     fi
     if (( querystaged )) ; then
         if ${vcs_comm[cmd]} rev-parse --quiet --verify HEAD &> /dev/null ; then
-            ${vcs_comm[cmd]} diff-index --cached --quiet --ignore-submodules HEAD 2> /dev/null
+            ${vcs_comm[cmd]} diff-index --cached --quiet --ignore-submodules=dirty HEAD 2> /dev/null
             (( $? && $? != 128 )) && gitstaged=1
         else
             # empty repository (no commits yet)
             # 4b825dc642cb6eb9a060e54bf8d69288fbee4904 is the git empty tree.
-            ${vcs_comm[cmd]} diff-index --cached --quiet --ignore-submodules 4b825dc642cb6eb9a060e54bf8d69288fbee4904 2>/dev/null
+            ${vcs_comm[cmd]} diff-index --cached --quiet --ignore-submodules=dirty 4b825dc642cb6eb9a060e54bf8d69288fbee4904 2>/dev/null
             (( $? && $? != 128 )) && gitstaged=1
         fi
     fi
--
2.1.0


^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [PATCH] vcs_info: use `--ignore-submodules=dirty` with diff/diff-index
  2014-09-22 14:37 [PATCH] vcs_info: use `--ignore-submodules=dirty` with diff/diff-index Daniel Hahler
@ 2014-09-22 21:23 ` Frank Terbeck
  0 siblings, 0 replies; 2+ messages in thread
From: Frank Terbeck @ 2014-09-22 21:23 UTC (permalink / raw)
  To: Daniel Hahler; +Cc: Zsh Hackers' List

Daniel Hahler wrote:
> This will detect changes to submodules from the superproject's
> perspective, e.g. after `git rm submodule`.
>
> From GIT-DIFF-INDEX(1)/GIT-DIFF(1):
>
>     Using "dirty" ignores all changes to the work tree of submodules,
>     only changes to the commits stored in the superproject are shown
>     (this was the behavior until 1.7.0).
> ---
>  Functions/VCS_Info/Backends/VCS_INFO_get_data_git | 6 +++---
>  1 file changed, 3 insertions(+), 3 deletions(-)

Pushed, thanks!


^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2014-09-22 21:30 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-09-22 14:37 [PATCH] vcs_info: use `--ignore-submodules=dirty` with diff/diff-index Daniel Hahler
2014-09-22 21:23 ` Frank Terbeck

Code repositories for project(s) associated with this public inbox

	https://git.vuxu.org/mirror/zsh/

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).