Mirror von
https://github.com/ViaVersion/ViaVersion.git
synchronisiert 2024-11-19 14:30:16 +01:00
24w06a
Dieser Commit ist enthalten in:
Ursprung
0fcb764652
Commit
4a8bd2cca2
@ -23,12 +23,13 @@
|
|||||||
package com.viaversion.viaversion.api.minecraft;
|
package com.viaversion.viaversion.api.minecraft;
|
||||||
|
|
||||||
import com.github.steveice10.opennbt.tag.builtin.Tag;
|
import com.github.steveice10.opennbt.tag.builtin.Tag;
|
||||||
|
import org.checkerframework.checker.nullness.qual.Nullable;
|
||||||
|
|
||||||
public final class RegistryEntry {
|
public final class RegistryEntry {
|
||||||
private final String key;
|
private final String key;
|
||||||
private final Tag tag;
|
private final Tag tag;
|
||||||
|
|
||||||
public RegistryEntry(String key, Tag tag) {
|
public RegistryEntry(String key, @Nullable Tag tag) {
|
||||||
this.key = key;
|
this.key = key;
|
||||||
this.tag = tag;
|
this.tag = tag;
|
||||||
}
|
}
|
||||||
@ -37,11 +38,11 @@ public final class RegistryEntry {
|
|||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Tag tag() {
|
public @Nullable Tag tag() {
|
||||||
return tag;
|
return tag;
|
||||||
}
|
}
|
||||||
|
|
||||||
public RegistryEntry withKey(final String key) {
|
public RegistryEntry withKey(final String key) {
|
||||||
return new RegistryEntry(key, tag.copy());
|
return new RegistryEntry(key, tag != null ? tag.copy() : null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -100,7 +100,7 @@ public enum EntityTypes1_20_5 implements EntityType {
|
|||||||
DONKEY(CHESTED_HORSE),
|
DONKEY(CHESTED_HORSE),
|
||||||
MULE(CHESTED_HORSE),
|
MULE(CHESTED_HORSE),
|
||||||
LLAMA(CHESTED_HORSE),
|
LLAMA(CHESTED_HORSE),
|
||||||
TRADER_LLAMA(CHESTED_HORSE),
|
TRADER_LLAMA(LLAMA),
|
||||||
HORSE(ABSTRACT_HORSE),
|
HORSE(ABSTRACT_HORSE),
|
||||||
SKELETON_HORSE(ABSTRACT_HORSE),
|
SKELETON_HORSE(ABSTRACT_HORSE),
|
||||||
ZOMBIE_HORSE(ABSTRACT_HORSE),
|
ZOMBIE_HORSE(ABSTRACT_HORSE),
|
||||||
@ -220,7 +220,9 @@ public enum EntityTypes1_20_5 implements EntityType {
|
|||||||
EGG(PROJECTILE_ABSTRACT),
|
EGG(PROJECTILE_ABSTRACT),
|
||||||
POTION(PROJECTILE_ABSTRACT),
|
POTION(PROJECTILE_ABSTRACT),
|
||||||
EXPERIENCE_BOTTLE(PROJECTILE_ABSTRACT),
|
EXPERIENCE_BOTTLE(PROJECTILE_ABSTRACT),
|
||||||
WIND_CHARGE(PROJECTILE_ABSTRACT),
|
ABSTRACT_WIND_CHARGE(PROJECTILE_ABSTRACT, null),
|
||||||
|
WIND_CHARGE(ABSTRACT_WIND_CHARGE),
|
||||||
|
BREEZE_WIND_CHARGE(ABSTRACT_WIND_CHARGE),
|
||||||
|
|
||||||
// Vehicles
|
// Vehicles
|
||||||
MINECART_ABSTRACT(ENTITY, null),
|
MINECART_ABSTRACT(ENTITY, null),
|
||||||
|
@ -86,7 +86,7 @@ public class ProtocolVersion {
|
|||||||
public static final ProtocolVersion v1_20 = register(763, "1.20/1.20.1", new VersionRange("1.20", 0, 1));
|
public static final ProtocolVersion v1_20 = register(763, "1.20/1.20.1", new VersionRange("1.20", 0, 1));
|
||||||
public static final ProtocolVersion v1_20_2 = register(764, "1.20.2");
|
public static final ProtocolVersion v1_20_2 = register(764, "1.20.2");
|
||||||
public static final ProtocolVersion v1_20_3 = register(765, "1.20.3/1.20.4", new VersionRange("1.20", 3, 4));
|
public static final ProtocolVersion v1_20_3 = register(765, "1.20.3/1.20.4", new VersionRange("1.20", 3, 4));
|
||||||
public static final ProtocolVersion v1_20_5 = register(766, 175, "1.20.5");
|
public static final ProtocolVersion v1_20_5 = register(766, 176, "1.20.5");
|
||||||
public static final ProtocolVersion unknown = register(-1, "UNKNOWN");
|
public static final ProtocolVersion unknown = register(-1, "UNKNOWN");
|
||||||
|
|
||||||
public static ProtocolVersion register(int version, String name) {
|
public static ProtocolVersion register(int version, String name) {
|
||||||
|
@ -34,12 +34,12 @@ public class RegistryEntryType extends Type<RegistryEntry> {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public RegistryEntry read(final ByteBuf buffer) throws Exception {
|
public RegistryEntry read(final ByteBuf buffer) throws Exception {
|
||||||
return new RegistryEntry(Type.STRING.read(buffer), Type.TAG.read(buffer));
|
return new RegistryEntry(Type.STRING.read(buffer), Type.OPTIONAL_TAG.read(buffer));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(final ByteBuf buffer, final RegistryEntry entry) throws Exception {
|
public void write(final ByteBuf buffer, final RegistryEntry entry) throws Exception {
|
||||||
Type.STRING.write(buffer, entry.key());
|
Type.STRING.write(buffer, entry.key());
|
||||||
Type.TAG.write(buffer, entry.tag());
|
Type.OPTIONAL_TAG.write(buffer, entry.tag());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -27,11 +27,13 @@ import com.viaversion.viaversion.api.minecraft.metadata.types.MetaTypes1_20_5;
|
|||||||
import com.viaversion.viaversion.api.type.Type;
|
import com.viaversion.viaversion.api.type.Type;
|
||||||
import com.viaversion.viaversion.api.type.types.metadata.MetaListType;
|
import com.viaversion.viaversion.api.type.types.metadata.MetaListType;
|
||||||
import com.viaversion.viaversion.api.type.types.metadata.MetadataType;
|
import com.viaversion.viaversion.api.type.types.metadata.MetadataType;
|
||||||
|
import com.viaversion.viaversion.api.type.types.misc.ParticleType;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public final class Types1_20_5 {
|
public final class Types1_20_5 {
|
||||||
|
|
||||||
public static final MetaTypes1_20_5 META_TYPES = new MetaTypes1_20_5(Types1_20_3.PARTICLE);
|
public static final ParticleType PARTICLE = new ParticleType(); // Only safe to use after protocol loading
|
||||||
|
public static final MetaTypes1_20_5 META_TYPES = new MetaTypes1_20_5(PARTICLE);
|
||||||
public static final Type<Metadata> METADATA = new MetadataType(META_TYPES);
|
public static final Type<Metadata> METADATA = new MetadataType(META_TYPES);
|
||||||
public static final Type<List<Metadata>> METADATA_LIST = new MetaListType(METADATA);
|
public static final Type<List<Metadata>> METADATA_LIST = new MetaListType(METADATA);
|
||||||
}
|
}
|
||||||
|
@ -57,4 +57,13 @@ public final class TrackedEntityImpl implements TrackedEntity {
|
|||||||
public void sentMetadata(final boolean sentMetadata) {
|
public void sentMetadata(final boolean sentMetadata) {
|
||||||
this.sentMetadata = sentMetadata;
|
this.sentMetadata = sentMetadata;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "TrackedEntityImpl{" +
|
||||||
|
"entityType=" + entityType +
|
||||||
|
", data=" + data +
|
||||||
|
", sentMetadata=" + sentMetadata +
|
||||||
|
'}';
|
||||||
|
}
|
||||||
}
|
}
|
@ -26,6 +26,8 @@ import com.viaversion.viaversion.api.protocol.packet.State;
|
|||||||
import com.viaversion.viaversion.api.protocol.packet.provider.PacketTypesProvider;
|
import com.viaversion.viaversion.api.protocol.packet.provider.PacketTypesProvider;
|
||||||
import com.viaversion.viaversion.api.protocol.packet.provider.SimplePacketTypesProvider;
|
import com.viaversion.viaversion.api.protocol.packet.provider.SimplePacketTypesProvider;
|
||||||
import com.viaversion.viaversion.api.type.Type;
|
import com.viaversion.viaversion.api.type.Type;
|
||||||
|
import com.viaversion.viaversion.api.type.types.misc.ParticleType;
|
||||||
|
import com.viaversion.viaversion.api.type.types.version.Types1_20_5;
|
||||||
import com.viaversion.viaversion.data.entity.EntityTrackerBase;
|
import com.viaversion.viaversion.data.entity.EntityTrackerBase;
|
||||||
import com.viaversion.viaversion.protocols.base.ClientboundLoginPackets;
|
import com.viaversion.viaversion.protocols.base.ClientboundLoginPackets;
|
||||||
import com.viaversion.viaversion.protocols.base.ServerboundLoginPackets;
|
import com.viaversion.viaversion.protocols.base.ServerboundLoginPackets;
|
||||||
@ -86,6 +88,7 @@ public final class Protocol1_20_5To1_20_3 extends AbstractProtocol<ClientboundPa
|
|||||||
|
|
||||||
cancelServerbound(State.LOGIN, ServerboundLoginPackets.COOKIE_RESPONSE.getId());
|
cancelServerbound(State.LOGIN, ServerboundLoginPackets.COOKIE_RESPONSE.getId());
|
||||||
cancelServerbound(ServerboundConfigurationPackets1_20_5.COOKIE_RESPONSE);
|
cancelServerbound(ServerboundConfigurationPackets1_20_5.COOKIE_RESPONSE);
|
||||||
|
cancelServerbound(ServerboundConfigurationPackets1_20_5.SELECT_KNOWN_PACKS);
|
||||||
cancelServerbound(ServerboundPackets1_20_5.COOKIE_RESPONSE);
|
cancelServerbound(ServerboundPackets1_20_5.COOKIE_RESPONSE);
|
||||||
cancelServerbound(ServerboundPackets1_20_5.DEBUG_SAMPLE_SUBSCRIPTION);
|
cancelServerbound(ServerboundPackets1_20_5.DEBUG_SAMPLE_SUBSCRIPTION);
|
||||||
}
|
}
|
||||||
@ -95,6 +98,16 @@ public final class Protocol1_20_5To1_20_3 extends AbstractProtocol<ClientboundPa
|
|||||||
super.onMappingDataLoaded();
|
super.onMappingDataLoaded();
|
||||||
|
|
||||||
EntityTypes1_20_5.initialize(this);
|
EntityTypes1_20_5.initialize(this);
|
||||||
|
Types1_20_5.PARTICLE.filler(this)
|
||||||
|
.reader("block", ParticleType.Readers.BLOCK)
|
||||||
|
.reader("block_marker", ParticleType.Readers.BLOCK)
|
||||||
|
.reader("dust", ParticleType.Readers.DUST)
|
||||||
|
.reader("falling_dust", ParticleType.Readers.BLOCK)
|
||||||
|
.reader("dust_color_transition", ParticleType.Readers.DUST_TRANSITION)
|
||||||
|
.reader("item", ParticleType.Readers.ITEM1_20_2)
|
||||||
|
.reader("vibration", ParticleType.Readers.VIBRATION1_20_3)
|
||||||
|
.reader("sculk_charge", ParticleType.Readers.SCULK_CHARGE)
|
||||||
|
.reader("shriek", ParticleType.Readers.SHRIEK);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -33,7 +33,8 @@ public enum ClientboundConfigurationPackets1_20_5 implements ClientboundPacket1_
|
|||||||
STORE_COOKIE, // 0x09
|
STORE_COOKIE, // 0x09
|
||||||
TRANSFER, // 0x0A
|
TRANSFER, // 0x0A
|
||||||
UPDATE_ENABLED_FEATURES, // 0x0B
|
UPDATE_ENABLED_FEATURES, // 0x0B
|
||||||
UPDATE_TAGS; // 0x0C
|
UPDATE_TAGS, // 0x0C
|
||||||
|
SELECT_KNOWN_PACKS; // 0x0D
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getId() {
|
public int getId() {
|
||||||
|
@ -47,99 +47,99 @@ public enum ClientboundPackets1_20_5 implements ClientboundPacket1_20_5 {
|
|||||||
PLUGIN_MESSAGE, // 0x19
|
PLUGIN_MESSAGE, // 0x19
|
||||||
DAMAGE_EVENT, // 0x1A
|
DAMAGE_EVENT, // 0x1A
|
||||||
DEBUG_SAMPLE, // 0x1B
|
DEBUG_SAMPLE, // 0x1B
|
||||||
DELETE_CHAT_MESSAGE, // 0x1B
|
DELETE_CHAT_MESSAGE, // 0x1C
|
||||||
DISCONNECT, // 0x1C
|
DISCONNECT, // 0x1D
|
||||||
DISGUISED_CHAT, // 0x1D
|
DISGUISED_CHAT, // 0x1E
|
||||||
ENTITY_STATUS, // 0x1E
|
ENTITY_STATUS, // 0x1F
|
||||||
EXPLOSION, // 0x1F
|
EXPLOSION, // 0x20
|
||||||
UNLOAD_CHUNK, // 0x20
|
UNLOAD_CHUNK, // 0x21
|
||||||
GAME_EVENT, // 0x21
|
GAME_EVENT, // 0x22
|
||||||
OPEN_HORSE_WINDOW, // 0x22
|
OPEN_HORSE_WINDOW, // 0x23
|
||||||
HIT_ANIMATION, // 0x23
|
HIT_ANIMATION, // 0x24
|
||||||
WORLD_BORDER_INIT, // 0x24
|
WORLD_BORDER_INIT, // 0x25
|
||||||
KEEP_ALIVE, // 0x25
|
KEEP_ALIVE, // 0x26
|
||||||
CHUNK_DATA, // 0x26
|
CHUNK_DATA, // 0x27
|
||||||
EFFECT, // 0x27
|
EFFECT, // 0x28
|
||||||
SPAWN_PARTICLE, // 0x28
|
SPAWN_PARTICLE, // 0x29
|
||||||
UPDATE_LIGHT, // 0x29
|
UPDATE_LIGHT, // 0x2A
|
||||||
JOIN_GAME, // 0x2A
|
JOIN_GAME, // 0x2B
|
||||||
MAP_DATA, // 0x2B
|
MAP_DATA, // 0x2C
|
||||||
TRADE_LIST, // 0x2C
|
TRADE_LIST, // 0x2D
|
||||||
ENTITY_POSITION, // 0x2D
|
ENTITY_POSITION, // 0x2E
|
||||||
ENTITY_POSITION_AND_ROTATION, // 0x2E
|
ENTITY_POSITION_AND_ROTATION, // 0x2F
|
||||||
ENTITY_ROTATION, // 0x2F
|
ENTITY_ROTATION, // 0x30
|
||||||
VEHICLE_MOVE, // 0x30
|
VEHICLE_MOVE, // 0x31
|
||||||
OPEN_BOOK, // 0x31
|
OPEN_BOOK, // 0x32
|
||||||
OPEN_WINDOW, // 0x32
|
OPEN_WINDOW, // 0x33
|
||||||
OPEN_SIGN_EDITOR, // 0x33
|
OPEN_SIGN_EDITOR, // 0x34
|
||||||
PING, // 0x34
|
PING, // 0x35
|
||||||
PONG_RESPONSE, // 0x35
|
PONG_RESPONSE, // 0x36
|
||||||
CRAFT_RECIPE_RESPONSE, // 0x36
|
CRAFT_RECIPE_RESPONSE, // 0x37
|
||||||
PLAYER_ABILITIES, // 0x37
|
PLAYER_ABILITIES, // 0x38
|
||||||
PLAYER_CHAT, // 0x38
|
PLAYER_CHAT, // 0x39
|
||||||
COMBAT_END, // 0x39
|
COMBAT_END, // 0x3A
|
||||||
COMBAT_ENTER, // 0x3A
|
COMBAT_ENTER, // 0x3B
|
||||||
COMBAT_KILL, // 0x3B
|
COMBAT_KILL, // 0x3C
|
||||||
PLAYER_INFO_REMOVE, // 0x3C
|
PLAYER_INFO_REMOVE, // 0x3D
|
||||||
PLAYER_INFO_UPDATE, // 0x3D
|
PLAYER_INFO_UPDATE, // 0x3E
|
||||||
FACE_PLAYER, // 0x3E
|
FACE_PLAYER, // 0x3F
|
||||||
PLAYER_POSITION, // 0x3F
|
PLAYER_POSITION, // 0x40
|
||||||
UNLOCK_RECIPES, // 0x40
|
UNLOCK_RECIPES, // 0x41
|
||||||
REMOVE_ENTITIES, // 0x41
|
REMOVE_ENTITIES, // 0x42
|
||||||
REMOVE_ENTITY_EFFECT, // 0x42
|
REMOVE_ENTITY_EFFECT, // 0x43
|
||||||
RESET_SCORE, // 0x43
|
RESET_SCORE, // 0x44
|
||||||
RESOURCE_PACK_POP, // 0x44
|
RESOURCE_PACK_POP, // 0x45
|
||||||
RESOURCE_PACK_PUSH, // 0x45
|
RESOURCE_PACK_PUSH, // 0x46
|
||||||
RESPAWN, // 0x46
|
RESPAWN, // 0x47
|
||||||
ENTITY_HEAD_LOOK, // 0x47
|
ENTITY_HEAD_LOOK, // 0x48
|
||||||
MULTI_BLOCK_CHANGE, // 0x48
|
MULTI_BLOCK_CHANGE, // 0x49
|
||||||
SELECT_ADVANCEMENTS_TAB, // 0x49
|
SELECT_ADVANCEMENTS_TAB, // 0x4A
|
||||||
SERVER_DATA, // 0x4A
|
SERVER_DATA, // 0x4B
|
||||||
ACTIONBAR, // 0x4B
|
ACTIONBAR, // 0x4C
|
||||||
WORLD_BORDER_CENTER, // 0x4C
|
WORLD_BORDER_CENTER, // 0x4D
|
||||||
WORLD_BORDER_LERP_SIZE, // 0x4D
|
WORLD_BORDER_LERP_SIZE, // 0x4E
|
||||||
WORLD_BORDER_SIZE, // 0x4E
|
WORLD_BORDER_SIZE, // 0x4F
|
||||||
WORLD_BORDER_WARNING_DELAY, // 0x4F
|
WORLD_BORDER_WARNING_DELAY, // 0x50
|
||||||
WORLD_BORDER_WARNING_DISTANCE, // 0x50
|
WORLD_BORDER_WARNING_DISTANCE, // 0x51
|
||||||
CAMERA, // 0x51
|
CAMERA, // 0x52
|
||||||
HELD_ITEM_CHANGE, // 0x52
|
HELD_ITEM_CHANGE, // 0x53
|
||||||
UPDATE_VIEW_POSITION, // 0x53
|
UPDATE_VIEW_POSITION, // 0x54
|
||||||
UPDATE_VIEW_DISTANCE, // 0x54
|
UPDATE_VIEW_DISTANCE, // 0x55
|
||||||
SPAWN_POSITION, // 0x55
|
SPAWN_POSITION, // 0x56
|
||||||
DISPLAY_SCOREBOARD, // 0x56
|
DISPLAY_SCOREBOARD, // 0x57
|
||||||
ENTITY_METADATA, // 0x57
|
ENTITY_METADATA, // 0x58
|
||||||
ATTACH_ENTITY, // 0x58
|
ATTACH_ENTITY, // 0x59
|
||||||
ENTITY_VELOCITY, // 0x59
|
ENTITY_VELOCITY, // 0x5A
|
||||||
ENTITY_EQUIPMENT, // 0x5A
|
ENTITY_EQUIPMENT, // 0x5B
|
||||||
SET_EXPERIENCE, // 0x5B
|
SET_EXPERIENCE, // 0x5C
|
||||||
UPDATE_HEALTH, // 0x5C
|
UPDATE_HEALTH, // 0x5D
|
||||||
SCOREBOARD_OBJECTIVE, // 0x5D
|
SCOREBOARD_OBJECTIVE, // 0x5E
|
||||||
SET_PASSENGERS, // 0x5E
|
SET_PASSENGERS, // 0x5F
|
||||||
TEAMS, // 0x5F
|
TEAMS, // 0x60
|
||||||
UPDATE_SCORE, // 0x60
|
UPDATE_SCORE, // 0x61
|
||||||
SET_SIMULATION_DISTANCE, // 0x61
|
SET_SIMULATION_DISTANCE, // 0x62
|
||||||
TITLE_SUBTITLE, // 0x62
|
TITLE_SUBTITLE, // 0x63
|
||||||
TIME_UPDATE, // 0x63
|
TIME_UPDATE, // 0x64
|
||||||
TITLE_TEXT, // 0x64
|
TITLE_TEXT, // 0x65
|
||||||
TITLE_TIMES, // 0x65
|
TITLE_TIMES, // 0x66
|
||||||
ENTITY_SOUND, // 0x66
|
ENTITY_SOUND, // 0x67
|
||||||
SOUND, // 0x67
|
SOUND, // 0x68
|
||||||
START_CONFIGURATION, // 0x68
|
START_CONFIGURATION, // 0x69
|
||||||
STOP_SOUND, // 0x69
|
STOP_SOUND, // 0x6A
|
||||||
STORE_COOKIE, // 0x6A
|
STORE_COOKIE, // 0x6B
|
||||||
SYSTEM_CHAT, // 0x6B
|
SYSTEM_CHAT, // 0x6C
|
||||||
TAB_LIST, // 0x6C
|
TAB_LIST, // 0x6D
|
||||||
NBT_QUERY, // 0x6D
|
NBT_QUERY, // 0x6E
|
||||||
COLLECT_ITEM, // 0x6E
|
COLLECT_ITEM, // 0x6F
|
||||||
ENTITY_TELEPORT, // 0x6F
|
ENTITY_TELEPORT, // 0x70
|
||||||
TICKING_STATE, // 0x70
|
TICKING_STATE, // 0x71
|
||||||
TICKING_STEP, // 0x71
|
TICKING_STEP, // 0x72
|
||||||
TRANSFER, // 0x72
|
TRANSFER, // 0x73
|
||||||
ADVANCEMENTS, // 0x73
|
ADVANCEMENTS, // 0x74
|
||||||
ENTITY_PROPERTIES, // 0x74
|
ENTITY_PROPERTIES, // 0x75
|
||||||
ENTITY_EFFECT, // 0x75
|
ENTITY_EFFECT, // 0x76
|
||||||
DECLARE_RECIPES, // 0x76
|
DECLARE_RECIPES, // 0x77
|
||||||
TAGS; // 0x77
|
TAGS; // 0x78
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getId() {
|
public int getId() {
|
||||||
|
@ -27,7 +27,8 @@ public enum ServerboundConfigurationPackets1_20_5 implements ServerboundPacket1_
|
|||||||
FINISH_CONFIGURATION, // 0x03
|
FINISH_CONFIGURATION, // 0x03
|
||||||
KEEP_ALIVE, // 0x04
|
KEEP_ALIVE, // 0x04
|
||||||
PONG, // 0x05
|
PONG, // 0x05
|
||||||
RESOURCE_PACK; // 0x06
|
RESOURCE_PACK, // 0x06
|
||||||
|
SELECT_KNOWN_PACKS; // 0x07
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getId() {
|
public int getId() {
|
||||||
|
@ -38,44 +38,44 @@ public enum ServerboundPackets1_20_5 implements ServerboundPacket1_20_5 {
|
|||||||
COOKIE_RESPONSE, // 0x10
|
COOKIE_RESPONSE, // 0x10
|
||||||
PLUGIN_MESSAGE, // 0x11
|
PLUGIN_MESSAGE, // 0x11
|
||||||
DEBUG_SAMPLE_SUBSCRIPTION, // 0x12
|
DEBUG_SAMPLE_SUBSCRIPTION, // 0x12
|
||||||
EDIT_BOOK, // 0x12
|
EDIT_BOOK, // 0x13
|
||||||
ENTITY_NBT_REQUEST, // 0x13
|
ENTITY_NBT_REQUEST, // 0x14
|
||||||
INTERACT_ENTITY, // 0x14
|
INTERACT_ENTITY, // 0x15
|
||||||
GENERATE_JIGSAW, // 0x15
|
GENERATE_JIGSAW, // 0x16
|
||||||
KEEP_ALIVE, // 0x16
|
KEEP_ALIVE, // 0x17
|
||||||
LOCK_DIFFICULTY, // 0x17
|
LOCK_DIFFICULTY, // 0x18
|
||||||
PLAYER_POSITION, // 0x18
|
PLAYER_POSITION, // 0x19
|
||||||
PLAYER_POSITION_AND_ROTATION, // 0x19
|
PLAYER_POSITION_AND_ROTATION, // 0x1A
|
||||||
PLAYER_ROTATION, // 0x1A
|
PLAYER_ROTATION, // 0x1B
|
||||||
PLAYER_MOVEMENT, // 0x1B
|
PLAYER_MOVEMENT, // 0x1C
|
||||||
VEHICLE_MOVE, // 0x1C
|
VEHICLE_MOVE, // 0x1D
|
||||||
STEER_BOAT, // 0x1D
|
STEER_BOAT, // 0x1E
|
||||||
PICK_ITEM, // 0x1E
|
PICK_ITEM, // 0x1F
|
||||||
PING_REQUEST, // 0x1F
|
PING_REQUEST, // 0x20
|
||||||
CRAFT_RECIPE_REQUEST, // 0x20
|
CRAFT_RECIPE_REQUEST, // 0x21
|
||||||
PLAYER_ABILITIES, // 0x21
|
PLAYER_ABILITIES, // 0x22
|
||||||
PLAYER_DIGGING, // 0x22
|
PLAYER_DIGGING, // 0x23
|
||||||
ENTITY_ACTION, // 0x23
|
ENTITY_ACTION, // 0x24
|
||||||
STEER_VEHICLE, // 0x24
|
STEER_VEHICLE, // 0x25
|
||||||
PONG, // 0x25
|
PONG, // 0x26
|
||||||
RECIPE_BOOK_DATA, // 0x26
|
RECIPE_BOOK_DATA, // 0x27
|
||||||
SEEN_RECIPE, // 0x27
|
SEEN_RECIPE, // 0x28
|
||||||
RENAME_ITEM, // 0x28
|
RENAME_ITEM, // 0x29
|
||||||
RESOURCE_PACK_STATUS, // 0x29
|
RESOURCE_PACK_STATUS, // 0x2A
|
||||||
ADVANCEMENT_TAB, // 0x2A
|
ADVANCEMENT_TAB, // 0x2B
|
||||||
SELECT_TRADE, // 0x2B
|
SELECT_TRADE, // 0x2C
|
||||||
SET_BEACON_EFFECT, // 0x2C
|
SET_BEACON_EFFECT, // 0x2D
|
||||||
HELD_ITEM_CHANGE, // 0x2D
|
HELD_ITEM_CHANGE, // 0x2E
|
||||||
UPDATE_COMMAND_BLOCK, // 0x2E
|
UPDATE_COMMAND_BLOCK, // 0x2F
|
||||||
UPDATE_COMMAND_BLOCK_MINECART, // 0x2F
|
UPDATE_COMMAND_BLOCK_MINECART, // 0x30
|
||||||
CREATIVE_INVENTORY_ACTION, // 0x30
|
CREATIVE_INVENTORY_ACTION, // 0x31
|
||||||
UPDATE_JIGSAW_BLOCK, // 0x31
|
UPDATE_JIGSAW_BLOCK, // 0x32
|
||||||
UPDATE_STRUCTURE_BLOCK, // 0x32
|
UPDATE_STRUCTURE_BLOCK, // 0x33
|
||||||
UPDATE_SIGN, // 0x33
|
UPDATE_SIGN, // 0x34
|
||||||
ANIMATION, // 0x34
|
ANIMATION, // 0x35
|
||||||
SPECTATE, // 0x35
|
SPECTATE, // 0x36
|
||||||
PLAYER_BLOCK_PLACEMENT, // 0x36
|
PLAYER_BLOCK_PLACEMENT, // 0x37
|
||||||
USE_ITEM; // 0x37
|
USE_ITEM; // 0x38
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getId() {
|
public int getId() {
|
||||||
|
@ -24,6 +24,7 @@ import com.viaversion.viaversion.api.minecraft.item.Item;
|
|||||||
import com.viaversion.viaversion.api.type.Type;
|
import com.viaversion.viaversion.api.type.Type;
|
||||||
import com.viaversion.viaversion.api.type.types.chunk.ChunkType1_20_2;
|
import com.viaversion.viaversion.api.type.types.chunk.ChunkType1_20_2;
|
||||||
import com.viaversion.viaversion.api.type.types.version.Types1_20_3;
|
import com.viaversion.viaversion.api.type.types.version.Types1_20_3;
|
||||||
|
import com.viaversion.viaversion.api.type.types.version.Types1_20_5;
|
||||||
import com.viaversion.viaversion.protocols.protocol1_20_3to1_20_2.packet.ClientboundPacket1_20_3;
|
import com.viaversion.viaversion.protocols.protocol1_20_3to1_20_2.packet.ClientboundPacket1_20_3;
|
||||||
import com.viaversion.viaversion.protocols.protocol1_20_3to1_20_2.packet.ClientboundPackets1_20_3;
|
import com.viaversion.viaversion.protocols.protocol1_20_3to1_20_2.packet.ClientboundPackets1_20_3;
|
||||||
import com.viaversion.viaversion.protocols.protocol1_20_3to1_20_2.rewriter.RecipeRewriter1_20_3;
|
import com.viaversion.viaversion.protocols.protocol1_20_3to1_20_2.rewriter.RecipeRewriter1_20_3;
|
||||||
@ -90,7 +91,7 @@ public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<Clientboun
|
|||||||
particle.add(Type.ITEM1_20_2, item);
|
particle.add(Type.ITEM1_20_2, item);
|
||||||
}
|
}
|
||||||
|
|
||||||
wrapper.write(Types1_20_3.PARTICLE, particle);
|
wrapper.write(Types1_20_5.PARTICLE, particle);
|
||||||
});
|
});
|
||||||
|
|
||||||
protocol.registerClientbound(ClientboundPackets1_20_3.EXPLOSION, wrapper -> {
|
protocol.registerClientbound(ClientboundPackets1_20_3.EXPLOSION, wrapper -> {
|
||||||
@ -109,10 +110,8 @@ public final class BlockItemPacketRewriter1_20_5 extends ItemRewriter<Clientboun
|
|||||||
wrapper.passthrough(Type.FLOAT); // Knockback Z
|
wrapper.passthrough(Type.FLOAT); // Knockback Z
|
||||||
wrapper.passthrough(Type.VAR_INT); // Block interaction type
|
wrapper.passthrough(Type.VAR_INT); // Block interaction type
|
||||||
|
|
||||||
final Particle smallExplosionParticle = wrapper.passthrough(Types1_20_3.PARTICLE);
|
protocol.getEntityRewriter().rewriteParticle(wrapper, Types1_20_3.PARTICLE, Types1_20_5.PARTICLE); // Small explosion particle
|
||||||
final Particle largeExplosionParticle = wrapper.passthrough(Types1_20_3.PARTICLE);
|
protocol.getEntityRewriter().rewriteParticle(wrapper, Types1_20_3.PARTICLE, Types1_20_5.PARTICLE); // Large explosion particle
|
||||||
protocol.getEntityRewriter().rewriteParticle(smallExplosionParticle);
|
|
||||||
protocol.getEntityRewriter().rewriteParticle(largeExplosionParticle);
|
|
||||||
|
|
||||||
wrapper.write(Type.VAR_INT, 0); // "Empty" registry id to instead use the resource location that follows after
|
wrapper.write(Type.VAR_INT, 0); // "Empty" registry id to instead use the resource location that follows after
|
||||||
});
|
});
|
||||||
|
@ -56,6 +56,10 @@ public final class EntityPacketRewriter1_20_5 extends EntityRewriter<Clientbound
|
|||||||
registerRemoveEntities(ClientboundPackets1_20_3.REMOVE_ENTITIES);
|
registerRemoveEntities(ClientboundPackets1_20_3.REMOVE_ENTITIES);
|
||||||
|
|
||||||
protocol.registerClientbound(ClientboundConfigurationPackets1_20_3.REGISTRY_DATA, wrapper -> {
|
protocol.registerClientbound(ClientboundConfigurationPackets1_20_3.REGISTRY_DATA, wrapper -> {
|
||||||
|
final PacketWrapper knownPacksPacket = wrapper.create(ClientboundConfigurationPackets1_20_5.SELECT_KNOWN_PACKS);
|
||||||
|
knownPacksPacket.write(Type.VAR_INT, 0); // No known packs, everything is sent here
|
||||||
|
knownPacksPacket.send(Protocol1_20_5To1_20_3.class);
|
||||||
|
|
||||||
final CompoundTag registryData = wrapper.read(Type.COMPOUND_TAG);
|
final CompoundTag registryData = wrapper.read(Type.COMPOUND_TAG);
|
||||||
cacheDimensionData(wrapper.user(), registryData);
|
cacheDimensionData(wrapper.user(), registryData);
|
||||||
trackBiomeSize(wrapper.user(), registryData);
|
trackBiomeSize(wrapper.user(), registryData);
|
||||||
|
@ -39,6 +39,7 @@ import com.viaversion.viaversion.api.minecraft.metadata.MetaType;
|
|||||||
import com.viaversion.viaversion.api.minecraft.metadata.Metadata;
|
import com.viaversion.viaversion.api.minecraft.metadata.Metadata;
|
||||||
import com.viaversion.viaversion.api.protocol.Protocol;
|
import com.viaversion.viaversion.api.protocol.Protocol;
|
||||||
import com.viaversion.viaversion.api.protocol.packet.ClientboundPacketType;
|
import com.viaversion.viaversion.api.protocol.packet.ClientboundPacketType;
|
||||||
|
import com.viaversion.viaversion.api.protocol.packet.PacketWrapper;
|
||||||
import com.viaversion.viaversion.api.protocol.remapper.PacketHandler;
|
import com.viaversion.viaversion.api.protocol.remapper.PacketHandler;
|
||||||
import com.viaversion.viaversion.api.protocol.remapper.PacketHandlers;
|
import com.viaversion.viaversion.api.protocol.remapper.PacketHandlers;
|
||||||
import com.viaversion.viaversion.api.rewriter.RewriterBase;
|
import com.viaversion.viaversion.api.rewriter.RewriterBase;
|
||||||
@ -595,6 +596,12 @@ public abstract class EntityRewriter<C extends ClientboundPacketType, T extends
|
|||||||
particle.setId(protocol.getMappingData().getNewParticleId(id));
|
particle.setId(protocol.getMappingData().getNewParticleId(id));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void rewriteParticle(PacketWrapper wrapper, Type<Particle> from, Type<Particle> to) throws Exception {
|
||||||
|
final Particle particle = wrapper.read(from);
|
||||||
|
rewriteParticle(particle);
|
||||||
|
wrapper.write(to, particle);
|
||||||
|
}
|
||||||
|
|
||||||
private void logException(Exception e, @Nullable EntityType type, List<Metadata> metadataList, Metadata metadata) {
|
private void logException(Exception e, @Nullable EntityType type, List<Metadata> metadataList, Metadata metadata) {
|
||||||
if (!Via.getConfig().isSuppressMetadataErrors() || Via.getManager().isDebug()) {
|
if (!Via.getConfig().isSuppressMetadataErrors() || Via.getManager().isDebug()) {
|
||||||
Logger logger = Via.getPlatform().getLogger();
|
Logger logger = Via.getPlatform().getLogger();
|
||||||
|
Binäre Datei nicht angezeigt.
Binäre Datei nicht angezeigt.
@ -1,5 +1,5 @@
|
|||||||
# Project properties - we put these here so they can be modified without causing a recompile of the build scripts
|
# Project properties - we put these here so they can be modified without causing a recompile of the build scripts
|
||||||
projectVersion=4.10.0-24w05b-SNAPSHOT
|
projectVersion=4.10.0-24w06a-SNAPSHOT
|
||||||
|
|
||||||
# Smile emoji
|
# Smile emoji
|
||||||
mcVersions=1.20.4, 1.20.3, 1.20.2, 1.20.1, 1.20, 1.19.4, 1.19.3, 1.19.2, 1.19.1, 1.19, 1.18.2, 1.18.1, 1.18, 1.17.1, 1.17, 1.16.5, 1.16.4, 1.16.3, 1.16.2, 1.16.1, 1.16, 1.15.2, 1.15.1, 1.15, 1.14.4, 1.14.3, 1.14.2, 1.14.1, 1.14, 1.13.2, 1.13.1, 1.13, 1.12.2, 1.12.1, 1.12, 1.11.2, 1.11.1, 1.11, 1.10.2, 1.10.1, 1.10, 1.9.4, 1.9.3, 1.9.2, 1.9.1, 1.9, 1.8.9
|
mcVersions=1.20.4, 1.20.3, 1.20.2, 1.20.1, 1.20, 1.19.4, 1.19.3, 1.19.2, 1.19.1, 1.19, 1.18.2, 1.18.1, 1.18, 1.17.1, 1.17, 1.16.5, 1.16.4, 1.16.3, 1.16.2, 1.16.1, 1.16, 1.15.2, 1.15.1, 1.15, 1.14.4, 1.14.3, 1.14.2, 1.14.1, 1.14, 1.13.2, 1.13.1, 1.13, 1.12.2, 1.12.1, 1.12, 1.11.2, 1.11.1, 1.11, 1.10.2, 1.10.1, 1.10, 1.9.4, 1.9.3, 1.9.2, 1.9.1, 1.9, 1.8.9
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren