* [PATCH] git-prompt: GIT_PS1_SHOWCONFLICTSTATE variable fix
@ 2024-03-19 20:32 Michiel W. Beijen
2024-03-19 22:58 ` Justin Donnelly
0 siblings, 1 reply; 4+ messages in thread
From: Michiel W. Beijen @ 2024-03-19 20:32 UTC (permalink / raw)
To: git; +Cc: justinrdonnelly, Michiel W. Beijen
There are a few environment variables that can influence the output for
the __git_ps1 macro in git-prompt.sh. All settings that are 'on/off'
types such as GIT_PS1_SHOWUNTRACKEDFILES and GIT_PS1_SHOWDIRTYSTATE
just take any value, and in the tests are tested with 'y', however
GIT_PS1_SHOWCONFLICTSTATE must be set to 'yes' otherwise it will not
work.
This commit changes that behaviour, and makes sure
GIT_PS1_SHOWCONFLICTSTATE is consistent with these other parameters.
Signed-off-by: Michiel W. Beijen <mb@x14.nl>
---
contrib/completion/git-prompt.sh | 6 +++---
t/t9903-bash-prompt.sh | 2 +-
2 files changed, 4 insertions(+), 4 deletions(-)
diff --git a/contrib/completion/git-prompt.sh b/contrib/completion/git-prompt.sh
index 71f179cba3..fd6141e463 100644
--- a/contrib/completion/git-prompt.sh
+++ b/contrib/completion/git-prompt.sh
@@ -85,8 +85,8 @@
# by setting GIT_PS1_OMITSPARSESTATE.
#
# If you would like to see a notification on the prompt when there are
-# unresolved conflicts, set GIT_PS1_SHOWCONFLICTSTATE to "yes". The
-# prompt will include "|CONFLICT".
+# unresolved conflicts, set GIT_PS1_SHOWCONFLICTSTATE to a nonempty
+# value. The prompt will include "|CONFLICT".
#
# If you would like to see more information about the identity of
# commits checked out as a detached HEAD, set GIT_PS1_DESCRIBE_STYLE
@@ -528,7 +528,7 @@ __git_ps1 ()
fi
local conflict="" # state indicator for unresolved conflicts
- if [[ "${GIT_PS1_SHOWCONFLICTSTATE}" == "yes" ]] &&
+ if [ -n "${GIT_PS1_SHOWCONFLICTSTATE-}" ] &&
[[ $(git ls-files --unmerged 2>/dev/null) ]]; then
conflict="|CONFLICT"
fi
diff --git a/t/t9903-bash-prompt.sh b/t/t9903-bash-prompt.sh
index d667dda654..6479a0d898 100755
--- a/t/t9903-bash-prompt.sh
+++ b/t/t9903-bash-prompt.sh
@@ -769,7 +769,7 @@ test_expect_success 'prompt - conflict indicator' '
test_when_finished "git reset --hard HEAD~" &&
test_must_fail git stash apply &&
(
- GIT_PS1_SHOWCONFLICTSTATE="yes" &&
+ GIT_PS1_SHOWCONFLICTSTATE=y &&
__git_ps1 >"$actual"
) &&
test_cmp expected "$actual"
base-commit: 3bd955d26919e149552f34aacf8a4e6368c26cec
--
2.43.0
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH] git-prompt: GIT_PS1_SHOWCONFLICTSTATE variable fix
2024-03-19 20:32 [PATCH] git-prompt: GIT_PS1_SHOWCONFLICTSTATE variable fix Michiel W. Beijen
@ 2024-03-19 22:58 ` Justin Donnelly
2024-03-24 17:18 ` Michiel Beijen
0 siblings, 1 reply; 4+ messages in thread
From: Justin Donnelly @ 2024-03-19 22:58 UTC (permalink / raw)
To: Michiel W. Beijen; +Cc: git
Hi Michiel,
This is my code, so I'm really glad somebody else finds it useful!
On Tue, Mar 19, 2024 at 4:33 PM Michiel W. Beijen <mb@x14.nl> wrote:
>
> There are a few environment variables that can influence the output for
> the __git_ps1 macro in git-prompt.sh. All settings that are 'on/off'
> types such as GIT_PS1_SHOWUNTRACKEDFILES and GIT_PS1_SHOWDIRTYSTATE
> just take any value, and in the tests are tested with 'y', however
> GIT_PS1_SHOWCONFLICTSTATE must be set to 'yes' otherwise it will not
> work.
I had actually considered using set/unset (for the same reason as you
- consistency), but was advised to use a boolean flag.
See: https://marc.info/?l=git&m=165897458021238&w=2 and
https://marc.info/?l=git&m=165903017715652&w=2
>
> This commit changes that behaviour, and makes sure
> GIT_PS1_SHOWCONFLICTSTATE is consistent with these other parameters.
>
> Signed-off-by: Michiel W. Beijen <mb@x14.nl>
> ---
> contrib/completion/git-prompt.sh | 6 +++---
> t/t9903-bash-prompt.sh | 2 +-
> 2 files changed, 4 insertions(+), 4 deletions(-)
>
> diff --git a/contrib/completion/git-prompt.sh b/contrib/completion/git-prompt.sh
> index 71f179cba3..fd6141e463 100644
> --- a/contrib/completion/git-prompt.sh
> +++ b/contrib/completion/git-prompt.sh
> @@ -85,8 +85,8 @@
> # by setting GIT_PS1_OMITSPARSESTATE.
> #
> # If you would like to see a notification on the prompt when there are
> -# unresolved conflicts, set GIT_PS1_SHOWCONFLICTSTATE to "yes". The
> -# prompt will include "|CONFLICT".
> +# unresolved conflicts, set GIT_PS1_SHOWCONFLICTSTATE to a nonempty
> +# value. The prompt will include "|CONFLICT".
> #
> # If you would like to see more information about the identity of
> # commits checked out as a detached HEAD, set GIT_PS1_DESCRIBE_STYLE
> @@ -528,7 +528,7 @@ __git_ps1 ()
> fi
>
> local conflict="" # state indicator for unresolved conflicts
> - if [[ "${GIT_PS1_SHOWCONFLICTSTATE}" == "yes" ]] &&
> + if [ -n "${GIT_PS1_SHOWCONFLICTSTATE-}" ] &&
> [[ $(git ls-files --unmerged 2>/dev/null) ]]; then
> conflict="|CONFLICT"
> fi
> diff --git a/t/t9903-bash-prompt.sh b/t/t9903-bash-prompt.sh
> index d667dda654..6479a0d898 100755
> --- a/t/t9903-bash-prompt.sh
> +++ b/t/t9903-bash-prompt.sh
> @@ -769,7 +769,7 @@ test_expect_success 'prompt - conflict indicator' '
> test_when_finished "git reset --hard HEAD~" &&
> test_must_fail git stash apply &&
> (
> - GIT_PS1_SHOWCONFLICTSTATE="yes" &&
> + GIT_PS1_SHOWCONFLICTSTATE=y &&
> __git_ps1 >"$actual"
> ) &&
> test_cmp expected "$actual"
>
> base-commit: 3bd955d26919e149552f34aacf8a4e6368c26cec
> --
> 2.43.0
>
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] git-prompt: GIT_PS1_SHOWCONFLICTSTATE variable fix
2024-03-19 22:58 ` Justin Donnelly
@ 2024-03-24 17:18 ` Michiel Beijen
2024-03-24 19:01 ` Justin Donnelly
0 siblings, 1 reply; 4+ messages in thread
From: Michiel Beijen @ 2024-03-24 17:18 UTC (permalink / raw)
To: Justin Donnelly; +Cc: git
On 19-03-2024 23:58, Justin Donnelly wrote:
> Hi Michiel,
> This is my code, so I'm really glad somebody else finds it useful!
>
>
> On Tue, Mar 19, 2024 at 4:33 PM Michiel W. Beijen <mb@x14.nl> wrote:
>> There are a few environment variables that can influence the output for
>> the __git_ps1 macro in git-prompt.sh. All settings that are 'on/off'
>> types such as GIT_PS1_SHOWUNTRACKEDFILES and GIT_PS1_SHOWDIRTYSTATE
>> just take any value, and in the tests are tested with 'y', however
>> GIT_PS1_SHOWCONFLICTSTATE must be set to 'yes' otherwise it will not
>> work.
> I had actually considered using set/unset (for the same reason as you
> - consistency), but was advised to use a boolean flag.
>
> See: https://marc.info/?l=git&m=165897458021238&w=2 and
> https://marc.info/?l=git&m=165903017715652&w=2
I read the comments in that thread. While requiring the setting be set
to 'yes' explicitly might make it possible to change it to a three-way
switch in some unknown future, I think right now it is confusing and
strange that of the many settings for GIT_PS1 only this one requires the
explicit value 'yes'.
So I would still request to consider this change.
--
Michiel
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] git-prompt: GIT_PS1_SHOWCONFLICTSTATE variable fix
2024-03-24 17:18 ` Michiel Beijen
@ 2024-03-24 19:01 ` Justin Donnelly
0 siblings, 0 replies; 4+ messages in thread
From: Justin Donnelly @ 2024-03-24 19:01 UTC (permalink / raw)
To: Michiel Beijen; +Cc: git
On Sun, Mar 24, 2024 at 1:18 PM Michiel Beijen <mb@x14.nl> wrote:
>
> On 19-03-2024 23:58, Justin Donnelly wrote:
>
> > Hi Michiel,
> > This is my code, so I'm really glad somebody else finds it useful!
> >
> >
> > On Tue, Mar 19, 2024 at 4:33 PM Michiel W. Beijen <mb@x14.nl> wrote:
> >> There are a few environment variables that can influence the output for
> >> the __git_ps1 macro in git-prompt.sh. All settings that are 'on/off'
> >> types such as GIT_PS1_SHOWUNTRACKEDFILES and GIT_PS1_SHOWDIRTYSTATE
> >> just take any value, and in the tests are tested with 'y', however
> >> GIT_PS1_SHOWCONFLICTSTATE must be set to 'yes' otherwise it will not
> >> work.
> > I had actually considered using set/unset (for the same reason as you
> > - consistency), but was advised to use a boolean flag.
> >
> > See: https://marc.info/?l=git&m=165897458021238&w=2 and
> > https://marc.info/?l=git&m=165903017715652&w=2
>
> I read the comments in that thread. While requiring the setting be set
> to 'yes' explicitly might make it possible to change it to a three-way
> switch in some unknown future, I think right now it is confusing and
> strange that of the many settings for GIT_PS1 only this one requires the
> explicit value 'yes'.
>
> So I would still request to consider this change.
It's not clear to me who besides Junio has the authority to approve
(i.e. who you have to convince). But it isn't me. You might want to CC
a few others (maybe use `git-contacts` to determine who) and see if
anyone is interested in discussing this. Good luck!
>
> --
>
> Michiel
>
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2024-03-24 19:01 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-03-19 20:32 [PATCH] git-prompt: GIT_PS1_SHOWCONFLICTSTATE variable fix Michiel W. Beijen
2024-03-19 22:58 ` Justin Donnelly
2024-03-24 17:18 ` Michiel Beijen
2024-03-24 19:01 ` Justin Donnelly
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox