Added PneumaticCraft rotation support

This commit is contained in:
LemADEC 2017-01-22 17:33:50 +01:00
parent a93c93a289
commit 7fde3397cc
3 changed files with 203 additions and 1 deletions

View file

@ -0,0 +1,195 @@
package cr0s.warpdrive.compat;
import cr0s.warpdrive.WarpDrive;
import cr0s.warpdrive.api.IBlockTransformer;
import cr0s.warpdrive.api.ITransformation;
import cr0s.warpdrive.config.WarpDriveConfig;
import net.minecraft.block.Block;
import net.minecraft.nbt.NBTBase;
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.nbt.NBTTagList;
import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.ChunkCoordinates;
public class CompatPneumaticCraft implements IBlockTransformer {
private static Class<?> classTileEntityBase;
public static void register() {
try {
classTileEntityBase = Class.forName("pneumaticCraft.common.tileentity.TileEntityBase");
WarpDriveConfig.registerBlockTransformer("PneumaticCraft", new CompatPneumaticCraft());
} catch(ClassNotFoundException exception) {
exception.printStackTrace();
}
}
@Override
public boolean isApplicable(final Block block, final int metadata, final TileEntity tileEntity) {
WarpDrive.logger.info("isApplicable " + classTileEntityBase.isInstance(tileEntity));
return classTileEntityBase.isInstance(tileEntity);
}
@Override
public boolean isJumpReady(final Block block, final int metadata, final TileEntity tileEntity, StringBuilder reason) {
return true;
}
@Override
public NBTBase saveExternals(final TileEntity tileEntity) {
return null;
}
@Override
public void remove(TileEntity tileEntity) {
// nothing to do
}
private static final byte[] mrotForgeDirection = { 0, 1, 5, 4, 2, 3, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 };
private static final byte[] mrotTextRotation = { 1, 2, 3, 0 };
private static final byte[] mrotDoor = { 0, 1, 5, 4, 2, 3, 6, 7, 11, 10, 8, 9, 12, 13, 14, 15 };
@Override
public int rotate(final Block block, final int metadata, NBTTagCompound nbtTileEntity, final ITransformation transformation) {
byte rotationSteps = transformation.getRotationSteps();
if ( rotationSteps == 0
&& !nbtTileEntity.hasKey("valveX")
&& !nbtTileEntity.hasKey("multiBlockX")) {
return metadata;
}
// hoppers
if (nbtTileEntity.hasKey("inputDir")) {
int inputDir = nbtTileEntity.getInteger("inputDir");
switch (rotationSteps) {
case 1:
nbtTileEntity.setInteger("inputDir", mrotForgeDirection[inputDir]);
return mrotForgeDirection[metadata];
case 2:
nbtTileEntity.setInteger("inputDir", mrotForgeDirection[mrotForgeDirection[inputDir]]);
return mrotForgeDirection[mrotForgeDirection[metadata]];
case 3:
nbtTileEntity.setInteger("inputDir", mrotForgeDirection[mrotForgeDirection[mrotForgeDirection[inputDir]]]);
return mrotForgeDirection[mrotForgeDirection[mrotForgeDirection[metadata]]];
default:
return metadata;
}
}
// Aphorism signs
if (nbtTileEntity.hasKey("textRotation")) {
int textRotation = nbtTileEntity.getInteger("textRotation");
switch (rotationSteps) {
case 1:
nbtTileEntity.setInteger("textRotation", mrotTextRotation[textRotation]);
return mrotForgeDirection[metadata];
case 2:
nbtTileEntity.setInteger("textRotation", mrotTextRotation[mrotTextRotation[textRotation]]);
return mrotForgeDirection[mrotForgeDirection[metadata]];
case 3:
nbtTileEntity.setInteger("textRotation", mrotTextRotation[mrotTextRotation[mrotTextRotation[textRotation]]]);
return mrotForgeDirection[mrotForgeDirection[mrotForgeDirection[metadata]]];
default:
return metadata;
}
}
// door base
if (nbtTileEntity.hasKey("orientation")) {
int orientation = nbtTileEntity.getInteger("orientation");
switch (rotationSteps) {
case 1:
nbtTileEntity.setInteger("orientation", mrotTextRotation[orientation]);
return metadata;
case 2:
nbtTileEntity.setInteger("orientation", mrotTextRotation[mrotTextRotation[orientation]]);
return metadata;
case 3:
nbtTileEntity.setInteger("orientation", mrotTextRotation[mrotTextRotation[mrotTextRotation[orientation]]]);
return metadata;
default:
return metadata;
}
}
// door
if (nbtTileEntity.getString("id").equals("TileEntityPneumaticDoor")) {
switch (rotationSteps) {
case 1:
return mrotDoor[metadata];
case 2:
return mrotDoor[mrotDoor[metadata]];
case 3:
return mrotDoor[mrotDoor[mrotDoor[metadata]]];
default:
return metadata;
}
}
// pressure chamber wall, pressure chamber window, pressure chamber interface
if (nbtTileEntity.hasKey("valveX")) {
WarpDrive.logger.info("hasKey valveX");
ChunkCoordinates target = transformation.apply(
nbtTileEntity.getInteger("valveX"),
nbtTileEntity.getInteger("valveY"),
nbtTileEntity.getInteger("valveZ"));
nbtTileEntity.setInteger("valveX", target.posX);
nbtTileEntity.setInteger("valveY", target.posY);
nbtTileEntity.setInteger("valveZ", target.posZ);
// use default metadata rotation
}
// pressure chamber valve
if (nbtTileEntity.hasKey("multiBlockX")) {
ChunkCoordinates sourceMin = new ChunkCoordinates(
nbtTileEntity.getInteger("multiBlockX"),
nbtTileEntity.getInteger("multiBlockY"),
nbtTileEntity.getInteger("multiBlockZ"));
int multiBlockSize = nbtTileEntity.getInteger("multiBlockSize");
ChunkCoordinates sourceMax = new ChunkCoordinates(
sourceMin.posX + multiBlockSize - 1,
sourceMin.posY + multiBlockSize - 1,
sourceMin.posZ + multiBlockSize - 1);
ChunkCoordinates target1 = transformation.apply(sourceMin);
ChunkCoordinates target2 = transformation.apply(sourceMax);
nbtTileEntity.setInteger("multiBlockX", Math.min(target1.posX, target2.posX));
nbtTileEntity.setInteger("multiBlockY", Math.min(target1.posY, target2.posY));
nbtTileEntity.setInteger("multiBlockZ", Math.min(target1.posZ, target2.posZ));
NBTTagList tagListOld = nbtTileEntity.getTagList("Valves", 10);
NBTTagList tagListNew = new NBTTagList();
for (int index = 0; index < tagListOld.tagCount(); index++) {
NBTTagCompound tagCompound = tagListOld.getCompoundTagAt(index);
if (tagCompound != null) {
ChunkCoordinates coordinates = transformation.apply(
tagCompound.getInteger("xCoord"),
tagCompound.getInteger("yCoord"),
tagCompound.getInteger("zCoord"));
tagCompound.setInteger("xCoord", coordinates.posX);
tagCompound.setInteger("yCoord", coordinates.posY);
tagCompound.setInteger("zCoord", coordinates.posZ);
tagListNew.appendTag(tagCompound);
}
}
nbtTileEntity.setTag("Valves", tagListNew);
// use default metadata rotation
}
// all other tile entities: security station, programmer, pneumatic dynamo, charging station, air cannon, elevator caller, air compressor
switch (rotationSteps) {
case 1:
return mrotForgeDirection[metadata];
case 2:
return mrotForgeDirection[mrotForgeDirection[metadata]];
case 3:
return mrotForgeDirection[mrotForgeDirection[mrotForgeDirection[metadata]]];
default:
return metadata;
}
}
@Override
public void restoreExternals(TileEntity tileEntity, ITransformation transformation, NBTBase nbtBase) {
// nothing to do
}
}

View file

@ -142,6 +142,7 @@ public class Dictionary {
config.get("block_tags", "OpenComputers:case3" , "PlaceLatest").getString(); config.get("block_tags", "OpenComputers:case3" , "PlaceLatest").getString();
config.get("block_tags", "OpenComputers:caseCreative" , "PlaceLatest").getString(); config.get("block_tags", "OpenComputers:caseCreative" , "PlaceLatest").getString();
config.get("block_tags", "OpenComputers:keyboard" , "PlaceLatest").getString(); config.get("block_tags", "OpenComputers:keyboard" , "PlaceLatest").getString();
config.get("block_tags", "PneumaticCraft:pressureChamberValve" , "PlaceEarlier").getString();
config.get("block_tags", "StargateTech2:block.shieldEmitter" , "PlaceLater StopMining").getString(); config.get("block_tags", "StargateTech2:block.shieldEmitter" , "PlaceLater StopMining").getString();
config.get("block_tags", "StargateTech2:block.shieldController" , "PlaceNormal StopMining").getString(); config.get("block_tags", "StargateTech2:block.shieldController" , "PlaceNormal StopMining").getString();
config.get("block_tags", "StargateTech2:block.shield" , "PlaceNormal StopMining").getString(); config.get("block_tags", "StargateTech2:block.shield" , "PlaceNormal StopMining").getString();

View file

@ -114,6 +114,7 @@ public class WarpDriveConfig {
public static boolean LOGGING_BREAK_PLACE = false; public static boolean LOGGING_BREAK_PLACE = false;
public static boolean LOGGING_FORCEFIELD = false; public static boolean LOGGING_FORCEFIELD = false;
public static boolean LOGGING_FORCEFIELD_REGISTRY = false; public static boolean LOGGING_FORCEFIELD_REGISTRY = false;
public static boolean LOGGING_ACCELERATOR = false;
// Planets // Planets
public static Planet[] PLANETS = null; public static Planet[] PLANETS = null;
@ -164,7 +165,7 @@ public class WarpDriveConfig {
// Ship Scanner // Ship Scanner
public static int SS_MAX_ENERGY_STORED = 500000000; public static int SS_MAX_ENERGY_STORED = 500000000;
public static int SS_ENERGY_PER_BLOCK_SCAN = 100; // eU per block of ship volume (including air) public static int SS_ENERGY_PER_BLOCK_SCAN = 100;
public static int SS_ENERGY_PER_BLOCK_DEPLOY = 5000; public static int SS_ENERGY_PER_BLOCK_DEPLOY = 5000;
public static int SS_MAX_DEPLOY_RADIUS_BLOCKS = 50; public static int SS_MAX_DEPLOY_RADIUS_BLOCKS = 50;
public static int SS_SEARCH_INTERVAL_TICKS = 20; public static int SS_SEARCH_INTERVAL_TICKS = 20;
@ -407,6 +408,7 @@ public class WarpDriveConfig {
LOGGING_BREAK_PLACE = config.get("logging", "enable_break_place_logs", LOGGING_BREAK_PLACE, "Detailed break/place event logs to help debug the mod, enable it before reporting a bug").getBoolean(false); LOGGING_BREAK_PLACE = config.get("logging", "enable_break_place_logs", LOGGING_BREAK_PLACE, "Detailed break/place event logs to help debug the mod, enable it before reporting a bug").getBoolean(false);
LOGGING_FORCEFIELD = config.get("logging", "enable_forcefield_logs", LOGGING_FORCEFIELD, "Detailed forcefield logs to help debug the mod, enable it before reporting a bug").getBoolean(false); LOGGING_FORCEFIELD = config.get("logging", "enable_forcefield_logs", LOGGING_FORCEFIELD, "Detailed forcefield logs to help debug the mod, enable it before reporting a bug").getBoolean(false);
LOGGING_FORCEFIELD_REGISTRY = config.get("logging", "enable_forcefield_registry_logs", LOGGING_FORCEFIELD_REGISTRY, "ForceField registry logs, enable it to dump forcefield registry updates").getBoolean(false); LOGGING_FORCEFIELD_REGISTRY = config.get("logging", "enable_forcefield_registry_logs", LOGGING_FORCEFIELD_REGISTRY, "ForceField registry logs, enable it to dump forcefield registry updates").getBoolean(false);
LOGGING_ACCELERATOR = config.get("logging", "enable_accelerator_logs", LOGGING_ACCELERATOR, "Detailed accelerator logs to help debug the mod, enable it before reporting a bug").getBoolean(false);
// Planets // Planets
{ {
@ -864,6 +866,10 @@ public class WarpDriveConfig {
if (isNaturaLoaded) { if (isNaturaLoaded) {
CompatNatura.register(); CompatNatura.register();
} }
boolean isPneumaticCraftLoaded = Loader.isModLoaded("PneumaticCraft");
if (isPneumaticCraftLoaded) {
CompatPneumaticCraft.register();
}
boolean isRedstonePasteLoaded = Loader.isModLoaded("RedstonePasteMod"); boolean isRedstonePasteLoaded = Loader.isModLoaded("RedstonePasteMod");
if (isRedstonePasteLoaded) { if (isRedstonePasteLoaded) {
CompatRedstonePaste.register(); CompatRedstonePaste.register();