aboutsummaryrefslogtreecommitdiff
path: root/lib/compress.js
diff options
context:
space:
mode:
authorAlex Lam S.L <alexlamsl@gmail.com>2018-03-13 17:35:34 +0800
committerGitHub <noreply@github.com>2018-03-13 17:35:34 +0800
commit5429234138b1645d0c06de48c60e3c5469a81daf (patch)
tree55732a276f8ba97e3b4d8b1acfbbddb513c33823 /lib/compress.js
parentb9f72a4a81d69a7dd782a5ee70f7eee1cb4aa0e0 (diff)
downloadtracifyjs-5429234138b1645d0c06de48c60e3c5469a81daf.tar.gz
tracifyjs-5429234138b1645d0c06de48c60e3c5469a81daf.zip
preserve non-constant value assignments with modifications (#2997)
fixes #2995
Diffstat (limited to 'lib/compress.js')
-rw-r--r--lib/compress.js27
1 files changed, 25 insertions, 2 deletions
diff --git a/lib/compress.js b/lib/compress.js
index 1b52f83e..cacffd37 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -3114,6 +3114,8 @@ merge(Compressor.prototype, {
var in_use = [];
var in_use_ids = Object.create(null); // avoid expensive linear scans of in_use
var fixed_ids = Object.create(null);
+ var value_read = Object.create(null);
+ var value_modified = Object.create(null);
if (self instanceof AST_Toplevel && compressor.top_retain) {
self.variables.each(function(def) {
if (compressor.top_retain(def) && !(def.id in in_use_ids)) {
@@ -3381,6 +3383,17 @@ merge(Compressor.prototype, {
);
self.transform(tt);
+ function verify_safe_usage(def, read, modified) {
+ if (def.id in in_use_ids) return;
+ if (read && modified) {
+ in_use_ids[def.id] = true;
+ in_use.push(def);
+ } else {
+ value_read[def.id] = read;
+ value_modified[def.id] = modified;
+ }
+ }
+
function scan_ref_scoped(node, descend) {
var node_def, props = [], sym = assign_as_unused(node, props);
if (sym instanceof AST_SymbolRef
@@ -3390,8 +3403,18 @@ merge(Compressor.prototype, {
});
if (node instanceof AST_Assign) {
node.right.walk(tw);
- if (node.left === sym && !node_def.chained && sym.fixed_value() === node.right) {
- fixed_ids[node_def.id] = node;
+ if (node.left === sym) {
+ if (!node_def.chained && sym.fixed_value() === node.right) {
+ fixed_ids[node_def.id] = node;
+ }
+ if (!node.write_only) {
+ verify_safe_usage(node_def, true, value_modified[node_def.id]);
+ }
+ } else {
+ var fixed = sym.fixed_value();
+ if (!fixed || !fixed.is_constant()) {
+ verify_safe_usage(node_def, value_read[node_def.id], true);
+ }
}
}
return true;