@@ -318,7 +318,7 @@ merge(Compressor.prototype, {
|
|||||||
if (value instanceof AST_RegExp) return native_fns.RegExp[name] && !value.value.global;
|
if (value instanceof AST_RegExp) return native_fns.RegExp[name] && !value.value.global;
|
||||||
}
|
}
|
||||||
|
|
||||||
function is_modified(compressor, tw, node, value, level, immutable) {
|
function is_modified(compressor, tw, node, value, level, immutable, recursive) {
|
||||||
var parent = tw.parent(level);
|
var parent = tw.parent(level);
|
||||||
if (compressor.option("unsafe") && parent instanceof AST_Dot && is_read_only_fn(value, parent.property)) {
|
if (compressor.option("unsafe") && parent instanceof AST_Dot && is_read_only_fn(value, parent.property)) {
|
||||||
return;
|
return;
|
||||||
@@ -342,7 +342,7 @@ merge(Compressor.prototype, {
|
|||||||
}
|
}
|
||||||
if (parent instanceof AST_PropAccess && parent.expression === node) {
|
if (parent instanceof AST_PropAccess && parent.expression === node) {
|
||||||
var prop = read_property(value, parent);
|
var prop = read_property(value, parent);
|
||||||
return !immutable && is_modified(compressor, tw, parent, prop, level + 1);
|
return (!immutable || recursive) && is_modified(compressor, tw, parent, prop, level + 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -759,7 +759,8 @@ merge(Compressor.prototype, {
|
|||||||
d.fixed = false;
|
d.fixed = false;
|
||||||
} else if (d.fixed) {
|
} else if (d.fixed) {
|
||||||
value = this.fixed_value();
|
value = this.fixed_value();
|
||||||
if (recursive_ref(tw, d)) {
|
var recursive = recursive_ref(tw, d);
|
||||||
|
if (recursive) {
|
||||||
d.recursive_refs++;
|
d.recursive_refs++;
|
||||||
} else if (value && ref_once(tw, compressor, d)) {
|
} else if (value && ref_once(tw, compressor, d)) {
|
||||||
d.single_use = value instanceof AST_Lambda && !value.pinned()
|
d.single_use = value instanceof AST_Lambda && !value.pinned()
|
||||||
@@ -767,7 +768,7 @@ merge(Compressor.prototype, {
|
|||||||
} else {
|
} else {
|
||||||
d.single_use = false;
|
d.single_use = false;
|
||||||
}
|
}
|
||||||
if (is_modified(compressor, tw, this, value, 0, is_immutable(value))) {
|
if (is_modified(compressor, tw, this, value, 0, is_immutable(value), recursive)) {
|
||||||
if (d.single_use) {
|
if (d.single_use) {
|
||||||
d.single_use = "m";
|
d.single_use = "m";
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -6510,17 +6510,17 @@ issue_3240_3: {
|
|||||||
}
|
}
|
||||||
expect: {
|
expect: {
|
||||||
(function() {
|
(function() {
|
||||||
(function f(b) {
|
f();
|
||||||
|
function f(b) {
|
||||||
if (!f.a) f.a = 0;
|
if (!f.a) f.a = 0;
|
||||||
console.log(f.a.toString());
|
console.log(f.a.toString());
|
||||||
var g = function() {
|
(function() {
|
||||||
(b ? function() {} : function() {
|
(b ? function() {} : function() {
|
||||||
f.a++;
|
f.a++;
|
||||||
f(1);
|
f(1);
|
||||||
})();
|
})();
|
||||||
};
|
})();
|
||||||
g();
|
}
|
||||||
})();
|
|
||||||
})();
|
})();
|
||||||
}
|
}
|
||||||
expect_stdout: [
|
expect_stdout: [
|
||||||
@@ -6554,7 +6554,8 @@ issue_3240_4: {
|
|||||||
}
|
}
|
||||||
expect: {
|
expect: {
|
||||||
(function() {
|
(function() {
|
||||||
(function f(b) {
|
f();
|
||||||
|
function f(b) {
|
||||||
if (!f.a) f.a = 0;
|
if (!f.a) f.a = 0;
|
||||||
console.log(f.a.toString());
|
console.log(f.a.toString());
|
||||||
(function() {
|
(function() {
|
||||||
@@ -6563,7 +6564,7 @@ issue_3240_4: {
|
|||||||
f(1);
|
f(1);
|
||||||
})();
|
})();
|
||||||
})();
|
})();
|
||||||
})();
|
}
|
||||||
})();
|
})();
|
||||||
}
|
}
|
||||||
expect_stdout: [
|
expect_stdout: [
|
||||||
@@ -6872,3 +6873,42 @@ issue_3666: {
|
|||||||
}
|
}
|
||||||
expect_stdout: "PASS PASS"
|
expect_stdout: "PASS PASS"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
issue_3774: {
|
||||||
|
options = {
|
||||||
|
reduce_funcs: true,
|
||||||
|
reduce_vars: true,
|
||||||
|
unused: true,
|
||||||
|
}
|
||||||
|
input: {
|
||||||
|
var f = function() {
|
||||||
|
function g() {
|
||||||
|
if (!g.p) {
|
||||||
|
g.p = 1;
|
||||||
|
console.log("PASS");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return function() {
|
||||||
|
g();
|
||||||
|
};
|
||||||
|
}();
|
||||||
|
f();
|
||||||
|
f();
|
||||||
|
}
|
||||||
|
expect: {
|
||||||
|
var f = function() {
|
||||||
|
function g() {
|
||||||
|
if (!g.p) {
|
||||||
|
g.p = 1;
|
||||||
|
console.log("PASS");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return function() {
|
||||||
|
g();
|
||||||
|
};
|
||||||
|
}();
|
||||||
|
f();
|
||||||
|
f();
|
||||||
|
}
|
||||||
|
expect_stdout: "PASS"
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user