This commit is contained in:
Aria Sangarin 2020-03-10 18:41:39 +01:00
commit 15dc8c73f3
2 changed files with 117 additions and 121 deletions

View File

@ -128,7 +128,7 @@ public class MMOItems extends JavaPlugin {
abilityManager.registerDefaultAbilities(); abilityManager.registerDefaultAbilities();
configManager = new ConfigManager(); configManager = new ConfigManager();
itemManager = new ItemManager(getConfig().getBoolean("use-item-caching")); itemManager = new ItemManager(getConfig().getBoolean("use-item-caching"));
tierManager = new TierManager(); tierManager = new TierManager();
setManager = new SetManager(); setManager = new SetManager();
upgradeManager = new UpgradeManager(); upgradeManager = new UpgradeManager();

View File

@ -4,45 +4,30 @@ import java.util.HashMap;
import java.util.HashSet; import java.util.HashSet;
import java.util.Map; import java.util.Map;
import org.bukkit.Bukkit;
import org.bukkit.configuration.ConfigurationSection; import org.bukkit.configuration.ConfigurationSection;
import org.bukkit.configuration.file.FileConfiguration; import org.bukkit.configuration.file.FileConfiguration;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
import org.bukkit.scheduler.BukkitRunnable;
import net.Indyuce.mmoitems.MMOItems; import net.Indyuce.mmoitems.MMOItems;
import net.Indyuce.mmoitems.api.Type; import net.Indyuce.mmoitems.api.Type;
import net.Indyuce.mmoitems.api.item.MMOItem; import net.Indyuce.mmoitems.api.item.MMOItem;
import net.Indyuce.mmoitems.stat.type.ItemStat; import net.Indyuce.mmoitems.stat.type.ItemStat;
public class ItemManager extends BukkitRunnable { public class ItemManager {
private final Map<Type, Map<String, LoadedItem>> map = new HashMap<>(); private final Map<Type, Map<String, LoadedItem>> map = new HashMap<>();
private final boolean cache; private final boolean useCache;
public ItemManager(boolean cache) { public ItemManager(boolean useCache) {
if (this.cache = cache) if (this.useCache = useCache)
runTaskTimerAsynchronously(MMOItems.plugin, 60 * 20, 2 * 60 * 20); Bukkit.getScheduler().runTaskTimerAsynchronously(MMOItems.plugin, () -> clearCache(), 60 * 20, 2 * 60 * 20);
} }
public void uncache(Type type, String id) {
if (map.containsKey(type))
map.get(type).remove(id);
}
public void cache(MMOItem item) {
if (!map.containsKey(item.getType()))
map.put(item.getType(), new HashMap<>());
map.get(item.getType()).put(item.getId(), new LoadedItem(item));
}
public LoadedItem getCachedMMOItem(Type type, String id) {
Map<String, LoadedItem> map;
return this.map.containsKey(type) ? (map = this.map.get(type)).containsKey(id) ? map.get(id) : null : null;
}
public MMOItem getMMOItem(Type type, String id) { public MMOItem getMMOItem(Type type, String id) {
id = id.toUpperCase().replace("-", "_").replace(" ", "_"); id = id.toUpperCase().replace("-", "_").replace(" ", "_");
if (cache) { if (useCache) {
LoadedItem cached = getCachedMMOItem(type, id); LoadedItem cached = getCachedMMOItem(type, id);
if (cached != null) { if (cached != null) {
cached.refresh(); cached.refresh();
@ -61,8 +46,9 @@ public class ItemManager extends BukkitRunnable {
if (section.contains(stat.getPath()) && !stat.whenLoaded(mmoitem, section)) if (section.contains(stat.getPath()) && !stat.whenLoaded(mmoitem, section))
return null; return null;
if (cache) if (useCache)
cache(mmoitem); cache(mmoitem);
return mmoitem; return mmoitem;
} }
@ -71,17 +57,27 @@ public class ItemManager extends BukkitRunnable {
return item == null ? null : item.newBuilder().build(); return item == null ? null : item.newBuilder().build();
} }
public boolean exists(Type type, String id) { public LoadedItem getCachedMMOItem(Type type, String id) {
if(type == null) return false; Map<String, LoadedItem> map;
return type.getConfigFile().getConfig().contains(id.replace("-", "_").toUpperCase()); return this.map.containsKey(type) ? (map = this.map.get(type)).containsKey(id) ? map.get(id) : null : null;
}
public void uncache(Type type, String id) {
if (map.containsKey(type))
map.get(type).remove(id);
}
private void cache(MMOItem item) {
if (!map.containsKey(item.getType()))
map.put(item.getType(), new HashMap<>());
map.get(item.getType()).put(item.getId(), new LoadedItem(item));
} }
/* /*
* every two minutes, loops through any loaded item and uncaches any if they * every two minutes, loops through any loaded item and uncaches any if they
* have not been generated for more than 5 minutes. * have not been generated for more than 5 minutes.
*/ */
@Override private void clearCache() {
public void run() {
for (Type type : map.keySet()) { for (Type type : map.keySet()) {
Map<String, LoadedItem> map = this.map.get(type); Map<String, LoadedItem> map = this.map.get(type);
for (String id : new HashSet<>(map.keySet())) { for (String id : new HashSet<>(map.keySet())) {