mirror of
https://github.com/ViaVersion/ViaBackwards.git
synced 2024-12-17 16:08:00 +01:00
Implement tab-complete
This commit is contained in:
parent
c9067354c0
commit
be8c1b69dc
@ -27,6 +27,12 @@ import us.myles.ViaVersion.packets.State;
|
|||||||
import us.myles.ViaVersion.protocols.protocol1_9_3to1_9_1_2.storage.ClientWorld;
|
import us.myles.ViaVersion.protocols.protocol1_9_3to1_9_1_2.storage.ClientWorld;
|
||||||
|
|
||||||
public class Protocol1_12_2To1_13 extends BackwardsProtocol {
|
public class Protocol1_12_2To1_13 extends BackwardsProtocol {
|
||||||
|
static {
|
||||||
|
BackwardsMappings.init();
|
||||||
|
PaintingMapping.init();
|
||||||
|
SoundMapping.init();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void registerPackets() {
|
protected void registerPackets() {
|
||||||
new BlockItemPackets1_13().register(this);
|
new BlockItemPackets1_13().register(this);
|
||||||
@ -40,7 +46,6 @@ public class Protocol1_12_2To1_13 extends BackwardsProtocol {
|
|||||||
out(State.PLAY, 0x07, 0x07, cancel()); // Statistics TODO MODIFIED
|
out(State.PLAY, 0x07, 0x07, cancel()); // Statistics TODO MODIFIED
|
||||||
out(State.PLAY, 0x09, 0x09, cancel()); // Update Block Entity TODO MODIFIED
|
out(State.PLAY, 0x09, 0x09, cancel()); // Update Block Entity TODO MODIFIED
|
||||||
out(State.PLAY, 0x0E, 0x0F); // Chat Message (clientbound)
|
out(State.PLAY, 0x0E, 0x0F); // Chat Message (clientbound)
|
||||||
out(State.PLAY, 0x10, 0x0E, cancel()); // Tab-Complete (clientbound) TODO MODIFIED
|
|
||||||
out(State.PLAY, 0x11, -1, cancel()); // Declare Commands TODO NEW
|
out(State.PLAY, 0x11, -1, cancel()); // Declare Commands TODO NEW
|
||||||
out(State.PLAY, 0x12, 0x11); // Confirm Transaction (clientbound)
|
out(State.PLAY, 0x12, 0x11); // Confirm Transaction (clientbound)
|
||||||
out(State.PLAY, 0x13, 0x12); // Close Window (clientbound)
|
out(State.PLAY, 0x13, 0x12); // Close Window (clientbound)
|
||||||
@ -54,11 +59,6 @@ public class Protocol1_12_2To1_13 extends BackwardsProtocol {
|
|||||||
out(State.PLAY, 0x1F, 0x1D); // Unload Chunk
|
out(State.PLAY, 0x1F, 0x1D); // Unload Chunk
|
||||||
out(State.PLAY, 0x20, 0x1E); // Change Game State
|
out(State.PLAY, 0x20, 0x1E); // Change Game State
|
||||||
out(State.PLAY, 0x21, 0x1F); // Keep Alive (clientbound)
|
out(State.PLAY, 0x21, 0x1F); // Keep Alive (clientbound)
|
||||||
|
|
||||||
// Chunk Data -> moved to BlockItemPackets
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
out(State.PLAY, 0x24, 0x22, cancel()); // Spawn Particle TODO MODIFIED
|
out(State.PLAY, 0x24, 0x22, cancel()); // Spawn Particle TODO MODIFIED
|
||||||
out(State.PLAY, 0x27, 0x25); // Entity
|
out(State.PLAY, 0x27, 0x25); // Entity
|
||||||
out(State.PLAY, 0x28, 0x26); // Entity Relative Move
|
out(State.PLAY, 0x28, 0x26); // Entity Relative Move
|
||||||
@ -100,8 +100,6 @@ public class Protocol1_12_2To1_13 extends BackwardsProtocol {
|
|||||||
out(State.PLAY, 0x54, -1, cancel()); // Declare Recipes TODO NEW
|
out(State.PLAY, 0x54, -1, cancel()); // Declare Recipes TODO NEW
|
||||||
out(State.PLAY, 0x55, -1, cancel()); // Tags (the client won't need this)
|
out(State.PLAY, 0x55, -1, cancel()); // Tags (the client won't need this)
|
||||||
|
|
||||||
|
|
||||||
in(State.PLAY, 0x05, 0x01, cancel()); // Tab-Complete (serverbound) TODO MODIFIED
|
|
||||||
in(State.PLAY, 0x06, 0x05); // Confirm Transaction (serverbound)
|
in(State.PLAY, 0x06, 0x05); // Confirm Transaction (serverbound)
|
||||||
in(State.PLAY, 0x07, 0x06); // Enchant Item
|
in(State.PLAY, 0x07, 0x06); // Enchant Item
|
||||||
in(State.PLAY, 0x09, 0x08); // Close Window (serverbound)
|
in(State.PLAY, 0x09, 0x08); // Close Window (serverbound)
|
||||||
@ -160,10 +158,4 @@ public class Protocol1_12_2To1_13 extends BackwardsProtocol {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
static {
|
|
||||||
BackwardsMappings.init();
|
|
||||||
PaintingMapping.init();
|
|
||||||
SoundMapping.init();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -132,113 +132,163 @@ public class PlayerPacket1_13 extends Rewriter<Protocol1_12_2To1_13> {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
//Plugin Message
|
// Tab-Complete (clientbound) TODO MODIFIED
|
||||||
protocol.in(State.PLAY, 0x0A, 0x09, new PacketRemapper() {
|
protocol.out(State.PLAY, 0x10, 0x0E, new PacketRemapper() {
|
||||||
@Override
|
@Override
|
||||||
public void registerMap() {
|
public void registerMap() {
|
||||||
handler(new PacketHandler() {
|
handler(new PacketHandler() {
|
||||||
@Override
|
@Override
|
||||||
public void handle(PacketWrapper wrapper) throws Exception {
|
public void handle(PacketWrapper wrapper) throws Exception {
|
||||||
String channel = wrapper.read(Type.STRING);
|
int key = wrapper.read(Type.VAR_INT);
|
||||||
if (channel.equals("MC|BSign") || channel.equals("MC|BEdit")) {
|
int start = wrapper.read(Type.VAR_INT);
|
||||||
wrapper.setId(0x0B);
|
int length = wrapper.read(Type.VAR_INT);
|
||||||
Item book = wrapper.read(Type.ITEM);
|
|
||||||
System.out.println(book);
|
|
||||||
BlockItemPackets1_13.toServer(book);
|
|
||||||
System.out.println(book);
|
|
||||||
wrapper.write(Type.FLAT_ITEM, book);
|
|
||||||
boolean signing = channel.equals("MC|BSign");
|
|
||||||
System.out.println(channel);
|
|
||||||
System.out.println(signing);
|
|
||||||
wrapper.write(Type.BOOLEAN, signing);
|
|
||||||
} else if (channel.equals("MC|ItemName")) {
|
|
||||||
wrapper.setId(0x1C);
|
|
||||||
} else if (channel.equals("MC|AdvCmd")) {
|
|
||||||
byte type = wrapper.read(Type.BYTE);
|
|
||||||
if (type == 0) {
|
|
||||||
//Information from https://wiki.vg/index.php?title=Plugin_channels&oldid=14089
|
|
||||||
//The Notchain client only uses this for command block minecarts and uses MC|AutoCmd for blocks, but the Notchian server still accepts it for either.
|
|
||||||
//Maybe older versions used this and we need to implement this? The issues is that we would have to save the command block types
|
|
||||||
wrapper.setId(0x22);
|
|
||||||
wrapper.cancel();
|
|
||||||
ViaBackwards.getPlatform().getLogger().warning("Client send MC|AdvCmd custom payload to update command block, weird!");
|
|
||||||
} else if (type == 1) {
|
|
||||||
wrapper.setId(0x23);
|
|
||||||
wrapper.write(Type.VAR_INT, wrapper.read(Type.INT)); //Entity Id
|
|
||||||
wrapper.passthrough(Type.STRING); //Command
|
|
||||||
wrapper.passthrough(Type.BOOLEAN); //Track Output
|
|
||||||
|
|
||||||
} else {
|
int count = wrapper.passthrough(Type.VAR_INT);
|
||||||
wrapper.cancel();
|
for (int i = 0; i < count; i++) {
|
||||||
}
|
String match = wrapper.read(Type.STRING);
|
||||||
} else if (channel.equals("MC|AutoCmd")) {
|
wrapper.write(Type.STRING, (start == 0 ? "/" : "") + match);
|
||||||
wrapper.setId(0x22);
|
// Ignore tooltip
|
||||||
Integer x = wrapper.read(Type.INT);
|
wrapper.read(Type.OPTIONAL_CHAT);
|
||||||
Integer y = wrapper.read(Type.INT);
|
}
|
||||||
Integer z = wrapper.read(Type.INT);
|
|
||||||
wrapper.write(Type.POSITION, new Position(x.longValue(), y.longValue(), z.longValue()));
|
|
||||||
wrapper.passthrough(Type.STRING); //Command
|
|
||||||
byte flags = 0;
|
|
||||||
if (wrapper.read(Type.BOOLEAN)) flags |= 0x01; //Track Output
|
|
||||||
String mode = wrapper.read(Type.STRING);
|
|
||||||
int modeId = mode.equals("SEQUENCE") ? 0 : mode.equals("AUTO") ? 1 : 2;
|
|
||||||
wrapper.write(Type.VAR_INT, modeId);
|
|
||||||
if (wrapper.read(Type.BOOLEAN)) flags |= 0x02; //Is conditional
|
|
||||||
if (wrapper.read(Type.BOOLEAN)) flags |= 0x04; //Automatic
|
|
||||||
} else if (channel.equals("MC|Struct")) {
|
|
||||||
wrapper.setId(0x25);
|
|
||||||
Integer x = wrapper.read(Type.INT);
|
|
||||||
Integer y = wrapper.read(Type.INT);
|
|
||||||
Integer z = wrapper.read(Type.INT);
|
|
||||||
wrapper.write(Type.POSITION, new Position(x.longValue(), y.longValue(), z.longValue()));
|
|
||||||
wrapper.write(Type.VAR_INT, wrapper.read(Type.BYTE) - 1);
|
|
||||||
String mode = wrapper.read(Type.STRING);
|
|
||||||
int modeId = mode.equals("SAVE") ? 0 : mode.equals("LOAD") ? 1 : mode.equals("CORNER") ? 2 : 3;
|
|
||||||
wrapper.write(Type.VAR_INT, modeId);
|
|
||||||
wrapper.passthrough(Type.STRING); //Name
|
|
||||||
wrapper.write(Type.BYTE, wrapper.read(Type.INT).byteValue()); //Offset X
|
|
||||||
wrapper.write(Type.BYTE, wrapper.read(Type.INT).byteValue()); //Offset Y
|
|
||||||
wrapper.write(Type.BYTE, wrapper.read(Type.INT).byteValue()); //Offset Z
|
|
||||||
wrapper.write(Type.BYTE, wrapper.read(Type.INT).byteValue()); //Size X
|
|
||||||
wrapper.write(Type.BYTE, wrapper.read(Type.INT).byteValue()); //Size Y
|
|
||||||
wrapper.write(Type.BYTE, wrapper.read(Type.INT).byteValue()); //Size Z
|
|
||||||
String mirror = wrapper.read(Type.STRING);
|
|
||||||
int mirrorId = mode.equals("NONE") ? 0 : mode.equals("LEFT_RIGHT") ? 1 : 2;
|
|
||||||
String rotation = wrapper.read(Type.STRING);
|
|
||||||
int rotationId = mode.equals("NONE") ? 0 : mode.equals("CLOCKWISE_90") ? 1 : mode.equals("CLOCKWISE_180") ? 2 : 3;
|
|
||||||
wrapper.passthrough(Type.STRING); //Metadata
|
|
||||||
byte flags = 0;
|
|
||||||
if (wrapper.read(Type.BOOLEAN)) flags |= 0x01; //Ignore entities
|
|
||||||
if (wrapper.read(Type.BOOLEAN)) flags |= 0x02; //Show air
|
|
||||||
if (wrapper.read(Type.BOOLEAN)) flags |= 0x04; //Show bounding box
|
|
||||||
wrapper.passthrough(Type.FLOAT); //Integrity
|
|
||||||
wrapper.passthrough(Type.VAR_LONG); //Seed
|
|
||||||
wrapper.write(Type.BYTE, flags);
|
|
||||||
} else if (channel.equals("MC|Beacon")) {
|
|
||||||
wrapper.setId(0x20);
|
|
||||||
wrapper.write(Type.VAR_INT, wrapper.read(Type.INT)); //Primary Effect
|
|
||||||
wrapper.write(Type.VAR_INT, wrapper.read(Type.INT)); //Secondary Effect
|
|
||||||
} else if (channel.equals("MC|TrSel")) {
|
|
||||||
wrapper.setId(0x1F);
|
|
||||||
wrapper.write(Type.VAR_INT, wrapper.read(Type.INT)); //Slot
|
|
||||||
} else if (channel.equals("MC|PickItem")) {
|
|
||||||
wrapper.setId(0x15);
|
|
||||||
} else {
|
|
||||||
String newChannel = InventoryPackets.getNewPluginChannelId(channel);
|
|
||||||
if (newChannel == null) {
|
|
||||||
ViaBackwards.getPlatform().getLogger().warning("Could not find new channel for " + channel);
|
|
||||||
wrapper.cancel();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
wrapper.write(Type.STRING, newChannel);
|
|
||||||
//TODO REGISTER and UNREGISTER (see ViaVersion)
|
|
||||||
wrapper.cancel();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
|
||||||
|
// Tab-Complete (serverbound)
|
||||||
|
protocol.in(State.PLAY, 0x05, 0x01, new PacketRemapper() {
|
||||||
|
@Override
|
||||||
|
public void registerMap() {
|
||||||
|
|
||||||
|
handler(new PacketHandler() {
|
||||||
|
@Override
|
||||||
|
public void handle(PacketWrapper wrapper) throws Exception {
|
||||||
|
// Send a fake key
|
||||||
|
wrapper.write(Type.VAR_INT, 13337);
|
||||||
|
|
||||||
|
String command = wrapper.read(Type.STRING);
|
||||||
|
|
||||||
|
if (command.startsWith("/"))
|
||||||
|
command = command.substring(1);
|
||||||
|
|
||||||
|
wrapper.write(Type.STRING, command);
|
||||||
|
|
||||||
|
// Ignore fields
|
||||||
|
wrapper.read(Type.BOOLEAN);
|
||||||
|
wrapper.read(Type.OPTIONAL_POSITION);
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
//Plugin Message
|
||||||
|
protocol.in(State.PLAY, 0x0A, 0x09, new PacketRemapper() {
|
||||||
|
@Override
|
||||||
|
public void registerMap() {
|
||||||
|
handler(new PacketHandler() {
|
||||||
|
@Override
|
||||||
|
public void handle(PacketWrapper wrapper) throws Exception {
|
||||||
|
String channel = wrapper.read(Type.STRING);
|
||||||
|
if (channel.equals("MC|BSign") || channel.equals("MC|BEdit")) {
|
||||||
|
wrapper.setId(0x0B);
|
||||||
|
Item book = wrapper.read(Type.ITEM);
|
||||||
|
System.out.println(book);
|
||||||
|
BlockItemPackets1_13.toServer(book);
|
||||||
|
System.out.println(book);
|
||||||
|
wrapper.write(Type.FLAT_ITEM, book);
|
||||||
|
boolean signing = channel.equals("MC|BSign");
|
||||||
|
System.out.println(channel);
|
||||||
|
System.out.println(signing);
|
||||||
|
wrapper.write(Type.BOOLEAN, signing);
|
||||||
|
} else if (channel.equals("MC|ItemName")) {
|
||||||
|
wrapper.setId(0x1C);
|
||||||
|
} else if (channel.equals("MC|AdvCmd")) {
|
||||||
|
byte type = wrapper.read(Type.BYTE);
|
||||||
|
if (type == 0) {
|
||||||
|
//Information from https://wiki.vg/index.php?title=Plugin_channels&oldid=14089
|
||||||
|
//The Notchain client only uses this for command block minecarts and uses MC|AutoCmd for blocks, but the Notchian server still accepts it for either.
|
||||||
|
//Maybe older versions used this and we need to implement this? The issues is that we would have to save the command block types
|
||||||
|
wrapper.setId(0x22);
|
||||||
|
wrapper.cancel();
|
||||||
|
ViaBackwards.getPlatform().getLogger().warning("Client send MC|AdvCmd custom payload to update command block, weird!");
|
||||||
|
} else if (type == 1) {
|
||||||
|
wrapper.setId(0x23);
|
||||||
|
wrapper.write(Type.VAR_INT, wrapper.read(Type.INT)); //Entity Id
|
||||||
|
wrapper.passthrough(Type.STRING); //Command
|
||||||
|
wrapper.passthrough(Type.BOOLEAN); //Track Output
|
||||||
|
|
||||||
|
} else {
|
||||||
|
wrapper.cancel();
|
||||||
|
}
|
||||||
|
} else if (channel.equals("MC|AutoCmd")) {
|
||||||
|
wrapper.setId(0x22);
|
||||||
|
Integer x = wrapper.read(Type.INT);
|
||||||
|
Integer y = wrapper.read(Type.INT);
|
||||||
|
Integer z = wrapper.read(Type.INT);
|
||||||
|
wrapper.write(Type.POSITION, new Position(x.longValue(), y.longValue(), z.longValue()));
|
||||||
|
wrapper.passthrough(Type.STRING); //Command
|
||||||
|
byte flags = 0;
|
||||||
|
if (wrapper.read(Type.BOOLEAN)) flags |= 0x01; //Track Output
|
||||||
|
String mode = wrapper.read(Type.STRING);
|
||||||
|
int modeId = mode.equals("SEQUENCE") ? 0 : mode.equals("AUTO") ? 1 : 2;
|
||||||
|
wrapper.write(Type.VAR_INT, modeId);
|
||||||
|
if (wrapper.read(Type.BOOLEAN)) flags |= 0x02; //Is conditional
|
||||||
|
if (wrapper.read(Type.BOOLEAN)) flags |= 0x04; //Automatic
|
||||||
|
} else if (channel.equals("MC|Struct")) {
|
||||||
|
wrapper.setId(0x25);
|
||||||
|
Integer x = wrapper.read(Type.INT);
|
||||||
|
Integer y = wrapper.read(Type.INT);
|
||||||
|
Integer z = wrapper.read(Type.INT);
|
||||||
|
wrapper.write(Type.POSITION, new Position(x.longValue(), y.longValue(), z.longValue()));
|
||||||
|
wrapper.write(Type.VAR_INT, wrapper.read(Type.BYTE) - 1);
|
||||||
|
String mode = wrapper.read(Type.STRING);
|
||||||
|
int modeId = mode.equals("SAVE") ? 0 : mode.equals("LOAD") ? 1 : mode.equals("CORNER") ? 2 : 3;
|
||||||
|
wrapper.write(Type.VAR_INT, modeId);
|
||||||
|
wrapper.passthrough(Type.STRING); //Name
|
||||||
|
wrapper.write(Type.BYTE, wrapper.read(Type.INT).byteValue()); //Offset X
|
||||||
|
wrapper.write(Type.BYTE, wrapper.read(Type.INT).byteValue()); //Offset Y
|
||||||
|
wrapper.write(Type.BYTE, wrapper.read(Type.INT).byteValue()); //Offset Z
|
||||||
|
wrapper.write(Type.BYTE, wrapper.read(Type.INT).byteValue()); //Size X
|
||||||
|
wrapper.write(Type.BYTE, wrapper.read(Type.INT).byteValue()); //Size Y
|
||||||
|
wrapper.write(Type.BYTE, wrapper.read(Type.INT).byteValue()); //Size Z
|
||||||
|
String mirror = wrapper.read(Type.STRING);
|
||||||
|
int mirrorId = mode.equals("NONE") ? 0 : mode.equals("LEFT_RIGHT") ? 1 : 2;
|
||||||
|
String rotation = wrapper.read(Type.STRING);
|
||||||
|
int rotationId = mode.equals("NONE") ? 0 : mode.equals("CLOCKWISE_90") ? 1 : mode.equals("CLOCKWISE_180") ? 2 : 3;
|
||||||
|
wrapper.passthrough(Type.STRING); //Metadata
|
||||||
|
byte flags = 0;
|
||||||
|
if (wrapper.read(Type.BOOLEAN)) flags |= 0x01; //Ignore entities
|
||||||
|
if (wrapper.read(Type.BOOLEAN)) flags |= 0x02; //Show air
|
||||||
|
if (wrapper.read(Type.BOOLEAN)) flags |= 0x04; //Show bounding box
|
||||||
|
wrapper.passthrough(Type.FLOAT); //Integrity
|
||||||
|
wrapper.passthrough(Type.VAR_LONG); //Seed
|
||||||
|
wrapper.write(Type.BYTE, flags);
|
||||||
|
} else if (channel.equals("MC|Beacon")) {
|
||||||
|
wrapper.setId(0x20);
|
||||||
|
wrapper.write(Type.VAR_INT, wrapper.read(Type.INT)); //Primary Effect
|
||||||
|
wrapper.write(Type.VAR_INT, wrapper.read(Type.INT)); //Secondary Effect
|
||||||
|
} else if (channel.equals("MC|TrSel")) {
|
||||||
|
wrapper.setId(0x1F);
|
||||||
|
wrapper.write(Type.VAR_INT, wrapper.read(Type.INT)); //Slot
|
||||||
|
} else if (channel.equals("MC|PickItem")) {
|
||||||
|
wrapper.setId(0x15);
|
||||||
|
} else {
|
||||||
|
String newChannel = InventoryPackets.getNewPluginChannelId(channel);
|
||||||
|
if (newChannel == null) {
|
||||||
|
ViaBackwards.getPlatform().getLogger().warning("Could not find new channel for " + channel);
|
||||||
|
wrapper.cancel();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
wrapper.write(Type.STRING, newChannel);
|
||||||
|
//TODO REGISTER and UNREGISTER (see ViaVersion)
|
||||||
|
wrapper.cancel();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void registerRewrites() {
|
protected void registerRewrites() {
|
||||||
|
Loading…
Reference in New Issue
Block a user