correctly save and restore hasPulsar()

tested by saving and restoring a std. aut. gate.
This commit is contained in:
Andrew Hill 2012-09-14 07:37:57 +10:00
parent 6b557f1d99
commit 2df8069c57
2 changed files with 13 additions and 4 deletions

View file

@ -74,7 +74,7 @@ public class GateVanilla extends Gate {
} }
// / INFORMATION // / INFORMATION
private boolean hasPulser() { public boolean hasPulser() {
return pulser != null; return pulser != null;
} }

View file

@ -55,7 +55,10 @@ public class BptBlockPipe extends BptBlock {
if (slot.cpt.hasKey("gate")) { if (slot.cpt.hasKey("gate")) {
int gateId = slot.cpt.getInteger("gate"); int gateId = slot.cpt.getInteger("gate");
requirements.add(new ItemStack(BuildCraftTransport.pipeGate, 1, gateId - 1)); if(slot.cpt.hasKey("hasPulser") && slot.cpt.getBoolean("hasPulser"))
requirements.add(new ItemStack(BuildCraftTransport.pipeGateAutarchic, 1, gateId - 1));
else
requirements.add(new ItemStack(BuildCraftTransport.pipeGate, 1, gateId - 1));
} }
if (BuildCraftCore.itemBptProps[pipeId] != null) if (BuildCraftCore.itemBptProps[pipeId] != null)
@ -93,8 +96,12 @@ public class BptBlockPipe extends BptBlock {
if (slot.cpt.hasKey("gate")) { if (slot.cpt.hasKey("gate")) {
// / TODO: Does not save/load custom gates // / TODO: Does not save/load custom gates
int gateId = slot.cpt.getInteger("gate"); int gateId = slot.cpt.getInteger("gate");
pipe.gate = new GateVanilla(pipe); GateVanilla newGate;
pipe.gate.kind = Gate.GateKind.values()[gateId]; if(slot.cpt.hasKey("hasPulser") && slot.cpt.getBoolean("hasPulser"))
newGate= new GateVanilla(pipe,new ItemStack(BuildCraftTransport.pipeGateAutarchic, 1, gateId - 1));
else
newGate= new GateVanilla(pipe,new ItemStack(BuildCraftTransport.pipeGate, 1, gateId - 1));
pipe.gate = newGate;
for (int i = 0; i < 8; ++i) { for (int i = 0; i < 8; ++i) {
if (slot.cpt.hasKey("trigger" + i)) if (slot.cpt.hasKey("trigger" + i))
@ -134,6 +141,8 @@ public class BptBlockPipe extends BptBlock {
// / TODO: Does not save/load custom gates // / TODO: Does not save/load custom gates
if (pipe.hasGate()) { if (pipe.hasGate()) {
bptSlot.cpt.setInteger("gate", pipe.gate.kind.ordinal()); bptSlot.cpt.setInteger("gate", pipe.gate.kind.ordinal());
if(pipe.gate instanceof GateVanilla)
bptSlot.cpt.setBoolean("hasPulser", ((GateVanilla)pipe.gate).hasPulser());
for (int i = 0; i < 8; ++i) { for (int i = 0; i < 8; ++i) {
if (pipe.activatedTriggers[i] != null) if (pipe.activatedTriggers[i] != null)