aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Lam S.L <alexlamsl@gmail.com>2017-06-17 14:32:37 +0800
committerGitHub <noreply@github.com>2017-06-17 14:32:37 +0800
commit0a0f4f55912fed32b09c93a2a1efa19edce24e28 (patch)
tree5b8cac3c39a92a66c12232f87932b6b20b2ba51b
parent931daa85bf72f6799dca83c1e1ac9b339d85b70b (diff)
downloadtracifyjs-0a0f4f55912fed32b09c93a2a1efa19edce24e28.tar.gz
tracifyjs-0a0f4f55912fed32b09c93a2a1efa19edce24e28.zip
make defensive copies when `inline` (#2116)
fixes #2114
-rw-r--r--lib/compress.js7
-rw-r--r--test/compress/functions.js67
2 files changed, 72 insertions, 2 deletions
diff --git a/lib/compress.js b/lib/compress.js
index 309b87ce..aa7affc4 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -3177,16 +3177,19 @@ merge(Compressor.prototype, {
if (exp.argnames.length > 0) {
fn.body.push(make_node(AST_Var, self, {
definitions: exp.argnames.map(function(sym, i) {
+ var arg = self.args[i];
return make_node(AST_VarDef, sym, {
name: sym,
- value: self.args[i] || make_node(AST_Undefined, self)
+ value: arg ? arg.clone(true) : make_node(AST_Undefined, self)
});
})
}));
}
if (self.args.length > exp.argnames.length) {
fn.body.push(make_node(AST_SimpleStatement, self, {
- body: make_sequence(self, self.args.slice(exp.argnames.length))
+ body: make_sequence(self, self.args.slice(exp.argnames.length).map(function(node) {
+ return node.clone(true);
+ }))
}));
}
fn.body.push(make_node(AST_Return, self, {
diff --git a/test/compress/functions.js b/test/compress/functions.js
index dc430d18..d2640bb9 100644
--- a/test/compress/functions.js
+++ b/test/compress/functions.js
@@ -443,3 +443,70 @@ issue_2107: {
}
expect_stdout: "5"
}
+
+issue_2114_1: {
+ options = {
+ collapse_vars: true,
+ if_return: true,
+ inline: true,
+ keep_fargs: false,
+ side_effects: true,
+ unused: true,
+ }
+ input: {
+ var c = 0;
+ !function(a) {
+ a = 0;
+ }([ {
+ 0: c = c + 1,
+ length: c = 1 + c
+ }, typeof void function a() {
+ var b = function f1(a) {
+ }(b && (b.b += (c = c + 1, 0)));
+ }() ]);
+ console.log(c);
+ }
+ expect: {
+ var c = 0;
+ !function() {
+ 0;
+ }((c += 1, c = 1 + c, function() {
+ var b = void (b && (b.b += (c += 1, 0)));
+ }()));
+ console.log(c);
+ }
+ expect_stdout: "2"
+}
+
+issue_2114_2: {
+ options = {
+ collapse_vars: true,
+ if_return: true,
+ inline: true,
+ keep_fargs: false,
+ passes: 2,
+ side_effects: true,
+ unused: true,
+ }
+ input: {
+ var c = 0;
+ !function(a) {
+ a = 0;
+ }([ {
+ 0: c = c + 1,
+ length: c = 1 + c
+ }, typeof void function a() {
+ var b = function f1(a) {
+ }(b && (b.b += (c = c + 1, 0)));
+ }() ]);
+ console.log(c);
+ }
+ expect: {
+ var c = 0;
+ c = 1 + (c += 1), function() {
+ var b = void (b && (b.b += (c += 1, 0)));
+ }();
+ console.log(c);
+ }
+ expect_stdout: "2"
+}