Skip to content

Commit

Permalink
Read change positions at once
Browse files Browse the repository at this point in the history
  • Loading branch information
SirYwell committed Jan 7, 2024
1 parent fe626a9 commit 8ffa165
Show file tree
Hide file tree
Showing 4 changed files with 46 additions and 56 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package com.fastasyncworldedit.core.history.change;

import com.sk89q.worldedit.history.change.Change;
import org.jetbrains.annotations.ApiStatus;

/**
* Represents a change that is associated with {@code (x, y, z)} block coordinates.
* @since TODO
*/
@ApiStatus.Internal
public sealed abstract class BlockPositionChange implements Change
permits MutableBlockChange, MutableFullBlockChange {
public int x;
public int y;
public int z;
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,17 +2,13 @@

import com.sk89q.worldedit.WorldEditException;
import com.sk89q.worldedit.history.UndoContext;
import com.sk89q.worldedit.history.change.Change;
import com.sk89q.worldedit.world.block.BlockState;
import org.jetbrains.annotations.ApiStatus;

public class MutableBlockChange implements Change {

public int z;
public int y;
public int x;
@ApiStatus.Internal
public final class MutableBlockChange extends BlockPositionChange {
public int ordinal;


public MutableBlockChange(int x, int y, int z, int ordinal) {
this.x = x;
this.y = y;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,12 @@
import com.sk89q.worldedit.extent.inventory.BlockBag;
import com.sk89q.worldedit.extent.inventory.BlockBagException;
import com.sk89q.worldedit.history.UndoContext;
import com.sk89q.worldedit.history.change.Change;
import com.sk89q.worldedit.world.block.BlockState;
import com.sk89q.worldedit.world.block.BlockTypesCache;
import org.jetbrains.annotations.ApiStatus;

public class MutableFullBlockChange implements Change {

public int z;
public int y;
public int x;
@ApiStatus.Internal
public final class MutableFullBlockChange extends BlockPositionChange {
public int from;
public int to;
public BlockBag blockBag;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
import com.fastasyncworldedit.core.history.change.MutableEntityChange;
import com.fastasyncworldedit.core.history.change.MutableFullBlockChange;
import com.fastasyncworldedit.core.history.change.MutableTileChange;
import com.fastasyncworldedit.core.history.change.BlockPositionChange;
import com.fastasyncworldedit.core.internal.exception.FaweSmallEditUnsupportedException;
import com.fastasyncworldedit.core.internal.io.FaweInputStream;
import com.fastasyncworldedit.core.internal.io.FaweOutputStream;
Expand All @@ -20,6 +21,7 @@
import com.sk89q.worldedit.world.World;
import com.sk89q.worldedit.world.biome.BiomeType;
import com.sk89q.worldedit.world.block.BlockTypes;
import org.jetbrains.annotations.ApiStatus;

import java.io.EOFException;
import java.io.IOException;
Expand All @@ -32,6 +34,7 @@
/**
* FAWE stream ChangeSet offering support for extended-height worlds
*/
@ApiStatus.Internal
public abstract class FaweStreamChangeSet extends AbstractChangeSet {

public static final int HEADER_SIZE = 9;
Expand Down Expand Up @@ -68,19 +71,15 @@ private void init(boolean storeRedo, boolean smallLoc) {
}
}

public interface FaweStreamPositionDelegate {
interface FaweStreamPositionDelegate {

void write(OutputStream out, int x, int y, int z) throws IOException;

int readX(FaweInputStream in) throws IOException;

int readY(FaweInputStream in) throws IOException;

int readZ(FaweInputStream in) throws IOException;
void read(FaweInputStream in, BlockPositionChange change) throws IOException;

}

public interface FaweStreamIdDelegate {
interface FaweStreamIdDelegate {

void writeChange(FaweOutputStream out, int from, int to) throws IOException;

Expand Down Expand Up @@ -138,6 +137,7 @@ public void readCombined(FaweInputStream is, MutableFullBlockChange change) thro
}
if (mode == 1 || mode == 4) { // small
posDel = new FaweStreamPositionDelegate() {
final byte[] buffer = new byte[4];
int lx;
int ly;
int lz;
Expand All @@ -162,23 +162,14 @@ public void write(OutputStream out, int x, int y, int z) throws IOException {
out.write(b4);
}

final byte[] buffer = new byte[4];

@Override
public int readX(FaweInputStream in) throws IOException {
public void read(final FaweInputStream in, final BlockPositionChange change) throws IOException {
in.readFully(buffer);
return lx = lx + ((((buffer[1] & 0xFF) | ((MathMan.unpair16x(buffer[3])) << 8)) << 20) >> 20);
change.x = lx = lx + ((((buffer[1] & 0xFF) | ((MathMan.unpair16x(buffer[3])) << 8)) << 20) >> 20);
change.y = (ly = ly + buffer[0]) & 0xFF;
change.z = lz = lz + ((((buffer[2] & 0xFF) | ((MathMan.unpair16y(buffer[3])) << 8)) << 20) >> 20);
}

@Override
public int readY(FaweInputStream in) {
return (ly = ly + buffer[0]) & 0xFF;
}

@Override
public int readZ(FaweInputStream in) throws IOException {
return lz = lz + ((((buffer[2] & 0xFF) | ((MathMan.unpair16y(buffer[3])) << 8)) << 20) >> 20);
}
};
} else {
posDel = new FaweStreamPositionDelegate() {
Expand All @@ -201,19 +192,11 @@ public void write(OutputStream stream, int x, int y, int z) throws IOException {
}

@Override
public int readX(FaweInputStream is) throws IOException {
is.readFully(buffer);
return lx = lx + ((buffer[0] & 0xFF) | (buffer[1] << 8));
}

@Override
public int readY(FaweInputStream is) throws IOException {
return ly = ly + ((buffer[4] & 0xFF) | (buffer[5]) << 8);
}

@Override
public int readZ(FaweInputStream is) throws IOException {
return lz = lz + ((buffer[2] & 0xFF) | (buffer[3]) << 8);
public void read(final FaweInputStream in, final BlockPositionChange change) throws IOException {
in.readFully(buffer);
change.x = lx = lx + ((buffer[0] & 0xFF) | (buffer[1] << 8));
change.z = lz = lz + ((buffer[2] & 0xFF) | (buffer[3]) << 8);
change.y = ly = ly + ((buffer[4] & 0xFF) | (buffer[5]) << 8);
}
};
}
Expand Down Expand Up @@ -428,9 +411,9 @@ public Iterator<MutableBlockChange> getBlockIterator(final boolean dir) throws I

public MutableBlockChange read() {
try {
change.x = posDel.readX(is) + originX;
change.y = posDel.readY(is);
change.z = posDel.readZ(is) + originZ;
posDel.read(is, change);
change.x += originX;
change.z += originZ;
idDel.readCombined(is, change, dir);
return change;
} catch (EOFException ignored) {
Expand Down Expand Up @@ -545,9 +528,9 @@ public Iterator<MutableFullBlockChange> getFullBlockIterator(BlockBag blockBag,

public MutableFullBlockChange read() {
try {
change.x = posDel.readX(is) + originX;
change.y = posDel.readY(is);
change.z = posDel.readZ(is) + originZ;
posDel.read(is, change);
change.x += originX;
change.z += originZ;
idDel.readCombined(is, change);
return change;
} catch (EOFException ignored) {
Expand Down Expand Up @@ -765,11 +748,9 @@ public SimpleChangeSetSummary summarize(Region region, boolean shallow) {
int amount = (Settings.settings().HISTORY.BUFFER_SIZE - HEADER_SIZE) / 9;
MutableFullBlockChange change = new MutableFullBlockChange(null, 0, false);
for (int i = 0; i < amount; i++) {
int x = posDel.readX(fis) + ox;
int y = posDel.readY(fis);
int z = posDel.readZ(fis) + ox;
posDel.read(fis, change);
idDel.readCombined(fis, change);
summary.add(x, z, change.to);
summary.add(change.x, change.z, change.to);
}
}
} catch (EOFException ignored) {
Expand Down

0 comments on commit 8ffa165

Please sign in to comment.