mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-08 01:17:47 +01:00
hollow-cube/1.20
* initial 1.20 support
* test fixes
* anvil 1.20, 1.20.1
(cherry picked from commit 716f32972a
)
This commit is contained in:
parent
128c525b7c
commit
969e0d6643
@ -3,11 +3,11 @@ metadata.format.version = "1.1"
|
|||||||
[versions]
|
[versions]
|
||||||
|
|
||||||
# Important dependencies
|
# Important dependencies
|
||||||
data = "1.19.4-rv2"
|
data = "1.20-rv2"
|
||||||
adventure = "4.12.0"
|
adventure = "4.12.0"
|
||||||
kotlin = "1.7.22"
|
kotlin = "1.7.22"
|
||||||
hydrazine = "1.7.2"
|
hydrazine = "1.7.2"
|
||||||
hephaistos = "2.5.3"
|
hephaistos = "2.6.0"
|
||||||
jetbrainsAnnotations = "23.0.0"
|
jetbrainsAnnotations = "23.0.0"
|
||||||
slf4j = "2.0.7"
|
slf4j = "2.0.7"
|
||||||
|
|
||||||
|
@ -81,6 +81,8 @@ interface Blocks {
|
|||||||
|
|
||||||
Block GRAVEL = BlockImpl.get("minecraft:gravel");
|
Block GRAVEL = BlockImpl.get("minecraft:gravel");
|
||||||
|
|
||||||
|
Block SUSPICIOUS_GRAVEL = BlockImpl.get("minecraft:suspicious_gravel");
|
||||||
|
|
||||||
Block GOLD_ORE = BlockImpl.get("minecraft:gold_ore");
|
Block GOLD_ORE = BlockImpl.get("minecraft:gold_ore");
|
||||||
|
|
||||||
Block DEEPSLATE_GOLD_ORE = BlockImpl.get("minecraft:deepslate_gold_ore");
|
Block DEEPSLATE_GOLD_ORE = BlockImpl.get("minecraft:deepslate_gold_ore");
|
||||||
@ -1201,6 +1203,10 @@ interface Blocks {
|
|||||||
|
|
||||||
Block TORCHFLOWER_CROP = BlockImpl.get("minecraft:torchflower_crop");
|
Block TORCHFLOWER_CROP = BlockImpl.get("minecraft:torchflower_crop");
|
||||||
|
|
||||||
|
Block PITCHER_CROP = BlockImpl.get("minecraft:pitcher_crop");
|
||||||
|
|
||||||
|
Block PITCHER_PLANT = BlockImpl.get("minecraft:pitcher_plant");
|
||||||
|
|
||||||
Block BEETROOTS = BlockImpl.get("minecraft:beetroots");
|
Block BEETROOTS = BlockImpl.get("minecraft:beetroots");
|
||||||
|
|
||||||
Block DIRT_PATH = BlockImpl.get("minecraft:dirt_path");
|
Block DIRT_PATH = BlockImpl.get("minecraft:dirt_path");
|
||||||
@ -1363,6 +1369,8 @@ interface Blocks {
|
|||||||
|
|
||||||
Block TURTLE_EGG = BlockImpl.get("minecraft:turtle_egg");
|
Block TURTLE_EGG = BlockImpl.get("minecraft:turtle_egg");
|
||||||
|
|
||||||
|
Block SNIFFER_EGG = BlockImpl.get("minecraft:sniffer_egg");
|
||||||
|
|
||||||
Block DEAD_TUBE_CORAL_BLOCK = BlockImpl.get("minecraft:dead_tube_coral_block");
|
Block DEAD_TUBE_CORAL_BLOCK = BlockImpl.get("minecraft:dead_tube_coral_block");
|
||||||
|
|
||||||
Block DEAD_BRAIN_CORAL_BLOCK = BlockImpl.get("minecraft:dead_brain_coral_block");
|
Block DEAD_BRAIN_CORAL_BLOCK = BlockImpl.get("minecraft:dead_brain_coral_block");
|
||||||
@ -1825,6 +1833,8 @@ interface Blocks {
|
|||||||
|
|
||||||
Block SCULK_SENSOR = BlockImpl.get("minecraft:sculk_sensor");
|
Block SCULK_SENSOR = BlockImpl.get("minecraft:sculk_sensor");
|
||||||
|
|
||||||
|
Block CALIBRATED_SCULK_SENSOR = BlockImpl.get("minecraft:calibrated_sculk_sensor");
|
||||||
|
|
||||||
Block SCULK = BlockImpl.get("minecraft:sculk");
|
Block SCULK = BlockImpl.get("minecraft:sculk");
|
||||||
|
|
||||||
Block SCULK_VEIN = BlockImpl.get("minecraft:sculk_vein");
|
Block SCULK_VEIN = BlockImpl.get("minecraft:sculk_vein");
|
||||||
|
@ -97,6 +97,8 @@ interface Materials {
|
|||||||
|
|
||||||
Material SUSPICIOUS_SAND = MaterialImpl.get("minecraft:suspicious_sand");
|
Material SUSPICIOUS_SAND = MaterialImpl.get("minecraft:suspicious_sand");
|
||||||
|
|
||||||
|
Material SUSPICIOUS_GRAVEL = MaterialImpl.get("minecraft:suspicious_gravel");
|
||||||
|
|
||||||
Material RED_SAND = MaterialImpl.get("minecraft:red_sand");
|
Material RED_SAND = MaterialImpl.get("minecraft:red_sand");
|
||||||
|
|
||||||
Material GRAVEL = MaterialImpl.get("minecraft:gravel");
|
Material GRAVEL = MaterialImpl.get("minecraft:gravel");
|
||||||
@ -423,6 +425,8 @@ interface Materials {
|
|||||||
|
|
||||||
Material TORCHFLOWER = MaterialImpl.get("minecraft:torchflower");
|
Material TORCHFLOWER = MaterialImpl.get("minecraft:torchflower");
|
||||||
|
|
||||||
|
Material PITCHER_PLANT = MaterialImpl.get("minecraft:pitcher_plant");
|
||||||
|
|
||||||
Material SPORE_BLOSSOM = MaterialImpl.get("minecraft:spore_blossom");
|
Material SPORE_BLOSSOM = MaterialImpl.get("minecraft:spore_blossom");
|
||||||
|
|
||||||
Material BROWN_MUSHROOM = MaterialImpl.get("minecraft:brown_mushroom");
|
Material BROWN_MUSHROOM = MaterialImpl.get("minecraft:brown_mushroom");
|
||||||
@ -1133,6 +1137,8 @@ interface Materials {
|
|||||||
|
|
||||||
Material TURTLE_EGG = MaterialImpl.get("minecraft:turtle_egg");
|
Material TURTLE_EGG = MaterialImpl.get("minecraft:turtle_egg");
|
||||||
|
|
||||||
|
Material SNIFFER_EGG = MaterialImpl.get("minecraft:sniffer_egg");
|
||||||
|
|
||||||
Material DEAD_TUBE_CORAL_BLOCK = MaterialImpl.get("minecraft:dead_tube_coral_block");
|
Material DEAD_TUBE_CORAL_BLOCK = MaterialImpl.get("minecraft:dead_tube_coral_block");
|
||||||
|
|
||||||
Material DEAD_BRAIN_CORAL_BLOCK = MaterialImpl.get("minecraft:dead_brain_coral_block");
|
Material DEAD_BRAIN_CORAL_BLOCK = MaterialImpl.get("minecraft:dead_brain_coral_block");
|
||||||
@ -1307,6 +1313,8 @@ interface Materials {
|
|||||||
|
|
||||||
Material SCULK_SENSOR = MaterialImpl.get("minecraft:sculk_sensor");
|
Material SCULK_SENSOR = MaterialImpl.get("minecraft:sculk_sensor");
|
||||||
|
|
||||||
|
Material CALIBRATED_SCULK_SENSOR = MaterialImpl.get("minecraft:calibrated_sculk_sensor");
|
||||||
|
|
||||||
Material TRIPWIRE_HOOK = MaterialImpl.get("minecraft:tripwire_hook");
|
Material TRIPWIRE_HOOK = MaterialImpl.get("minecraft:tripwire_hook");
|
||||||
|
|
||||||
Material TRAPPED_CHEST = MaterialImpl.get("minecraft:trapped_chest");
|
Material TRAPPED_CHEST = MaterialImpl.get("minecraft:trapped_chest");
|
||||||
@ -2211,6 +2219,8 @@ interface Materials {
|
|||||||
|
|
||||||
Material TORCHFLOWER_SEEDS = MaterialImpl.get("minecraft:torchflower_seeds");
|
Material TORCHFLOWER_SEEDS = MaterialImpl.get("minecraft:torchflower_seeds");
|
||||||
|
|
||||||
|
Material PITCHER_POD = MaterialImpl.get("minecraft:pitcher_pod");
|
||||||
|
|
||||||
Material BEETROOT = MaterialImpl.get("minecraft:beetroot");
|
Material BEETROOT = MaterialImpl.get("minecraft:beetroot");
|
||||||
|
|
||||||
Material BEETROOT_SEEDS = MaterialImpl.get("minecraft:beetroot_seeds");
|
Material BEETROOT_SEEDS = MaterialImpl.get("minecraft:beetroot_seeds");
|
||||||
@ -2265,6 +2275,8 @@ interface Materials {
|
|||||||
|
|
||||||
Material MUSIC_DISC_OTHERSIDE = MaterialImpl.get("minecraft:music_disc_otherside");
|
Material MUSIC_DISC_OTHERSIDE = MaterialImpl.get("minecraft:music_disc_otherside");
|
||||||
|
|
||||||
|
Material MUSIC_DISC_RELIC = MaterialImpl.get("minecraft:music_disc_relic");
|
||||||
|
|
||||||
Material MUSIC_DISC_5 = MaterialImpl.get("minecraft:music_disc_5");
|
Material MUSIC_DISC_5 = MaterialImpl.get("minecraft:music_disc_5");
|
||||||
|
|
||||||
Material MUSIC_DISC_PIGSTEP = MaterialImpl.get("minecraft:music_disc_pigstep");
|
Material MUSIC_DISC_PIGSTEP = MaterialImpl.get("minecraft:music_disc_pigstep");
|
||||||
@ -2453,11 +2465,53 @@ interface Materials {
|
|||||||
|
|
||||||
Material SPIRE_ARMOR_TRIM_SMITHING_TEMPLATE = MaterialImpl.get("minecraft:spire_armor_trim_smithing_template");
|
Material SPIRE_ARMOR_TRIM_SMITHING_TEMPLATE = MaterialImpl.get("minecraft:spire_armor_trim_smithing_template");
|
||||||
|
|
||||||
Material POTTERY_SHARD_ARCHER = MaterialImpl.get("minecraft:pottery_shard_archer");
|
Material WAYFINDER_ARMOR_TRIM_SMITHING_TEMPLATE = MaterialImpl.get("minecraft:wayfinder_armor_trim_smithing_template");
|
||||||
|
|
||||||
Material POTTERY_SHARD_PRIZE = MaterialImpl.get("minecraft:pottery_shard_prize");
|
Material SHAPER_ARMOR_TRIM_SMITHING_TEMPLATE = MaterialImpl.get("minecraft:shaper_armor_trim_smithing_template");
|
||||||
|
|
||||||
Material POTTERY_SHARD_ARMS_UP = MaterialImpl.get("minecraft:pottery_shard_arms_up");
|
Material SILENCE_ARMOR_TRIM_SMITHING_TEMPLATE = MaterialImpl.get("minecraft:silence_armor_trim_smithing_template");
|
||||||
|
|
||||||
Material POTTERY_SHARD_SKULL = MaterialImpl.get("minecraft:pottery_shard_skull");
|
Material RAISER_ARMOR_TRIM_SMITHING_TEMPLATE = MaterialImpl.get("minecraft:raiser_armor_trim_smithing_template");
|
||||||
|
|
||||||
|
Material HOST_ARMOR_TRIM_SMITHING_TEMPLATE = MaterialImpl.get("minecraft:host_armor_trim_smithing_template");
|
||||||
|
|
||||||
|
Material ANGLER_POTTERY_SHERD = MaterialImpl.get("minecraft:angler_pottery_sherd");
|
||||||
|
|
||||||
|
Material ARCHER_POTTERY_SHERD = MaterialImpl.get("minecraft:archer_pottery_sherd");
|
||||||
|
|
||||||
|
Material ARMS_UP_POTTERY_SHERD = MaterialImpl.get("minecraft:arms_up_pottery_sherd");
|
||||||
|
|
||||||
|
Material BLADE_POTTERY_SHERD = MaterialImpl.get("minecraft:blade_pottery_sherd");
|
||||||
|
|
||||||
|
Material BREWER_POTTERY_SHERD = MaterialImpl.get("minecraft:brewer_pottery_sherd");
|
||||||
|
|
||||||
|
Material BURN_POTTERY_SHERD = MaterialImpl.get("minecraft:burn_pottery_sherd");
|
||||||
|
|
||||||
|
Material DANGER_POTTERY_SHERD = MaterialImpl.get("minecraft:danger_pottery_sherd");
|
||||||
|
|
||||||
|
Material EXPLORER_POTTERY_SHERD = MaterialImpl.get("minecraft:explorer_pottery_sherd");
|
||||||
|
|
||||||
|
Material FRIEND_POTTERY_SHERD = MaterialImpl.get("minecraft:friend_pottery_sherd");
|
||||||
|
|
||||||
|
Material HEART_POTTERY_SHERD = MaterialImpl.get("minecraft:heart_pottery_sherd");
|
||||||
|
|
||||||
|
Material HEARTBREAK_POTTERY_SHERD = MaterialImpl.get("minecraft:heartbreak_pottery_sherd");
|
||||||
|
|
||||||
|
Material HOWL_POTTERY_SHERD = MaterialImpl.get("minecraft:howl_pottery_sherd");
|
||||||
|
|
||||||
|
Material MINER_POTTERY_SHERD = MaterialImpl.get("minecraft:miner_pottery_sherd");
|
||||||
|
|
||||||
|
Material MOURNER_POTTERY_SHERD = MaterialImpl.get("minecraft:mourner_pottery_sherd");
|
||||||
|
|
||||||
|
Material PLENTY_POTTERY_SHERD = MaterialImpl.get("minecraft:plenty_pottery_sherd");
|
||||||
|
|
||||||
|
Material PRIZE_POTTERY_SHERD = MaterialImpl.get("minecraft:prize_pottery_sherd");
|
||||||
|
|
||||||
|
Material SHEAF_POTTERY_SHERD = MaterialImpl.get("minecraft:sheaf_pottery_sherd");
|
||||||
|
|
||||||
|
Material SHELTER_POTTERY_SHERD = MaterialImpl.get("minecraft:shelter_pottery_sherd");
|
||||||
|
|
||||||
|
Material SKULL_POTTERY_SHERD = MaterialImpl.get("minecraft:skull_pottery_sherd");
|
||||||
|
|
||||||
|
Material SNORT_POTTERY_SHERD = MaterialImpl.get("minecraft:snort_pottery_sherd");
|
||||||
}
|
}
|
||||||
|
@ -63,11 +63,7 @@ interface Particles {
|
|||||||
|
|
||||||
Particle FLAME = ParticleImpl.get("minecraft:flame");
|
Particle FLAME = ParticleImpl.get("minecraft:flame");
|
||||||
|
|
||||||
Particle DRIPPING_CHERRY_LEAVES = ParticleImpl.get("minecraft:dripping_cherry_leaves");
|
Particle CHERRY_LEAVES = ParticleImpl.get("minecraft:cherry_leaves");
|
||||||
|
|
||||||
Particle FALLING_CHERRY_LEAVES = ParticleImpl.get("minecraft:falling_cherry_leaves");
|
|
||||||
|
|
||||||
Particle LANDING_CHERRY_LEAVES = ParticleImpl.get("minecraft:landing_cherry_leaves");
|
|
||||||
|
|
||||||
Particle SCULK_SOUL = ParticleImpl.get("minecraft:sculk_soul");
|
Particle SCULK_SOUL = ParticleImpl.get("minecraft:sculk_soul");
|
||||||
|
|
||||||
@ -196,4 +192,6 @@ interface Particles {
|
|||||||
Particle SCRAPE = ParticleImpl.get("minecraft:scrape");
|
Particle SCRAPE = ParticleImpl.get("minecraft:scrape");
|
||||||
|
|
||||||
Particle SHRIEK = ParticleImpl.get("minecraft:shriek");
|
Particle SHRIEK = ParticleImpl.get("minecraft:shriek");
|
||||||
|
|
||||||
|
Particle EGG_CRACK = ParticleImpl.get("minecraft:egg_crack");
|
||||||
}
|
}
|
||||||
|
@ -73,6 +73,8 @@ interface SoundEvents {
|
|||||||
|
|
||||||
SoundEvent BLOCK_AMETHYST_BLOCK_PLACE = SoundEventImpl.get("minecraft:block.amethyst_block.place");
|
SoundEvent BLOCK_AMETHYST_BLOCK_PLACE = SoundEventImpl.get("minecraft:block.amethyst_block.place");
|
||||||
|
|
||||||
|
SoundEvent BLOCK_AMETHYST_BLOCK_RESONATE = SoundEventImpl.get("minecraft:block.amethyst_block.resonate");
|
||||||
|
|
||||||
SoundEvent BLOCK_AMETHYST_BLOCK_STEP = SoundEventImpl.get("minecraft:block.amethyst_block.step");
|
SoundEvent BLOCK_AMETHYST_BLOCK_STEP = SoundEventImpl.get("minecraft:block.amethyst_block.step");
|
||||||
|
|
||||||
SoundEvent BLOCK_AMETHYST_CLUSTER_BREAK = SoundEventImpl.get("minecraft:block.amethyst_cluster.break");
|
SoundEvent BLOCK_AMETHYST_CLUSTER_BREAK = SoundEventImpl.get("minecraft:block.amethyst_cluster.break");
|
||||||
@ -337,9 +339,15 @@ interface SoundEvents {
|
|||||||
|
|
||||||
SoundEvent BLOCK_BREWING_STAND_BREW = SoundEventImpl.get("minecraft:block.brewing_stand.brew");
|
SoundEvent BLOCK_BREWING_STAND_BREW = SoundEventImpl.get("minecraft:block.brewing_stand.brew");
|
||||||
|
|
||||||
SoundEvent ITEM_BRUSH_BRUSHING = SoundEventImpl.get("minecraft:item.brush.brushing");
|
SoundEvent ITEM_BRUSH_BRUSHING_GENERIC = SoundEventImpl.get("minecraft:item.brush.brushing.generic");
|
||||||
|
|
||||||
SoundEvent ITEM_BRUSH_BRUSH_SAND_COMPLETED = SoundEventImpl.get("minecraft:item.brush.brush_sand_completed");
|
SoundEvent ITEM_BRUSH_BRUSHING_SAND = SoundEventImpl.get("minecraft:item.brush.brushing.sand");
|
||||||
|
|
||||||
|
SoundEvent ITEM_BRUSH_BRUSHING_GRAVEL = SoundEventImpl.get("minecraft:item.brush.brushing.gravel");
|
||||||
|
|
||||||
|
SoundEvent ITEM_BRUSH_BRUSHING_SAND_COMPLETE = SoundEventImpl.get("minecraft:item.brush.brushing.sand.complete");
|
||||||
|
|
||||||
|
SoundEvent ITEM_BRUSH_BRUSHING_GRAVEL_COMPLETE = SoundEventImpl.get("minecraft:item.brush.brushing.gravel.complete");
|
||||||
|
|
||||||
SoundEvent BLOCK_BUBBLE_COLUMN_BUBBLE_POP = SoundEventImpl.get("minecraft:block.bubble_column.bubble_pop");
|
SoundEvent BLOCK_BUBBLE_COLUMN_BUBBLE_POP = SoundEventImpl.get("minecraft:block.bubble_column.bubble_pop");
|
||||||
|
|
||||||
@ -961,6 +969,16 @@ interface SoundEvents {
|
|||||||
|
|
||||||
SoundEvent BLOCK_SUSPICIOUS_SAND_FALL = SoundEventImpl.get("minecraft:block.suspicious_sand.fall");
|
SoundEvent BLOCK_SUSPICIOUS_SAND_FALL = SoundEventImpl.get("minecraft:block.suspicious_sand.fall");
|
||||||
|
|
||||||
|
SoundEvent BLOCK_SUSPICIOUS_GRAVEL_BREAK = SoundEventImpl.get("minecraft:block.suspicious_gravel.break");
|
||||||
|
|
||||||
|
SoundEvent BLOCK_SUSPICIOUS_GRAVEL_STEP = SoundEventImpl.get("minecraft:block.suspicious_gravel.step");
|
||||||
|
|
||||||
|
SoundEvent BLOCK_SUSPICIOUS_GRAVEL_PLACE = SoundEventImpl.get("minecraft:block.suspicious_gravel.place");
|
||||||
|
|
||||||
|
SoundEvent BLOCK_SUSPICIOUS_GRAVEL_HIT = SoundEventImpl.get("minecraft:block.suspicious_gravel.hit");
|
||||||
|
|
||||||
|
SoundEvent BLOCK_SUSPICIOUS_GRAVEL_FALL = SoundEventImpl.get("minecraft:block.suspicious_gravel.fall");
|
||||||
|
|
||||||
SoundEvent BLOCK_FROGLIGHT_BREAK = SoundEventImpl.get("minecraft:block.froglight.break");
|
SoundEvent BLOCK_FROGLIGHT_BREAK = SoundEventImpl.get("minecraft:block.froglight.break");
|
||||||
|
|
||||||
SoundEvent BLOCK_FROGLIGHT_FALL = SoundEventImpl.get("minecraft:block.froglight.fall");
|
SoundEvent BLOCK_FROGLIGHT_FALL = SoundEventImpl.get("minecraft:block.froglight.fall");
|
||||||
@ -1589,6 +1607,8 @@ interface SoundEvents {
|
|||||||
|
|
||||||
SoundEvent MUSIC_DISC_OTHERSIDE = SoundEventImpl.get("minecraft:music_disc.otherside");
|
SoundEvent MUSIC_DISC_OTHERSIDE = SoundEventImpl.get("minecraft:music_disc.otherside");
|
||||||
|
|
||||||
|
SoundEvent MUSIC_DISC_RELIC = SoundEventImpl.get("minecraft:music_disc.relic");
|
||||||
|
|
||||||
SoundEvent MUSIC_DRAGON = SoundEventImpl.get("minecraft:music.dragon");
|
SoundEvent MUSIC_DRAGON = SoundEventImpl.get("minecraft:music.dragon");
|
||||||
|
|
||||||
SoundEvent MUSIC_END = SoundEventImpl.get("minecraft:music.end");
|
SoundEvent MUSIC_END = SoundEventImpl.get("minecraft:music.end");
|
||||||
@ -1613,7 +1633,7 @@ interface SoundEvents {
|
|||||||
|
|
||||||
SoundEvent MUSIC_OVERWORLD_SWAMP = SoundEventImpl.get("minecraft:music.overworld.swamp");
|
SoundEvent MUSIC_OVERWORLD_SWAMP = SoundEventImpl.get("minecraft:music.overworld.swamp");
|
||||||
|
|
||||||
SoundEvent MUSIC_OVERWORLD_JUNGLE_AND_FOREST = SoundEventImpl.get("minecraft:music.overworld.jungle_and_forest");
|
SoundEvent MUSIC_OVERWORLD_FOREST = SoundEventImpl.get("minecraft:music.overworld.forest");
|
||||||
|
|
||||||
SoundEvent MUSIC_OVERWORLD_OLD_GROWTH_TAIGA = SoundEventImpl.get("minecraft:music.overworld.old_growth_taiga");
|
SoundEvent MUSIC_OVERWORLD_OLD_GROWTH_TAIGA = SoundEventImpl.get("minecraft:music.overworld.old_growth_taiga");
|
||||||
|
|
||||||
@ -1633,6 +1653,18 @@ interface SoundEvents {
|
|||||||
|
|
||||||
SoundEvent MUSIC_NETHER_WARPED_FOREST = SoundEventImpl.get("minecraft:music.nether.warped_forest");
|
SoundEvent MUSIC_NETHER_WARPED_FOREST = SoundEventImpl.get("minecraft:music.nether.warped_forest");
|
||||||
|
|
||||||
|
SoundEvent MUSIC_OVERWORLD_FLOWER_FOREST = SoundEventImpl.get("minecraft:music.overworld.flower_forest");
|
||||||
|
|
||||||
|
SoundEvent MUSIC_OVERWORLD_DESERT = SoundEventImpl.get("minecraft:music.overworld.desert");
|
||||||
|
|
||||||
|
SoundEvent MUSIC_OVERWORLD_BADLANDS = SoundEventImpl.get("minecraft:music.overworld.badlands");
|
||||||
|
|
||||||
|
SoundEvent MUSIC_OVERWORLD_JUNGLE = SoundEventImpl.get("minecraft:music.overworld.jungle");
|
||||||
|
|
||||||
|
SoundEvent MUSIC_OVERWORLD_SPARSE_JUNGLE = SoundEventImpl.get("minecraft:music.overworld.sparse_jungle");
|
||||||
|
|
||||||
|
SoundEvent MUSIC_OVERWORLD_BAMBOO_JUNGLE = SoundEventImpl.get("minecraft:music.overworld.bamboo_jungle");
|
||||||
|
|
||||||
SoundEvent MUSIC_UNDER_WATER = SoundEventImpl.get("minecraft:music.under_water");
|
SoundEvent MUSIC_UNDER_WATER = SoundEventImpl.get("minecraft:music.under_water");
|
||||||
|
|
||||||
SoundEvent BLOCK_NETHER_BRICKS_BREAK = SoundEventImpl.get("minecraft:block.nether_bricks.break");
|
SoundEvent BLOCK_NETHER_BRICKS_BREAK = SoundEventImpl.get("minecraft:block.nether_bricks.break");
|
||||||
@ -2449,6 +2481,12 @@ interface SoundEvents {
|
|||||||
|
|
||||||
SoundEvent ENTITY_SNIFFER_HAPPY = SoundEventImpl.get("minecraft:entity.sniffer.happy");
|
SoundEvent ENTITY_SNIFFER_HAPPY = SoundEventImpl.get("minecraft:entity.sniffer.happy");
|
||||||
|
|
||||||
|
SoundEvent BLOCK_SNIFFER_EGG_PLOP = SoundEventImpl.get("minecraft:block.sniffer_egg.plop");
|
||||||
|
|
||||||
|
SoundEvent BLOCK_SNIFFER_EGG_CRACK = SoundEventImpl.get("minecraft:block.sniffer_egg.crack");
|
||||||
|
|
||||||
|
SoundEvent BLOCK_SNIFFER_EGG_HATCH = SoundEventImpl.get("minecraft:block.sniffer_egg.hatch");
|
||||||
|
|
||||||
SoundEvent ENTITY_SNOWBALL_THROW = SoundEventImpl.get("minecraft:entity.snowball.throw");
|
SoundEvent ENTITY_SNOWBALL_THROW = SoundEventImpl.get("minecraft:entity.snowball.throw");
|
||||||
|
|
||||||
SoundEvent BLOCK_SNOW_BREAK = SoundEventImpl.get("minecraft:block.snow.break");
|
SoundEvent BLOCK_SNOW_BREAK = SoundEventImpl.get("minecraft:block.snow.break");
|
||||||
@ -2753,6 +2791,8 @@ interface SoundEvents {
|
|||||||
|
|
||||||
SoundEvent ENTITY_WARDEN_TENDRIL_CLICKS = SoundEventImpl.get("minecraft:entity.warden.tendril_clicks");
|
SoundEvent ENTITY_WARDEN_TENDRIL_CLICKS = SoundEventImpl.get("minecraft:entity.warden.tendril_clicks");
|
||||||
|
|
||||||
|
SoundEvent BLOCK_SIGN_WAXED_INTERACT_FAIL = SoundEventImpl.get("minecraft:block.sign.waxed_interact_fail");
|
||||||
|
|
||||||
SoundEvent BLOCK_WATER_AMBIENT = SoundEventImpl.get("minecraft:block.water.ambient");
|
SoundEvent BLOCK_WATER_AMBIENT = SoundEventImpl.get("minecraft:block.water.ambient");
|
||||||
|
|
||||||
SoundEvent WEATHER_RAIN = SoundEventImpl.get("minecraft:weather.rain");
|
SoundEvent WEATHER_RAIN = SoundEventImpl.get("minecraft:weather.rain");
|
||||||
|
@ -45,8 +45,8 @@ public final class MinecraftServer {
|
|||||||
|
|
||||||
public static final ComponentLogger LOGGER = ComponentLogger.logger(MinecraftServer.class);
|
public static final ComponentLogger LOGGER = ComponentLogger.logger(MinecraftServer.class);
|
||||||
|
|
||||||
public static final String VERSION_NAME = "1.19.4";
|
public static final String VERSION_NAME = "1.20.1";
|
||||||
public static final int PROTOCOL_VERSION = 762;
|
public static final int PROTOCOL_VERSION = 763;
|
||||||
|
|
||||||
// Threads
|
// Threads
|
||||||
public static final String THREAD_NAME_BENCHMARK = "Ms-Benchmark";
|
public static final String THREAD_NAME_BENCHMARK = "Ms-Benchmark";
|
||||||
|
@ -158,6 +158,7 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
private final PlayerSettings settings;
|
private final PlayerSettings settings;
|
||||||
private float exp;
|
private float exp;
|
||||||
private int level;
|
private int level;
|
||||||
|
private int portalCooldown = 0;
|
||||||
|
|
||||||
protected PlayerInventory inventory;
|
protected PlayerInventory inventory;
|
||||||
private Inventory openInventory;
|
private Inventory openInventory;
|
||||||
@ -281,7 +282,7 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
final JoinGamePacket joinGamePacket = new JoinGamePacket(getEntityId(), false, gameMode, null,
|
final JoinGamePacket joinGamePacket = new JoinGamePacket(getEntityId(), false, gameMode, null,
|
||||||
List.of(dimensionType.getName().asString()), NBT.Compound(registry), dimensionType.toString(), dimensionType.getName().asString(),
|
List.of(dimensionType.getName().asString()), NBT.Compound(registry), dimensionType.toString(), dimensionType.getName().asString(),
|
||||||
0, 0, MinecraftServer.getChunkViewDistance(), MinecraftServer.getChunkViewDistance(),
|
0, 0, MinecraftServer.getChunkViewDistance(), MinecraftServer.getChunkViewDistance(),
|
||||||
false, true, false, levelFlat, deathLocation);
|
false, true, false, levelFlat, deathLocation, portalCooldown);
|
||||||
sendPacket(joinGamePacket);
|
sendPacket(joinGamePacket);
|
||||||
|
|
||||||
// Server brand name
|
// Server brand name
|
||||||
@ -449,7 +450,7 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
|
|
||||||
// #buildDeathScreenText can return null, check here
|
// #buildDeathScreenText can return null, check here
|
||||||
if (deathText != null) {
|
if (deathText != null) {
|
||||||
sendPacket(new DeathCombatEventPacket(getEntityId(), -1, deathText));
|
sendPacket(new DeathCombatEventPacket(getEntityId(), deathText));
|
||||||
}
|
}
|
||||||
|
|
||||||
// #buildDeathMessage can return null, check here
|
// #buildDeathMessage can return null, check here
|
||||||
@ -477,7 +478,7 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
refreshHealth();
|
refreshHealth();
|
||||||
|
|
||||||
sendPacket(new RespawnPacket(getDimensionType().toString(), getDimensionType().getName().asString(),
|
sendPacket(new RespawnPacket(getDimensionType().toString(), getDimensionType().getName().asString(),
|
||||||
0, gameMode, gameMode, false, levelFlat, true, deathLocation));
|
0, gameMode, gameMode, false, levelFlat, true, deathLocation, portalCooldown));
|
||||||
|
|
||||||
PlayerRespawnEvent respawnEvent = new PlayerRespawnEvent(this);
|
PlayerRespawnEvent respawnEvent = new PlayerRespawnEvent(this);
|
||||||
EventDispatcher.call(respawnEvent);
|
EventDispatcher.call(respawnEvent);
|
||||||
@ -1009,7 +1010,7 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
final PlayerInfoUpdatePacket addPlayerPacket = getAddPlayerToList();
|
final PlayerInfoUpdatePacket addPlayerPacket = getAddPlayerToList();
|
||||||
|
|
||||||
RespawnPacket respawnPacket = new RespawnPacket(getDimensionType().toString(), getDimensionType().getName().asString(),
|
RespawnPacket respawnPacket = new RespawnPacket(getDimensionType().toString(), getDimensionType().getName().asString(),
|
||||||
0, gameMode, gameMode, false, levelFlat, true, deathLocation);
|
0, gameMode, gameMode, false, levelFlat, true, deathLocation, portalCooldown);
|
||||||
|
|
||||||
sendPacket(removePlayerPacket);
|
sendPacket(removePlayerPacket);
|
||||||
sendPacket(destroyEntitiesPacket);
|
sendPacket(destroyEntitiesPacket);
|
||||||
@ -1249,6 +1250,14 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
sendPacket(new SetExperiencePacket(exp, level, 0));
|
sendPacket(new SetExperiencePacket(exp, level, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int getPortalCooldown() {
|
||||||
|
return portalCooldown;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPortalCooldown(int portalCooldown) {
|
||||||
|
this.portalCooldown = portalCooldown;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the player connection.
|
* Gets the player connection.
|
||||||
* <p>
|
* <p>
|
||||||
@ -1389,7 +1398,7 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
"The dimension needs to be different than the current one!");
|
"The dimension needs to be different than the current one!");
|
||||||
this.dimensionType = dimensionType;
|
this.dimensionType = dimensionType;
|
||||||
sendPacket(new RespawnPacket(dimensionType.toString(), getDimensionType().getName().asString(),
|
sendPacket(new RespawnPacket(dimensionType.toString(), getDimensionType().getName().asString(),
|
||||||
0, gameMode, gameMode, false, levelFlat, true, deathLocation));
|
0, gameMode, gameMode, false, levelFlat, true, deathLocation, portalCooldown));
|
||||||
refreshClientStateAfterRespawn();
|
refreshClientStateAfterRespawn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -246,10 +246,11 @@ public class DynamicChunk extends Chunk {
|
|||||||
emptyBlockMask.set(index);
|
emptyBlockMask.set(index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return new LightData(true,
|
return new LightData(
|
||||||
skyMask, blockMask,
|
skyMask, blockMask,
|
||||||
emptySkyMask, emptyBlockMask,
|
emptySkyMask, emptyBlockMask,
|
||||||
skyLights, blockLights);
|
skyLights, blockLights
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -195,10 +195,11 @@ public class LightingChunk extends DynamicChunk {
|
|||||||
sendNeighbours = false;
|
sendNeighbours = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new LightData(true,
|
return new LightData(
|
||||||
skyMask, blockMask,
|
skyMask, blockMask,
|
||||||
emptySkyMask, emptyBlockMask,
|
emptySkyMask, emptyBlockMask,
|
||||||
skyLights, blockLights);
|
skyLights, blockLights
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final Set<LightingChunk> sendQueue = ConcurrentHashMap.newKeySet();
|
private static final Set<LightingChunk> sendQueue = ConcurrentHashMap.newKeySet();
|
||||||
|
@ -7,11 +7,13 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import static net.minestom.server.network.NetworkBuffer.BLOCK_POSITION;
|
import static net.minestom.server.network.NetworkBuffer.*;
|
||||||
import static net.minestom.server.network.NetworkBuffer.STRING;
|
|
||||||
|
|
||||||
public record ClientUpdateSignPacket(@NotNull Point blockPosition,
|
public record ClientUpdateSignPacket(
|
||||||
@NotNull List<String> lines) implements ClientPacket {
|
@NotNull Point blockPosition,
|
||||||
|
boolean isFrontText,
|
||||||
|
@NotNull List<String> lines
|
||||||
|
) implements ClientPacket {
|
||||||
public ClientUpdateSignPacket {
|
public ClientUpdateSignPacket {
|
||||||
lines = List.copyOf(lines);
|
lines = List.copyOf(lines);
|
||||||
if (lines.size() != 4) {
|
if (lines.size() != 4) {
|
||||||
@ -25,12 +27,13 @@ public record ClientUpdateSignPacket(@NotNull Point blockPosition,
|
|||||||
}
|
}
|
||||||
|
|
||||||
public ClientUpdateSignPacket(@NotNull NetworkBuffer reader) {
|
public ClientUpdateSignPacket(@NotNull NetworkBuffer reader) {
|
||||||
this(reader.read(BLOCK_POSITION), readLines(reader));
|
this(reader.read(BLOCK_POSITION), reader.read(BOOLEAN), readLines(reader));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(@NotNull NetworkBuffer writer) {
|
public void write(@NotNull NetworkBuffer writer) {
|
||||||
writer.write(BLOCK_POSITION, blockPosition);
|
writer.write(BLOCK_POSITION, blockPosition);
|
||||||
|
writer.write(BOOLEAN, isFrontText);
|
||||||
writer.write(STRING, lines.get(0));
|
writer.write(STRING, lines.get(0));
|
||||||
writer.write(STRING, lines.get(1));
|
writer.write(STRING, lines.get(1));
|
||||||
writer.write(STRING, lines.get(2));
|
writer.write(STRING, lines.get(2));
|
||||||
|
@ -13,16 +13,14 @@ import java.util.function.UnaryOperator;
|
|||||||
|
|
||||||
import static net.minestom.server.network.NetworkBuffer.*;
|
import static net.minestom.server.network.NetworkBuffer.*;
|
||||||
|
|
||||||
public record DeathCombatEventPacket(int playerId, int entityId,
|
public record DeathCombatEventPacket(int playerId, @NotNull Component message) implements ComponentHoldingServerPacket {
|
||||||
@NotNull Component message) implements ComponentHoldingServerPacket {
|
|
||||||
public DeathCombatEventPacket(@NotNull NetworkBuffer reader) {
|
public DeathCombatEventPacket(@NotNull NetworkBuffer reader) {
|
||||||
this(reader.read(VAR_INT), reader.read(INT), reader.read(COMPONENT));
|
this(reader.read(VAR_INT), reader.read(COMPONENT));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(@NotNull NetworkBuffer writer) {
|
public void write(@NotNull NetworkBuffer writer) {
|
||||||
writer.write(VAR_INT, playerId);
|
writer.write(VAR_INT, playerId);
|
||||||
writer.write(INT, entityId);
|
|
||||||
writer.write(COMPONENT, message);
|
writer.write(COMPONENT, message);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -38,6 +36,6 @@ public record DeathCombatEventPacket(int playerId, int entityId,
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public @NotNull ServerPacket copyWithOperator(@NotNull UnaryOperator<Component> operator) {
|
public @NotNull ServerPacket copyWithOperator(@NotNull UnaryOperator<Component> operator) {
|
||||||
return new DeathCombatEventPacket(this.playerId, this.entityId, operator.apply(this.message));
|
return new DeathCombatEventPacket(this.playerId, operator.apply(this.message));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,18 +5,16 @@ import net.minestom.server.network.packet.server.ServerPacket;
|
|||||||
import net.minestom.server.network.packet.server.ServerPacketIdentifier;
|
import net.minestom.server.network.packet.server.ServerPacketIdentifier;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import static net.minestom.server.network.NetworkBuffer.INT;
|
|
||||||
import static net.minestom.server.network.NetworkBuffer.VAR_INT;
|
import static net.minestom.server.network.NetworkBuffer.VAR_INT;
|
||||||
|
|
||||||
public record EndCombatEventPacket(int duration, int entityId) implements ServerPacket {
|
public record EndCombatEventPacket(int duration) implements ServerPacket {
|
||||||
public EndCombatEventPacket(@NotNull NetworkBuffer reader) {
|
public EndCombatEventPacket(@NotNull NetworkBuffer reader) {
|
||||||
this(reader.read(VAR_INT), reader.read(INT));
|
this(reader.read(VAR_INT));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(@NotNull NetworkBuffer writer) {
|
public void write(@NotNull NetworkBuffer writer) {
|
||||||
writer.write(VAR_INT, duration);
|
writer.write(VAR_INT, duration);
|
||||||
writer.write(INT, entityId);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -17,7 +17,7 @@ public record JoinGamePacket(int entityId, boolean isHardcore, GameMode gameMode
|
|||||||
List<String> worlds, NBTCompound dimensionCodec, String dimensionType, String world,
|
List<String> worlds, NBTCompound dimensionCodec, String dimensionType, String world,
|
||||||
long hashedSeed, int maxPlayers, int viewDistance, int simulationDistance,
|
long hashedSeed, int maxPlayers, int viewDistance, int simulationDistance,
|
||||||
boolean reducedDebugInfo, boolean enableRespawnScreen, boolean isDebug, boolean isFlat,
|
boolean reducedDebugInfo, boolean enableRespawnScreen, boolean isDebug, boolean isFlat,
|
||||||
DeathLocation deathLocation) implements ServerPacket {
|
DeathLocation deathLocation, int portalCooldown) implements ServerPacket {
|
||||||
public JoinGamePacket {
|
public JoinGamePacket {
|
||||||
worlds = List.copyOf(worlds);
|
worlds = List.copyOf(worlds);
|
||||||
}
|
}
|
||||||
@ -27,7 +27,7 @@ public record JoinGamePacket(int entityId, boolean isHardcore, GameMode gameMode
|
|||||||
reader.readCollection(STRING), (NBTCompound) reader.read(NBT), reader.read(STRING), reader.read(STRING),
|
reader.readCollection(STRING), (NBTCompound) reader.read(NBT), reader.read(STRING), reader.read(STRING),
|
||||||
reader.read(LONG), reader.read(VAR_INT), reader.read(VAR_INT), reader.read(VAR_INT),
|
reader.read(LONG), reader.read(VAR_INT), reader.read(VAR_INT), reader.read(VAR_INT),
|
||||||
reader.read(BOOLEAN), reader.read(BOOLEAN), reader.read(BOOLEAN), reader.read(BOOLEAN),
|
reader.read(BOOLEAN), reader.read(BOOLEAN), reader.read(BOOLEAN), reader.read(BOOLEAN),
|
||||||
reader.read(DEATH_LOCATION));
|
reader.read(DEATH_LOCATION), reader.read(VAR_INT));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -58,6 +58,8 @@ public record JoinGamePacket(int entityId, boolean isHardcore, GameMode gameMode
|
|||||||
writer.write(BOOLEAN, isFlat);
|
writer.write(BOOLEAN, isFlat);
|
||||||
|
|
||||||
writer.write(DEATH_LOCATION, deathLocation);
|
writer.write(DEATH_LOCATION, deathLocation);
|
||||||
|
|
||||||
|
writer.write(VAR_INT, portalCooldown);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -7,24 +7,19 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
|
|
||||||
import static net.minestom.server.network.NetworkBuffer.*;
|
import static net.minestom.server.network.NetworkBuffer.*;
|
||||||
|
|
||||||
public record MultiBlockChangePacket(long chunkSectionPosition,
|
public record MultiBlockChangePacket(long chunkSectionPosition, long[] blocks) implements ServerPacket {
|
||||||
boolean suppressLightUpdates,
|
|
||||||
long[] blocks) implements ServerPacket {
|
|
||||||
public MultiBlockChangePacket(int chunkX, int section, int chunkZ,
|
public MultiBlockChangePacket(int chunkX, int section, int chunkZ,
|
||||||
boolean suppressLightUpdates,
|
|
||||||
long[] blocks) {
|
long[] blocks) {
|
||||||
this(((long) (chunkX & 0x3FFFFF) << 42) | (section & 0xFFFFF) | ((long) (chunkZ & 0x3FFFFF) << 20),
|
this(((long) (chunkX & 0x3FFFFF) << 42) | (section & 0xFFFFF) | ((long) (chunkZ & 0x3FFFFF) << 20), blocks);
|
||||||
suppressLightUpdates, blocks);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public MultiBlockChangePacket(@NotNull NetworkBuffer reader) {
|
public MultiBlockChangePacket(@NotNull NetworkBuffer reader) {
|
||||||
this(reader.read(LONG), reader.read(BOOLEAN), reader.read(VAR_LONG_ARRAY));
|
this(reader.read(LONG), reader.read(VAR_LONG_ARRAY));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(@NotNull NetworkBuffer writer) {
|
public void write(@NotNull NetworkBuffer writer) {
|
||||||
writer.write(LONG, chunkSectionPosition);
|
writer.write(LONG, chunkSectionPosition);
|
||||||
writer.write(BOOLEAN, suppressLightUpdates);
|
|
||||||
writer.write(VAR_LONG_ARRAY, blocks);
|
writer.write(VAR_LONG_ARRAY, blocks);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,15 +7,17 @@ import net.minestom.server.network.packet.server.ServerPacketIdentifier;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import static net.minestom.server.network.NetworkBuffer.BLOCK_POSITION;
|
import static net.minestom.server.network.NetworkBuffer.BLOCK_POSITION;
|
||||||
|
import static net.minestom.server.network.NetworkBuffer.BOOLEAN;
|
||||||
|
|
||||||
public record OpenSignEditorPacket(@NotNull Point position) implements ServerPacket {
|
public record OpenSignEditorPacket(@NotNull Point position, boolean isFrontText) implements ServerPacket {
|
||||||
public OpenSignEditorPacket(@NotNull NetworkBuffer reader) {
|
public OpenSignEditorPacket(@NotNull NetworkBuffer reader) {
|
||||||
this(reader.read(BLOCK_POSITION));
|
this(reader.read(BLOCK_POSITION), reader.read(BOOLEAN));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(@NotNull NetworkBuffer writer) {
|
public void write(@NotNull NetworkBuffer writer) {
|
||||||
writer.write(BLOCK_POSITION, position);
|
writer.write(BLOCK_POSITION, position);
|
||||||
|
writer.write(BOOLEAN, isFrontText);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -12,11 +12,14 @@ import static net.minestom.server.network.NetworkBuffer.*;
|
|||||||
public record RespawnPacket(String dimensionType, String worldName,
|
public record RespawnPacket(String dimensionType, String worldName,
|
||||||
long hashedSeed, GameMode gameMode, GameMode previousGameMode,
|
long hashedSeed, GameMode gameMode, GameMode previousGameMode,
|
||||||
boolean isDebug, boolean isFlat, boolean copyMeta,
|
boolean isDebug, boolean isFlat, boolean copyMeta,
|
||||||
DeathLocation deathLocation) implements ServerPacket {
|
DeathLocation deathLocation, int portalCooldown) implements ServerPacket {
|
||||||
public RespawnPacket(@NotNull NetworkBuffer reader) {
|
public RespawnPacket(@NotNull NetworkBuffer reader) {
|
||||||
this(reader.read(STRING), reader.read(STRING),
|
this(reader.read(STRING), reader.read(STRING),
|
||||||
reader.read(LONG), GameMode.fromId(reader.read(BYTE)), GameMode.fromId(reader.read(BYTE)),
|
reader.read(LONG), GameMode.fromId(reader.read(BYTE)),
|
||||||
reader.read(BOOLEAN), reader.read(BOOLEAN), reader.read(BOOLEAN), reader.read(DEATH_LOCATION));
|
GameMode.fromId(reader.read(BYTE)),
|
||||||
|
reader.read(BOOLEAN), reader.read(BOOLEAN),
|
||||||
|
reader.read(BOOLEAN), reader.read(DEATH_LOCATION),
|
||||||
|
reader.read(VAR_INT));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -30,6 +33,7 @@ public record RespawnPacket(String dimensionType, String worldName,
|
|||||||
writer.write(BOOLEAN, isFlat);
|
writer.write(BOOLEAN, isFlat);
|
||||||
writer.write(BOOLEAN, copyMeta);
|
writer.write(BOOLEAN, copyMeta);
|
||||||
writer.write(DEATH_LOCATION, deathLocation);
|
writer.write(DEATH_LOCATION, deathLocation);
|
||||||
|
writer.write(VAR_INT, portalCooldown);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -8,22 +8,22 @@ import java.util.List;
|
|||||||
|
|
||||||
import static net.minestom.server.network.NetworkBuffer.*;
|
import static net.minestom.server.network.NetworkBuffer.*;
|
||||||
|
|
||||||
public record LightData(boolean trustEdges,
|
public record LightData(
|
||||||
@NotNull BitSet skyMask, @NotNull BitSet blockMask,
|
@NotNull BitSet skyMask, @NotNull BitSet blockMask,
|
||||||
@NotNull BitSet emptySkyMask, @NotNull BitSet emptyBlockMask,
|
@NotNull BitSet emptySkyMask, @NotNull BitSet emptyBlockMask,
|
||||||
@NotNull List<byte[]> skyLight,
|
@NotNull List<byte[]> skyLight,
|
||||||
@NotNull List<byte[]> blockLight) implements NetworkBuffer.Writer {
|
@NotNull List<byte[]> blockLight
|
||||||
|
) implements NetworkBuffer.Writer {
|
||||||
public LightData(@NotNull NetworkBuffer reader) {
|
public LightData(@NotNull NetworkBuffer reader) {
|
||||||
this(reader.read(BOOLEAN),
|
this(
|
||||||
BitSet.valueOf(reader.read(LONG_ARRAY)), BitSet.valueOf(reader.read(LONG_ARRAY)),
|
BitSet.valueOf(reader.read(LONG_ARRAY)), BitSet.valueOf(reader.read(LONG_ARRAY)),
|
||||||
BitSet.valueOf(reader.read(LONG_ARRAY)), BitSet.valueOf(reader.read(LONG_ARRAY)),
|
BitSet.valueOf(reader.read(LONG_ARRAY)), BitSet.valueOf(reader.read(LONG_ARRAY)),
|
||||||
reader.readCollection(BYTE_ARRAY), reader.readCollection(BYTE_ARRAY));
|
reader.readCollection(BYTE_ARRAY), reader.readCollection(BYTE_ARRAY)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(@NotNull NetworkBuffer writer) {
|
public void write(@NotNull NetworkBuffer writer) {
|
||||||
writer.write(BOOLEAN, trustEdges);
|
|
||||||
|
|
||||||
writer.write(LONG_ARRAY, skyMask.toLongArray());
|
writer.write(LONG_ARRAY, skyMask.toLongArray());
|
||||||
writer.write(LONG_ARRAY, blockMask.toLongArray());
|
writer.write(LONG_ARRAY, blockMask.toLongArray());
|
||||||
|
|
||||||
|
@ -90,7 +90,7 @@ public class PacketWriteReadTest {
|
|||||||
SERVER_PACKETS.add(new CloseWindowPacket((byte) 2));
|
SERVER_PACKETS.add(new CloseWindowPacket((byte) 2));
|
||||||
SERVER_PACKETS.add(new CollectItemPacket(5, 5, 5));
|
SERVER_PACKETS.add(new CollectItemPacket(5, 5, 5));
|
||||||
SERVER_PACKETS.add(new CraftRecipeResponse((byte) 2, "recipe"));
|
SERVER_PACKETS.add(new CraftRecipeResponse((byte) 2, "recipe"));
|
||||||
SERVER_PACKETS.add(new DeathCombatEventPacket(5, 5, COMPONENT));
|
SERVER_PACKETS.add(new DeathCombatEventPacket(5, COMPONENT));
|
||||||
SERVER_PACKETS.add(new DeclareRecipesPacket(
|
SERVER_PACKETS.add(new DeclareRecipesPacket(
|
||||||
List.of(new DeclareRecipesPacket.DeclaredShapelessCraftingRecipe(
|
List.of(new DeclareRecipesPacket.DeclaredShapelessCraftingRecipe(
|
||||||
"minecraft:sticks",
|
"minecraft:sticks",
|
||||||
@ -112,7 +112,7 @@ public class PacketWriteReadTest {
|
|||||||
SERVER_PACKETS.add(new DisconnectPacket(COMPONENT));
|
SERVER_PACKETS.add(new DisconnectPacket(COMPONENT));
|
||||||
SERVER_PACKETS.add(new DisplayScoreboardPacket((byte) 5, "scoreboard"));
|
SERVER_PACKETS.add(new DisplayScoreboardPacket((byte) 5, "scoreboard"));
|
||||||
SERVER_PACKETS.add(new EffectPacket(5, VEC, 5, false));
|
SERVER_PACKETS.add(new EffectPacket(5, VEC, 5, false));
|
||||||
SERVER_PACKETS.add(new EndCombatEventPacket(5, 5));
|
SERVER_PACKETS.add(new EndCombatEventPacket(5));
|
||||||
SERVER_PACKETS.add(new EnterCombatEventPacket());
|
SERVER_PACKETS.add(new EnterCombatEventPacket());
|
||||||
SERVER_PACKETS.add(new EntityAnimationPacket(5, EntityAnimationPacket.Animation.TAKE_DAMAGE));
|
SERVER_PACKETS.add(new EntityAnimationPacket(5, EntityAnimationPacket.Animation.TAKE_DAMAGE));
|
||||||
SERVER_PACKETS.add(new EntityEquipmentPacket(6, Map.of(EquipmentSlot.MAIN_HAND, ItemStack.of(Material.DIAMOND_SWORD))));
|
SERVER_PACKETS.add(new EntityEquipmentPacket(6, Map.of(EquipmentSlot.MAIN_HAND, ItemStack.of(Material.DIAMOND_SWORD))));
|
||||||
|
Loading…
Reference in New Issue
Block a user