diff options
-rwxr-xr-x | bin/uglifyjs | 8 | ||||
-rw-r--r-- | lib/utils.js | 6 |
2 files changed, 13 insertions, 1 deletions
diff --git a/bin/uglifyjs b/bin/uglifyjs index 4160171d..9e8573e4 100755 --- a/bin/uglifyjs +++ b/bin/uglifyjs @@ -62,6 +62,7 @@ You need to pass an argument to this option to specify the name that your module .describe("lint", "Display some scope warnings") .describe("v", "Verbose") .describe("V", "Print version number and exit.") + .describe("noerr", "Don't throw an error for unknown options in -c, -b or -m.") .alias("p", "prefix") .alias("o", "output") @@ -96,6 +97,7 @@ You need to pass an argument to this option to specify the name that your module .boolean("spidermonkey") .boolean("lint") .boolean("V") + .boolean("noerr") .wrap(80) @@ -104,6 +106,12 @@ You need to pass an argument to this option to specify the name that your module normalize(ARGS); +if (ARGS.noerr) { + UglifyJS.DefaultsError.croak = function(msg, defs) { + sys.error("WARN: " + msg); + }; +} + if (ARGS.version || ARGS.V) { var json = require("../package.json"); sys.puts(json.name + ' ' + json.version); diff --git a/lib/utils.js b/lib/utils.js index 73964a09..fa24663c 100644 --- a/lib/utils.js +++ b/lib/utils.js @@ -86,12 +86,16 @@ function DefaultsError(msg, defs) { this.defs = defs; }; +DefaultsError.croak = function(msg, defs) { + throw new DefaultsError(msg, defs); +}; + function defaults(args, defs, croak) { if (args === true) args = {}; var ret = args || {}; if (croak) for (var i in ret) if (ret.hasOwnProperty(i) && !defs.hasOwnProperty(i)) - throw new DefaultsError("`" + i + "` is not a supported option", defs); + DefaultsError.croak("`" + i + "` is not a supported option", defs); for (var i in defs) if (defs.hasOwnProperty(i)) { ret[i] = (args && args.hasOwnProperty(i)) ? args[i] : defs[i]; } |