/******************************************************************************* * Copyright 2014 Tobias Welther * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. ******************************************************************************/ package de.tobiyas.racesandclasses.traitcontainer.traits.statictraits; import java.util.HashMap; import java.util.List; import java.util.concurrent.Callable; import org.bukkit.entity.EntityType; import org.bukkit.entity.LivingEntity; import org.bukkit.entity.Player; import org.bukkit.event.Event; import org.bukkit.event.entity.CreatureSpawnEvent; import org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason; import org.bukkit.event.entity.EntityDeathEvent; import org.bukkit.inventory.ItemStack; import org.bukkit.metadata.LazyMetadataValue; import de.tobiyas.racesandclasses.RacesAndClasses; import de.tobiyas.racesandclasses.configuration.traits.TraitConfig; import de.tobiyas.racesandclasses.eventprocessing.eventresolvage.EventWrapper; import de.tobiyas.racesandclasses.playermanagement.player.RaCPlayer; import de.tobiyas.racesandclasses.playermanagement.player.RaCPlayerManager; import de.tobiyas.racesandclasses.traitcontainer.interfaces.AbstractBasicTrait; import de.tobiyas.racesandclasses.traitcontainer.interfaces.TraitResults; import de.tobiyas.racesandclasses.traitcontainer.interfaces.annotations.bypasses.StaticTrait; import de.tobiyas.racesandclasses.traitcontainer.interfaces.annotations.configuration.TraitConfigurationNeeded; import de.tobiyas.racesandclasses.traitcontainer.interfaces.annotations.configuration.TraitEventsUsed; import de.tobiyas.racesandclasses.traitcontainer.interfaces.annotations.configuration.TraitInfos; import de.tobiyas.racesandclasses.traitcontainer.interfaces.markerinterfaces.Trait; import de.tobiyas.racesandclasses.traitcontainer.interfaces.markerinterfaces.TraitRestriction; import de.tobiyas.racesandclasses.util.consts.Consts; import de.tobiyas.racesandclasses.util.items.CreateDropContainer; import de.tobiyas.racesandclasses.util.items.DropContainer; import de.tobiyas.racesandclasses.util.traitutil.TraitConfiguration; public class DeathCheckerTrait extends AbstractBasicTrait implements StaticTrait{ private HashMap<EntityType, DropContainer> dropMap; private RacesAndClasses plugin; @TraitEventsUsed(registerdClasses = {EntityDeathEvent.class, CreatureSpawnEvent.class}) @Override public void generalInit() { plugin = RacesAndClasses.getPlugin(); dropMap = new HashMap<EntityType, DropContainer>(); TraitConfig config = plugin.getConfigManager().getTraitConfigManager().getConfigOfTrait(getName()); if(config == null){ initListsDefault(); } readListFromConfig(config); } private void readListFromConfig(TraitConfig config){ for(EntityType type : EntityType.values()){ String path = Consts.traitConfigDir + "DropRates.yml"; DropContainer container = CreateDropContainer.loadDropContainer(path, type); if(container != null) dropMap.put(type, container); } } private void initListsDefault(){ String path = Consts.traitConfigDir + "DropRates.yml"; CreateDropContainer.createAllContainers(path); } @Override public String getName() { return "DropRates"; } @Override protected String getPrettyConfigIntern() { return ""; } @TraitConfigurationNeeded @Override public void setConfiguration(TraitConfiguration configMap) { } @Override public TraitRestriction checkRestrictions(EventWrapper wrapper) { return TraitRestriction.None; } /** * This key indicates that the Monster has been spawned by a Spawner. */ private final static String SPAWNER_KEY = "spawner_spawned"; @Override public TraitResults trigger(EventWrapper eventWrapper) { Event event = eventWrapper.getEvent(); if(event instanceof CreatureSpawnEvent){ if(((CreatureSpawnEvent) event).getSpawnReason() == SpawnReason.SPAWNER){ ((CreatureSpawnEvent) event).getEntity().setMetadata(SPAWNER_KEY, new LazyMetadataValue(plugin, new Callable<Object>() { @Override public Object call() throws Exception { return true; } })); return TraitResults.True(); } return TraitResults.False(); } if(!plugin.getConfigManager().getGeneralConfig().isConfig_enable_expDropBonus()) return TraitResults.False(); if(!(event instanceof EntityDeathEvent)) return TraitResults.False(); EntityDeathEvent Eevent = (EntityDeathEvent) event; LivingEntity entity = Eevent.getEntity(); if(entity == null || entity instanceof Player) return TraitResults.False(); int exp = Eevent.getDroppedExp(); List<ItemStack> items = Eevent.getDrops(); Eevent.setDroppedExp(modifyEXP(exp, entity)); modifyItems(items, entity); if(Eevent.getEntity().getMetadata(SPAWNER_KEY).isEmpty()) return TraitResults.False(); Player killerTemp = entity.getKiller(); RaCPlayer killer = RaCPlayerManager.get().getPlayer(killerTemp); if(killer != null){ int expForLevel = (int) (Eevent.getDroppedExp() / 10d); killer.getLevelManager().addExp(expForLevel); } return TraitResults.True(); } private int modifyEXP(int exp, LivingEntity entity){ DropContainer container = dropMap.get(entity.getType()); if(container == null) return exp; return container.getEXP(); } private void modifyItems(List<ItemStack> list, LivingEntity entity){ DropContainer container = dropMap.get(entity.getType()); if(container == null) return; for(ItemStack stack : container.getItems()) list.add(stack); } @Override public boolean isBetterThan(Trait trait) { //Singleton, Not needed. return true; } @TraitInfos(category="static", traitName="DropTrait", visible=false) @Override public void importTrait() { } @Override public boolean canBeTriggered(EventWrapper wrapper) { return true; } @Override public boolean isStackable(){ return false; } @Override public boolean isVisible() { return false; } }