aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/kubatech/api/network/LoadConfigPacket.java
diff options
context:
space:
mode:
authorMartin Robertz <dream-master@gmx.net>2022-08-19 14:13:14 +0200
committerGitHub <noreply@github.com>2022-08-19 14:13:14 +0200
commit3fd8c269616b598d3647886b33b48a1656638ff4 (patch)
treec8cdd43785cc1bf27bdda56b0ce13ead64e3d6bc /src/main/java/kubatech/api/network/LoadConfigPacket.java
parent40590e12a74d38160229ac714e852a64705bc1b5 (diff)
parente047655eac4bf51bb5f72f36b8d1c5795cb4c817 (diff)
downloadGT5-Unofficial-3fd8c269616b598d3647886b33b48a1656638ff4.tar.gz
GT5-Unofficial-3fd8c269616b598d3647886b33b48a1656638ff4.tar.bz2
GT5-Unofficial-3fd8c269616b598d3647886b33b48a1656638ff4.zip
Merge pull request #4 from GTNewHorizons/structure
New Extreme Extermination Chamber structure
Diffstat (limited to 'src/main/java/kubatech/api/network/LoadConfigPacket.java')
-rw-r--r--src/main/java/kubatech/api/network/LoadConfigPacket.java74
1 files changed, 74 insertions, 0 deletions
diff --git a/src/main/java/kubatech/api/network/LoadConfigPacket.java b/src/main/java/kubatech/api/network/LoadConfigPacket.java
new file mode 100644
index 0000000000..f38293642e
--- /dev/null
+++ b/src/main/java/kubatech/api/network/LoadConfigPacket.java
@@ -0,0 +1,74 @@
+/*
+ * KubaTech - Gregtech Addon
+ * Copyright (C) 2022 kuba6000
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this library. If not, see <https://www.gnu.org/licenses/>.
+ *
+ */
+
+package kubatech.api.network;
+
+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 io.netty.buffer.ByteBuf;
+import java.nio.charset.StandardCharsets;
+import java.util.HashSet;
+import kubatech.Config;
+import kubatech.kubatech;
+import kubatech.loaders.MobRecipeLoader;
+
+public class LoadConfigPacket implements IMessage {
+
+ public static final LoadConfigPacket instance = new LoadConfigPacket();
+
+ public final HashSet<String> mobsToLoad = new HashSet<>();
+
+ @Override
+ public void fromBytes(ByteBuf buf) {
+ if (!buf.readBoolean()) mobsToLoad.clear();
+ else {
+ mobsToLoad.clear();
+ int mobssize = buf.readInt();
+ for (int i = 0; i < mobssize; i++) {
+ byte[] sbytes = new byte[buf.readInt()];
+ buf.readBytes(sbytes);
+ mobsToLoad.add(new String(sbytes, StandardCharsets.UTF_8));
+ }
+ }
+ }
+
+ @Override
+ public void toBytes(ByteBuf buf) {
+ if (!Config.mobHandlerEnabled) buf.writeBoolean(false);
+ else {
+ buf.writeBoolean(true);
+ buf.writeInt(mobsToLoad.size());
+ mobsToLoad.forEach(s -> {
+ byte[] sbytes = s.getBytes(StandardCharsets.UTF_8);
+ buf.writeInt(sbytes.length);
+ buf.writeBytes(sbytes);
+ });
+ }
+ }
+
+ public static class Handler implements IMessageHandler<LoadConfigPacket, IMessage> {
+ @Override
+ public IMessage onMessage(LoadConfigPacket message, MessageContext ctx) {
+ kubatech.info("Received Mob Handler config, parsing");
+ MobRecipeLoader.processMobRecipeMap(message.mobsToLoad);
+ return null;
+ }
+ }
+}