Initial implementation
This commit is contained in:
@ -0,0 +1,12 @@
|
||||
package de.zonlykroks.advancedscripts;
|
||||
|
||||
import net.fabricmc.api.ClientModInitializer;
|
||||
|
||||
public class AdvancedScripts implements ClientModInitializer {
|
||||
|
||||
public static boolean isOnSteamwar = false;
|
||||
@Override
|
||||
public void onInitializeClient() {
|
||||
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,23 @@
|
||||
package de.zonlykroks.advancedscripts.mixin;
|
||||
|
||||
import de.zonlykroks.advancedscripts.AdvancedScripts;
|
||||
import net.minecraft.client.network.ClientLoginNetworkHandler;
|
||||
import net.minecraft.network.packet.s2c.login.LoginSuccessS2CPacket;
|
||||
import org.spongepowered.asm.mixin.Mixin;
|
||||
import org.spongepowered.asm.mixin.injection.At;
|
||||
import org.spongepowered.asm.mixin.injection.Inject;
|
||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
||||
|
||||
@Mixin(ClientLoginNetworkHandler.class)
|
||||
public class ClientLoginNetworkHandlerMixin {
|
||||
|
||||
@Inject(method = "onSuccess", at = @At("TAIL"))
|
||||
public void isOnSteamwar(LoginSuccessS2CPacket packet, CallbackInfo ci) {
|
||||
if(AdvancedScripts.isOnSteamwar) {
|
||||
String adress = ((ClientLoginNetworkHandler) (Object)this).serverInfo.address;
|
||||
|
||||
AdvancedScripts.isOnSteamwar = adress == "steamwar.de" || adress == "78.31.71.136";
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
@ -0,0 +1,33 @@
|
||||
package de.zonlykroks.advancedscripts.mixin;
|
||||
|
||||
import io.netty.buffer.Unpooled;
|
||||
import net.minecraft.client.Keyboard;
|
||||
import net.minecraft.client.MinecraftClient;
|
||||
import net.minecraft.network.PacketByteBuf;
|
||||
import net.minecraft.network.packet.c2s.play.CustomPayloadC2SPacket;
|
||||
import net.minecraft.util.Identifier;
|
||||
import org.spongepowered.asm.mixin.Mixin;
|
||||
import org.spongepowered.asm.mixin.Unique;
|
||||
import org.spongepowered.asm.mixin.injection.At;
|
||||
import org.spongepowered.asm.mixin.injection.Inject;
|
||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
||||
|
||||
@Mixin(Keyboard.class)
|
||||
public class KeyboardMixin {
|
||||
|
||||
@Unique
|
||||
private static final Identifier channel = new Identifier("sw:hotkeys");
|
||||
|
||||
@Inject(method = "onKey", at = @At("HEAD"))
|
||||
public void sendKeyPress(long window, int key, int scancode, int action, int modifiers, CallbackInfo ci) {
|
||||
MinecraftClient client = ((Keyboard) (Object)this).client;
|
||||
if(client.currentScreen == null) {
|
||||
PacketByteBuf byteBuf = new PacketByteBuf(Unpooled.buffer());
|
||||
byteBuf.writeInt(key);
|
||||
byteBuf.writeByte(action);
|
||||
CustomPayloadC2SPacket customPayloadC2SPacket = new CustomPayloadC2SPacket(channel,byteBuf);
|
||||
client.getNetworkHandler().sendPacket(customPayloadC2SPacket);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
4
src/main/resources/advancedscripts.accesswidener
Normal file
4
src/main/resources/advancedscripts.accesswidener
Normal file
@ -0,0 +1,4 @@
|
||||
accessWidener v1 named
|
||||
|
||||
accessible field net/minecraft/client/network/ClientLoginNetworkHandler serverInfo Lnet/minecraft/client/network/ServerInfo;
|
||||
accessible field net/minecraft/client/Keyboard client Lnet/minecraft/client/MinecraftClient;
|
||||
15
src/main/resources/advancedscripts.mixins.json
Normal file
15
src/main/resources/advancedscripts.mixins.json
Normal file
@ -0,0 +1,15 @@
|
||||
{
|
||||
"required": true,
|
||||
"minVersion": "0.8",
|
||||
"package": "de.zonlykroks.advancedscripts.mixin",
|
||||
"compatibilityLevel": "JAVA_17",
|
||||
"mixins": [
|
||||
],
|
||||
"client": [
|
||||
"ClientLoginNetworkHandlerMixin",
|
||||
"KeyboardMixin"
|
||||
],
|
||||
"injectors": {
|
||||
"defaultRequire": 1
|
||||
}
|
||||
}
|
||||
27
src/main/resources/fabric.mod.json
Normal file
27
src/main/resources/fabric.mod.json
Normal file
@ -0,0 +1,27 @@
|
||||
{
|
||||
"schemaVersion": 1,
|
||||
"id": "advancedscripts",
|
||||
"version": "${version}",
|
||||
|
||||
"name": "Advanced Scripts",
|
||||
"description": "An addition to the Steamwar script system!",
|
||||
"authors": [
|
||||
"zOnlyKroks"
|
||||
],
|
||||
"license": "AGPL-3.0",
|
||||
"environment": "client",
|
||||
"entrypoints": {
|
||||
"client": [
|
||||
"de.zonlykroks.advancedscripts.AdvancedScripts"
|
||||
]
|
||||
},
|
||||
"mixins": [
|
||||
"advancedscripts.mixins.json"
|
||||
],
|
||||
"depends": {
|
||||
"fabricloader": ">=0.14.11",
|
||||
"minecraft": ">=1.19.2",
|
||||
"java": ">=17"
|
||||
},
|
||||
"accessWidener" : "advancedscripts.accesswidener"
|
||||
}
|
||||
Reference in New Issue
Block a user