aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Lam S.L <alexlamsl@gmail.com>2017-05-12 12:34:55 +0800
committerGitHub <noreply@github.com>2017-05-12 12:34:55 +0800
commitac73c5d4211b9ecff0f9650a032e964ef1cad585 (patch)
tree6c32e708e21369c61e3307686bb9d4e99aa03637
parent547f41beba43350970fdbe6a5a3793cb5b607847 (diff)
downloadtracifyjs-ac73c5d4211b9ecff0f9650a032e964ef1cad585.tar.gz
tracifyjs-ac73c5d4211b9ecff0f9650a032e964ef1cad585.zip
avoid `arguments` and `eval` in `reduce_vars` (#1924)
fixes #1922
-rw-r--r--lib/compress.js16
-rw-r--r--test/compress/reduce_vars.js57
2 files changed, 63 insertions, 10 deletions
diff --git a/lib/compress.js b/lib/compress.js
index aff5c643..1ded032b 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -354,10 +354,14 @@ merge(Compressor.prototype, {
// So existing transformation rules can work on them.
node.argnames.forEach(function(arg, i) {
var d = arg.definition();
- d.fixed = function() {
- return iife.args[i] || make_node(AST_Undefined, iife);
- };
- mark(d, true);
+ if (!node.uses_arguments && d.fixed === undefined) {
+ d.fixed = function() {
+ return iife.args[i] || make_node(AST_Undefined, iife);
+ };
+ mark(d, true);
+ } else {
+ d.fixed = false;
+ }
});
}
descend();
@@ -491,7 +495,9 @@ merge(Compressor.prototype, {
function reset_def(def) {
def.escaped = false;
- if (!def.global || def.orig[0] instanceof AST_SymbolConst || compressor.toplevel(def)) {
+ if (def.scope.uses_eval) {
+ def.fixed = false;
+ } else if (!def.global || def.orig[0] instanceof AST_SymbolConst || compressor.toplevel(def)) {
def.fixed = undefined;
} else {
def.fixed = false;
diff --git a/test/compress/reduce_vars.js b/test/compress/reduce_vars.js
index 5a79f574..d3b3d425 100644
--- a/test/compress/reduce_vars.js
+++ b/test/compress/reduce_vars.js
@@ -41,20 +41,20 @@ reduce_vars: {
var A = 1;
(function() {
console.log(-3);
- console.log(-4);
+ console.log(A - 5);
})();
(function f1() {
var a = 2;
- console.log(-3);
+ console.log(a - 5);
eval("console.log(a);");
})();
(function f2(eval) {
var a = 2;
- console.log(-3);
+ console.log(a - 5);
eval("console.log(a);");
})(eval);
"yes";
- console.log(2);
+ console.log(A + 1);
}
expect_stdout: true
}
@@ -1749,7 +1749,10 @@ redefine_arguments_3: {
console.log(function() {
var arguments;
return typeof arguments;
- }(), "number", "undefined");
+ }(), "number", function(x) {
+ var arguments = x;
+ return typeof arguments;
+ }());
}
expect_stdout: "object number undefined"
}
@@ -2461,3 +2464,47 @@ issue_1865: {
}
expect_stdout: true
}
+
+issue_1922_1: {
+ options = {
+ evaluate: true,
+ reduce_vars: true,
+ unused: true,
+ }
+ input: {
+ console.log(function(a) {
+ arguments[0] = 2;
+ return a;
+ }(1));
+ }
+ expect: {
+ console.log(function(a) {
+ arguments[0] = 2;
+ return a;
+ }(1));
+ }
+ expect_stdout: "2"
+}
+
+issue_1922_2: {
+ options = {
+ evaluate: true,
+ reduce_vars: true,
+ unused: true,
+ }
+ input: {
+ console.log(function() {
+ var a;
+ eval("a = 1");
+ return a;
+ }(1));
+ }
+ expect: {
+ console.log(function() {
+ var a;
+ eval("a = 1");
+ return a;
+ }(1));
+ }
+ expect_stdout: "1"
+}