Skip to content

Commit

Permalink
Move to Fawe/LinTag
Browse files Browse the repository at this point in the history
  • Loading branch information
dordsor21 committed Sep 29, 2024
1 parent 6f387ef commit 5b1c7e0
Show file tree
Hide file tree
Showing 5 changed files with 30 additions and 26 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
import net.minecraft.world.level.block.state.BlockState;
import net.minecraft.world.level.material.FluidState;
import net.minecraft.world.level.material.Fluids;
import org.enginehub.linbus.tree.LinCompoundTag;
import sun.misc.Unsafe;

import javax.annotation.Nonnull;
Expand Down Expand Up @@ -50,7 +51,7 @@ public BlockEntity getBlockEntity(@Nonnull BlockPos blockPos) {
if (blockPos.getX() == Integer.MAX_VALUE) {
return null;
}
com.sk89q.jnbt.CompoundTag tag = processor.getTileAt(blockPos.getX(), blockPos.getY(), blockPos.getZ());
LinCompoundTag tag = processor.getTileAt(blockPos.getX(), blockPos.getY(), blockPos.getZ());
if (tag == null) {
return null;
}
Expand All @@ -59,7 +60,7 @@ public BlockEntity getBlockEntity(@Nonnull BlockPos blockPos) {
return null;
}
BlockEntity tileEntity = entityBlock.newBlockEntity(blockPos, state);
tileEntity.load((CompoundTag) adapter.fromNative(tag));
tileEntity.load((CompoundTag) adapter.fromNativeLin(tag));
return tileEntity;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
import net.minecraft.world.level.block.state.BlockState;
import net.minecraft.world.level.material.FluidState;
import net.minecraft.world.level.material.Fluids;
import org.enginehub.linbus.tree.LinCompoundTag;
import sun.misc.Unsafe;

import javax.annotation.Nonnull;
Expand Down Expand Up @@ -50,7 +51,7 @@ public BlockEntity getBlockEntity(@Nonnull BlockPos blockPos) {
if (blockPos.getY() == Integer.MAX_VALUE) {
return null;
}
com.sk89q.jnbt.CompoundTag tag = processor.getTileAt(blockPos.getX(), blockPos.getY(), blockPos.getZ());
LinCompoundTag tag = processor.getTileAt(blockPos.getX(), blockPos.getY(), blockPos.getZ());
if (tag == null) {
return null;
}
Expand All @@ -59,7 +60,7 @@ public BlockEntity getBlockEntity(@Nonnull BlockPos blockPos) {
return null;
}
BlockEntity tileEntity = entityBlock.newBlockEntity(blockPos, state);
tileEntity.load((CompoundTag) adapter.fromNative(tag));
tileEntity.load((CompoundTag) adapter.fromNativeLin(tag));
return tileEntity;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
import net.minecraft.world.level.block.state.BlockState;
import net.minecraft.world.level.material.FluidState;
import net.minecraft.world.level.material.Fluids;
import org.enginehub.linbus.tree.LinCompoundTag;
import sun.misc.Unsafe;

import javax.annotation.Nonnull;
Expand Down Expand Up @@ -50,7 +51,7 @@ public BlockEntity getBlockEntity(@Nonnull BlockPos blockPos) {
if (blockPos.getX() == Integer.MAX_VALUE) {
return null;
}
com.sk89q.jnbt.CompoundTag tag = processor.getTileAt(blockPos.getX(), blockPos.getY(), blockPos.getZ());
LinCompoundTag tag = processor.getTileAt(blockPos.getX(), blockPos.getY(), blockPos.getZ());
if (tag == null) {
return null;
}
Expand All @@ -59,7 +60,7 @@ public BlockEntity getBlockEntity(@Nonnull BlockPos blockPos) {
return null;
}
BlockEntity tileEntity = entityBlock.newBlockEntity(blockPos, state);
tileEntity.loadWithComponents((CompoundTag) adapter.fromNative(tag), serverLevel.registryAccess());
tileEntity.loadWithComponents((CompoundTag) adapter.fromNativeLin(tag), serverLevel.registryAccess());
return tileEntity;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
import net.minecraft.world.level.block.state.BlockState;
import net.minecraft.world.level.material.FluidState;
import net.minecraft.world.level.material.Fluids;
import org.enginehub.linbus.tree.LinCompoundTag;
import sun.misc.Unsafe;

import javax.annotation.Nonnull;
Expand Down Expand Up @@ -50,7 +51,7 @@ public BlockEntity getBlockEntity(@Nonnull BlockPos blockPos) {
if (blockPos.getX() == Integer.MAX_VALUE) {
return null;
}
com.sk89q.jnbt.CompoundTag tag = processor.getTileAt(blockPos.getX(), blockPos.getY(), blockPos.getZ());
LinCompoundTag tag = processor.getTileAt(blockPos.getX(), blockPos.getY(), blockPos.getZ());
if (tag == null) {
return null;
}
Expand All @@ -59,7 +60,7 @@ public BlockEntity getBlockEntity(@Nonnull BlockPos blockPos) {
return null;
}
BlockEntity tileEntity = entityBlock.newBlockEntity(blockPos, state);
tileEntity.loadWithComponents((CompoundTag) adapter.fromNative(tag), serverLevel.registryAccess());
tileEntity.loadWithComponents((CompoundTag) adapter.fromNativeLin(tag), serverLevel.registryAccess());
return tileEntity;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,12 @@
import com.fastasyncworldedit.core.math.BlockVector3ChunkMap;
import com.fastasyncworldedit.core.math.MutableBlockVector3;
import com.fastasyncworldedit.core.math.MutableVector3;
import com.fastasyncworldedit.core.nbt.FaweCompoundTag;
import com.fastasyncworldedit.core.queue.IBatchProcessor;
import com.fastasyncworldedit.core.queue.IChunk;
import com.fastasyncworldedit.core.queue.IChunkGet;
import com.fastasyncworldedit.core.queue.IChunkSet;
import com.fastasyncworldedit.core.registry.state.PropertyKey;
import com.sk89q.jnbt.CompoundTag;
import com.sk89q.worldedit.WorldEditException;
import com.sk89q.worldedit.extent.AbstractDelegateExtent;
import com.sk89q.worldedit.extent.Extent;
Expand Down Expand Up @@ -213,7 +213,7 @@ private void uninit() {
}

private IChunkSet process() {
Map<BlockVector3, CompoundTag> setTiles = processChunkSet.getTiles();
Map<BlockVector3, FaweCompoundTag> setTiles = processChunkSet.tiles();
for (int layer = processChunkGet.getMinSectionPosition(); layer <= processChunkGet.getMaxSectionPosition(); layer++) {
int layerY = layer << 4;
char[] set = processChunkSet.loadIfPresent(layer);
Expand All @@ -230,7 +230,7 @@ private IChunkSet process() {
}

private void checkAndPerformUpdate(
Map<BlockVector3, CompoundTag> setTiles,
Map<BlockVector3, FaweCompoundTag> setTiles,
char[] set,
int index,
int blockY,
Expand All @@ -254,7 +254,7 @@ private void checkAndPerformUpdate(
blockX,
blockY,
blockZ,
setTiles.isEmpty() ? null : ((BlockVector3ChunkMap<CompoundTag>) setTiles).remove(x, blockY, z)
setTiles.isEmpty() ? null : ((BlockVector3ChunkMap<FaweCompoundTag>) setTiles).remove(x, blockY, z)
), ordinal);
set[index] = BlockTypesCache.ReservedIDs.__RESERVED__;
continue;
Expand Down Expand Up @@ -300,7 +300,7 @@ public void flush() {
continue;
}
if (secondPass.tile != null) {
extent.setTile(secondPass.x, secondPass.y, secondPass.z, secondPass.tile);
extent.tile(secondPass.x, secondPass.y, secondPass.z, secondPass.tile);
}
extent.setBlock(secondPass.x, secondPass.y, secondPass.z, BlockTypesCache.states[newOrdinal]);
}
Expand Down Expand Up @@ -337,7 +337,7 @@ public BlockState getBlockStateAt(int x, int y, int z) {
return processChunkGet.getBlock(x & 15, y, z & 15);
}
BlockState state = BlockTypesCache.states[ordinal];
// "Hack" for stairs as internal server methods will only accept "single" chests for joining
// "Hack" for chests as internal server methods will only accept "single" chests for joining
if (state.getBlockType().equals(BlockTypes.CHEST) || state.getBlockType().equals(BlockTypes.TRAPPED_CHEST)) {
String shape = state.getState(PropertyKey.TYPE).toString();
if (shape.equals("right")) {
Expand All @@ -361,34 +361,34 @@ public BlockState getBlockStateAt(int x, int y, int z) {
return BlockTypesCache.states[ordinal];
}

public CompoundTag getTileAt(int x, int y, int z) {
public LinCompoundTag getTileAt(int x, int y, int z) {
SecondPass secondPass = new SecondPass(x, y, z, null);
Character ord = postCompleteSecondPasses.get(secondPass);
if (ord != null && ord != 0) {
// This should be rare enough...
for (SecondPass pass : postCompleteSecondPasses.keySet()) {
if (pass.hashCode() == secondPass.hashCode()) {
return pass.tile != null ? pass.tile : BlockTypesCache.states[ord].getNbtData();
return pass.tile != null ? pass.tile.linTag() : BlockTypesCache.states[ord].getNbt();
}
}
return BlockTypesCache.states[ord].getNbtData();
return BlockTypesCache.states[ord].getNbt();
}
if (processChunkSet == null || (x & CHUNK_BLOCK_POS_MASK) != processChunkX || (z & CHUNK_BLOCK_POS_MASK) != processChunkZ) {
return extent.getFullBlock(x, y, z).getNbtData();
return extent.getFullBlock(x, y, z).getNbt();
}
CompoundTag tile = processChunkSet.getTile(x & 15, y, z & 15);
FaweCompoundTag tile = processChunkSet.tile(x & 15, y, z & 15);
if (tile != null) {
return tile;
return tile.linTag();
}
char[] set = processChunkSet.loadIfPresent(y >> 4);
if (set == null) {
return processChunkGet.getFullBlock(x & 15, y, z & 15).getNbtData();
return processChunkGet.getFullBlock(x & 15, y, z & 15).getNbt();
}
char ordinal = set[(y & 15) << 8 | (z & 15) << 4 | (x & 15)];
if (ordinal == BlockTypesCache.ReservedIDs.__RESERVED__) {
return processChunkGet.getFullBlock(x & 15, y, z & 15).getNbtData();
return processChunkGet.getFullBlock(x & 15, y, z & 15).getNbt();
}
return BlockTypesCache.states[ordinal].getNbtData();
return BlockTypesCache.states[ordinal].getNbt();
}

private char getBlockOrdinal(int blockX, int blockY, int blockZ, BlockState state) {
Expand Down Expand Up @@ -487,9 +487,9 @@ public boolean apply(Extent orDefault, BlockVector3 get, BlockVector3 set) throw
if (block.getOrdinalChar() != newOrdinal) {
BlockState newState = BlockTypesCache.states[newOrdinal];
orDefault.setBlock(set.x(), set.y(), set.z(), newState);
CompoundTag nbt = block.getNbtData();
LinCompoundTag nbt = block.getNbt();
if (nbt != null && newState.getBlockType() == block.getBlockType()) {
orDefault.setTile(set.x(), set.y(), set.z(), nbt);
orDefault.tile(set.x(), set.y(), set.z(), FaweCompoundTag.of(nbt));
}
return true;
}
Expand Down Expand Up @@ -521,7 +521,7 @@ public BaseBlock applyBlock(BlockVector3 position) {
return null;
}

protected record SecondPass(int x, int y, int z, CompoundTag tile) {
protected record SecondPass(int x, int y, int z, FaweCompoundTag tile) {

private SecondPass(BlockVector3 pos) {
this(pos.x(), pos.y(), pos.z(), null);
Expand Down

0 comments on commit 5b1c7e0

Please sign in to comment.