mirror of
https://github.com/Creators-of-Create/Create.git
synced 2025-01-01 09:57:12 +01:00
Make schematics write tags for filtering behaviour
This commit is contained in:
parent
e916b06862
commit
947496995a
1 changed files with 13 additions and 3 deletions
|
@ -28,6 +28,8 @@ import com.simibubi.create.foundation.item.ItemHelper.ExtractionCountMode;
|
||||||
import com.simibubi.create.foundation.render.backend.instancing.IInstanceRendered;
|
import com.simibubi.create.foundation.render.backend.instancing.IInstanceRendered;
|
||||||
import com.simibubi.create.foundation.tileEntity.SmartTileEntity;
|
import com.simibubi.create.foundation.tileEntity.SmartTileEntity;
|
||||||
import com.simibubi.create.foundation.tileEntity.TileEntityBehaviour;
|
import com.simibubi.create.foundation.tileEntity.TileEntityBehaviour;
|
||||||
|
import com.simibubi.create.foundation.tileEntity.behaviour.BehaviourType;
|
||||||
|
import com.simibubi.create.foundation.tileEntity.behaviour.filtering.FilteringBehaviour;
|
||||||
import com.simibubi.create.foundation.utility.BlockHelper;
|
import com.simibubi.create.foundation.utility.BlockHelper;
|
||||||
import com.simibubi.create.foundation.utility.Iterate;
|
import com.simibubi.create.foundation.utility.Iterate;
|
||||||
import com.simibubi.create.foundation.utility.NBTProcessors;
|
import com.simibubi.create.foundation.utility.NBTProcessors;
|
||||||
|
@ -471,13 +473,21 @@ public class SchematicannonTileEntity extends SmartTileEntity implements INamedC
|
||||||
launchBlock(target, icon, blockState, null);
|
launchBlock(target, icon, blockState, null);
|
||||||
} else {
|
} else {
|
||||||
CompoundNBT data = null;
|
CompoundNBT data = null;
|
||||||
if (AllBlockTags.SAFE_NBT.matches(blockState)) {
|
TileEntity tile = blockReader.getTileEntity(target);
|
||||||
TileEntity tile = blockReader.getTileEntity(target);
|
if (tile != null) {
|
||||||
if (tile != null) {
|
if (AllBlockTags.SAFE_NBT.matches(blockState)) {
|
||||||
data = tile.write(new CompoundNBT());
|
data = tile.write(new CompoundNBT());
|
||||||
data = NBTProcessors.process(tile, data, true);
|
data = NBTProcessors.process(tile, data, true);
|
||||||
|
} else if (tile instanceof SmartTileEntity) {
|
||||||
|
FilteringBehaviour filtering = ((SmartTileEntity)tile).getBehaviour(FilteringBehaviour.TYPE);
|
||||||
|
if (filtering != null) {
|
||||||
|
data = new CompoundNBT();
|
||||||
|
filtering.write(data, false);
|
||||||
|
data = NBTProcessors.process(tile, data, true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
launchBlock(target, icon, blockState, data);
|
launchBlock(target, icon, blockState, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue