summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDenys Vlasenko2018-12-25 23:45:57 +0100
committerDenys Vlasenko2018-12-25 23:45:57 +0100
commit94576d2b972b3bd136fbe8057c95690ae36ea8c9 (patch)
treecc1b99c8e3fb95448b7595fea6b141516894cf40
parentc192b0442b0b3f50d4fbb34322e07f0ff3c5aecd (diff)
downloadbusybox-94576d2b972b3bd136fbe8057c95690ae36ea8c9.zip
busybox-94576d2b972b3bd136fbe8057c95690ae36ea8c9.tar.gz
bc: fix interactive handling of comments in strings and quotes in comments
function old new delta zbc_lex_next 1965 1979 +14 Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r--miscutils/bc.c36
-rwxr-xr-xtestsuite/bc.tests16
2 files changed, 34 insertions, 18 deletions
diff --git a/miscutils/bc.c b/miscutils/bc.c
index 809b4bf..9d04dde 100644
--- a/miscutils/bc.c
+++ b/miscutils/bc.c
@@ -2910,25 +2910,29 @@ static bool bc_lex_more_input(void)
string = G.input_buffer.v + prevlen;
while (*string) {
char c = *string;
- if (string == G.input_buffer.v || string[-1] != '\\') {
- if (IS_BC)
- str ^= (c == '"');
- else {
- if (c == ']')
- str -= 1;
- else if (c == '[')
- str += 1;
+ if (!comment) {
+ if (string == G.input_buffer.v || string[-1] != '\\') {
+ if (IS_BC)
+ str ^= (c == '"');
+ else {
+ if (c == ']')
+ str -= 1;
+ else if (c == '[')
+ str += 1;
+ }
}
}
string++;
- if (c == '/' && *string == '*') {
- comment = true;
- string++;
- continue;
- }
- if (c == '*' && *string == '/') {
- comment = false;
- string++;
+ if (!str) {
+ if (c == '/' && *string == '*') {
+ comment = true;
+ string++;
+ continue;
+ }
+ if (c == '*' && *string == '/') {
+ comment = false;
+ string++;
+ }
}
}
if (str != 0 || comment) {
diff --git a/testsuite/bc.tests b/testsuite/bc.tests
index 42fe830..3fbb499 100755
--- a/testsuite/bc.tests
+++ b/testsuite/bc.tests
@@ -6,16 +6,28 @@
# testing "test name" "command" "expected result" "file input" "stdin"
-testing "bc comment 1" \
+testing "bc comment" \
"bc" \
"3\n" \
"" "1 /* comment */ + 2"
-testing "bc comment 2: /*/ is not a closed comment" \
+testing "bc /*/ is not a closed comment" \
"bc" \
"4\n" \
"" "1 /*/ + 2 */ + 3"
+# this needs interactive testing
+testing "bc comment with \"" \
+ "bc" \
+ "3\n" \
+ "" "1 /* \" */ + 2"
+
+# this needs interactive testing
+testing "bc \"string/*\" is not a comment" \
+ "bc" \
+ "string/*9\n" \
+ "" "\"string/*\";9"
+
testing "bc comment 3: unterminated #comment" \
"bc" \
"" \