Liquid Pipes do a full update periodically for client sync
Added config option in BuildCraftCore regarding long update period Added to core as it may be used for other things in future too
This commit is contained in:
parent
f23ddb476a
commit
7d8efe6296
2 changed files with 13 additions and 5 deletions
|
@ -92,6 +92,8 @@ public class BuildCraftCore {
|
||||||
|
|
||||||
public static int updateFactor = 10;
|
public static int updateFactor = 10;
|
||||||
|
|
||||||
|
public static long longUpdateFactor = 40;
|
||||||
|
|
||||||
public static BuildCraftConfiguration mainConfiguration;
|
public static BuildCraftConfiguration mainConfiguration;
|
||||||
|
|
||||||
public static TreeMap<BlockIndex, PacketUpdate> bufferedDescriptions = new TreeMap<BlockIndex, PacketUpdate>();
|
public static TreeMap<BlockIndex, PacketUpdate> bufferedDescriptions = new TreeMap<BlockIndex, PacketUpdate>();
|
||||||
|
@ -189,6 +191,10 @@ public class BuildCraftCore {
|
||||||
factor.comment = "increasing this number will decrease network update frequency, useful for overloaded servers";
|
factor.comment = "increasing this number will decrease network update frequency, useful for overloaded servers";
|
||||||
updateFactor = factor.getInt(10);
|
updateFactor = factor.getInt(10);
|
||||||
|
|
||||||
|
Property longFactor = BuildCraftCore.mainConfiguration.get( Configuration.CATEGORY_GENERAL,"network.stateRefreshPeriod", 40);
|
||||||
|
longFactor.comment = "delay between full client sync packets, increasing it saves bandwidth, decreasing makes for better client syncronization.";
|
||||||
|
longUpdateFactor = longFactor.getInt(40);
|
||||||
|
|
||||||
String powerFrameworkClassName = "buildcraft.energy.PneumaticPowerFramework";
|
String powerFrameworkClassName = "buildcraft.energy.PneumaticPowerFramework";
|
||||||
if (!forcePneumaticPower)
|
if (!forcePneumaticPower)
|
||||||
{
|
{
|
||||||
|
|
|
@ -152,6 +152,7 @@ public class PipeTransportLiquids extends PipeTransport implements ITankContaine
|
||||||
private final short[] outputCooldown = new short[] {0, 0, 0, 0, 0, 0 };
|
private final short[] outputCooldown = new short[] {0, 0, 0, 0, 0, 0 };
|
||||||
|
|
||||||
private final SafeTimeTracker tracker = new SafeTimeTracker();
|
private final SafeTimeTracker tracker = new SafeTimeTracker();
|
||||||
|
private int clientSyncCounter = 0;
|
||||||
|
|
||||||
|
|
||||||
public PipeTransportLiquids() {
|
public PipeTransportLiquids() {
|
||||||
|
@ -196,7 +197,12 @@ public class PipeTransportLiquids extends PipeTransport implements ITankContaine
|
||||||
|
|
||||||
if (tracker.markTimeIfDelay(worldObj, BuildCraftCore.updateFactor)) {
|
if (tracker.markTimeIfDelay(worldObj, BuildCraftCore.updateFactor)) {
|
||||||
|
|
||||||
PacketLiquidUpdate packet = computeLiquidUpdate(false, true);
|
boolean init = false;
|
||||||
|
if(++clientSyncCounter > BuildCraftCore.longUpdateFactor){
|
||||||
|
clientSyncCounter = 0;
|
||||||
|
init = true;
|
||||||
|
}
|
||||||
|
PacketLiquidUpdate packet = computeLiquidUpdate(init, true);
|
||||||
if(packet != null){
|
if(packet != null){
|
||||||
CoreProxy.proxy.sendToPlayers(packet.getPacket(), worldObj, xCoord, yCoord, zCoord, DefaultProps.PIPE_CONTENTS_RENDER_DIST);
|
CoreProxy.proxy.sendToPlayers(packet.getPacket(), worldObj, xCoord, yCoord, zCoord, DefaultProps.PIPE_CONTENTS_RENDER_DIST);
|
||||||
}
|
}
|
||||||
|
@ -297,10 +303,6 @@ public class PipeTransportLiquids extends PipeTransport implements ITankContaine
|
||||||
public void sendDescriptionPacket() {
|
public void sendDescriptionPacket() {
|
||||||
super.sendDescriptionPacket();
|
super.sendDescriptionPacket();
|
||||||
|
|
||||||
PacketLiquidUpdate packet = computeLiquidUpdate(true, false);
|
|
||||||
if(packet != null){
|
|
||||||
CoreProxy.proxy.sendToPlayers(packet.getPacket(), worldObj, xCoord, yCoord, zCoord, DefaultProps.PIPE_CONTENTS_RENDER_DIST);
|
|
||||||
}
|
|
||||||
initClient = 6;
|
initClient = 6;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue