mirror of
https://github.com/Creators-of-Create/Create.git
synced 2025-01-04 03:16:43 +01:00
Hack to prevent rails placed by cannon from updating
This commit is contained in:
parent
947496995a
commit
8edfa73352
1 changed files with 33 additions and 1 deletions
|
@ -1,9 +1,18 @@
|
||||||
package com.simibubi.create.foundation.utility;
|
package com.simibubi.create.foundation.utility;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
|
import net.minecraft.block.AbstractRailBlock;
|
||||||
|
import net.minecraft.block.RailBlock;
|
||||||
|
|
||||||
|
import net.minecraft.world.chunk.Chunk;
|
||||||
|
import net.minecraft.world.chunk.ChunkSection;
|
||||||
|
import net.minecraftforge.common.util.BlockSnapshot;
|
||||||
|
|
||||||
import org.apache.commons.lang3.mutable.MutableInt;
|
import org.apache.commons.lang3.mutable.MutableInt;
|
||||||
|
|
||||||
import com.simibubi.create.AllBlocks;
|
import com.simibubi.create.AllBlocks;
|
||||||
|
@ -234,6 +243,23 @@ public class BlockHelper {
|
||||||
.isEmpty();
|
.isEmpty();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void placeRailWithoutUpdate(World world, BlockState state, BlockPos target) {
|
||||||
|
int i = target.getX() & 15;
|
||||||
|
int j = target.getY();
|
||||||
|
int k = target.getZ() & 15;
|
||||||
|
Chunk chunk = world.getChunkAt(target);
|
||||||
|
ChunkSection chunksection = chunk.getSections()[j >> 4];
|
||||||
|
if (chunksection == Chunk.EMPTY_SECTION) {
|
||||||
|
chunksection = new ChunkSection(j >> 4 << 4);
|
||||||
|
chunk.getSections()[j >> 4] = chunksection;
|
||||||
|
}
|
||||||
|
BlockState old = chunksection.setBlockState(i, j & 15, k, state);
|
||||||
|
chunk.markDirty();
|
||||||
|
world.markAndNotifyBlock(target, chunk, old, state, 82, 512);
|
||||||
|
|
||||||
|
world.setBlockState(target, state, 82);
|
||||||
|
}
|
||||||
|
|
||||||
public static void placeSchematicBlock(World world, BlockState state, BlockPos target, ItemStack stack,
|
public static void placeSchematicBlock(World world, BlockState state, BlockPos target, ItemStack stack,
|
||||||
@Nullable CompoundNBT data) {
|
@Nullable CompoundNBT data) {
|
||||||
// Piston
|
// Piston
|
||||||
|
@ -268,7 +294,13 @@ public class BlockHelper {
|
||||||
Block.spawnDrops(state, world, target);
|
Block.spawnDrops(state, world, target);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
world.setBlockState(target, state, 18);
|
|
||||||
|
if (BlockTags.RAILS.contains(state.getBlock())) {
|
||||||
|
placeRailWithoutUpdate(world, state, target);
|
||||||
|
} else {
|
||||||
|
world.setBlockState(target, state, 18);
|
||||||
|
}
|
||||||
|
|
||||||
if (data != null) {
|
if (data != null) {
|
||||||
TileEntity tile = world.getTileEntity(target);
|
TileEntity tile = world.getTileEntity(target);
|
||||||
if (tile != null) {
|
if (tile != null) {
|
||||||
|
|
Loading…
Reference in a new issue