mirror of
https://github.com/Jozufozu/Flywheel.git
synced 2025-01-26 04:47:59 +01:00
Force Crafters with a pulse
This commit is contained in:
parent
7e2b2ad776
commit
ba81d391e7
6 changed files with 72 additions and 37 deletions
|
@ -273,7 +273,7 @@ b7829c2ef2c47188713f8cab21b2c9bc7f9c5b79 assets\create\blockstates\portable_stor
|
||||||
e8b0a401c10d1ba67ed71ba31bd5f9bc28571b65 assets\create\blockstates\powered_toggle_latch.json
|
e8b0a401c10d1ba67ed71ba31bd5f9bc28571b65 assets\create\blockstates\powered_toggle_latch.json
|
||||||
3a739f9d4276828d83f2d2750bf3227c87bcd438 assets\create\blockstates\pulley_magnet.json
|
3a739f9d4276828d83f2d2750bf3227c87bcd438 assets\create\blockstates\pulley_magnet.json
|
||||||
469e430d96cb0a5e1aaf6b7cc5d401d488c9e600 assets\create\blockstates\pulse_repeater.json
|
469e430d96cb0a5e1aaf6b7cc5d401d488c9e600 assets\create\blockstates\pulse_repeater.json
|
||||||
5c1df061eb5efe49beee7219e113206fc31a4733 assets\create\blockstates\radial_chassis.json
|
5d1b30c2bab556f57c78e7780fd445b08f541a50 assets\create\blockstates\radial_chassis.json
|
||||||
8929677f2cc5354aa19ef182af69f9f0b41eb242 assets\create\blockstates\redstone_contact.json
|
8929677f2cc5354aa19ef182af69f9f0b41eb242 assets\create\blockstates\redstone_contact.json
|
||||||
c29213b77ac0c78d8979c5f6188d2b265696f9b9 assets\create\blockstates\redstone_link.json
|
c29213b77ac0c78d8979c5f6188d2b265696f9b9 assets\create\blockstates\redstone_link.json
|
||||||
e2990fe70ad5d10437a376e70e167d1856277cc1 assets\create\blockstates\rope.json
|
e2990fe70ad5d10437a376e70e167d1856277cc1 assets\create\blockstates\rope.json
|
||||||
|
@ -325,7 +325,7 @@ c77b46d8b459e5c7cc495393546f3fcca8a1fa1d assets\create\blockstates\weathered_lim
|
||||||
7f39521b211441f5c3e06d60c5978cebe16cacfb assets\create\blockstates\zinc_block.json
|
7f39521b211441f5c3e06d60c5978cebe16cacfb assets\create\blockstates\zinc_block.json
|
||||||
b7181bcd8182b2f17088e5aa881f374c9c65470c assets\create\blockstates\zinc_ore.json
|
b7181bcd8182b2f17088e5aa881f374c9c65470c assets\create\blockstates\zinc_ore.json
|
||||||
4311c87a21caccb97b693bf914c8ce79de3f814b assets\create\lang\en_ud.json
|
4311c87a21caccb97b693bf914c8ce79de3f814b assets\create\lang\en_ud.json
|
||||||
f7cd2198ffae7a8dea1902b242aa56110ca28885 assets\create\lang\en_us.json
|
076a6cd28a3c1020cf0080a5107718576eeb13e1 assets\create\lang\en_us.json
|
||||||
846200eb548d3bfa2e77b41039de159b4b6cfb45 assets\create\models\block\acacia_window.json
|
846200eb548d3bfa2e77b41039de159b4b6cfb45 assets\create\models\block\acacia_window.json
|
||||||
1930fa3a3c98d53dd19e4ee7f55bc27fd47aa281 assets\create\models\block\acacia_window_pane_noside.json
|
1930fa3a3c98d53dd19e4ee7f55bc27fd47aa281 assets\create\models\block\acacia_window_pane_noside.json
|
||||||
1763ea2c9b981d187f5031ba608f3d5d3be3986a assets\create\models\block\acacia_window_pane_noside_alt.json
|
1763ea2c9b981d187f5031ba608f3d5d3be3986a assets\create\models\block\acacia_window_pane_noside_alt.json
|
||||||
|
|
|
@ -29,8 +29,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"when": {
|
"when": {
|
||||||
"sticky_south": "true",
|
"axis": "x",
|
||||||
"axis": "x"
|
"sticky_south": "true"
|
||||||
},
|
},
|
||||||
"apply": {
|
"apply": {
|
||||||
"model": "create:block/radial_chassis_side_x_sticky",
|
"model": "create:block/radial_chassis_side_x_sticky",
|
||||||
|
@ -39,8 +39,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"when": {
|
"when": {
|
||||||
"sticky_south": "true",
|
"axis": "y",
|
||||||
"axis": "y"
|
"sticky_south": "true"
|
||||||
},
|
},
|
||||||
"apply": {
|
"apply": {
|
||||||
"model": "create:block/radial_chassis_side_y_sticky"
|
"model": "create:block/radial_chassis_side_y_sticky"
|
||||||
|
@ -48,8 +48,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"when": {
|
"when": {
|
||||||
"sticky_south": "true",
|
"axis": "z",
|
||||||
"axis": "z"
|
"sticky_south": "true"
|
||||||
},
|
},
|
||||||
"apply": {
|
"apply": {
|
||||||
"model": "create:block/radial_chassis_side_x_sticky",
|
"model": "create:block/radial_chassis_side_x_sticky",
|
||||||
|
@ -59,8 +59,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"when": {
|
"when": {
|
||||||
"sticky_south": "false",
|
"axis": "x",
|
||||||
"axis": "x"
|
"sticky_south": "false"
|
||||||
},
|
},
|
||||||
"apply": {
|
"apply": {
|
||||||
"model": "create:block/radial_chassis_side_x",
|
"model": "create:block/radial_chassis_side_x",
|
||||||
|
@ -69,8 +69,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"when": {
|
"when": {
|
||||||
"sticky_south": "false",
|
"axis": "y",
|
||||||
"axis": "y"
|
"sticky_south": "false"
|
||||||
},
|
},
|
||||||
"apply": {
|
"apply": {
|
||||||
"model": "create:block/radial_chassis_side_y"
|
"model": "create:block/radial_chassis_side_y"
|
||||||
|
@ -78,8 +78,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"when": {
|
"when": {
|
||||||
"sticky_south": "false",
|
"axis": "z",
|
||||||
"axis": "z"
|
"sticky_south": "false"
|
||||||
},
|
},
|
||||||
"apply": {
|
"apply": {
|
||||||
"model": "create:block/radial_chassis_side_x",
|
"model": "create:block/radial_chassis_side_x",
|
||||||
|
@ -89,8 +89,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"when": {
|
"when": {
|
||||||
"sticky_west": "true",
|
"axis": "x",
|
||||||
"axis": "x"
|
"sticky_west": "true"
|
||||||
},
|
},
|
||||||
"apply": {
|
"apply": {
|
||||||
"model": "create:block/radial_chassis_side_x_sticky",
|
"model": "create:block/radial_chassis_side_x_sticky",
|
||||||
|
@ -99,8 +99,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"when": {
|
"when": {
|
||||||
"sticky_west": "true",
|
"axis": "y",
|
||||||
"axis": "y"
|
"sticky_west": "true"
|
||||||
},
|
},
|
||||||
"apply": {
|
"apply": {
|
||||||
"model": "create:block/radial_chassis_side_y_sticky",
|
"model": "create:block/radial_chassis_side_y_sticky",
|
||||||
|
@ -109,8 +109,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"when": {
|
"when": {
|
||||||
"sticky_west": "true",
|
"axis": "z",
|
||||||
"axis": "z"
|
"sticky_west": "true"
|
||||||
},
|
},
|
||||||
"apply": {
|
"apply": {
|
||||||
"model": "create:block/radial_chassis_side_z_sticky",
|
"model": "create:block/radial_chassis_side_z_sticky",
|
||||||
|
@ -119,8 +119,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"when": {
|
"when": {
|
||||||
"sticky_west": "false",
|
"axis": "x",
|
||||||
"axis": "x"
|
"sticky_west": "false"
|
||||||
},
|
},
|
||||||
"apply": {
|
"apply": {
|
||||||
"model": "create:block/radial_chassis_side_x",
|
"model": "create:block/radial_chassis_side_x",
|
||||||
|
@ -129,8 +129,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"when": {
|
"when": {
|
||||||
"sticky_west": "false",
|
"axis": "y",
|
||||||
"axis": "y"
|
"sticky_west": "false"
|
||||||
},
|
},
|
||||||
"apply": {
|
"apply": {
|
||||||
"model": "create:block/radial_chassis_side_y",
|
"model": "create:block/radial_chassis_side_y",
|
||||||
|
@ -139,8 +139,8 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"when": {
|
"when": {
|
||||||
"sticky_west": "false",
|
"axis": "z",
|
||||||
"axis": "z"
|
"sticky_west": "false"
|
||||||
},
|
},
|
||||||
"apply": {
|
"apply": {
|
||||||
"model": "create:block/radial_chassis_side_z",
|
"model": "create:block/radial_chassis_side_z",
|
||||||
|
|
|
@ -1047,6 +1047,8 @@
|
||||||
"block.create.mechanical_crafter.tooltip.summary": "A kinetic assembler for _automating_ any _shaped_ _crafting_ recipe. Place _multiple_ _in_ _a_ _grid_ corresponding to your recipe, and _arrange_ _their_ _belts_ to create a _flow_ that exits the grid on one of the crafters.",
|
"block.create.mechanical_crafter.tooltip.summary": "A kinetic assembler for _automating_ any _shaped_ _crafting_ recipe. Place _multiple_ _in_ _a_ _grid_ corresponding to your recipe, and _arrange_ _their_ _belts_ to create a _flow_ that exits the grid on one of the crafters.",
|
||||||
"block.create.mechanical_crafter.tooltip.condition1": "When Rotated",
|
"block.create.mechanical_crafter.tooltip.condition1": "When Rotated",
|
||||||
"block.create.mechanical_crafter.tooltip.behaviour1": "_Starts_ _the_ _crafting_ _process_ as soon as _all_ _crafters_ in the grid have been _given_ _an_ _item_.",
|
"block.create.mechanical_crafter.tooltip.behaviour1": "_Starts_ _the_ _crafting_ _process_ as soon as _all_ _crafters_ in the grid have been _given_ _an_ _item_.",
|
||||||
|
"block.create.mechanical_crafter.tooltip.condition2": "On Redstone Pulse",
|
||||||
|
"block.create.mechanical_crafter.tooltip.behaviour2": "_Forces_ the start of the _crafting_ _process_ with all currently given _items_ in the grid.",
|
||||||
"block.create.mechanical_crafter.tooltip.control1": "When Wrenched at Front",
|
"block.create.mechanical_crafter.tooltip.control1": "When Wrenched at Front",
|
||||||
"block.create.mechanical_crafter.tooltip.action1": "_Cycles_ _the_ _direction_ an individual crafter _moves_ _its_ _items_ towards. To form a working grid, _arrange_ _the_ _belts_ _in_ _a_ _flow_ which moves all items towards a final crafter. The final crafter must _point_ _away_ from the grid.",
|
"block.create.mechanical_crafter.tooltip.action1": "_Cycles_ _the_ _direction_ an individual crafter _moves_ _its_ _items_ towards. To form a working grid, _arrange_ _the_ _belts_ _in_ _a_ _flow_ which moves all items towards a final crafter. The final crafter must _point_ _away_ from the grid.",
|
||||||
"block.create.mechanical_crafter.tooltip.control2": "When Wrenched at back",
|
"block.create.mechanical_crafter.tooltip.control2": "When Wrenched at back",
|
||||||
|
|
|
@ -63,10 +63,12 @@ public class MechanicalCrafterTileEntity extends KineticTileEntity {
|
||||||
return stack;
|
return stack;
|
||||||
return super.insertItem(slot, stack, simulate);
|
return super.insertItem(slot, stack, simulate);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
protected void onContentsChanged(int slot) {
|
protected void onContentsChanged(int slot) {
|
||||||
if (!getStackInSlot(slot).isEmpty() && phase == Phase.IDLE)
|
if (!getStackInSlot(slot).isEmpty() && phase == Phase.IDLE)
|
||||||
checkCompletedRecipe();
|
checkCompletedRecipe(false);
|
||||||
markDirty();
|
markDirty();
|
||||||
sendData();
|
sendData();
|
||||||
};
|
};
|
||||||
|
@ -80,6 +82,7 @@ public class MechanicalCrafterTileEntity extends KineticTileEntity {
|
||||||
protected Phase phase;
|
protected Phase phase;
|
||||||
protected int countDown;
|
protected int countDown;
|
||||||
protected boolean covered;
|
protected boolean covered;
|
||||||
|
private boolean wasPoweredBefore = true;
|
||||||
|
|
||||||
protected GroupedItems groupedItemsBeforeCraft; // for rendering on client
|
protected GroupedItems groupedItemsBeforeCraft; // for rendering on client
|
||||||
private InsertingBehaviour inserting;
|
private InsertingBehaviour inserting;
|
||||||
|
@ -198,11 +201,20 @@ public class MechanicalCrafterTileEntity extends KineticTileEntity {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void tick() {
|
public void tick() {
|
||||||
super.tick();
|
super.tick();
|
||||||
|
|
||||||
if (phase == Phase.ACCEPTING)
|
if (phase == Phase.ACCEPTING)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if(wasPoweredBefore != world.isBlockPowered(pos)) {
|
||||||
|
wasPoweredBefore = world.isBlockPowered(pos);
|
||||||
|
if(wasPoweredBefore) {
|
||||||
|
if (world.isRemote)
|
||||||
|
return;
|
||||||
|
checkCompletedRecipe(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (phase == Phase.ASSEMBLING) {
|
if (phase == Phase.ASSEMBLING) {
|
||||||
countDown -= getCountDownSpeed();
|
countDown -= getCountDownSpeed();
|
||||||
|
@ -321,7 +333,6 @@ public class MechanicalCrafterTileEntity extends KineticTileEntity {
|
||||||
tryInsert();
|
tryInsert();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected boolean isTargetingBelt() {
|
protected boolean isTargetingBelt() {
|
||||||
|
@ -405,23 +416,26 @@ public class MechanicalCrafterTileEntity extends KineticTileEntity {
|
||||||
if (world.isRemote)
|
if (world.isRemote)
|
||||||
return;
|
return;
|
||||||
if (phase == Phase.IDLE && craftingItemPresent())
|
if (phase == Phase.IDLE && craftingItemPresent())
|
||||||
checkCompletedRecipe();
|
checkCompletedRecipe(false);
|
||||||
if (phase == Phase.INSERTING)
|
if (phase == Phase.INSERTING)
|
||||||
tryInsert();
|
tryInsert();
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean craftingItemPresent() {
|
public boolean craftingItemPresent() {
|
||||||
return !inventory.getStackInSlot(0)
|
return !inventory.getStackInSlot(0).isEmpty();
|
||||||
.isEmpty() || covered;
|
}
|
||||||
|
|
||||||
|
public boolean craftingItemOrCoverPresent() {
|
||||||
|
return !inventory.getStackInSlot(0).isEmpty() || covered;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void checkCompletedRecipe() {
|
protected void checkCompletedRecipe(boolean poweredStart) {
|
||||||
if (getSpeed() == 0)
|
if (getSpeed() == 0)
|
||||||
return;
|
return;
|
||||||
if (world.isRemote)
|
if (world.isRemote)
|
||||||
return;
|
return;
|
||||||
List<MechanicalCrafterTileEntity> chain =
|
List<MechanicalCrafterTileEntity> chain =
|
||||||
RecipeGridHandler.getAllCraftersOfChainIf(this, MechanicalCrafterTileEntity::craftingItemPresent);
|
RecipeGridHandler.getAllCraftersOfChainIf(this, poweredStart ? MechanicalCrafterTileEntity::craftingItemPresent : MechanicalCrafterTileEntity::craftingItemOrCoverPresent, poweredStart);
|
||||||
if (chain == null)
|
if (chain == null)
|
||||||
return;
|
return;
|
||||||
chain.forEach(MechanicalCrafterTileEntity::begin);
|
chain.forEach(MechanicalCrafterTileEntity::begin);
|
||||||
|
|
|
@ -33,21 +33,38 @@ public class RecipeGridHandler {
|
||||||
public static List<MechanicalCrafterTileEntity> getAllCraftersOfChain(MechanicalCrafterTileEntity root) {
|
public static List<MechanicalCrafterTileEntity> getAllCraftersOfChain(MechanicalCrafterTileEntity root) {
|
||||||
return getAllCraftersOfChainIf(root, Predicates.alwaysTrue());
|
return getAllCraftersOfChainIf(root, Predicates.alwaysTrue());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static List<MechanicalCrafterTileEntity> getAllCraftersOfChainIf(MechanicalCrafterTileEntity root,
|
||||||
|
Predicate<MechanicalCrafterTileEntity> test){
|
||||||
|
return getAllCraftersOfChainIf(root, test, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public static List<MechanicalCrafterTileEntity> getAllCraftersOfChainIf(MechanicalCrafterTileEntity root,
|
public static List<MechanicalCrafterTileEntity> getAllCraftersOfChainIf(MechanicalCrafterTileEntity root,
|
||||||
Predicate<MechanicalCrafterTileEntity> test) {
|
Predicate<MechanicalCrafterTileEntity> test, boolean poweredStart) {
|
||||||
List<MechanicalCrafterTileEntity> crafters = new ArrayList<>();
|
List<MechanicalCrafterTileEntity> crafters = new ArrayList<>();
|
||||||
List<Pair<MechanicalCrafterTileEntity, MechanicalCrafterTileEntity>> frontier = new ArrayList<>();
|
List<Pair<MechanicalCrafterTileEntity, MechanicalCrafterTileEntity>> frontier = new ArrayList<>();
|
||||||
Set<MechanicalCrafterTileEntity> visited = new HashSet<>();
|
Set<MechanicalCrafterTileEntity> visited = new HashSet<>();
|
||||||
frontier.add(Pair.of(root, null));
|
frontier.add(Pair.of(root, null));
|
||||||
|
|
||||||
|
boolean powered = false;
|
||||||
|
boolean empty = false;
|
||||||
|
boolean allEmpty = true;
|
||||||
|
|
||||||
while (!frontier.isEmpty()) {
|
while (!frontier.isEmpty()) {
|
||||||
Pair<MechanicalCrafterTileEntity, MechanicalCrafterTileEntity> pair = frontier.remove(0);
|
Pair<MechanicalCrafterTileEntity, MechanicalCrafterTileEntity> pair = frontier.remove(0);
|
||||||
MechanicalCrafterTileEntity current = pair.getKey();
|
MechanicalCrafterTileEntity current = pair.getKey();
|
||||||
MechanicalCrafterTileEntity last = pair.getValue();
|
MechanicalCrafterTileEntity last = pair.getValue();
|
||||||
|
|
||||||
if (visited.contains(current) || !test.test(current))
|
if (visited.contains(current))
|
||||||
return null;
|
return null;
|
||||||
|
if(!(test.test(current)))
|
||||||
|
empty = true;
|
||||||
|
else
|
||||||
|
allEmpty = false;
|
||||||
|
if(poweredStart && current.getWorld().isBlockPowered(current.getPos()))
|
||||||
|
powered = true;
|
||||||
|
|
||||||
crafters.add(current);
|
crafters.add(current);
|
||||||
visited.add(current);
|
visited.add(current);
|
||||||
|
|
||||||
|
@ -59,7 +76,7 @@ public class RecipeGridHandler {
|
||||||
frontier.add(Pair.of(preceding, current));
|
frontier.add(Pair.of(preceding, current));
|
||||||
}
|
}
|
||||||
|
|
||||||
return crafters;
|
return empty && ! powered || allEmpty ? null : crafters;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static MechanicalCrafterTileEntity getTargetingCrafter(MechanicalCrafterTileEntity crafter) {
|
public static MechanicalCrafterTileEntity getTargetingCrafter(MechanicalCrafterTileEntity crafter) {
|
||||||
|
|
|
@ -223,6 +223,8 @@
|
||||||
"block.create.mechanical_crafter.tooltip.summary": "A kinetic assembler for _automating_ any _shaped_ _crafting_ recipe. Place _multiple_ _in_ _a_ _grid_ corresponding to your recipe, and _arrange_ _their_ _belts_ to create a _flow_ that exits the grid on one of the crafters.",
|
"block.create.mechanical_crafter.tooltip.summary": "A kinetic assembler for _automating_ any _shaped_ _crafting_ recipe. Place _multiple_ _in_ _a_ _grid_ corresponding to your recipe, and _arrange_ _their_ _belts_ to create a _flow_ that exits the grid on one of the crafters.",
|
||||||
"block.create.mechanical_crafter.tooltip.condition1": "When Rotated",
|
"block.create.mechanical_crafter.tooltip.condition1": "When Rotated",
|
||||||
"block.create.mechanical_crafter.tooltip.behaviour1": "_Starts_ _the_ _crafting_ _process_ as soon as _all_ _crafters_ in the grid have been _given_ _an_ _item_.",
|
"block.create.mechanical_crafter.tooltip.behaviour1": "_Starts_ _the_ _crafting_ _process_ as soon as _all_ _crafters_ in the grid have been _given_ _an_ _item_.",
|
||||||
|
"block.create.mechanical_crafter.tooltip.condition2": "On Redstone Pulse",
|
||||||
|
"block.create.mechanical_crafter.tooltip.behaviour2": "_Forces_ the start of the _crafting_ _process_ with all currently given _items_ in the grid.",
|
||||||
"block.create.mechanical_crafter.tooltip.control1": "When Wrenched at Front",
|
"block.create.mechanical_crafter.tooltip.control1": "When Wrenched at Front",
|
||||||
"block.create.mechanical_crafter.tooltip.action1": "_Cycles_ _the_ _direction_ an individual crafter _moves_ _its_ _items_ towards. To form a working grid, _arrange_ _the_ _belts_ _in_ _a_ _flow_ which moves all items towards a final crafter. The final crafter must _point_ _away_ from the grid.",
|
"block.create.mechanical_crafter.tooltip.action1": "_Cycles_ _the_ _direction_ an individual crafter _moves_ _its_ _items_ towards. To form a working grid, _arrange_ _the_ _belts_ _in_ _a_ _flow_ which moves all items towards a final crafter. The final crafter must _point_ _away_ from the grid.",
|
||||||
"block.create.mechanical_crafter.tooltip.control2": "When Wrenched at back",
|
"block.create.mechanical_crafter.tooltip.control2": "When Wrenched at back",
|
||||||
|
|
Loading…
Reference in a new issue