3
0
Mirror von https://github.com/ViaVersion/ViaVersion.git synchronisiert 2024-12-25 15:50:10 +01:00

Merge pull request #150 from HugoDaBosss/patch

Fix mob spawners when no EntityId is given
Dieser Commit ist enthalten in:
Myles 2016-03-06 13:45:56 +00:00
Commit 0ea32b3318

Datei anzeigen

@ -624,14 +624,28 @@ public class OutgoingTransformer {
output.writeByte(action); output.writeByte(action);
if (action == 1) { // update spawner if (action == 1) { // update spawner
try { try {
int index = input.readerIndex();
DataInputStream stream = new DataInputStream(new ByteBufInputStream(input)); DataInputStream stream = new DataInputStream(new ByteBufInputStream(input));
CompoundTag tag = (CompoundTag) NBTIO.readTag(stream); CompoundTag tag = (CompoundTag) NBTIO.readTag(stream);
String entity = (String) tag.get("EntityId").getValue(); if(tag != null && tag.contains("EntityId")) {
CompoundTag spawn = new CompoundTag("SpawnData"); String entity = (String) tag.get("EntityId").getValue();
spawn.put(new StringTag("id", entity)); CompoundTag spawn = new CompoundTag("SpawnData");
tag.put(spawn); spawn.put(new StringTag("id", entity));
DataOutputStream out = new DataOutputStream(new ByteBufOutputStream(output)); tag.put(spawn);
NBTIO.writeTag(out, tag); DataOutputStream out = new DataOutputStream(new ByteBufOutputStream(output));
NBTIO.writeTag(out, tag);
}
else if(tag != null) { // EntityID does not exist
CompoundTag spawn = new CompoundTag("SpawnData");
spawn.put(new StringTag("id", "AreaEffectCloud")); //Make spawners show up as empty when no EntityId is given.
tag.put(spawn);
DataOutputStream out = new DataOutputStream(new ByteBufOutputStream(output));
NBTIO.writeTag(out, tag);
}
else { //There doesn't exist any NBT tag
input.readerIndex(index);
output.writeBytes(input, input.readableBytes());
}
} catch (IOException e) { } catch (IOException e) {
e.printStackTrace(); e.printStackTrace();
} }