On Fri, Nov 16, 2012 at 10:22 PM, SZEDER Gábor <szeder@xxxxxxxxxx> wrote: > On Fri, Nov 16, 2012 at 10:03:41PM +0100, Felipe Contreras wrote: >> > As I understand the main issues with using the completion script with >> > zsh are the various little incompatibilities between the two shells >> > and bugs in zsh's emulation of Bash's completion-related builtins. >> > Running the completion script under Bash and using its results in zsh >> > would solve these issues at the root. And would allow as to remove >> > some if [[ -n ${ZSH_VERSION-} ]] code. >> >> We can remove that code already, because we now have code that is >> superior than zsh's bash completion emulation: >> >> http://article.gmane.org/gmane.comp.version-control.git/208173 > > Which depends on the completion script having a wrapper function > around compgen filling COMPREPLY. No, it does not. Previous incarnations didn't have this dependency: http://article.gmane.org/gmane.comp.version-control.git/196720 I just thought it was neater this way. > However, COMPREPLY will be soon > filled by hand-rolled code to prevent expansion issues with compgen, > and there will be no such wrapper. I'm still waiting to see a resemblance of that code, but my bet would be that there will be a way to fill both COMPREPLY, and call zsh's compadd. But it's hard to figure that out without any code. Which is why I'm thinking on doing it myself. But even in that case, if push comes to shoves, this zsh wrapper can ultimately read COMPREPLY and figure things backwards, as even more previous versions did: http://article.gmane.org/gmane.comp.version-control.git/189310 >> This is the equivalent of what Marc is doing, except that zsh has no >> problems running bash's code. Note there's a difference with zsh's >> emulation bash (or rather bourne shell, or k shell), and zsh's >> emulation of bash's _completion_. The former is fine, the later is >> not. > > There are a couple of constructs supported by Bash but not by zsh, > which we usually try to avoid. Yes, and is that a big deal? Cheers. -- 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