mirror of
https://github.com/Creators-of-Create/Create.git
synced 2025-01-12 15:26:39 +01:00
Merge branch 'mc1.20.1/0.5.1' into mc1.20.1/dev
This commit is contained in:
commit
1935b790dd
13 changed files with 18 additions and 43 deletions
|
@ -545,9 +545,12 @@ public abstract class AbstractContraptionEntity extends Entity implements IEntit
|
||||||
relativeMotion = reverseRotation(relativeMotion, 1);
|
relativeMotion = reverseRotation(relativeMotion, 1);
|
||||||
context.relativeMotion = relativeMotion;
|
context.relativeMotion = relativeMotion;
|
||||||
|
|
||||||
return !BlockPos.containing(previousPosition).equals(gridPosition)
|
boolean ignoreMotionForFirstMovement =
|
||||||
|| (context.relativeMotion.length() > 0 || context.contraption instanceof CarriageContraption)
|
context.contraption instanceof CarriageContraption || actor instanceof PortableStorageInterfaceMovement;
|
||||||
&& context.firstMovement;
|
|
||||||
|
return !BlockPos.containing(previousPosition)
|
||||||
|
.equals(gridPosition)
|
||||||
|
|| (context.relativeMotion.length() > 0 || ignoreMotionForFirstMovement) && context.firstMovement;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void move(double x, double y, double z) {
|
public void move(double x, double y, double z) {
|
||||||
|
|
|
@ -106,7 +106,7 @@ public class FluidTankBlock extends Block implements IWrenchable, IBE<FluidTankB
|
||||||
@Override
|
@Override
|
||||||
public int getLightEmission(BlockState state, BlockGetter world, BlockPos pos) {
|
public int getLightEmission(BlockState state, BlockGetter world, BlockPos pos) {
|
||||||
FluidTankBlockEntity tankAt = ConnectivityHandler.partAt(getBlockEntityType(), world, pos);
|
FluidTankBlockEntity tankAt = ConnectivityHandler.partAt(getBlockEntityType(), world, pos);
|
||||||
if (tankAt == null)
|
if (tankAt == null || !tankAt.hasLevel())
|
||||||
return 0;
|
return 0;
|
||||||
FluidTankBlockEntity controllerBE = tankAt.getControllerBE();
|
FluidTankBlockEntity controllerBE = tankAt.getControllerBE();
|
||||||
if (controllerBE == null || !controllerBE.window)
|
if (controllerBE == null || !controllerBE.window)
|
||||||
|
|
|
@ -197,7 +197,7 @@ public class FluidTankBlockEntity extends SmartBlockEntity implements IHaveGoggl
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public FluidTankBlockEntity getControllerBE() {
|
public FluidTankBlockEntity getControllerBE() {
|
||||||
if (isController())
|
if (isController() || !hasLevel())
|
||||||
return this;
|
return this;
|
||||||
BlockEntity blockEntity = level.getBlockEntity(controller);
|
BlockEntity blockEntity = level.getBlockEntity(controller);
|
||||||
if (blockEntity instanceof FluidTankBlockEntity)
|
if (blockEntity instanceof FluidTankBlockEntity)
|
||||||
|
|
|
@ -120,12 +120,6 @@ public class MechanicalCrafterBlockEntity extends KineticBlockEntity {
|
||||||
registerAwardables(behaviours, AllAdvancements.CRAFTER, AllAdvancements.CRAFTER_LAZY);
|
registerAwardables(behaviours, AllAdvancements.CRAFTER, AllAdvancements.CRAFTER_LAZY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void invalidateCaps() {
|
|
||||||
inserting.removeListener();
|
|
||||||
super.invalidateCaps();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onSpeedChanged(float previousSpeed) {
|
public void onSpeedChanged(float previousSpeed) {
|
||||||
super.onSpeedChanged(previousSpeed);
|
super.onSpeedChanged(previousSpeed);
|
||||||
|
@ -138,7 +132,6 @@ public class MechanicalCrafterBlockEntity extends KineticBlockEntity {
|
||||||
|
|
||||||
public void blockChanged() {
|
public void blockChanged() {
|
||||||
removeBehaviour(InvManipulationBehaviour.TYPE);
|
removeBehaviour(InvManipulationBehaviour.TYPE);
|
||||||
inserting.removeListener();
|
|
||||||
inserting = new InvManipulationBehaviour(this, this::getTargetFace);
|
inserting = new InvManipulationBehaviour(this, this::getTargetFace);
|
||||||
attachBehaviourLate(inserting);
|
attachBehaviourLate(inserting);
|
||||||
}
|
}
|
||||||
|
|
|
@ -171,6 +171,8 @@ public class DeployerBlockEntity extends KineticBlockEntity {
|
||||||
}
|
}
|
||||||
if (level.isClientSide)
|
if (level.isClientSide)
|
||||||
return;
|
return;
|
||||||
|
if (player == null)
|
||||||
|
return;
|
||||||
|
|
||||||
ItemStack stack = player.getMainHandItem();
|
ItemStack stack = player.getMainHandItem();
|
||||||
if (state == State.WAITING) {
|
if (state == State.WAITING) {
|
||||||
|
|
|
@ -273,12 +273,6 @@ public class FunnelBlockEntity extends SmartBlockEntity implements IHaveHovering
|
||||||
registerAwardables(behaviours, AllAdvancements.FUNNEL);
|
registerAwardables(behaviours, AllAdvancements.FUNNEL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void invalidateCaps() {
|
|
||||||
invManipulation.removeListener();
|
|
||||||
super.invalidateCaps();
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean supportsAmountOnFilter() {
|
private boolean supportsAmountOnFilter() {
|
||||||
BlockState blockState = getBlockState();
|
BlockState blockState = getBlockState();
|
||||||
boolean beltFunnelsupportsAmount = false;
|
boolean beltFunnelsupportsAmount = false;
|
||||||
|
|
|
@ -56,13 +56,6 @@ public class SmartObserverBlockEntity extends SmartBlockEntity {
|
||||||
behaviours.add(observedTank = new TankManipulationBehaviour(this, towardBlockFacing).bypassSidedness());
|
behaviours.add(observedTank = new TankManipulationBehaviour(this, towardBlockFacing).bypassSidedness());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void invalidateCaps() {
|
|
||||||
observedInventory.removeListener();
|
|
||||||
observedTank.removeListener();
|
|
||||||
super.invalidateCaps();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void tick() {
|
public void tick() {
|
||||||
super.tick();
|
super.tick();
|
||||||
|
|
|
@ -233,13 +233,6 @@ public class ThresholdSwitchBlockEntity extends SmartBlockEntity {
|
||||||
behaviours.add(observedTank = new TankManipulationBehaviour(this, towardBlockFacing).bypassSidedness());
|
behaviours.add(observedTank = new TankManipulationBehaviour(this, towardBlockFacing).bypassSidedness());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void invalidateCaps() {
|
|
||||||
observedInventory.removeListener();
|
|
||||||
observedTank.removeListener();
|
|
||||||
super.invalidateCaps();
|
|
||||||
}
|
|
||||||
|
|
||||||
public float getLevelForDisplay() {
|
public float getLevelForDisplay() {
|
||||||
return currentLevel == -1 ? 0 : currentLevel;
|
return currentLevel == -1 ? 0 : currentLevel;
|
||||||
}
|
}
|
||||||
|
|
|
@ -799,6 +799,8 @@ public class Carriage {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void createEntity(Level level, boolean loadPassengers) {
|
private void createEntity(Level level, boolean loadPassengers) {
|
||||||
|
if (positionAnchor != null)
|
||||||
|
serialisedEntity.put("Pos", VecHelper.writeNBT(positionAnchor));
|
||||||
Entity entity = EntityType.create(serialisedEntity, level)
|
Entity entity = EntityType.create(serialisedEntity, level)
|
||||||
.orElse(null);
|
.orElse(null);
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,6 @@ import com.simibubi.create.foundation.blockEntity.behaviour.BlockEntityBehaviour
|
||||||
import com.simibubi.create.foundation.blockEntity.behaviour.filtering.FilteringBehaviour;
|
import com.simibubi.create.foundation.blockEntity.behaviour.filtering.FilteringBehaviour;
|
||||||
import com.simibubi.create.foundation.item.ItemHelper.ExtractionCountMode;
|
import com.simibubi.create.foundation.item.ItemHelper.ExtractionCountMode;
|
||||||
import com.simibubi.create.foundation.utility.BlockFace;
|
import com.simibubi.create.foundation.utility.BlockFace;
|
||||||
import com.simibubi.create.foundation.utility.HashableNonNullConsumer;
|
|
||||||
|
|
||||||
import net.minecraft.core.BlockPos;
|
import net.minecraft.core.BlockPos;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
|
@ -80,10 +79,6 @@ public abstract class CapManipulationBehaviourBase<T, S extends CapManipulationB
|
||||||
targetCapability = LazyOptional.empty();
|
targetCapability = LazyOptional.empty();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void removeListener() {
|
|
||||||
targetCapability.removeListener(new HashableNonNullConsumer<>(this::onHandlerInvalidated, this));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void lazyTick() {
|
public void lazyTick() {
|
||||||
super.lazyTick();
|
super.lazyTick();
|
||||||
|
@ -132,8 +127,6 @@ public abstract class CapManipulationBehaviourBase<T, S extends CapManipulationB
|
||||||
Capability<T> capability = capability();
|
Capability<T> capability = capability();
|
||||||
targetCapability =
|
targetCapability =
|
||||||
bypassSided ? invBE.getCapability(capability) : invBE.getCapability(capability, targetBlockFace.getFace());
|
bypassSided ? invBE.getCapability(capability) : invBE.getCapability(capability, targetBlockFace.getFace());
|
||||||
if (targetCapability.isPresent())
|
|
||||||
targetCapability.addListener(new HashableNonNullConsumer<>(this::onHandlerInvalidated, this));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@FunctionalInterface
|
@FunctionalInterface
|
||||||
|
|
|
@ -53,11 +53,11 @@ public class FluidHelper {
|
||||||
public static boolean isLava(Fluid fluid) {
|
public static boolean isLava(Fluid fluid) {
|
||||||
return convertToStill(fluid) == Fluids.LAVA;
|
return convertToStill(fluid) == Fluids.LAVA;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isSame(FluidStack fluidStack, FluidStack fluidStack2) {
|
public static boolean isSame(FluidStack fluidStack, FluidStack fluidStack2) {
|
||||||
return fluidStack.getFluid() == fluidStack2.getFluid();
|
return fluidStack.getFluid() == fluidStack2.getFluid();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isSame(FluidStack fluidStack, Fluid fluid) {
|
public static boolean isSame(FluidStack fluidStack, Fluid fluid) {
|
||||||
return fluidStack.getFluid() == fluid;
|
return fluidStack.getFluid() == fluid;
|
||||||
}
|
}
|
||||||
|
@ -147,6 +147,8 @@ public class FluidHelper {
|
||||||
Fluid fluid = ForgeRegistries.FLUIDS.getValue(id);
|
Fluid fluid = ForgeRegistries.FLUIDS.getValue(id);
|
||||||
if (fluid == null)
|
if (fluid == null)
|
||||||
throw new JsonSyntaxException("Unknown fluid '" + id + "'");
|
throw new JsonSyntaxException("Unknown fluid '" + id + "'");
|
||||||
|
if (fluid == Fluids.EMPTY)
|
||||||
|
throw new JsonSyntaxException("Invalid empty fluid '" + id + "'");
|
||||||
int amount = GsonHelper.getAsInt(json, "amount");
|
int amount = GsonHelper.getAsInt(json, "amount");
|
||||||
FluidStack stack = new FluidStack(fluid, amount);
|
FluidStack stack = new FluidStack(fluid, amount);
|
||||||
|
|
||||||
|
|
|
@ -124,7 +124,7 @@ public abstract class FluidIngredient implements Predicate<FluidStack> {
|
||||||
|
|
||||||
public static FluidIngredient deserialize(@Nullable JsonElement je) {
|
public static FluidIngredient deserialize(@Nullable JsonElement je) {
|
||||||
if (!isFluidIngredient(je))
|
if (!isFluidIngredient(je))
|
||||||
throw new JsonSyntaxException("Invalid fluid ingredient: " + Objects.toString(je));
|
throw new JsonSyntaxException("Invalid fluid ingredient: " + je);
|
||||||
|
|
||||||
JsonObject json = je.getAsJsonObject();
|
JsonObject json = je.getAsJsonObject();
|
||||||
FluidIngredient ingredient = json.has("fluidTag") ? new FluidTagIngredient() : new FluidStackIngredient();
|
FluidIngredient ingredient = json.has("fluidTag") ? new FluidTagIngredient() : new FluidStackIngredient();
|
||||||
|
|
|
@ -19,7 +19,7 @@ Technology that empowers the player.'''
|
||||||
[[dependencies.create]]
|
[[dependencies.create]]
|
||||||
modId="forge"
|
modId="forge"
|
||||||
mandatory=true
|
mandatory=true
|
||||||
versionRange="[47.1.43,)"
|
versionRange="[47.1.3,)"
|
||||||
ordering="NONE"
|
ordering="NONE"
|
||||||
side="BOTH"
|
side="BOTH"
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue