diff options
author | Alex Lam S.L <alexlamsl@gmail.com> | 2021-02-07 05:52:09 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-02-07 13:52:09 +0800 |
commit | 522cceeccf7f66bffaa71f60a678b3fdfede94bf (patch) | |
tree | d2486babf82d649977c647b45099a33f3b912c08 /lib/compress.js | |
parent | 5c84dfa1517c89018cf61b9e356224b08f393052 (diff) | |
download | tracifyjs-522cceeccf7f66bffaa71f60a678b3fdfede94bf.tar.gz tracifyjs-522cceeccf7f66bffaa71f60a678b3fdfede94bf.zip |
fix corner case in `functions` (#4619)
fixes #4618
Diffstat (limited to 'lib/compress.js')
-rw-r--r-- | lib/compress.js | 37 |
1 files changed, 22 insertions, 15 deletions
diff --git a/lib/compress.js b/lib/compress.js index d4cf0da9..7a6a0bcb 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -5854,13 +5854,7 @@ merge(Compressor.prototype, { && var_defs[sym.id] == 1 && sym.assignments == 0 && (value instanceof AST_AsyncFunction || value instanceof AST_Function) - && (sym.references.length ? all(sym.references, function(ref) { - return value === ref.fixed_value(); - }) : value === def.name.fixed_value()) - && (!value.name || (old_def = value.name.definition()).assignments == 0 - && (old_def.name == def.name.name || all(old_def.references, function(ref) { - return ref.scope.find_variable(def.name.name) === def.name.definition(); - }))) + && assigned_once(value, sym.references) && can_declare_defun() && can_rename(value, def.name.name)) { AST_Node.warn("Declaring {name} as function [{file}:{line},{col}]", template(def.name)); @@ -5902,14 +5896,11 @@ merge(Compressor.prototype, { sym.eliminated++; } - function is_catch(node) { - var sym = node.definition(); - return sym.orig[0] instanceof AST_SymbolCatch && sym.scope.resolve() === node.scope.resolve(); - } - - function can_rename(fn, name) { - var def = fn.variables.get(name); - return !def || fn.name && def === fn.name.definition(); + function assigned_once(fn, refs) { + if (refs.length == 0) return fn === def.name.fixed_value(); + return all(refs, function(ref) { + return fn === ref.fixed_value(); + }); } function can_declare_defun() { @@ -5919,6 +5910,22 @@ merge(Compressor.prototype, { || parent instanceof AST_If; } + function can_rename(fn, name) { + if (!fn.name) return !fn.variables.get(name); + old_def = fn.name.definition(); + if (old_def.assignments > 0) return false; + if (old_def.name == name) return true; + if (name == "await" && is_async(fn)) return false; + return all(old_def.references, function(ref) { + return ref.scope.find_variable(name) === sym; + }); + } + + function is_catch(node) { + var sym = node.definition(); + return sym.orig[0] instanceof AST_SymbolCatch && sym.scope.resolve() === node.scope.resolve(); + } + function flush() { if (side_effects.length > 0) { if (tail.length == 0) { |