diff options
author | Glease <4586901+Glease@users.noreply.github.com> | 2022-09-01 12:01:50 +0800 |
---|---|---|
committer | Glease <4586901+Glease@users.noreply.github.com> | 2022-09-01 12:40:28 +0800 |
commit | 1bc9006d7bbe5c503f36364b2c4dce2a29293e3a (patch) | |
tree | 5a6cb5230f93739fee59310b41dbe540c951ce63 /src/main/java/net/glease/ggfab/GGUtils.java | |
parent | b0698efc456a3dc92a8b7a059b01433d461866e3 (diff) | |
download | GT5-Unofficial-1bc9006d7bbe5c503f36364b2c4dce2a29293e3a.tar.gz GT5-Unofficial-1bc9006d7bbe5c503f36364b2c4dce2a29293e3a.tar.bz2 GT5-Unofficial-1bc9006d7bbe5c503f36364b2c4dce2a29293e3a.zip |
add skeleton code
this should be the least common code for all the branches I work on...
Diffstat (limited to 'src/main/java/net/glease/ggfab/GGUtils.java')
-rw-r--r-- | src/main/java/net/glease/ggfab/GGUtils.java | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/src/main/java/net/glease/ggfab/GGUtils.java b/src/main/java/net/glease/ggfab/GGUtils.java new file mode 100644 index 0000000000..ea34952971 --- /dev/null +++ b/src/main/java/net/glease/ggfab/GGUtils.java @@ -0,0 +1,39 @@ +package net.glease.ggfab; + +import gregtech.api.interfaces.metatileentity.IMetaTileEntity; +import gregtech.api.interfaces.tileentity.IGregTechTileEntity; +import net.minecraft.util.ChunkCoordinates; +import net.minecraftforge.common.util.ForgeDirection; + +import java.util.StringJoiner; + +public class GGUtils { + public static boolean isValidTile(IGregTechTileEntity tile) { + return tile != null && !tile.isDead() && tile.getMetaTileEntity() != null && tile.getMetaTileEntity().getBaseMetaTileEntity() == tile; + } + public static boolean isValidTile(IMetaTileEntity mte) { + return mte != null && mte.getBaseMetaTileEntity() != null && mte.getBaseMetaTileEntity().getMetaTileEntity() == mte && !mte.getBaseMetaTileEntity().isDead(); + } + public static ChunkCoordinates translate(ChunkCoordinates origin, ForgeDirection direction) { + return new ChunkCoordinates(origin.posX + direction.offsetX, origin.posY + direction.offsetY, origin.posZ + direction.offsetZ); + } + + public static String formatTileInfo(String prefix, IMetaTileEntity mte, String delimiter, String suffix) { + if (!isValidTile(mte)) return prefix + "N/A" + suffix; + StringJoiner sj = new StringJoiner(delimiter, prefix, suffix); + IGregTechTileEntity til = mte.getBaseMetaTileEntity(); + sj.add(String.valueOf(til.getXCoord())); + sj.add(String.valueOf(til.getYCoord())); + sj.add(String.valueOf(til.getZCoord())); + return sj.toString(); + } + + public static String formatTileInfo(String prefix, IGregTechTileEntity tile, String delimiter, String suffix) { + if (!isValidTile(tile)) return prefix + "N/A" + suffix; + StringJoiner sj = new StringJoiner(delimiter, prefix, suffix); + sj.add(String.valueOf(tile.getXCoord())); + sj.add(String.valueOf(tile.getYCoord())); + sj.add(String.valueOf(tile.getZCoord())); + return sj.toString(); + } +} |