From c05a2d20937b2fee0b54adcbdc76d134a8d3f7a9 Mon Sep 17 00:00:00 2001 From: Sven Wischnowsky Date: Mon, 2 Apr 2001 09:05:47 +0000 Subject: make `_arguments -S' still complete long options after `--'; fix for cursor positioning with partial word match specs (13868) --- ChangeLog | 6 ++++++ Src/Zle/compmatch.c | 3 ++- Src/Zle/computil.c | 2 +- 3 files changed, 9 insertions(+), 2 deletions(-) diff --git a/ChangeLog b/ChangeLog index 8751aec83..7ed226bc8 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2001-04-02 Sven Wischnowsky + + * 13868: Src/Zle/compmatch.c, Src/Zle/computil.c: make + `_arguments -S' still complete long options after `--'; + fix for cursor positioning with partial word match specs + 2001-04-02 Clint Adams * 13866: Completion/Debian/_apt: complete a release diff --git a/Src/Zle/compmatch.c b/Src/Zle/compmatch.c index e9c6721ba..fc1e6fb54 100644 --- a/Src/Zle/compmatch.c +++ b/Src/Zle/compmatch.c @@ -2076,7 +2076,8 @@ join_clines(Cline o, Cline n) if ((diff = sub_join(o, n, tn, 0))) { o->flags = (o->flags & ~CLF_MISS) | of; - if (po) { + if (po && po->prefix && + cmp_anchors(o, po, 0)) { po->flags |= CLF_MISS; po->max += diff; } diff --git a/Src/Zle/computil.c b/Src/Zle/computil.c index 063ad4c2f..90714f5fe 100644 --- a/Src/Zle/computil.c +++ b/Src/Zle/computil.c @@ -1316,7 +1316,7 @@ ca_parse_line(Cadef d, int multi, int first) doff = state.singles = arglast = 0; if (ca_inactive(d, argxor, cur, 0) || - ((d->flags & CDF_SEP) && !strcmp(line, "--"))) { + ((d->flags & CDF_SEP) && cur != compcurrent && !strcmp(line, "--"))) { if (ca_inactive(d, NULL, cur, 1)) return 1; continue; -- cgit 1.4.1