aboutsummaryrefslogtreecommitdiff
path: root/libbb/lineedit.c
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2017-11-07 18:09:29 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2017-11-08 12:35:02 +0100
commitc3797d40a1c57352192c6106cc0f435e7d9c11e8 (patch)
treeab6c18347fe168135382013a660e0725cca52452 /libbb/lineedit.c
parenta5060b8364faa7c677c8950f1315c451403b0660 (diff)
downloadbusybox-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.c12
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
646static void add_match(char *matched) 646static 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++;