mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-04 02:01:44 +01:00
SPIGOT-4307: Fix hacky API for banners on shields
This commit is contained in:
parent
2a271162af
commit
b3dc236663
2 changed files with 58 additions and 2 deletions
|
@ -1,5 +1,6 @@
|
||||||
package org.bukkit.craftbukkit.block;
|
package org.bukkit.craftbukkit.block;
|
||||||
|
|
||||||
|
import com.google.common.base.Preconditions;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import net.minecraft.server.EnumColor;
|
import net.minecraft.server.EnumColor;
|
||||||
|
@ -30,7 +31,9 @@ public class CraftBanner extends CraftBlockEntityState<TileEntityBanner> impleme
|
||||||
public void load(TileEntityBanner banner) {
|
public void load(TileEntityBanner banner) {
|
||||||
super.load(banner);
|
super.load(banner);
|
||||||
|
|
||||||
base = DyeColor.getByWoolData((byte) banner.color.getColorIndex());
|
if (banner.color != null) {
|
||||||
|
base = DyeColor.getByWoolData((byte) banner.color.getColorIndex());
|
||||||
|
}
|
||||||
patterns = new ArrayList<Pattern>();
|
patterns = new ArrayList<Pattern>();
|
||||||
|
|
||||||
if (banner.patterns != null) {
|
if (banner.patterns != null) {
|
||||||
|
@ -48,6 +51,7 @@ public class CraftBanner extends CraftBlockEntityState<TileEntityBanner> impleme
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setBaseColor(DyeColor color) {
|
public void setBaseColor(DyeColor color) {
|
||||||
|
Preconditions.checkArgument(color != null, "color");
|
||||||
this.base = color;
|
this.base = color;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,7 @@ import com.google.common.base.Objects;
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import net.minecraft.server.BlockJukeBox;
|
import net.minecraft.server.BlockJukeBox;
|
||||||
|
import net.minecraft.server.EnumColor;
|
||||||
import net.minecraft.server.NBTBase;
|
import net.minecraft.server.NBTBase;
|
||||||
import net.minecraft.server.NBTTagCompound;
|
import net.minecraft.server.NBTTagCompound;
|
||||||
import net.minecraft.server.TileEntity;
|
import net.minecraft.server.TileEntity;
|
||||||
|
@ -335,6 +336,10 @@ public class CraftMetaBlockState extends CraftMetaItem implements BlockStateMeta
|
||||||
}
|
}
|
||||||
return new CraftBeacon(material, (TileEntityBeacon) te);
|
return new CraftBeacon(material, (TileEntityBeacon) te);
|
||||||
case SHIELD:
|
case SHIELD:
|
||||||
|
if (te == null) {
|
||||||
|
te = new TileEntityBanner();
|
||||||
|
}
|
||||||
|
((TileEntityBanner) te).color = (blockEntityTag == null) ? EnumColor.WHITE : EnumColor.fromColorIndex(blockEntityTag.getInt(CraftMetaBanner.BASE.NBT));
|
||||||
case BLACK_BANNER:
|
case BLACK_BANNER:
|
||||||
case BLACK_WALL_BANNER:
|
case BLACK_WALL_BANNER:
|
||||||
case BLUE_BANNER:
|
case BLUE_BANNER:
|
||||||
|
@ -370,7 +375,7 @@ public class CraftMetaBlockState extends CraftMetaItem implements BlockStateMeta
|
||||||
if (te == null) {
|
if (te == null) {
|
||||||
te = new TileEntityBanner();
|
te = new TileEntityBanner();
|
||||||
}
|
}
|
||||||
return new CraftBanner(material, (TileEntityBanner) te);
|
return new CraftBanner(material == Material.SHIELD ? shieldToBannerHack(blockEntityTag) : material, (TileEntityBanner) te);
|
||||||
case STRUCTURE_BLOCK:
|
case STRUCTURE_BLOCK:
|
||||||
if (te == null) {
|
if (te == null) {
|
||||||
te = new TileEntityStructure();
|
te = new TileEntityStructure();
|
||||||
|
@ -559,5 +564,52 @@ public class CraftMetaBlockState extends CraftMetaItem implements BlockStateMeta
|
||||||
Validate.isTrue(valid, "Invalid blockState for " + material);
|
Validate.isTrue(valid, "Invalid blockState for " + material);
|
||||||
|
|
||||||
blockEntityTag = ((CraftBlockEntityState) blockState).getSnapshotNBT();
|
blockEntityTag = ((CraftBlockEntityState) blockState).getSnapshotNBT();
|
||||||
|
// Set shield base
|
||||||
|
if (material == Material.SHIELD) {
|
||||||
|
blockEntityTag.setInt(CraftMetaBanner.BASE.NBT, ((CraftBanner) blockState).getBaseColor().getWoolData());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Material shieldToBannerHack(NBTTagCompound tag) {
|
||||||
|
if (tag == null || !tag.hasKeyOfType(CraftMetaBanner.BASE.NBT, CraftMagicNumbers.NBT.TAG_INT)) {
|
||||||
|
return Material.WHITE_BANNER;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (tag.getInt(CraftMetaBanner.BASE.NBT)) {
|
||||||
|
case 0:
|
||||||
|
return Material.WHITE_BANNER;
|
||||||
|
case 1:
|
||||||
|
return Material.ORANGE_BANNER;
|
||||||
|
case 2:
|
||||||
|
return Material.MAGENTA_BANNER;
|
||||||
|
case 3:
|
||||||
|
return Material.LIGHT_BLUE_BANNER;
|
||||||
|
case 4:
|
||||||
|
return Material.YELLOW_BANNER;
|
||||||
|
case 5:
|
||||||
|
return Material.LIME_BANNER;
|
||||||
|
case 6:
|
||||||
|
return Material.PINK_BANNER;
|
||||||
|
case 7:
|
||||||
|
return Material.GRAY_BANNER;
|
||||||
|
case 8:
|
||||||
|
return Material.LIGHT_GRAY_BANNER;
|
||||||
|
case 9:
|
||||||
|
return Material.CYAN_BANNER;
|
||||||
|
case 10:
|
||||||
|
return Material.PURPLE_BANNER;
|
||||||
|
case 11:
|
||||||
|
return Material.BLUE_BANNER;
|
||||||
|
case 12:
|
||||||
|
return Material.BROWN_BANNER;
|
||||||
|
case 13:
|
||||||
|
return Material.GREEN_BANNER;
|
||||||
|
case 14:
|
||||||
|
return Material.RED_BANNER;
|
||||||
|
case 15:
|
||||||
|
return Material.BLACK_BANNER;
|
||||||
|
default:
|
||||||
|
throw new IllegalArgumentException("Unknown banner colour");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue