hush: fix a backslash-removal bug in case
authorDenys Vlasenko <vda.linux@googlemail.com>
Mon, 2 Apr 2018 15:25:18 +0000 (17:25 +0200)
committerDenys Vlasenko <vda.linux@googlemail.com>
Mon, 2 Apr 2018 15:25:18 +0000 (17:25 +0200)
function                                             old     new   delta
run_list                                            1270    1053    -217

Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
shell/ash_test/ash-quoting/bkslash_case2.right [new file with mode: 0644]
shell/ash_test/ash-quoting/bkslash_case2.tests [new file with mode: 0755]
shell/hush.c
shell/hush_test/hush-quoting/bkslash_case2.right [new file with mode: 0644]
shell/hush_test/hush-quoting/bkslash_case2.tests [new file with mode: 0755]

diff --git a/shell/ash_test/ash-quoting/bkslash_case2.right b/shell/ash_test/ash-quoting/bkslash_case2.right
new file mode 100644 (file)
index 0000000..8d2038b
--- /dev/null
@@ -0,0 +1,3 @@
+ok1
+ok2
+Ok:0
diff --git a/shell/ash_test/ash-quoting/bkslash_case2.tests b/shell/ash_test/ash-quoting/bkslash_case2.tests
new file mode 100755 (executable)
index 0000000..348ddc2
--- /dev/null
@@ -0,0 +1,13 @@
+x='\abc'
+
+case "$x" in
+\\*) echo ok1;;
+*)   echo BUG1;;
+esac
+
+case $x in
+\\*) echo ok2;;
+*)   echo BUG2;;
+esac
+
+echo Ok:$?
index 1779009e07c27a198d3e6dc935ae9cbe4f6c7611..867a921ec54708e66f3f86516b96a10698f39019 100644 (file)
@@ -6347,7 +6347,7 @@ static char *expand_string_to_string(const char *str, int do_unbackslash)
        return (char*)list;
 }
 
-#if ENABLE_HUSH_CASE
+#if 0
 static char* expand_strvec_to_string(char **argv)
 {
        char **list;
@@ -8731,8 +8731,10 @@ static int run_list(struct pipe *pi)
 #if ENABLE_HUSH_CASE
                if (rword == RES_CASE) {
                        debug_printf_exec("CASE cond_code:%d\n", cond_code);
-                       case_word = expand_strvec_to_string(pi->cmds->argv);
-                       unbackslash(case_word);
+                       case_word = expand_string_to_string(pi->cmds->argv[0], 1);
+                       debug_printf_exec("CASE word1:'%s'\n", case_word);
+                       //unbackslash(case_word);
+                       //debug_printf_exec("CASE word2:'%s'\n", case_word);
                        continue;
                }
                if (rword == RES_MATCH) {
diff --git a/shell/hush_test/hush-quoting/bkslash_case2.right b/shell/hush_test/hush-quoting/bkslash_case2.right
new file mode 100644 (file)
index 0000000..8d2038b
--- /dev/null
@@ -0,0 +1,3 @@
+ok1
+ok2
+Ok:0
diff --git a/shell/hush_test/hush-quoting/bkslash_case2.tests b/shell/hush_test/hush-quoting/bkslash_case2.tests
new file mode 100755 (executable)
index 0000000..348ddc2
--- /dev/null
@@ -0,0 +1,13 @@
+x='\abc'
+
+case "$x" in
+\\*) echo ok1;;
+*)   echo BUG1;;
+esac
+
+case $x in
+\\*) echo ok2;;
+*)   echo BUG2;;
+esac
+
+echo Ok:$?