Move SoulNetwork to UUID system

*Should* work correctly. As for all major changes, needs to be
thoroughly tested.
This commit is contained in:
Nick 2015-12-28 20:13:11 -08:00
parent 8edb8a45e6
commit 24058d7350
14 changed files with 112 additions and 49 deletions

View file

@ -280,8 +280,7 @@ public class BloodAltar {
isActive = false; isActive = false;
} }
public void update() public void update() {
{
World world = tileAltar.getWorld(); World world = tileAltar.getWorld();
BlockPos pos = tileAltar.getPos(); BlockPos pos = tileAltar.getPos();
@ -387,15 +386,15 @@ public class BloodAltar {
if (itemTag == null) if (itemTag == null)
return; return;
String ownerName = itemTag.getString(Constants.NBT.OWNER_NAME); String ownerUUID = itemTag.getString(Constants.NBT.OWNER_UUID);
if (Strings.isNullOrEmpty(ownerName)) if (Strings.isNullOrEmpty(ownerUUID))
return; return;
if (fluid != null && fluid.amount >= 1) { if (fluid != null && fluid.amount >= 1) {
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(ownerName, world).addLifeEssence(liquidDrained, (int) (item.getMaxEssence(returnedItem.getMetadata()) * this.orbCapacityMultiplier)); int drain = NetworkHelper.getSoulNetwork(ownerUUID, world).addLifeEssence(liquidDrained, (int) (item.getMaxEssence(returnedItem.getMetadata()) * this.orbCapacityMultiplier));
fluid.amount = fluid.amount - drain; fluid.amount = fluid.amount - drain;
@ -403,8 +402,8 @@ public class BloodAltar {
world.spawnParticle(EnumParticleTypes.REDSTONE, pos.getX() + Math.random() - Math.random(), pos.getY() + Math.random() - Math.random(), pos.getZ() + Math.random() - Math.random(), f1, f2, f3); world.spawnParticle(EnumParticleTypes.REDSTONE, pos.getX() + Math.random() - Math.random(), pos.getY() + Math.random() - Math.random(), pos.getZ() + Math.random() - Math.random(), f1, f2, f3);
} }
} }
if (world != null)
world.markBlockForUpdate(pos); world.markBlockForUpdate(pos);
} }
public void checkTier() { public void checkTier() {

View file

@ -8,7 +8,7 @@ public class Constants {
public static class NBT { public static class NBT {
public static final String OWNER_NAME = "ownerName"; public static final String OWNER_UUID = "ownerUUID";
public static final String USES = "uses"; public static final String USES = "uses";
public static final String UNUSABLE = "unusable"; public static final String UNUSABLE = "unusable";
public static final String SACRIFICE = "sacrifice"; public static final String SACRIFICE = "sacrifice";

View file

@ -75,6 +75,8 @@ public class SoulNetwork extends WorldSavedData {
if (event.getResult() != Event.Result.DENY) if (event.getResult() != Event.Result.DENY)
data.setCurrentEssence(newEss); data.setCurrentEssence(newEss);
markDirty();
return newEss - currEss; return newEss - currEss;
} }

View file

@ -8,6 +8,8 @@ import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraftforge.common.MinecraftForge; import net.minecraftforge.common.MinecraftForge;
import java.util.UUID;
public class BindableHelper { public class BindableHelper {
/** /**
@ -20,7 +22,7 @@ public class BindableHelper {
* @return - Whether binding was successful * @return - Whether binding was successful
*/ */
public static boolean checkAndSetItemOwner(ItemStack stack, EntityPlayer player) { public static boolean checkAndSetItemOwner(ItemStack stack, EntityPlayer player) {
return !PlayerHelper.isFakePlayer(player) && checkAndSetItemOwner(stack, player.getGameProfile().getName()); return !PlayerHelper.isFakePlayer(player) && checkAndSetItemOwner(stack, PlayerHelper.getUUIDFromPlayer(player));
} }
/** /**
@ -31,26 +33,33 @@ public class BindableHelper {
* Fires {@link ItemBindEvent}. * Fires {@link ItemBindEvent}.
* *
* @param stack - The ItemStack to bind * @param stack - The ItemStack to bind
* @param ownerName - The username to bind the ItemStack to * @param uuid - The username to bind the ItemStack to
* *
* @return - Whether the binding was successful * @return - Whether the binding was successful
*/ */
public static boolean checkAndSetItemOwner(ItemStack stack, String ownerName) { public static boolean checkAndSetItemOwner(ItemStack stack, String uuid) {
stack = NBTHelper.checkNBT(stack); stack = NBTHelper.checkNBT(stack);
if (!(stack.getItem() instanceof IBindable)) if (!(stack.getItem() instanceof IBindable))
return false; return false;
if (Strings.isNullOrEmpty(stack.getTagCompound().getString(Constants.NBT.OWNER_NAME))) { if (Strings.isNullOrEmpty(stack.getTagCompound().getString(Constants.NBT.OWNER_UUID))) {
MinecraftForge.EVENT_BUS.post(new ItemBindEvent(PlayerHelper.getPlayerFromUsername(ownerName), ownerName, stack)); MinecraftForge.EVENT_BUS.post(new ItemBindEvent(PlayerHelper.getPlayerFromUUID(uuid), uuid, stack));
((IBindable) stack.getItem()).onBind(PlayerHelper.getPlayerFromUsername(ownerName), stack); ((IBindable) stack.getItem()).onBind(PlayerHelper.getPlayerFromUUID(uuid), stack);
stack.getTagCompound().setString(Constants.NBT.OWNER_NAME, ownerName); stack.getTagCompound().setString(Constants.NBT.OWNER_UUID, uuid);
return true; return true;
} }
return true; return true;
} }
/**
* @see BindableHelper#checkAndSetItemOwner(ItemStack, String)
*/
public static boolean checkAndSetItemOwner(ItemStack stack, UUID uuid) {
return checkAndSetItemOwner(stack, uuid.toString());
}
/** /**
* Sets the Owner of the item without checking if it is already bound. * Sets the Owner of the item without checking if it is already bound.
* Also bypasses {@link ItemBindEvent}. * Also bypasses {@link ItemBindEvent}.
@ -61,7 +70,7 @@ public class BindableHelper {
public static void setItemOwner(ItemStack stack, String ownerName) { public static void setItemOwner(ItemStack stack, String ownerName) {
stack = NBTHelper.checkNBT(stack); stack = NBTHelper.checkNBT(stack);
stack.getTagCompound().setString(Constants.NBT.OWNER_NAME, ownerName); stack.getTagCompound().setString(Constants.NBT.OWNER_UUID, ownerName);
} }
/** /**
@ -74,6 +83,19 @@ public class BindableHelper {
public static String getOwnerName(ItemStack stack) { public static String getOwnerName(ItemStack stack) {
stack = NBTHelper.checkNBT(stack); stack = NBTHelper.checkNBT(stack);
return stack.getTagCompound().getString(Constants.NBT.OWNER_NAME); return PlayerHelper.getUsernameFromStack(stack);
}
/**
* Used to safely obtain the UUID of the ItemStack's owner
*
* @param stack - The ItemStack to check the owner of
*
* @return - The UUID of the ItemStack's owner
*/
public static String getOwnerUUID(ItemStack stack) {
stack = NBTHelper.checkNBT(stack);
return stack.getTagCompound().getString(Constants.NBT.OWNER_UUID);
} }
} }

View file

@ -13,6 +13,8 @@ import net.minecraft.world.World;
import net.minecraftforge.common.MinecraftForge; import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.fml.common.eventhandler.Event; import net.minecraftforge.fml.common.eventhandler.Event;
import java.util.UUID;
public class NetworkHelper { public class NetworkHelper {
// Get // Get
@ -20,22 +22,36 @@ public class NetworkHelper {
/** /**
* Gets the SoulNetwork for the player. * Gets the SoulNetwork for the player.
* *
* @param ownerName - The name of the SoulNetwork owner * @param name - The username of the SoulNetwork owner
* @param world - The world * @param world - The world
* *
* @return - The SoulNetwork for the given name. * @return - The SoulNetwork for the given name.
*/ */
public static SoulNetwork getSoulNetwork(String ownerName, World world) { public static SoulNetwork getSoulNetwork(String name, World world) {
SoulNetwork network = (SoulNetwork) world.getMapStorage().loadData(SoulNetwork.class, ownerName); SoulNetwork network = (SoulNetwork) world.getMapStorage().loadData(SoulNetwork.class, name);
if (network == null) { if (network == null) {
network = new SoulNetwork(ownerName); network = new SoulNetwork(name);
world.getMapStorage().setData(ownerName, network); world.getMapStorage().setData(name, network);
} }
return network; return network;
} }
/**
* @see NetworkHelper#getSoulNetwork(String, World)
*/
public static SoulNetwork getSoulNetwork(UUID uuid, World world) {
return getSoulNetwork(PlayerHelper.getUsernameFromUUID(uuid), world);
}
/**
* @see NetworkHelper#getSoulNetwork(String, World)
*/
public static SoulNetwork getSoulNetwork(EntityPlayer player, World world) {
return getSoulNetwork(PlayerHelper.getUUIDFromPlayer(player), world);
}
/** /**
* Gets the current orb tier of the SoulNetwork. * Gets the current orb tier of the SoulNetwork.
* *
@ -79,7 +95,7 @@ public class NetworkHelper {
*/ */
public static boolean syphonFromContainer(ItemStack stack, World world, int toSyphon) { public static boolean syphonFromContainer(ItemStack stack, World world, int toSyphon) {
stack = NBTHelper.checkNBT(stack); stack = NBTHelper.checkNBT(stack);
String ownerName = stack.getTagCompound().getString(Constants.NBT.OWNER_NAME); String ownerName = stack.getTagCompound().getString(Constants.NBT.OWNER_UUID);
if (Strings.isNullOrEmpty(ownerName)) if (Strings.isNullOrEmpty(ownerName))
return false; return false;
@ -122,7 +138,7 @@ public class NetworkHelper {
return false; return false;
stack = NBTHelper.checkNBT(stack); stack = NBTHelper.checkNBT(stack);
String ownerName = stack.getTagCompound().getString(Constants.NBT.OWNER_NAME); String ownerName = stack.getTagCompound().getString(Constants.NBT.OWNER_UUID);
if (!Strings.isNullOrEmpty(ownerName)) { if (!Strings.isNullOrEmpty(ownerName)) {
SoulNetworkEvent.ItemDrainNetworkEvent event = new SoulNetworkEvent.ItemDrainNetworkEvent(player, ownerName, stack, syphon); SoulNetworkEvent.ItemDrainNetworkEvent event = new SoulNetworkEvent.ItemDrainNetworkEvent(player, ownerName, stack, syphon);
@ -149,7 +165,7 @@ public class NetworkHelper {
@Deprecated @Deprecated
public static boolean syphonFromNetworkWhileInContainer(ItemStack stack, int syphon) { public static boolean syphonFromNetworkWhileInContainer(ItemStack stack, int syphon) {
stack = NBTHelper.checkNBT(stack); stack = NBTHelper.checkNBT(stack);
String ownerName = stack.getTagCompound().getString(Constants.NBT.OWNER_NAME); String ownerName = stack.getTagCompound().getString(Constants.NBT.OWNER_UUID);
if (Strings.isNullOrEmpty(ownerName)) if (Strings.isNullOrEmpty(ownerName))
return false; return false;
@ -165,7 +181,7 @@ public class NetworkHelper {
@Deprecated @Deprecated
public static int syphonFromNetwork(ItemStack stack, int syphon) { public static int syphonFromNetwork(ItemStack stack, int syphon) {
stack = NBTHelper.checkNBT(stack); stack = NBTHelper.checkNBT(stack);
String ownerName = stack.getTagCompound().getString(Constants.NBT.OWNER_NAME); String ownerName = stack.getTagCompound().getString(Constants.NBT.OWNER_UUID);
if (!Strings.isNullOrEmpty(ownerName)) if (!Strings.isNullOrEmpty(ownerName))
return syphonFromNetwork(ownerName, syphon); return syphonFromNetwork(ownerName, syphon);

View file

@ -7,6 +7,7 @@ import net.minecraft.item.ItemStack;
import net.minecraft.potion.Potion; import net.minecraft.potion.Potion;
import net.minecraft.potion.PotionEffect; import net.minecraft.potion.PotionEffect;
import net.minecraft.server.MinecraftServer; import net.minecraft.server.MinecraftServer;
import net.minecraftforge.common.UsernameCache;
import net.minecraftforge.common.util.FakePlayer; import net.minecraftforge.common.util.FakePlayer;
import java.util.UUID; import java.util.UUID;
@ -17,7 +18,7 @@ public class PlayerHelper {
private static final Pattern FAKE_PLAYER_PATTERN = Pattern.compile("^(?:\\[.*\\])|(?:ComputerCraft)$"); private static final Pattern FAKE_PLAYER_PATTERN = Pattern.compile("^(?:\\[.*\\])|(?:ComputerCraft)$");
public static String getUsernameFromPlayer(EntityPlayer player) { public static String getUsernameFromPlayer(EntityPlayer player) {
return player.getGameProfile().getName(); return UsernameCache.getLastKnownUsername(getUUIDFromPlayer(player));
} }
public static EntityPlayer getPlayerFromUsername(String username) { public static EntityPlayer getPlayerFromUsername(String username) {
@ -27,10 +28,32 @@ public class PlayerHelper {
return MinecraftServer.getServer().getConfigurationManager().getPlayerByUsername(username); return MinecraftServer.getServer().getConfigurationManager().getPlayerByUsername(username);
} }
public static EntityPlayer getPlayerFromUUID(String uuid) {
return getPlayerFromUsername(getUsernameFromUUID(uuid));
}
public static EntityPlayer getPlayerFromUUID(UUID uuid) {
return getPlayerFromUsername(getUsernameFromUUID(uuid));
}
public static UUID getUUIDFromPlayer(EntityPlayer player) { public static UUID getUUIDFromPlayer(EntityPlayer player) {
return player.getGameProfile().getId(); return player.getGameProfile().getId();
} }
public static String getUsernameFromUUID(String uuid) {
return UsernameCache.getLastKnownUsername(UUID.fromString(uuid));
}
public static String getUsernameFromUUID(UUID uuid) {
return UsernameCache.getLastKnownUsername(uuid);
}
public static String getUsernameFromStack(ItemStack stack) {
stack = NBTHelper.checkNBT(stack);
return PlayerHelper.getUsernameFromUUID(stack.getTagCompound().getString(Constants.NBT.OWNER_UUID));
}
public static boolean isFakePlayer(EntityPlayer player) { public static boolean isFakePlayer(EntityPlayer player) {
return player instanceof FakePlayer || FAKE_PLAYER_PATTERN.matcher(getUsernameFromPlayer(player)).matches(); return player instanceof FakePlayer || FAKE_PLAYER_PATTERN.matcher(getUsernameFromPlayer(player)).matches();
} }
@ -38,8 +61,8 @@ public class PlayerHelper {
public static void causeNauseaToPlayer(ItemStack stack) { public static void causeNauseaToPlayer(ItemStack stack) {
stack = NBTHelper.checkNBT(stack); stack = NBTHelper.checkNBT(stack);
if (!Strings.isNullOrEmpty(stack.getTagCompound().getString(Constants.NBT.OWNER_NAME))) if (!Strings.isNullOrEmpty(stack.getTagCompound().getString(Constants.NBT.OWNER_UUID)))
causeNauseaToPlayer(stack.getTagCompound().getString(Constants.NBT.OWNER_NAME)); causeNauseaToPlayer(stack.getTagCompound().getString(Constants.NBT.OWNER_UUID));
} }
public static void causeNauseaToPlayer(String ownerName) { public static void causeNauseaToPlayer(String ownerName) {

View file

@ -7,6 +7,7 @@ import WayofTime.bloodmagic.api.iface.IBindable;
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.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;
@ -35,7 +36,7 @@ public class ItemBindable extends Item implements IBindable {
public static boolean syphonBatteries(ItemStack stack, EntityPlayer player, int damageToBeDone) { public static boolean syphonBatteries(ItemStack stack, EntityPlayer player, int damageToBeDone) {
if (!player.worldObj.isRemote) { if (!player.worldObj.isRemote) {
return NetworkHelper.syphonAndDamage(NetworkHelper.getSoulNetwork(BindableHelper.getOwnerName(stack), player.worldObj), damageToBeDone); return NetworkHelper.syphonAndDamage(NetworkHelper.getSoulNetwork(player, player.worldObj), damageToBeDone);
} else { } else {
double posX = player.posX; double posX = player.posX;
double posY = player.posY; double posY = player.posY;
@ -76,8 +77,8 @@ public class ItemBindable extends Item implements IBindable {
public void addInformation(ItemStack stack, EntityPlayer player, List<String> tooltip, boolean advanced) { public void addInformation(ItemStack stack, EntityPlayer player, List<String> tooltip, boolean advanced) {
NBTHelper.checkNBT(stack); NBTHelper.checkNBT(stack);
if (!Strings.isNullOrEmpty(stack.getTagCompound().getString(Constants.NBT.OWNER_NAME))) if (!Strings.isNullOrEmpty(stack.getTagCompound().getString(Constants.NBT.OWNER_UUID)))
tooltip.add(TextHelper.getFormattedText(String.format(StatCollector.translateToLocal("tooltip.BloodMagic.currentOwner"), stack.getTagCompound().getString(Constants.NBT.OWNER_NAME)))); tooltip.add(TextHelper.getFormattedText(String.format(StatCollector.translateToLocal("tooltip.BloodMagic.currentOwner"), PlayerHelper.getUsernameFromStack(stack))));
} }
@Override @Override
@ -129,7 +130,7 @@ public class ItemBindable extends Item implements IBindable {
public String getBindableOwner(ItemStack stack) { public String getBindableOwner(ItemStack stack) {
stack = NBTHelper.checkNBT(stack); stack = NBTHelper.checkNBT(stack);
return stack.getTagCompound().getString(Constants.NBT.OWNER_NAME); return stack.getTagCompound().getString(Constants.NBT.OWNER_UUID);
} }
// IBindable // IBindable

View file

@ -54,16 +54,16 @@ public class ItemBloodOrb extends ItemBindable implements IBloodOrb, IBindable {
if (PlayerHelper.isFakePlayer(player)) if (PlayerHelper.isFakePlayer(player))
return stack; return stack;
if (Strings.isNullOrEmpty(stack.getTagCompound().getString(Constants.NBT.OWNER_NAME))) if (Strings.isNullOrEmpty(stack.getTagCompound().getString(Constants.NBT.OWNER_UUID)))
return stack; return stack;
if (world.isRemote) if (world.isRemote)
return stack; return stack;
if (stack.getTagCompound().getString(Constants.NBT.OWNER_NAME).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_NAME), world), getOrbLevel(stack.getItemDamage())); NetworkHelper.setMaxOrb(NetworkHelper.getSoulNetwork(stack.getTagCompound().getString(Constants.NBT.OWNER_UUID), world), getOrbLevel(stack.getItemDamage()));
NetworkHelper.getSoulNetwork(stack.getTagCompound().getString(Constants.NBT.OWNER_NAME), world).addLifeEssence(200, getMaxEssence(stack.getItemDamage())); NetworkHelper.getSoulNetwork(stack.getTagCompound().getString(Constants.NBT.OWNER_UUID), world).addLifeEssence(200, getMaxEssence(stack.getItemDamage()));
hurtPlayer(player, 200); hurtPlayer(player, 200);
return stack; return stack;
} }

View file

@ -73,7 +73,7 @@ public class ItemPackSelfSacrifice extends ItemArmor implements IAltarManipulato
boolean shouldSyphon = player.getHealth() / player.getMaxHealth() > HEALTHREQ && getStoredLP(stack) < CAPACITY; boolean shouldSyphon = player.getHealth() / player.getMaxHealth() > HEALTHREQ && getStoredLP(stack) < CAPACITY;
if (shouldSyphon & world.getTotalWorldTime() % INTERVAL == 0) { if (shouldSyphon & world.getTotalWorldTime() % INTERVAL == 0) {
NetworkHelper.getSoulNetwork(player.getName(), world).hurtPlayer(1.0F); NetworkHelper.getSoulNetwork(player, world).hurtPlayer(1.0F);
addLP(stack, CONVERSION); addLP(stack, CONVERSION);
} }
} }

View file

@ -32,7 +32,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.getOwnerName(stack), world).getCurrentEssence(); int currentEssence = NetworkHelper.getSoulNetwork(BindableHelper.getOwnerUUID(stack), world).getCurrentEssence();
if (position == null) { if (position == null) {
ChatUtil.sendNoSpam(player, new ChatComponentText(TextHelper.localize(tooltipBase + "currentEssence", currentEssence))); ChatUtil.sendNoSpam(player, new ChatComponentText(TextHelper.localize(tooltipBase + "currentEssence", currentEssence)));

View file

@ -32,7 +32,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.getOwnerName(stack), world).getCurrentEssence(); int currentEssence = NetworkHelper.getSoulNetwork(BindableHelper.getOwnerUUID(stack), world).getCurrentEssence();
if (position == null) { if (position == null) {
ChatUtil.sendNoSpam(player, new ChatComponentText(TextHelper.localize(tooltipBase + "currentEssence", currentEssence))); ChatUtil.sendNoSpam(player, new ChatComponentText(TextHelper.localize(tooltipBase + "currentEssence", currentEssence)));

View file

@ -22,7 +22,7 @@ public class RitualTest extends Ritual {
@Override @Override
public void performRitual(IMasterRitualStone masterRitualStone) { public void performRitual(IMasterRitualStone masterRitualStone) {
EntityPlayer player = PlayerHelper.getPlayerFromUsername(masterRitualStone.getOwner()); EntityPlayer player = PlayerHelper.getPlayerFromUUID(masterRitualStone.getOwner());
if (player != null) if (player != null)
player.addChatComponentMessage(new ChatComponentText("effect performed")); player.addChatComponentMessage(new ChatComponentText("effect performed"));
@ -30,7 +30,7 @@ public class RitualTest extends Ritual {
@Override @Override
public void stopRitual(IMasterRitualStone masterRitualStone, BreakType breakType) { public void stopRitual(IMasterRitualStone masterRitualStone, BreakType breakType) {
EntityPlayer player = PlayerHelper.getPlayerFromUsername(masterRitualStone.getOwner()); EntityPlayer player = PlayerHelper.getPlayerFromUUID(masterRitualStone.getOwner());
if (player != null) if (player != null)
player.addChatComponentMessage(new ChatComponentText("ritual stopped - " + breakType.name())); player.addChatComponentMessage(new ChatComponentText("ritual stopped - " + breakType.name()));

View file

@ -20,7 +20,7 @@ public class TileImperfectRitualStone extends TileEntity implements IImperfectRi
public boolean performRitual(World world, BlockPos pos, ImperfectRitual imperfectRitual, EntityPlayer player) { public boolean performRitual(World world, BlockPos pos, ImperfectRitual imperfectRitual, EntityPlayer player) {
if (imperfectRitual != null && ImperfectRitualRegistry.ritualEnabled(imperfectRitual)) { if (imperfectRitual != null && ImperfectRitualRegistry.ritualEnabled(imperfectRitual)) {
NetworkHelper.getSoulNetwork(player.getDisplayNameString(), world).syphonAndDamage(imperfectRitual.getActivationCost()); NetworkHelper.getSoulNetwork(player, world).syphonAndDamage(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()));

View file

@ -53,7 +53,7 @@ public class TileMasterRitualStone extends TileEntity implements IMasterRitualSt
@Override @Override
public void readFromNBT(NBTTagCompound tag) { public void readFromNBT(NBTTagCompound tag) {
owner = tag.getString(Constants.NBT.OWNER_NAME); owner = tag.getString(Constants.NBT.OWNER_UUID);
currentRitual = RitualRegistry.getRitualForId(tag.getString(Constants.NBT.CURRENT_RITUAL)); currentRitual = RitualRegistry.getRitualForId(tag.getString(Constants.NBT.CURRENT_RITUAL));
active = tag.getBoolean(Constants.NBT.IS_RUNNING); active = tag.getBoolean(Constants.NBT.IS_RUNNING);
activeTime = tag.getInteger(Constants.NBT.RUNTIME); activeTime = tag.getInteger(Constants.NBT.RUNTIME);
@ -62,7 +62,7 @@ public class TileMasterRitualStone extends TileEntity implements IMasterRitualSt
@Override @Override
public void writeToNBT(NBTTagCompound tag) { public void writeToNBT(NBTTagCompound tag) {
String ritualId = RitualRegistry.getIdForRitual(getCurrentRitual()); String ritualId = RitualRegistry.getIdForRitual(getCurrentRitual());
tag.setString(Constants.NBT.OWNER_NAME, Strings.isNullOrEmpty(getOwner()) ? "" : getOwner()); tag.setString(Constants.NBT.OWNER_UUID, Strings.isNullOrEmpty(getOwner()) ? "" : getOwner());
tag.setString(Constants.NBT.CURRENT_RITUAL, Strings.isNullOrEmpty(ritualId) ? "" : ritualId); tag.setString(Constants.NBT.CURRENT_RITUAL, Strings.isNullOrEmpty(ritualId) ? "" : ritualId);
tag.setBoolean(Constants.NBT.IS_RUNNING, isActive()); tag.setBoolean(Constants.NBT.IS_RUNNING, isActive());
tag.setInteger(Constants.NBT.RUNTIME, getActiveTime()); tag.setInteger(Constants.NBT.RUNTIME, getActiveTime());
@ -75,14 +75,14 @@ public class TileMasterRitualStone extends TileEntity implements IMasterRitualSt
return false; return false;
activationCrystal = NBTHelper.checkNBT(activationCrystal); activationCrystal = NBTHelper.checkNBT(activationCrystal);
String crystalOwner = activationCrystal.getTagCompound().getString(Constants.NBT.OWNER_NAME); String crystalOwner = activationCrystal.getTagCompound().getString(Constants.NBT.OWNER_UUID);
if (!Strings.isNullOrEmpty(crystalOwner) && ritual != null) { if (!Strings.isNullOrEmpty(crystalOwner) && ritual != null) {
if (activationCrystal.getItem() instanceof ItemActivationCrystal) { if (activationCrystal.getItem() instanceof ItemActivationCrystal) {
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(activator.getDisplayNameString(), getWorld()); SoulNetwork network = NetworkHelper.getSoulNetwork(activator, getWorld());
if (network.getCurrentEssence() < ritual.getActivationCost()) { if (network.getCurrentEssence() < ritual.getActivationCost()) {
ChatUtil.sendNoSpamUnloc(activator, "chat.BloodMagic.ritual.weak"); ChatUtil.sendNoSpamUnloc(activator, "chat.BloodMagic.ritual.weak");
@ -103,7 +103,7 @@ public class TileMasterRitualStone extends TileEntity implements IMasterRitualSt
network.syphon(ritual.getActivationCost()); network.syphon(ritual.getActivationCost());
this.active = true; this.active = true;
this.owner = activator.getDisplayNameString(); this.owner = PlayerHelper.getUUIDFromPlayer(activator).toString();
this.currentRitual = ritual; this.currentRitual = ritual;
return true; return true;