Added PneumaticCraft rotation support
This commit is contained in:
parent
a93c93a289
commit
7fde3397cc
3 changed files with 203 additions and 1 deletions
195
src/main/java/cr0s/warpdrive/compat/CompatPneumaticCraft.java
Normal file
195
src/main/java/cr0s/warpdrive/compat/CompatPneumaticCraft.java
Normal 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
|
||||||
|
}
|
||||||
|
}
|
|
@ -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();
|
||||||
|
|
|
@ -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();
|
||||||
|
|
Loading…
Add table
Reference in a new issue