Difference between revisions of "Pre-release protocol"

From wiki.vg
Jump to navigation Jump to search
(→‎Title: You were right - decompiling the enum (ie$a) shows the constant names in the static block.)
(Updated to 1.21-pre2)
 
(885 intermediate revisions by 54 users not shown)
Line 1: Line 1:
This page documents the changes from the [[Protocol|last stable Minecraft release]] (currently [[Protocol version numbers|1.10.2, protocol 210]]) to the current pre-release (currently [[Protocol version numbers|16w40a, protocol 310]]). Note that this page contains bleeding-edge information that may not be completely or correctly documented.
+
This page documents the changes from the [[Protocol|last stable Minecraft release]] (currently [[Protocol version numbers|1.20.6, protocol 766]]) to the current pre-release (currently [[Protocol version numbers|1.21-pre2, protocol {{Snapshot PVN|1073742024}}]]). Note that this page contains bleeding-edge information that may not be completely or correctly documented.
  
 
One who wishes to commandeer the merging of this into [[Protocol]] when an update is made must be sure to respect any changes that may have occurred to the respective packets there.
 
One who wishes to commandeer the merging of this into [[Protocol]] when an update is made must be sure to respect any changes that may have occurred to the respective packets there.
Line 9: Line 9:
 
=== Data types ===
 
=== Data types ===
  
No changes so far.
+
No changes documented so far.
  
 
=== Packets ===
 
=== Packets ===
 
No changes so far.
 
  
 
{| class="wikitable"
 
{| class="wikitable"
Line 20: Line 18:
 
  !colspan="2"| Documentation
 
  !colspan="2"| Documentation
 
  |-
 
  |-
  !colspan="4"| Handshaking serverbound
+
  !colspan="4"| Configuration clientbound
  {{PacketList|0x00|Handshake}}
+
  {{PacketList|0x0F|Clientbound Report Details (configuration)|rel=added}}
 +
{{PacketList|0x10|Clientbound Server Links (configuration)|rel=added}}
 
  |-
 
  |-
 
  !colspan="4"| Play clientbound
 
  !colspan="4"| Play clientbound
  {{PacketList|0x03|Spawn Mob}}
+
  {{PacketList|0x7A|Clientbound Report Details (play)|rel=added}}
{{PacketList|0x09|Update Block Entity}}
+
  {{PacketList|0x7B|Clientbound Server Links (play)|rel=added}}
{{PacketList|0x0E|Tab-Complete (clientbound)}}
 
{{PacketList|0x1B|Entity Status}}
 
{{PacketList|0x24|Map}}
 
{{PacketList|0x45|Title}}
 
  {{PacketList|0x48|Collect Item}}
 
|-
 
!colspan="4"| Play serverbound
 
{{PacketList|0x02|Chat Message (serverbound)}}
 
{{PacketList|0x1C|Player Block Placement}}
 
 
  |-
 
  |-
 
|}
 
|}
  
== New/modified data types ==
+
== Handshake ==
  
=== Objects ===
+
No changes so far.
  
