mirror of
https://github.com/BentoBoxWorld/BentoBox.git
synced 2025-01-28 02:51:51 +01:00
Merge pull request #2568 from BentoBoxWorld/MC_1_21_4
Update to MC 1 21 4. Remove code for older versions.
This commit is contained in:
commit
336ed7e88e
6
pom.xml
6
pom.xml
@ -234,6 +234,12 @@
|
|||||||
<version>${spigot.version}</version>
|
<version>${spigot.version}</version>
|
||||||
<scope>provided</scope>
|
<scope>provided</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.spigotmc......</groupId>
|
||||||
|
<artifactId>spigot</artifactId>
|
||||||
|
<version>1.21.4-R0.1-SNAPSHOT</version>
|
||||||
|
<scope>provided</scope>
|
||||||
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.spigotmc.....</groupId>
|
<groupId>org.spigotmc.....</groupId>
|
||||||
<artifactId>spigot</artifactId>
|
<artifactId>spigot</artifactId>
|
||||||
|
@ -1,52 +0,0 @@
|
|||||||
package world.bentobox.bentobox.nms.v1_20_0_R0_1_SNAPSHOT;
|
|
||||||
|
|
||||||
import java.util.concurrent.CompletableFuture;
|
|
||||||
|
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.block.Block;
|
|
||||||
import org.bukkit.block.data.BlockData;
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R1.CraftWorld;
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R1.block.data.CraftBlockData;
|
|
||||||
|
|
||||||
import net.minecraft.core.BlockPosition;
|
|
||||||
import net.minecraft.world.level.block.state.IBlockData;
|
|
||||||
import net.minecraft.world.level.chunk.Chunk;
|
|
||||||
import world.bentobox.bentobox.blueprints.dataobjects.BlueprintBlock;
|
|
||||||
import world.bentobox.bentobox.database.objects.Island;
|
|
||||||
import world.bentobox.bentobox.nms.PasteHandler;
|
|
||||||
import world.bentobox.bentobox.util.DefaultPasteUtil;
|
|
||||||
import world.bentobox.bentobox.util.Util;
|
|
||||||
|
|
||||||
public class PasteHandlerImpl implements PasteHandler {
|
|
||||||
|
|
||||||
|
|
||||||
protected static final IBlockData AIR = ((CraftBlockData) AIR_BLOCKDATA).getState();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the block to the location
|
|
||||||
*
|
|
||||||
* @param island - island
|
|
||||||
* @param location - location
|
|
||||||
* @param bpBlock - blueprint block
|
|
||||||
*/
|
|
||||||
public CompletableFuture<Void> setBlock(Island island, Location location, BlueprintBlock bpBlock) {
|
|
||||||
return Util.getChunkAtAsync(location).thenRun(() -> {
|
|
||||||
Block block = location.getBlock();
|
|
||||||
// Set the block data - default is AIR
|
|
||||||
BlockData bd = DefaultPasteUtil.createBlockData(bpBlock);
|
|
||||||
CraftBlockData craft = (CraftBlockData) bd;
|
|
||||||
net.minecraft.world.level.World nmsWorld = ((CraftWorld) location.getWorld()).getHandle();
|
|
||||||
Chunk nmsChunk = nmsWorld.d(location.getBlockX() >> 4, location.getBlockZ() >> 4);
|
|
||||||
BlockPosition bp = new BlockPosition(location.getBlockX(), location.getBlockY(), location.getBlockZ());
|
|
||||||
// Setting the block to air before setting to another state prevents some console errors
|
|
||||||
nmsChunk.a(bp, AIR, false);
|
|
||||||
nmsChunk.a(bp, craft.getState(), false);
|
|
||||||
block.setBlockData(bd, false);
|
|
||||||
DefaultPasteUtil.setBlockState(island, block, bpBlock);
|
|
||||||
// Set biome
|
|
||||||
if (bpBlock.getBiome() != null) {
|
|
||||||
block.setBiome(bpBlock.getBiome());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,26 +0,0 @@
|
|||||||
package world.bentobox.bentobox.nms.v1_20_0_R0_1_SNAPSHOT;
|
|
||||||
|
|
||||||
import org.bukkit.block.data.BlockData;
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R1.CraftWorld;
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R1.block.data.CraftBlockData;
|
|
||||||
|
|
||||||
import net.minecraft.core.BlockPosition;
|
|
||||||
import net.minecraft.world.level.World;
|
|
||||||
import net.minecraft.world.level.chunk.Chunk;
|
|
||||||
import world.bentobox.bentobox.nms.CopyWorldRegenerator;
|
|
||||||
|
|
||||||
public class WorldRegeneratorImpl extends CopyWorldRegenerator {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setBlockInNativeChunk(org.bukkit.Chunk chunk, int x, int y, int z, BlockData blockData,
|
|
||||||
boolean applyPhysics) {
|
|
||||||
CraftBlockData craft = (CraftBlockData) blockData;
|
|
||||||
World nmsWorld = ((CraftWorld) chunk.getWorld()).getHandle();
|
|
||||||
Chunk nmsChunk = nmsWorld.d(chunk.getX(), chunk.getZ());
|
|
||||||
BlockPosition bp = new BlockPosition((chunk.getX() << 4) + x, y, (chunk.getZ() << 4) + z);
|
|
||||||
// Setting the block to air before setting to another state prevents some console errors
|
|
||||||
nmsChunk.a(bp, PasteHandlerImpl.AIR, applyPhysics);
|
|
||||||
nmsChunk.a(bp, craft.getState(), applyPhysics);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,51 +0,0 @@
|
|||||||
package world.bentobox.bentobox.nms.v1_20_1_R0_1_SNAPSHOT;
|
|
||||||
|
|
||||||
import java.util.concurrent.CompletableFuture;
|
|
||||||
|
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.block.Block;
|
|
||||||
import org.bukkit.block.data.BlockData;
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R1.CraftWorld;
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R1.block.data.CraftBlockData;
|
|
||||||
|
|
||||||
import net.minecraft.core.BlockPosition;
|
|
||||||
import net.minecraft.world.level.block.state.IBlockData;
|
|
||||||
import net.minecraft.world.level.chunk.Chunk;
|
|
||||||
import world.bentobox.bentobox.blueprints.dataobjects.BlueprintBlock;
|
|
||||||
import world.bentobox.bentobox.database.objects.Island;
|
|
||||||
import world.bentobox.bentobox.nms.PasteHandler;
|
|
||||||
import world.bentobox.bentobox.util.DefaultPasteUtil;
|
|
||||||
import world.bentobox.bentobox.util.Util;
|
|
||||||
|
|
||||||
public class PasteHandlerImpl implements PasteHandler {
|
|
||||||
|
|
||||||
protected static final IBlockData AIR = ((CraftBlockData) AIR_BLOCKDATA).getState();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the block to the location
|
|
||||||
*
|
|
||||||
* @param island - island
|
|
||||||
* @param location - location
|
|
||||||
* @param bpBlock - blueprint block
|
|
||||||
*/
|
|
||||||
public CompletableFuture<Void> setBlock(Island island, Location location, BlueprintBlock bpBlock) {
|
|
||||||
return Util.getChunkAtAsync(location).thenRun(() -> {
|
|
||||||
Block block = location.getBlock();
|
|
||||||
// Set the block data - default is AIR
|
|
||||||
BlockData bd = DefaultPasteUtil.createBlockData(bpBlock);
|
|
||||||
CraftBlockData craft = (CraftBlockData) bd;
|
|
||||||
net.minecraft.world.level.World nmsWorld = ((CraftWorld) location.getWorld()).getHandle();
|
|
||||||
Chunk nmsChunk = nmsWorld.d(location.getBlockX() >> 4, location.getBlockZ() >> 4);
|
|
||||||
BlockPosition bp = new BlockPosition(location.getBlockX(), location.getBlockY(), location.getBlockZ());
|
|
||||||
// Setting the block to air before setting to another state prevents some console errors
|
|
||||||
nmsChunk.a(bp, AIR, false);
|
|
||||||
nmsChunk.a(bp, craft.getState(), false);
|
|
||||||
block.setBlockData(bd, false);
|
|
||||||
DefaultPasteUtil.setBlockState(island, block, bpBlock);
|
|
||||||
// Set biome
|
|
||||||
if (bpBlock.getBiome() != null) {
|
|
||||||
block.setBiome(bpBlock.getBiome());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,26 +0,0 @@
|
|||||||
package world.bentobox.bentobox.nms.v1_20_1_R0_1_SNAPSHOT;
|
|
||||||
|
|
||||||
import org.bukkit.block.data.BlockData;
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R1.CraftWorld;
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R1.block.data.CraftBlockData;
|
|
||||||
|
|
||||||
import net.minecraft.core.BlockPosition;
|
|
||||||
import net.minecraft.world.level.World;
|
|
||||||
import net.minecraft.world.level.chunk.Chunk;
|
|
||||||
import world.bentobox.bentobox.nms.CopyWorldRegenerator;
|
|
||||||
|
|
||||||
public class WorldRegeneratorImpl extends CopyWorldRegenerator {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setBlockInNativeChunk(org.bukkit.Chunk chunk, int x, int y, int z, BlockData blockData,
|
|
||||||
boolean applyPhysics) {
|
|
||||||
CraftBlockData craft = (CraftBlockData) blockData;
|
|
||||||
World nmsWorld = ((CraftWorld) chunk.getWorld()).getHandle();
|
|
||||||
Chunk nmsChunk = nmsWorld.d(chunk.getX(), chunk.getZ());
|
|
||||||
BlockPosition bp = new BlockPosition((chunk.getX() << 4) + x, y, (chunk.getZ() << 4) + z);
|
|
||||||
// Setting the block to air before setting to another state prevents some console errors
|
|
||||||
nmsChunk.a(bp, PasteHandlerImpl.AIR, applyPhysics);
|
|
||||||
nmsChunk.a(bp, craft.getState(), applyPhysics);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,52 +0,0 @@
|
|||||||
package world.bentobox.bentobox.nms.v1_20_6_R0_1_SNAPSHOT;
|
|
||||||
|
|
||||||
import java.util.concurrent.CompletableFuture;
|
|
||||||
|
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.block.Block;
|
|
||||||
import org.bukkit.block.data.BlockData;
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R4.CraftWorld;
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R4.block.data.CraftBlockData;
|
|
||||||
|
|
||||||
import net.minecraft.core.BlockPosition;
|
|
||||||
import net.minecraft.world.level.block.state.IBlockData;
|
|
||||||
import net.minecraft.world.level.chunk.Chunk;
|
|
||||||
import world.bentobox.bentobox.blueprints.dataobjects.BlueprintBlock;
|
|
||||||
import world.bentobox.bentobox.database.objects.Island;
|
|
||||||
import world.bentobox.bentobox.nms.PasteHandler;
|
|
||||||
import world.bentobox.bentobox.util.DefaultPasteUtil;
|
|
||||||
import world.bentobox.bentobox.util.Util;
|
|
||||||
|
|
||||||
public class PasteHandlerImpl implements PasteHandler {
|
|
||||||
|
|
||||||
protected static final IBlockData AIR = ((CraftBlockData) AIR_BLOCKDATA).getState();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the block to the location
|
|
||||||
*
|
|
||||||
* @param island - island
|
|
||||||
* @param location - location
|
|
||||||
* @param bpBlock - blueprint block
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public CompletableFuture<Void> setBlock(Island island, Location location, BlueprintBlock bpBlock) {
|
|
||||||
return Util.getChunkAtAsync(location).thenRun(() -> {
|
|
||||||
Block block = location.getBlock();
|
|
||||||
// Set the block data - default is AIR
|
|
||||||
BlockData bd = DefaultPasteUtil.createBlockData(bpBlock);
|
|
||||||
CraftBlockData craft = (CraftBlockData) bd;
|
|
||||||
net.minecraft.world.level.World nmsWorld = ((CraftWorld) location.getWorld()).getHandle();
|
|
||||||
Chunk nmsChunk = nmsWorld.d(location.getBlockX() >> 4, location.getBlockZ() >> 4);
|
|
||||||
BlockPosition bp = new BlockPosition(location.getBlockX(), location.getBlockY(), location.getBlockZ());
|
|
||||||
// Setting the block to air before setting to another state prevents some console errors
|
|
||||||
nmsChunk.a(bp, AIR, false);
|
|
||||||
nmsChunk.a(bp, craft.getState(), false);
|
|
||||||
block.setBlockData(bd, false);
|
|
||||||
DefaultPasteUtil.setBlockState(island, block, bpBlock);
|
|
||||||
// Set biome
|
|
||||||
if (bpBlock.getBiome() != null) {
|
|
||||||
block.setBiome(bpBlock.getBiome());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,26 +0,0 @@
|
|||||||
package world.bentobox.bentobox.nms.v1_20_6_R0_1_SNAPSHOT;
|
|
||||||
|
|
||||||
import org.bukkit.block.data.BlockData;
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R4.CraftWorld;
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R4.block.data.CraftBlockData;
|
|
||||||
|
|
||||||
import net.minecraft.core.BlockPosition;
|
|
||||||
import net.minecraft.world.level.World;
|
|
||||||
import net.minecraft.world.level.chunk.Chunk;
|
|
||||||
import world.bentobox.bentobox.nms.CopyWorldRegenerator;
|
|
||||||
|
|
||||||
public class WorldRegeneratorImpl extends CopyWorldRegenerator {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setBlockInNativeChunk(org.bukkit.Chunk chunk, int x, int y, int z, BlockData blockData,
|
|
||||||
boolean applyPhysics) {
|
|
||||||
CraftBlockData craft = (CraftBlockData) blockData;
|
|
||||||
World nmsWorld = ((CraftWorld) chunk.getWorld()).getHandle();
|
|
||||||
Chunk nmsChunk = nmsWorld.d(chunk.getX(), chunk.getZ());
|
|
||||||
BlockPosition bp = new BlockPosition((chunk.getX() << 4) + x, y, (chunk.getZ() << 4) + z);
|
|
||||||
// Setting the block to air before setting to another state prevents some console errors
|
|
||||||
nmsChunk.a(bp, PasteHandlerImpl.AIR, applyPhysics);
|
|
||||||
nmsChunk.a(bp, craft.getState(), applyPhysics);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,12 +1,12 @@
|
|||||||
package world.bentobox.bentobox.nms.v1_20_4_R0_1_SNAPSHOT;
|
package world.bentobox.bentobox.nms.v1_21_4_R0_1_SNAPSHOT;
|
||||||
|
|
||||||
import java.util.concurrent.CompletableFuture;
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.block.Block;
|
import org.bukkit.block.Block;
|
||||||
import org.bukkit.block.data.BlockData;
|
import org.bukkit.block.data.BlockData;
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.CraftWorld;
|
import org.bukkit.craftbukkit.v1_21_R3.CraftWorld;
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.block.data.CraftBlockData;
|
import org.bukkit.craftbukkit.v1_21_R3.block.data.CraftBlockData;
|
||||||
|
|
||||||
import net.minecraft.core.BlockPosition;
|
import net.minecraft.core.BlockPosition;
|
||||||
import net.minecraft.world.level.block.state.IBlockData;
|
import net.minecraft.world.level.block.state.IBlockData;
|
@ -1,8 +1,8 @@
|
|||||||
package world.bentobox.bentobox.nms.v1_20_4_R0_1_SNAPSHOT;
|
package world.bentobox.bentobox.nms.v1_21_4_R0_1_SNAPSHOT;
|
||||||
|
|
||||||
import org.bukkit.block.data.BlockData;
|
import org.bukkit.block.data.BlockData;
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.CraftWorld;
|
import org.bukkit.craftbukkit.v1_21_R3.CraftWorld;
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.block.data.CraftBlockData;
|
import org.bukkit.craftbukkit.v1_21_R3.block.data.CraftBlockData;
|
||||||
|
|
||||||
import net.minecraft.core.BlockPosition;
|
import net.minecraft.core.BlockPosition;
|
||||||
import net.minecraft.world.level.World;
|
import net.minecraft.world.level.World;
|
@ -197,23 +197,23 @@ public class ServerCompatibility {
|
|||||||
/**
|
/**
|
||||||
* @since 1.21.0
|
* @since 1.21.0
|
||||||
*/
|
*/
|
||||||
V1_19(Compatibility.COMPATIBLE),
|
V1_19(Compatibility.INCOMPATIBLE),
|
||||||
/**
|
/**
|
||||||
* @since 1.21.0
|
* @since 1.21.0
|
||||||
*/
|
*/
|
||||||
V1_19_1(Compatibility.COMPATIBLE),
|
V1_19_1(Compatibility.INCOMPATIBLE),
|
||||||
/**
|
/**
|
||||||
* @since 1.21.0
|
* @since 1.21.0
|
||||||
*/
|
*/
|
||||||
V1_19_2(Compatibility.COMPATIBLE),
|
V1_19_2(Compatibility.INCOMPATIBLE),
|
||||||
/**
|
/**
|
||||||
* @since 1.22.0
|
* @since 1.22.0
|
||||||
*/
|
*/
|
||||||
V1_19_3(Compatibility.COMPATIBLE),
|
V1_19_3(Compatibility.INCOMPATIBLE),
|
||||||
/**
|
/**
|
||||||
* @since 1.22.1
|
* @since 1.22.1
|
||||||
*/
|
*/
|
||||||
V1_19_4(Compatibility.COMPATIBLE),
|
V1_19_4(Compatibility.INCOMPATIBLE),
|
||||||
/**
|
/**
|
||||||
* @since 1.24.0
|
* @since 1.24.0
|
||||||
*/
|
*/
|
||||||
@ -221,40 +221,50 @@ public class ServerCompatibility {
|
|||||||
/**
|
/**
|
||||||
* @since 1.24.0
|
* @since 1.24.0
|
||||||
*/
|
*/
|
||||||
V1_20_1(Compatibility.COMPATIBLE),
|
V1_20_1(Compatibility.INCOMPATIBLE),
|
||||||
/**
|
/**
|
||||||
* @since 2.0.0
|
* @since 2.0.0
|
||||||
*/
|
*/
|
||||||
V1_20_2(Compatibility.COMPATIBLE),
|
V1_20_2(Compatibility.INCOMPATIBLE),
|
||||||
/**
|
/**
|
||||||
* @since 2.0.0
|
* @since 2.0.0
|
||||||
*/
|
*/
|
||||||
V1_20_3(Compatibility.COMPATIBLE),
|
V1_20_3(Compatibility.INCOMPATIBLE),
|
||||||
/**
|
/**
|
||||||
* @since 2.0.0
|
* @since 2.0.0
|
||||||
*/
|
*/
|
||||||
V1_20_4(Compatibility.COMPATIBLE),
|
V1_20_4(Compatibility.INCOMPATIBLE),
|
||||||
/**
|
/**
|
||||||
* @since 2.4.0
|
* @since 2.4.0
|
||||||
*/
|
*/
|
||||||
V1_20_5(Compatibility.COMPATIBLE),
|
V1_20_5(Compatibility.INCOMPATIBLE),
|
||||||
/**
|
/**
|
||||||
* @since 2.4.0
|
* @since 2.4.0
|
||||||
*/
|
*/
|
||||||
V1_20_6(Compatibility.COMPATIBLE),
|
V1_20_6(Compatibility.INCOMPATIBLE),
|
||||||
/**
|
/**
|
||||||
* @since 2.4.0
|
* @since 2.4.0
|
||||||
*/
|
*/
|
||||||
V1_21(Compatibility.COMPATIBLE),
|
V1_21(Compatibility.INCOMPATIBLE),
|
||||||
/**
|
/**
|
||||||
* @since 2.5.0
|
* @since 2.5.0
|
||||||
*/
|
*/
|
||||||
V1_21_1(Compatibility.COMPATIBLE),
|
V1_21_1(Compatibility.INCOMPATIBLE),
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @since 2.7.0
|
* @since 2.7.0
|
||||||
*/
|
*/
|
||||||
V1_21_2(Compatibility.INCOMPATIBLE), V1_21_3(Compatibility.COMPATIBLE);
|
V1_21_2(Compatibility.INCOMPATIBLE),
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 3.0.0
|
||||||
|
*/
|
||||||
|
V1_21_3(Compatibility.COMPATIBLE),
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @since 3.0.1
|
||||||
|
*/
|
||||||
|
V1_21_4(Compatibility.COMPATIBLE),;
|
||||||
|
|
||||||
private final Compatibility compatibility;
|
private final Compatibility compatibility;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user