Jens Lehmann <jens.lehm...@web.de> writes:

> Currently setting submodule.<name>.ignore and/or diff.ignoreSubmodules to
> "all" suppresses all output of submodule changes for git-gui. This is
> really confusing, as even when the user chooses to record a new commit for
> an ignored submodule by adding it manually this change won't show up under
> "Staged Changes (Will Commit)".
>
> Fix that by using the '--ignore-submodules=dirty' option for both callers
> of "git diff-index --cached" when the underlying git version supports that
> option.
>
> Signed-off-by: Jens Lehmann <jens.lehm...@web.de>
> ---

I'll tentatively queue this on jl/git-gui-show-added-submodule-changes
and park it on 'pu'.

I'll be tagging 2.0.0-rc0 later this week; if you have some
accumulated changes (I saw that your public repository is at
gitgui-0.19.0 which I already have), please plan to get them
in by the end of next week.

Thanks.

>  git-gui.sh   | 6 +++++-
>  lib/diff.tcl | 3 +++
>  2 files changed, 8 insertions(+), 1 deletion(-)
>
> diff --git a/git-gui.sh b/git-gui.sh
> index cf2209b..c69bfb3 100755
> --- a/git-gui.sh
> +++ b/git-gui.sh
> @@ -1558,7 +1558,11 @@ proc rescan_stage2 {fd after} {
>
>       set rescan_active 2
>       ui_status [mc "Scanning for modified files ..."]
> -     set fd_di [git_read diff-index --cached -z [PARENT]]
> +     if {[git-version >= "1.7.2"]} {
> +             set fd_di [git_read diff-index --cached 
> --ignore-submodules=dirty -z [PARENT]]
> +     } else {
> +             set fd_di [git_read diff-index --cached -z [PARENT]]
> +     }
>       set fd_df [git_read diff-files -z]
>
>       fconfigure $fd_di -blocking 0 -translation binary -encoding binary
> diff --git a/lib/diff.tcl b/lib/diff.tcl
> index 30d9a79..b0a5180 100644
> --- a/lib/diff.tcl
> +++ b/lib/diff.tcl
> @@ -287,6 +287,9 @@ proc start_show_diff {cont_info {add_opts {}}} {
>       if {$w eq $ui_index} {
>               lappend cmd diff-index
>               lappend cmd --cached
> +             if {[git-version >= "1.7.2"]} {
> +                     lappend cmd --ignore-submodules=dirty
> +             }
>       } elseif {$w eq $ui_workdir} {
>               if {[string first {U} $m] >= 0} {
>                       lappend cmd diff
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to