@@ -428,7 +428,7 @@ merge(Compressor.prototype, {
|
|||||||
var parent = tw.parent(level);
|
var parent = tw.parent(level);
|
||||||
if (value && value.is_constant()) return;
|
if (value && value.is_constant()) return;
|
||||||
if (parent instanceof AST_Assign && parent.operator == "=" && node === parent.right
|
if (parent instanceof AST_Assign && parent.operator == "=" && node === parent.right
|
||||||
|| parent instanceof AST_Call && node !== parent.expression
|
|| parent instanceof AST_Call && (node !== parent.expression || parent instanceof AST_New)
|
||||||
|| parent instanceof AST_Exit && node === parent.value && node.scope !== d.scope
|
|| parent instanceof AST_Exit && node === parent.value && node.scope !== d.scope
|
||||||
|| parent instanceof AST_VarDef && node === parent.value) {
|
|| parent instanceof AST_VarDef && node === parent.value) {
|
||||||
if (depth > 1 && !(value && value.is_constant_expression(scope))) depth = 1;
|
if (depth > 1 && !(value && value.is_constant_expression(scope))) depth = 1;
|
||||||
|
|||||||
@@ -5582,3 +5582,75 @@ issue_2992: {
|
|||||||
}
|
}
|
||||||
expect_stdout: "PASS"
|
expect_stdout: "PASS"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
issue_3042_1: {
|
||||||
|
options = {
|
||||||
|
reduce_funcs: true,
|
||||||
|
reduce_vars: true,
|
||||||
|
toplevel: true,
|
||||||
|
unused: true,
|
||||||
|
}
|
||||||
|
input: {
|
||||||
|
function f() {}
|
||||||
|
var a = [ 1, 2 ].map(function() {
|
||||||
|
return new f();
|
||||||
|
});
|
||||||
|
console.log(a[0].constructor === a[1].constructor);
|
||||||
|
}
|
||||||
|
expect: {
|
||||||
|
function f() {}
|
||||||
|
var a = [ 1, 2 ].map(function() {
|
||||||
|
return new f();
|
||||||
|
});
|
||||||
|
console.log(a[0].constructor === a[1].constructor);
|
||||||
|
}
|
||||||
|
expect_stdout: "true"
|
||||||
|
}
|
||||||
|
|
||||||
|
issue_3042_2: {
|
||||||
|
options = {
|
||||||
|
reduce_funcs: true,
|
||||||
|
reduce_vars: true,
|
||||||
|
toplevel: true,
|
||||||
|
unused: true,
|
||||||
|
}
|
||||||
|
input: {
|
||||||
|
function Foo() {
|
||||||
|
this.isFoo = function(o) {
|
||||||
|
return o instanceof Foo;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
function FooCollection() {
|
||||||
|
this.foos = [1, 1].map(function() {
|
||||||
|
return new Foo();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
var fooCollection = new FooCollection();
|
||||||
|
console.log(fooCollection.foos[0].isFoo(fooCollection.foos[0]));
|
||||||
|
console.log(fooCollection.foos[0].isFoo(fooCollection.foos[1]));
|
||||||
|
console.log(fooCollection.foos[1].isFoo(fooCollection.foos[0]));
|
||||||
|
console.log(fooCollection.foos[1].isFoo(fooCollection.foos[1]));
|
||||||
|
}
|
||||||
|
expect: {
|
||||||
|
function Foo() {
|
||||||
|
this.isFoo = function(o) {
|
||||||
|
return o instanceof Foo;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
var fooCollection = new function() {
|
||||||
|
this.foos = [1, 1].map(function() {
|
||||||
|
return new Foo();
|
||||||
|
});
|
||||||
|
}();
|
||||||
|
console.log(fooCollection.foos[0].isFoo(fooCollection.foos[0]));
|
||||||
|
console.log(fooCollection.foos[0].isFoo(fooCollection.foos[1]));
|
||||||
|
console.log(fooCollection.foos[1].isFoo(fooCollection.foos[0]));
|
||||||
|
console.log(fooCollection.foos[1].isFoo(fooCollection.foos[1]));
|
||||||
|
}
|
||||||
|
expect_stdout: [
|
||||||
|
"true",
|
||||||
|
"true",
|
||||||
|
"true",
|
||||||
|
"true",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user