Re: [PATCH v3 (for maint)] git-completion: fix zsh support

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

 



On Tue, May 10, 2011 at 12:13 AM, Jonathan Nieder <jrnieder@xxxxxxxxx> wrote:
> Felipe Contreras wrote:
>
>> It turns out 'words' is a special variable used by zsh completion, sort
>> of like 'COMP_WORDS' in bash.
>
> I was not aware that COMP_WORDS was special (rather than just
> prepopulated). ÂIs it?

I didn't mean to suggest it was special, only what 'words' was used
for. I'll remove that section as it doesn't really matter.

>> This was not isolated correctly in zsh's
>> bash completion, so by trying to set it as 'local' in git's completion,
>> unexpected results occur; assignations are not propagated to upper
>> levels in the call stack.
>
> Does the call stack grow up or down? ÂI suspect this means:

I'll change that to "outer levels".

> Â Â Â Âzsh's bash completion emulation layer does not sufficiently
> Â Â Â Âinsulate us from that reality. ÂIn particular, the variable
> Â Â Â Âkeeps the "special" attribute (even after a declaration "local
> Â Â Â Âwords"), so assignments within a function are undone whenever
> Â Â Â Âthe function returns.

That explains less.

> Â Â Â ÂIn particular, until 3bee6a473 (completion: don't declare
> Â Â Â Â'local words' to make zsh happy, 2011-04-28), the "words" array
> Â Â Â Âwould be cleared in _git by declaring "local words" and its new
> Â Â Â Âvalue would never be propagated from _get_comp_words_by_ref so
> Â Â Â Âit remained empty and the completion script could not tell that
> Â Â Â Âthere were existing subcommand names on the command line (so
> Â Â Â Â"git log m<TAB>" would complete subcommand names).

I don't see the point in explaining in excruciating detail all the
series of steps in which an unset variable causes problems; the
variable doesn't get set, thus one can assume there are problems. And
the problem is already explained to be that completion is completely
broken.

> Â Â Â ÂAnd even after 3bee6a473 we do not have the ability to modify
> Â Â Â Âwords. Â(... explanation of impact of the change goes here ...)
>
> I am not a great writer so that is probably more verbose than needed.
> So it might be better for me to describe the goals of a commit message:
>
> Â1) the text should be specific about what the commit fixes, so
> Â Âsomeone reading it later (e.g., after bisecting) does not come
> Â Âaround and accidentally break it

See the title: fix zsh support

> Â2) in particular, the text should be specific about the observable
> Â Âsymptoms, so it can be easier to check if a later change has
> Â Âbroken it.

>From the title: zsh completion doesn't work at all. Which is repeated again:
---
Right now zsh is completely broken...
---

If zsh completion is completely broken, chance are it has to do with
this. And I did explain the most obvious test; check if the value of
'words' doesn't get propagated to the upper layers in the call stack.

>> This is now fixed in the latest master branch of zsh[1] by simply
>> defining 'words' as hidden (typeset -h), which removes the special
>> meaning inside the emulated bash function. It probably won't be released
>> until version 4.3.12.
>>
>> In the meantime, we can workaround the issue by doing the same; defining
>> words as hidden (typeset -h) as soon as possible.
>
> It might make sense to reverse the order of these: first explain the
> fix in the context of the problem being solved, and then add a note
> mentioning that the fix will not be needed for long and that the
> method is the same as what zsh is planning to use.

That's what I did initially, but everyone doubted my solution. Now I
want to start making sure people see it's a good solution.

> Meanwhile this doesn't address the risk that functions called by the
> completion script will use $words.

It does.

> Outside the context of the commit
> message I think you've said something about that (e.g., that the zsh
> developers prefer this fix --- a reference would be nice so we could
> steal their rationale).

I did. If you don't like their commit message, talk to them.

> Maybe the best thing to say would be "that is
> a risk, but let's wait and see", to give future readers more
> confidence that that was considered but it is ok to fix it if it comes
> up?

I don't see any risk.

>> --- a/contrib/completion/git-completion.bash
>> +++ b/contrib/completion/git-completion.bash
>> @@ -2710,6 +2710,10 @@ _git ()
>> Â Â Â if [[ -n ${ZSH_VERSION-} ]]; then
>> Â Â Â Â Â Â Â emulate -L bash
>> Â Â Â Â Â Â Â setopt KSH_TYPESET
>> +
>> + Â Â Â Â Â Â # workaround zsh's bashinit's bug that leaves 'words' as a
>> + Â Â Â Â Â Â # special variable in versions < 4.3.12
>> + Â Â Â Â Â Â typeset -h words
>
> I don't think the comment clarifies much. ÂWhat is the intended
> message to the reader? ÂFor example if it is "don't remove this line
> unless you use zsh 4.3.12 or greater", I'd say something like
>
> Â Â Â Â Â Â Â Â# bashcompinit versions after 4.3.12 already hide the
> Â Â Â Â Â Â Â Â# special "words" variable already. ÂWe do it
> Â Â Â Â Â Â Â Â# again ourselves to support older zsh versions.

I think it's perfectly clear. Specially if you compare it against the
two lines above that have no explanation at all. Double standards
much?

-- 
Felipe Contreras
--
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]