From 8b8ef665ef17a4ca54b696ed8fc71e2fc04624d4 Mon Sep 17 00:00:00 2001 From: Gravit Date: Sat, 12 Sep 2020 16:34:09 +0700 Subject: [PATCH] =?UTF-8?q?[FEATURE][EXPERIMENTAL]=20=D0=9F=D0=BE=D1=82?= =?UTF-8?q?=D0=B5=D0=BD=D1=86=D0=B8=D0=B0=D0=BB=D1=8C=D0=BD=D0=B0=D1=8F=20?= =?UTF-8?q?=D0=BF=D1=80=D0=BE=D0=B1=D0=BB=D0=B5=D0=BC=D0=B0=20=D1=81=20?= =?UTF-8?q?=D0=B7=D0=B0=D0=B2=D0=B8=D1=81=D0=B8=D0=BC=D0=BE=D1=81=D1=82?= =?UTF-8?q?=D1=8F=D0=BC=D0=B8=20=D0=B2=20=D0=BE=D0=BF=D1=86=D0=B8=D0=BE?= =?UTF-8?q?=D0=BD=D0=B0=D0=BB=D1=8C=D0=BD=D1=8B=D1=85=20=D0=BC=D0=BE=D0=B4?= =?UTF-8?q?=D0=B0=D1=85?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../profiles/optional/OptionalFile.java | 1 + .../profiles/optional/OptionalView.java | 23 +++++++++++-------- 2 files changed, 14 insertions(+), 10 deletions(-) diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/optional/OptionalFile.java b/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/optional/OptionalFile.java index 3addee6e..6965ffcd 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/optional/OptionalFile.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/optional/OptionalFile.java @@ -47,6 +47,7 @@ public class OptionalFile { public int subTreeLevel = 1; @LauncherNetworkAPI public boolean isPreset; + @Deprecated public transient Set dependenciesCount; private volatile transient Collection> watchList = null; diff --git a/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/optional/OptionalView.java b/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/optional/OptionalView.java index 7fa1cf3c..9a248b75 100644 --- a/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/optional/OptionalView.java +++ b/LauncherAPI/src/main/java/pro/gravit/launcher/profiles/optional/OptionalView.java @@ -3,11 +3,14 @@ import pro.gravit.launcher.profiles.ClientProfile; import pro.gravit.launcher.profiles.optional.actions.OptionalAction; +import java.util.HashMap; import java.util.HashSet; +import java.util.Map; import java.util.Set; public class OptionalView { public Set enabled = new HashSet<>(); + public Map> dependenciesCountMap = new HashMap<>(); public Set all; @SuppressWarnings("unchecked") @@ -64,8 +67,8 @@ public void enable(OptionalFile file) file.watchEvent(true); if (file.dependencies != null) { for (OptionalFile dep : file.dependencies) { - if (dep.dependenciesCount == null) dep.dependenciesCount = new HashSet<>(); - dep.dependenciesCount.add(file); + Set dependenciesCount = dependenciesCountMap.computeIfAbsent(dep, k -> new HashSet<>()); + dependenciesCount.add(file); enable(dep); } } @@ -79,22 +82,22 @@ public void disable(OptionalFile file) { if(!enabled.remove(file)) return; file.watchEvent(false); - if (file.dependenciesCount != null) { - for (OptionalFile f : file.dependenciesCount) { + Set dependenciesCount = dependenciesCountMap.get(file); + if (dependenciesCount != null) { + for (OptionalFile f : dependenciesCount) { if (f.isPreset) continue; disable(f); } - file.dependenciesCount.clear(); - file.dependenciesCount = null; + dependenciesCount.clear(); } if (file.dependencies != null) { for (OptionalFile f : file.dependencies) { if (!enabled.contains(f)) continue; - if (f.dependenciesCount == null) { + dependenciesCount = dependenciesCountMap.get(f); + if (dependenciesCount == null) { disable(f); - } else if (f.dependenciesCount.size() <= 1) { - f.dependenciesCount.clear(); - f.dependenciesCount = null; + } else if (dependenciesCount.size() <= 1) { + dependenciesCount.clear(); disable(f); } }