mirror of
https://github.com/ViaVersion/ViaVersion.git
synced 2025-01-07 00:08:17 +01:00
Don't call PlayerInteractEvent twice and fix the gamemode message (#390)
* Experimental feature to fix the 'Your gamemode has been updated to ' message * Don't fire PlayerInteractEvent twice, fix #326
This commit is contained in:
parent
cb3f0291b7
commit
4cffdd4f64
@ -16,10 +16,7 @@ import us.myles.ViaVersion.api.type.Type;
|
|||||||
import us.myles.ViaVersion.protocols.base.ProtocolInfo;
|
import us.myles.ViaVersion.protocols.base.ProtocolInfo;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.listeners.*;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.listeners.*;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.packets.*;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.packets.*;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.ClientChunks;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.*;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.EntityTracker;
|
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.InventoryTracker;
|
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.MovementTracker;
|
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.types.MetadataListType;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.types.MetadataListType;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.types.MetadataType;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.types.MetadataType;
|
||||||
|
|
||||||
@ -62,9 +59,9 @@ public class Protocol1_9TO1_8 extends Protocol {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static Item getHandItem(final UserConnection info) {
|
public static Item getHandItem(final UserConnection info) {
|
||||||
if(HandItemCache.CACHE){
|
if (HandItemCache.CACHE) {
|
||||||
return HandItemCache.getHandItem(info.get(ProtocolInfo.class).getUuid());
|
return HandItemCache.getHandItem(info.get(ProtocolInfo.class).getUuid());
|
||||||
}else {
|
} else {
|
||||||
try {
|
try {
|
||||||
return Bukkit.getScheduler().callSyncMethod(Bukkit.getPluginManager().getPlugin("ViaVersion"), new Callable<Item>() {
|
return Bukkit.getScheduler().callSyncMethod(Bukkit.getPluginManager().getPlugin("ViaVersion"), new Callable<Item>() {
|
||||||
@Override
|
@Override
|
||||||
@ -133,5 +130,7 @@ public class Protocol1_9TO1_8 extends Protocol {
|
|||||||
userConnection.put(new MovementTracker(userConnection));
|
userConnection.put(new MovementTracker(userConnection));
|
||||||
// Inventory tracker
|
// Inventory tracker
|
||||||
userConnection.put(new InventoryTracker(userConnection));
|
userConnection.put(new InventoryTracker(userConnection));
|
||||||
|
// Place block tracker
|
||||||
|
userConnection.put(new PlaceBlockTracker(userConnection));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,25 @@
|
|||||||
|
package us.myles.ViaVersion.protocols.protocol1_9to1_8.chat;
|
||||||
|
|
||||||
|
import com.google.gson.JsonArray;
|
||||||
|
import com.google.gson.JsonObject;
|
||||||
|
import us.myles.ViaVersion.api.data.UserConnection;
|
||||||
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.EntityTracker;
|
||||||
|
|
||||||
|
public class ChatRewriter {
|
||||||
|
public static void toClient(JsonObject obj, UserConnection user) {
|
||||||
|
//Check gamemode change
|
||||||
|
if (obj.get("translate") != null && obj.get("translate").getAsString().equals("gameMode.changed")) {
|
||||||
|
String gameMode = user.get(EntityTracker.class).getGameMode().getText();
|
||||||
|
|
||||||
|
JsonObject gameModeObject = new JsonObject();
|
||||||
|
gameModeObject.addProperty("text", gameMode);
|
||||||
|
gameModeObject.addProperty("color", "gray");
|
||||||
|
gameModeObject.addProperty("italic", true);
|
||||||
|
|
||||||
|
JsonArray array = new JsonArray();
|
||||||
|
array.add(gameModeObject);
|
||||||
|
|
||||||
|
obj.add("with", array);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,23 @@
|
|||||||
|
package us.myles.ViaVersion.protocols.protocol1_9to1_8.chat;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.RequiredArgsConstructor;
|
||||||
|
|
||||||
|
@RequiredArgsConstructor
|
||||||
|
@Getter
|
||||||
|
public enum GameMode {
|
||||||
|
SURVIVAL(0, "Survival Mode"),
|
||||||
|
CREATIVE(1, "Creative Mode"),
|
||||||
|
ADVENTURE(2, "Adventure Mode"),
|
||||||
|
SPECTATOR(3, "Spectator Mode");
|
||||||
|
|
||||||
|
private final int id;
|
||||||
|
private final String text;
|
||||||
|
|
||||||
|
public static GameMode getById(int id) {
|
||||||
|
for (GameMode gm : GameMode.values())
|
||||||
|
if (gm.getId() == id)
|
||||||
|
return gm;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,7 @@
|
|||||||
package us.myles.ViaVersion.protocols.protocol1_9to1_8.packets;
|
package us.myles.ViaVersion.protocols.protocol1_9to1_8.packets;
|
||||||
|
|
||||||
|
import com.google.gson.JsonObject;
|
||||||
|
import com.google.gson.JsonParser;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.entity.EntityType;
|
import org.bukkit.entity.EntityType;
|
||||||
import us.myles.ViaVersion.ViaVersionPlugin;
|
import us.myles.ViaVersion.ViaVersionPlugin;
|
||||||
@ -16,6 +18,8 @@ import us.myles.ViaVersion.protocols.base.ProtocolInfo;
|
|||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.ItemRewriter;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.ItemRewriter;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.PlayerMovementMapper;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.PlayerMovementMapper;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.Protocol1_9TO1_8;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.Protocol1_9TO1_8;
|
||||||
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.chat.ChatRewriter;
|
||||||
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.chat.GameMode;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.ClientChunks;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.ClientChunks;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.EntityTracker;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.EntityTracker;
|
||||||
|
|
||||||
@ -27,6 +31,19 @@ public class PlayerPackets {
|
|||||||
public void registerMap() {
|
public void registerMap() {
|
||||||
map(Type.STRING, Protocol1_9TO1_8.FIX_JSON); // 0 - Chat Message (json)
|
map(Type.STRING, Protocol1_9TO1_8.FIX_JSON); // 0 - Chat Message (json)
|
||||||
map(Type.BYTE); // 1 - Chat Positon
|
map(Type.BYTE); // 1 - Chat Positon
|
||||||
|
|
||||||
|
handler(new PacketHandler() {
|
||||||
|
@Override
|
||||||
|
public void handle(PacketWrapper wrapper) throws Exception {
|
||||||
|
try {
|
||||||
|
JsonObject obj = (JsonObject) new JsonParser().parse(wrapper.get(Type.STRING, 0));
|
||||||
|
ChatRewriter.toClient(obj, wrapper.user());
|
||||||
|
wrapper.set(Type.STRING, 0, obj.toString());
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -160,6 +177,14 @@ public class PlayerPackets {
|
|||||||
map(Type.UNSIGNED_BYTE); // 4 - Max Players (Tab)
|
map(Type.UNSIGNED_BYTE); // 4 - Max Players (Tab)
|
||||||
map(Type.STRING); // 5 - Level Type
|
map(Type.STRING); // 5 - Level Type
|
||||||
map(Type.BOOLEAN); // 6 - Reduced Debug info
|
map(Type.BOOLEAN); // 6 - Reduced Debug info
|
||||||
|
|
||||||
|
handler(new PacketHandler() {
|
||||||
|
@Override
|
||||||
|
public void handle(PacketWrapper wrapper) throws Exception {
|
||||||
|
EntityTracker tracker = wrapper.user().get(EntityTracker.class);
|
||||||
|
tracker.setGameMode(GameMode.getById(wrapper.get(Type.UNSIGNED_BYTE, 0))); //Set player gamemode
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -283,6 +308,11 @@ public class PlayerPackets {
|
|||||||
protocol.registerOutgoing(State.PLAY, 0x07, 0x33, new PacketRemapper() {
|
protocol.registerOutgoing(State.PLAY, 0x07, 0x33, new PacketRemapper() {
|
||||||
@Override
|
@Override
|
||||||
public void registerMap() {
|
public void registerMap() {
|
||||||
|
map(Type.INT); // 0 - Dimension
|
||||||
|
map(Type.UNSIGNED_BYTE); // 1 - Difficulty
|
||||||
|
map(Type.UNSIGNED_BYTE); // 2 - GameMode
|
||||||
|
map(Type.STRING); // 3 - Level Type
|
||||||
|
|
||||||
handler(new PacketHandler() {
|
handler(new PacketHandler() {
|
||||||
@Override
|
@Override
|
||||||
public void handle(PacketWrapper wrapper) throws Exception {
|
public void handle(PacketWrapper wrapper) throws Exception {
|
||||||
@ -290,6 +320,28 @@ public class PlayerPackets {
|
|||||||
ClientChunks cc = wrapper.user().get(ClientChunks.class);
|
ClientChunks cc = wrapper.user().get(ClientChunks.class);
|
||||||
cc.getBulkChunks().clear();
|
cc.getBulkChunks().clear();
|
||||||
cc.getLoadedChunks().clear();
|
cc.getLoadedChunks().clear();
|
||||||
|
|
||||||
|
int gamemode = wrapper.get(Type.UNSIGNED_BYTE, 0);
|
||||||
|
wrapper.user().get(EntityTracker.class).setGameMode(GameMode.getById(gamemode));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Change Game State Packet
|
||||||
|
protocol.registerOutgoing(State.PLAY, 0x2B, 0x1E, new PacketRemapper() {
|
||||||
|
@Override
|
||||||
|
public void registerMap() {
|
||||||
|
map(Type.UNSIGNED_BYTE); //0 - Reason
|
||||||
|
map(Type.FLOAT); //1 - Value
|
||||||
|
|
||||||
|
handler(new PacketHandler() {
|
||||||
|
@Override
|
||||||
|
public void handle(PacketWrapper wrapper) throws Exception {
|
||||||
|
if (wrapper.get(Type.UNSIGNED_BYTE, 0) == 3) { //Change gamemode
|
||||||
|
int gamemode = wrapper.get(Type.FLOAT, 0).intValue();
|
||||||
|
wrapper.user().get(EntityTracker.class).setGameMode(GameMode.getById(gamemode));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -333,7 +385,6 @@ public class PlayerPackets {
|
|||||||
protocol.registerOutgoing(State.PLAY, 0x00, 0x1F); // Keep Alive Packet
|
protocol.registerOutgoing(State.PLAY, 0x00, 0x1F); // Keep Alive Packet
|
||||||
protocol.registerOutgoing(State.PLAY, 0x48, 0x32); // Resource Pack Send Packet
|
protocol.registerOutgoing(State.PLAY, 0x48, 0x32); // Resource Pack Send Packet
|
||||||
protocol.registerOutgoing(State.PLAY, 0x43, 0x36); // Camera Packet
|
protocol.registerOutgoing(State.PLAY, 0x43, 0x36); // Camera Packet
|
||||||
protocol.registerOutgoing(State.PLAY, 0x2B, 0x1E); // Change Game State Packet
|
|
||||||
|
|
||||||
protocol.registerOutgoing(State.PLAY, 0x3D, 0x38); // Display Scoreboard Packet
|
protocol.registerOutgoing(State.PLAY, 0x3D, 0x38); // Display Scoreboard Packet
|
||||||
protocol.registerOutgoing(State.PLAY, 0x3B, 0x3F); // Scoreboard Objective Packet
|
protocol.registerOutgoing(State.PLAY, 0x3B, 0x3F); // Scoreboard Objective Packet
|
||||||
|
@ -14,13 +14,13 @@ import us.myles.ViaVersion.api.remapper.PacketRemapper;
|
|||||||
import us.myles.ViaVersion.api.remapper.ValueCreator;
|
import us.myles.ViaVersion.api.remapper.ValueCreator;
|
||||||
import us.myles.ViaVersion.api.type.Type;
|
import us.myles.ViaVersion.api.type.Type;
|
||||||
import us.myles.ViaVersion.packets.State;
|
import us.myles.ViaVersion.packets.State;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.ArmorType;
|
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.ItemRewriter;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.ItemRewriter;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.Protocol1_9TO1_8;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.Protocol1_9TO1_8;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.sounds.Effect;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.sounds.Effect;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.sounds.SoundEffect;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.sounds.SoundEffect;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.ClientChunks;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.ClientChunks;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.EntityTracker;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.EntityTracker;
|
||||||
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.storage.PlaceBlockTracker;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.types.ChunkType;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.types.ChunkType;
|
||||||
|
|
||||||
public class WorldPackets {
|
public class WorldPackets {
|
||||||
@ -349,32 +349,12 @@ public class WorldPackets {
|
|||||||
handler(new PacketHandler() {
|
handler(new PacketHandler() {
|
||||||
@Override
|
@Override
|
||||||
public void handle(PacketWrapper wrapper) throws Exception {
|
public void handle(PacketWrapper wrapper) throws Exception {
|
||||||
Item item = wrapper.get(Type.ITEM, 0);
|
Position position = wrapper.get(Type.POSITION, 0);
|
||||||
if (item != null) {
|
PlaceBlockTracker tracker = wrapper.user().get(PlaceBlockTracker.class);
|
||||||
Material m = Material.getMaterial(item.getId());
|
if (tracker.getLastPlacedPosition() != null && tracker.getLastPlacedPosition().equals(position) && !tracker.isExpired(50))
|
||||||
if (m != null) {
|
wrapper.cancel();
|
||||||
// Prevent special items from sending certain info
|
tracker.updateTime();
|
||||||
// Books
|
tracker.setLastPlacedPosition(position);
|
||||||
boolean special = m == Material.WRITTEN_BOOK;
|
|
||||||
// Buckets
|
|
||||||
special = special || m == Material.WATER_BUCKET || m == Material.LAVA_BUCKET || m == Material.BUCKET;
|
|
||||||
// Food
|
|
||||||
special = special || m.isEdible();
|
|
||||||
// Potions
|
|
||||||
special = special || m == Material.POTION || m == Material.GLASS_BOTTLE;
|
|
||||||
// Projectiles
|
|
||||||
special = special || m == Material.BOW;
|
|
||||||
special = special || m == Material.SNOW_BALL || m == Material.EGG || m == Material.EXP_BOTTLE || m == Material.ENDER_PEARL || m == Material.EYE_OF_ENDER;
|
|
||||||
// Armour
|
|
||||||
special = special || ArmorType.isArmor(m);
|
|
||||||
// Don't send data if special
|
|
||||||
if (special && m != Material.AIR) {
|
|
||||||
EntityTracker tracker = wrapper.user().get(EntityTracker.class);
|
|
||||||
tracker.setLastPlaceBlock(wrapper.user().getReceivedPackets());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -22,6 +22,7 @@ import us.myles.ViaVersion.api.minecraft.item.Item;
|
|||||||
import us.myles.ViaVersion.api.minecraft.metadata.Metadata;
|
import us.myles.ViaVersion.api.minecraft.metadata.Metadata;
|
||||||
import us.myles.ViaVersion.api.type.Type;
|
import us.myles.ViaVersion.api.type.Type;
|
||||||
import us.myles.ViaVersion.protocols.base.ProtocolInfo;
|
import us.myles.ViaVersion.protocols.base.ProtocolInfo;
|
||||||
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.chat.GameMode;
|
||||||
import us.myles.ViaVersion.protocols.protocol1_9to1_8.metadata.NewType;
|
import us.myles.ViaVersion.protocols.protocol1_9to1_8.metadata.NewType;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
@ -47,6 +48,8 @@ public class EntityTracker extends StoredObject {
|
|||||||
@Setter
|
@Setter
|
||||||
private Position currentlyDigging = null;
|
private Position currentlyDigging = null;
|
||||||
private boolean teamExists = false;
|
private boolean teamExists = false;
|
||||||
|
@Setter
|
||||||
|
private GameMode gameMode;
|
||||||
|
|
||||||
public EntityTracker(UserConnection user) {
|
public EntityTracker(UserConnection user) {
|
||||||
super(user);
|
super(user);
|
||||||
|
@ -0,0 +1,26 @@
|
|||||||
|
package us.myles.ViaVersion.protocols.protocol1_9to1_8.storage;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import us.myles.ViaVersion.api.data.StoredObject;
|
||||||
|
import us.myles.ViaVersion.api.data.UserConnection;
|
||||||
|
import us.myles.ViaVersion.api.minecraft.Position;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public class PlaceBlockTracker extends StoredObject {
|
||||||
|
private long lastPlaceTimestamp = System.currentTimeMillis();
|
||||||
|
@Setter
|
||||||
|
private Position lastPlacedPosition = null;
|
||||||
|
|
||||||
|
public PlaceBlockTracker(UserConnection user) {
|
||||||
|
super(user);
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isExpired(int ms) {
|
||||||
|
return System.currentTimeMillis() > (lastPlaceTimestamp + ms);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void updateTime() {
|
||||||
|
lastPlaceTimestamp = System.currentTimeMillis();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user