mirror of
https://github.com/MCCTeam/Minecraft-Console-Client
synced 2025-10-14 21:22:49 +00:00
Fixed a crash on Explosion packet
This commit is contained in:
parent
59e02c2da9
commit
1e07fa576a
1 changed files with 18 additions and 13 deletions
|
|
@ -156,7 +156,7 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
entityPalette = new EntityPalette114();
|
entityPalette = new EntityPalette114();
|
||||||
else if (protocolVersion >= MC_1_13_Version)
|
else if (protocolVersion >= MC_1_13_Version)
|
||||||
entityPalette = new EntityPalette113();
|
entityPalette = new EntityPalette113();
|
||||||
else
|
else
|
||||||
entityPalette = new EntityPalette112();
|
entityPalette = new EntityPalette112();
|
||||||
|
|
||||||
// Item palette
|
// Item palette
|
||||||
|
|
@ -173,7 +173,7 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
itemPalette = new ItemPalette1162();
|
itemPalette = new ItemPalette1162();
|
||||||
else if (protocolVersion >= MC_1_16_1_Version)
|
else if (protocolVersion >= MC_1_16_1_Version)
|
||||||
itemPalette = new ItemPalette1161();
|
itemPalette = new ItemPalette1161();
|
||||||
else
|
else
|
||||||
itemPalette = new ItemPalette115();
|
itemPalette = new ItemPalette115();
|
||||||
|
|
||||||
// MessageType
|
// MessageType
|
||||||
|
|
@ -586,7 +586,7 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
byte[] bodyDigest = dataTypes.ReadNextByteArray(packetData);
|
byte[] bodyDigest = dataTypes.ReadNextByteArray(packetData);
|
||||||
|
|
||||||
bool verifyResult;
|
bool verifyResult;
|
||||||
|
|
||||||
if (!isOnlineMode)
|
if (!isOnlineMode)
|
||||||
verifyResult = false;
|
verifyResult = false;
|
||||||
else if (senderUUID == handler.GetUserUuid())
|
else if (senderUUID == handler.GetUserUuid())
|
||||||
|
|
@ -594,7 +594,7 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
PlayerInfo? player = handler.GetPlayerInfo(senderUUID);
|
PlayerInfo? player = handler.GetPlayerInfo(senderUUID);
|
||||||
|
|
||||||
if (player == null || !player.IsMessageChainLegal())
|
if (player == null || !player.IsMessageChainLegal())
|
||||||
verifyResult = false;
|
verifyResult = false;
|
||||||
else
|
else
|
||||||
|
|
@ -1365,7 +1365,7 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
{
|
{
|
||||||
int entityid = dataTypes.ReadNextVarInt(packetData);
|
int entityid = dataTypes.ReadNextVarInt(packetData);
|
||||||
Inventory.Effects effect = Effects.Speed;
|
Inventory.Effects effect = Effects.Speed;
|
||||||
int effectId = protocolVersion >= MC_1_18_2_Version ?
|
int effectId = protocolVersion >= MC_1_18_2_Version ?
|
||||||
dataTypes.ReadNextVarInt(packetData) : dataTypes.ReadNextByte(packetData);
|
dataTypes.ReadNextVarInt(packetData) : dataTypes.ReadNextByte(packetData);
|
||||||
if (Enum.TryParse(effectId.ToString(), out effect))
|
if (Enum.TryParse(effectId.ToString(), out effect))
|
||||||
{
|
{
|
||||||
|
|
@ -1540,16 +1540,20 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
handler.OnSetExperience(experiencebar, level, totalexperience);
|
handler.OnSetExperience(experiencebar, level, totalexperience);
|
||||||
break;
|
break;
|
||||||
case PacketTypesIn.Explosion:
|
case PacketTypesIn.Explosion:
|
||||||
Location explosionLocation;
|
Location explosionLocation = new(dataTypes.ReadNextFloat(packetData), dataTypes.ReadNextFloat(packetData), dataTypes.ReadNextFloat(packetData));
|
||||||
if (protocolVersion >= MC_1_19_Version)
|
|
||||||
explosionLocation = new(dataTypes.ReadNextDouble(packetData), dataTypes.ReadNextDouble(packetData), dataTypes.ReadNextDouble(packetData));
|
|
||||||
else
|
|
||||||
explosionLocation = new(dataTypes.ReadNextFloat(packetData), dataTypes.ReadNextFloat(packetData), dataTypes.ReadNextFloat(packetData));
|
|
||||||
float explosionStrength = dataTypes.ReadNextFloat(packetData);
|
float explosionStrength = dataTypes.ReadNextFloat(packetData);
|
||||||
int explosionBlockCount = protocolVersion >= MC_1_17_Version
|
int explosionBlockCount = protocolVersion >= MC_1_17_Version
|
||||||
? dataTypes.ReadNextVarInt(packetData)
|
? dataTypes.ReadNextVarInt(packetData)
|
||||||
: dataTypes.ReadNextInt(packetData);
|
: dataTypes.ReadNextInt(packetData);
|
||||||
// Ignoring additional fields (records, pushback)
|
|
||||||
|
for (int i = 0; i < explosionBlockCount; i++)
|
||||||
|
dataTypes.ReadData(3, packetData);
|
||||||
|
|
||||||
|
float playerVelocityX = dataTypes.ReadNextFloat(packetData);
|
||||||
|
float playerVelocityY = dataTypes.ReadNextFloat(packetData);
|
||||||
|
float playerVelocityZ = dataTypes.ReadNextFloat(packetData);
|
||||||
|
|
||||||
handler.OnExplosion(explosionLocation, explosionStrength, explosionBlockCount);
|
handler.OnExplosion(explosionLocation, explosionStrength, explosionBlockCount);
|
||||||
break;
|
break;
|
||||||
case PacketTypesIn.HeldItemChange:
|
case PacketTypesIn.HeldItemChange:
|
||||||
|
|
@ -1657,7 +1661,8 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
{
|
{
|
||||||
netMain.Item2.Cancel();
|
netMain.Item2.Cancel();
|
||||||
}
|
}
|
||||||
if (netReader != null){
|
if (netReader != null)
|
||||||
|
{
|
||||||
netReader.Item2.Cancel();
|
netReader.Item2.Cancel();
|
||||||
socketWrapper.Disconnect();
|
socketWrapper.Disconnect();
|
||||||
}
|
}
|
||||||
|
|
@ -2192,7 +2197,7 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
DateTimeOffset timeNow = DateTimeOffset.UtcNow;
|
DateTimeOffset timeNow = DateTimeOffset.UtcNow;
|
||||||
fields.AddRange(dataTypes.GetLong(timeNow.ToUnixTimeMilliseconds()));
|
fields.AddRange(dataTypes.GetLong(timeNow.ToUnixTimeMilliseconds()));
|
||||||
|
|
||||||
List<Tuple<string, string>>? needSigned =
|
List<Tuple<string, string>>? needSigned =
|
||||||
playerKeyPair != null ? CollectCommandArguments(command) : null; // List< Argument Name, Argument Value >
|
playerKeyPair != null ? CollectCommandArguments(command) : null; // List< Argument Name, Argument Value >
|
||||||
if (needSigned == null || needSigned!.Count == 0)
|
if (needSigned == null || needSigned!.Count == 0)
|
||||||
{
|
{
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue