aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/GoodGenerator/Network
diff options
context:
space:
mode:
authorGlodBlock <60341015+GlodBlock@users.noreply.github.com>2021-08-17 10:51:56 +0800
committerGitHub <noreply@github.com>2021-08-17 10:51:56 +0800
commit0734e08309d0475441d2c60170272b67307aa0c3 (patch)
tree63bc6e4c9e4d7e2404937d05214cf5939bb7590e /src/main/java/GoodGenerator/Network
parentb00aebd72df14381b08639d86d65a04439289302 (diff)
parent5fd50a358464907982a696b977a17e14227b44aa (diff)
downloadGT5-Unofficial-0734e08309d0475441d2c60170272b67307aa0c3.tar.gz
GT5-Unofficial-0734e08309d0475441d2c60170272b67307aa0c3.tar.bz2
GT5-Unofficial-0734e08309d0475441d2c60170272b67307aa0c3.zip
Merge pull request #7 from GTNewHorizons/neutron-sensor-gui-sync
Fix NeutronSensor GUI sync
Diffstat (limited to 'src/main/java/GoodGenerator/Network')
-rw-r--r--src/main/java/GoodGenerator/Network/MessageMTEBase.java98
-rw-r--r--src/main/java/GoodGenerator/Network/MessageOpenNeutronSensorGUI.java50
-rw-r--r--src/main/java/GoodGenerator/Network/MessageSetNeutronSensorData.java52
3 files changed, 200 insertions, 0 deletions
diff --git a/src/main/java/GoodGenerator/Network/MessageMTEBase.java b/src/main/java/GoodGenerator/Network/MessageMTEBase.java
new file mode 100644
index 0000000000..e54249e545
--- /dev/null
+++ b/src/main/java/GoodGenerator/Network/MessageMTEBase.java
@@ -0,0 +1,98 @@
+/*
+ * MIT License
+ *
+ * Copyright (c) 2021 Glease
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in all
+ * copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ * SOFTWARE.
+ */
+package GoodGenerator.Network;
+
+import com.github.technus.tectech.TecTech;
+import cpw.mods.fml.common.network.simpleimpl.IMessage;
+import cpw.mods.fml.common.network.simpleimpl.IMessageHandler;
+import cpw.mods.fml.common.network.simpleimpl.MessageContext;
+import cpw.mods.fml.relauncher.Side;
+import gregtech.api.interfaces.metatileentity.IMetaTileEntity;
+import gregtech.api.interfaces.tileentity.IGregTechTileEntity;
+import io.netty.buffer.ByteBuf;
+import net.minecraft.tileentity.TileEntity;
+import net.minecraft.world.World;
+import net.minecraftforge.common.DimensionManager;
+
+public abstract class MessageMTEBase implements IMessage {
+ protected int w;
+ protected int x;
+ protected short y;
+ protected int z;
+
+ public MessageMTEBase() {
+ }
+
+ public MessageMTEBase(IGregTechTileEntity tile) {
+ this.w = tile.getWorld().provider.dimensionId;
+ this.x = tile.getXCoord();
+ this.y = tile.getYCoord();
+ this.z = tile.getZCoord();
+ }
+
+ @Override
+ public void fromBytes(ByteBuf buf) {
+ x = buf.readInt();
+ y = buf.readShort();
+ z = buf.readInt();
+ w = buf.readInt();
+ }
+
+ @Override
+ public void toBytes(ByteBuf buf) {
+ buf.writeInt(x);
+ buf.writeShort(y);
+ buf.writeInt(z);
+ buf.writeInt(w);
+ }
+
+ public static abstract class Handler<REQ extends MessageMTEBase, REPLY extends IMessage> implements IMessageHandler<REQ, REPLY> {
+ protected abstract REPLY onError(REQ message, MessageContext ctx);
+
+ protected abstract REPLY onSuccess(REQ message, MessageContext ctx, IMetaTileEntity mte);
+
+ @Override
+ public REPLY onMessage(REQ message, MessageContext ctx) {
+ World world;
+ if (ctx.side == Side.SERVER) {
+ world = DimensionManager.getWorld(message.w);
+ } else {
+ world = TecTech.proxy.getClientWorld();
+ if (world.provider.dimensionId != message.w)
+ return onError(message, ctx);
+ }
+ if (world == null)
+ return onError(message, ctx);
+ if (world.blockExists(message.x, message.y, message.z)) {
+ TileEntity te = world.getTileEntity(message.x, message.y, message.z);
+ if (te instanceof IGregTechTileEntity && !((IGregTechTileEntity) te).isInvalidTileEntity()) {
+ IMetaTileEntity mte = ((IGregTechTileEntity) te).getMetaTileEntity();
+ if (mte != null)
+ return onSuccess(message, ctx, mte);
+ }
+ }
+ return onError(message, ctx);
+ }
+ }
+}
diff --git a/src/main/java/GoodGenerator/Network/MessageOpenNeutronSensorGUI.java b/src/main/java/GoodGenerator/Network/MessageOpenNeutronSensorGUI.java
new file mode 100644
index 0000000000..0b3c045ece
--- /dev/null
+++ b/src/main/java/GoodGenerator/Network/MessageOpenNeutronSensorGUI.java
@@ -0,0 +1,50 @@
+package GoodGenerator.Network;
+
+import GoodGenerator.Blocks.TEs.MetaTE.NeutronSensor;
+import com.github.technus.tectech.TecTech;
+import cpw.mods.fml.common.network.ByteBufUtils;
+import cpw.mods.fml.common.network.simpleimpl.IMessage;
+import cpw.mods.fml.common.network.simpleimpl.MessageContext;
+import gregtech.api.interfaces.metatileentity.IMetaTileEntity;
+import gregtech.api.interfaces.tileentity.IGregTechTileEntity;
+import io.netty.buffer.ByteBuf;
+
+public class MessageOpenNeutronSensorGUI extends MessageMTEBase {
+ protected String data;
+
+ public MessageOpenNeutronSensorGUI() {
+ }
+
+ public MessageOpenNeutronSensorGUI(IGregTechTileEntity tile, String data) {
+ super(tile);
+ this.data = data;
+ }
+
+ @Override
+ public void fromBytes(ByteBuf buf) {
+ super.fromBytes(buf);
+ data = ByteBufUtils.readUTF8String(buf);
+ }
+
+ @Override
+ public void toBytes(ByteBuf buf) {
+ super.toBytes(buf);
+ ByteBufUtils.writeUTF8String(buf, data);
+ }
+
+ public static class ClientHandler extends MessageMTEBase.Handler<MessageOpenNeutronSensorGUI, IMessage> {
+ @Override
+ protected IMessage onError(MessageOpenNeutronSensorGUI message, MessageContext ctx) {
+ return null;
+ }
+
+ @Override
+ protected IMessage onSuccess(MessageOpenNeutronSensorGUI message, MessageContext ctx, IMetaTileEntity mte) {
+ if (mte instanceof NeutronSensor) {
+ ((NeutronSensor) mte).setText(message.data);
+ mte.getBaseMetaTileEntity().openGUI(TecTech.proxy.getPlayer());
+ }
+ return null;
+ }
+ }
+}
diff --git a/src/main/java/GoodGenerator/Network/MessageSetNeutronSensorData.java b/src/main/java/GoodGenerator/Network/MessageSetNeutronSensorData.java
new file mode 100644
index 0000000000..39d08d92c3
--- /dev/null
+++ b/src/main/java/GoodGenerator/Network/MessageSetNeutronSensorData.java
@@ -0,0 +1,52 @@
+package GoodGenerator.Network;
+
+import GoodGenerator.Blocks.TEs.MetaTE.NeutronSensor;
+import com.github.technus.tectech.TecTech;
+import cpw.mods.fml.common.network.ByteBufUtils;
+import cpw.mods.fml.common.network.simpleimpl.IMessage;
+import cpw.mods.fml.common.network.simpleimpl.MessageContext;
+import cpw.mods.fml.relauncher.Side;
+import gregtech.api.interfaces.metatileentity.IMetaTileEntity;
+import gregtech.api.interfaces.tileentity.IGregTechTileEntity;
+import io.netty.buffer.ByteBuf;
+
+public class MessageSetNeutronSensorData extends MessageMTEBase {
+ protected String data;
+
+ public MessageSetNeutronSensorData() {
+ }
+
+ public MessageSetNeutronSensorData(IGregTechTileEntity tile, String data) {
+ super(tile);
+ this.data = data;
+ }
+
+ @Override
+ public void fromBytes(ByteBuf buf) {
+ super.fromBytes(buf);
+ data = ByteBufUtils.readUTF8String(buf);
+ }
+
+ @Override
+ public void toBytes(ByteBuf buf) {
+ super.toBytes(buf);
+ ByteBufUtils.writeUTF8String(buf, data);
+ }
+
+ public static class ServerHandler extends MessageMTEBase.Handler<MessageSetNeutronSensorData, IMessage> {
+ @Override
+ protected IMessage onError(MessageSetNeutronSensorData message, MessageContext ctx) {
+ return null;
+ }
+
+ @Override
+ protected IMessage onSuccess(MessageSetNeutronSensorData message, MessageContext ctx, IMetaTileEntity mte) {
+ if (mte instanceof NeutronSensor) {
+ ((NeutronSensor) mte).setText(message.data);
+ if (ctx.side == Side.CLIENT)
+ mte.getBaseMetaTileEntity().openGUI(TecTech.proxy.getPlayer());
+ }
+ return null;
+ }
+ }
+}