From 1d6954bd2f047ed7e6b608eaf40bf0e1c5429b67 Mon Sep 17 00:00:00 2001 From: Peter Stephenson Date: Mon, 26 Feb 2018 21:43:12 +0000 Subject: 23180: Fix expand-or-complete with ~[...]. The square brackets shouldn't be treated as wildcards. --- ChangeLog | 4 ++++ Src/Zle/zle_tricky.c | 9 +++++++++ 2 files changed, 13 insertions(+) diff --git a/ChangeLog b/ChangeLog index b2054f4f9..c6b48d14a 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,9 @@ 2018-02-26 Peter Stephenson + * 23180: Src/Zle/zle_tricky.c: Square brackets in dynamic + directory expansion shouldn't force expansion in + expand-or-complete. + * Joey Pabalinas: 42401: Src/mem.c: replace malloc with use of realloc to work around crash with gcc using -foptimize-strlen. diff --git a/Src/Zle/zle_tricky.c b/Src/Zle/zle_tricky.c index caeef7692..22c381237 100644 --- a/Src/Zle/zle_tricky.c +++ b/Src/Zle/zle_tricky.c @@ -456,6 +456,7 @@ checkparams(char *p) static int cmphaswilds(char *str) { + char *ptr; if ((*str == Inbrack || *str == Outbrack) && !str[1]) return 0; @@ -465,6 +466,14 @@ cmphaswilds(char *str) if (str[0] == '%' && str[1] ==Quest) str += 2; + /* + * In ~[foo], the square brackets are not wild cards. + * This test matches the master one in filesubstr(). + */ + if (*str == Tilde && str[1] == Inbrack && + (ptr = strchr(str+2, Outbrack))) + str = ptr + 1; + for (; *str;) { if (*str == String || *str == Qstring) { /* A parameter expression. */ -- cgit 1.4.1