Objects are spawned via [[Protocol#Spawn_Object|Spawn Object]]. See [[Object Data]] for more details.
+
== Status ==
  
{| class="wikitable"
+
No changes so far.
|-
 
! ID
 
! Name
 
! x, z
 
! y
 
|-
 
| 1
 
| Boat
 
| 1.5
 
| 0.6
 
|-
 
| 2
 
| Item Stack ([[Slot]])
 
| 0.25
 
| 0.25
 
|-
 
| 3
 
| Area Effect Cloud
 
| ?
 
| ?
 
|-
 
| 10
 
| Minecart
 
| 0.98
 
| 0.7
 
|-
 
| 50
 
| Activated TNT
 
| 0.98
 
| 0.98
 
|-
 
| 51
 
| EnderCrystal
 
| 2.0
 
| 2.0
 
|-
 
| 60
 
| Tipped arrow (projectile; also used for regular arrows)
 
| 0.5
 
| 0.5
 
|-
 
| 61
 
| Snowball (projectile)
 
| 0.25
 
| 0.25
 
|-
 
| 62
 
| Egg (projectile)
 
| 0.25
 
| 0.25
 
|-
 
| 63
 
| FireBall (ghast projectile)
 
| 1.0
 
| 1.0
 
|-
 
| 64
 
| FireCharge (blaze projectile)
 
| 0.3125
 
| 0.3125
 
|-
 
| 65
 
| Thrown Enderpearl
 
| 0.25
 
| 0.25
 
|-
 
| 66
 
| Wither Skull (projectile)
 
| 0.3125
 
| 0.3125
 
|-
 
| 67
 
| Shulker Bullet
 
| 0.3125
 
| 0.3125
 
|-
 
|style="background-color: #d9ead3;"|68
 
|style="background-color: #d9ead3;"|Llama spit
 
|style="background-color: #d9ead3;"|0.25
 
|style="background-color: #d9ead3;"|0.25
 
|-
 
| 70
 
| Falling Objects
 
| 0.98
 
| 0.98
 
|-
 
| 71
 
| Item frames
 
| varies
 
| varies
 
|-
 
| 72
 
| Eye of Ender
 
| 0.25
 
| 0.25
 
|-
 
| 73
 
| Thrown Potion
 
| 0.25
 
| 0.25
 
|-
 
| 75
 
| Thrown Exp Bottle
 
| 0.25
 
| 0.25
 
|-
 
| 76
 
| Firework Rocket
 
| 0.25
 
| 0.25
 
|-
 
| 77
 
| Leash Knot
 
| 0.5
 
| 0.5
 
|-
 
| 78
 
| ArmorStand
 
| 0.5
 
| 2.0
 
|-
 
|style="background-color: #d9ead3;"|79
 
|style="background-color: #d9ead3;"|Evocation Fangs
 
|style="background-color: #d9ead3;"|0.8
 
|style="background-color: #d9ead3;"|0.5
 
|-
 
| 90
 
| Fishing Float
 
| 0.25
 
| 0.25
 
|-
 
| 91
 
| Spectral Arrow
 
| 0.5
 
| 0.5
 
|-
 
| 93
 
| Dragon Fireball
 
| 0.3125
 
| 0.3125
 
|}
 
  
Since release {{Minecraft Wiki|1.6}}, all minecarts are spawned with object type 10 and their functionality is then specified in the [[Object Data#Minecarts (id 10)|Data field]] within the packet. Also, their visual appearance may be sent via the [[Protocol#Entity Metadata|Entity Metadata]] packet.
+
== Login ==
  
 +
No changes so far.
  
=== Mobs ===
+
== Configuration ==
  
Mobs are spawned via [[Protocol#Spawn_Mob|Spawn Mob]]. {{change|There are two extra mob types in the code that refer to mobs classes that can never spawn: Mob and Monster (they are always subclasses, aka another more specific type).}}
+
=== Clientbound ===
  
{| class="wikitable"
+
==== Clientbound Report Details (configuration) ====
|-
 
! Type
 
! Name
 
! x, z
 
! y
 
! ID
 
|- style="background-color: #d9ead3;"
 
| 4
 
| ElderGuardian
 
| 0.85
 
| 0.85
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:elder_guardian</code>
 
|- style="background-color: #d9ead3;"
 
| 5
 
| WitherSkeleton
 
| 0.7
 
| 2.4
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:wither_skeleton</code>
 
|- style="background-color: #d9ead3;"
 
| 6
 
| Stray
 
| 0.6
 
| 1.99
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:stray</code>
 
|- style="background-color: #d9ead3;"
 
| 23
 
| Husk
 
| 0.6
 
| 1.95
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:husk</code>
 
|- style="background-color: #d9ead3;"
 
| 27
 
| ZombieVillager
 
| 0.6
 
| 1.95
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:zombie_villager</code>
 
|- style="background-color: #d9ead3;"
 
| 28
 
| SkeletonHorse
 
| 1.396484
 
| 1.6
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:skeleton_horse</code>
 
|- style="background-color: #d9ead3;"
 
| 29
 
| ZombieHorse
 
| 1.396484
 
| 1.6
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:zombie_horse</code>
 
|- style="background-color: #d9ead3;"
 
| 31
 
| Donkey
 
| 1.396484
 
| 1.6
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:donkey</code>
 
|- style="background-color: #d9ead3;"
 
| 32
 
| Mule
 
| 1.396484
 
| 1.6
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:mule</code>
 
|- style="background-color: #d9ead3;"
 
| 33
 
| EvocationFangs
 
| 0.5
 
| 0.8
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:evocation_fangs</code>
 
|- style="background-color: #d9ead3;"
 
| 34
 
| EvocationIllager
 
| 0.6
 
| 1.95
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:evocation_illager</code>
 
|- style="background-color: #d9ead3;"
 
| 35
 
| Vex
 
| 0.4
 
| 0.8
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:vex</code>
 
|- style="background-color: #d9ead3;"
 
| 36
 
| VindicationIllager
 
| 0.6
 
| 1.95
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:vindication_illager</code>
 
|- style="background-color: #f4cccc;"
 
| 48
 
| Mob
 
| N/A
 
| N/A
 
| N/A
 
|- style="background-color: #f4cccc;"
 
| 49
 
| Monster
 
| N/A
 
| N/A
 
| N/A
 
|-
 
| 50
 
| Creeper
 
| 0.6
 
| 1.7
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:creeper</code>
 
|-
 
| 51
 
| Skeleton
 
| 0.6
 
| 1.99
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:skeleton</code>
 
|-
 
| 52
 
| Spider
 
| 1.4
 
| 0.9
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:spider</code>
 
|-
 
| 53
 
| {{change|Giant Zombie|Giant}}
 
| 0.6 * 6
 
| 1.8 * 6
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:giant</code>
 
|-
 
| 54
 
| Zombie
 
| 0.6
 
| 1.8
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:zombie</code>
 
|-
 
| 55
 
| Slime
 
| 0.51000005 * size
 
| 0.51000005 * size
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:slime</code>
 
|-
 
| 56
 
| Ghast
 
| 4
 
| 4
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:ghast</code>
 
|-
 
| 57
 
| {{change|Zombie Pigman|PigZombie}}
 
| 0.6
 
| 1.8
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:zombie_pigman</code>
 
|-
 
| 58
 
| Enderman
 
| 0.6
 
| 2.9
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:enderman</code>
 
|-
 
| 59
 
| {{change|Cave Spider|CaveSpider}}
 
| 0.7
 
| 0.5
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:cave_spider</code>
 
|-
 
| 60
 
| Silverfish
 
| 0.4
 
| 0.3
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:silverfish</code>
 
|-
 
| 61
 
| Blaze
 
| 0.6
 
| 1.8
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:blaze</code>
 
|-
 
| 62
 
| {{change|Magma Cube|LavaSlime}}
 
| 0.51000005 * size
 
| 0.51000005 * size
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:magma_cube</code>
 
|-
 
| 63
 
| {{change|Ender Dragon|EnderDragon}}
 
| 16.0
 
| 8.0
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:ender_dragon</code>
 
|-
 
| 64
 
| {{change|Wither|WitherBoss}}
 
| 0.9
 
| 3.5
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:wither</code>
 
|-
 
| 65
 
| Bat
 
| 0.5
 
| 0.9
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:bat</code>
 
|-
 
| 66
 
| Witch
 
| 0.6
 
| 1.8
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:witch</code>
 
|-
 
| 67
 
| Endermite
 
| 0.4
 
| 0.3
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:endermite</code>
 
|-
 
| 68
 
| Guardian
 
| 0.85
 
| 0.85
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:guardian</code>
 
|-
 
| 69
 
| Shulker
 
| 1
 
| 1
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:shulker</code>
 
|-
 
| 90
 
| Pig
 
| 0.9
 
| 0.9
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:pig</code>
 
|-
 
| 91
 
| Sheep
 
| 0.9
 
| 1.3
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:sheep</code>
 
|-
 
| 92
 
| Cow
 
| 0.9
 
| 1.4
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:cow</code>
 
|-
 
| 93
 
| Chicken
 
| 0.4
 
| 0.7
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:chicken</code>
 
|-
 
| 94
 
| Squid
 
| 0.8
 
| 0.8
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:squid</code>
 
|-
 
| 95
 
| Wolf
 
| 0.6
 
| 0.85
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:wolf</code>
 
|-
 
| 96
 
| {{change|Mooshroom|MushroomCow}}
 
| 0.9
 
| 1.3
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:mooshroom</code>
 
|-
 
| 97
 
| {{change|Snowman|SnowMan}}
 
| 0.7
 
| 1.9
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:snowman</code>
 
|-
 
| 98
 
| {{change|Ocelot|Ozelot}}
 
| 0.6
 
| 0.8
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:ocelot</code>
 
|-
 
| 99
 
| {{change|Iron Golem|VillagerGolem}}
 
| 1.4
 
| 2.7
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:villager_golem</code>
 
|-
 
| 100
 
| {{change|EntityHorse|Horse}}
 
| 1.396484
 
| 1.6
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:horse</code>
 
|-
 
| 101
 
| Rabbit
 
| 0.4
 
| 0.5
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:rabbit</code>
 
|-
 
| 102
 
| {{change|Polar Bear|PolarBear}}
 
| 1.3
 
| 1.4
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:polar_bear</code>
 
|- style="background-color: #d9ead3;"
 
| 103
 
| Llama
 
| 1.3964844
 
| 1.87
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:llama</code>
 
|-
 
|-
 
| 120
 
| Villager
 
| 0.6
 
| 1.95
 
| style="background-color: #d9ead3; text-align: center;" | <code>minecraft:villager</code>
 
|}
 
  
=== Entity Metadata ===
+
Contains a list of key-value text entries that are included in any crash or disconnection report generated during connection to the server.
  
=== EvocationIllager ===
+
{| class="wikitable" {{added}}
 
+
! Packet ID
Extends [[#Monster|Monster]].
+
  ! State
 
+
  ! Bound To
{| class="wikitable" style="background-color: #d9ead3;"
+
  ! colspan="2"| Field Name
  ! Index
+
  ! colspan="2"| Field Type
  ! Type
+
  ! Notes
  !style="width: 250px;" colspan="2"| Meaning
 
  |-
 
| 12
 
| Byte
 
| Unknown (Probably hands up animation)
 
|}
 
 
 
=== Vex ===
 
 
 
Extends [[#Monster|Monster]].
 
 
 
{| class="wikitable" style="background-color: #d9ead3;"
 
! Index
 
! Type
 
  !style="width: 250px;" colspan="2"| Meaning
 
 
  |-
 
  |-
  |rowspan="3"| 12
+
  | rowspan="3"| 0x0F
  |rowspan="3"| Byte
+
  | rowspan="3"| Configuration
! Bit mask
+
  | rowspan="3"| Client
! Meaning
+
  | colspan="2"| Details Count
  |- style="background-color: #d9ead3;"
+
| colspan="2"| {{Type|VarInt}} (32)
| 0x01
+
  | The number of details in the following array.
  | Is in attack mode
 
|}
 
 
 
=== VindicationIllager ===
 
 
 
Extends [[#Monster|Monster]].
 
 
 
{| class="wikitable" style="background-color: #d9ead3;"
 
! Index
 
! Type
 
  !style="width: 250px;" colspan="2"| Meaning
 
 
  |-
 
  |-
  |rowspan="3"| 12
+
  | rowspan="2"| Details
  |rowspan="3"| Byte
+
  | Title
! Bit mask
+
  | rowspan="2"| {{Type|Array}}
! Meaning
+
  | {{Type|String}} (128)
  |- style="background-color: #d9ead3;"
+
  |
| 0x01
 
| Has target (aggressive state)
 
  |}
 
 
 
=== EvocationFangs ===
 
 
 
Extends [[#Entity|Entity]].
 
 
 
=== AbstractSkeleton ===
 
 
 
Extends [[#Monster|Monster]].
 
 
 
{| class="wikitable" style="background-color: #d9ead3;"
 
! Index
 
! Type
 
  !style="width: 250px;" colspan="2"| Meaning
 
 
  |-
 
  |-
  | 12
+
  | Description
  | Boolean
+
  | {{Type|String}} (4096)
|colspan="2"| Is swinging arms
+
  |
|}
+
|}
 
 
=== Skeleton ===
 
 
 
Extends [[#AbstractSkeleton|AbstractSkeleton]].
 
 
 
{| class="wikitable" style="background-color: #f4cccc;"
 
! Index
 
! Type
 
!style="width: 250px;" colspan="2"| Meaning
 
|-
 
| 12
 
| VarInt
 
|colspan="2"| Type (Normal = 0, Wither = 1, Stray = 2)
 
|-
 
| 13
 
| Boolean
 
|colspan="2"| Is swinging arms (Used to animate arms for melee attacks; only used when the skeleton does not have a bow in its hand)
 
|}
 
 
 
=== Wither Skeleton ===
 
 
 
Extends [[#AbstractSkeleton|AbstractSkeleton]].
 
 
 
=== Stray ===
 
 
 
Extends [[#AbstractSkeleton|AbstractSkeleton]].
 
 
 
=== Zombie ===
 
 
 
Extends [[#Monster|Monster]].
 
 
 
{| class="wikitable"
 
! Index
 
! Type
 
!style="width: 250px;" colspan="2"| Meaning
 
|-
 
| 12
 
| Boolean
 
|colspan="2"| Is baby
 
|-
 
| 13
 
| VarInt
 
|colspan="2"| {{change|Zombie type (0 for zombie, profession+1 for villagers, 6 for Husk)|Unused}}
 
|- style="background-color: #f4cccc;"
 
| 14
 
| Boolean
 
|colspan="2"| Is converting
 
|-
 
| {{change|15|14}}
 
| Boolean
 
|colspan="2"| Are hands held up
 
|}
 
 
 
=== Zombie Villager ===
 
 
 
Extends [[#Zombie|Zombie]].
 
 
 
{| class="wikitable"
 
! Index
 
! Type
 
!style="width: 250px;" colspan="2"| Meaning
 
|- style="background-color: #d9ead3;"
 
| 15
 
| Boolean
 
|colspan="2"| Is converting
 
|- style="background-color: #d9ead3;"
 
| 16
 
| VarInt
 
|colspan="2"| Profession
 
|}
 
 
 
=== Husk ===
 
 
 
Extends [[#Zombie|Zombie]].
 
 
 
=== Guardian ===
 
 
 
Extends [[#Monster|Monster]].
 
 
 
{| class="wikitable"
 
! Index
 
! Type
 
!style="width: 250px;" colspan="2"| Meaning
 
|- style="background-color: #f4cccc;"
 
|rowspan="3"| 12
 
|rowspan="3"| Byte
 
! Bit mask
 
! Meaning
 
|- style="background-color: #f4cccc;"
 
| 0x02
 
| is retracting spikes
 
|- style="background-color: #f4cccc;"
 
| 0x04
 
| is elderly
 
|- style="background-color: #d9ead3;"
 
| 12
 
| Boolean
 
|colspan="2"| Is retracting spikes
 
|-
 
| 13
 
| VarInt
 
|colspan="2"| Target EID
 
|}
 
 
 
=== ElderGuardian ===
 
 
 
Extends [[#Guardian|Guardian]].
 
 
 
=== AbstractHorse ===
 
 
 
Extends [[#Animal|Animal]].
 
 
 
{| class="wikitable" style="background-color: #d9ead3;"
 
! Index
 
! Type
 
!style="width: 250px;" colspan="2"| Meaning
 
|-
 
|rowspan="9"| 13
 
|rowspan="9"| Byte
 
! Bit mask
 
! Meaning
 
|-
 
| 0x01
 
| ''Unused''
 
|-
 
| 0x02
 
| Is Tame
 
|-
 
| 0x04
 
| Is saddled
 
|-
 
| 0x08
 
| Has Chest
 
|-
 
| 0x10
 
| Is Bred (not used on the Notchian server; controlled via the unused Bred NBT flag)
 
|-
 
| 0x20
 
| Is eating
 
|-
 
| 0x40
 
| Is rearing (on hind legs)
 
|-
 
| 0x80
 
| Is mouth open
 
|-
 
| 14
 
| OptUUID
 
|colspan="2"| Owner
 
|}
 
 
 
=== Horse ===
 
 
 
Extends [[#AbstractHorse|AbstractHorse]].
 
 
 
{| class="wikitable" style="background-color: #d9ead3;"
 
! Index
 
! Type
 
!style="width: 250px;" colspan="2"| Meaning
 
|-
 
| 15
 
| VarInt
 
|colspan="2"| Variant (Color & Style)
 
  |-
 
| 16
 
| VarInt
 
|colspan="2"| Armor
 
|}
 
 
 
=== ZombieHorse ===
 
 
 
Extends [[#AbstractHorse|AbstractHorse]].
 
  
=== SkeletonHorse ===
+
==== Clientbound Server Links (configuration) ====
  
Extends [[#AbstractHorse|AbstractHorse]].
+
This packet contains a list of links that the Notchian client will display in the menu available from the pause menu. Link labels can be built-in or custom (i.e., any text).
  
=== ChestedHorse ===
+
{| class="wikitable" {{added}}
 
 
Extends [[#AbstractHorse|AbstractHorse]].
 
 
 
{| class="wikitable" style="background-color: #d9ead3;"
 
! Index
 
! Type
 
!style="width: 250px;" colspan="2"| Meaning
 
|-
 
| 15
 
| Boolean
 
|colspan="2"| Has Chest
 
|}
 
 
 
=== Donkey ===
 
 
 
Extends [[#ChestedHorse|ChestedHorse]].
 
 
 
=== Llama ===
 
 
 
Extends [[#ChestedHorse|ChestedHorse]].
 
 
 
{| class="wikitable" style="background-color: #d9ead3;"
 
! Index
 
! Type
 
!style="width: 250px;" colspan="2"| Meaning
 
|-
 
| 16
 
| Integer
 
| colspan="2"| Strength (number of columns of 3 slots in the llama's inventory once a chest is equipped)
 
|-
 
| 17
 
| Integer
 
| colspan="2"| Carpet color (a dye color, or -1 if no carpet equipped)
 
|-
 
| 18
 
| Integer
 
| colspan="2"| Variant (0: <code>llama_creamy.png</code>, 1: <code>llama_white.png</code>, 2: <code>llama_brown.png</code>, 3: <code>llama_gray.png</code>)
 
|}
 
 
 
=== Mule ===
 
 
 
Extends [[#ChestedHorse|ChestedHorse]].
 
 
 
=== Shulker ===
 
 
 
Extends [[#Golem|Golem]].
 
 
 
{| class="wikitable"
 
! Index
 
! Type
 
! style="width: 250px;" colspan="2"| Meaning
 
|-
 
| 12
 
| Direction
 
|colspan="2"| Facing direction
 
|-
 
| 13
 
| OptPosition
 
|colspan="2"| Attachment position
 
|-
 
| 14
 
| Byte
 
|colspan="2"| Shield height
 
|- style="background-color: #d9ead3;"
 
| 15
 
| Byte
 
| colspan="2"| Color (dye color, default of purple)
 
|}
 
 
 
== Inventory ==
 
 
 
{| class="wikitable"
 
|-
 
! Window Type
 
! Description
 
|-
 
| minecraft:chest
 
| {{Minecraft Wiki|Chest}}, large chest, or {{Minecraft Wiki|minecart with chest}}
 
|-
 
| minecraft:crafting_table
 
| {{Minecraft Wiki|Crafting table}}
 
|-
 
| minecraft:furnace
 
| {{Minecraft Wiki|Furnace}}
 
|-
 
| minecraft:dispenser
 
| {{Minecraft Wiki|Dispenser}}
 
|-
 
| minecraft:enchanting_table
 
| {{Minecraft Wiki|Enchantment table}}
 
|-
 
| minecraft:brewing_stand
 
| {{Minecraft Wiki|Brewing stand}}
 
|-
 
| minecraft:villager
 
| {{Minecraft Wiki|Villager}}
 
|-
 
| minecraft:beacon
 
| {{Minecraft Wiki|Beacon}}
 
|-
 
| minecraft:anvil
 
| {{Minecraft Wiki|Anvil}}
 
|-
 
| minecraft:hopper
 
| {{Minecraft Wiki|Hopper}} or {{Minecraft Wiki|minecart with hopper}}
 
|-
 
| minecraft:dropper
 
| {{Minecraft Wiki|Dropper}}
 
|-
 
|style="background-color: #d9ead3;"| minecraft:shulker_box
 
|style="background-color: #d9ead3;"| {{Minecraft Wiki|Shulker box}}
 
|-
 
| EntityHorse
 
| {{Minecraft Wiki|Horse|Horse, donkey, or mule}}, {{change||or {{Minecraft Wiki|Llama}}}}
 
|}
 
 
 
=== Shulker box ===
 
<!-- Yes, this image doesn't exist yet; I'll add it later. -->
 
[[File:Shulker-box-slots.png|thumb|Shulker box slots]]
 
 
 
This is the window that is opened when the player right-clicks on a shulker box chest.
 
 
 
{| class="wikitable"
 
|-
 
! Slot range
 
! Description
 
|-
 
| 0–26
 
| box slots
 
|-
 
| 27–53
 
| main inventory
 
|-
 
| 54–62
 
| hotbar
 
|}
 
 
 
{{-}}
 
 
 
=== Llama ===
 
<!-- Again, this image doesn't exist yet -->
 
[[File:Llama-strength5-slots.png|thumb|Llama slots]]
 
 
 
The inventory that appears when a tamed llama is right-clicked and has a chest, or when the player's inventory is opened while riding a tamed llama.  Depending on the value of the strength field, the number of chest rows may vary (max is 5, so 15 slots).
 
 
 
{{warning|There still is a saddle slot, even though it cannot be used and is invisible.}}
 
 
 
{{warning|Slot positions within the llama inventory vary - slot 2 may be at (1,0) or at (0,1) depending on the number of columns.}}
 
 
 
{| class="wikitable"
 
|-
 
! Slot range
 
! Description
 
|-
 
| 0
 
| saddle
 
|-
 
| 1
 
| carpet
 
|-
 
| 2-(2+3*Strength)
 
| llama inventory
 
|-
 
| (2+3*Strength)+1-(2+3*Strength)+27
 
| player inventory
 
|-
 
| (2+3*Strength)+28-(2+3*Strength)+35
 
| hotbar
 
|}
 
 
 
<gallery>
 
File:Llama-unchested-slots.png|Unchested llama
 
File:Llama-strength1-slots.png|Llama with strength 1
 
File:Llama-strength2-slots.png|Llama with strength 2
 
File:Llama-strength3-slots.png|Llama with strength 3
 
File:Llama-strength4-slots.png|Llama with strength 4
 
File:Llama-strength5-slots.png|Llama with strength 5
 
</gallery>
 
 
 
== Block Actions ==
 
 
 
=== Shulker Box ===
 
 
 
Animates the shulker box's shell opening.
 
 
 
==== Action IDs ====
 
 
 
There is only one action: 1, which updates the number of players who are looking in the shulker box.
 
 
 
==== Action param ====
 
 
 
If the action is 1, updates the number of players who have the shulker box open.  If 0, the shulker box enters its closing animation; if 1, the shulker box enters its opening animation.
 
 
 
[[Category:Minecraft Modern]]
 
 
 
== Handshaking ==
 
 
 
=== Clientbound ===
 
 
 
No changes so far.
 
 
 
=== Serverbound ===
 
 
 
==== Handshake ====
 
 
 
This causes the server to switch into the target state.
 
 
 
{| class="wikitable"
 
 
  ! Packet ID
 
  ! Packet ID
 
  ! State
 
  ! State
 
  ! Bound To
 
  ! Bound To
  ! Field Name
+
  ! colspan="2"| Field Name
  ! Field Type
+
  ! colspan="2"| Field Type
 
  ! Notes
 
  ! Notes
 
  |-
 
  |-
  |rowspan="4"| 0x00
+
  | rowspan="4"| 0x10
  |rowspan="4"| Handshaking
+
  | rowspan="4"| Configuration
  |rowspan="4"| Server
+
  | rowspan="4"| Client
  | Protocol Version
+
  | colspan="2"| Links Count
  | VarInt
+
  | colspan="2"| {{Type|VarInt}}
| See [[protocol version numbers]] (currently {{change|210|310}})
+
| The number of links in the following array.
 
  |-
 
  |-
  | Server Address
+
  | rowspan="3"| Links
  | String
+
  | Is built-in
  | Hostname or IP, e.g. localhost or 127.0.0.1, that was used to connect.  The Notchian server does not use this information.
+
  | rowspan="3"| {{Type|Array}}
|-
+
  | {{Type|Boolean}}
  | Server Port
+
  | Determines if the following label is built-in (from enum) or custom (text component).
| Unsigned Short
 
  | Default is 25565.  The Notchian server does not use this information.
 
 
  |-
 
  |-
  | Next State
+
  | Label
  | VarInt Enum
+
  | {{Type|VarInt}} {{Type|Enum}} / {{Type|Text Component}}
  | 1 for [[#Status|status]], 2 for [[#Login|login]]
+
  | See below.
  |}
+
|-
 +
| URL
 +
  | {{Type|String}}
 +
| Valid URL.
 +
|}
  
== Play ==
 
  
=== Clientbound ===
+
{| class="wikitable" {{added}}
 
+
  ! ID
==== Spawn Mob ====
+
  ! Name
 
 
Sent by the server when a mob entity is spawned.
 
 
 
{| class="wikitable"
 
  ! Packet ID
 
  ! State
 
! Bound To
 
! Field Name
 
! Field Type
 
 
  ! Notes
 
  ! Notes
 
  |-
 
  |-
  |rowspan="13"| 0x03
+
  | 0
|rowspan="13"| Play
+
  | Bug Report
|rowspan="13"| Client
+
  | Displayed on connection error screen; included as a comment in the disconnection report.
| Entity ID
 
  | VarInt
 
  |  
 
 
  |-
 
  |-
  | Entity UUID
+
  | 1
  | UUID
+
  | Community Guidelines
 
  |  
 
  |  
 
  |-
 
  |-
  | Type
+
  | 2
  | {{change|Unsigned Byte|VarInt}}
+
  | Support
| The type of mob. See [[Entities#Mobs]]
 
|-
 
| X
 
| Double
 
 
  |  
 
  |  
 
  |-
 
  |-
  | Y
+
  | 3
  | Double
+
  | Status
 
  |  
 
  |  
 
  |-
 
  |-
  | Z
+
  | 4
  | Double
+
  | Feedback
 
  |  
 
  |  
 
  |-
 
  |-
  | Yaw
+
  | 5
  | Angle
+
  | Community
 
  |  
 
  |  
 
  |-
 
  |-
  | Pitch
+
  | 6
  | Angle
+
  | Website
 
  |  
 
  |  
 
  |-
 
  |-
  | Head Pitch
+
  | 7
  | Angle
+
  | Forums
 
  |  
 
  |  
 
  |-
 
  |-
  | Velocity X
+
  | 8
  | Short
+
  | News
| Same units as [[#Entity Velocity|Entity Velocity]]
 
|-
 
| Velocity Y
 
| Short
 
| Same units as [[#Entity Velocity|Entity Velocity]]
 
|-
 
| Velocity Z
 
| Short
 
| Same units as [[#Entity Velocity|Entity Velocity]]
 
|-
 
| Metadata
 
| [[Entities#Entity Metadata Format|Entity Metadata]]
 
 
  |  
 
  |  
|}
 
 
==== Update Block Entity ====
 
 
Sets tile entity associated with the block at the given location.
 
 
{| class="wikitable"
 
! Packet ID
 
! State
 
! Bound To
 
! Field Name
 
! Field Type
 
! Notes
 
 
  |-
 
  |-
  |rowspan="3"| 0x09
+
  | 9
|rowspan="3"| Play
+
  | Announcements
|rowspan="3"| Client
 
| Location
 
  | Position
 
 
  |  
 
  |  
 
  |-
 
  |-
| Action
 
| Unsigned Byte
 
| The type of update to perform, see below
 
|-
 
| NBT Data
 
| [[NBT|NBT Tag]]
 
| Data to set.  May be a TAG_END (0), in which case the block entity at the given location is removed (though this is not required since the client will remove the block entity automatically on chunk unload or block removal)
 
 
  |}
 
  |}
  
''Action'' field:
+
=== Serverbound ===
  
* '''1''': Set SpawnPotentials of a mob spawner
+
No changes so far.
* '''2''': Set command block text (command and last execution status)
 
* '''3''': Set the level, primary, and secondary powers of a beacon
 
* '''4''': Set rotation and skin of mob head
 
* '''5''': Set type of flower in flower pot
 
* '''6''': Set base color and patterns on a banner
 
* '''7''': Set the data for a Structure tile entity
 
* '''8''': Set the destination for a end gateway
 
* '''9''': Set the text on a sign
 
* {{Change||'''10''': Declare a shulker box (unclear if there is any actual data)}}
 
  
==== Tab-Complete (clientbound) ====
+
== Play ==
  
The server responds with a list of auto-completions of the last word sent to it. In the case of regular chat, this is a player username. Command names and parameters are also supported. {{change|The client lists these in the order that they are in the array.|The client sorts these alphabetically before listing them.}}
+
=== Clientbound ===
  
{| class="wikitable"
+
==== Clientbound Report Details (play) ====
! Packet ID
 
! State
 
! Bound To
 
! Field Name
 
! Field Type
 
! Notes
 
|-
 
|rowspan="2"| 0x0E
 
|rowspan="2"| Play
 
|rowspan="2"| Client
 
| Count
 
| VarInt
 
| Number of elements in the following array
 
|-
 
| Matches
 
| Array of String
 
| One eligible command, note that each command is sent separately instead of in a single string, hence the need for Count
 
|}
 
  
==== Entity Status ====
+
Contains a list of key-value text entries that are included in any crash or disconnection report generated during connection to the server.
  
{| class="wikitable"
+
{| class="wikitable" {{added}}
 
  ! Packet ID
 
  ! Packet ID
 
  ! State
 
  ! State
 
  ! Bound To
 
  ! Bound To
  ! Field Name
+
  ! colspan="2"| Field Name
  ! Field Type
+
  ! colspan="2"| Field Type
 
  ! Notes
 
  ! Notes
 
  |-
 
  |-
  |rowspan="2"| 0x1B
+
  | rowspan="3"| 0x7A
  |rowspan="2"| Play
+
  | rowspan="3"| Configuration
  |rowspan="2"| Client
+
  | rowspan="3"| Client
  | Entity ID
+
  | colspan="2"| Details Count
  | Int
+
  | colspan="2"| {{Type|VarInt}} (32)
  |  
+
  | The number of details in the following array.
 
  |-
 
  |-
  | Entity Status
+
  | rowspan="2"| Details
  | Byte Enum
+
  | Title
  | See below
+
  | rowspan="2"| {{Type|Array}}
  |}
+
  | {{Type|String}} (128)
 
+
|
{| class="wikitable"
 
 
  |-
 
  |-
! Entity Status
+
  | Description
! Meaning
+
  | {{Type|String}} (4096)
|-
+
  |
| 0
+
|}
| Spawn tipped arrow particle effects
 
|-
 
  | 1
 
  | Reset a mob spawner minecart's timer (unused by the client?)
 
|-
 
| 1
 
| Create rabbit running particles
 
|-
 
| 2
 
| Entity hurt animation
 
|-
 
| 3
 
| Entity died animation
 
|-
 
| 4
 
| Iron Golem throwing up arms
 
|-
 
| 6
 
| Wolf/Ocelot/Horse taming — Spawn “heart” particles
 
|-
 
| 7
 
| Wolf/Ocelot/Horse tamed — Spawn “smoke” particles
 
|-
 
| 8
 
| Wolf shaking water — Trigger the shaking animation
 
|-
 
| 9
 
| Mark item use as finished (ie, eating finished, drinking finished)
 
|-
 
| 10
 
| Sheep eating grass
 
|-
 
| 10
 
| Ignite TNT minecart
 
|-
 
| 11
 
| Iron Golem handing over a rose
 
|-
 
| 12
 
| Villager mating — Spawn “heart” particles
 
|-
 
| 13
 
| Spawn particles indicating that a villager is angry and seeking revenge
 
|-
 
| 14
 
| Spawn happy particles near a villager
 
|-
 
| 15
 
| Witch animation — Spawn “magic” particles
 
|-
 
| 16
 
| Play zombie converting into a villager sound
 
|-
 
| 17
 
| Firework exploding
 
|-
 
| 18
 
| Animal in love (ready to mate) — Spawn “heart” particles
 
|-
 
| 19
 
| Reset squid rotation
 
|-
 
| 20
 
| Spawn explosion particle — works for some living entities
 
|-
 
| 21
 
| Play guardian sound — works for every entity
 
|-
 
| 22
 
| Enables reduced {{Minecraft Wiki|Debug screen|debug}} for the given player
 
|-
 
| 23
 
| Disables reduced {{Minecraft Wiki|Debug screen|debug}} for the given player
 
|-
 
| 24–28
 
| Sets the {{Minecraft Wiki|Server.properties#op-permission-level|op permission level}} 0–4 for the connected player
 
|-
 
| 29
 
| Shield block sound
 
|-
 
| 30
 
| Shield break sound
 
|-
 
| 31
 
| For a fishing rod bobber, if the hooked entity is this player, tug that player toward the caster of the rod
 
|-
 
| 32
 
| Armorstand hit sound
 
|-
 
| 33
 
| Entity hurt due to thorns (play thorns sound, perform normal hurt animation)
 
  |-
 
|style="background-color: #d9ead3;"| 35
 
|style="background-color: #d9ead3;"| Plays the Totem of Undying animation
 
|}
 
  
==== Map ====
+
==== Clientbound Server Links (play) ====
  
Updates a rectangular area on a {{Minecraft Wiki|map}} item.
+
This packet contains a list of links that the Notchian client will display in the menu available from the pause menu. Link labels can be built-in or custom (i.e., any text).
  
{| class="wikitable"
+
{| class="wikitable" {{added}}
 
  ! Packet ID
 
  ! Packet ID
 
  ! State
 
  ! State
 
  ! Bound To
 
  ! Bound To
  !colspan="2"| Field Name
+
  ! colspan="2"| Field Name
  !colspan="2"| Field Type
+
  ! colspan="2"| Field Type
 
  ! Notes
 
  ! Notes
 
  |-
 
  |-
  |rowspan="13"| 0x24
+
  | rowspan="4"| 0x7B
  |rowspan="13"| Play
+
  | rowspan="4"| Configuration
  |rowspan="13"| Client
+
  | rowspan="4"| Client
  |colspan="2"| Item Damage
+
  | colspan="2"| Links Count
  |colspan="2"| VarInt
+
  | colspan="2"| {{Type|VarInt}}
  | The damage value (map ID) of the map being modified
+
  | The number of links in the following array.
 
  |-
 
  |-
  |colspan="2"| Scale
+
  | rowspan="3"| Links
  |colspan="2"| Byte
+
  | Is built-in
| From 0 for a fully zoomed-in map (1 block per pixel) to 4 for a fully zoomed-out map (16 blocks per pixel)
+
  | rowspan="3"| {{Type|Array}}
|-
+
  | {{Type|Boolean}}
  |colspan="2"| Tracking Position
+
  | Determines if the following label is built-in (from enum) or custom (text component).
  |colspan="2"| Boolean
 
  | Specifies whether the icons are shown
 
|-  
 
|colspan="2"| Icon Count
 
|colspan="2"| VarInt
 
| Number of elements in the following array
 
 
  |-
 
  |-
  |rowspan="3"| Icon
+
  | Label
  | Direction And Type
+
  | {{Type|VarInt}} {{Type|Enum}} / {{Type|Text Component}}
|rowspan="3"| Array
+
  | See below.
| Byte
 
  | 0xF0 = Direction, 0x0F = Type
 
 
  |-
 
  |-
  | X
+
  | URL
  | Byte
+
  | {{Type|String}}
|
+
  | Valid URL.
|-
+
|}
| Z
 
| Byte
 
|
 
|-
 
|colspan="2"| Columns
 
|colspan="2"| Byte
 
| Number of columns updated
 
|-
 
|colspan="2"| Rows
 
|colspan="2"| Optional Byte
 
| Only if Columns is more than 0; number of rows updated
 
|-
 
|colspan="2"| X
 
|colspan="2"| Optional Byte
 
| Only if Columns is more than 0; x offset of the westernmost column
 
|-
 
|colspan="2"| Z
 
|colspan="2"| Optional Byte
 
| Only if Columns is more than 0; z offset of the northernmost row
 
|-
 
|colspan="2"| Length
 
|colspan="2"| Optional VarInt
 
| Only if Columns is more than 0; length of the following array
 
|-
 
|colspan="2"| Data
 
|colspan="2"| Optional Array of Unsigned Byte
 
| Only if Columns is more than 0; see {{Minecraft Wiki|Map item format}}
 
  |}
 
  
For icons, a direction of 0 is a vertical icon and increments by 22.5&deg; (360/16).
+
{| class="wikitable" {{added}}
 
+
  ! ID
Types are based off of rows and columns in <code>map_icons.png</code>:
+
  ! Name
 
+
  ! Notes
{| class="wikitable"
 
  |-
 
  ! Icon type
 
  ! Result
 
 
  |-
 
  |-
 
  | 0
 
  | 0
  | White arrow (players)
+
  | Bug Report
 +
| Displayed on connection error screen; included as a comment in the disconnection report.
 
  |-
 
  |-
 
  | 1
 
  | 1
  | Green arrow (item frames)
+
  | Community Guidelines
 +
|
 
  |-
 
  |-
 
  | 2
 
  | 2
  | Red arrow
+
  | Support
 +
|
 
  |-
 
  |-
 
  | 3
 
  | 3
  | Blue arrow
+
  | Status
 +
|
 
  |-
 
  |-
 
  | 4
 
  | 4
  | White cross
+
  | Feedback
 +
|
 
  |-
 
  |-
 
  | 5
 
  | 5
  | Red pointer
+
  | Community
 +
|
 
  |-
 
  |-
 
  | 6
 
  | 6
  | White circle (off-map players)
+
  | Website
|-
 
|style="background-color: #d9ead3;"| 7
 
|style="background-color: #d9ead3;"| Small white circle (far-off-map players)
 
|-
 
|style="background-color: #d9ead3;"| 8
 
|style="background-color: #d9ead3;"| Mansion
 
|-
 
|style="background-color: #d9ead3;"| 9
 
|style="background-color: #d9ead3;"| Temple
 
|-
 
| 10-15
 
| Unused (blue square)
 
|}
 
 
 
==== Title ====
 
 
 
{| class="wikitable"
 
! Packet ID
 
! State
 
! Bound To
 
!colspan="2"| Field Name
 
! Field Type
 
! Notes
 
|-
 
|rowspan="10"| 0x45
 
|rowspan="10"| Play
 
|rowspan="10"| Client
 
|colspan="2"| Action
 
| VarInt Enum
 
 
  |  
 
  |  
 
  |-
 
  |-
! Action
+
  | 7
! Field Name
+
  | Forums
!
 
!
 
|-
 
| 0: set title
 
  | Title Text
 
  | [[Chat]]
 
 
  |  
 
  |  
 
  |-
 
  |-
  | 1: set subtitle
+
  | 8
  | Subtitle Text
+
  | News
| [[Chat]]
 
 
  |  
 
  |  
|-
 
|style="background-color: #d9ead3;"|2: set action bar
 
|style="background-color: #d9ead3;"|Action bar text
 
|style="background-color: #d9ead3;"|[[Chat]]
 
|style="background-color: #d9ead3;"|Behaves the same as with position 2 in [[#Chat Message (clientbound)|Chat Message (clientbound)]]
 
 
  |-
 
  |-
  |rowspan="3"| {{change|2|3}}: set times and display
+
  | 9
| Fade In
+
  | Announcements
| Int
 
| Ticks to spend fading in
 
|-
 
| Stay
 
| Int
 
| Ticks to keep the title displayed
 
|-
 
| Fade Out
 
| Int
 
| Ticks to spend out, not when to start fading out
 
|-
 
| {{change|3|4}}: hide
 
| ''no fields''
 
  | ''no fields''
 
 
  |  
 
  |  
 
  |-
 
  |-
| {{change|4|5}}: reset
 
| ''no fields''
 
| ''no fields''
 
|
 
|}
 
 
“Hide” makes the title disappear, but if you run times again the same title will appear. “Reset” erases the text.
 
 
The title is visible on screen for Fade In + Stay + Fade Out ticks.
 
 
==== Collect Item ====
 
 
Sent by the server when someone picks up an item lying on the ground — its sole purpose appears to be the animation of the item flying towards you. It doesn't destroy the entity in the client memory, and it doesn't add it to your inventory. The server only checks for items to be picked up after each [[#Player Position|Player Position]] (and [[#Player Position And Look|Player Position And Look]]) packet sent by the client.
 
 
{| class="wikitable"
 
! Packet ID
 
! State
 
! Bound To
 
! Field Name
 
! Field Type
 
! Notes
 
|-
 
|rowspan="3"| 0x48
 
|rowspan="3"| Play
 
|rowspan="3"| Client
 
| Collected Entity ID
 
| VarInt
 
|
 
|-
 
| Collector Entity ID
 
| VarInt
 
|
 
|-
 
|style="background-color: #d9ead3;"|Pickup Item Count
 
|style="background-color: #d9ead3;"|VarInt
 
|style="background-color: #d9ead3;"|Seems to be 1 for XP orbs, otherwise the number of items in the stack.
 
 
  |}
 
  |}
  
 
=== Serverbound ===
 
=== Serverbound ===
 
==== Chat Message (serverbound) ====
 
 
Used to send a chat message to the server.  The message may not be longer than {{change|100|256}} characters or else the server will kick the client.
 
 
If the message starts with a <code>/</code>, the server will attempt to interpret it as a command.  Otherwise, the server will broadcast the same chat message to all players on the server (including the player that sent the message), prepended with player's name.  Specifically, it will respond with a translate [[chat]] component, "<code>chat.type.text</code>" with the first parameter set to the display name of the player (including some chat component logic to support clicking the name to send a PM) and the second parameter set to the message.
 
 
{| class="wikitable"
 
! Packet ID
 
! State
 
! Bound To
 
! Field Name
 
! Field Type
 
! Notes
 
|-
 
|rowspan="1"| 0x02
 
|rowspan="1"| Play
 
|rowspan="1"| Server
 
| Message
 
| String
 
| The client sends the raw input, not a [[Chat]] component
 
|}
 
 
==== Player Block Placement ====
 
 
{| class="wikitable"
 
|-
 
! Packet ID
 
! State
 
! Bound To
 
! Field Name
 
! Field Type
 
! Notes
 
|-
 
|rowspan="6"| 0x1C
 
|rowspan="6"| Play
 
|rowspan="6"| Server
 
| Location
 
| Position
 
| Block position
 
|-
 
| Face
 
| VarInt Enum
 
| The face on which the block is placed (as documented at [[#Player Digging|Player Digging]])
 
|-
 
| Hand
 
| VarInt Enum
 
| The hand from which the block is placed; 0: main hand, 1: off hand
 
|-
 
| Cursor Position X
 
| {{change|Unsigned Byte|Float}}
 
| The position of the crosshair on the block, from 0 to 1 increasing from west to east
 
|-
 
| Cursor Position Y
 
| {{change|Unsigned Byte|Float}}
 
| The position of the crosshair on the block, from 0 to 1 increasing from bottom to top
 
|-
 
| Cursor Position Z
 
| {{change|Unsigned Byte|Float}}
 
| The position of the crosshair on the block, from 0 to 1 increasing from north to south
 
|}
 
 
== Status ==
 
 
=== Clientbound ===
 
  
 
No changes so far.
 
No changes so far.
  
=== Serverbound ===
+
[[Category:Minecraft Modern]]
 
 
No changes so far.
 
 
 
== Login ==
 
 
 
=== Clientbound ===
 
 
 
No changes so far.
 
 
 
=== Serverbound ===
 
 
 
No changes so far.
 

Latest revision as of 10:40, 8 June 2024

This page documents the changes from the last stable Minecraft release (currently 1.20.6, protocol 766) to the current pre-release (currently 1.21-pre2, protocol Snapshot 200). Note that this page contains bleeding-edge information that may not be completely or correctly documented.

One who wishes to commandeer the merging of this into Protocol when an update is made must be sure to respect any changes that may have occurred to the respective packets there.

Contents

Data types

No changes documented so far.

Packets

ID Packet name Documentation
Configuration clientbound
0x0F Clientbound Report Details (configuration) Pre
0x10 Clientbound Server Links (configuration) Pre
Play clientbound
0x7A Clientbound Report Details (play) Pre
0x7B Clientbound Server Links (play) Pre

Handshake

No changes so far.

Status

No changes so far.

Login

No changes so far.

Configuration

Clientbound

Clientbound Report Details (configuration)

Contains a list of key-value text entries that are included in any crash or disconnection report generated during connection to the server.

Packet ID State Bound To Field Name Field Type Notes
0x0F Configuration Client Details Count VarInt (32) The number of details in the following array.
Details Title Array String (128)
Description String (4096)

Clientbound Server Links (configuration)

This packet contains a list of links that the Notchian client will display in the menu available from the pause menu. Link labels can be built-in or custom (i.e., any text).

Packet ID State Bound To Field Name Field Type Notes
0x10 Configuration Client Links Count VarInt The number of links in the following array.
Links Is built-in Array Boolean Determines if the following label is built-in (from enum) or custom (text component).
Label VarInt Enum / Text Component See below.
URL String Valid URL.


ID Name Notes
0 Bug Report Displayed on connection error screen; included as a comment in the disconnection report.
1 Community Guidelines
2 Support
3 Status
4 Feedback
5 Community
6 Website
7 Forums
8 News
9 Announcements

Serverbound

No changes so far.

Play

Clientbound

Clientbound Report Details (play)

Contains a list of key-value text entries that are included in any crash or disconnection report generated during connection to the server.

Packet ID State Bound To Field Name Field Type Notes
0x7A Configuration Client Details Count VarInt (32) The number of details in the following array.
Details Title Array String (128)
Description String (4096)

Clientbound Server Links (play)

This packet contains a list of links that the Notchian client will display in the menu available from the pause menu. Link labels can be built-in or custom (i.e., any text).

Packet ID State Bound To Field Name Field Type Notes
0x7B Configuration Client Links Count VarInt The number of links in the following array.
Links Is built-in Array Boolean Determines if the following label is built-in (from enum) or custom (text component).
Label VarInt Enum / Text Component See below.
URL String Valid URL.
ID Name Notes
0 Bug Report Displayed on connection error screen; included as a comment in the disconnection report.
1 Community Guidelines
2 Support
3 Status
4 Feedback
5 Community
6 Website
7 Forums
8 News
9 Announcements

Serverbound

No changes so far.