aboutsummaryrefslogtreecommitdiff
path: root/lib/compress.js
diff options
context:
space:
mode:
Diffstat (limited to 'lib/compress.js')
-rw-r--r--lib/compress.js21
1 files changed, 14 insertions, 7 deletions
diff --git a/lib/compress.js b/lib/compress.js
index 4ce283da..43c32a75 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -1151,7 +1151,7 @@ merge(Compressor.prototype, {
return node;
} else {
replaced++;
- if (value_def && candidate instanceof AST_VarDef) return node;
+ if (value_def) return node;
}
CHANGED = abort = true;
AST_Node.info("Collapsing {name} [{file}:{line},{col}]", {
@@ -1207,7 +1207,7 @@ merge(Compressor.prototype, {
if (is_lhs(node, multi_replacer.parent())) return node;
def.replaced++;
value_def.replaced--;
- return candidate.value.clone();
+ return get_rvalue(candidate).clone();
}
// Skip (non-executed) functions and (leading) default case in switch statements
if (node instanceof AST_Default || node instanceof AST_Scope) return node;
@@ -1255,10 +1255,17 @@ merge(Compressor.prototype, {
statements[i].transform(scanner);
}
if (value_def) {
- var def = candidate.name.definition();
- if (abort && def.references.length - def.replaced > replaced) replaced = false;
- else {
- abort = false;
+ var def = lhs.definition();
+ if (abort) {
+ var referenced = def.references.length - def.replaced;
+ if (candidate instanceof AST_Assign) referenced--;
+ if (referenced > replaced) {
+ replaced = false;
+ } else {
+ abort = false;
+ }
+ }
+ if (!abort) {
hit_index = 0;
hit = funarg;
for (var i = stat_index; !abort && i < statements.length; i++) {
@@ -1334,7 +1341,7 @@ merge(Compressor.prototype, {
return compressor.option("ie8") && node.name && lvalues.has(node.name.name);
}
if (node instanceof AST_PropAccess) {
- return side_effects || node.expression.may_throw_on_access(compressor);
+ return side_effects || !value_def && node.expression.may_throw_on_access(compressor);
}
if (node instanceof AST_SymbolRef) {
if (symbol_in_lvalues(node, parent)) {