mirror of
https://github.com/Creators-of-Create/Create.git
synced 2025-01-12 07:16:54 +01:00
A cure to darkness
- Kinetic blocks no longer cause chunks to lose all block light information - Stockpile switch and sequencer no longer open the GUI to the wrong players - Belt items no longer skip blocking attachments while loaded in - Nozzle explosions no longer cause block damage - PSIs no longer transfer an excess of items, deleting them in the process
This commit is contained in:
parent
72ddc1251a
commit
3c0b55ac1d
17 changed files with 74 additions and 58 deletions
|
@ -13,7 +13,7 @@ apply plugin: 'net.minecraftforge.gradle'
|
||||||
apply plugin: 'eclipse'
|
apply plugin: 'eclipse'
|
||||||
apply plugin: 'maven-publish'
|
apply plugin: 'maven-publish'
|
||||||
|
|
||||||
version = 'mc1.14.4_v0.2.2a'
|
version = 'mc1.14.4_v0.2.2b'
|
||||||
group = 'com.simibubi.create'
|
group = 'com.simibubi.create'
|
||||||
archivesBaseName = 'create'
|
archivesBaseName = 'create'
|
||||||
|
|
||||||
|
|
|
@ -38,12 +38,12 @@ public class KineticNetwork {
|
||||||
return;
|
return;
|
||||||
if (te.isSource()) {
|
if (te.isSource()) {
|
||||||
unloadedCapacity -= lastCapacity * getStressMultiplierForSpeed(te.getGeneratedSpeed());
|
unloadedCapacity -= lastCapacity * getStressMultiplierForSpeed(te.getGeneratedSpeed());
|
||||||
float addedStressCapacity = te.getAddedStressCapacity();
|
float addedStressCapacity = te.calculateAddedStressCapacity();
|
||||||
sources.put(te, addedStressCapacity);
|
sources.put(te, addedStressCapacity);
|
||||||
}
|
}
|
||||||
|
|
||||||
unloadedStress -= lastStress * getStressMultiplierForSpeed(te.getTheoreticalSpeed());
|
unloadedStress -= lastStress * getStressMultiplierForSpeed(te.getTheoreticalSpeed());
|
||||||
float stressApplied = te.getStressApplied();
|
float stressApplied = te.calculateStressApplied();
|
||||||
members.put(te, stressApplied);
|
members.put(te, stressApplied);
|
||||||
|
|
||||||
unloadedMembers--;
|
unloadedMembers--;
|
||||||
|
@ -59,8 +59,8 @@ public class KineticNetwork {
|
||||||
if (members.containsKey(te))
|
if (members.containsKey(te))
|
||||||
return;
|
return;
|
||||||
if (te.isSource())
|
if (te.isSource())
|
||||||
sources.put(te, te.getAddedStressCapacity());
|
sources.put(te, te.calculateAddedStressCapacity());
|
||||||
members.put(te, te.getStressApplied());
|
members.put(te, te.calculateStressApplied());
|
||||||
te.updateFromNetwork(currentCapacity, currentStress, getSize());
|
te.updateFromNetwork(currentCapacity, currentStress, getSize());
|
||||||
te.networkDirty = true;
|
te.networkDirty = true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,7 +55,7 @@ public abstract class GeneratingKineticTileEntity extends KineticTileEntity {
|
||||||
public boolean addToGoggleTooltip(List<String> tooltip, boolean isPlayerSneaking) {
|
public boolean addToGoggleTooltip(List<String> tooltip, boolean isPlayerSneaking) {
|
||||||
boolean added = super.addToGoggleTooltip(tooltip, isPlayerSneaking);
|
boolean added = super.addToGoggleTooltip(tooltip, isPlayerSneaking);
|
||||||
|
|
||||||
float stressBase = getAddedStressCapacity();
|
float stressBase = calculateAddedStressCapacity();
|
||||||
if (stressBase != 0 && IRotate.StressImpact.isEnabled()) {
|
if (stressBase != 0 && IRotate.StressImpact.isEnabled()) {
|
||||||
tooltip.add(spacing + Lang.translate("gui.goggles.generator_stats"));
|
tooltip.add(spacing + Lang.translate("gui.goggles.generator_stats"));
|
||||||
tooltip.add(spacing + TextFormatting.GRAY + Lang.translate("tooltip.capacityProvided"));
|
tooltip.add(spacing + TextFormatting.GRAY + Lang.translate("tooltip.capacityProvided"));
|
||||||
|
@ -97,8 +97,8 @@ public abstract class GeneratingKineticTileEntity extends KineticTileEntity {
|
||||||
|
|
||||||
if (hasNetwork() && speed != 0) {
|
if (hasNetwork() && speed != 0) {
|
||||||
KineticNetwork network = getOrCreateNetwork();
|
KineticNetwork network = getOrCreateNetwork();
|
||||||
notifyStressCapacityChange(getAddedStressCapacity());
|
notifyStressCapacityChange(calculateAddedStressCapacity());
|
||||||
getOrCreateNetwork().updateStressFor(this, getStressApplied());
|
getOrCreateNetwork().updateStressFor(this, calculateStressApplied());
|
||||||
network.updateStress();
|
network.updateStress();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,7 +112,7 @@ public abstract class GeneratingKineticTileEntity extends KineticTileEntity {
|
||||||
if (speed == 0) {
|
if (speed == 0) {
|
||||||
if (hasSource()) {
|
if (hasSource()) {
|
||||||
notifyStressCapacityChange(0);
|
notifyStressCapacityChange(0);
|
||||||
getOrCreateNetwork().updateStressFor(this, getStressApplied());
|
getOrCreateNetwork().updateStressFor(this, calculateStressApplied());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
detachKinetics();
|
detachKinetics();
|
||||||
|
|
|
@ -139,20 +139,22 @@ public abstract class KineticTileEntity extends SmartTileEntity
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public float getAddedStressCapacity() {
|
public float calculateAddedStressCapacity() {
|
||||||
Map<ResourceLocation, ConfigValue<Double>> capacityMap = AllConfigs.SERVER.kinetics.stressValues.capacities;
|
Map<ResourceLocation, ConfigValue<Double>> capacityMap = AllConfigs.SERVER.kinetics.stressValues.capacities;
|
||||||
ResourceLocation path = getBlockState().getBlock().getRegistryName();
|
ResourceLocation path = getBlockState().getBlock().getRegistryName();
|
||||||
if (!capacityMap.containsKey(path))
|
|
||||||
return 0;
|
float capacity = capacityMap.containsKey(path) ? capacityMap.get(path).get().floatValue() : 0;
|
||||||
return capacityMap.get(path).get().floatValue();
|
this.lastCapacityProvided = capacity;
|
||||||
|
return capacity;
|
||||||
}
|
}
|
||||||
|
|
||||||
public float getStressApplied() {
|
public float calculateStressApplied() {
|
||||||
Map<ResourceLocation, ConfigValue<Double>> stressEntries = AllConfigs.SERVER.kinetics.stressValues.impacts;
|
Map<ResourceLocation, ConfigValue<Double>> stressEntries = AllConfigs.SERVER.kinetics.stressValues.impacts;
|
||||||
ResourceLocation path = getBlockState().getBlock().getRegistryName();
|
ResourceLocation path = getBlockState().getBlock().getRegistryName();
|
||||||
if (!stressEntries.containsKey(path))
|
|
||||||
return 1;
|
float impact = stressEntries.containsKey(path) ? stressEntries.get(path).get().floatValue() : 1;
|
||||||
return stressEntries.get(path).get().floatValue();
|
this.lastStressApplied = impact;
|
||||||
|
return impact;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onSpeedChanged(float previousSpeed) {
|
public void onSpeedChanged(float previousSpeed) {
|
||||||
|
@ -187,12 +189,10 @@ public abstract class KineticTileEntity extends SmartTileEntity
|
||||||
networkTag.putFloat("Capacity", capacity);
|
networkTag.putFloat("Capacity", capacity);
|
||||||
networkTag.putInt("Size", networkSize);
|
networkTag.putInt("Size", networkSize);
|
||||||
|
|
||||||
float stressApplied = getStressApplied();
|
if (lastStressApplied != 0)
|
||||||
float addedStressCapacity = getAddedStressCapacity();
|
networkTag.putFloat("AddedStress", lastStressApplied);
|
||||||
if (stressApplied != 0)
|
if (lastCapacityProvided != 0)
|
||||||
networkTag.putFloat("AddedStress", stressApplied);
|
networkTag.putFloat("AddedCapacity", lastCapacityProvided);
|
||||||
if (addedStressCapacity != 0)
|
|
||||||
networkTag.putFloat("AddedCapacity", addedStressCapacity);
|
|
||||||
|
|
||||||
compound.put("Network", networkTag);
|
compound.put("Network", networkTag);
|
||||||
}
|
}
|
||||||
|
@ -203,7 +203,6 @@ public abstract class KineticTileEntity extends SmartTileEntity
|
||||||
@Override
|
@Override
|
||||||
public void read(CompoundNBT compound) {
|
public void read(CompoundNBT compound) {
|
||||||
speed = compound.getFloat("Speed");
|
speed = compound.getFloat("Speed");
|
||||||
|
|
||||||
source = null;
|
source = null;
|
||||||
network = null;
|
network = null;
|
||||||
overStressed = false;
|
overStressed = false;
|
||||||
|
@ -392,9 +391,9 @@ public abstract class KineticTileEntity extends SmartTileEntity
|
||||||
@Override
|
@Override
|
||||||
public boolean addToGoggleTooltip(List<String> tooltip, boolean isPlayerSneaking) {
|
public boolean addToGoggleTooltip(List<String> tooltip, boolean isPlayerSneaking) {
|
||||||
boolean added = false;
|
boolean added = false;
|
||||||
float stressAtBase = getStressApplied();
|
float stressAtBase = calculateStressApplied();
|
||||||
|
|
||||||
if (getStressApplied() != 0 && StressImpact.isEnabled()) {
|
if (calculateStressApplied() != 0 && StressImpact.isEnabled()) {
|
||||||
tooltip.add(spacing + Lang.translate("gui.goggles.kinetic_stats"));
|
tooltip.add(spacing + Lang.translate("gui.goggles.kinetic_stats"));
|
||||||
tooltip.add(spacing + TextFormatting.GRAY + Lang.translate("tooltip.stressImpact"));
|
tooltip.add(spacing + TextFormatting.GRAY + Lang.translate("tooltip.stressImpact"));
|
||||||
|
|
||||||
|
|
|
@ -102,8 +102,8 @@ public class StorageInterfaceMovement extends MovementBehaviour {
|
||||||
|
|
||||||
extracting.withAmountThreshold(stack -> {
|
extracting.withAmountThreshold(stack -> {
|
||||||
ItemStack tester = stack.copy();
|
ItemStack tester = stack.copy();
|
||||||
tester.setCount(64);
|
tester.setCount(tester.getMaxStackSize());
|
||||||
return 64 - ItemHandlerHelper.insertItemStacked(inv, stack, true).getCount();
|
return stack.getCount() - ItemHandlerHelper.insertItemStacked(inv, stack, true).getCount();
|
||||||
});
|
});
|
||||||
|
|
||||||
extracting.setCallback(stack -> {
|
extracting.setCallback(stack -> {
|
||||||
|
|
|
@ -52,13 +52,13 @@ public class MechanicalBearingTileEntity extends GeneratingKineticTileEntity imp
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public float getAddedStressCapacity() {
|
public float calculateAddedStressCapacity() {
|
||||||
return isWindmill ? super.getAddedStressCapacity() : 0;
|
return isWindmill ? super.calculateAddedStressCapacity() : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public float getStressApplied() {
|
public float calculateStressApplied() {
|
||||||
return isWindmill ? 0 : super.getStressApplied();
|
return isWindmill ? 0 : super.calculateStressApplied();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void neighbourChanged() {
|
public void neighbourChanged() {
|
||||||
|
|
|
@ -204,7 +204,7 @@ public class CrushingWheelControllerTileEntity extends SyncedTileEntity implemen
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompoundNBT write(CompoundNBT compound) {
|
public CompoundNBT write(CompoundNBT compound) {
|
||||||
if (hasEntity() && !isFrozen())
|
if (hasEntity())
|
||||||
compound.put("Entity", NBTUtil.writeUniqueId(entityUUID));
|
compound.put("Entity", NBTUtil.writeUniqueId(entityUUID));
|
||||||
compound.put("Inventory", inventory.serializeNBT());
|
compound.put("Inventory", inventory.serializeNBT());
|
||||||
compound.putFloat("Speed", crushingspeed);
|
compound.putFloat("Speed", crushingspeed);
|
||||||
|
|
|
@ -45,13 +45,13 @@ public class EncasedFanTileEntity extends GeneratingKineticTileEntity {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public float getAddedStressCapacity() {
|
public float calculateAddedStressCapacity() {
|
||||||
return isGenerator ? super.getAddedStressCapacity() : 0;
|
return isGenerator ? super.calculateAddedStressCapacity() : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public float getStressApplied() {
|
public float calculateStressApplied() {
|
||||||
return isGenerator ? 0 : super.getStressApplied();
|
return isGenerator ? 0 : super.calculateStressApplied();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -158,8 +158,21 @@ public class NozzleTileEntity extends SmartTileEntity {
|
||||||
pushingEntities.add(entity);
|
pushingEntities.add(entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!pushing && pushingEntities.size() > 512 && !world.isRemote)
|
for (Iterator<Entity> iterator = pushingEntities.iterator(); iterator.hasNext();) {
|
||||||
world.createExplosion(null, center.x, center.y, center.z, 6, Mode.BREAK);
|
Entity entity = iterator.next();
|
||||||
|
if (entity.isAlive())
|
||||||
|
continue;
|
||||||
|
iterator.remove();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!pushing && pushingEntities.size() > 256 && !world.isRemote) {
|
||||||
|
world.createExplosion(null, center.x, center.y, center.z, 2, Mode.NONE);
|
||||||
|
for (Iterator<Entity> iterator = pushingEntities.iterator(); iterator.hasNext();) {
|
||||||
|
Entity entity = iterator.next();
|
||||||
|
entity.remove();
|
||||||
|
iterator.remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -43,7 +43,7 @@ public class FlywheelTileEntity extends GeneratingKineticTileEntity {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public float getAddedStressCapacity() {
|
public float calculateAddedStressCapacity() {
|
||||||
return generatedCapacity;
|
return generatedCapacity;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,7 @@ import com.simibubi.create.modules.contraptions.base.RotatedPillarKineticBlock;
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.block.BlockState;
|
import net.minecraft.block.BlockState;
|
||||||
import net.minecraft.block.Blocks;
|
import net.minecraft.block.Blocks;
|
||||||
|
import net.minecraft.client.entity.player.ClientPlayerEntity;
|
||||||
import net.minecraft.entity.player.PlayerEntity;
|
import net.minecraft.entity.player.PlayerEntity;
|
||||||
import net.minecraft.item.BlockItem;
|
import net.minecraft.item.BlockItem;
|
||||||
import net.minecraft.item.BlockItemUseContext;
|
import net.minecraft.item.BlockItemUseContext;
|
||||||
|
@ -86,6 +87,7 @@ public class SequencedGearshiftBlock extends HorizontalAxisKineticBlock implemen
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (player instanceof ClientPlayerEntity)
|
||||||
DistExecutor.runWhenOn(Dist.CLIENT, () -> () -> withTileEntityDo(worldIn, pos, this::displayScreen));
|
DistExecutor.runWhenOn(Dist.CLIENT, () -> () -> withTileEntityDo(worldIn, pos, this::displayScreen));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,7 +56,7 @@ public class BeltTileEntity extends KineticTileEntity {
|
||||||
protected BeltInventory inventory;
|
protected BeltInventory inventory;
|
||||||
protected LazyOptional<IItemHandler> itemHandler;
|
protected LazyOptional<IItemHandler> itemHandler;
|
||||||
|
|
||||||
private CompoundNBT trackerUpdateTag;
|
public CompoundNBT trackerUpdateTag;
|
||||||
|
|
||||||
public BeltTileEntity() {
|
public BeltTileEntity() {
|
||||||
super(AllTileEntities.BELT.type);
|
super(AllTileEntities.BELT.type);
|
||||||
|
@ -115,10 +115,10 @@ public class BeltTileEntity extends KineticTileEntity {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public float getStressApplied() {
|
public float calculateStressApplied() {
|
||||||
if (!isController())
|
if (!isController())
|
||||||
return 0;
|
return 0;
|
||||||
return super.getStressApplied();
|
return super.calculateStressApplied();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -126,6 +126,10 @@ public class BeltInventory {
|
||||||
BeltTileEntity beltSegment = BeltHelper.getBeltAtSegment(belt, segmentBefore);
|
BeltTileEntity beltSegment = BeltHelper.getBeltAtSegment(belt, segmentBefore);
|
||||||
if (beltSegment != null) {
|
if (beltSegment != null) {
|
||||||
|
|
||||||
|
// wait in case belt isnt initialized yet
|
||||||
|
if (current.locked && beltSegment.trackerUpdateTag != null)
|
||||||
|
continue;
|
||||||
|
|
||||||
current.locked = false;
|
current.locked = false;
|
||||||
List<BeltAttachmentState> attachments = beltSegment.attachmentTracker.attachments;
|
List<BeltAttachmentState> attachments = beltSegment.attachmentTracker.attachments;
|
||||||
for (BeltAttachmentState attachmentState : attachments) {
|
for (BeltAttachmentState attachmentState : attachments) {
|
||||||
|
|
|
@ -8,6 +8,7 @@ import net.minecraft.block.BlockState;
|
||||||
import net.minecraft.block.Blocks;
|
import net.minecraft.block.Blocks;
|
||||||
import net.minecraft.block.HorizontalBlock;
|
import net.minecraft.block.HorizontalBlock;
|
||||||
import net.minecraft.block.material.PushReaction;
|
import net.minecraft.block.material.PushReaction;
|
||||||
|
import net.minecraft.client.entity.player.ClientPlayerEntity;
|
||||||
import net.minecraft.entity.player.PlayerEntity;
|
import net.minecraft.entity.player.PlayerEntity;
|
||||||
import net.minecraft.item.BlockItemUseContext;
|
import net.minecraft.item.BlockItemUseContext;
|
||||||
import net.minecraft.state.IntegerProperty;
|
import net.minecraft.state.IntegerProperty;
|
||||||
|
@ -87,6 +88,7 @@ public class StockswitchBlock extends HorizontalBlock implements ITE<Stockswitch
|
||||||
@Override
|
@Override
|
||||||
public boolean onBlockActivated(BlockState state, World worldIn, BlockPos pos, PlayerEntity player, Hand handIn,
|
public boolean onBlockActivated(BlockState state, World worldIn, BlockPos pos, PlayerEntity player, Hand handIn,
|
||||||
BlockRayTraceResult hit) {
|
BlockRayTraceResult hit) {
|
||||||
|
if (player instanceof ClientPlayerEntity)
|
||||||
DistExecutor.runWhenOn(Dist.CLIENT, () -> () -> withTileEntityDo(worldIn, pos, this::displayScreen));
|
DistExecutor.runWhenOn(Dist.CLIENT, () -> () -> withTileEntityDo(worldIn, pos, this::displayScreen));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -162,20 +162,16 @@ public class FlexcrateTileEntity extends SyncedTileEntity implements INamedConta
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompoundNBT write(CompoundNBT compound) {
|
public CompoundNBT write(CompoundNBT compound) {
|
||||||
if (!isSecondaryCrate()) {
|
|
||||||
compound.putBoolean("Main", true);
|
compound.putBoolean("Main", true);
|
||||||
compound.putInt("AllowedAmount", allowedAmount);
|
compound.putInt("AllowedAmount", allowedAmount);
|
||||||
compound.put("Inventory", inventory.serializeNBT());
|
compound.put("Inventory", inventory.serializeNBT());
|
||||||
}
|
|
||||||
return super.write(compound);
|
return super.write(compound);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void read(CompoundNBT compound) {
|
public void read(CompoundNBT compound) {
|
||||||
if (compound.contains("Main")) {
|
|
||||||
allowedAmount = compound.getInt("AllowedAmount");
|
allowedAmount = compound.getInt("AllowedAmount");
|
||||||
inventory.deserializeNBT(compound.getCompound("Inventory"));
|
inventory.deserializeNBT(compound.getCompound("Inventory"));
|
||||||
}
|
|
||||||
super.read(compound);
|
super.read(compound);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@ loaderVersion="[28,)"
|
||||||
|
|
||||||
[[mods]]
|
[[mods]]
|
||||||
modId="create"
|
modId="create"
|
||||||
version="mc1.14-0.2.2a"
|
version="mc1.14-0.2.2b"
|
||||||
displayName="Create"
|
displayName="Create"
|
||||||
#updateJSONURL=""
|
#updateJSONURL=""
|
||||||
authors="simibubi"
|
authors="simibubi"
|
||||||
|
|
Loading…
Reference in a new issue