Merge pull request #87 from GeyserMC/feature/1.13-bedrock

1.13 Support
This commit is contained in:
Redned 2019-11-27 10:09:58 -06:00 committed by GitHub
commit 2e90759f40
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
26 changed files with 1062 additions and 17026 deletions

View file

@ -74,8 +74,8 @@
</dependency> </dependency>
<dependency> <dependency>
<groupId>com.nukkitx.protocol</groupId> <groupId>com.nukkitx.protocol</groupId>
<artifactId>bedrock-v361</artifactId> <artifactId>bedrock-v388</artifactId>
<version>2.3.0</version> <version>2.4.0</version>
<scope>compile</scope> <scope>compile</scope>
</dependency> </dependency>
<dependency> <dependency>

View file

@ -27,7 +27,8 @@ package org.geysermc.connector;
import com.nukkitx.protocol.bedrock.BedrockPacketCodec; import com.nukkitx.protocol.bedrock.BedrockPacketCodec;
import com.nukkitx.protocol.bedrock.BedrockServer; import com.nukkitx.protocol.bedrock.BedrockServer;
import com.nukkitx.protocol.bedrock.v361.Bedrock_v361; import com.nukkitx.protocol.bedrock.v388.Bedrock_v388;
import lombok.Getter; import lombok.Getter;
import org.fusesource.jansi.AnsiConsole; import org.fusesource.jansi.AnsiConsole;
import org.geysermc.api.Connector; import org.geysermc.api.Connector;
@ -55,7 +56,6 @@ import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.net.InetSocketAddress; import java.net.InetSocketAddress;
import java.text.DecimalFormat; import java.text.DecimalFormat;
import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
@ -67,7 +67,7 @@ import java.util.concurrent.TimeUnit;
@Getter @Getter
public class GeyserConnector implements Connector { public class GeyserConnector implements Connector {
public static final BedrockPacketCodec BEDROCK_PACKET_CODEC = Bedrock_v361.V361_CODEC; public static final BedrockPacketCodec BEDROCK_PACKET_CODEC = Bedrock_v388.V388_CODEC;
public static final String NAME = "Geyser"; public static final String NAME = "Geyser";
public static final String VERSION = "1.0-SNAPSHOT"; public static final String VERSION = "1.0-SNAPSHOT";
@ -97,7 +97,6 @@ public class GeyserConnector implements Connector {
} }
private GeyserConnector() { private GeyserConnector() {
long startupTime = System.currentTimeMillis(); long startupTime = System.currentTimeMillis();
// Metric // Metric
@ -117,7 +116,6 @@ public class GeyserConnector implements Connector {
try { try {
File configFile = FileUtils.fileOrCopiedFromResource("config.yml", (x) -> x.replaceAll("generateduuid", UUID.randomUUID().toString())); File configFile = FileUtils.fileOrCopiedFromResource("config.yml", (x) -> x.replaceAll("generateduuid", UUID.randomUUID().toString()));
config = FileUtils.loadConfig(configFile, GeyserConfiguration.class); config = FileUtils.loadConfig(configFile, GeyserConfiguration.class);
} catch (IOException ex) { } catch (IOException ex) {
logger.severe("Failed to read/create config.yml! Make sure it's up to date and/or readable+writable!", ex); logger.severe("Failed to read/create config.yml! Make sure it's up to date and/or readable+writable!", ex);
@ -130,6 +128,7 @@ public class GeyserConnector implements Connector {
logger.setDebug(config.isDebugMode()); logger.setDebug(config.isDebugMode());
Toolbox.init();
TranslatorsInit.start(); TranslatorsInit.start();
commandMap = new GeyserCommandMap(this); commandMap = new GeyserCommandMap(this);

View file

@ -90,55 +90,40 @@ public class GeyserLogger implements org.geysermc.api.logger.Logger {
@Override @Override
public void severe(String message) { public void severe(String message) {
waitFor();
System.out.println(printConsole(ChatColor.DARK_RED + message, colored)); System.out.println(printConsole(ChatColor.DARK_RED + message, colored));
} }
@Override @Override
public void severe(String message, Throwable error) { public void severe(String message, Throwable error) {
waitFor();
System.out.println(printConsole(ChatColor.DARK_RED + message + "\n" + error.getMessage(), colored)); System.out.println(printConsole(ChatColor.DARK_RED + message + "\n" + error.getMessage(), colored));
} }
@Override @Override
public void error(String message) { public void error(String message) {
waitFor();
System.out.println(printConsole(ChatColor.RED + message, colored)); System.out.println(printConsole(ChatColor.RED + message, colored));
} }
@Override @Override
public void error(String message, Throwable error) { public void error(String message, Throwable error) {
waitFor();
System.out.println(printConsole(ChatColor.RED + message + "\n" + error, colored)); System.out.println(printConsole(ChatColor.RED + message + "\n" + error, colored));
} }
@Override @Override
public void warning(String message) { public void warning(String message) {
waitFor();
System.out.println(printConsole(ChatColor.YELLOW + message, colored)); System.out.println(printConsole(ChatColor.YELLOW + message, colored));
} }
@Override @Override
public void info(String message) { public void info(String message) {
waitFor();
System.out.println(printConsole(ChatColor.WHITE + message, colored)); System.out.println(printConsole(ChatColor.WHITE + message, colored));
} }
@Override @Override
public void debug(String message) { public void debug(String message) {
waitFor();
if (debug) if (debug)
System.out.println(printConsole(ChatColor.GRAY + message, colored)); System.out.println(printConsole(ChatColor.GRAY + message, colored));
} }
private synchronized void waitFor() {
}
public void stop() {
}
public static String printConsole(String message, boolean colors) { public static String printConsole(String message, boolean colors) {
return colors ? ChatColor.toANSI(message + ChatColor.RESET) : ChatColor.stripColors(message + ChatColor.RESET); return colors ? ChatColor.toANSI(message + ChatColor.RESET) : ChatColor.stripColors(message + ChatColor.RESET);
} }

View file

@ -87,13 +87,13 @@ public enum EntityType {
TRIPOD_CAMERA(62, 0f), TRIPOD_CAMERA(62, 0f),
PLAYER(63, 1.8f, 0.6f, 0.6f, 1.62f), PLAYER(63, 1.8f, 0.6f, 0.6f, 1.62f),
ITEM(64, 0.25f, 0.25f), ITEM(64, 0.25f, 0.25f),
PRIMED_TNT(65, 0.98f, 0.98f), TNT(65, 0.98f, 0.98f),
FALLING_BLOCK(66, 0.98f, 0.98f), FALLING_BLOCK(66, 0.98f, 0.98f),
MOVING_BLOCK(67, 0f), MOVING_BLOCK(67, 0f),
EXPERIENCE_BOTTLE(68, 0.25f, 0.25f), EXPERIENCE_BOTTLE(68, 0.25f, 0.25f),
EXPERIENCE_ORB(69, 0f), EXPERIENCE_ORB(69, 0f),
EYE_OF_ENDER(70, 0f), EYE_OF_ENDER(70, 0f),
ENDER_CRYSTAL(71, 0f), END_CRYSTAL(71, 0f),
FIREWORK_ROCKET(72, 0f), FIREWORK_ROCKET(72, 0f),
TRIDENT(73, 0f), TRIDENT(73, 0f),
TURTLE(74, 0.4f, 1.2f), TURTLE(74, 0.4f, 1.2f),
@ -108,7 +108,7 @@ public enum EntityType {
EGG(82, 0f), EGG(82, 0f),
PAINTING(83, 0f), PAINTING(83, 0f),
MINECART(84, 0f), MINECART(84, 0f),
LARGE_FIREBALL(85, 0f), FIREBALL(85, 0f),
SPLASH_POTION(86, 0f), SPLASH_POTION(86, 0f),
ENDER_PEARL(87, 0f), ENDER_PEARL(87, 0f),
LEASH_KNOT(88, 0f), LEASH_KNOT(88, 0f),
@ -135,7 +135,8 @@ public enum EntityType {
DROWNED(110, 1.95f, 0.6f), DROWNED(110, 1.95f, 0.6f),
TROPICAL_FISH(111, 0.6f, 0.6f), TROPICAL_FISH(111, 0.6f, 0.6f),
COD(112, 0.25f, 0.5f), COD(112, 0.25f, 0.5f),
PANDA(113, 1.25f, 1.125f, 1.825f); PANDA(113, 1.25f, 1.125f, 1.825f),
FOX(121, 0.5f, 1.25f);
private final int type; private final int type;
private final float height; private final float height;

View file

@ -55,48 +55,45 @@ public class ConnectorServerEventHandler implements BedrockServerEventHandler {
@Override @Override
public BedrockPong onQuery(InetSocketAddress inetSocketAddress) { public BedrockPong onQuery(InetSocketAddress inetSocketAddress) {
PingEvent pong = new PingEvent(inetSocketAddress);
GeyserLogger.DEFAULT.debug(inetSocketAddress + " has pinged you!"); GeyserLogger.DEFAULT.debug(inetSocketAddress + " has pinged you!");
GeyserConfiguration config = connector.getConfig(); GeyserConfiguration config = connector.getConfig();
pong.setEdition("MCPE"); PingEvent pongEvent = new PingEvent(inetSocketAddress);
pong.setGameType("Default"); pongEvent.setEdition("MCPE");
pong.setNintendoLimited(false); pongEvent.setGameType("Default");
pong.setProtocolVersion(GeyserConnector.BEDROCK_PACKET_CODEC.getProtocolVersion()); pongEvent.setNintendoLimited(false);
pong.setVersion("1.12.0"); pongEvent.setProtocolVersion(GeyserConnector.BEDROCK_PACKET_CODEC.getProtocolVersion());
pongEvent.setVersion(GeyserConnector.BEDROCK_PACKET_CODEC.getMinecraftVersion());
connector.getPluginManager().runEvent(pong); connector.getPluginManager().runEvent(pongEvent);
if (connector.getConfig().isPingPassthrough()) { if (connector.getConfig().isPingPassthrough()) {
ServerStatusInfo serverInfo = connector.getPassthroughThread().getInfo(); ServerStatusInfo serverInfo = connector.getPassthroughThread().getInfo();
if (serverInfo != null) { if (serverInfo != null) {
pong.setMotd(MessageUtils.getBedrockMessage(serverInfo.getDescription())); pongEvent.setMotd(MessageUtils.getBedrockMessage(serverInfo.getDescription()));
pong.setSubMotd(config.getBedrock().getMotd2()); pongEvent.setSubMotd(config.getBedrock().getMotd2());
pong.setPlayerCount(serverInfo.getPlayerInfo().getOnlinePlayers()); pongEvent.setPlayerCount(serverInfo.getPlayerInfo().getOnlinePlayers());
pong.setMaximumPlayerCount(serverInfo.getPlayerInfo().getMaxPlayers()); pongEvent.setMaximumPlayerCount(serverInfo.getPlayerInfo().getMaxPlayers());
} }
} else { } else {
pong.setPlayerCount(1); pongEvent.setPlayerCount(1);
pong.setMaximumPlayerCount(config.getMaxPlayers()); pongEvent.setMaximumPlayerCount(config.getMaxPlayers());
pong.setMotd(config.getBedrock().getMotd1()); pongEvent.setMotd(config.getBedrock().getMotd1());
pong.setSubMotd(config.getBedrock().getMotd2()); pongEvent.setSubMotd(config.getBedrock().getMotd2());
} }
BedrockPong c = new BedrockPong(); BedrockPong pong = new BedrockPong();
pong.setEdition(pongEvent.getEdition());
c.setEdition(pong.getEdition()); pong.setGameType(pongEvent.getGameType());
c.setGameType(pong.getGameType()); pong.setNintendoLimited(pongEvent.isNintendoLimited());
c.setNintendoLimited(pong.isNintendoLimited()); pong.setProtocolVersion(pongEvent.getProtocolVersion());
c.setProtocolVersion(pong.getProtocolVersion()); pong.setVersion(pongEvent.getVersion());
c.setVersion(pong.getVersion()); pong.setMotd(pongEvent.getMotd());
pong.setSubMotd(pongEvent.getSubMotd());
c.setMotd(pong.getMotd()); pong.setPlayerCount(pongEvent.getPlayerCount());
c.setSubMotd(pong.getSubMotd()); pong.setMaximumPlayerCount(pongEvent.getMaximumPlayerCount());
c.setPlayerCount(pong.getPlayerCount()); pong.setIpv4Port(config.getBedrock().getPort());
c.setMaximumPlayerCount(pong.getMaximumPlayerCount());
c.setIpv4Port(config.getBedrock().getPort());
return c;
return pong;
} }
@Override @Override

View file

@ -716,4 +716,49 @@ public class LoggingPacketHandler implements BedrockPacketHandler {
public boolean handle(VideoStreamConnectPacket packet) { public boolean handle(VideoStreamConnectPacket packet) {
return defaultHandler(packet); return defaultHandler(packet);
} }
@Override
public boolean handle(EmotePacket packet) {
return defaultHandler(packet);
}
@Override
public boolean handle(TickSyncPacket packet) {
return defaultHandler(packet);
}
@Override
public boolean handle(AnvilDamagePacket packet) {
return defaultHandler(packet);
}
@Override
public boolean handle(NetworkSettingsPacket packet) {
return defaultHandler(packet);
}
@Override
public boolean handle(PlayerAuthInputPacket packet) {
return defaultHandler(packet);
}
@Override
public boolean handle(SettingsCommandPacket packet) {
return defaultHandler(packet);
}
@Override
public boolean handle(EducationSettingsPacket packet) {
return defaultHandler(packet);
}
@Override
public boolean handle(CompletedUsingItemPacket packet) {
return defaultHandler(packet);
}
@Override
public boolean handle(MultiplayerSettingsPacket packet) {
return defaultHandler(packet);
}
} }

View file

@ -45,7 +45,6 @@ public class UpstreamPacketHandler extends LoggingPacketHandler {
@Override @Override
public boolean handle(LoginPacket loginPacket) { public boolean handle(LoginPacket loginPacket) {
// TODO: Implement support for multiple protocols
if (loginPacket.getProtocolVersion() != GeyserConnector.BEDROCK_PACKET_CODEC.getProtocolVersion()) { if (loginPacket.getProtocolVersion() != GeyserConnector.BEDROCK_PACKET_CODEC.getProtocolVersion()) {
connector.getLogger().debug("unsupported"); connector.getLogger().debug("unsupported");
session.getUpstream().disconnect("Unsupported Bedrock version. Are you running an outdated version?"); session.getUpstream().disconnect("Unsupported Bedrock version. Are you running an outdated version?");
@ -56,16 +55,16 @@ public class UpstreamPacketHandler extends LoggingPacketHandler {
PlayStatusPacket playStatus = new PlayStatusPacket(); PlayStatusPacket playStatus = new PlayStatusPacket();
playStatus.setStatus(PlayStatusPacket.Status.LOGIN_SUCCESS); playStatus.setStatus(PlayStatusPacket.Status.LOGIN_SUCCESS);
session.getUpstream().sendPacketImmediately(playStatus); session.getUpstream().sendPacket(playStatus);
ResourcePacksInfoPacket resourcePacksInfo = new ResourcePacksInfoPacket(); ResourcePacksInfoPacket resourcePacksInfo = new ResourcePacksInfoPacket();
session.getUpstream().sendPacketImmediately(resourcePacksInfo); session.getUpstream().sendPacket(resourcePacksInfo);
return true; return true;
} }
@Override @Override
public boolean handle(ResourcePackClientResponsePacket textPacket) { public boolean handle(ResourcePackClientResponsePacket packet) {
switch (textPacket.getStatus()) { switch (packet.getStatus()) {
case COMPLETED: case COMPLETED:
session.connect(connector.getRemoteServer()); session.connect(connector.getRemoteServer());
connector.getLogger().info("Player connected with username " + session.getAuthenticationData().getName()); connector.getLogger().info("Player connected with username " + session.getAuthenticationData().getName());
@ -74,7 +73,8 @@ public class UpstreamPacketHandler extends LoggingPacketHandler {
ResourcePackStackPacket stack = new ResourcePackStackPacket(); ResourcePackStackPacket stack = new ResourcePackStackPacket();
stack.setExperimental(false); stack.setExperimental(false);
stack.setForcedToAccept(false); stack.setForcedToAccept(false);
session.getUpstream().sendPacketImmediately(stack); stack.setGameVersion(GeyserConnector.BEDROCK_PACKET_CODEC.getMinecraftVersion());
session.getUpstream().sendPacket(stack);
break; break;
default: default:
session.getUpstream().disconnect("disconnectionScreen.resourcePack"); session.getUpstream().disconnect("disconnectionScreen.resourcePack");

View file

@ -29,7 +29,6 @@ import com.github.steveice10.mc.auth.data.GameProfile;
import com.github.steveice10.mc.auth.exception.request.RequestException; import com.github.steveice10.mc.auth.exception.request.RequestException;
import com.github.steveice10.mc.protocol.MinecraftProtocol; import com.github.steveice10.mc.protocol.MinecraftProtocol;
import com.github.steveice10.mc.protocol.data.game.entity.player.GameMode; import com.github.steveice10.mc.protocol.data.game.entity.player.GameMode;
import com.github.steveice10.mc.protocol.data.game.world.block.BlockFace;
import com.github.steveice10.packetlib.Client; import com.github.steveice10.packetlib.Client;
import com.github.steveice10.packetlib.event.session.ConnectedEvent; import com.github.steveice10.packetlib.event.session.ConnectedEvent;
import com.github.steveice10.packetlib.event.session.DisconnectedEvent; import com.github.steveice10.packetlib.event.session.DisconnectedEvent;
@ -41,9 +40,14 @@ import com.nukkitx.math.vector.Vector2f;
import com.nukkitx.math.vector.Vector2i; import com.nukkitx.math.vector.Vector2i;
import com.nukkitx.math.vector.Vector3f; import com.nukkitx.math.vector.Vector3f;
import com.nukkitx.math.vector.Vector3i; import com.nukkitx.math.vector.Vector3i;
import com.nukkitx.nbt.tag.CompoundTag;
import com.nukkitx.protocol.bedrock.BedrockServerSession; import com.nukkitx.protocol.bedrock.BedrockServerSession;
import com.nukkitx.protocol.bedrock.data.GamePublishSetting; import com.nukkitx.protocol.bedrock.data.GamePublishSetting;
import com.nukkitx.protocol.bedrock.data.GameRule; import com.nukkitx.protocol.bedrock.data.GameRule;
import com.nukkitx.protocol.bedrock.packet.AvailableEntityIdentifiersPacket;
import com.nukkitx.protocol.bedrock.packet.BiomeDefinitionListPacket;
import com.nukkitx.protocol.bedrock.packet.LevelChunkPacket;
import com.nukkitx.protocol.bedrock.packet.NetworkChunkPublisherUpdatePacket;
import com.nukkitx.protocol.bedrock.packet.PlayStatusPacket; import com.nukkitx.protocol.bedrock.packet.PlayStatusPacket;
import com.nukkitx.protocol.bedrock.packet.StartGamePacket; import com.nukkitx.protocol.bedrock.packet.StartGamePacket;
import com.nukkitx.protocol.bedrock.packet.TextPacket; import com.nukkitx.protocol.bedrock.packet.TextPacket;
@ -58,6 +62,7 @@ import org.geysermc.connector.entity.PlayerEntity;
import org.geysermc.connector.inventory.PlayerInventory; import org.geysermc.connector.inventory.PlayerInventory;
import org.geysermc.connector.network.session.cache.*; import org.geysermc.connector.network.session.cache.*;
import org.geysermc.connector.network.translators.Registry; import org.geysermc.connector.network.translators.Registry;
import org.geysermc.connector.network.translators.TranslatorsInit;
import org.geysermc.connector.utils.Toolbox; import org.geysermc.connector.utils.Toolbox;
import java.net.InetSocketAddress; import java.net.InetSocketAddress;
@ -120,14 +125,39 @@ public class GeyserSession implements Player {
} }
public void connect(RemoteServer remoteServer) { public void connect(RemoteServer remoteServer) {
// This has to be sent first so the player actually joins
startGame(); startGame();
this.remoteServer = remoteServer; this.remoteServer = remoteServer;
if (!(connector.getConfig().getRemote().getAuthType().hashCode() == "online".hashCode())) { if (!(connector.getConfig().getRemote().getAuthType().hashCode() == "online".hashCode())) {
connector.getLogger().info("Attempting to login using offline mode... authentication is disabled."); connector.getLogger().info("Attempting to login using offline mode... authentication is disabled.");
authenticate(authenticationData.getName()); authenticate(authenticationData.getName());
} }
Vector3f pos = Vector3f.ZERO;
int chunkX = pos.getFloorX() >> 4;
int chunkZ = pos.getFloorZ() >> 4;
NetworkChunkPublisherUpdatePacket chunkPublisherUpdatePacket = new NetworkChunkPublisherUpdatePacket();
chunkPublisherUpdatePacket.setPosition(pos.toInt());
chunkPublisherUpdatePacket.setRadius(renderDistance << 4);
upstream.sendPacket(chunkPublisherUpdatePacket);
LevelChunkPacket data = new LevelChunkPacket();
data.setChunkX(chunkX);
data.setChunkZ(chunkZ);
data.setSubChunksLength(0);
data.setData(TranslatorsInit.EMPTY_LEVEL_CHUNK_DATA);
upstream.sendPacket(data);
BiomeDefinitionListPacket biomePacket = new BiomeDefinitionListPacket();
biomePacket.setTag(CompoundTag.EMPTY);
upstream.sendPacket(biomePacket);
AvailableEntityIdentifiersPacket entityPacket = new AvailableEntityIdentifiersPacket();
entityPacket.setTag(CompoundTag.EMPTY);
upstream.sendPacket(entityPacket);
PlayStatusPacket playStatusPacket = new PlayStatusPacket();
playStatusPacket.setStatus(PlayStatusPacket.Status.PLAYER_SPAWN);
upstream.sendPacket(playStatusPacket);
} }
public void authenticate(String username) { public void authenticate(String username) {
@ -259,15 +289,15 @@ public class GeyserSession implements Player {
startGamePacket.setPlayerPosition(Vector3f.from(0, 69, 0)); startGamePacket.setPlayerPosition(Vector3f.from(0, 69, 0));
startGamePacket.setRotation(Vector2f.from(1, 1)); startGamePacket.setRotation(Vector2f.from(1, 1));
startGamePacket.setSeed(0); startGamePacket.setSeed(-1);
startGamePacket.setDimensionId(playerEntity.getDimension()); startGamePacket.setDimensionId(playerEntity.getDimension());
startGamePacket.setGeneratorId(1); startGamePacket.setGeneratorId(1);
startGamePacket.setLevelGamemode(0); startGamePacket.setLevelGamemode(0);
startGamePacket.setDifficulty(1); startGamePacket.setDifficulty(1);
startGamePacket.setDefaultSpawn(Vector3i.ZERO); startGamePacket.setDefaultSpawn(Vector3i.ZERO);
startGamePacket.setAcheivementsDisabled(true); startGamePacket.setAcheivementsDisabled(true);
startGamePacket.setTime(0); startGamePacket.setTime(-1);
startGamePacket.setEduLevel(false); startGamePacket.setEduEditionOffers(0);
startGamePacket.setEduFeaturesEnabled(false); startGamePacket.setEduFeaturesEnabled(false);
startGamePacket.setRainLevel(0); startGamePacket.setRainLevel(0);
startGamePacket.setLightningLevel(0); startGamePacket.setLightningLevel(0);
@ -293,15 +323,13 @@ public class GeyserSession implements Player {
startGamePacket.setLevelId("world"); startGamePacket.setLevelId("world");
startGamePacket.setWorldName("world"); startGamePacket.setWorldName("world");
startGamePacket.setPremiumWorldTemplateId("00000000-0000-0000-0000-000000000000"); startGamePacket.setPremiumWorldTemplateId("00000000-0000-0000-0000-000000000000");
startGamePacket.setCurrentTick(0); // startGamePacket.setCurrentTick(0);
startGamePacket.setEnchantmentSeed(0); startGamePacket.setEnchantmentSeed(0);
startGamePacket.setMultiplayerCorrelationId(""); startGamePacket.setMultiplayerCorrelationId("");
startGamePacket.setCachedPalette(Toolbox.CACHED_PALLETE.retainedDuplicate()); startGamePacket.setBlockPalette(Toolbox.BLOCKS);
startGamePacket.setItemEntries(Toolbox.ITEMS); startGamePacket.setItemEntries(Toolbox.ITEMS);
startGamePacket.setVanillaVersion(GeyserConnector.BEDROCK_PACKET_CODEC.getMinecraftVersion());
// startGamePacket.setMovementServerAuthoritative(true);
upstream.sendPacket(startGamePacket); upstream.sendPacket(startGamePacket);
PlayStatusPacket playStatusPacket = new PlayStatusPacket();
playStatusPacket.setStatus(PlayStatusPacket.Status.PLAYER_SPAWN);
upstream.sendPacket(playStatusPacket);
} }
} }

View file

@ -15,7 +15,6 @@ public class BedrockPlayerInitializedTranslator extends PacketTranslator<SetLoca
for (PlayerEntity entity : session.getEntityCache().getEntitiesByType(PlayerEntity.class)) { for (PlayerEntity entity : session.getEntityCache().getEntitiesByType(PlayerEntity.class)) {
if (!entity.isValid()) { if (!entity.isValid()) {
entity.sendPlayer(session);
// async skin loading // async skin loading
SkinUtils.requestAndHandleSkinAndCape(entity, session, skinAndCape -> entity.sendPlayer(session)); SkinUtils.requestAndHandleSkinAndCape(entity, session, skinAndCape -> entity.sendPlayer(session));
} }

View file

@ -26,10 +26,17 @@
package org.geysermc.connector.network.translators.java; package org.geysermc.connector.network.translators.java;
import com.github.steveice10.mc.protocol.packet.ingame.server.ServerJoinGamePacket; import com.github.steveice10.mc.protocol.packet.ingame.server.ServerJoinGamePacket;
import com.nukkitx.protocol.bedrock.packet.*; import com.nukkitx.math.vector.Vector3i;
import com.nukkitx.protocol.bedrock.packet.AdventureSettingsPacket;
import com.nukkitx.protocol.bedrock.packet.ChunkRadiusUpdatedPacket;
import com.nukkitx.protocol.bedrock.packet.PlayStatusPacket;
import com.nukkitx.protocol.bedrock.packet.SetEntityDataPacket;
import com.nukkitx.protocol.bedrock.packet.SetPlayerGameTypePacket;
import org.geysermc.connector.entity.PlayerEntity; import org.geysermc.connector.entity.PlayerEntity;
import org.geysermc.connector.network.session.GeyserSession; import org.geysermc.connector.network.session.GeyserSession;
import org.geysermc.connector.network.translators.PacketTranslator; import org.geysermc.connector.network.translators.PacketTranslator;
import org.geysermc.connector.world.chunk.ChunkPosition;
public class JavaJoinGameTranslator extends PacketTranslator<ServerJoinGamePacket> { public class JavaJoinGameTranslator extends PacketTranslator<ServerJoinGamePacket> {
@ -38,16 +45,14 @@ public class JavaJoinGameTranslator extends PacketTranslator<ServerJoinGamePacke
AdventureSettingsPacket bedrockPacket = new AdventureSettingsPacket(); AdventureSettingsPacket bedrockPacket = new AdventureSettingsPacket();
bedrockPacket.setUniqueEntityId(session.getPlayerEntity().getGeyserId()); bedrockPacket.setUniqueEntityId(session.getPlayerEntity().getGeyserId());
bedrockPacket.setPlayerPermission(1); bedrockPacket.setPlayerPermission(1);
session.getUpstream().sendPacketImmediately(bedrockPacket); session.getUpstream().sendPacket(bedrockPacket);
PlayStatusPacket playStatus = new PlayStatusPacket(); PlayStatusPacket playStatus = new PlayStatusPacket();
playStatus.setStatus(PlayStatusPacket.Status.LOGIN_SUCCESS); playStatus.setStatus(PlayStatusPacket.Status.LOGIN_SUCCESS);
session.getUpstream().sendPacketImmediately(playStatus); // session.getUpstream().sendPacket(playStatus);
PlayerEntity entity = session.getPlayerEntity(); PlayerEntity entity = session.getPlayerEntity();
if (entity == null) return; entity.setEntityId(packet.getEntityId());
session.getPlayerEntity().setEntityId(packet.getEntityId());
SetPlayerGameTypePacket playerGameTypePacket = new SetPlayerGameTypePacket(); SetPlayerGameTypePacket playerGameTypePacket = new SetPlayerGameTypePacket();
playerGameTypePacket.setGamemode(packet.getGameMode().ordinal()); playerGameTypePacket.setGamemode(packet.getGameMode().ordinal());
@ -62,9 +67,9 @@ public class JavaJoinGameTranslator extends PacketTranslator<ServerJoinGamePacke
session.setRenderDistance(packet.getViewDistance() + 1); // +1 to be sure it includes every chunk session.setRenderDistance(packet.getViewDistance() + 1); // +1 to be sure it includes every chunk
if (session.getRenderDistance() > 32) session.setRenderDistance(32); // <3 u ViaVersion but I don't like crashing clients x) if (session.getRenderDistance() > 32) session.setRenderDistance(32); // <3 u ViaVersion but I don't like crashing clients x)
ChunkRadiusUpdatedPacket packet1 = new ChunkRadiusUpdatedPacket(); ChunkRadiusUpdatedPacket chunkRadiusPacket = new ChunkRadiusUpdatedPacket();
packet1.setRadius(session.getRenderDistance()); chunkRadiusPacket.setRadius(session.getRenderDistance());
session.getUpstream().sendPacket(packet1); session.getUpstream().sendPacket(chunkRadiusPacket);
session.setSpawned(true); session.setSpawned(true);
} }

View file

@ -57,9 +57,11 @@ public class JavaRespawnTranslator extends PacketTranslator<ServerRespawnPacket>
session.getUpstream().sendPacket(playerGameTypePacket); session.getUpstream().sendPacket(playerGameTypePacket);
session.setGameMode(packet.getGamemode()); session.setGameMode(packet.getGamemode());
/*
PlayStatusPacket playStatusPacket = new PlayStatusPacket(); PlayStatusPacket playStatusPacket = new PlayStatusPacket();
playStatusPacket.setStatus(PlayStatusPacket.Status.PLAYER_SPAWN); playStatusPacket.setStatus(PlayStatusPacket.Status.PLAYER_SPAWN);
session.getUpstream().sendPacket(playStatusPacket); session.getUpstream().sendPacket(playStatusPacket);
*/
} }
private int getDimension(int javaDimension) { private int getDimension(int javaDimension) {

View file

@ -61,8 +61,10 @@ public class JavaPlayerHealthTranslator extends PacketTranslator<ServerPlayerHea
if (packet.getHealth() <= 0) { if (packet.getHealth() <= 0) {
RespawnPacket respawnPacket = new RespawnPacket(); RespawnPacket respawnPacket = new RespawnPacket();
respawnPacket.setRuntimeEntityId(entity.getGeyserId());
respawnPacket.setPosition(Vector3f.from(0, 72, 0)); respawnPacket.setPosition(Vector3f.from(0, 72, 0));
session.getUpstream().sendPacket(new RespawnPacket()); respawnPacket.setSpawnState(RespawnPacket.State.SERVER_SEARCHING);
session.getUpstream().sendPacket(respawnPacket);
ClientRequestPacket javaRespawnPacket = new ClientRequestPacket(ClientRequest.RESPAWN); ClientRequestPacket javaRespawnPacket = new ClientRequestPacket(ClientRequest.RESPAWN);
session.getDownstream().getSession().send(javaRespawnPacket); session.getDownstream().getSession().send(javaRespawnPacket);

View file

@ -51,8 +51,9 @@ public class JavaSpawnPlayerTranslator extends PacketTranslator<ServerSpawnPlaye
entity.setPosition(position); entity.setPosition(position);
entity.setRotation(rotation); entity.setRotation(rotation);
entity.sendPlayer(session);
// async skin loading // async skin loading
SkinUtils.requestAndHandleSkinAndCape(entity, session, skinAndCape -> entity.sendPlayer(session)); if (session.getUpstream().isInitialized()) {
SkinUtils.requestAndHandleSkinAndCape(entity, session, skinAndCape -> entity.sendPlayer(session));
}
} }
} }

View file

@ -1,12 +0,0 @@
package org.geysermc.connector.utils;
import lombok.AccessLevel;
import lombok.AllArgsConstructor;
import lombok.Getter;
@AllArgsConstructor(access = AccessLevel.PUBLIC)
@Getter
public class BiValue<F, S> {
private F f;
private S s;
}

View file

@ -19,10 +19,10 @@ public class ProvidedSkin {
for (int y = 0; y < image.getHeight(); y++) { for (int y = 0; y < image.getHeight(); y++) {
for (int x = 0; x < image.getWidth(); x++) { for (int x = 0; x < image.getWidth(); x++) {
int rgba = image.getRGB(x, y); int rgba = image.getRGB(x, y);
outputStream.write((rgba >> 16) & 0xFF); outputStream.write((rgba >> 16) & 0xFF); // Red
outputStream.write((rgba >> 8) & 0xFF); outputStream.write((rgba >> 8) & 0xFF); // Green
outputStream.write(rgba & 0xFF); outputStream.write(rgba & 0xFF); // Blue
outputStream.write((rgba >> 24) & 0xFF); outputStream.write((rgba >> 24) & 0xFF); // Alpha
} }
} }
image.flush(); image.flush();

View file

@ -22,12 +22,12 @@ public class SkinProvider {
public static final boolean ALLOW_THIRD_PARTY_CAPES = ((GeyserConnector)Geyser.getConnector()).getConfig().isAllowThirdPartyCapes(); public static final boolean ALLOW_THIRD_PARTY_CAPES = ((GeyserConnector)Geyser.getConnector()).getConfig().isAllowThirdPartyCapes();
private static final ExecutorService EXECUTOR_SERVICE = Executors.newFixedThreadPool(ALLOW_THIRD_PARTY_CAPES ? 21 : 14); private static final ExecutorService EXECUTOR_SERVICE = Executors.newFixedThreadPool(ALLOW_THIRD_PARTY_CAPES ? 21 : 14);
public static final Skin EMPTY_SKIN = new Skin(-1, "");
public static final byte[] STEVE_SKIN = new ProvidedSkin("bedrock/skin/skin_steve.png").getSkin(); public static final byte[] STEVE_SKIN = new ProvidedSkin("bedrock/skin/skin_steve.png").getSkin();
public static final Skin EMPTY_SKIN = new Skin(-1, "steve", STEVE_SKIN);
private static Map<UUID, Skin> cachedSkins = new ConcurrentHashMap<>(); private static Map<UUID, Skin> cachedSkins = new ConcurrentHashMap<>();
private static Map<UUID, CompletableFuture<Skin>> requestedSkins = new ConcurrentHashMap<>(); private static Map<UUID, CompletableFuture<Skin>> requestedSkins = new ConcurrentHashMap<>();
public static final Cape EMPTY_CAPE = new Cape("", new byte[0], -1, true); public static final Cape EMPTY_CAPE = new Cape("", "no-cape", new byte[0], -1, true);
private static Map<String, Cape> cachedCapes = new ConcurrentHashMap<>(); private static Map<String, Cape> cachedCapes = new ConcurrentHashMap<>();
private static Map<String, CompletableFuture<Cape>> requestedCapes = new ConcurrentHashMap<>(); private static Map<String, CompletableFuture<Cape>> requestedCapes = new ConcurrentHashMap<>();
@ -149,8 +149,11 @@ public class SkinProvider {
cape = requestImage(capeUrl, true); cape = requestImage(capeUrl, true);
} catch (Exception ignored) {} // just ignore I guess } catch (Exception ignored) {} // just ignore I guess
String[] urlSection = capeUrl.split("/"); // A real url is expected at this stage
return new Cape( return new Cape(
capeUrl, capeUrl,
urlSection[urlSection.length - 1], // get the texture id and use it as cape id
cape.length > 0 ? cape : EMPTY_CAPE.getCapeData(), cape.length > 0 ? cape : EMPTY_CAPE.getCapeData(),
System.currentTimeMillis(), System.currentTimeMillis(),
cape.length == 0 cape.length == 0
@ -209,13 +212,14 @@ public class SkinProvider {
public static class Skin { public static class Skin {
private UUID skinOwner; private UUID skinOwner;
private String textureUrl; private String textureUrl;
private byte[] skinData = STEVE_SKIN; private byte[] skinData;
private long requestedOn; private long requestedOn;
private boolean updated; private boolean updated;
private Skin(long requestedOn, String textureUrl) { private Skin(long requestedOn, String textureUrl, byte[] skinData) {
this.requestedOn = requestedOn; this.requestedOn = requestedOn;
this.textureUrl = textureUrl; this.textureUrl = textureUrl;
this.skinData = skinData;
} }
} }
@ -223,6 +227,7 @@ public class SkinProvider {
@Getter @Getter
public static class Cape { public static class Cape {
private String textureUrl; private String textureUrl;
private String capeId;
private byte[] capeData; private byte[] capeData;
private long requestedOn; private long requestedOn;
private boolean failed; private boolean failed;

View file

@ -2,21 +2,26 @@ package org.geysermc.connector.utils;
import com.github.steveice10.mc.auth.data.GameProfile; import com.github.steveice10.mc.auth.data.GameProfile;
import com.google.gson.JsonObject; import com.google.gson.JsonObject;
import com.nukkitx.protocol.bedrock.data.ImageData;
import com.nukkitx.protocol.bedrock.data.SerializedSkin;
import com.nukkitx.protocol.bedrock.packet.PlayerListPacket; import com.nukkitx.protocol.bedrock.packet.PlayerListPacket;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
import lombok.Getter; import lombok.Getter;
import org.apache.commons.codec.Charsets; import org.apache.commons.codec.Charsets;
import org.geysermc.api.Geyser; import org.geysermc.api.Geyser;
import org.geysermc.connector.GeyserConnector;
import org.geysermc.connector.entity.PlayerEntity; import org.geysermc.connector.entity.PlayerEntity;
import org.geysermc.connector.network.session.GeyserSession; import org.geysermc.connector.network.session.GeyserSession;
import java.util.Base64; import java.util.Base64;
import java.util.Collections;
import java.util.UUID; import java.util.UUID;
import java.util.function.Consumer; import java.util.function.Consumer;
public class SkinUtils { public class SkinUtils {
public static PlayerListPacket.Entry buildCachedEntry(GameProfile profile, long geyserId) { public static PlayerListPacket.Entry buildCachedEntry(GameProfile profile, long geyserId) {
GameProfileData data = GameProfileData.from(profile); GameProfileData data = GameProfileData.from(profile);
SkinProvider.Cape cape = SkinProvider.getCachedCape(data.getCapeUrl());
return buildEntryManually( return buildEntryManually(
profile.getId(), profile.getId(),
@ -24,8 +29,9 @@ public class SkinUtils {
geyserId, geyserId,
profile.getIdAsString(), profile.getIdAsString(),
SkinProvider.getCachedSkin(profile.getId()).getSkinData(), SkinProvider.getCachedSkin(profile.getId()).getSkinData(),
SkinProvider.getCachedCape(data.getCapeUrl()).getCapeData(), cape.getCapeId(),
"geometry.humanoid.custom" + (data.isAlex() ? "Slim" : ""), cape.getCapeData(),
getLegacySkinGeometry("geometry.humanoid.custom" + (data.isAlex() ? "Slim" : "")),
"" ""
); );
} }
@ -37,25 +43,29 @@ public class SkinUtils {
geyserId, geyserId,
profile.getIdAsString(), profile.getIdAsString(),
SkinProvider.STEVE_SKIN, SkinProvider.STEVE_SKIN,
SkinProvider.EMPTY_CAPE.getCapeId(),
SkinProvider.EMPTY_CAPE.getCapeData(), SkinProvider.EMPTY_CAPE.getCapeData(),
"geometry.humanoid", getLegacySkinGeometry("geometry.humanoid"),
"" ""
); );
} }
public static PlayerListPacket.Entry buildEntryManually(UUID uuid, String username, long geyserId, public static PlayerListPacket.Entry buildEntryManually(UUID uuid, String username, long geyserId,
String skinId, byte[] skinData, byte[] capeData, String skinId, byte[] skinData,
String capeId, byte[] capeData,
String geometryName, String geometryData) { String geometryName, String geometryData) {
SerializedSkin serializedSkin = SerializedSkin.of(
skinId, geometryName, ImageData.of(skinData), Collections.emptyList(),
ImageData.of(capeData), geometryData, "", true, false, false, capeId, uuid.toString()
);
PlayerListPacket.Entry entry = new PlayerListPacket.Entry(uuid); PlayerListPacket.Entry entry = new PlayerListPacket.Entry(uuid);
entry.setName(username); entry.setName(username);
entry.setEntityId(geyserId); entry.setEntityId(geyserId);
entry.setSkinId(skinId); entry.setSkin(serializedSkin);
entry.setSkinData(skinData != null ? skinData : SkinProvider.STEVE_SKIN);
entry.setCapeData(capeData);
entry.setGeometryName(geometryName);
entry.setGeometryData(geometryData);
entry.setXuid(""); entry.setXuid("");
entry.setPlatformChatId(""); entry.setPlatformChatId("");
entry.setTeacher(false);
return entry; return entry;
} }
@ -86,8 +96,10 @@ public class SkinUtils {
return new GameProfileData(skinUrl, capeUrl, isAlex); return new GameProfileData(skinUrl, capeUrl, isAlex);
} catch (Exception exception) { } catch (Exception exception) {
if (!((GeyserConnector) Geyser.getConnector()).getConfig().getRemote().getAuthType().equals("offline")) {
Geyser.getLogger().debug("Got invalid texture data for " + profile.getName() + " " + exception.getMessage());
}
// return default skin with default cape when texture data is invalid // return default skin with default cape when texture data is invalid
Geyser.getLogger().debug("Got invalid texture data for " + profile.getName() + " " + exception.getMessage());
return new GameProfileData("", "", false); return new GameProfileData("", "", false);
} }
} }
@ -96,7 +108,7 @@ public class SkinUtils {
public static void requestAndHandleSkinAndCape(PlayerEntity entity, GeyserSession session, public static void requestAndHandleSkinAndCape(PlayerEntity entity, GeyserSession session,
Consumer<SkinProvider.SkinAndCape> skinAndCapeConsumer) { Consumer<SkinProvider.SkinAndCape> skinAndCapeConsumer) {
Geyser.getGeneralThreadPool().execute(() -> { Geyser.getGeneralThreadPool().execute(() -> {
SkinUtils.GameProfileData data = SkinUtils.GameProfileData.from(entity.getProfile()); GameProfileData data = GameProfileData.from(entity.getProfile());
SkinProvider.requestSkinAndCape(entity.getUuid(), data.getSkinUrl(), data.getCapeUrl()) SkinProvider.requestSkinAndCape(entity.getUuid(), data.getSkinUrl(), data.getCapeUrl())
.whenCompleteAsync((skinAndCape, throwable) -> { .whenCompleteAsync((skinAndCape, throwable) -> {
@ -115,14 +127,15 @@ public class SkinUtils {
entity.setLastSkinUpdate(skin.getRequestedOn()); entity.setLastSkinUpdate(skin.getRequestedOn());
if (session.getUpstream().isInitialized()) { if (session.getUpstream().isInitialized()) {
PlayerListPacket.Entry updatedEntry = SkinUtils.buildEntryManually( PlayerListPacket.Entry updatedEntry = buildEntryManually(
entity.getUuid(), entity.getUuid(),
entity.getUsername(), entity.getUsername(),
entity.getGeyserId(), entity.getGeyserId(),
entity.getUuid().toString(), entity.getUuid().toString(),
skin.getSkinData(), skin.getSkinData(),
cape.getCapeId(),
cape.getCapeData(), cape.getCapeData(),
"geometry.humanoid.custom" + (data.isAlex() ? "Slim" : ""), getLegacySkinGeometry("geometry.humanoid.custom" + (data.isAlex() ? "Slim" : "")),
"" ""
); );
@ -145,4 +158,8 @@ public class SkinUtils {
}); });
}); });
} }
private static String getLegacySkinGeometry(String geometryName) {
return "{\"geometry\" :{\"default\" :\"" + geometryName + "\"}}";
}
} }

View file

@ -1,13 +1,15 @@
package org.geysermc.connector.utils; package org.geysermc.connector.utils;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import com.nukkitx.network.VarInts; import com.nukkitx.nbt.NbtUtils;
import com.nukkitx.nbt.stream.NBTInputStream;
import com.nukkitx.nbt.tag.CompoundTag;
import com.nukkitx.nbt.tag.ListTag;
import com.nukkitx.protocol.bedrock.packet.StartGamePacket; import com.nukkitx.protocol.bedrock.packet.StartGamePacket;
import com.nukkitx.protocol.bedrock.v361.BedrockUtils;
import gnu.trove.map.TIntObjectMap; import gnu.trove.map.TIntObjectMap;
import gnu.trove.map.hash.TIntObjectHashMap; import gnu.trove.map.hash.TIntObjectHashMap;
import io.netty.buffer.ByteBuf; import org.geysermc.connector.GeyserConnector;
import io.netty.buffer.Unpooled;
import org.geysermc.connector.console.GeyserLogger; import org.geysermc.connector.console.GeyserLogger;
import org.geysermc.connector.network.translators.block.BlockEntry; import org.geysermc.connector.network.translators.block.BlockEntry;
import org.geysermc.connector.network.translators.item.ItemEntry; import org.geysermc.connector.network.translators.item.ItemEntry;
@ -18,39 +20,40 @@ import java.util.*;
public class Toolbox { public class Toolbox {
public static final Collection<StartGamePacket.ItemEntry> ITEMS; public static final Collection<StartGamePacket.ItemEntry> ITEMS = new ArrayList<>();
public static final ByteBuf CACHED_PALLETE; public static ListTag<CompoundTag> BLOCKS;
public static final TIntObjectMap<ItemEntry> ITEM_ENTRIES; public static final TIntObjectMap<ItemEntry> ITEM_ENTRIES = new TIntObjectHashMap<>();
public static final TIntObjectMap<BlockEntry> BLOCK_ENTRIES; public static final TIntObjectMap<BlockEntry> BLOCK_ENTRIES = new TIntObjectHashMap<>();
static { public static void init() {
InputStream stream = Toolbox.class.getClassLoader().getResourceAsStream("bedrock/cached_palette.json"); InputStream stream = GeyserConnector.class.getClassLoader().getResourceAsStream("bedrock/runtime_block_states.dat");
ObjectMapper mapper = new ObjectMapper(); if (stream == null) {
List<LinkedHashMap<String, Object>> entries = new ArrayList<>(); throw new AssertionError("Unable to find bedrock/runtime_block_states.dat");
try {
entries = mapper.readValue(stream, ArrayList.class);
} catch (Exception e) {
e.printStackTrace();
} }
ByteBuf cachedPalette = Unpooled.buffer();
VarInts.writeUnsignedInt(cachedPalette, entries.size());
Map<String, Integer> blockIdToIdentifier = new HashMap<>(); Map<String, Integer> blockIdToIdentifier = new HashMap<>();
ListTag<CompoundTag> blocksTag;
for (Map<String, Object> entry : entries) { NBTInputStream nbtInputStream = NbtUtils.createNetworkReader(stream);
blockIdToIdentifier.put((String) entry.get("name"), (int) entry.get("id")); try {
blocksTag = (ListTag<CompoundTag>) nbtInputStream.readTag();
GlobalBlockPalette.registerMapping((int) entry.get("id") << 4 | (int) entry.get("data")); nbtInputStream.close();
BedrockUtils.writeString(cachedPalette, (String) entry.get("name")); } catch (Exception ex) {
cachedPalette.writeShortLE((int) entry.get("data")); GeyserLogger.DEFAULT.warning("Failed to get blocks from runtime block states, please report this error!");
cachedPalette.writeShortLE((int) entry.get("id")); throw new AssertionError(ex);
} }
CACHED_PALLETE = cachedPalette; for (CompoundTag entry : blocksTag.getValue()) {
String name = entry.getAsCompound("block").getAsString("name");
int id = entry.getAsShort("id");
int data = entry.getAsShort("meta");
blockIdToIdentifier.put(name, id);
GlobalBlockPalette.registerMapping(id << 4 | data);
}
BLOCKS = blocksTag;
InputStream stream2 = Toolbox.class.getClassLoader().getResourceAsStream("bedrock/items.json"); InputStream stream2 = Toolbox.class.getClassLoader().getResourceAsStream("bedrock/items.json");
if (stream2 == null) { if (stream2 == null) {
throw new AssertionError("Items Table not found"); throw new AssertionError("Items Table not found");
@ -64,13 +67,10 @@ public class Toolbox {
e.printStackTrace(); e.printStackTrace();
} }
List<StartGamePacket.ItemEntry> startGameEntries = new ArrayList<>();
for (Map entry : startGameItems) { for (Map entry : startGameItems) {
startGameEntries.add(new StartGamePacket.ItemEntry((String) entry.get("name"), (short) ((int) entry.get("id")))); ITEMS.add(new StartGamePacket.ItemEntry((String) entry.get("name"), (short) ((int) entry.get("id"))));
} }
ITEMS = startGameEntries;
InputStream itemStream = Toolbox.class.getClassLoader().getResourceAsStream("items.json"); InputStream itemStream = Toolbox.class.getClassLoader().getResourceAsStream("items.json");
ObjectMapper itemMapper = new ObjectMapper(); ObjectMapper itemMapper = new ObjectMapper();
Map<String, Map<String, Object>> items = new HashMap<>(); Map<String, Map<String, Object>> items = new HashMap<>();
@ -81,16 +81,12 @@ public class Toolbox {
ex.printStackTrace(); ex.printStackTrace();
} }
TIntObjectMap<ItemEntry> itemEntries = new TIntObjectHashMap<>();
int itemIndex = 0; int itemIndex = 0;
for (Map.Entry<String, Map<String, Object>> itemEntry : items.entrySet()) { for (Map.Entry<String, Map<String, Object>> itemEntry : items.entrySet()) {
itemEntries.put(itemIndex, new ItemEntry(itemEntry.getKey(), itemIndex, (int) itemEntry.getValue().get("bedrock_id"), (int) itemEntry.getValue().get("bedrock_data"))); ITEM_ENTRIES.put(itemIndex, new ItemEntry(itemEntry.getKey(), itemIndex, (int) itemEntry.getValue().get("bedrock_id"), (int) itemEntry.getValue().get("bedrock_data")));
itemIndex++; itemIndex++;
} }
ITEM_ENTRIES = itemEntries;
InputStream blockStream = Toolbox.class.getClassLoader().getResourceAsStream("blocks.json"); InputStream blockStream = Toolbox.class.getClassLoader().getResourceAsStream("blocks.json");
ObjectMapper blockMapper = new ObjectMapper(); ObjectMapper blockMapper = new ObjectMapper();
Map<String, Map<String, Object>> blocks = new HashMap<>(); Map<String, Map<String, Object>> blocks = new HashMap<>();
@ -101,20 +97,16 @@ public class Toolbox {
ex.printStackTrace(); ex.printStackTrace();
} }
TIntObjectMap<BlockEntry> blockEntries = new TIntObjectHashMap<>();
int blockIndex = 0; int blockIndex = 0;
for (Map.Entry<String, Map<String, Object>> itemEntry : blocks.entrySet()) { for (Map.Entry<String, Map<String, Object>> itemEntry : blocks.entrySet()) {
if (!blockIdToIdentifier.containsKey(itemEntry.getValue().get("bedrock_identifier"))) { if (!blockIdToIdentifier.containsKey(itemEntry.getValue().get("bedrock_identifier"))) {
GeyserLogger.DEFAULT.debug("Mapping " + itemEntry.getValue().get("bedrock_identifier") + " does not exist on bedrock edition!"); GeyserLogger.DEFAULT.debug("Mapping " + itemEntry.getValue().get("bedrock_identifier") + " was not found for bedrock edition!");
blockEntries.put(blockIndex, new BlockEntry(itemEntry.getKey(), blockIndex, 248, 0)); // update block BLOCK_ENTRIES.put(blockIndex, new BlockEntry(itemEntry.getKey(), blockIndex, 248, 0)); // update block
} else { } else {
blockEntries.put(blockIndex, new BlockEntry(itemEntry.getKey(), blockIndex, blockIdToIdentifier.get(itemEntry.getValue().get("bedrock_identifier")), (int) itemEntry.getValue().get("bedrock_data"))); BLOCK_ENTRIES.put(blockIndex, new BlockEntry(itemEntry.getKey(), blockIndex, blockIdToIdentifier.get(itemEntry.getValue().get("bedrock_identifier")), (int) itemEntry.getValue().get("bedrock_data")));
} }
blockIndex++; blockIndex++;
} }
BLOCK_ENTRIES = blockEntries;
} }
} }

File diff suppressed because it is too large Load diff

View file

@ -1039,6 +1039,9 @@
{ {
"id" : 2 "id" : 2
}, },
{
"id" : 198
},
{ {
"id" : 243 "id" : 243
}, },
@ -1336,6 +1339,26 @@
"id" : -131, "id" : -131,
"damage" : 4 "damage" : 4
}, },
{
"id" : -131,
"damage" : 11
},
{
"id" : -131,
"damage" : 9
},
{
"id" : -131,
"damage" : 10
},
{
"id" : -131,
"damage" : 8
},
{
"id" : -131,
"damage" : 12
},
{ {
"id" : -133, "id" : -133,
"damage" : 3 "damage" : 3
@ -1441,6 +1464,9 @@
"id" : 175, "id" : 175,
"damage" : 5 "damage" : 5
}, },
{
"id" : -216
},
{ {
"id" : 351, "id" : 351,
"damage" : 19 "damage" : 19
@ -1748,6 +1774,10 @@
"id" : 383, "id" : 383,
"damage" : 113 "damage" : 113
}, },
{
"id" : 383,
"damage" : 121
},
{ {
"id" : 383, "id" : 383,
"damage" : 33 "damage" : 33
@ -2993,15 +3023,15 @@
{ {
"id" : 54 "id" : 54
}, },
{
"id" : -203
},
{ {
"id" : 146 "id" : 146
}, },
{ {
"id" : 130 "id" : 130
}, },
{
"id" : -203
},
{ {
"id" : 205 "id" : 205
}, },
@ -3819,32 +3849,25 @@
"id" : 69 "id" : 69
}, },
{ {
"id" : 143, "id" : 143
"damage" : 5
}, },
{ {
"id" : -144, "id" : -144
"damage" : 5
}, },
{ {
"id" : -141, "id" : -141
"damage" : 5
}, },
{ {
"id" : -143, "id" : -143
"damage" : 5
}, },
{ {
"id" : -140, "id" : -140
"damage" : 5
}, },
{ {
"id" : -142, "id" : -142
"damage" : 5
}, },
{ {
"id" : 77, "id" : 77
"damage" : 5
}, },
{ {
"id" : 131 "id" : 131

View file

@ -51,6 +51,10 @@
"name": "minecraft:bread", "name": "minecraft:bread",
"id": 297 "id": 297
}, },
{
"name": "minecraft:light_block",
"id": -215
},
{ {
"name": "minecraft:porkchop", "name": "minecraft:porkchop",
"id": 319 "id": 319
@ -63,10 +67,18 @@
"name": "minecraft:fish", "name": "minecraft:fish",
"id": 349 "id": 349
}, },
{
"name": "minecraft:element_52",
"id": -63
},
{ {
"name": "minecraft:diamond_sword", "name": "minecraft:diamond_sword",
"id": 276 "id": 276
}, },
{
"name": "minecraft:element_38",
"id": -49
},
{ {
"name": "minecraft:sandstone_stairs", "name": "minecraft:sandstone_stairs",
"id": 128 "id": 128
@ -87,6 +99,10 @@
"name": "minecraft:horsearmorgold", "name": "minecraft:horsearmorgold",
"id": 418 "id": 418
}, },
{
"name": "minecraft:element_74",
"id": -85
},
{ {
"name": "minecraft:pufferfish", "name": "minecraft:pufferfish",
"id": 462 "id": 462
@ -107,6 +123,10 @@
"name": "minecraft:emerald", "name": "minecraft:emerald",
"id": 388 "id": 388
}, },
{
"name": "minecraft:element_47",
"id": -58
},
{ {
"name": "minecraft:mushroom_stew", "name": "minecraft:mushroom_stew",
"id": 282 "id": 282
@ -135,10 +155,22 @@
"name": "minecraft:cooked_fish", "name": "minecraft:cooked_fish",
"id": 350 "id": 350
}, },
{
"name": "minecraft:element_32",
"id": -43
},
{ {
"name": "minecraft:double_stone_slab4", "name": "minecraft:double_stone_slab4",
"id": -166 "id": -166
}, },
{
"name": "minecraft:element_5",
"id": -16
},
{
"name": "minecraft:element_25",
"id": -36
},
{ {
"name": "minecraft:polished_granite_stairs", "name": "minecraft:polished_granite_stairs",
"id": -172 "id": -172
@ -159,10 +191,18 @@
"name": "minecraft:cooked_salmon", "name": "minecraft:cooked_salmon",
"id": 463 "id": 463
}, },
{
"name": "minecraft:element_87",
"id": -98
},
{ {
"name": "minecraft:pumpkin_seeds", "name": "minecraft:pumpkin_seeds",
"id": 361 "id": 361
}, },
{
"name": "minecraft:element_53",
"id": -64
},
{ {
"name": "minecraft:dried_kelp", "name": "minecraft:dried_kelp",
"id": 464 "id": 464
@ -219,6 +259,10 @@
"name": "minecraft:chicken", "name": "minecraft:chicken",
"id": 365 "id": 365
}, },
{
"name": "minecraft:element_31",
"id": -42
},
{ {
"name": "minecraft:cooked_chicken", "name": "minecraft:cooked_chicken",
"id": 366 "id": 366
@ -243,6 +287,10 @@
"name": "minecraft:diamond_axe", "name": "minecraft:diamond_axe",
"id": 279 "id": 279
}, },
{
"name": "minecraft:element_105",
"id": -116
},
{ {
"name": "minecraft:carrot", "name": "minecraft:carrot",
"id": 391 "id": 391
@ -259,6 +307,10 @@
"name": "minecraft:baked_potato", "name": "minecraft:baked_potato",
"id": 393 "id": 393
}, },
{
"name": "minecraft:element_15",
"id": -26
},
{ {
"name": "minecraft:carpet", "name": "minecraft:carpet",
"id": 171 "id": 171
@ -367,6 +419,10 @@
"name": "minecraft:arrow", "name": "minecraft:arrow",
"id": 262 "id": 262
}, },
{
"name": "minecraft:element_97",
"id": -108
},
{ {
"name": "minecraft:campfire", "name": "minecraft:campfire",
"id": 720 "id": 720
@ -463,6 +519,10 @@
"name": "minecraft:slime_ball", "name": "minecraft:slime_ball",
"id": 341 "id": 341
}, },
{
"name": "minecraft:element_58",
"id": -69
},
{ {
"name": "minecraft:golden_sword", "name": "minecraft:golden_sword",
"id": 283 "id": 283
@ -483,6 +543,10 @@
"name": "minecraft:golden_axe", "name": "minecraft:golden_axe",
"id": 286 "id": 286
}, },
{
"name": "minecraft:element_62",
"id": -73
},
{ {
"name": "minecraft:string", "name": "minecraft:string",
"id": 287 "id": 287
@ -551,14 +615,26 @@
"name": "minecraft:grindstone", "name": "minecraft:grindstone",
"id": -195 "id": -195
}, },
{
"name": "minecraft:element_46",
"id": -57
},
{ {
"name": "minecraft:potion", "name": "minecraft:potion",
"id": 373 "id": 373
}, },
{
"name": "minecraft:wither_rose",
"id": -216
},
{ {
"name": "minecraft:leather_helmet", "name": "minecraft:leather_helmet",
"id": 298 "id": 298
}, },
{
"name": "minecraft:element_48",
"id": -59
},
{ {
"name": "minecraft:leather_chestplate", "name": "minecraft:leather_chestplate",
"id": 299 "id": 299
@ -587,6 +663,14 @@
"name": "minecraft:stonebrick", "name": "minecraft:stonebrick",
"id": 98 "id": 98
}, },
{
"name": "minecraft:stickypistonarmcollision",
"id": -217
},
{
"name": "minecraft:structure_void",
"id": 217
},
{ {
"name": "minecraft:chainmail_chestplate", "name": "minecraft:chainmail_chestplate",
"id": 303 "id": 303
@ -595,6 +679,10 @@
"name": "minecraft:lit_blast_furnace", "name": "minecraft:lit_blast_furnace",
"id": -214 "id": -214
}, },
{
"name": "minecraft:element_11",
"id": -22
},
{ {
"name": "minecraft:chainmail_leggings", "name": "minecraft:chainmail_leggings",
"id": 304 "id": 304
@ -631,6 +719,10 @@
"name": "minecraft:iron_boots", "name": "minecraft:iron_boots",
"id": 309 "id": 309
}, },
{
"name": "minecraft:element_104",
"id": -115
},
{ {
"name": "minecraft:chorus_fruit_popped", "name": "minecraft:chorus_fruit_popped",
"id": 433 "id": 433
@ -643,6 +735,10 @@
"name": "minecraft:diamond_leggings", "name": "minecraft:diamond_leggings",
"id": 312 "id": 312
}, },
{
"name": "minecraft:element_75",
"id": -86
},
{ {
"name": "minecraft:diamond_boots", "name": "minecraft:diamond_boots",
"id": 313 "id": 313
@ -787,6 +883,10 @@
"name": "minecraft:flowing_lava", "name": "minecraft:flowing_lava",
"id": 10 "id": 10
}, },
{
"name": "minecraft:element_86",
"id": -97
},
{ {
"name": "minecraft:red_glazed_terracotta", "name": "minecraft:red_glazed_terracotta",
"id": 234 "id": 234
@ -831,6 +931,10 @@
"name": "minecraft:clock", "name": "minecraft:clock",
"id": 347 "id": 347
}, },
{
"name": "minecraft:element_96",
"id": -107
},
{ {
"name": "minecraft:dye", "name": "minecraft:dye",
"id": 351 "id": 351
@ -859,6 +963,10 @@
"name": "minecraft:cake", "name": "minecraft:cake",
"id": 354 "id": 354
}, },
{
"name": "minecraft:element_113",
"id": -124
},
{ {
"name": "minecraft:mossy_cobblestone", "name": "minecraft:mossy_cobblestone",
"id": 48 "id": 48
@ -891,6 +999,14 @@
"name": "minecraft:double_stone_slab2", "name": "minecraft:double_stone_slab2",
"id": 182 "id": 182
}, },
{
"name": "minecraft:element_3",
"id": -14
},
{
"name": "minecraft:element_23",
"id": -34
},
{ {
"name": "minecraft:skull", "name": "minecraft:skull",
"id": 397 "id": 397
@ -939,6 +1055,10 @@
"name": "minecraft:fermented_spider_eye", "name": "minecraft:fermented_spider_eye",
"id": 376 "id": 376
}, },
{
"name": "minecraft:element_81",
"id": -92
},
{ {
"name": "minecraft:monster_egg", "name": "minecraft:monster_egg",
"id": 97 "id": 97
@ -1019,10 +1139,18 @@
"name": "minecraft:netherstar", "name": "minecraft:netherstar",
"id": 399 "id": 399
}, },
{
"name": "minecraft:element_16",
"id": -27
},
{ {
"name": "minecraft:fireworks", "name": "minecraft:fireworks",
"id": 401 "id": 401
}, },
{
"name": "minecraft:element_30",
"id": -41
},
{ {
"name": "minecraft:fireworkscharge", "name": "minecraft:fireworkscharge",
"id": 402 "id": 402
@ -1047,6 +1175,10 @@
"name": "minecraft:concrete", "name": "minecraft:concrete",
"id": 236 "id": 236
}, },
{
"name": "minecraft:element_73",
"id": -84
},
{ {
"name": "minecraft:quartz", "name": "minecraft:quartz",
"id": 406 "id": 406
@ -1059,10 +1191,18 @@
"name": "minecraft:leaves2", "name": "minecraft:leaves2",
"id": 161 "id": 161
}, },
{
"name": "minecraft:element_102",
"id": -113
},
{ {
"name": "minecraft:coral_fan_hang2", "name": "minecraft:coral_fan_hang2",
"id": -136 "id": -136
}, },
{
"name": "minecraft:element_67",
"id": -78
},
{ {
"name": "minecraft:hopper_minecart", "name": "minecraft:hopper_minecart",
"id": 408 "id": 408
@ -1107,13 +1247,17 @@
"name": "minecraft:record_13", "name": "minecraft:record_13",
"id": 500 "id": 500
}, },
{
"name": "minecraft:stone_button",
"id": 77
},
{ {
"name": "minecraft:record_cat", "name": "minecraft:record_cat",
"id": 501 "id": 501
}, },
{ {
"name": "minecraft:stone_button", "name": "minecraft:element_89",
"id": 77 "id": -100
}, },
{ {
"name": "minecraft:record_blocks", "name": "minecraft:record_blocks",
@ -1123,6 +1267,10 @@
"name": "minecraft:bamboo", "name": "minecraft:bamboo",
"id": -163 "id": -163
}, },
{
"name": "minecraft:element_72",
"id": -83
},
{ {
"name": "minecraft:record_chirp", "name": "minecraft:record_chirp",
"id": 503 "id": 503
@ -1187,6 +1335,10 @@
"name": "minecraft:end_crystal", "name": "minecraft:end_crystal",
"id": 426 "id": 426
}, },
{
"name": "minecraft:element_55",
"id": -66
},
{ {
"name": "minecraft:birch_door", "name": "minecraft:birch_door",
"id": 428 "id": 428
@ -1203,6 +1355,10 @@
"name": "minecraft:acacia_door", "name": "minecraft:acacia_door",
"id": 430 "id": 430
}, },
{
"name": "minecraft:element_116",
"id": -127
},
{ {
"name": "minecraft:chorus_fruit", "name": "minecraft:chorus_fruit",
"id": 432 "id": 432
@ -1251,6 +1407,10 @@
"name": "minecraft:prismarine_shard", "name": "minecraft:prismarine_shard",
"id": 409 "id": 409
}, },
{
"name": "minecraft:element_112",
"id": -123
},
{ {
"name": "minecraft:totem", "name": "minecraft:totem",
"id": 450 "id": 450
@ -1263,6 +1423,10 @@
"name": "minecraft:pumpkin_stem", "name": "minecraft:pumpkin_stem",
"id": 104 "id": 104
}, },
{
"name": "minecraft:element_50",
"id": -61
},
{ {
"name": "minecraft:lever", "name": "minecraft:lever",
"id": 69 "id": 69
@ -1271,6 +1435,10 @@
"name": "minecraft:heart_of_the_sea", "name": "minecraft:heart_of_the_sea",
"id": 467 "id": 467
}, },
{
"name": "minecraft:element_92",
"id": -103
},
{ {
"name": "minecraft:grass", "name": "minecraft:grass",
"id": 2 "id": 2
@ -1323,6 +1491,22 @@
"name": "minecraft:banner_pattern", "name": "minecraft:banner_pattern",
"id": 434 "id": 434
}, },
{
"name": "minecraft:suspicious_stew",
"id": 734
},
{
"name": "minecraft:element_4",
"id": -15
},
{
"name": "minecraft:element_24",
"id": -35
},
{
"name": "minecraft:camera",
"id": 498
},
{ {
"name": "minecraft:compound", "name": "minecraft:compound",
"id": 499 "id": 499
@ -1331,6 +1515,10 @@
"name": "minecraft:bleach", "name": "minecraft:bleach",
"id": 451 "id": 451
}, },
{
"name": "minecraft:element_40",
"id": -51
},
{ {
"name": "minecraft:rapid_fertilizer", "name": "minecraft:rapid_fertilizer",
"id": 449 "id": 449
@ -1399,6 +1587,10 @@
"name": "minecraft:coral_block", "name": "minecraft:coral_block",
"id": -132 "id": -132
}, },
{
"name": "minecraft:element_54",
"id": -65
},
{ {
"name": "minecraft:double_stone_slab", "name": "minecraft:double_stone_slab",
"id": 44 "id": 44
@ -1407,6 +1599,14 @@
"name": "minecraft:double_stone_slab3", "name": "minecraft:double_stone_slab3",
"id": -162 "id": -162
}, },
{
"name": "minecraft:element_2",
"id": -13
},
{
"name": "minecraft:element_22",
"id": -33
},
{ {
"name": "minecraft:real_double_stone_slab2", "name": "minecraft:real_double_stone_slab2",
"id": 181 "id": 181
@ -1423,6 +1623,10 @@
"name": "minecraft:leaves", "name": "minecraft:leaves",
"id": 18 "id": 18
}, },
{
"name": "minecraft:element_10",
"id": -21
},
{ {
"name": "minecraft:birch_button", "name": "minecraft:birch_button",
"id": -141 "id": -141
@ -1435,6 +1639,10 @@
"name": "minecraft:red_sandstone", "name": "minecraft:red_sandstone",
"id": 179 "id": 179
}, },
{
"name": "minecraft:element_91",
"id": -102
},
{ {
"name": "minecraft:wooden_slab", "name": "minecraft:wooden_slab",
"id": 158 "id": 158
@ -1463,10 +1671,6 @@
"name": "minecraft:planks", "name": "minecraft:planks",
"id": 5 "id": 5
}, },
{
"name": "minecraft:redstone_torch",
"id": 76
},
{ {
"name": "minecraft:quartz_block", "name": "minecraft:quartz_block",
"id": 155 "id": 155
@ -1511,6 +1715,10 @@
"name": "minecraft:stained_glass", "name": "minecraft:stained_glass",
"id": 241 "id": 241
}, },
{
"name": "minecraft:element_82",
"id": -93
},
{ {
"name": "minecraft:stained_glass_pane", "name": "minecraft:stained_glass_pane",
"id": 160 "id": 160
@ -1523,6 +1731,10 @@
"name": "minecraft:undyed_shulker_box", "name": "minecraft:undyed_shulker_box",
"id": 205 "id": 205
}, },
{
"name": "minecraft:element_107",
"id": -118
},
{ {
"name": "minecraft:piston", "name": "minecraft:piston",
"id": 33 "id": 33
@ -1567,6 +1779,10 @@
"name": "minecraft:bell", "name": "minecraft:bell",
"id": -206 "id": -206
}, },
{
"name": "minecraft:element_42",
"id": -53
},
{ {
"name": "minecraft:cartography_table", "name": "minecraft:cartography_table",
"id": -200 "id": -200
@ -1587,6 +1803,10 @@
"name": "minecraft:chemistry_table", "name": "minecraft:chemistry_table",
"id": 238 "id": 238
}, },
{
"name": "minecraft:element_70",
"id": -81
},
{ {
"name": "minecraft:tnt", "name": "minecraft:tnt",
"id": 46 "id": 46
@ -1603,54 +1823,214 @@
"name": "minecraft:brown_mushroom", "name": "minecraft:brown_mushroom",
"id": 39 "id": 39
}, },
{
"name": "minecraft:element_0",
"id": 36
},
{
"name": "minecraft:element_20",
"id": -31
},
{
"name": "minecraft:element_1",
"id": -12
},
{
"name": "minecraft:element_21",
"id": -32
},
{
"name": "minecraft:element_6",
"id": -17
},
{
"name": "minecraft:element_26",
"id": -37
},
{
"name": "minecraft:element_7",
"id": -18
},
{
"name": "minecraft:element_27",
"id": -38
},
{
"name": "minecraft:element_8",
"id": -19
},
{
"name": "minecraft:element_28",
"id": -39
},
{ {
"name": "minecraft:dark_oak_pressure_plate", "name": "minecraft:dark_oak_pressure_plate",
"id": -152 "id": -152
}, },
{
"name": "minecraft:element_9",
"id": -20
},
{
"name": "minecraft:element_29",
"id": -40
},
{ {
"name": "minecraft:item.spruce_door", "name": "minecraft:item.spruce_door",
"id": 193 "id": 193
}, },
{
"name": "minecraft:element_12",
"id": -23
},
{ {
"name": "minecraft:cyan_glazed_terracotta", "name": "minecraft:cyan_glazed_terracotta",
"id": 229 "id": 229
}, },
{
"name": "minecraft:element_13",
"id": -24
},
{
"name": "minecraft:element_14",
"id": -25
},
{ {
"name": "minecraft:iron_ore", "name": "minecraft:iron_ore",
"id": 15 "id": 15
}, },
{
"name": "minecraft:element_17",
"id": -28
},
{
"name": "minecraft:element_18",
"id": -29
},
{ {
"name": "minecraft:birch_pressure_plate", "name": "minecraft:birch_pressure_plate",
"id": -151 "id": -151
}, },
{
"name": "minecraft:element_19",
"id": -30
},
{ {
"name": "minecraft:wooden_pressure_plate", "name": "minecraft:wooden_pressure_plate",
"id": 72 "id": 72
}, },
{
"name": "minecraft:element_33",
"id": -44
},
{
"name": "minecraft:element_34",
"id": -45
},
{
"name": "minecraft:element_35",
"id": -46
},
{ {
"name": "minecraft:composter", "name": "minecraft:composter",
"id": -213 "id": -213
}, },
{
"name": "minecraft:element_36",
"id": -47
},
{
"name": "minecraft:element_37",
"id": -48
},
{
"name": "minecraft:element_39",
"id": -50
},
{
"name": "minecraft:element_41",
"id": -52
},
{ {
"name": "minecraft:hay_block", "name": "minecraft:hay_block",
"id": 170 "id": 170
}, },
{
"name": "minecraft:element_43",
"id": -54
},
{ {
"name": "minecraft:lit_redstone_lamp", "name": "minecraft:lit_redstone_lamp",
"id": 124 "id": 124
}, },
{
"name": "minecraft:element_44",
"id": -55
},
{
"name": "minecraft:element_45",
"id": -56
},
{
"name": "minecraft:element_49",
"id": -60
},
{
"name": "minecraft:element_51",
"id": -62
},
{
"name": "minecraft:element_56",
"id": -67
},
{
"name": "minecraft:element_57",
"id": -68
},
{
"name": "minecraft:element_59",
"id": -70
},
{
"name": "minecraft:element_60",
"id": -71
},
{ {
"name": "minecraft:dropper", "name": "minecraft:dropper",
"id": 125 "id": 125
}, },
{
"name": "minecraft:element_61",
"id": -72
},
{
"name": "minecraft:element_63",
"id": -74
},
{
"name": "minecraft:element_64",
"id": -75
},
{
"name": "minecraft:element_65",
"id": -76
},
{ {
"name": "minecraft:coral_fan_hang3", "name": "minecraft:coral_fan_hang3",
"id": -137 "id": -137
}, },
{
"name": "minecraft:element_66",
"id": -77
},
{ {
"name": "minecraft:redstone_lamp", "name": "minecraft:redstone_lamp",
"id": 123 "id": 123
}, },
{
"name": "minecraft:element_68",
"id": -79
},
{ {
"name": "minecraft:spruce_trapdoor", "name": "minecraft:spruce_trapdoor",
"id": -149 "id": -149
@ -1659,18 +2039,54 @@
"name": "minecraft:purple_glazed_terracotta", "name": "minecraft:purple_glazed_terracotta",
"id": 219 "id": 219
}, },
{
"name": "minecraft:element_69",
"id": -80
},
{ {
"name": "minecraft:iron_block", "name": "minecraft:iron_block",
"id": 42 "id": 42
}, },
{
"name": "minecraft:element_71",
"id": -82
},
{
"name": "minecraft:element_76",
"id": -87
},
{
"name": "minecraft:element_77",
"id": -88
},
{ {
"name": "minecraft:water", "name": "minecraft:water",
"id": 9 "id": 9
}, },
{
"name": "minecraft:element_78",
"id": -89
},
{
"name": "minecraft:element_79",
"id": -90
},
{
"name": "minecraft:element_80",
"id": -91
},
{ {
"name": "minecraft:netherreactor", "name": "minecraft:netherreactor",
"id": 247 "id": 247
}, },
{
"name": "minecraft:element_83",
"id": -94
},
{
"name": "minecraft:element_84",
"id": -95
},
{ {
"name": "minecraft:jungle_wall_sign", "name": "minecraft:jungle_wall_sign",
"id": -189 "id": -189
@ -1679,6 +2095,18 @@
"name": "minecraft:end_brick_stairs", "name": "minecraft:end_brick_stairs",
"id": -178 "id": -178
}, },
{
"name": "minecraft:element_85",
"id": -96
},
{
"name": "minecraft:element_88",
"id": -99
},
{
"name": "minecraft:element_90",
"id": -101
},
{ {
"name": "minecraft:birch_standing_sign", "name": "minecraft:birch_standing_sign",
"id": -186 "id": -186
@ -1687,6 +2115,18 @@
"name": "minecraft:gold_ore", "name": "minecraft:gold_ore",
"id": 14 "id": 14
}, },
{
"name": "minecraft:element_93",
"id": -104
},
{
"name": "minecraft:element_94",
"id": -105
},
{
"name": "minecraft:element_95",
"id": -106
},
{ {
"name": "minecraft:glass", "name": "minecraft:glass",
"id": 20 "id": 20
@ -1695,10 +2135,62 @@
"name": "minecraft:red_nether_brick", "name": "minecraft:red_nether_brick",
"id": 215 "id": 215
}, },
{
"name": "minecraft:element_98",
"id": -109
},
{
"name": "minecraft:element_99",
"id": -110
},
{
"name": "minecraft:element_100",
"id": -111
},
{
"name": "minecraft:element_101",
"id": -112
},
{
"name": "minecraft:element_103",
"id": -114
},
{
"name": "minecraft:element_106",
"id": -117
},
{
"name": "minecraft:element_108",
"id": -119
},
{
"name": "minecraft:element_109",
"id": -120
},
{
"name": "minecraft:element_110",
"id": -121
},
{
"name": "minecraft:element_111",
"id": -122
},
{
"name": "minecraft:element_114",
"id": -125
},
{ {
"name": "minecraft:birch_fence_gate", "name": "minecraft:birch_fence_gate",
"id": 184 "id": 184
}, },
{
"name": "minecraft:element_115",
"id": -126
},
{
"name": "minecraft:element_117",
"id": -128
},
{ {
"name": "minecraft:slime", "name": "minecraft:slime",
"id": 165 "id": 165
@ -1707,6 +2199,10 @@
"name": "minecraft:spruce_standing_sign", "name": "minecraft:spruce_standing_sign",
"id": -181 "id": -181
}, },
{
"name": "minecraft:element_118",
"id": -129
},
{ {
"name": "minecraft:gravel", "name": "minecraft:gravel",
"id": 13 "id": 13
@ -1855,6 +2351,10 @@
"name": "minecraft:red_nether_brick_stairs", "name": "minecraft:red_nether_brick_stairs",
"id": -184 "id": -184
}, },
{
"name": "minecraft:redstone_torch",
"id": 76
},
{ {
"name": "minecraft:ice", "name": "minecraft:ice",
"id": 79 "id": 79
@ -2179,6 +2679,14 @@
"name": "minecraft:chorus_plant", "name": "minecraft:chorus_plant",
"id": 240 "id": 240
}, },
{
"name": "minecraft:fire",
"id": 51
},
{
"name": "minecraft:item.camera",
"id": 242
},
{ {
"name": "minecraft:stonecutter", "name": "minecraft:stonecutter",
"id": 245 "id": 245
@ -2203,10 +2711,6 @@
"name": "minecraft:stripped_dark_oak_log", "name": "minecraft:stripped_dark_oak_log",
"id": -9 "id": -9
}, },
{
"name": "minecraft:fire",
"id": 51
},
{ {
"name": "minecraft:hard_glass_pane", "name": "minecraft:hard_glass_pane",
"id": 190 "id": 190

View file

@ -577,339 +577,339 @@
}, },
"minecraft:oak_leaves[distance=1,persistent=true]": { "minecraft:oak_leaves[distance=1,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:oak_leaves[distance=1,persistent=false]": { "minecraft:oak_leaves[distance=1,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:oak_leaves[distance=2,persistent=true]": { "minecraft:oak_leaves[distance=2,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:oak_leaves[distance=2,persistent=false]": { "minecraft:oak_leaves[distance=2,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:oak_leaves[distance=3,persistent=true]": { "minecraft:oak_leaves[distance=3,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:oak_leaves[distance=3,persistent=false]": { "minecraft:oak_leaves[distance=3,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:oak_leaves[distance=4,persistent=true]": { "minecraft:oak_leaves[distance=4,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:oak_leaves[distance=4,persistent=false]": { "minecraft:oak_leaves[distance=4,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:oak_leaves[distance=5,persistent=true]": { "minecraft:oak_leaves[distance=5,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:oak_leaves[distance=5,persistent=false]": { "minecraft:oak_leaves[distance=5,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:oak_leaves[distance=6,persistent=true]": { "minecraft:oak_leaves[distance=6,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:oak_leaves[distance=6,persistent=false]": { "minecraft:oak_leaves[distance=6,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:oak_leaves[distance=7,persistent=true]": { "minecraft:oak_leaves[distance=7,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:oak_leaves[distance=7,persistent=false]": { "minecraft:oak_leaves[distance=7,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:spruce_leaves[distance=1,persistent=true]": { "minecraft:spruce_leaves[distance=1,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:spruce_leaves[distance=1,persistent=false]": { "minecraft:spruce_leaves[distance=1,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:spruce_leaves[distance=2,persistent=true]": { "minecraft:spruce_leaves[distance=2,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:spruce_leaves[distance=2,persistent=false]": { "minecraft:spruce_leaves[distance=2,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:spruce_leaves[distance=3,persistent=true]": { "minecraft:spruce_leaves[distance=3,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:spruce_leaves[distance=3,persistent=false]": { "minecraft:spruce_leaves[distance=3,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:spruce_leaves[distance=4,persistent=true]": { "minecraft:spruce_leaves[distance=4,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:spruce_leaves[distance=4,persistent=false]": { "minecraft:spruce_leaves[distance=4,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:spruce_leaves[distance=5,persistent=true]": { "minecraft:spruce_leaves[distance=5,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:spruce_leaves[distance=5,persistent=false]": { "minecraft:spruce_leaves[distance=5,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:spruce_leaves[distance=6,persistent=true]": { "minecraft:spruce_leaves[distance=6,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:spruce_leaves[distance=6,persistent=false]": { "minecraft:spruce_leaves[distance=6,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:spruce_leaves[distance=7,persistent=true]": { "minecraft:spruce_leaves[distance=7,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:spruce_leaves[distance=7,persistent=false]": { "minecraft:spruce_leaves[distance=7,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:birch_leaves[distance=1,persistent=true]": { "minecraft:birch_leaves[distance=1,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 10 "bedrock_data": 6
}, },
"minecraft:birch_leaves[distance=1,persistent=false]": { "minecraft:birch_leaves[distance=1,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 6 "bedrock_data": 2
}, },
"minecraft:birch_leaves[distance=2,persistent=true]": { "minecraft:birch_leaves[distance=2,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 10 "bedrock_data": 6
}, },
"minecraft:birch_leaves[distance=2,persistent=false]": { "minecraft:birch_leaves[distance=2,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 6 "bedrock_data": 2
}, },
"minecraft:birch_leaves[distance=3,persistent=true]": { "minecraft:birch_leaves[distance=3,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 10 "bedrock_data": 6
}, },
"minecraft:birch_leaves[distance=3,persistent=false]": { "minecraft:birch_leaves[distance=3,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 6 "bedrock_data": 2
}, },
"minecraft:birch_leaves[distance=4,persistent=true]": { "minecraft:birch_leaves[distance=4,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 10 "bedrock_data": 6
}, },
"minecraft:birch_leaves[distance=4,persistent=false]": { "minecraft:birch_leaves[distance=4,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 6 "bedrock_data": 2
}, },
"minecraft:birch_leaves[distance=5,persistent=true]": { "minecraft:birch_leaves[distance=5,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 10 "bedrock_data": 6
}, },
"minecraft:birch_leaves[distance=5,persistent=false]": { "minecraft:birch_leaves[distance=5,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 6 "bedrock_data": 2
}, },
"minecraft:birch_leaves[distance=6,persistent=true]": { "minecraft:birch_leaves[distance=6,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 10 "bedrock_data": 6
}, },
"minecraft:birch_leaves[distance=6,persistent=false]": { "minecraft:birch_leaves[distance=6,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 6 "bedrock_data": 2
}, },
"minecraft:birch_leaves[distance=7,persistent=true]": { "minecraft:birch_leaves[distance=7,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 10 "bedrock_data": 6
}, },
"minecraft:birch_leaves[distance=7,persistent=false]": { "minecraft:birch_leaves[distance=7,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 6 "bedrock_data": 2
}, },
"minecraft:jungle_leaves[distance=1,persistent=true]": { "minecraft:jungle_leaves[distance=1,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 11 "bedrock_data": 7
}, },
"minecraft:jungle_leaves[distance=1,persistent=false]": { "minecraft:jungle_leaves[distance=1,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 7 "bedrock_data": 3
}, },
"minecraft:jungle_leaves[distance=2,persistent=true]": { "minecraft:jungle_leaves[distance=2,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 11 "bedrock_data": 7
}, },
"minecraft:jungle_leaves[distance=2,persistent=false]": { "minecraft:jungle_leaves[distance=2,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 7 "bedrock_data": 3
}, },
"minecraft:jungle_leaves[distance=3,persistent=true]": { "minecraft:jungle_leaves[distance=3,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 11 "bedrock_data": 7
}, },
"minecraft:jungle_leaves[distance=3,persistent=false]": { "minecraft:jungle_leaves[distance=3,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 7 "bedrock_data": 3
}, },
"minecraft:jungle_leaves[distance=4,persistent=true]": { "minecraft:jungle_leaves[distance=4,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 11 "bedrock_data": 7
}, },
"minecraft:jungle_leaves[distance=4,persistent=false]": { "minecraft:jungle_leaves[distance=4,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 7 "bedrock_data": 3
}, },
"minecraft:jungle_leaves[distance=5,persistent=true]": { "minecraft:jungle_leaves[distance=5,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 11 "bedrock_data": 7
}, },
"minecraft:jungle_leaves[distance=5,persistent=false]": { "minecraft:jungle_leaves[distance=5,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 7 "bedrock_data": 3
}, },
"minecraft:jungle_leaves[distance=6,persistent=true]": { "minecraft:jungle_leaves[distance=6,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 11 "bedrock_data": 7
}, },
"minecraft:jungle_leaves[distance=6,persistent=false]": { "minecraft:jungle_leaves[distance=6,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 7 "bedrock_data": 3
}, },
"minecraft:jungle_leaves[distance=7,persistent=true]": { "minecraft:jungle_leaves[distance=7,persistent=true]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 11 "bedrock_data": 7
}, },
"minecraft:jungle_leaves[distance=7,persistent=false]": { "minecraft:jungle_leaves[distance=7,persistent=false]": {
"bedrock_identifier": "minecraft:leaves", "bedrock_identifier": "minecraft:leaves",
"bedrock_data": 7 "bedrock_data": 3
}, },
"minecraft:acacia_leaves[distance=1,persistent=true]": { "minecraft:acacia_leaves[distance=1,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:acacia_leaves[distance=1,persistent=false]": { "minecraft:acacia_leaves[distance=1,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:acacia_leaves[distance=2,persistent=true]": { "minecraft:acacia_leaves[distance=2,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:acacia_leaves[distance=2,persistent=false]": { "minecraft:acacia_leaves[distance=2,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:acacia_leaves[distance=3,persistent=true]": { "minecraft:acacia_leaves[distance=3,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:acacia_leaves[distance=3,persistent=false]": { "minecraft:acacia_leaves[distance=3,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:acacia_leaves[distance=4,persistent=true]": { "minecraft:acacia_leaves[distance=4,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:acacia_leaves[distance=4,persistent=false]": { "minecraft:acacia_leaves[distance=4,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:acacia_leaves[distance=5,persistent=true]": { "minecraft:acacia_leaves[distance=5,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:acacia_leaves[distance=5,persistent=false]": { "minecraft:acacia_leaves[distance=5,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:acacia_leaves[distance=6,persistent=true]": { "minecraft:acacia_leaves[distance=6,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:acacia_leaves[distance=6,persistent=false]": { "minecraft:acacia_leaves[distance=6,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:acacia_leaves[distance=7,persistent=true]": { "minecraft:acacia_leaves[distance=7,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 8 "bedrock_data": 4
}, },
"minecraft:acacia_leaves[distance=7,persistent=false]": { "minecraft:acacia_leaves[distance=7,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 4 "bedrock_data": 0
}, },
"minecraft:dark_oak_leaves[distance=1,persistent=true]": { "minecraft:dark_oak_leaves[distance=1,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:dark_oak_leaves[distance=1,persistent=false]": { "minecraft:dark_oak_leaves[distance=1,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:dark_oak_leaves[distance=2,persistent=true]": { "minecraft:dark_oak_leaves[distance=2,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:dark_oak_leaves[distance=2,persistent=false]": { "minecraft:dark_oak_leaves[distance=2,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:dark_oak_leaves[distance=3,persistent=true]": { "minecraft:dark_oak_leaves[distance=3,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:dark_oak_leaves[distance=3,persistent=false]": { "minecraft:dark_oak_leaves[distance=3,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:dark_oak_leaves[distance=4,persistent=true]": { "minecraft:dark_oak_leaves[distance=4,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:dark_oak_leaves[distance=4,persistent=false]": { "minecraft:dark_oak_leaves[distance=4,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:dark_oak_leaves[distance=5,persistent=true]": { "minecraft:dark_oak_leaves[distance=5,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:dark_oak_leaves[distance=5,persistent=false]": { "minecraft:dark_oak_leaves[distance=5,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:dark_oak_leaves[distance=6,persistent=true]": { "minecraft:dark_oak_leaves[distance=6,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:dark_oak_leaves[distance=6,persistent=false]": { "minecraft:dark_oak_leaves[distance=6,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:dark_oak_leaves[distance=7,persistent=true]": { "minecraft:dark_oak_leaves[distance=7,persistent=true]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 9 "bedrock_data": 5
}, },
"minecraft:dark_oak_leaves[distance=7,persistent=false]": { "minecraft:dark_oak_leaves[distance=7,persistent=false]": {
"bedrock_identifier": "minecraft:leaves2", "bedrock_identifier": "minecraft:leaves2",
"bedrock_data": 5 "bedrock_data": 1
}, },
"minecraft:sponge": { "minecraft:sponge": {
"bedrock_identifier": "minecraft:sponge", "bedrock_identifier": "minecraft:sponge",
@ -5688,8 +5688,8 @@
"bedrock_data": 9 "bedrock_data": 9
}, },
"minecraft:wither_rose": { "minecraft:wither_rose": {
"bedrock_identifier": "minecraft:red_flower", "bedrock_identifier": "minecraft:wither_rose",
"bedrock_data": 11 "bedrock_data": 0
}, },
"minecraft:lily_of_the_valley": { "minecraft:lily_of_the_valley": {
"bedrock_identifier": "minecraft:red_flower", "bedrock_identifier": "minecraft:red_flower",
@ -34892,7 +34892,7 @@
"bedrock_data": 8 "bedrock_data": 8
}, },
"minecraft:structure_void": { "minecraft:structure_void": {
"bedrock_identifier": "minecraft:air", "bedrock_identifier": "minecraft:structure_void",
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:observer[facing=north,powered=true]": { "minecraft:observer[facing=north,powered=true]": {
@ -35897,23 +35897,23 @@
}, },
"minecraft:dead_tube_coral_block": { "minecraft:dead_tube_coral_block": {
"bedrock_identifier": "minecraft:coral_block", "bedrock_identifier": "minecraft:coral_block",
"bedrock_data": 5 "bedrock_data": 8
}, },
"minecraft:dead_brain_coral_block": { "minecraft:dead_brain_coral_block": {
"bedrock_identifier": "minecraft:coral_block", "bedrock_identifier": "minecraft:coral_block",
"bedrock_data": 6 "bedrock_data": 9
}, },
"minecraft:dead_bubble_coral_block": { "minecraft:dead_bubble_coral_block": {
"bedrock_identifier": "minecraft:coral_block", "bedrock_identifier": "minecraft:coral_block",
"bedrock_data": 7 "bedrock_data": 10
}, },
"minecraft:dead_fire_coral_block": { "minecraft:dead_fire_coral_block": {
"bedrock_identifier": "minecraft:coral_block", "bedrock_identifier": "minecraft:coral_block",
"bedrock_data": 8 "bedrock_data": 11
}, },
"minecraft:dead_horn_coral_block": { "minecraft:dead_horn_coral_block": {
"bedrock_identifier": "minecraft:coral_block", "bedrock_identifier": "minecraft:coral_block",
"bedrock_data": 9 "bedrock_data": 12
}, },
"minecraft:tube_coral_block": { "minecraft:tube_coral_block": {
"bedrock_identifier": "minecraft:coral_block", "bedrock_identifier": "minecraft:coral_block",
@ -35937,43 +35937,43 @@
}, },
"minecraft:dead_tube_coral[waterlogged=true]": { "minecraft:dead_tube_coral[waterlogged=true]": {
"bedrock_identifier": "minecraft:coral", "bedrock_identifier": "minecraft:coral",
"bedrock_data": 0 "bedrock_data": 8
}, },
"minecraft:dead_tube_coral[waterlogged=false]": { "minecraft:dead_tube_coral[waterlogged=false]": {
"bedrock_identifier": "minecraft:coral", "bedrock_identifier": "minecraft:coral",
"bedrock_data": 0 "bedrock_data": 8
}, },
"minecraft:dead_brain_coral[waterlogged=true]": { "minecraft:dead_brain_coral[waterlogged=true]": {
"bedrock_identifier": "minecraft:coral", "bedrock_identifier": "minecraft:coral",
"bedrock_data": 1 "bedrock_data": 9
}, },
"minecraft:dead_brain_coral[waterlogged=false]": { "minecraft:dead_brain_coral[waterlogged=false]": {
"bedrock_identifier": "minecraft:coral", "bedrock_identifier": "minecraft:coral",
"bedrock_data": 1 "bedrock_data": 9
}, },
"minecraft:dead_bubble_coral[waterlogged=true]": { "minecraft:dead_bubble_coral[waterlogged=true]": {
"bedrock_identifier": "minecraft:coral", "bedrock_identifier": "minecraft:coral",
"bedrock_data": 2 "bedrock_data": 10
}, },
"minecraft:dead_bubble_coral[waterlogged=false]": { "minecraft:dead_bubble_coral[waterlogged=false]": {
"bedrock_identifier": "minecraft:coral", "bedrock_identifier": "minecraft:coral",
"bedrock_data": 2 "bedrock_data": 10
}, },
"minecraft:dead_fire_coral[waterlogged=true]": { "minecraft:dead_fire_coral[waterlogged=true]": {
"bedrock_identifier": "minecraft:coral", "bedrock_identifier": "minecraft:coral",
"bedrock_data": 3 "bedrock_data": 11
}, },
"minecraft:dead_fire_coral[waterlogged=false]": { "minecraft:dead_fire_coral[waterlogged=false]": {
"bedrock_identifier": "minecraft:coral", "bedrock_identifier": "minecraft:coral",
"bedrock_data": 3 "bedrock_data": 11
}, },
"minecraft:dead_horn_coral[waterlogged=true]": { "minecraft:dead_horn_coral[waterlogged=true]": {
"bedrock_identifier": "minecraft:coral", "bedrock_identifier": "minecraft:coral",
"bedrock_data": 4 "bedrock_data": 12
}, },
"minecraft:dead_horn_coral[waterlogged=false]": { "minecraft:dead_horn_coral[waterlogged=false]": {
"bedrock_identifier": "minecraft:coral", "bedrock_identifier": "minecraft:coral",
"bedrock_data": 4 "bedrock_data": 12
}, },
"minecraft:tube_coral[waterlogged=true]": { "minecraft:tube_coral[waterlogged=true]": {
"bedrock_identifier": "minecraft:coral", "bedrock_identifier": "minecraft:coral",

View file

@ -1,6 +1,6 @@
{ {
"minecraft:air": { "minecraft:air": {
"bedrock_id": 0, "bedrock_id": -158,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:stone": { "minecraft:stone": {
@ -176,52 +176,52 @@
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:stripped_oak_wood": { "minecraft:stripped_oak_wood": {
"bedrock_id": -10, "bedrock_id": -212,
"bedrock_data": 0 "bedrock_data": 8
}, },
"minecraft:stripped_spruce_wood": { "minecraft:stripped_spruce_wood": {
"bedrock_id": -5, "bedrock_id": -212,
"bedrock_data": 0 "bedrock_data": 9
}, },
"minecraft:stripped_birch_wood": { "minecraft:stripped_birch_wood": {
"bedrock_id": -6, "bedrock_id": -212,
"bedrock_data": 0 "bedrock_data": 10
}, },
"minecraft:stripped_jungle_wood": { "minecraft:stripped_jungle_wood": {
"bedrock_id": -7, "bedrock_id": -212,
"bedrock_data": 0 "bedrock_data": 11
}, },
"minecraft:stripped_acacia_wood": { "minecraft:stripped_acacia_wood": {
"bedrock_id": -8, "bedrock_id": -212,
"bedrock_data": 0 "bedrock_data": 12
}, },
"minecraft:stripped_dark_oak_wood": { "minecraft:stripped_dark_oak_wood": {
"bedrock_id": -9, "bedrock_id": -212,
"bedrock_data": 0 "bedrock_data": 13
}, },
"minecraft:oak_wood": { "minecraft:oak_wood": {
"bedrock_id": 248, "bedrock_id": -212,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:spruce_wood": { "minecraft:spruce_wood": {
"bedrock_id": 248, "bedrock_id": -212,
"bedrock_data": 0 "bedrock_data": 1
}, },
"minecraft:birch_wood": { "minecraft:birch_wood": {
"bedrock_id": 248, "bedrock_id": -212,
"bedrock_data": 0 "bedrock_data": 2
}, },
"minecraft:jungle_wood": { "minecraft:jungle_wood": {
"bedrock_id": 248, "bedrock_id": -212,
"bedrock_data": 0 "bedrock_data": 3
}, },
"minecraft:acacia_wood": { "minecraft:acacia_wood": {
"bedrock_id": 248, "bedrock_id": -212,
"bedrock_data": 0 "bedrock_data": 4
}, },
"minecraft:dark_oak_wood": { "minecraft:dark_oak_wood": {
"bedrock_id": 248, "bedrock_id": -212,
"bedrock_data": 0 "bedrock_data": 5
}, },
"minecraft:oak_leaves": { "minecraft:oak_leaves": {
"bedrock_id": 18, "bedrock_id": 18,
@ -269,7 +269,7 @@
}, },
"minecraft:dispenser": { "minecraft:dispenser": {
"bedrock_id": 23, "bedrock_id": 23,
"bedrock_data": 3 "bedrock_data": 0
}, },
"minecraft:sandstone": { "minecraft:sandstone": {
"bedrock_id": 24, "bedrock_id": 24,
@ -297,7 +297,7 @@
}, },
"minecraft:sticky_piston": { "minecraft:sticky_piston": {
"bedrock_id": 29, "bedrock_id": 29,
"bedrock_data": 1 "bedrock_data": 0
}, },
"minecraft:cobweb": { "minecraft:cobweb": {
"bedrock_id": 30, "bedrock_id": 30,
@ -325,7 +325,7 @@
}, },
"minecraft:piston": { "minecraft:piston": {
"bedrock_id": 33, "bedrock_id": 33,
"bedrock_data": 1 "bedrock_data": 0
}, },
"minecraft:white_wool": { "minecraft:white_wool": {
"bedrock_id": 35, "bedrock_id": 35,
@ -432,15 +432,15 @@
"bedrock_data": 8 "bedrock_data": 8
}, },
"minecraft:cornflower": { "minecraft:cornflower": {
"bedrock_id": 248, "bedrock_id": 38,
"bedrock_data": 0 "bedrock_data": 9
}, },
"minecraft:lily_of_the_valley": { "minecraft:lily_of_the_valley": {
"bedrock_id": 248, "bedrock_id": 38,
"bedrock_data": 0 "bedrock_data": 10
}, },
"minecraft:wither_rose": { "minecraft:wither_rose": {
"bedrock_id": 248, "bedrock_id": -216,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:brown_mushroom": { "minecraft:brown_mushroom": {
@ -484,11 +484,11 @@
"bedrock_data": 5 "bedrock_data": 5
}, },
"minecraft:stone_slab": { "minecraft:stone_slab": {
"bedrock_id": 44, "bedrock_id": -166,
"bedrock_data": 0 "bedrock_data": 2
}, },
"minecraft:smooth_stone_slab": { "minecraft:smooth_stone_slab": {
"bedrock_id": 248, "bedrock_id": 44,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:sandstone_slab": { "minecraft:sandstone_slab": {
@ -496,8 +496,8 @@
"bedrock_data": 1 "bedrock_data": 1
}, },
"minecraft:cut_sandstone_slab": { "minecraft:cut_sandstone_slab": {
"bedrock_id": 248, "bedrock_id": -166,
"bedrock_data": 0 "bedrock_data": 3
}, },
"minecraft:petrified_oak_slab": { "minecraft:petrified_oak_slab": {
"bedrock_id": 44, "bedrock_id": 44,
@ -528,8 +528,8 @@
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:cut_red_sandstone_slab": { "minecraft:cut_red_sandstone_slab": {
"bedrock_id": 248, "bedrock_id": -166,
"bedrock_data": 0 "bedrock_data": 4
}, },
"minecraft:purpur_slab": { "minecraft:purpur_slab": {
"bedrock_id": 182, "bedrock_id": 182,
@ -548,19 +548,19 @@
"bedrock_data": 3 "bedrock_data": 3
}, },
"minecraft:smooth_quartz": { "minecraft:smooth_quartz": {
"bedrock_id": 248, "bedrock_id": 155,
"bedrock_data": 0 "bedrock_data": 3
}, },
"minecraft:smooth_red_sandstone": { "minecraft:smooth_red_sandstone": {
"bedrock_id": 248, "bedrock_id": 179,
"bedrock_data": 0 "bedrock_data": 3
}, },
"minecraft:smooth_sandstone": { "minecraft:smooth_sandstone": {
"bedrock_id": 248, "bedrock_id": 24,
"bedrock_data": 0 "bedrock_data": 3
}, },
"minecraft:smooth_stone": { "minecraft:smooth_stone": {
"bedrock_id": 248, "bedrock_id": -183,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:bricks": { "minecraft:bricks": {
@ -697,7 +697,7 @@
}, },
"minecraft:stone_button": { "minecraft:stone_button": {
"bedrock_id": 77, "bedrock_id": 77,
"bedrock_data": 5 "bedrock_data": 0
}, },
"minecraft:snow": { "minecraft:snow": {
"bedrock_id": 78, "bedrock_id": 78,
@ -988,56 +988,56 @@
"bedrock_data": 1 "bedrock_data": 1
}, },
"minecraft:brick_wall": { "minecraft:brick_wall": {
"bedrock_id": 248, "bedrock_id": 139,
"bedrock_data": 0 "bedrock_data": 6
}, },
"minecraft:prismarine_wall": { "minecraft:prismarine_wall": {
"bedrock_id": 248, "bedrock_id": 139,
"bedrock_data": 0 "bedrock_data": 11
}, },
"minecraft:red_sandstone_wall": { "minecraft:red_sandstone_wall": {
"bedrock_id": 248, "bedrock_id": 139,
"bedrock_data": 0 "bedrock_data": 12
}, },
"minecraft:mossy_stone_brick_wall": { "minecraft:mossy_stone_brick_wall": {
"bedrock_id": 248, "bedrock_id": 139,
"bedrock_data": 0 "bedrock_data": 8
}, },
"minecraft:granite_wall": { "minecraft:granite_wall": {
"bedrock_id": 248, "bedrock_id": 139,
"bedrock_data": 0 "bedrock_data": 2
}, },
"minecraft:stone_brick_wall": { "minecraft:stone_brick_wall": {
"bedrock_id": 248, "bedrock_id": 139,
"bedrock_data": 0 "bedrock_data": 7
}, },
"minecraft:nether_brick_wall": { "minecraft:nether_brick_wall": {
"bedrock_id": 248, "bedrock_id": 139,
"bedrock_data": 0 "bedrock_data": 9
}, },
"minecraft:andesite_wall": { "minecraft:andesite_wall": {
"bedrock_id": 248, "bedrock_id": 139,
"bedrock_data": 0 "bedrock_data": 4
}, },
"minecraft:red_nether_brick_wall": { "minecraft:red_nether_brick_wall": {
"bedrock_id": 248, "bedrock_id": 139,
"bedrock_data": 0 "bedrock_data": 13
}, },
"minecraft:sandstone_wall": { "minecraft:sandstone_wall": {
"bedrock_id": 248, "bedrock_id": 139,
"bedrock_data": 0 "bedrock_data": 5
}, },
"minecraft:end_stone_brick_wall": { "minecraft:end_stone_brick_wall": {
"bedrock_id": 248, "bedrock_id": 139,
"bedrock_data": 0 "bedrock_data": 10
}, },
"minecraft:diorite_wall": { "minecraft:diorite_wall": {
"bedrock_id": 248, "bedrock_id": 139,
"bedrock_data": 0 "bedrock_data": 3
}, },
"minecraft:oak_button": { "minecraft:oak_button": {
"bedrock_id": 143, "bedrock_id": 143,
"bedrock_data": 5 "bedrock_data": 0
}, },
"minecraft:spruce_button": { "minecraft:spruce_button": {
"bedrock_id": -144, "bedrock_id": -144,
@ -1121,7 +1121,7 @@
}, },
"minecraft:dropper": { "minecraft:dropper": {
"bedrock_id": 125, "bedrock_id": 125,
"bedrock_data": 3 "bedrock_data": 0
}, },
"minecraft:white_terracotta": { "minecraft:white_terracotta": {
"bedrock_id": 159, "bedrock_id": 159,
@ -1188,7 +1188,7 @@
"bedrock_data": 15 "bedrock_data": 15
}, },
"minecraft:barrier": { "minecraft:barrier": {
"bedrock_id": 95, "bedrock_id": -161,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:iron_trapdoor": { "minecraft:iron_trapdoor": {
@ -1844,24 +1844,24 @@
"bedrock_data": 4 "bedrock_data": 4
}, },
"minecraft:dead_brain_coral": { "minecraft:dead_brain_coral": {
"bedrock_id": 248, "bedrock_id": -131,
"bedrock_data": 0 "bedrock_data": 9
}, },
"minecraft:dead_bubble_coral": { "minecraft:dead_bubble_coral": {
"bedrock_id": 248, "bedrock_id": -131,
"bedrock_data": 0 "bedrock_data": 10
}, },
"minecraft:dead_fire_coral": { "minecraft:dead_fire_coral": {
"bedrock_id": 248, "bedrock_id": -131,
"bedrock_data": 0 "bedrock_data": 11
}, },
"minecraft:dead_horn_coral": { "minecraft:dead_horn_coral": {
"bedrock_id": 248, "bedrock_id": -131,
"bedrock_data": 0 "bedrock_data": 12
}, },
"minecraft:dead_tube_coral": { "minecraft:dead_tube_coral": {
"bedrock_id": 248, "bedrock_id": -131,
"bedrock_data": 0 "bedrock_data": 8
}, },
"minecraft:tube_coral_fan": { "minecraft:tube_coral_fan": {
"bedrock_id": -133, "bedrock_id": -133,
@ -1912,51 +1912,51 @@
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:polished_granite_stairs": { "minecraft:polished_granite_stairs": {
"bedrock_id": 248, "bedrock_id": -172,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:smooth_red_sandstone_stairs": { "minecraft:smooth_red_sandstone_stairs": {
"bedrock_id": 248, "bedrock_id": -176,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:mossy_stone_brick_stairs": { "minecraft:mossy_stone_brick_stairs": {
"bedrock_id": 248, "bedrock_id": -175,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:polished_diorite_stairs": { "minecraft:polished_diorite_stairs": {
"bedrock_id": 248, "bedrock_id": -173,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:mossy_cobblestone_stairs": { "minecraft:mossy_cobblestone_stairs": {
"bedrock_id": 248, "bedrock_id": -179,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:end_stone_brick_stairs": { "minecraft:end_stone_brick_stairs": {
"bedrock_id": 248, "bedrock_id": -178,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:stone_stairs": { "minecraft:stone_stairs": {
"bedrock_id": 248, "bedrock_id": -180,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:smooth_sandstone_stairs": { "minecraft:smooth_sandstone_stairs": {
"bedrock_id": 248, "bedrock_id": -177,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:smooth_quartz_stairs": { "minecraft:smooth_quartz_stairs": {
"bedrock_id": 248, "bedrock_id": -185,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:granite_stairs": { "minecraft:granite_stairs": {
"bedrock_id": 248, "bedrock_id": -169,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:andesite_stairs": { "minecraft:andesite_stairs": {
"bedrock_id": 248, "bedrock_id": -171,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:red_nether_brick_stairs": { "minecraft:red_nether_brick_stairs": {
"bedrock_id": 248, "bedrock_id": -184,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:polished_andesite_stairs": { "minecraft:polished_andesite_stairs": {
@ -1968,59 +1968,59 @@
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:polished_granite_slab": { "minecraft:polished_granite_slab": {
"bedrock_id": 248, "bedrock_id": -162,
"bedrock_data": 0 "bedrock_data": 7
}, },
"minecraft:smooth_red_sandstone_slab": { "minecraft:smooth_red_sandstone_slab": {
"bedrock_id": 248, "bedrock_id": -162,
"bedrock_data": 0 "bedrock_data": 1
}, },
"minecraft:mossy_stone_brick_slab": { "minecraft:mossy_stone_brick_slab": {
"bedrock_id": 248, "bedrock_id": -166,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:polished_diorite_slab": { "minecraft:polished_diorite_slab": {
"bedrock_id": 248, "bedrock_id": -162,
"bedrock_data": 0 "bedrock_data": 5
}, },
"minecraft:mossy_cobblestone_slab": { "minecraft:mossy_cobblestone_slab": {
"bedrock_id": 248, "bedrock_id": 182,
"bedrock_data": 0 "bedrock_data": 5
}, },
"minecraft:end_stone_brick_slab": { "minecraft:end_stone_brick_slab": {
"bedrock_id": 248, "bedrock_id": -162,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:smooth_sandstone_slab": { "minecraft:smooth_sandstone_slab": {
"bedrock_id": 248, "bedrock_id": 182,
"bedrock_data": 0 "bedrock_data": 6
}, },
"minecraft:smooth_quartz_slab": { "minecraft:smooth_quartz_slab": {
"bedrock_id": 248, "bedrock_id": -166,
"bedrock_data": 0 "bedrock_data": 1
}, },
"minecraft:granite_slab": { "minecraft:granite_slab": {
"bedrock_id": 248, "bedrock_id": -162,
"bedrock_data": 0 "bedrock_data": 6
}, },
"minecraft:andesite_slab": { "minecraft:andesite_slab": {
"bedrock_id": 248, "bedrock_id": -162,
"bedrock_data": 0 "bedrock_data": 3
}, },
"minecraft:red_nether_brick_slab": { "minecraft:red_nether_brick_slab": {
"bedrock_id": 248, "bedrock_id": 182,
"bedrock_data": 0 "bedrock_data": 7
}, },
"minecraft:polished_andesite_slab": { "minecraft:polished_andesite_slab": {
"bedrock_id": 248, "bedrock_id": -162,
"bedrock_data": 0 "bedrock_data": 2
}, },
"minecraft:diorite_slab": { "minecraft:diorite_slab": {
"bedrock_id": 248, "bedrock_id": -162,
"bedrock_data": 0 "bedrock_data": 4
}, },
"minecraft:scaffolding": { "minecraft:scaffolding": {
"bedrock_id": 248, "bedrock_id": -165,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:iron_door": { "minecraft:iron_door": {
@ -2360,7 +2360,7 @@
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:spruce_sign": { "minecraft:spruce_sign": {
"bedrock_id": 427, "bedrock_id": 472,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:birch_sign": { "minecraft:birch_sign": {
@ -2376,7 +2376,7 @@
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:dark_oak_sign": { "minecraft:dark_oak_sign": {
"bedrock_id": 276, "bedrock_id": 476,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:bucket": { "minecraft:bucket": {
@ -2588,20 +2588,20 @@
"bedrock_data": 15 "bedrock_data": 15
}, },
"minecraft:blue_dye": { "minecraft:blue_dye": {
"bedrock_id": 248, "bedrock_id": 351,
"bedrock_data": 0 "bedrock_data": 18
}, },
"minecraft:brown_dye": { "minecraft:brown_dye": {
"bedrock_id": 248, "bedrock_id": 351,
"bedrock_data": 0 "bedrock_data": 17
}, },
"minecraft:black_dye": { "minecraft:black_dye": {
"bedrock_id": 248, "bedrock_id": 351,
"bedrock_data": 0 "bedrock_data": 16
}, },
"minecraft:white_dye": { "minecraft:white_dye": {
"bedrock_id": 248, "bedrock_id": 351,
"bedrock_data": 0 "bedrock_data": 19
}, },
"minecraft:bone": { "minecraft:bone": {
"bedrock_id": 352, "bedrock_id": 352,
@ -2796,8 +2796,8 @@
"bedrock_data": 43 "bedrock_data": 43
}, },
"minecraft:cat_spawn_egg": { "minecraft:cat_spawn_egg": {
"bedrock_id": 248, "bedrock_id": 383,
"bedrock_data": 0 "bedrock_data": 75
}, },
"minecraft:cave_spider_spawn_egg": { "minecraft:cave_spider_spawn_egg": {
"bedrock_id": 383, "bedrock_id": 383,
@ -2848,8 +2848,8 @@
"bedrock_data": 104 "bedrock_data": 104
}, },
"minecraft:fox_spawn_egg": { "minecraft:fox_spawn_egg": {
"bedrock_id": 248, "bedrock_id": 383,
"bedrock_data": 0 "bedrock_data": 121
}, },
"minecraft:ghast_spawn_egg": { "minecraft:ghast_spawn_egg": {
"bedrock_id": 383, "bedrock_id": 383,
@ -2888,8 +2888,8 @@
"bedrock_data": 22 "bedrock_data": 22
}, },
"minecraft:panda_spawn_egg": { "minecraft:panda_spawn_egg": {
"bedrock_id": 248, "bedrock_id": 383,
"bedrock_data": 0 "bedrock_data": 113
}, },
"minecraft:parrot_spawn_egg": { "minecraft:parrot_spawn_egg": {
"bedrock_id": 383, "bedrock_id": 383,
@ -2904,8 +2904,8 @@
"bedrock_data": 12 "bedrock_data": 12
}, },
"minecraft:pillager_spawn_egg": { "minecraft:pillager_spawn_egg": {
"bedrock_id": 248, "bedrock_id": 383,
"bedrock_data": 0 "bedrock_data": 114
}, },
"minecraft:polar_bear_spawn_egg": { "minecraft:polar_bear_spawn_egg": {
"bedrock_id": 383, "bedrock_id": 383,
@ -2920,8 +2920,8 @@
"bedrock_data": 18 "bedrock_data": 18
}, },
"minecraft:ravager_spawn_egg": { "minecraft:ravager_spawn_egg": {
"bedrock_id": 248, "bedrock_id": 383,
"bedrock_data": 0 "bedrock_data": 59
}, },
"minecraft:salmon_spawn_egg": { "minecraft:salmon_spawn_egg": {
"bedrock_id": 383, "bedrock_id": 383,
@ -2964,8 +2964,8 @@
"bedrock_data": 46 "bedrock_data": 46
}, },
"minecraft:trader_llama_spawn_egg": { "minecraft:trader_llama_spawn_egg": {
"bedrock_id": 248, "bedrock_id": 383,
"bedrock_data": 0 "bedrock_data": 29
}, },
"minecraft:tropical_fish_spawn_egg": { "minecraft:tropical_fish_spawn_egg": {
"bedrock_id": 383, "bedrock_id": 383,
@ -2988,8 +2988,8 @@
"bedrock_data": 57 "bedrock_data": 57
}, },
"minecraft:wandering_trader_spawn_egg": { "minecraft:wandering_trader_spawn_egg": {
"bedrock_id": 248, "bedrock_id": 383,
"bedrock_data": 0 "bedrock_data": 118
}, },
"minecraft:witch_spawn_egg": { "minecraft:witch_spawn_egg": {
"bedrock_id": 383, "bedrock_id": 383,
@ -3301,18 +3301,18 @@
}, },
"minecraft:spectral_arrow": { "minecraft:spectral_arrow": {
"bedrock_id": 262, "bedrock_id": 262,
"bedrock_data": 2 "bedrock_data": 0
}, },
"minecraft:tipped_arrow": { "minecraft:tipped_arrow": {
"bedrock_id": 440, "bedrock_id": 262,
"bedrock_data": 1 "bedrock_data": 0
}, },
"minecraft:lingering_potion": { "minecraft:lingering_potion": {
"bedrock_id": 441, "bedrock_id": 441,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:shield": { "minecraft:shield": {
"bedrock_id": 268, "bedrock_id": 513,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:elytra": { "minecraft:elytra": {
@ -3356,7 +3356,7 @@
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:debug_stick": { "minecraft:debug_stick": {
"bedrock_id": 248, "bedrock_id": 280,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:music_disc_13": { "minecraft:music_disc_13": {
@ -3428,7 +3428,7 @@
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:suspicious_stew": { "minecraft:suspicious_stew": {
"bedrock_id": 248, "bedrock_id": 734,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:loom": { "minecraft:loom": {
@ -3436,75 +3436,75 @@
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:flower_banner_pattern": { "minecraft:flower_banner_pattern": {
"bedrock_id": 248, "bedrock_id": 434,
"bedrock_data": 0 "bedrock_data": 2
}, },
"minecraft:creeper_banner_pattern": { "minecraft:creeper_banner_pattern": {
"bedrock_id": 248, "bedrock_id": 434,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:skull_banner_pattern": { "minecraft:skull_banner_pattern": {
"bedrock_id": 248, "bedrock_id": 434,
"bedrock_data": 0 "bedrock_data": 1
}, },
"minecraft:mojang_banner_pattern": { "minecraft:mojang_banner_pattern": {
"bedrock_id": 248, "bedrock_id": 434,
"bedrock_data": 0 "bedrock_data": 3
}, },
"minecraft:globe_banner_pattern": { "minecraft:globe_banner_pattern": {
"bedrock_id": 248, "bedrock_id": 434,
"bedrock_data": 0 "bedrock_data": 4
}, },
"minecraft:barrel": { "minecraft:barrel": {
"bedrock_id": 248, "bedrock_id": -203,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:smoker": { "minecraft:smoker": {
"bedrock_id": 248, "bedrock_id": -198,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:blast_furnace": { "minecraft:blast_furnace": {
"bedrock_id": 248, "bedrock_id": -196,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:cartography_table": { "minecraft:cartography_table": {
"bedrock_id": 248, "bedrock_id": -200,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:fletching_table": { "minecraft:fletching_table": {
"bedrock_id": 248, "bedrock_id": -201,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:grindstone": { "minecraft:grindstone": {
"bedrock_id": 248, "bedrock_id": -195,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:lectern": { "minecraft:lectern": {
"bedrock_id": 248, "bedrock_id": -194,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:smithing_table": { "minecraft:smithing_table": {
"bedrock_id": 248, "bedrock_id": -202,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:stonecutter": { "minecraft:stonecutter": {
"bedrock_id": 248, "bedrock_id": -197,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:bell": { "minecraft:bell": {
"bedrock_id": 248, "bedrock_id": -206,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:lantern": { "minecraft:lantern": {
"bedrock_id": 248, "bedrock_id": -208,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:sweet_berries": { "minecraft:sweet_berries": {
"bedrock_id": 248, "bedrock_id": 477,
"bedrock_data": 0 "bedrock_data": 0
}, },
"minecraft:campfire": { "minecraft:campfire": {
"bedrock_id": 248, "bedrock_id": 720,
"bedrock_data": 0 "bedrock_data": 0
} }
} }

View file

@ -88,7 +88,7 @@
<resources> <resources>
<resource> <resource>
<directory>src/main/resources/</directory> <directory>src/main/resources/</directory>
<filtering>true</filtering> <filtering>false</filtering>
</resource> </resource>
</resources> </resources>
<plugins> <plugins>