mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-15 14:13:56 +01:00
More more patches
This commit is contained in:
parent
3f1ea3f769
commit
588aa467be
59 changed files with 130 additions and 106 deletions
|
@ -1,6 +1,5 @@
|
||||||
group=io.papermc.paper
|
group=io.papermc.paper
|
||||||
version=1.19-R0.1-SNAPSHOT
|
version=1.19-R0.1-SNAPSHOT
|
||||||
|
|
||||||
mcVersion=1.19
|
mcVersion=1.19
|
||||||
|
|
||||||
org.gradle.caching=true
|
org.gradle.caching=true
|
||||||
|
|
|
@ -30,7 +30,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@@ -0,0 +0,0 @@ public class FrostedIceBlock extends IceBlock {
|
@@ -0,0 +0,0 @@ public class FrostedIceBlock extends IceBlock {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void tick(BlockState state, ServerLevel world, BlockPos pos, Random random) {
|
public void tick(BlockState state, ServerLevel world, BlockPos pos, RandomSource random) {
|
||||||
+ if (!world.paperConfig.frostedIceEnabled) return; // Paper - add ability to disable frosted ice
|
+ if (!world.paperConfig.frostedIceEnabled) return; // Paper - add ability to disable frosted ice
|
||||||
if ((random.nextInt(3) == 0 || this.fewerNeigboursThan(world, pos, 4)) && world.getMaxLocalRawBrightness(pos) > 11 - state.getValue(AGE) - state.getLightBlock(world, pos) && this.slightlyMelt(state, world, pos)) {
|
if ((random.nextInt(3) == 0 || this.fewerNeigboursThan(world, pos, 4)) && world.getMaxLocalRawBrightness(pos) > 11 - state.getValue(AGE) - state.getLightBlock(world, pos) && this.slightlyMelt(state, world, pos)) {
|
||||||
BlockPos.MutableBlockPos mutableBlockPos = new BlockPos.MutableBlockPos();
|
BlockPos.MutableBlockPos mutableBlockPos = new BlockPos.MutableBlockPos();
|
|
@ -10,7 +10,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/network/ServerHandshakePacketListenerImpl.java
|
--- a/src/main/java/net/minecraft/server/network/ServerHandshakePacketListenerImpl.java
|
||||||
+++ b/src/main/java/net/minecraft/server/network/ServerHandshakePacketListenerImpl.java
|
+++ b/src/main/java/net/minecraft/server/network/ServerHandshakePacketListenerImpl.java
|
||||||
@@ -0,0 +0,0 @@ public class ServerHandshakePacketListenerImpl implements ServerHandshakePacketL
|
@@ -0,0 +0,0 @@ public class ServerHandshakePacketListenerImpl implements ServerHandshakePacketL
|
||||||
this.connection.disconnect(chatmessage);
|
this.connection.disconnect(ichatmutablecomponent);
|
||||||
} else {
|
} else {
|
||||||
this.connection.setListener(new ServerLoginPacketListenerImpl(this.server, this.connection));
|
this.connection.setListener(new ServerLoginPacketListenerImpl(this.server, this.connection));
|
||||||
+ // Paper start - handshake event
|
+ // Paper start - handshake event
|
|
@ -37,11 +37,11 @@ diff --git a/src/main/java/net/minecraft/world/level/chunk/ChunkGenerator.java b
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/world/level/chunk/ChunkGenerator.java
|
--- a/src/main/java/net/minecraft/world/level/chunk/ChunkGenerator.java
|
||||||
+++ b/src/main/java/net/minecraft/world/level/chunk/ChunkGenerator.java
|
+++ b/src/main/java/net/minecraft/world/level/chunk/ChunkGenerator.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class ChunkGenerator implements BiomeManager.NoiseBiomeSource {
|
@@ -0,0 +0,0 @@ public abstract class ChunkGenerator {
|
||||||
int l1 = i + i1 * j1;
|
|
||||||
int i2 = j + i1 * k1;
|
|
||||||
ChunkPos chunkcoordintpair = randomspreadstructureplacement.getPotentialFeatureChunk(l, l1, i2);
|
|
||||||
+ if (!iworldreader.getWorldBorder().isChunkInBounds(chunkcoordintpair.x, chunkcoordintpair.z)) { continue; } // Paper
|
|
||||||
Iterator iterator = set.iterator();
|
|
||||||
|
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
|
ChunkPos chunkcoordintpair = (ChunkPos) iterator.next();
|
||||||
|
+ if (!world.getWorldBorder().isChunkInBounds(chunkcoordintpair.x, chunkcoordintpair.z)) { continue; } // Paper
|
||||||
|
|
||||||
|
blockposition_mutableblockposition.set(SectionPos.sectionToBlockCoord(chunkcoordintpair.x, 8), 32, SectionPos.sectionToBlockCoord(chunkcoordintpair.z, 8));
|
||||||
|
double d1 = blockposition_mutableblockposition.distSqr(center);
|
|
@ -10,7 +10,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
||||||
@@ -0,0 +0,0 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Ser
|
@@ -0,0 +0,0 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Ser
|
||||||
ServerGamePacketListenerImpl.LOGGER.info("Disconnecting {} due to resource pack rejection", this.player.getName());
|
ServerGamePacketListenerImpl.LOGGER.info("Disconnecting {} due to resource pack rejection", this.player.getName());
|
||||||
this.disconnect(new TranslatableComponent("multiplayer.requiredTexturePrompt.disconnect"));
|
this.disconnect(Component.translatable("multiplayer.requiredTexturePrompt.disconnect"));
|
||||||
}
|
}
|
||||||
- this.cserver.getPluginManager().callEvent(new PlayerResourcePackStatusEvent(this.getCraftPlayer(), PlayerResourcePackStatusEvent.Status.values()[packet.action.ordinal()])); // CraftBukkit
|
- this.cserver.getPluginManager().callEvent(new PlayerResourcePackStatusEvent(this.getCraftPlayer(), PlayerResourcePackStatusEvent.Status.values()[packet.action.ordinal()])); // CraftBukkit
|
||||||
-
|
-
|
|
@ -58,9 +58,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
return null;
|
return null;
|
||||||
} else {
|
} else {
|
||||||
ServerLevel serverLevel = (ServerLevel)entity.level;
|
ServerLevel serverLevel = (ServerLevel)entity.level;
|
||||||
- BlockPos blockPos = serverLevel.findNearestMapFeature(this.destination, entity.blockPosition(), 100, true);
|
- BlockPos blockPos = serverLevel.findNearestMapStructure(this.destination, entity.blockPosition(), 100, true);
|
||||||
+ if (!serverLevel.paperConfig.enableTreasureMaps) return null; // Paper
|
+ if (!serverLevel.paperConfig.enableTreasureMaps) return null; // Paper
|
||||||
+ BlockPos blockPos = serverLevel.findNearestMapFeature(this.destination, entity.blockPosition(), 100, !serverLevel.paperConfig.treasureMapsAlreadyDiscoveredVillager); // Paper
|
+ BlockPos blockPos = serverLevel.findNearestMapStructure(this.destination, entity.blockPosition(), 100, !serverLevel.paperConfig.treasureMapsAlreadyDiscoveredVillager); // Paper
|
||||||
if (blockPos != null) {
|
if (blockPos != null) {
|
||||||
ItemStack itemStack = MapItem.create(serverLevel, blockPos.getX(), blockPos.getZ(), (byte)2, true, true);
|
ItemStack itemStack = MapItem.create(serverLevel, blockPos.getX(), blockPos.getZ(), (byte)2, true, true);
|
||||||
MapItem.renderBiomePreviewMap(serverLevel, itemStack);
|
MapItem.renderBiomePreviewMap(serverLevel, itemStack);
|
||||||
|
@ -72,7 +72,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
Vec3 vec3 = context.getParamOrNull(LootContextParams.ORIGIN);
|
Vec3 vec3 = context.getParamOrNull(LootContextParams.ORIGIN);
|
||||||
if (vec3 != null) {
|
if (vec3 != null) {
|
||||||
ServerLevel serverLevel = context.getLevel();
|
ServerLevel serverLevel = context.getLevel();
|
||||||
- BlockPos blockPos = serverLevel.findNearestMapFeature(this.destination, new BlockPos(vec3), this.searchRadius, this.skipKnownStructures);
|
- BlockPos blockPos = serverLevel.findNearestMapStructure(this.destination, new BlockPos(vec3), this.searchRadius, this.skipKnownStructures);
|
||||||
+ // Paper start
|
+ // Paper start
|
||||||
+ if (!serverLevel.paperConfig.enableTreasureMaps) {
|
+ if (!serverLevel.paperConfig.enableTreasureMaps) {
|
||||||
+ /*
|
+ /*
|
||||||
|
@ -82,7 +82,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ return stack;
|
+ return stack;
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
+ BlockPos blockPos = serverLevel.findNearestMapFeature(this.destination, new BlockPos(vec3), this.searchRadius, serverLevel.paperConfig.treasureMapsAlreadyDiscoveredLootTable == null ? this.skipKnownStructures : serverLevel.paperConfig.treasureMapsAlreadyDiscoveredLootTable); // Paper
|
+ BlockPos blockPos = serverLevel.findNearestMapStructure(this.destination, new BlockPos(vec3), this.searchRadius, serverLevel.paperConfig.treasureMapsAlreadyDiscoveredLootTable == null ? this.skipKnownStructures : serverLevel.paperConfig.treasureMapsAlreadyDiscoveredLootTable); // Paper
|
||||||
if (blockPos != null) {
|
if (blockPos != null) {
|
||||||
ItemStack itemStack = MapItem.create(serverLevel, blockPos.getX(), blockPos.getZ(), this.zoom, true, true);
|
ItemStack itemStack = MapItem.create(serverLevel, blockPos.getX(), blockPos.getZ(), this.zoom, true, true);
|
||||||
MapItem.renderBiomePreviewMap(serverLevel, itemStack);
|
MapItem.renderBiomePreviewMap(serverLevel, itemStack);
|
|
@ -46,4 +46,4 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
@Override
|
@Override
|
||||||
public GameEventDispatcher getEventDispatcher(int ySectionCoord) {
|
public GameEventDispatcher getEventDispatcher(int ySectionCoord) {
|
||||||
return (GameEventDispatcher) this.gameEventDispatcherSections.computeIfAbsent(ySectionCoord, (j) -> {
|
Level world = this.level;
|
|
@ -24,17 +24,17 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/world/level/block/SpreadingSnowyDirtBlock.java
|
--- a/src/main/java/net/minecraft/world/level/block/SpreadingSnowyDirtBlock.java
|
||||||
+++ b/src/main/java/net/minecraft/world/level/block/SpreadingSnowyDirtBlock.java
|
+++ b/src/main/java/net/minecraft/world/level/block/SpreadingSnowyDirtBlock.java
|
||||||
@@ -0,0 +0,0 @@ package net.minecraft.world.level.block;
|
@@ -0,0 +0,0 @@ package net.minecraft.world.level.block;
|
||||||
import java.util.Random;
|
|
||||||
import net.minecraft.core.BlockPos;
|
import net.minecraft.core.BlockPos;
|
||||||
import net.minecraft.core.Direction;
|
import net.minecraft.core.Direction;
|
||||||
+import net.minecraft.server.MinecraftServer;
|
+import net.minecraft.server.MinecraftServer;
|
||||||
import net.minecraft.server.level.ServerLevel;
|
import net.minecraft.server.level.ServerLevel;
|
||||||
import net.minecraft.tags.FluidTags;
|
import net.minecraft.tags.FluidTags;
|
||||||
import net.minecraft.world.level.LevelReader;
|
import net.minecraft.util.RandomSource;
|
||||||
@@ -0,0 +0,0 @@ public abstract class SpreadingSnowyDirtBlock extends SnowyDirtBlock {
|
@@ -0,0 +0,0 @@ public abstract class SpreadingSnowyDirtBlock extends SnowyDirtBlock {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void randomTick(BlockState state, ServerLevel world, BlockPos pos, Random random) {
|
public void randomTick(BlockState state, ServerLevel world, BlockPos pos, RandomSource random) {
|
||||||
+ if (this instanceof GrassBlock && world.paperConfig.grassUpdateRate != 1 && (world.paperConfig.grassUpdateRate < 1 || (MinecraftServer.currentTick + pos.hashCode()) % world.paperConfig.grassUpdateRate != 0)) { return; } // Paper
|
+ if (this instanceof GrassBlock && world.paperConfig.grassUpdateRate != 1 && (world.paperConfig.grassUpdateRate < 1 || (MinecraftServer.currentTick + pos.hashCode()) % world.paperConfig.grassUpdateRate != 0)) { return; } // Paper
|
||||||
if (!SpreadingSnowyDirtBlock.canBeGrass(state, world, pos)) {
|
if (!SpreadingSnowyDirtBlock.canBeGrass(state, world, pos)) {
|
||||||
// CraftBukkit start
|
// CraftBukkit start
|
|
@ -19,9 +19,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
public DedicatedServerProperties(Properties properties, OptionSet optionset) {
|
public DedicatedServerProperties(Properties properties, OptionSet optionset) {
|
||||||
super(properties, optionset);
|
super(properties, optionset);
|
||||||
@@ -0,0 +0,0 @@ public class DedicatedServerProperties extends Settings<DedicatedServerPropertie
|
@@ -0,0 +0,0 @@ public class DedicatedServerProperties extends Settings<DedicatedServerPropertie
|
||||||
}, new JsonObject()), this.get("generate-structures", true), (String) this.get("level-type", (s) -> {
|
|
||||||
return s.toLowerCase(Locale.ROOT);
|
return s.toLowerCase(Locale.ROOT);
|
||||||
}, "default"));
|
}, WorldPresets.NORMAL.location().toString()));
|
||||||
|
this.serverResourcePackInfo = DedicatedServerProperties.getServerPackInfo(this.get("resource-pack", ""), this.get("resource-pack-sha1", ""), this.getLegacyString("resource-pack-hash"), this.get("require-resource-pack", false), this.get("resource-pack-prompt", ""));
|
||||||
+ // Paper start - Configurable rcon ip
|
+ // Paper start - Configurable rcon ip
|
||||||
+ final String rconIp = this.getStringRaw("rcon.ip");
|
+ final String rconIp = this.getStringRaw("rcon.ip");
|
||||||
+ this.rconIp = rconIp == null ? this.serverIp : rconIp;
|
+ this.rconIp = rconIp == null ? this.serverIp : rconIp;
|
|
@ -28,7 +28,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
if (this.clientIsFloating && !this.player.isSleeping() && !this.player.isPassenger()) {
|
if (this.clientIsFloating && !this.player.isSleeping() && !this.player.isPassenger()) {
|
||||||
if (++this.aboveGroundTickCount > 80) {
|
if (++this.aboveGroundTickCount > 80) {
|
||||||
ServerGamePacketListenerImpl.LOGGER.warn("{} was kicked for floating too long!", this.player.getName().getString());
|
ServerGamePacketListenerImpl.LOGGER.warn("{} was kicked for floating too long!", this.player.getName().getString());
|
||||||
- this.disconnect(new TranslatableComponent("multiplayer.disconnect.flying"));
|
- this.disconnect(Component.translatable("multiplayer.disconnect.flying"));
|
||||||
+ this.disconnect(com.destroystokyo.paper.PaperConfig.flyingKickPlayerMessage); // Paper - use configurable kick message
|
+ this.disconnect(com.destroystokyo.paper.PaperConfig.flyingKickPlayerMessage); // Paper - use configurable kick message
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -37,7 +37,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
if (this.clientVehicleIsFloating && this.player.getRootVehicle().getControllingPassenger() == this.player) {
|
if (this.clientVehicleIsFloating && this.player.getRootVehicle().getControllingPassenger() == this.player) {
|
||||||
if (++this.aboveGroundVehicleTickCount > 80) {
|
if (++this.aboveGroundVehicleTickCount > 80) {
|
||||||
ServerGamePacketListenerImpl.LOGGER.warn("{} was kicked for floating a vehicle too long!", this.player.getName().getString());
|
ServerGamePacketListenerImpl.LOGGER.warn("{} was kicked for floating a vehicle too long!", this.player.getName().getString());
|
||||||
- this.disconnect(new TranslatableComponent("multiplayer.disconnect.flying"));
|
- this.disconnect(Component.translatable("multiplayer.disconnect.flying"));
|
||||||
+ this.disconnect(com.destroystokyo.paper.PaperConfig.flyingKickVehicleMessage); // Paper - use configurable kick message
|
+ this.disconnect(com.destroystokyo.paper.PaperConfig.flyingKickVehicleMessage); // Paper - use configurable kick message
|
||||||
return;
|
return;
|
||||||
}
|
}
|
|
@ -14,6 +14,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
- if (!GameProfileCache.usesAuthentication() && gameprofile == null) {
|
- if (!GameProfileCache.usesAuthentication() && gameprofile == null) {
|
||||||
+ if (!GameProfileCache.usesAuthentication() && gameprofile == null && !org.apache.commons.lang3.StringUtils.isBlank(name)) { // Paper - Don't lookup a profile with a blank name
|
+ if (!GameProfileCache.usesAuthentication() && gameprofile == null && !org.apache.commons.lang3.StringUtils.isBlank(name)) { // Paper - Don't lookup a profile with a blank name
|
||||||
UUID uuid = Player.createPlayerUUID(new GameProfile((UUID) null, name));
|
UUID uuid = UUIDUtil.getOrCreatePlayerUUID(new GameProfile((UUID) null, name));
|
||||||
|
|
||||||
return Optional.of(new GameProfile(uuid, name));
|
return Optional.of(new GameProfile(uuid, name));
|
|
@ -22,5 +22,5 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
// CraftBukkit end
|
// CraftBukkit end
|
||||||
+ new com.destroystokyo.paper.event.entity.EntityRemoveFromWorldEvent(entity.getBukkitEntity()).callEvent(); // Paper - fire while valid
|
+ new com.destroystokyo.paper.event.entity.EntityRemoveFromWorldEvent(entity.getBukkitEntity()).callEvent(); // Paper - fire while valid
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
public void onSectionChange(Entity entity) {
|
|
@ -32,7 +32,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
public static final int RESTART_DELAY = 160;
|
public static final int RESTART_DELAY = 160;
|
||||||
@@ -0,0 +0,0 @@ public class RedstoneTorchBlock extends TorchBlock {
|
@@ -0,0 +0,0 @@ public class RedstoneTorchBlock extends TorchBlock {
|
||||||
@Override
|
@Override
|
||||||
public void tick(BlockState state, ServerLevel world, BlockPos pos, Random random) {
|
public void tick(BlockState state, ServerLevel world, BlockPos pos, RandomSource random) {
|
||||||
boolean flag = this.hasNeighborSignal(world, pos, state);
|
boolean flag = this.hasNeighborSignal(world, pos, state);
|
||||||
- List list = (List) RedstoneTorchBlock.RECENT_TOGGLES.get(world);
|
- List list = (List) RedstoneTorchBlock.RECENT_TOGGLES.get(world);
|
||||||
-
|
-
|
|
@ -0,0 +1,18 @@
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Aikar <aikar@aikar.co>
|
||||||
|
Date: Sun, 3 Apr 2016 17:48:50 -0400
|
||||||
|
Subject: [PATCH] Fix Cancelling BlockPlaceEvent triggering physics
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/server/level/ServerLevel.java b/src/main/java/net/minecraft/server/level/ServerLevel.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/server/level/ServerLevel.java
|
||||||
|
+++ b/src/main/java/net/minecraft/server/level/ServerLevel.java
|
||||||
|
@@ -0,0 +0,0 @@ public class ServerLevel extends Level implements WorldGenLevel {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateNeighborsAt(BlockPos pos, Block sourceBlock) {
|
||||||
|
+ if (captureBlockStates) { return; } // Paper - Cancel all physics during placement
|
||||||
|
this.neighborUpdater.updateNeighborsAtExceptFromFacing(pos, sourceBlock, (Direction) null);
|
||||||
|
}
|
||||||
|
|
|
@ -519,7 +519,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/world/entity/Entity.java
|
--- a/src/main/java/net/minecraft/world/entity/Entity.java
|
||||||
+++ b/src/main/java/net/minecraft/world/entity/Entity.java
|
+++ b/src/main/java/net/minecraft/world/entity/Entity.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource {
|
@@ -0,0 +0,0 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource {
|
||||||
};
|
}
|
||||||
// Paper end
|
// Paper end
|
||||||
|
|
||||||
+ public com.destroystokyo.paper.loottable.PaperLootableInventoryData lootableData; // Paper
|
+ public com.destroystokyo.paper.loottable.PaperLootableInventoryData lootableData; // Paper
|
||||||
|
@ -542,49 +542,58 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@Override
|
@Override
|
||||||
protected void addAdditionalSaveData(CompoundTag nbt) {
|
protected void addAdditionalSaveData(CompoundTag nbt) {
|
||||||
super.addAdditionalSaveData(nbt);
|
super.addAdditionalSaveData(nbt);
|
||||||
+ this.lootableData.saveNbt(nbt); // Paper
|
+ this.lootableData.loadNbt(nbt); // Paper
|
||||||
if (this.lootTable != null) {
|
this.addChestVehicleSaveData(nbt);
|
||||||
nbt.putString("LootTable", this.lootTable.toString());
|
|
||||||
if (this.lootTableSeed != 0L) {
|
|
||||||
nbt.putLong("LootTableSeed", this.lootTableSeed);
|
|
||||||
}
|
|
||||||
- } else {
|
|
||||||
+ } if (true) { // Paper - Always save the items, Table may stick around
|
|
||||||
ContainerHelper.saveAllItems(nbt, this.itemStacks);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public abstract class AbstractMinecartContainer extends AbstractMinecart impleme
|
|
||||||
@Override
|
@Override
|
||||||
protected void readAdditionalSaveData(CompoundTag nbt) {
|
protected void readAdditionalSaveData(CompoundTag nbt) {
|
||||||
super.readAdditionalSaveData(nbt);
|
super.readAdditionalSaveData(nbt);
|
||||||
+ this.lootableData.loadNbt(nbt); // Paper
|
+ this.lootableData.loadNbt(nbt); // Paper
|
||||||
this.itemStacks = NonNullList.withSize(this.getContainerSize(), ItemStack.EMPTY);
|
this.readChestVehicleSaveData(nbt);
|
||||||
if (nbt.contains("LootTable", 8)) {
|
}
|
||||||
this.lootTable = new ResourceLocation(nbt.getString("LootTable"));
|
|
||||||
this.lootTableSeed = nbt.getLong("LootTableSeed");
|
diff --git a/src/main/java/net/minecraft/world/entity/vehicle/ChestBoat.java b/src/main/java/net/minecraft/world/entity/vehicle/ChestBoat.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/entity/vehicle/ChestBoat.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/entity/vehicle/ChestBoat.java
|
||||||
|
@@ -0,0 +0,0 @@ public class ChestBoat extends Boat implements HasCustomInventoryScreen, Contain
|
||||||
|
@Override
|
||||||
|
protected void addAdditionalSaveData(CompoundTag nbt) {
|
||||||
|
super.addAdditionalSaveData(nbt);
|
||||||
|
+ this.lootableData.loadNbt(nbt); // Paper
|
||||||
|
this.addChestVehicleSaveData(nbt);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void readAdditionalSaveData(CompoundTag nbt) {
|
||||||
|
super.readAdditionalSaveData(nbt);
|
||||||
|
+ this.lootableData.loadNbt(nbt); // Paper
|
||||||
|
this.readChestVehicleSaveData(nbt);
|
||||||
|
}
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/entity/vehicle/ContainerEntity.java b/src/main/java/net/minecraft/world/entity/vehicle/ContainerEntity.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/entity/vehicle/ContainerEntity.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/entity/vehicle/ContainerEntity.java
|
||||||
|
@@ -0,0 +0,0 @@ public interface ContainerEntity extends Container, MenuProvider {
|
||||||
|
if (this.getLootTableSeed() != 0L) {
|
||||||
|
nbt.putLong("LootTableSeed", this.getLootTableSeed());
|
||||||
|
}
|
||||||
- } else {
|
- } else {
|
||||||
+ } if (true) { // Paper - always load the items, table may still remain
|
+ } else if (true) { // Paper - always load the items, table may still remain
|
||||||
ContainerHelper.loadAllItems(nbt, this.itemStacks);
|
ContainerHelper.saveAllItems(nbt, this.getItemStacks());
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public abstract class AbstractMinecartContainer extends AbstractMinecart impleme
|
@@ -0,0 +0,0 @@ public interface ContainerEntity extends Container, MenuProvider {
|
||||||
|
if (nbt.contains("LootTable", 8)) {
|
||||||
|
this.setLootTable(new ResourceLocation(nbt.getString("LootTable")));
|
||||||
|
this.setLootTableSeed(nbt.getLong("LootTableSeed"));
|
||||||
|
- } else {
|
||||||
|
+ } else if (true) { // Paper - always load the items, table may still remain
|
||||||
|
ContainerHelper.loadAllItems(nbt, this.getItemStacks());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void unpackLootTable(@Nullable Player player) {
|
|
||||||
- if (this.lootTable != null && this.level.getServer() != null) {
|
|
||||||
+ if (this.lootableData.shouldReplenish(player) && this.level.getServer() != null) { // Paper
|
|
||||||
LootTable loottable = this.level.getServer().getLootTables().get(this.lootTable);
|
|
||||||
|
|
||||||
if (player instanceof ServerPlayer) {
|
|
||||||
CriteriaTriggers.GENERATE_LOOT.trigger((ServerPlayer) player, this.lootTable);
|
|
||||||
}
|
|
||||||
|
|
||||||
- this.lootTable = null;
|
|
||||||
+ //this.lootTable = null; // Paper
|
|
||||||
+ this.lootableData.processRefill(player); // Paper
|
|
||||||
LootContext.Builder loottableinfo_builder = (new LootContext.Builder((ServerLevel) this.level)).withParameter(LootContextParams.ORIGIN, this.position()).withOptionalRandomSeed(this.lootTableSeed);
|
|
||||||
|
|
||||||
if (player != null) {
|
|
||||||
diff --git a/src/main/java/net/minecraft/world/level/block/entity/RandomizableContainerBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/RandomizableContainerBlockEntity.java
|
diff --git a/src/main/java/net/minecraft/world/level/block/entity/RandomizableContainerBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/RandomizableContainerBlockEntity.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/world/level/block/entity/RandomizableContainerBlockEntity.java
|
--- a/src/main/java/net/minecraft/world/level/block/entity/RandomizableContainerBlockEntity.java
|
|
@ -22,7 +22,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/server/level/ServerLevel.java
|
--- a/src/main/java/net/minecraft/server/level/ServerLevel.java
|
||||||
+++ b/src/main/java/net/minecraft/server/level/ServerLevel.java
|
+++ b/src/main/java/net/minecraft/server/level/ServerLevel.java
|
||||||
@@ -0,0 +0,0 @@ public class ServerLevel extends Level implements WorldGenLevel {
|
@@ -0,0 +0,0 @@ public class ServerLevel extends Level implements WorldGenLevel {
|
||||||
private int tickPosition;
|
// CraftBukkit start
|
||||||
public final LevelStorageSource.LevelStorageAccess convertable;
|
public final LevelStorageSource.LevelStorageAccess convertable;
|
||||||
public final UUID uuid;
|
public final UUID uuid;
|
||||||
+ public boolean hasPhysicsEvent = true; // Paper
|
+ public boolean hasPhysicsEvent = true; // Paper
|
||||||
|
@ -42,15 +42,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
BlockPhysicsEvent event = new BlockPhysicsEvent(world.getBlockAt(blockposition.getX(), blockposition.getY(), blockposition.getZ()), CraftBlockData.fromData(iblockdata));
|
BlockPhysicsEvent event = new BlockPhysicsEvent(world.getBlockAt(blockposition.getX(), blockposition.getY(), blockposition.getZ()), CraftBlockData.fromData(iblockdata));
|
||||||
this.getCraftServer().getPluginManager().callEvent(event);
|
this.getCraftServer().getPluginManager().callEvent(event);
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public abstract class Level implements LevelAccessor, AutoCloseable {
|
|
||||||
try {
|
|
||||||
// CraftBukkit start
|
|
||||||
CraftWorld world = ((ServerLevel) this).getWorld();
|
|
||||||
- if (world != null) {
|
|
||||||
+ if (world != null && ((ServerLevel)this).hasPhysicsEvent) { // Paper
|
|
||||||
BlockPhysicsEvent event = new BlockPhysicsEvent(world.getBlockAt(pos.getX(), pos.getY(), pos.getZ()), CraftBlockData.fromData(iblockdata), world.getBlockAt(neighborPos.getX(), neighborPos.getY(), neighborPos.getZ()));
|
|
||||||
this.getCraftServer().getPluginManager().callEvent(event);
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/world/level/block/BushBlock.java b/src/main/java/net/minecraft/world/level/block/BushBlock.java
|
diff --git a/src/main/java/net/minecraft/world/level/block/BushBlock.java b/src/main/java/net/minecraft/world/level/block/BushBlock.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/world/level/block/BushBlock.java
|
--- a/src/main/java/net/minecraft/world/level/block/BushBlock.java
|
|
@ -24,7 +24,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ private final int divideAdd; private final long divideAddUnsigned; // Paper
|
+ private final int divideAdd; private final long divideAddUnsigned; // Paper
|
||||||
private final int divideShift;
|
private final int divideShift;
|
||||||
|
|
||||||
public SimpleBitStorage(int elementBits, int size, int[] is) {
|
public SimpleBitStorage(int elementBits, int size, int[] data) {
|
||||||
@@ -0,0 +0,0 @@ public class SimpleBitStorage implements BitStorage {
|
@@ -0,0 +0,0 @@ public class SimpleBitStorage implements BitStorage {
|
||||||
this.mask = (1L << elementBits) - 1L;
|
this.mask = (1L << elementBits) - 1L;
|
||||||
this.valuesPerLong = (char)(64 / elementBits);
|
this.valuesPerLong = (char)(64 / elementBits);
|
|
@ -92,7 +92,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/net/minecraft/world/level/chunk/LevelChunk.java
|
--- a/src/main/java/net/minecraft/world/level/chunk/LevelChunk.java
|
||||||
+++ b/src/main/java/net/minecraft/world/level/chunk/LevelChunk.java
|
+++ b/src/main/java/net/minecraft/world/level/chunk/LevelChunk.java
|
||||||
@@ -0,0 +0,0 @@ public class LevelChunk extends ChunkAccess {
|
@@ -0,0 +0,0 @@ public class LevelChunk extends ChunkAccess {
|
||||||
});
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
+ // Paper start - Optimize getBlockData to reduce instructions
|
+ // Paper start - Optimize getBlockData to reduce instructions
|
|
@ -9,13 +9,23 @@ diff --git a/src/main/java/net/minecraft/world/entity/Entity.java b/src/main/jav
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/world/entity/Entity.java
|
--- a/src/main/java/net/minecraft/world/entity/Entity.java
|
||||||
+++ b/src/main/java/net/minecraft/world/entity/Entity.java
|
+++ b/src/main/java/net/minecraft/world/entity/Entity.java
|
||||||
|
@@ -0,0 +0,0 @@ import net.minecraft.world.level.entity.EntityInLevelCallback;
|
||||||
|
import net.minecraft.world.level.gameevent.DynamicGameEventListener;
|
||||||
|
import net.minecraft.world.level.gameevent.GameEvent;
|
||||||
|
import net.minecraft.world.level.levelgen.Heightmap;
|
||||||
|
+import net.minecraft.world.level.levelgen.PositionalRandomFactory;
|
||||||
|
import net.minecraft.world.level.material.Fluid;
|
||||||
|
import net.minecraft.world.level.material.FluidState;
|
||||||
|
import net.minecraft.world.level.material.PushReaction;
|
||||||
@@ -0,0 +0,0 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource {
|
@@ -0,0 +0,0 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource {
|
||||||
return tag.contains("Bukkit.updateLevel") && tag.getInt("Bukkit.updateLevel") >= level;
|
return tag.contains("Bukkit.updateLevel") && tag.getInt("Bukkit.updateLevel") >= level;
|
||||||
}
|
}
|
||||||
|
|
||||||
+ // Paper start
|
+ // Paper start
|
||||||
+ public static Random SHARED_RANDOM = new Random() {
|
+ public static RandomSource SHARED_RANDOM = new RandomRandomSource();
|
||||||
|
+ private static final class RandomRandomSource extends java.util.Random implements RandomSource {
|
||||||
+ private boolean locked = false;
|
+ private boolean locked = false;
|
||||||
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public synchronized void setSeed(long seed) {
|
+ public synchronized void setSeed(long seed) {
|
||||||
+ if (locked) {
|
+ if (locked) {
|
||||||
|
@ -25,7 +35,22 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ locked = true;
|
+ locked = true;
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ };
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public RandomSource fork() {
|
||||||
|
+ return new net.minecraft.world.level.levelgen.LegacyRandomSource(this.nextLong());
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public PositionalRandomFactory forkPositional() {
|
||||||
|
+ return new net.minecraft.world.level.levelgen.LegacyRandomSource.LegacyPositionalRandomFactory(this.nextLong());
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public int nextInt(int origin, int bound) {
|
||||||
|
+ return RandomSource.super.nextInt(origin, bound);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
+
|
+
|
||||||
private CraftEntity bukkitEntity;
|
private CraftEntity bukkitEntity;
|
||||||
|
@ -35,7 +60,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
this.bb = Entity.INITIAL_AABB;
|
this.bb = Entity.INITIAL_AABB;
|
||||||
this.stuckSpeedMultiplier = Vec3.ZERO;
|
this.stuckSpeedMultiplier = Vec3.ZERO;
|
||||||
this.nextStep = 1.0F;
|
this.nextStep = 1.0F;
|
||||||
- this.random = new Random();
|
- this.random = RandomSource.create();
|
||||||
+ this.random = SHARED_RANDOM; // Paper
|
+ this.random = SHARED_RANDOM; // Paper
|
||||||
this.remainingFireTicks = -this.getFireImmuneTicks();
|
this.remainingFireTicks = -this.getFireImmuneTicks();
|
||||||
this.fluidHeight = new Object2DoubleArrayMap(2);
|
this.fluidHeight = new Object2DoubleArrayMap(2);
|
|
@ -19,7 +19,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
private static final float AVERAGE_TICK_TIME_SMOOTHING = 0.8F;
|
private static final float AVERAGE_TICK_TIME_SMOOTHING = 0.8F;
|
||||||
@@ -0,0 +0,0 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
@@ -0,0 +0,0 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
||||||
|
|
||||||
public MinecraftServer(OptionSet options, DataPackConfig datapackconfiguration, DynamicOps<Tag> registryreadops, Thread thread, LevelStorageSource.LevelStorageAccess convertable_conversionsession, PackRepository resourcepackrepository, WorldStem worldstem, Proxy proxy, DataFixer datafixer, @Nullable MinecraftSessionService minecraftsessionservice, @Nullable GameProfileRepository gameprofilerepository, @Nullable GameProfileCache usercache, ChunkProgressListenerFactory worldloadlistenerfactory) {
|
public MinecraftServer(OptionSet options, DataPackConfig datapackconfiguration, DynamicOps<Tag> registryreadops, Thread thread, LevelStorageSource.LevelStorageAccess convertable_conversionsession, PackRepository resourcepackrepository, WorldStem worldstem, Proxy proxy, DataFixer datafixer, Services services, ChunkProgressListenerFactory worldloadlistenerfactory) {
|
||||||
super("Server");
|
super("Server");
|
||||||
+ SERVER = this; // Paper - better singleton
|
+ SERVER = this; // Paper - better singleton
|
||||||
this.metricsRecorder = InactiveMetricsRecorder.INSTANCE;
|
this.metricsRecorder = InactiveMetricsRecorder.INSTANCE;
|
|
@ -1,18 +0,0 @@
|
||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Aikar <aikar@aikar.co>
|
|
||||||
Date: Sun, 3 Apr 2016 17:48:50 -0400
|
|
||||||
Subject: [PATCH] Fix Cancelling BlockPlaceEvent triggering physics
|
|
||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/world/level/Level.java b/src/main/java/net/minecraft/world/level/Level.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/net/minecraft/world/level/Level.java
|
|
||||||
+++ b/src/main/java/net/minecraft/world/level/Level.java
|
|
||||||
@@ -0,0 +0,0 @@ public abstract class Level implements LevelAccessor, AutoCloseable {
|
|
||||||
public void setBlocksDirty(BlockPos pos, BlockState old, BlockState updated) {}
|
|
||||||
|
|
||||||
public void updateNeighborsAt(BlockPos pos, Block block) {
|
|
||||||
+ if (captureBlockStates) { return; } // Paper - Cancel all physics during placement
|
|
||||||
this.neighborChanged(pos.west(), block, pos);
|
|
||||||
this.neighborChanged(pos.east(), block, pos);
|
|
||||||
this.neighborChanged(pos.below(), block, pos);
|
|
Loading…
Reference in a new issue