All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.shynixn.petblocks.bukkit.logic.business.configuration.ParticleConfiguration Maven / Gradle / Ivy

There is a newer version: 8.29.0
Show newest version
package com.github.shynixn.petblocks.bukkit.logic.business.configuration;

import com.github.shynixn.petblocks.api.business.entity.GUIItemContainer;
import com.github.shynixn.petblocks.api.persistence.controller.ParticleController;
import com.github.shynixn.petblocks.api.persistence.entity.ParticleEffectMeta;
import com.github.shynixn.petblocks.bukkit.PetBlocksPlugin;
import com.github.shynixn.petblocks.bukkit.logic.business.entity.ItemContainer;
import com.github.shynixn.petblocks.bukkit.logic.persistence.entity.ParticleEffectData;
import org.bukkit.configuration.MemorySection;
import org.bukkit.plugin.Plugin;

import java.util.*;
import java.util.logging.Level;

/**
 * Copyright 2017 Shynixn
 * 

* Do not remove this header! *

* Version 1.0 *

* MIT License *

* Copyright (c) 2017 *

* Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: *

* The above copyright notice and this permission notice shall be included in all * copies or substantial portions of the Software. *

* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ public class ParticleConfiguration implements ParticleController { private Plugin plugin; private final Map particleCache = new HashMap<>(); /** * Initializes a new engine repository * * @param plugin plugin */ public ParticleConfiguration(Plugin plugin) { super(); if (plugin == null) throw new IllegalArgumentException("Plugin cannot be null!"); this.plugin = plugin; } /** * Stores a new a item in the repository * * @param item item */ @Override public void store(GUIItemContainer item) { throw new RuntimeException("Not implemented!"); } /** * Removes an item from the repository * * @param item item */ @Override public void remove(GUIItemContainer item) { if (this.particleCache.containsKey(item)) { this.particleCache.remove(item); } } /** * Returns the amount of items in the repository * * @return size */ @Override public int size() { return this.particleCache.size(); } /** * Returns all items from the repository as unmodifiableList * * @return items */ @Override public List getAll() { final List containers = new ArrayList<>(this.particleCache.keySet()); containers.sort(Comparator.comparingInt(GUIItemContainer::getPosition)); return containers; } /** * Returns the container by the given order id * * @param id id * @return container */ @Override @Deprecated public GUIItemContainer getContainerByPosition(int id) { for (final GUIItemContainer guiItemContainer : this.particleCache.keySet()) { if (guiItemContainer.getPosition() == id) { return guiItemContainer; } } return null; } /** * Returns the container by the given order id. * * @param id id * @return container */ @Override public Optional getContainerFromPosition(int id) { for (final GUIItemContainer guiItemContainer : this.particleCache.keySet()) { if (guiItemContainer.getPosition() == id) { return Optional.of(guiItemContainer); } } return Optional.empty(); } /** * Returns the particleEffect by the given container * * @param container container * @return particleEffect */ @Override public ParticleEffectMeta getByItem(GUIItemContainer container) { if (this.particleCache.containsKey(container)) { return this.particleCache.get(container); } return null; } /** * Returns the particleEffect by the given container. * * @param container container * @return particleEffect */ @Override public Optional getFromItem(GUIItemContainer container) { if (this.particleCache.containsKey(container)) { return Optional.of(this.particleCache.get(container)); } return Optional.empty(); } /** * Reloads the content from the fileSystem */ @Override public void reload() { this.particleCache.clear(); this.plugin.reloadConfig(); final Map data = ((MemorySection) this.plugin.getConfig().get("particles")).getValues(false); for (final String key : data.keySet()) { try { final GUIItemContainer container = new ItemContainer(Integer.parseInt(key), ((MemorySection) data.get(key)).getValues(false)); final ParticleEffectMeta meta = new ParticleEffectData(((MemorySection) ((MemorySection) data.get(key)).getValues(false).get("effect")).getValues(true)); this.particleCache.put(container, meta); } catch (final Exception e) { PetBlocksPlugin.logger().log(Level.WARNING, "Failed to load particle " + key + '.', e); } } } /** * Closes this resource, relinquishing any underlying resources. * This method is invoked automatically on objects managed by the * {@code try}-with-resources statement. * However, implementers of this interface are strongly encouraged * to make their {@code close} methods idempotent. * * @throws Exception if this resource cannot be closed */ @Override public void close() throws Exception { this.plugin = null; this.particleCache.clear(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy