- rename `screw_ie8` to `ie8` - rename `mangle.except` to `mangle.reserved` - rename `mangle.properties.ignore_quoted` to `mangle.properties.keep_quoted` - compact `sourceMap` options - more stringent verification on input `options` - toplevel shorthands - `ie8` - `keep_fnames` - `toplevel` - `warnings` - support arrays and unquoted string values on CLI - drop `fromString` from `minify()` - `minify()` no longer handles any `fs` operations - unify order of operations for `mangle_properties()` on CLI & API - `bin/uglifyjs` used to `mangle_properties()` before even `Compressor` - `minify()` used to `mangle_properties()` after `Compressor` but before `mangle_names()` - both will now do `Compressor`, `mangle_names()` then `mangle_properties()` - `options.parse` / `--parse` for parser options beyond `bare_returns` - add `mangle.properties.builtins` to disable built-in reserved list - disable with `--mangle-props builtins` on CLI - `warnings` now off by default - add `--warn` and `--verbose` on CLI - drop `--enclose` - drop `--export-all` - drop `--reserved-file` - use `--mangle reserved` instead - drop `--reserve-domprops` - enabled by default, disable with `--mangle-props domprops` - drop `--prefix` - use `--source-map base` instead - drop `--lint` - remove `bin/extract-props.js` - limit exposure of internal APIs - update documentations closes #96 closes #102 closes #136 closes #166 closes #243 closes #254 closes #261 closes #311 closes #700 closes #748 closes #912 closes #1072 closes #1366 fixes #101 fixes #123 fixes #124 fixes #263 fixes #379 fixes #419 fixes #423 fixes #461 fixes #465 fixes #576 fixes #737 fixes #772 fixes #958 fixes #1036 fixes #1142 fixes #1175 fixes #1220 fixes #1223 fixes #1280 fixes #1359 fixes #1368
348 lines
6.7 KiB
JavaScript
348 lines
6.7 KiB
JavaScript
mangle_catch: {
|
|
options = {
|
|
ie8: false,
|
|
toplevel: false,
|
|
}
|
|
mangle = {
|
|
ie8: false,
|
|
toplevel: false,
|
|
}
|
|
input: {
|
|
var a = "FAIL";
|
|
try {
|
|
throw 1;
|
|
} catch (args) {
|
|
a = "PASS";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'var a="FAIL";try{throw 1}catch(o){a="PASS"}console.log(a);'
|
|
expect_stdout: "PASS"
|
|
}
|
|
|
|
mangle_catch_ie8: {
|
|
options = {
|
|
ie8: true,
|
|
toplevel: false,
|
|
}
|
|
mangle = {
|
|
ie8: true,
|
|
toplevel: false,
|
|
}
|
|
input: {
|
|
var a = "FAIL";
|
|
try {
|
|
throw 1;
|
|
} catch (args) {
|
|
a = "PASS";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'var a="FAIL";try{throw 1}catch(args){a="PASS"}console.log(a);'
|
|
expect_stdout: "PASS"
|
|
}
|
|
|
|
mangle_catch_var: {
|
|
options = {
|
|
ie8: false,
|
|
toplevel: false,
|
|
}
|
|
mangle = {
|
|
ie8: false,
|
|
toplevel: false,
|
|
}
|
|
input: {
|
|
var a = "FAIL";
|
|
try {
|
|
throw 1;
|
|
} catch (args) {
|
|
var a = "PASS";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'var a="FAIL";try{throw 1}catch(o){var a="PASS"}console.log(a);'
|
|
expect_stdout: "PASS"
|
|
}
|
|
|
|
mangle_catch_var_ie8: {
|
|
options = {
|
|
ie8: true,
|
|
toplevel: false,
|
|
}
|
|
mangle = {
|
|
ie8: true,
|
|
toplevel: false,
|
|
}
|
|
input: {
|
|
var a = "FAIL";
|
|
try {
|
|
throw 1;
|
|
} catch (args) {
|
|
var a = "PASS";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'var a="FAIL";try{throw 1}catch(args){var a="PASS"}console.log(a);'
|
|
expect_stdout: "PASS"
|
|
}
|
|
|
|
mangle_catch_toplevel: {
|
|
options = {
|
|
ie8: false,
|
|
toplevel: true,
|
|
}
|
|
mangle = {
|
|
ie8: false,
|
|
toplevel: true,
|
|
}
|
|
input: {
|
|
var a = "FAIL";
|
|
try {
|
|
throw 1;
|
|
} catch (args) {
|
|
a = "PASS";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'var o="FAIL";try{throw 1}catch(c){o="PASS"}console.log(o);'
|
|
expect_stdout: "PASS"
|
|
}
|
|
|
|
mangle_catch_ie8_toplevel: {
|
|
options = {
|
|
ie8: true,
|
|
toplevel: true,
|
|
}
|
|
mangle = {
|
|
ie8: true,
|
|
toplevel: true,
|
|
}
|
|
input: {
|
|
var a = "FAIL";
|
|
try {
|
|
throw 1;
|
|
} catch (args) {
|
|
a = "PASS";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'var o="FAIL";try{throw 1}catch(c){o="PASS"}console.log(o);'
|
|
expect_stdout: "PASS"
|
|
}
|
|
|
|
mangle_catch_var_toplevel: {
|
|
options = {
|
|
ie8: false,
|
|
toplevel: true,
|
|
}
|
|
mangle = {
|
|
ie8: false,
|
|
toplevel: true,
|
|
}
|
|
input: {
|
|
var a = "FAIL";
|
|
try {
|
|
throw 1;
|
|
} catch (args) {
|
|
var a = "PASS";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'var o="FAIL";try{throw 1}catch(r){var o="PASS"}console.log(o);'
|
|
expect_stdout: "PASS"
|
|
}
|
|
|
|
mangle_catch_var_ie8_toplevel: {
|
|
options = {
|
|
ie8: true,
|
|
toplevel: true,
|
|
}
|
|
mangle = {
|
|
ie8: true,
|
|
toplevel: true,
|
|
}
|
|
input: {
|
|
var a = "FAIL";
|
|
try {
|
|
throw 1;
|
|
} catch (args) {
|
|
var a = "PASS";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'var o="FAIL";try{throw 1}catch(r){var o="PASS"}console.log(o);'
|
|
expect_stdout: "PASS"
|
|
}
|
|
|
|
mangle_catch_redef_1: {
|
|
options = {
|
|
ie8: false,
|
|
toplevel: false,
|
|
}
|
|
mangle = {
|
|
ie8: false,
|
|
toplevel: false,
|
|
}
|
|
input: {
|
|
var a = "PASS";
|
|
try {
|
|
throw "FAIL1";
|
|
} catch (a) {
|
|
var a = "FAIL2";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'var a="PASS";try{throw"FAIL1"}catch(a){var a="FAIL2"}console.log(a);'
|
|
expect_stdout: "PASS"
|
|
}
|
|
|
|
mangle_catch_redef_1_ie8: {
|
|
options = {
|
|
ie8: true,
|
|
toplevel: false,
|
|
}
|
|
mangle = {
|
|
ie8: true,
|
|
toplevel: false,
|
|
}
|
|
input: {
|
|
var a = "PASS";
|
|
try {
|
|
throw "FAIL1";
|
|
} catch (a) {
|
|
var a = "FAIL2";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'var a="PASS";try{throw"FAIL1"}catch(a){var a="FAIL2"}console.log(a);'
|
|
expect_stdout: "PASS"
|
|
}
|
|
|
|
mangle_catch_redef_1_toplevel: {
|
|
options = {
|
|
ie8: false,
|
|
toplevel: true,
|
|
}
|
|
mangle = {
|
|
ie8: false,
|
|
toplevel: true,
|
|
}
|
|
input: {
|
|
var a = "PASS";
|
|
try {
|
|
throw "FAIL1";
|
|
} catch (a) {
|
|
var a = "FAIL2";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'var o="PASS";try{throw"FAIL1"}catch(o){var o="FAIL2"}console.log(o);'
|
|
expect_stdout: "PASS"
|
|
}
|
|
|
|
mangle_catch_redef_1_ie8_toplevel: {
|
|
options = {
|
|
ie8: true,
|
|
toplevel: true,
|
|
}
|
|
mangle = {
|
|
ie8: true,
|
|
toplevel: true,
|
|
}
|
|
input: {
|
|
var a = "PASS";
|
|
try {
|
|
throw "FAIL1";
|
|
} catch (a) {
|
|
var a = "FAIL2";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'var o="PASS";try{throw"FAIL1"}catch(o){var o="FAIL2"}console.log(o);'
|
|
expect_stdout: "PASS"
|
|
}
|
|
|
|
mangle_catch_redef_2: {
|
|
options = {
|
|
ie8: false,
|
|
toplevel: false,
|
|
}
|
|
mangle = {
|
|
ie8: false,
|
|
toplevel: false,
|
|
}
|
|
input: {
|
|
try {
|
|
throw "FAIL1";
|
|
} catch (a) {
|
|
var a = "FAIL2";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'try{throw"FAIL1"}catch(a){var a="FAIL2"}console.log(a);'
|
|
expect_stdout: "undefined"
|
|
}
|
|
|
|
mangle_catch_redef_2_ie8: {
|
|
options = {
|
|
ie8: true,
|
|
toplevel: false,
|
|
}
|
|
mangle = {
|
|
ie8: true,
|
|
toplevel: false,
|
|
}
|
|
input: {
|
|
try {
|
|
throw "FAIL1";
|
|
} catch (a) {
|
|
var a = "FAIL2";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'try{throw"FAIL1"}catch(a){var a="FAIL2"}console.log(a);'
|
|
expect_stdout: "undefined"
|
|
}
|
|
|
|
mangle_catch_redef_2_toplevel: {
|
|
options = {
|
|
ie8: false,
|
|
toplevel: true,
|
|
}
|
|
mangle = {
|
|
ie8: false,
|
|
toplevel: true,
|
|
}
|
|
input: {
|
|
try {
|
|
throw "FAIL1";
|
|
} catch (a) {
|
|
var a = "FAIL2";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'try{throw"FAIL1"}catch(o){var o="FAIL2"}console.log(o);'
|
|
expect_stdout: "undefined"
|
|
}
|
|
|
|
mangle_catch_redef_2_ie8_toplevel: {
|
|
options = {
|
|
ie8: true,
|
|
toplevel: true,
|
|
}
|
|
mangle = {
|
|
ie8: true,
|
|
toplevel: true,
|
|
}
|
|
input: {
|
|
try {
|
|
throw "FAIL1";
|
|
} catch (a) {
|
|
var a = "FAIL2";
|
|
}
|
|
console.log(a);
|
|
}
|
|
expect_exact: 'try{throw"FAIL1"}catch(o){var o="FAIL2"}console.log(o);'
|
|
expect_stdout: "undefined"
|
|
}
|