From: Denys Vlasenko Date: Tue, 7 Nov 2017 17:09:29 +0000 (+0100) Subject: lineedit: do not tab-complete any strings which have control characters X-Git-Tag: 1_28_0~15 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=c3797d40a1c57352192c6106cc0f435e7d9c11e8;p=oweals%2Fbusybox.git lineedit: do not tab-complete any strings which have control characters function old new delta add_match 41 68 +27 Signed-off-by: Denys Vlasenko --- diff --git a/libbb/lineedit.c b/libbb/lineedit.c index c0e35bb21..56e81404e 100644 --- a/libbb/lineedit.c +++ b/libbb/lineedit.c @@ -645,6 +645,18 @@ static void free_tab_completion_data(void) static void add_match(char *matched) { + unsigned char *p = (unsigned char*)matched; + while (*p) { + /* ESC attack fix: drop any string with control chars */ + if (*p < ' ' + || (!ENABLE_UNICODE_SUPPORT && *p >= 0x7f) + || (ENABLE_UNICODE_SUPPORT && *p == 0x7f) + ) { + free(matched); + return; + } + p++; + } matches = xrealloc_vector(matches, 4, num_matches); matches[num_matches] = matched; num_matches++;