aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/compress.js19
1 files changed, 14 insertions, 5 deletions
diff --git a/lib/compress.js b/lib/compress.js
index 09dc1802..ddb4437b 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -1321,9 +1321,10 @@ function Compressor(options, false_by_default) {
});
AST_UnaryPrefix.DEFMETHOD("optimize", function(compressor){
+ var self = this;
+ var e = self.expression;
if (compressor.option("booleans") && compressor.in_boolean_context()) {
- var e = this.expression;
- switch (this.operator) {
+ switch (self.operator) {
case "!":
if (e instanceof AST_UnaryPrefix && e.operator == "!") {
// !!foo ==> foo, if we're in boolean context
@@ -1333,11 +1334,14 @@ function Compressor(options, false_by_default) {
case "typeof":
// typeof always returns a non-empty string, thus it's
// always true in booleans
- compressor.warn("Boolean expression always true [{line},{col}]", this.start);
- return make_node(AST_True, this).optimize(compressor);
+ compressor.warn("Boolean expression always true [{line},{col}]", self.start);
+ return make_node(AST_True, self).optimize(compressor);
}
}
- return this.evaluate(compressor)[0];
+ if (e instanceof AST_Binary) {
+ self = best_of(self, e.negate(compressor));
+ }
+ return self.evaluate(compressor)[0];
});
SQUEEZE(AST_Binary, function(self, compressor){
@@ -1531,6 +1535,11 @@ function Compressor(options, false_by_default) {
AST_Conditional.DEFMETHOD("optimize", function(compressor){
var self = this;
if (!compressor.option("conditionals")) return self;
+ if (self.condition instanceof AST_Seq) {
+ var car = self.condition.car;
+ self.condition = self.condition.cdr;
+ return AST_Seq.cons(car, self.optimize(compressor)).optimize(compressor);
+ }
var cond = self.condition.evaluate(compressor);
if (cond.length == 2) {
if (cond[1]) {