aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Lam S.L <alexlamsl@gmail.com>2019-11-18 13:44:13 +0800
committerGitHub <noreply@github.com>2019-11-18 13:44:13 +0800
commit644f65feca92d03076c57a6a078dc9c35a82fadb (patch)
tree3e0eebe2689d57c72662952040b6e91ec44590f2
parent8504a4ea0eddeb759f6f762f4ee46e5dde5f8e07 (diff)
downloadtracifyjs-644f65feca92d03076c57a6a078dc9c35a82fadb.tar.gz
tracifyjs-644f65feca92d03076c57a6a078dc9c35a82fadb.zip
fix corner case in `unsafe_math` (#3594)
fixes #3593
-rw-r--r--lib/compress.js60
-rw-r--r--test/compress/numbers.js18
2 files changed, 45 insertions, 33 deletions
diff --git a/lib/compress.js b/lib/compress.js
index 45db019b..b7a73430 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -6191,38 +6191,12 @@ merge(Compressor.prototype, {
&& self.left.operator != "%"
&& PRECEDENCE[self.left.operator] == PRECEDENCE[self.operator]
&& self.left.is_number(compressor)) {
- if (self.left.left instanceof AST_Constant
- && (self.operator != "+"
- || self.left.left.is_boolean(compressor)
- || self.left.left.is_number(compressor))) {
- self = make_node(AST_Binary, self, {
- operator: self.left.operator,
- left: make_node(AST_Binary, self.left, {
- operator: self.operator,
- left: self.left.left,
- right: self.right,
- start: self.left.left.start,
- end: self.right.end
- }),
- right: self.left.right
- });
+ if (self.left.left instanceof AST_Constant) {
+ var lhs = make_binary(self.left, self.operator, self.left.left, self.right, self.left.left.start, self.right.end);
+ self = make_binary(self, self.left.operator, lhs, self.left.right);
} else if (self.left.right instanceof AST_Constant) {
- var op = align(self.left.operator, self.operator);
- if (op != "+"
- || self.left.right.is_boolean(compressor)
- || self.left.right.is_number(compressor)) {
- self = make_node(AST_Binary, self, {
- operator: self.left.operator,
- left: self.left.left,
- right: make_node(AST_Binary, self.left, {
- operator: op,
- left: self.left.right,
- right: self.right,
- start: self.left.right.start,
- end: self.right.end
- })
- });
- }
+ var rhs = make_binary(self.left, align(self.left.operator, self.operator), self.left.right, self.right, self.left.right.start, self.right.end);
+ self = make_binary(self, self.left.operator, self.left.left, rhs);
}
}
break;
@@ -6304,6 +6278,30 @@ merge(Compressor.prototype, {
}
}
+ function make_binary(orig, op, left, right, start, end) {
+ if (op == "+") {
+ if (!left.is_boolean(compressor) && !left.is_number(compressor)) {
+ left = make_node(AST_UnaryPrefix, left, {
+ operator: "+",
+ expression: left
+ });
+ }
+ if (!right.is_boolean(compressor) && !right.is_number(compressor)) {
+ right = make_node(AST_UnaryPrefix, right, {
+ operator: "+",
+ expression: right
+ });
+ }
+ }
+ return make_node(AST_Binary, orig, {
+ operator: op,
+ left: left,
+ right: right,
+ start: start,
+ end: end
+ });
+ }
+
function fuzzy_eval(node) {
if (node.truthy) return true;
if (node.falsy) return false;
diff --git a/test/compress/numbers.js b/test/compress/numbers.js
index ee20fc15..1203412a 100644
--- a/test/compress/numbers.js
+++ b/test/compress/numbers.js
@@ -870,7 +870,7 @@ issue_3547_3: {
a + "21",
a + "2" - 1,
a - 1,
- a - "2" - 1,
+ a - 3,
].forEach(function(n) {
console.log(typeof n, n);
});
@@ -904,7 +904,7 @@ issue_3547_4: {
[
"3" + a + 1,
"3" + a - 1,
- "3" - a + 1,
+ 4 - a,
2 - a,
].forEach(function(n) {
console.log(typeof n, n);
@@ -931,3 +931,17 @@ unsafe_math_rounding: {
}
expect_stdout: "false"
}
+
+issue_3593: {
+ options = {
+ evaluate: true,
+ unsafe_math: true,
+ }
+ input: {
+ console.log((0 === this) - 1 - "1");
+ }
+ expect: {
+ console.log((0 === this) - 2);
+ }
+ expect_stdout: "-2"
+}