Fixed Electric Pump lag - was able to completely eliminate system of node cleaning while boosting performance immensely
This commit is contained in:
parent
20dc1ae28a
commit
08914da371
1 changed files with 4 additions and 107 deletions
|
@ -44,9 +44,6 @@ public class TileEntityElectricPump extends TileEntityElectricBlock implements I
|
||||||
/** The nodes that have full sources near them or in them */
|
/** The nodes that have full sources near them or in them */
|
||||||
public Set<Coord4D> recurringNodes = new HashSet<Coord4D>();
|
public Set<Coord4D> recurringNodes = new HashSet<Coord4D>();
|
||||||
|
|
||||||
/** The nodes that have already been sucked up, but are held on to in order to remove dead blocks */
|
|
||||||
public Set<Coord4D> cleaningNodes = new HashSet<Coord4D>();
|
|
||||||
|
|
||||||
public TileEntityElectricPump()
|
public TileEntityElectricPump()
|
||||||
{
|
{
|
||||||
super("ElectricPump", 10000);
|
super("ElectricPump", 10000);
|
||||||
|
@ -129,8 +126,6 @@ public class TileEntityElectricPump extends TileEntityElectricBlock implements I
|
||||||
{
|
{
|
||||||
Mekanism.packetHandler.sendToAllAround(new TileEntityMessage(Coord4D.get(this), getNetworkedData(new ArrayList())), Coord4D.get(this).getTargetPoint(50D));
|
Mekanism.packetHandler.sendToAllAround(new TileEntityMessage(Coord4D.get(this), getNetworkedData(new ArrayList())), Coord4D.get(this).getTargetPoint(50D));
|
||||||
}
|
}
|
||||||
|
|
||||||
clean(true);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -161,6 +156,7 @@ public class TileEntityElectricPump extends TileEntityElectricBlock implements I
|
||||||
List<Coord4D> tempPumpList = Arrays.asList(recurringNodes.toArray(new Coord4D[recurringNodes.size()]));
|
List<Coord4D> tempPumpList = Arrays.asList(recurringNodes.toArray(new Coord4D[recurringNodes.size()]));
|
||||||
Collections.shuffle(tempPumpList);
|
Collections.shuffle(tempPumpList);
|
||||||
|
|
||||||
|
//First see if there are any fluid blocks touching the pump - if so, sucks and adds the location to the recurring list
|
||||||
for(ForgeDirection orientation : ForgeDirection.VALID_DIRECTIONS)
|
for(ForgeDirection orientation : ForgeDirection.VALID_DIRECTIONS)
|
||||||
{
|
{
|
||||||
Coord4D wrapper = Coord4D.get(this).getFromSide(orientation);
|
Coord4D wrapper = Coord4D.get(this).getFromSide(orientation);
|
||||||
|
@ -182,24 +178,8 @@ public class TileEntityElectricPump extends TileEntityElectricBlock implements I
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for(Coord4D wrapper : cleaningNodes)
|
//Finally, go over the recurring list of nodes and see if there is a fluid block available to suck - if not, will iterate around the recurring block, attempt to suck,
|
||||||
{
|
//and then add the adjacent block to the recurring list
|
||||||
if(MekanismUtils.isFluid(worldObj, wrapper.xCoord, wrapper.yCoord, wrapper.zCoord))
|
|
||||||
{
|
|
||||||
if(fluidTank.getFluid() != null && MekanismUtils.getFluid(worldObj, wrapper.xCoord, wrapper.yCoord, wrapper.zCoord).isFluidEqual(fluidTank.getFluid()))
|
|
||||||
{
|
|
||||||
if(take)
|
|
||||||
{
|
|
||||||
setEnergy(getEnergy() - Mekanism.electricPumpUsage);
|
|
||||||
fluidTank.fill(MekanismUtils.getFluid(worldObj, wrapper.xCoord, wrapper.yCoord, wrapper.zCoord), true);
|
|
||||||
worldObj.setBlockToAir(wrapper.xCoord, wrapper.yCoord, wrapper.zCoord);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for(Coord4D wrapper : tempPumpList)
|
for(Coord4D wrapper : tempPumpList)
|
||||||
{
|
{
|
||||||
if(MekanismUtils.isFluid(worldObj, wrapper.xCoord, wrapper.yCoord, wrapper.zCoord))
|
if(MekanismUtils.isFluid(worldObj, wrapper.xCoord, wrapper.yCoord, wrapper.zCoord))
|
||||||
|
@ -217,6 +197,7 @@ public class TileEntityElectricPump extends TileEntityElectricBlock implements I
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Add all the blocks surrounding this recurring node to the recurring node list
|
||||||
for(ForgeDirection orientation : ForgeDirection.VALID_DIRECTIONS)
|
for(ForgeDirection orientation : ForgeDirection.VALID_DIRECTIONS)
|
||||||
{
|
{
|
||||||
Coord4D side = wrapper.getFromSide(orientation);
|
Coord4D side = wrapper.getFromSide(orientation);
|
||||||
|
@ -241,73 +222,12 @@ public class TileEntityElectricPump extends TileEntityElectricBlock implements I
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cleaningNodes.add(wrapper);
|
|
||||||
recurringNodes.remove(wrapper);
|
recurringNodes.remove(wrapper);
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean clean(boolean take)
|
|
||||||
{
|
|
||||||
boolean took = false;
|
|
||||||
|
|
||||||
if(!worldObj.isRemote)
|
|
||||||
{
|
|
||||||
for(Coord4D wrapper : cleaningNodes)
|
|
||||||
{
|
|
||||||
if(MekanismUtils.isDeadFluid(worldObj, wrapper.xCoord, wrapper.yCoord, wrapper.zCoord))
|
|
||||||
{
|
|
||||||
if(fluidTank.getFluid() != null && MekanismUtils.getFluidId(worldObj, wrapper.xCoord, wrapper.yCoord, wrapper.zCoord) == fluidTank.getFluid().fluidID)
|
|
||||||
{
|
|
||||||
took = true;
|
|
||||||
|
|
||||||
if(take)
|
|
||||||
{
|
|
||||||
worldObj.setBlockToAir(wrapper.xCoord, wrapper.yCoord, wrapper.zCoord);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for(Coord4D wrapper : recurringNodes)
|
|
||||||
{
|
|
||||||
if(MekanismUtils.isDeadFluid(worldObj, wrapper.xCoord, wrapper.yCoord, wrapper.zCoord))
|
|
||||||
{
|
|
||||||
if(fluidTank.getFluid() != null && MekanismUtils.getFluidId(worldObj, wrapper.xCoord, wrapper.yCoord, wrapper.zCoord) == fluidTank.getFluid().fluidID)
|
|
||||||
{
|
|
||||||
took = true;
|
|
||||||
|
|
||||||
if(take)
|
|
||||||
{
|
|
||||||
worldObj.setBlockToAir(wrapper.xCoord, wrapper.yCoord, wrapper.zCoord);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for(ForgeDirection orientation : ForgeDirection.VALID_DIRECTIONS)
|
|
||||||
{
|
|
||||||
Coord4D wrapper = Coord4D.get(this).getFromSide(orientation);
|
|
||||||
|
|
||||||
if(MekanismUtils.isDeadFluid(worldObj, wrapper.xCoord, wrapper.yCoord, wrapper.zCoord))
|
|
||||||
{
|
|
||||||
if(fluidTank.getFluid() != null && MekanismUtils.getFluidId(worldObj, wrapper.xCoord, wrapper.yCoord, wrapper.zCoord) == fluidTank.getFluid().fluidID)
|
|
||||||
{
|
|
||||||
took = true;
|
|
||||||
|
|
||||||
if(take)
|
|
||||||
{
|
|
||||||
worldObj.setBlockToAir(wrapper.xCoord, wrapper.yCoord, wrapper.zCoord);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return took;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void handlePacketData(ByteBuf dataStream)
|
public void handlePacketData(ByteBuf dataStream)
|
||||||
{
|
{
|
||||||
|
@ -370,18 +290,6 @@ public class TileEntityElectricPump extends TileEntityElectricBlock implements I
|
||||||
{
|
{
|
||||||
nbtTags.setTag("recurringNodes", recurringList);
|
nbtTags.setTag("recurringNodes", recurringList);
|
||||||
}
|
}
|
||||||
|
|
||||||
NBTTagList cleaningList = new NBTTagList();
|
|
||||||
|
|
||||||
for(Coord4D obj : cleaningNodes)
|
|
||||||
{
|
|
||||||
cleaningList.appendTag(obj.write(new NBTTagCompound()));
|
|
||||||
}
|
|
||||||
|
|
||||||
if(cleaningList.tagCount() != 0)
|
|
||||||
{
|
|
||||||
nbtTags.setTag("cleaningNodes", cleaningList);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -403,16 +311,6 @@ public class TileEntityElectricPump extends TileEntityElectricBlock implements I
|
||||||
recurringNodes.add(Coord4D.read((NBTTagCompound)tagList.getCompoundTagAt(i)));
|
recurringNodes.add(Coord4D.read((NBTTagCompound)tagList.getCompoundTagAt(i)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(nbtTags.hasKey("cleaningNodes"))
|
|
||||||
{
|
|
||||||
NBTTagList tagList = nbtTags.getTagList("cleaningNodes", NBT.TAG_COMPOUND);
|
|
||||||
|
|
||||||
for(int i = 0; i < tagList.tagCount(); i++)
|
|
||||||
{
|
|
||||||
cleaningNodes.add(Coord4D.read((NBTTagCompound)tagList.getCompoundTagAt(i)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -550,7 +448,6 @@ public class TileEntityElectricPump extends TileEntityElectricBlock implements I
|
||||||
public boolean onSneakRightClick(EntityPlayer player, int side)
|
public boolean onSneakRightClick(EntityPlayer player, int side)
|
||||||
{
|
{
|
||||||
recurringNodes.clear();
|
recurringNodes.clear();
|
||||||
cleaningNodes.clear();
|
|
||||||
|
|
||||||
player.addChatMessage(new ChatComponentText(EnumColor.DARK_BLUE + "[Mekanism] " + EnumColor.GREY + MekanismUtils.localize("tooltip.configurator.pumpReset")));
|
player.addChatMessage(new ChatComponentText(EnumColor.DARK_BLUE + "[Mekanism] " + EnumColor.GREY + MekanismUtils.localize("tooltip.configurator.pumpReset")));
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue