Skip to content

Commit

Permalink
improve usability of pure_funcs (#3336)
Browse files Browse the repository at this point in the history
fixes #3325
  • Loading branch information
alexlamsl authored Mar 14, 2019
1 parent ebd82b3 commit e49297e
Show file tree
Hide file tree
Showing 2 changed files with 47 additions and 3 deletions.
12 changes: 9 additions & 3 deletions lib/compress.js
Original file line number Diff line number Diff line change
Expand Up @@ -106,10 +106,16 @@ function Compressor(options, false_by_default) {
var pure_funcs = this.options["pure_funcs"];
if (typeof pure_funcs == "function") {
this.pure_funcs = pure_funcs;
} else {
this.pure_funcs = pure_funcs ? function(node) {
} else if (typeof pure_funcs == "string") {
this.pure_funcs = function(node) {
return pure_funcs !== node.expression.print_to_string();
};
} else if (Array.isArray(pure_funcs)) {
this.pure_funcs = function(node) {
return pure_funcs.indexOf(node.expression.print_to_string()) < 0;
} : return_true;
};
} else {
this.pure_funcs = return_true;
}
var top_retain = this.options["top_retain"];
if (top_retain instanceof RegExp) {
Expand Down
38 changes: 38 additions & 0 deletions test/compress/pure_funcs.js
Original file line number Diff line number Diff line change
Expand Up @@ -642,3 +642,41 @@ issue_3065_4: {
})();
}
}

issue_3325_1: {
options = {
pure_funcs: "cb",
side_effects: true,
}
input: {
function cb() {
console.log("PASS");
}
cb();
}
expect: {
function cb() {
console.log("PASS");
}
}
}

issue_3325_2: {
options = {
pure_funcs: "xxxcbxxx",
side_effects: true,
}
input: {
function cb() {
console.log("PASS");
}
cb();
}
expect: {
function cb() {
console.log("PASS");
}
cb();
}
expect_stdout: "PASS"
}

0 comments on commit e49297e

Please sign in to comment.