Fixed the Soul Network and made sure the majority of the items worked on it.
This commit is contained in:
parent
241c0b8dda
commit
6fb409f20f
|
@ -431,7 +431,7 @@ public class BloodAltar
|
||||||
{
|
{
|
||||||
int liquidDrained = Math.min((int) (altarTier.ordinal() >= 2 ? consumptionRate * (1 + consumptionMultiplier) : consumptionRate), fluid.amount);
|
int liquidDrained = Math.min((int) (altarTier.ordinal() >= 2 ? consumptionRate * (1 + consumptionMultiplier) : consumptionRate), fluid.amount);
|
||||||
|
|
||||||
int drain = NetworkHelper.getSoulNetwork(ownerUUID, world).addLifeEssence(liquidDrained, (int) (item.getMaxEssence(returnedItem.getMetadata()) * this.orbCapacityMultiplier));
|
int drain = NetworkHelper.getSoulNetwork(ownerUUID).addLifeEssence(liquidDrained, (int) (item.getMaxEssence(returnedItem.getMetadata()) * this.orbCapacityMultiplier));
|
||||||
|
|
||||||
fluid.amount = fluid.amount - drain;
|
fluid.amount = fluid.amount - drain;
|
||||||
|
|
||||||
|
|
|
@ -90,6 +90,7 @@ public class SoulNetwork extends WorldSavedData
|
||||||
*/
|
*/
|
||||||
public int syphon(int syphon)
|
public int syphon(int syphon)
|
||||||
{
|
{
|
||||||
|
System.out.println("Being syphoned");
|
||||||
if (getCurrentEssence() >= syphon)
|
if (getCurrentEssence() >= syphon)
|
||||||
{
|
{
|
||||||
setCurrentEssence(getCurrentEssence() - syphon);
|
setCurrentEssence(getCurrentEssence() - syphon);
|
||||||
|
@ -101,37 +102,40 @@ public class SoulNetwork extends WorldSavedData
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* If the player exists on the server, syphon the given amount of LP from
|
* Syphons from the network of the owner. If not enough LP is found, it will
|
||||||
* the player's LP network and damage for any remaining LP required.
|
* instead take away from the user's health.
|
||||||
*
|
*
|
||||||
* Always returns false on the client side.
|
* Always returns false on the client side.
|
||||||
*
|
*
|
||||||
* @return - Whether the action should be performed.
|
* @return - Whether the action should be performed.
|
||||||
*/
|
*/
|
||||||
public boolean syphonAndDamage(int toSyphon)
|
public boolean syphonAndDamage(EntityPlayer user, int toSyphon)
|
||||||
{
|
{
|
||||||
if (getPlayer() != null)
|
BloodMagicAPI.getLogger().debug("The operation has requested a drain of " + toSyphon + " LP.");
|
||||||
|
if (user != null)
|
||||||
{
|
{
|
||||||
if (getPlayer().worldObj.isRemote)
|
if (user.worldObj.isRemote)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (!Strings.isNullOrEmpty(mapName))
|
if (!Strings.isNullOrEmpty(mapName))
|
||||||
{
|
{
|
||||||
SoulNetworkEvent.ItemDrainNetworkEvent event = new SoulNetworkEvent.ItemDrainNetworkEvent(player, mapName, getPlayer().getHeldItem(), toSyphon);
|
SoulNetworkEvent.ItemDrainNetworkEvent event = new SoulNetworkEvent.ItemDrainNetworkEvent(user, mapName, null, toSyphon);
|
||||||
|
|
||||||
if (MinecraftForge.EVENT_BUS.post(event))
|
if (MinecraftForge.EVENT_BUS.post(event))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
int drainAmount = syphon(event.syphon);
|
int drainAmount = syphon(event.syphon);
|
||||||
|
|
||||||
if (drainAmount == 0 || event.shouldDamage)
|
if (drainAmount <= 0 || event.shouldDamage)
|
||||||
hurtPlayer(event.syphon);
|
hurtPlayer(user, event.syphon);
|
||||||
|
|
||||||
return event.getResult() != Event.Result.DENY;
|
return event.getResult() != Event.Result.DENY;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
System.out.println("I got here?!?");
|
||||||
|
|
||||||
int amount = syphon(toSyphon);
|
int amount = syphon(toSyphon);
|
||||||
hurtPlayer(toSyphon - amount);
|
hurtPlayer(user, toSyphon - amount);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -139,27 +143,26 @@ public class SoulNetwork extends WorldSavedData
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void hurtPlayer(float syphon)
|
public void hurtPlayer(EntityPlayer user, float syphon)
|
||||||
{
|
{
|
||||||
System.out.println("Called");
|
if (user != null)
|
||||||
if (getPlayer() != null)
|
|
||||||
{
|
{
|
||||||
if (syphon < 100 && syphon > 0)
|
if (syphon < 100 && syphon > 0)
|
||||||
{
|
{
|
||||||
if (!getPlayer().capabilities.isCreativeMode)
|
if (!user.capabilities.isCreativeMode)
|
||||||
{
|
{
|
||||||
getPlayer().hurtResistantTime = 0;
|
user.hurtResistantTime = 0;
|
||||||
getPlayer().attackEntityFrom(BloodMagicAPI.getDamageSource(), 1.0F);
|
user.attackEntityFrom(BloodMagicAPI.getDamageSource(), 1.0F);
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if (syphon >= 100)
|
} else if (syphon >= 100)
|
||||||
{
|
{
|
||||||
if (!getPlayer().capabilities.isCreativeMode)
|
if (!user.capabilities.isCreativeMode)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < ((syphon + 99) / 100); i++)
|
for (int i = 0; i < ((syphon + 99) / 100); i++)
|
||||||
{
|
{
|
||||||
getPlayer().hurtResistantTime = 0;
|
user.hurtResistantTime = 0;
|
||||||
getPlayer().attackEntityFrom(BloodMagicAPI.getDamageSource(), 1.0F);
|
user.attackEntityFrom(BloodMagicAPI.getDamageSource(), 1.0F);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,11 +5,14 @@ import WayofTime.bloodmagic.api.Constants;
|
||||||
import WayofTime.bloodmagic.api.event.AddToNetworkEvent;
|
import WayofTime.bloodmagic.api.event.AddToNetworkEvent;
|
||||||
import WayofTime.bloodmagic.api.event.SoulNetworkEvent;
|
import WayofTime.bloodmagic.api.event.SoulNetworkEvent;
|
||||||
import WayofTime.bloodmagic.api.network.SoulNetwork;
|
import WayofTime.bloodmagic.api.network.SoulNetwork;
|
||||||
|
|
||||||
import com.google.common.base.Strings;
|
import com.google.common.base.Strings;
|
||||||
|
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.server.MinecraftServer;
|
import net.minecraft.server.MinecraftServer;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
import net.minecraftforge.common.DimensionManager;
|
||||||
import net.minecraftforge.common.MinecraftForge;
|
import net.minecraftforge.common.MinecraftForge;
|
||||||
import net.minecraftforge.fml.common.eventhandler.Event;
|
import net.minecraftforge.fml.common.eventhandler.Event;
|
||||||
|
|
||||||
|
@ -25,13 +28,12 @@ public class NetworkHelper
|
||||||
*
|
*
|
||||||
* @param name
|
* @param name
|
||||||
* - The username of the SoulNetwork owner
|
* - The username of the SoulNetwork owner
|
||||||
* @param world
|
|
||||||
* - The world
|
|
||||||
*
|
*
|
||||||
* @return - The SoulNetwork for the given name.
|
* @return - The SoulNetwork for the given name.
|
||||||
*/
|
*/
|
||||||
public static SoulNetwork getSoulNetwork(String name, World world)
|
public static SoulNetwork getSoulNetwork(String name)
|
||||||
{
|
{
|
||||||
|
World world = DimensionManager.getWorld(0);
|
||||||
SoulNetwork network = (SoulNetwork) world.getMapStorage().loadData(SoulNetwork.class, name);
|
SoulNetwork network = (SoulNetwork) world.getMapStorage().loadData(SoulNetwork.class, name);
|
||||||
|
|
||||||
if (network == null)
|
if (network == null)
|
||||||
|
@ -46,17 +48,17 @@ public class NetworkHelper
|
||||||
/**
|
/**
|
||||||
* @see NetworkHelper#getSoulNetwork(String, World)
|
* @see NetworkHelper#getSoulNetwork(String, World)
|
||||||
*/
|
*/
|
||||||
public static SoulNetwork getSoulNetwork(UUID uuid, World world)
|
public static SoulNetwork getSoulNetwork(UUID uuid)
|
||||||
{
|
{
|
||||||
return getSoulNetwork(PlayerHelper.getUsernameFromUUID(uuid), world);
|
return getSoulNetwork(PlayerHelper.getUsernameFromUUID(uuid));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see NetworkHelper#getSoulNetwork(String, World)
|
* @see NetworkHelper#getSoulNetwork(String, World)
|
||||||
*/
|
*/
|
||||||
public static SoulNetwork getSoulNetwork(EntityPlayer player, World world)
|
public static SoulNetwork getSoulNetwork(EntityPlayer player)
|
||||||
{
|
{
|
||||||
return getSoulNetwork(PlayerHelper.getUUIDFromPlayer(player), world);
|
return getSoulNetwork(PlayerHelper.getUUIDFromPlayer(player));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -82,20 +84,23 @@ public class NetworkHelper
|
||||||
*
|
*
|
||||||
* @param soulNetwork
|
* @param soulNetwork
|
||||||
* - SoulNetwork to syphon from
|
* - SoulNetwork to syphon from
|
||||||
|
* @param user
|
||||||
|
* - User of the item.
|
||||||
* @param toSyphon
|
* @param toSyphon
|
||||||
* - Amount of LP to syphon
|
* - Amount of LP to syphon
|
||||||
*
|
*
|
||||||
* @return - Whether the action should be performed.
|
* @return - Whether the action should be performed.
|
||||||
*/
|
*/
|
||||||
public static boolean syphonAndDamage(SoulNetwork soulNetwork, int toSyphon)
|
public static boolean syphonAndDamage(SoulNetwork soulNetwork, EntityPlayer user, int toSyphon)
|
||||||
{
|
{
|
||||||
if (soulNetwork.getPlayer() == null)
|
|
||||||
{
|
|
||||||
soulNetwork.syphon(toSyphon);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return soulNetwork.syphonAndDamage(toSyphon);
|
// if (soulNetwork.getPlayer() == null)
|
||||||
|
// {
|
||||||
|
// soulNetwork.syphon(toSyphon);
|
||||||
|
// return true;
|
||||||
|
// }
|
||||||
|
|
||||||
|
return soulNetwork.syphonAndDamage(user, toSyphon);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -103,22 +108,21 @@ public class NetworkHelper
|
||||||
*
|
*
|
||||||
* @param stack
|
* @param stack
|
||||||
* - ItemStack in the Container.
|
* - ItemStack in the Container.
|
||||||
* @param world
|
|
||||||
* - The world the Container is in
|
|
||||||
* @param toSyphon
|
* @param toSyphon
|
||||||
* - Amount of LP to syphon
|
* - Amount of LP to syphon
|
||||||
*
|
*
|
||||||
* @return - If the syphon was successful.
|
* @return - If the syphon was successful.
|
||||||
*/
|
*/
|
||||||
public static boolean syphonFromContainer(ItemStack stack, World world, int toSyphon)
|
public static boolean syphonFromContainer(ItemStack stack, int toSyphon) //TODO: Change to a String, int?
|
||||||
{
|
{
|
||||||
|
System.out.println("Test");
|
||||||
stack = NBTHelper.checkNBT(stack);
|
stack = NBTHelper.checkNBT(stack);
|
||||||
String ownerName = stack.getTagCompound().getString(Constants.NBT.OWNER_UUID);
|
String ownerName = stack.getTagCompound().getString(Constants.NBT.OWNER_UUID);
|
||||||
|
|
||||||
if (Strings.isNullOrEmpty(ownerName))
|
if (Strings.isNullOrEmpty(ownerName))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
SoulNetwork network = getSoulNetwork(ownerName, world);
|
SoulNetwork network = getSoulNetwork(ownerName);
|
||||||
|
|
||||||
SoulNetworkEvent.ItemDrainInContainerEvent event = new SoulNetworkEvent.ItemDrainInContainerEvent(stack, ownerName, toSyphon);
|
SoulNetworkEvent.ItemDrainInContainerEvent event = new SoulNetworkEvent.ItemDrainInContainerEvent(stack, ownerName, toSyphon);
|
||||||
|
|
||||||
|
|
|
@ -4,12 +4,15 @@ import WayofTime.bloodmagic.BloodMagic;
|
||||||
import WayofTime.bloodmagic.api.BloodMagicAPI;
|
import WayofTime.bloodmagic.api.BloodMagicAPI;
|
||||||
import WayofTime.bloodmagic.api.Constants;
|
import WayofTime.bloodmagic.api.Constants;
|
||||||
import WayofTime.bloodmagic.api.iface.IBindable;
|
import WayofTime.bloodmagic.api.iface.IBindable;
|
||||||
|
import WayofTime.bloodmagic.api.network.SoulNetwork;
|
||||||
import WayofTime.bloodmagic.api.util.helper.BindableHelper;
|
import WayofTime.bloodmagic.api.util.helper.BindableHelper;
|
||||||
import WayofTime.bloodmagic.api.util.helper.NBTHelper;
|
import WayofTime.bloodmagic.api.util.helper.NBTHelper;
|
||||||
import WayofTime.bloodmagic.api.util.helper.NetworkHelper;
|
import WayofTime.bloodmagic.api.util.helper.NetworkHelper;
|
||||||
import WayofTime.bloodmagic.api.util.helper.PlayerHelper;
|
import WayofTime.bloodmagic.api.util.helper.PlayerHelper;
|
||||||
import WayofTime.bloodmagic.util.helper.TextHelper;
|
import WayofTime.bloodmagic.util.helper.TextHelper;
|
||||||
|
|
||||||
import com.google.common.base.Strings;
|
import com.google.common.base.Strings;
|
||||||
|
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
@ -35,6 +38,15 @@ public class ItemBindable extends Item implements IBindable
|
||||||
setMaxStackSize(1);
|
setMaxStackSize(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Syphons from the owner's network if possible - if not enough LP is found,
|
||||||
|
* it will instead take the LP from the holder of the item.
|
||||||
|
*
|
||||||
|
* @param stack
|
||||||
|
* @param player
|
||||||
|
* @param lpUsed
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean syphonNetwork(ItemStack stack, EntityPlayer player, int lpUsed)
|
public static boolean syphonNetwork(ItemStack stack, EntityPlayer player, int lpUsed)
|
||||||
{
|
{
|
||||||
if (player == null)
|
if (player == null)
|
||||||
|
@ -42,7 +54,14 @@ public class ItemBindable extends Item implements IBindable
|
||||||
|
|
||||||
if (!player.worldObj.isRemote)
|
if (!player.worldObj.isRemote)
|
||||||
{
|
{
|
||||||
return NetworkHelper.syphonAndDamage(NetworkHelper.getSoulNetwork(player, player.worldObj), lpUsed);
|
if (stack != null && stack.getItem() instanceof ItemBindable)
|
||||||
|
{
|
||||||
|
ItemBindable itemBindable = (ItemBindable) stack.getItem();
|
||||||
|
String owner = itemBindable.getBindableOwner(stack);
|
||||||
|
SoulNetwork network = NetworkHelper.getSoulNetwork(owner);
|
||||||
|
return NetworkHelper.syphonAndDamage(network, player, lpUsed);
|
||||||
|
}
|
||||||
|
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
double posX = player.posX;
|
double posX = player.posX;
|
||||||
|
@ -50,17 +69,26 @@ public class ItemBindable extends Item implements IBindable
|
||||||
double posZ = player.posZ;
|
double posZ = player.posZ;
|
||||||
|
|
||||||
// SpellHelper.sendIndexedParticleToAllAround(player.worldObj, posX,posY, posZ, 20, player.worldObj.provider.getDimensionId(), 4, posX, posY, posZ);
|
// SpellHelper.sendIndexedParticleToAllAround(player.worldObj, posX,posY, posZ, 20, player.worldObj.provider.getDimensionId(), 4, posX, posY, posZ);
|
||||||
player.worldObj.playSoundEffect((double) ((float) player.posX + 0.5F), (double) ((float) player.posY + 0.5F), (double) ((float) player.posZ + 0.5F), "random.fizz", 0.5F, 2.6F + (player.worldObj.rand.nextFloat() - player.worldObj.rand.nextFloat()) * 0.8F);
|
player.worldObj.playSoundEffect((double) ((float) posX + 0.5F), (double) ((float) posY + 0.5F), (double) ((float) posZ + 0.5F), "random.fizz", 0.5F, 2.6F + (player.worldObj.rand.nextFloat() - player.worldObj.rand.nextFloat()) * 0.8F);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This method is to be used for when you want to drain from a network
|
||||||
|
* without an online player. This will not take health from the owner if it
|
||||||
|
* fails to find sufficient LP.
|
||||||
|
*
|
||||||
|
* @param itemStack
|
||||||
|
* @param lpUsed
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
public static boolean syphonNetwork(ItemStack itemStack, int lpUsed)
|
public static boolean syphonNetwork(ItemStack itemStack, int lpUsed)
|
||||||
{
|
{
|
||||||
if (itemStack.getItem() instanceof ItemBindable)
|
if (itemStack.getItem() instanceof ItemBindable)
|
||||||
{
|
{
|
||||||
ItemBindable itemBindable = (ItemBindable) itemStack.getItem();
|
ItemBindable itemBindable = (ItemBindable) itemStack.getItem();
|
||||||
return !Strings.isNullOrEmpty(itemBindable.getBindableOwner(itemStack)) && syphonNetwork(itemStack, PlayerHelper.getPlayerFromUUID(itemBindable.getBindableOwner(itemStack)), lpUsed);
|
return !Strings.isNullOrEmpty(itemBindable.getBindableOwner(itemStack)) && NetworkHelper.syphonFromContainer(itemStack, lpUsed);
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -67,9 +67,9 @@ public class ItemBloodOrb extends ItemBindable implements IBloodOrb, IBindable
|
||||||
return stack;
|
return stack;
|
||||||
|
|
||||||
if (stack.getTagCompound().getString(Constants.NBT.OWNER_UUID).equals(PlayerHelper.getUsernameFromPlayer(player)))
|
if (stack.getTagCompound().getString(Constants.NBT.OWNER_UUID).equals(PlayerHelper.getUsernameFromPlayer(player)))
|
||||||
NetworkHelper.setMaxOrb(NetworkHelper.getSoulNetwork(stack.getTagCompound().getString(Constants.NBT.OWNER_UUID), world), getOrbLevel(stack.getItemDamage()));
|
NetworkHelper.setMaxOrb(NetworkHelper.getSoulNetwork(stack.getTagCompound().getString(Constants.NBT.OWNER_UUID)), getOrbLevel(stack.getItemDamage()));
|
||||||
|
|
||||||
NetworkHelper.getSoulNetwork(stack.getTagCompound().getString(Constants.NBT.OWNER_UUID), world).addLifeEssence(200, getMaxEssence(stack.getItemDamage()));
|
NetworkHelper.getSoulNetwork(stack.getTagCompound().getString(Constants.NBT.OWNER_UUID)).addLifeEssence(200, getMaxEssence(stack.getItemDamage()));
|
||||||
hurtPlayer(player, 200);
|
hurtPlayer(player, 200);
|
||||||
return stack;
|
return stack;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +1,11 @@
|
||||||
package WayofTime.bloodmagic.item;
|
package WayofTime.bloodmagic.item;
|
||||||
|
|
||||||
import WayofTime.bloodmagic.api.Constants;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import WayofTime.bloodmagic.api.util.helper.PlayerHelper;
|
|
||||||
import com.google.common.base.Strings;
|
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
|
||||||
import net.minecraft.server.MinecraftServer;
|
|
||||||
import net.minecraftforge.fml.common.IFuelHandler;
|
import net.minecraftforge.fml.common.IFuelHandler;
|
||||||
|
import WayofTime.bloodmagic.api.Constants;
|
||||||
|
import WayofTime.bloodmagic.api.util.helper.PlayerHelper;
|
||||||
|
|
||||||
public class ItemLavaCrystal extends ItemBindable implements IFuelHandler
|
public class ItemLavaCrystal extends ItemBindable implements IFuelHandler
|
||||||
{
|
{
|
||||||
|
@ -15,7 +13,7 @@ public class ItemLavaCrystal extends ItemBindable implements IFuelHandler
|
||||||
{
|
{
|
||||||
super();
|
super();
|
||||||
setUnlocalizedName(Constants.Mod.MODID + ".lavaCrystal");
|
setUnlocalizedName(Constants.Mod.MODID + ".lavaCrystal");
|
||||||
setLPUsed(1);
|
setLPUsed(25);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -46,20 +44,16 @@ public class ItemLavaCrystal extends ItemBindable implements IFuelHandler
|
||||||
|
|
||||||
if (fuelItem instanceof ItemLavaCrystal)
|
if (fuelItem instanceof ItemLavaCrystal)
|
||||||
{
|
{
|
||||||
if (syphonNetwork(fuel, getLPUsed()))
|
if (syphonNetwork(fuel, getLPUsed())) //TODO: change to canSyphonNetwork
|
||||||
{
|
{
|
||||||
return 1;
|
return 200;
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
NBTTagCompound tag = fuel.getTagCompound();
|
EntityPlayer player = PlayerHelper.getPlayerFromUUID(getBindableOwner(fuel));
|
||||||
|
if (player != null)
|
||||||
if (tag == null || MinecraftServer.getServer() == null || MinecraftServer.getServer().getConfigurationManager() == null)
|
{
|
||||||
return 0;
|
//TODO: Add nausea to the player.
|
||||||
|
}
|
||||||
if (Strings.isNullOrEmpty(((ItemLavaCrystal) fuelItem).getBindableOwner(fuel)))
|
|
||||||
return 0;
|
|
||||||
else
|
|
||||||
hurtPlayer(PlayerHelper.getPlayerFromUUID(getBindableOwner(fuel)), getLPUsed());
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -84,7 +84,7 @@ public class ItemPackSelfSacrifice extends ItemArmor implements IAltarManipulato
|
||||||
|
|
||||||
if (shouldSyphon & world.getTotalWorldTime() % INTERVAL == 0)
|
if (shouldSyphon & world.getTotalWorldTime() % INTERVAL == 0)
|
||||||
{
|
{
|
||||||
NetworkHelper.getSoulNetwork(player, world).hurtPlayer(1.0F);
|
NetworkHelper.getSoulNetwork(player).hurtPlayer(player, 1.0F);
|
||||||
addLP(stack, CONVERSION);
|
addLP(stack, CONVERSION);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,7 +34,7 @@ public class ItemSigilDivination extends ItemSigilBase implements IAltarReader
|
||||||
if (!world.isRemote)
|
if (!world.isRemote)
|
||||||
{
|
{
|
||||||
MovingObjectPosition position = getMovingObjectPositionFromPlayer(world, player, false);
|
MovingObjectPosition position = getMovingObjectPositionFromPlayer(world, player, false);
|
||||||
int currentEssence = NetworkHelper.getSoulNetwork(BindableHelper.getOwnerUUID(stack), world).getCurrentEssence();
|
int currentEssence = NetworkHelper.getSoulNetwork(BindableHelper.getOwnerUUID(stack)).getCurrentEssence();
|
||||||
|
|
||||||
if (position == null)
|
if (position == null)
|
||||||
{
|
{
|
||||||
|
|
|
@ -62,9 +62,6 @@ public class ItemSigilLava extends ItemSigilBase
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!player.capabilities.isCreativeMode)
|
|
||||||
this.setUnusable(stack, !syphonNetwork(stack, player, getLPUsed()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return stack;
|
return stack;
|
||||||
|
|
|
@ -35,7 +35,7 @@ public class ItemSigilSeer extends ItemSigilBase implements IAltarReader
|
||||||
if (!world.isRemote)
|
if (!world.isRemote)
|
||||||
{
|
{
|
||||||
MovingObjectPosition position = getMovingObjectPositionFromPlayer(world, player, false);
|
MovingObjectPosition position = getMovingObjectPositionFromPlayer(world, player, false);
|
||||||
int currentEssence = NetworkHelper.getSoulNetwork(BindableHelper.getOwnerUUID(stack), world).getCurrentEssence();
|
int currentEssence = NetworkHelper.getSoulNetwork(BindableHelper.getOwnerUUID(stack)).getCurrentEssence();
|
||||||
|
|
||||||
if (position == null)
|
if (position == null)
|
||||||
{
|
{
|
||||||
|
|
|
@ -62,9 +62,6 @@ public class ItemSigilWater extends ItemSigilBase
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!player.capabilities.isCreativeMode)
|
|
||||||
this.setUnusable(stack, !syphonNetwork(stack, player, getLPUsed()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return stack;
|
return stack;
|
||||||
|
|
|
@ -39,7 +39,7 @@ public class RitualFeatheredKnife extends Ritual
|
||||||
public void performRitual(IMasterRitualStone masterRitualStone)
|
public void performRitual(IMasterRitualStone masterRitualStone)
|
||||||
{
|
{
|
||||||
World world = masterRitualStone.getWorld();
|
World world = masterRitualStone.getWorld();
|
||||||
SoulNetwork network = NetworkHelper.getSoulNetwork(masterRitualStone.getOwner(), world);
|
SoulNetwork network = NetworkHelper.getSoulNetwork(masterRitualStone.getOwner());
|
||||||
int currentEssence = network.getCurrentEssence();
|
int currentEssence = network.getCurrentEssence();
|
||||||
|
|
||||||
if (currentEssence < getRefreshCost())
|
if (currentEssence < getRefreshCost())
|
||||||
|
|
|
@ -32,7 +32,7 @@ public class RitualGreenGrove extends Ritual
|
||||||
public void performRitual(IMasterRitualStone masterRitualStone)
|
public void performRitual(IMasterRitualStone masterRitualStone)
|
||||||
{
|
{
|
||||||
World world = masterRitualStone.getWorld();
|
World world = masterRitualStone.getWorld();
|
||||||
SoulNetwork network = NetworkHelper.getSoulNetwork(masterRitualStone.getOwner(), world);
|
SoulNetwork network = NetworkHelper.getSoulNetwork(masterRitualStone.getOwner());
|
||||||
int currentEssence = network.getCurrentEssence();
|
int currentEssence = network.getCurrentEssence();
|
||||||
|
|
||||||
if (currentEssence < getRefreshCost())
|
if (currentEssence < getRefreshCost())
|
||||||
|
|
|
@ -31,7 +31,7 @@ public class RitualJumping extends Ritual
|
||||||
public void performRitual(IMasterRitualStone masterRitualStone)
|
public void performRitual(IMasterRitualStone masterRitualStone)
|
||||||
{
|
{
|
||||||
World world = masterRitualStone.getWorld();
|
World world = masterRitualStone.getWorld();
|
||||||
SoulNetwork network = NetworkHelper.getSoulNetwork(masterRitualStone.getOwner(), world);
|
SoulNetwork network = NetworkHelper.getSoulNetwork(masterRitualStone.getOwner());
|
||||||
int currentEssence = network.getCurrentEssence();
|
int currentEssence = network.getCurrentEssence();
|
||||||
|
|
||||||
if (currentEssence < getRefreshCost())
|
if (currentEssence < getRefreshCost())
|
||||||
|
|
|
@ -24,7 +24,7 @@ public class RitualLava extends Ritual
|
||||||
public void performRitual(IMasterRitualStone masterRitualStone)
|
public void performRitual(IMasterRitualStone masterRitualStone)
|
||||||
{
|
{
|
||||||
World world = masterRitualStone.getWorld();
|
World world = masterRitualStone.getWorld();
|
||||||
SoulNetwork network = NetworkHelper.getSoulNetwork(masterRitualStone.getOwner(), world);
|
SoulNetwork network = NetworkHelper.getSoulNetwork(masterRitualStone.getOwner());
|
||||||
int currentEssence = network.getCurrentEssence();
|
int currentEssence = network.getCurrentEssence();
|
||||||
|
|
||||||
if (currentEssence < getRefreshCost())
|
if (currentEssence < getRefreshCost())
|
||||||
|
|
|
@ -24,7 +24,7 @@ public class RitualWater extends Ritual
|
||||||
public void performRitual(IMasterRitualStone masterRitualStone)
|
public void performRitual(IMasterRitualStone masterRitualStone)
|
||||||
{
|
{
|
||||||
World world = masterRitualStone.getWorld();
|
World world = masterRitualStone.getWorld();
|
||||||
SoulNetwork network = NetworkHelper.getSoulNetwork(masterRitualStone.getOwner(), world);
|
SoulNetwork network = NetworkHelper.getSoulNetwork(masterRitualStone.getOwner());
|
||||||
int currentEssence = network.getCurrentEssence();
|
int currentEssence = network.getCurrentEssence();
|
||||||
|
|
||||||
if (currentEssence < getRefreshCost())
|
if (currentEssence < getRefreshCost())
|
||||||
|
|
|
@ -40,7 +40,7 @@ public class RitualWellOfSuffering extends Ritual
|
||||||
public void performRitual(IMasterRitualStone masterRitualStone)
|
public void performRitual(IMasterRitualStone masterRitualStone)
|
||||||
{
|
{
|
||||||
World world = masterRitualStone.getWorld();
|
World world = masterRitualStone.getWorld();
|
||||||
SoulNetwork network = NetworkHelper.getSoulNetwork(masterRitualStone.getOwner(), world);
|
SoulNetwork network = NetworkHelper.getSoulNetwork(masterRitualStone.getOwner());
|
||||||
int currentEssence = network.getCurrentEssence();
|
int currentEssence = network.getCurrentEssence();
|
||||||
|
|
||||||
if (currentEssence < getRefreshCost())
|
if (currentEssence < getRefreshCost())
|
||||||
|
|
|
@ -23,7 +23,7 @@ public class TileImperfectRitualStone extends TileEntity implements IImperfectRi
|
||||||
|
|
||||||
if (imperfectRitual != null && ImperfectRitualRegistry.ritualEnabled(imperfectRitual))
|
if (imperfectRitual != null && ImperfectRitualRegistry.ritualEnabled(imperfectRitual))
|
||||||
{
|
{
|
||||||
NetworkHelper.getSoulNetwork(player, world).syphonAndDamage(imperfectRitual.getActivationCost());
|
NetworkHelper.getSoulNetwork(player).syphonAndDamage(player, imperfectRitual.getActivationCost());
|
||||||
if (imperfectRitual.onActivate(this, player))
|
if (imperfectRitual.onActivate(this, player))
|
||||||
if (imperfectRitual.isLightshow())
|
if (imperfectRitual.isLightshow())
|
||||||
getWorld().addWeatherEffect(new EntityLightningBolt(getWorld(), getPos().getX(), getPos().getY() + 2, getPos().getZ()));
|
getWorld().addWeatherEffect(new EntityLightningBolt(getWorld(), getPos().getX(), getPos().getY() + 2, getPos().getZ()));
|
||||||
|
|
|
@ -80,7 +80,6 @@ public class TileMasterRitualStone extends TileEntity implements IMasterRitualSt
|
||||||
@Override
|
@Override
|
||||||
public boolean activateRitual(ItemStack activationCrystal, EntityPlayer activator, Ritual ritual)
|
public boolean activateRitual(ItemStack activationCrystal, EntityPlayer activator, Ritual ritual)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (PlayerHelper.isFakePlayer(activator))
|
if (PlayerHelper.isFakePlayer(activator))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
@ -94,8 +93,7 @@ public class TileMasterRitualStone extends TileEntity implements IMasterRitualSt
|
||||||
int crystalLevel = ((ItemActivationCrystal) activationCrystal.getItem()).getCrystalLevel(activationCrystal);
|
int crystalLevel = ((ItemActivationCrystal) activationCrystal.getItem()).getCrystalLevel(activationCrystal);
|
||||||
if (RitualHelper.canCrystalActivate(ritual, crystalLevel))
|
if (RitualHelper.canCrystalActivate(ritual, crystalLevel))
|
||||||
{
|
{
|
||||||
|
SoulNetwork network = NetworkHelper.getSoulNetwork(crystalOwner);
|
||||||
SoulNetwork network = NetworkHelper.getSoulNetwork(crystalOwner, getWorld());
|
|
||||||
|
|
||||||
if (network.getCurrentEssence() < ritual.getActivationCost())
|
if (network.getCurrentEssence() < ritual.getActivationCost())
|
||||||
{
|
{
|
||||||
|
@ -146,8 +144,6 @@ public class TileMasterRitualStone extends TileEntity implements IMasterRitualSt
|
||||||
if (MinecraftForge.EVENT_BUS.post(event) || event.getResult() == Event.Result.DENY)
|
if (MinecraftForge.EVENT_BUS.post(event) || event.getResult() == Event.Result.DENY)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
SoulNetwork network = NetworkHelper.getSoulNetwork(getOwner(), getWorld());
|
|
||||||
network.syphonAndDamage(getCurrentRitual().getRefreshCost());
|
|
||||||
getCurrentRitual().performRitual(this);
|
getCurrentRitual().performRitual(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue