diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2017-11-07 18:09:29 +0100 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2017-11-08 12:35:02 +0100 |
commit | c3797d40a1c57352192c6106cc0f435e7d9c11e8 (patch) | |
tree | ab6c18347fe168135382013a660e0725cca52452 /libbb/lineedit.c | |
parent | a5060b8364faa7c677c8950f1315c451403b0660 (diff) | |
download | busybox-w32-c3797d40a1c57352192c6106cc0f435e7d9c11e8.tar.gz busybox-w32-c3797d40a1c57352192c6106cc0f435e7d9c11e8.tar.bz2 busybox-w32-c3797d40a1c57352192c6106cc0f435e7d9c11e8.zip |
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 <vda.linux@googlemail.com>
Diffstat (limited to 'libbb/lineedit.c')
-rw-r--r-- | libbb/lineedit.c | 12 |
1 files changed, 12 insertions, 0 deletions
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) | |||
645 | 645 | ||
646 | static void add_match(char *matched) | 646 | static void add_match(char *matched) |
647 | { | 647 | { |
648 | unsigned char *p = (unsigned char*)matched; | ||
649 | while (*p) { | ||
650 | /* ESC attack fix: drop any string with control chars */ | ||
651 | if (*p < ' ' | ||
652 | || (!ENABLE_UNICODE_SUPPORT && *p >= 0x7f) | ||
653 | || (ENABLE_UNICODE_SUPPORT && *p == 0x7f) | ||
654 | ) { | ||
655 | free(matched); | ||
656 | return; | ||
657 | } | ||
658 | p++; | ||
659 | } | ||
648 | matches = xrealloc_vector(matches, 4, num_matches); | 660 | matches = xrealloc_vector(matches, 4, num_matches); |
649 | matches[num_matches] = matched; | 661 | matches[num_matches] = matched; |
650 | num_matches++; | 662 | num_matches++; |