* [PATCH] git-prompt: changes == to = for zsh's sake
@ 2020-07-20 23:17 David J. Malan via GitGitGadget
2020-07-20 23:58 ` Junio C Hamano
` (2 more replies)
0 siblings, 3 replies; 6+ messages in thread
From: David J. Malan via GitGitGadget @ 2020-07-20 23:17 UTC (permalink / raw)
To: git; +Cc: Elijah Newren, Junio C Hamano, David J. Malan, David J. Malan
From: "David J. Malan" <malan@harvard.edu>
When using git-prompt.sh with Zsh, __git_ps1 currently errs
when inside a repo with:
__git_ps1:96: = not found
This commit changes `==` to `=` for both Bash and Zsh.
Signed-off-by: David J. Malan <malan@harvard.edu>
---
Changes == to = for zsh's sake in git-prompt.sh
Upon installing git-prompt.sh
[https://github.com/gitgitgadget/git/blob/master/contrib/completion/git-prompt.sh]
on macOS Catalina, I noticed that
https://github.com/gitgitgadget/git/commit/afda36dbf3b4f5a489ab44c00d5210c1fa894a40
seems to have introduced an issue for Zsh whereby __git_ps1 errs with
__git_ps1:96: = not found
when inside a repo. Changing == to = would seem to address for both Bash
and Zsh.
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-679%2Fdmalan%2Fpatch-1-v1
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-679/dmalan/patch-1-v1
Pull-Request: https://github.com/gitgitgadget/git/pull/679
contrib/completion/git-prompt.sh | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/contrib/completion/git-prompt.sh b/contrib/completion/git-prompt.sh
index e6cd5464e5..16260bab73 100644
--- a/contrib/completion/git-prompt.sh
+++ b/contrib/completion/git-prompt.sh
@@ -433,7 +433,7 @@ __git_ps1 ()
local sparse=""
if [ -z "${GIT_PS1_COMPRESSSPARSESTATE}" ] &&
[ -z "${GIT_PS1_OMITSPARSESTATE}" ] &&
- [ "$(git config --bool core.sparseCheckout)" == "true" ]; then
+ [ "$(git config --bool core.sparseCheckout)" = "true" ]; then
sparse="|SPARSE"
fi
@@ -542,7 +542,7 @@ __git_ps1 ()
fi
if [ -n "${GIT_PS1_COMPRESSSPARSESTATE}" ] &&
- [ "$(git config --bool core.sparseCheckout)" == "true" ]; then
+ [ "$(git config --bool core.sparseCheckout)" = "true" ]; then
h="?"
fi
base-commit: ae46588be0cd730430dded4491246dfb4eac5557
--
gitgitgadget
^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH] git-prompt: changes == to = for zsh's sake
2020-07-20 23:17 [PATCH] git-prompt: changes == to = for zsh's sake David J. Malan via GitGitGadget
@ 2020-07-20 23:58 ` Junio C Hamano
2020-07-21 0:40 ` Elijah Newren
2020-07-21 0:15 ` [PATCH v2] git-prompt: change " David J. Malan via GitGitGadget
2020-07-21 0:23 ` [PATCH] git-prompt: changes " Aaron Schrab
2 siblings, 1 reply; 6+ messages in thread
From: Junio C Hamano @ 2020-07-20 23:58 UTC (permalink / raw)
To: David J. Malan via GitGitGadget; +Cc: git, Elijah Newren, David J. Malan
"David J. Malan via GitGitGadget" <gitgitgadget@gmail.com> writes:
> From: "David J. Malan" <malan@harvard.edu>
> Subject: Re: [PATCH] git-prompt: changes == to = for zsh's sake
s/changes/change/
> When using git-prompt.sh with Zsh, __git_ps1 currently errs
> when inside a repo with:
>
> __git_ps1:96: = not found
OK.
> This commit changes `==` to `=` for both Bash and Zsh.
We prefer to see "why" instead of "what", as the latter can easily
be read from the patch text.
Avoid using non-portable "==" that is only understood by bash
and not zsh to "="; that way the prompt script becomes usable
with zsh again.
or something like that.
Elijah, I think this is a minor regression in this cycle, and the
fix is obvious enough that it deserves to be in the upcoming
release. Agreed?
Thank you, David, for a fix.
> Signed-off-by: David J. Malan <malan@harvard.edu>
> ---
> Changes == to = for zsh's sake in git-prompt.sh
>
> Upon installing git-prompt.sh
> [https://github.com/gitgitgadget/git/blob/master/contrib/completion/git-prompt.sh]
> on macOS Catalina, I noticed that
> https://github.com/gitgitgadget/git/commit/afda36dbf3b4f5a489ab44c00d5210c1fa894a40
> seems to have introduced an issue for Zsh whereby __git_ps1 errs with
>
> __git_ps1:96: = not found
>
> when inside a repo. Changing == to = would seem to address for both Bash
> and Zsh.
>
> Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-679%2Fdmalan%2Fpatch-1-v1
> Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-679/dmalan/patch-1-v1
> Pull-Request: https://github.com/gitgitgadget/git/pull/679
>
> contrib/completion/git-prompt.sh | 4 ++--
> 1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/contrib/completion/git-prompt.sh b/contrib/completion/git-prompt.sh
> index e6cd5464e5..16260bab73 100644
> --- a/contrib/completion/git-prompt.sh
> +++ b/contrib/completion/git-prompt.sh
> @@ -433,7 +433,7 @@ __git_ps1 ()
> local sparse=""
> if [ -z "${GIT_PS1_COMPRESSSPARSESTATE}" ] &&
> [ -z "${GIT_PS1_OMITSPARSESTATE}" ] &&
> - [ "$(git config --bool core.sparseCheckout)" == "true" ]; then
> + [ "$(git config --bool core.sparseCheckout)" = "true" ]; then
> sparse="|SPARSE"
> fi
>
> @@ -542,7 +542,7 @@ __git_ps1 ()
> fi
>
> if [ -n "${GIT_PS1_COMPRESSSPARSESTATE}" ] &&
> - [ "$(git config --bool core.sparseCheckout)" == "true" ]; then
> + [ "$(git config --bool core.sparseCheckout)" = "true" ]; then
> h="?"
> fi
>
>
> base-commit: ae46588be0cd730430dded4491246dfb4eac5557
^ permalink raw reply [flat|nested] 6+ messages in thread
* [PATCH v2] git-prompt: change == to = for zsh's sake
2020-07-20 23:17 [PATCH] git-prompt: changes == to = for zsh's sake David J. Malan via GitGitGadget
2020-07-20 23:58 ` Junio C Hamano
@ 2020-07-21 0:15 ` David J. Malan via GitGitGadget
2020-07-21 0:23 ` [PATCH] git-prompt: changes " Aaron Schrab
2 siblings, 0 replies; 6+ messages in thread
From: David J. Malan via GitGitGadget @ 2020-07-21 0:15 UTC (permalink / raw)
To: git; +Cc: Elijah Newren, Junio C Hamano, David J. Malan, David J. Malan
From: "David J. Malan" <malan@harvard.edu>
When using git-prompt.sh with zsh, __git_ps1 currently errs
when inside a repo with:
__git_ps1:96: = not found
Avoid using non-portable "==" that is only understood by bash
and not zsh. Change to "=" so that the prompt script becomes
usable with zsh again.
Signed-off-by: David J. Malan <malan@harvard.edu>
---
Change == to = for zsh's sake in git-prompt.sh
Upon installing git-prompt.sh
[https://github.com/gitgitgadget/git/blob/master/contrib/completion/git-prompt.sh]
on macOS Catalina, I noticed that
https://github.com/gitgitgadget/git/commit/afda36dbf3b4f5a489ab44c00d5210c1fa894a40
seems to have introduced an issue for Zsh whereby __git_ps1 errs with
__git_ps1:96: = not found
when inside a repo. Changing == to = would seem to address for both Bash
and Zsh.
Changes since v1:
* Commit message rewritten to use imperative mood.
* Commit message rewritten to elaborate on reason for change.
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-679%2Fdmalan%2Fpatch-1-v2
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-679/dmalan/patch-1-v2
Pull-Request: https://github.com/gitgitgadget/git/pull/679
Range-diff vs v1:
1: 95be513ed1 ! 1: f5402f1512 git-prompt: changes == to = for zsh's sake
@@ Metadata
Author: David J. Malan <malan@harvard.edu>
## Commit message ##
- git-prompt: changes == to = for zsh's sake
+ git-prompt: change == to = for zsh's sake
- When using git-prompt.sh with Zsh, __git_ps1 currently errs
+ When using git-prompt.sh with zsh, __git_ps1 currently errs
when inside a repo with:
__git_ps1:96: = not found
- This commit changes `==` to `=` for both Bash and Zsh.
+ Avoid using non-portable "==" that is only understood by bash
+ and not zsh. Change to "=" so that the prompt script becomes
+ usable with zsh again.
Signed-off-by: David J. Malan <malan@harvard.edu>
contrib/completion/git-prompt.sh | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/contrib/completion/git-prompt.sh b/contrib/completion/git-prompt.sh
index e6cd5464e5..16260bab73 100644
--- a/contrib/completion/git-prompt.sh
+++ b/contrib/completion/git-prompt.sh
@@ -433,7 +433,7 @@ __git_ps1 ()
local sparse=""
if [ -z "${GIT_PS1_COMPRESSSPARSESTATE}" ] &&
[ -z "${GIT_PS1_OMITSPARSESTATE}" ] &&
- [ "$(git config --bool core.sparseCheckout)" == "true" ]; then
+ [ "$(git config --bool core.sparseCheckout)" = "true" ]; then
sparse="|SPARSE"
fi
@@ -542,7 +542,7 @@ __git_ps1 ()
fi
if [ -n "${GIT_PS1_COMPRESSSPARSESTATE}" ] &&
- [ "$(git config --bool core.sparseCheckout)" == "true" ]; then
+ [ "$(git config --bool core.sparseCheckout)" = "true" ]; then
h="?"
fi
base-commit: ae46588be0cd730430dded4491246dfb4eac5557
--
gitgitgadget
^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH] git-prompt: changes == to = for zsh's sake
2020-07-20 23:17 [PATCH] git-prompt: changes == to = for zsh's sake David J. Malan via GitGitGadget
2020-07-20 23:58 ` Junio C Hamano
2020-07-21 0:15 ` [PATCH v2] git-prompt: change " David J. Malan via GitGitGadget
@ 2020-07-21 0:23 ` Aaron Schrab
2020-07-21 0:40 ` Junio C Hamano
2 siblings, 1 reply; 6+ messages in thread
From: Aaron Schrab @ 2020-07-21 0:23 UTC (permalink / raw)
To: David J. Malan via GitGitGadget
Cc: git, Elijah Newren, Junio C Hamano, David J. Malan
At 23:17 +0000 20 Jul 2020, "David J. Malan via GitGitGadget" <gitgitgadget@gmail.com> wrote:
>From: "David J. Malan" <malan@harvard.edu>
>
>When using git-prompt.sh with Zsh, __git_ps1 currently errs
>when inside a repo with:
>
>__git_ps1:96: = not found
That depends if zsh's `equals` option is set or not. If it's set (as it
is by default) you'll get that behavior. If it's unset (`setopt
no_equals`) that should behave as in bash. But, it fixing the code to
work regardless of shell options is definitely a good thing.
>This commit changes `==` to `=` for both Bash and Zsh.
An alternate fix would be to switch to using double square brackets
instead of single square brackets for the test. Since contents of double
brackets have their own parsing rules the `equals` option doesn't apply
there, and so `==` is available for checking equality same as in bash.
IMHO, this provides saner behavior in general; although it's definitely
not POSIX compliant.
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] git-prompt: changes == to = for zsh's sake
2020-07-20 23:58 ` Junio C Hamano
@ 2020-07-21 0:40 ` Elijah Newren
0 siblings, 0 replies; 6+ messages in thread
From: Elijah Newren @ 2020-07-21 0:40 UTC (permalink / raw)
To: Junio C Hamano
Cc: David J. Malan via GitGitGadget, Git Mailing List, David J. Malan
On Mon, Jul 20, 2020 at 4:58 PM Junio C Hamano <gitster@pobox.com> wrote:
>
> "David J. Malan via GitGitGadget" <gitgitgadget@gmail.com> writes:
>
> > From: "David J. Malan" <malan@harvard.edu>
> > Subject: Re: [PATCH] git-prompt: changes == to = for zsh's sake
>
> s/changes/change/
>
> > When using git-prompt.sh with Zsh, __git_ps1 currently errs
> > when inside a repo with:
> >
> > __git_ps1:96: = not found
>
> OK.
>
> > This commit changes `==` to `=` for both Bash and Zsh.
>
> We prefer to see "why" instead of "what", as the latter can easily
> be read from the patch text.
>
> Avoid using non-portable "==" that is only understood by bash
> and not zsh to "="; that way the prompt script becomes usable
> with zsh again.
>
> or something like that.
>
> Elijah, I think this is a minor regression in this cycle, and the
> fix is obvious enough that it deserves to be in the upcoming
> release. Agreed?
Yeah, it's a pretty obvious and very localized fix for a regression
from this cycle. I'd say putting it in the upcoming release makes
sense.
> Thank you, David, for a fix.
+1.
> > Signed-off-by: David J. Malan <malan@harvard.edu>
> > ---
> > Changes == to = for zsh's sake in git-prompt.sh
> >
> > Upon installing git-prompt.sh
> > [https://github.com/gitgitgadget/git/blob/master/contrib/completion/git-prompt.sh]
> > on macOS Catalina, I noticed that
> > https://github.com/gitgitgadget/git/commit/afda36dbf3b4f5a489ab44c00d5210c1fa894a40
> > seems to have introduced an issue for Zsh whereby __git_ps1 errs with
> >
> > __git_ps1:96: = not found
> >
> > when inside a repo. Changing == to = would seem to address for both Bash
> > and Zsh.
> >
> > Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-679%2Fdmalan%2Fpatch-1-v1
> > Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-679/dmalan/patch-1-v1
> > Pull-Request: https://github.com/gitgitgadget/git/pull/679
> >
> > contrib/completion/git-prompt.sh | 4 ++--
> > 1 file changed, 2 insertions(+), 2 deletions(-)
> >
> > diff --git a/contrib/completion/git-prompt.sh b/contrib/completion/git-prompt.sh
> > index e6cd5464e5..16260bab73 100644
> > --- a/contrib/completion/git-prompt.sh
> > +++ b/contrib/completion/git-prompt.sh
> > @@ -433,7 +433,7 @@ __git_ps1 ()
> > local sparse=""
> > if [ -z "${GIT_PS1_COMPRESSSPARSESTATE}" ] &&
> > [ -z "${GIT_PS1_OMITSPARSESTATE}" ] &&
> > - [ "$(git config --bool core.sparseCheckout)" == "true" ]; then
> > + [ "$(git config --bool core.sparseCheckout)" = "true" ]; then
> > sparse="|SPARSE"
> > fi
> >
> > @@ -542,7 +542,7 @@ __git_ps1 ()
> > fi
> >
> > if [ -n "${GIT_PS1_COMPRESSSPARSESTATE}" ] &&
> > - [ "$(git config --bool core.sparseCheckout)" == "true" ]; then
> > + [ "$(git config --bool core.sparseCheckout)" = "true" ]; then
> > h="?"
> > fi
> >
> >
> > base-commit: ae46588be0cd730430dded4491246dfb4eac5557
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] git-prompt: changes == to = for zsh's sake
2020-07-21 0:23 ` [PATCH] git-prompt: changes " Aaron Schrab
@ 2020-07-21 0:40 ` Junio C Hamano
0 siblings, 0 replies; 6+ messages in thread
From: Junio C Hamano @ 2020-07-21 0:40 UTC (permalink / raw)
To: Aaron Schrab
Cc: David J. Malan via GitGitGadget, git, Elijah Newren, David J. Malan
Aaron Schrab <aaron@schrab.com> writes:
> An alternate fix would be to switch to using double square brackets
> instead of single square brackets for the test. Since contents of
> double brackets have their own parsing rules the `equals` option
> doesn't apply there, and so `==` is available for checking equality
> same as in bash. IMHO, this provides saner behavior in general;
> although it's definitely not POSIX compliant.
It won't be but it does not have to be POSIX compliant anyway; after
all this is prompt support for bash with support for zsh added on
the side, neither is limited to strict POSIX.
I'd say that the patch posted is good as-is.
Thanks.
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2020-07-21 0:41 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-07-20 23:17 [PATCH] git-prompt: changes == to = for zsh's sake David J. Malan via GitGitGadget
2020-07-20 23:58 ` Junio C Hamano
2020-07-21 0:40 ` Elijah Newren
2020-07-21 0:15 ` [PATCH v2] git-prompt: change " David J. Malan via GitGitGadget
2020-07-21 0:23 ` [PATCH] git-prompt: changes " Aaron Schrab
2020-07-21 0:40 ` Junio C Hamano
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).