Mirror von
https://github.com/ViaVersion/ViaVersion.git
synchronisiert 2024-11-03 14:50:30 +01:00
Pot handler rewrite
Dieser Commit ist enthalten in:
Ursprung
f8b4a6e28a
Commit
3761ebf8c7
@ -2,7 +2,6 @@ package us.myles.ViaVersion.protocols.protocol1_13to1_12_2.providers.blockentiti
|
||||
|
||||
import com.github.steveice10.opennbt.tag.builtin.CompoundTag;
|
||||
import us.myles.ViaVersion.api.Pair;
|
||||
import us.myles.ViaVersion.api.Via;
|
||||
import us.myles.ViaVersion.api.data.UserConnection;
|
||||
import us.myles.ViaVersion.protocols.protocol1_13to1_12_2.providers.BlockEntityProvider;
|
||||
|
||||
@ -10,62 +9,66 @@ import java.util.Map;
|
||||
import java.util.concurrent.ConcurrentHashMap;
|
||||
|
||||
public class FlowerPotHandler implements BlockEntityProvider.BlockEntityHandler {
|
||||
private static final Map<Pair<String, Byte>, Integer> flowers = new ConcurrentHashMap<>();
|
||||
private static final Map<Pair<Byte, Byte>, Integer> flowersNumberId = new ConcurrentHashMap<>();
|
||||
// Object -> string (id without namespace) or byte (numeric id)
|
||||
private static final Map<Pair<?, Byte>, Integer> flowers = new ConcurrentHashMap<>();
|
||||
|
||||
static {
|
||||
register("minecraft:air", (byte) 0, (byte) 0, 5265);
|
||||
register("minecraft:sapling", (byte) 6, (byte) 0, 5266);
|
||||
register("minecraft:sapling", (byte) 6, (byte) 1, 5267);
|
||||
register("minecraft:sapling", (byte) 6, (byte) 2, 5268);
|
||||
register("minecraft:sapling", (byte) 6, (byte) 3, 5269);
|
||||
register("minecraft:sapling", (byte) 6, (byte) 4, 5270);
|
||||
register("minecraft:sapling", (byte) 6, (byte) 5, 5271);
|
||||
register("minecraft:tallgrass", (byte) 31, (byte) 2, 5272);
|
||||
register("minecraft:yellow_flower", (byte) 37, (byte) 0, 5273);
|
||||
register("minecraft:red_flower", (byte) 38, (byte) 0, 5274);
|
||||
register("minecraft:red_flower", (byte) 38, (byte) 1, 5275);
|
||||
register("minecraft:red_flower", (byte) 38, (byte) 2, 5276);
|
||||
register("minecraft:red_flower", (byte) 38, (byte) 3, 5277);
|
||||
register("minecraft:red_flower", (byte) 38, (byte) 4, 5278);
|
||||
register("minecraft:red_flower", (byte) 38, (byte) 5, 5279);
|
||||
register("minecraft:red_flower", (byte) 38, (byte) 6, 5280);
|
||||
register("minecraft:red_flower", (byte) 38, (byte) 7, 5281);
|
||||
register("minecraft:red_flower", (byte) 38, (byte) 8, 5282);
|
||||
register("minecraft:red_mushroom", (byte) 40, (byte) 0, 5283);
|
||||
register("minecraft:brown_mushroom", (byte) 39, (byte) 0, 5284);
|
||||
register("minecraft:deadbush", (byte) 32, (byte) 0, 5285);
|
||||
register("minecraft:cactus", (byte) 81, (byte) 0, 5286);
|
||||
register("air", (byte) 0, (byte) 0, 5265);
|
||||
register("sapling", (byte) 6, (byte) 0, 5266);
|
||||
register("sapling", (byte) 6, (byte) 1, 5267);
|
||||
register("sapling", (byte) 6, (byte) 2, 5268);
|
||||
register("sapling", (byte) 6, (byte) 3, 5269);
|
||||
register("sapling", (byte) 6, (byte) 4, 5270);
|
||||
register("sapling", (byte) 6, (byte) 5, 5271);
|
||||
register("tallgrass", (byte) 31, (byte) 2, 5272);
|
||||
register("yellow_flower", (byte) 37, (byte) 0, 5273);
|
||||
register("red_flower", (byte) 38, (byte) 0, 5274);
|
||||
register("red_flower", (byte) 38, (byte) 1, 5275);
|
||||
register("red_flower", (byte) 38, (byte) 2, 5276);
|
||||
register("red_flower", (byte) 38, (byte) 3, 5277);
|
||||
register("red_flower", (byte) 38, (byte) 4, 5278);
|
||||
register("red_flower", (byte) 38, (byte) 5, 5279);
|
||||
register("red_flower", (byte) 38, (byte) 6, 5280);
|
||||
register("red_flower", (byte) 38, (byte) 7, 5281);
|
||||
register("red_flower", (byte) 38, (byte) 8, 5282);
|
||||
register("red_mushroom", (byte) 40, (byte) 0, 5283);
|
||||
register("brown_mushroom", (byte) 39, (byte) 0, 5284);
|
||||
register("deadbush", (byte) 32, (byte) 0, 5285);
|
||||
register("cactus", (byte) 81, (byte) 0, 5286);
|
||||
|
||||
}
|
||||
|
||||
public static void register(String identifier, byte numbericBlockId, byte blockData, int newId) {
|
||||
flowers.put(new Pair<>(identifier, blockData), newId);
|
||||
flowersNumberId.put(new Pair<>(numbericBlockId, blockData), newId);
|
||||
flowers.put(new Pair<>(numbericBlockId, blockData), newId);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int transform(UserConnection user, CompoundTag tag) {
|
||||
Object item = tag.get("Item").getValue();
|
||||
byte data = ((Number) tag.get("Data").getValue()).byteValue();
|
||||
Object item = tag.contains("Item") ? tag.get("Item").getValue() : null;
|
||||
Object data = tag.contains("Data") ? tag.get("Data").getValue() : null;
|
||||
|
||||
Pair<?, Byte> pair = item instanceof Number
|
||||
? new Pair<>(((Number) item).byteValue(), data)
|
||||
: new Pair<>((String) item, data);
|
||||
|
||||
// Return air on empty string
|
||||
if (item instanceof String && ((String) item).isEmpty())
|
||||
return 5265;
|
||||
else if (flowers.containsKey(pair)) {
|
||||
return flowers.get(pair);
|
||||
} else if (flowersNumberId.containsKey(pair)) {
|
||||
return flowersNumberId.get(pair);
|
||||
// Convert item to String without namespace or to Byte
|
||||
if (item instanceof String) {
|
||||
item = ((String) item).replace("minecraft:", "");
|
||||
} else if (item instanceof Number) {
|
||||
item = ((Number) item).byteValue();
|
||||
} else {
|
||||
if (!Via.getConfig().isSuppress1_13ConversionErrors() || Via.getManager().isDebug()) {
|
||||
Via.getPlatform().getLogger().warning("Could not find flowerpot content " + item + " for " + tag);
|
||||
}
|
||||
item = (byte) 0;
|
||||
}
|
||||
|
||||
return -1;
|
||||
// Convert data to Byte
|
||||
if (data instanceof Number) {
|
||||
data = ((Number) data).byteValue();
|
||||
} else {
|
||||
data = (byte) 0;
|
||||
}
|
||||
|
||||
Integer flower = flowers.get(new Pair<>(item, (byte) data));
|
||||
if (flower != null) return flower;
|
||||
flower = flowers.get(new Pair<>(item, (byte) 0));
|
||||
if (flower != null) return flower;
|
||||
|
||||
return 5265; // Fallback to empty pot
|
||||
}
|
||||
}
|
||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren