mirror of
https://github.com/Anuken/Mindustry.git
synced 2025-12-05 18:30:22 -08:00
Compare commits
2 commits
b4aa16285e
...
3656e90ae1
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
3656e90ae1 | ||
|
|
03f6a7f590 |
3 changed files with 70 additions and 31 deletions
|
|
@ -355,17 +355,19 @@ public class ContentPatcher{
|
|||
}, value, true);
|
||||
}else if(value instanceof JsonValue jsv && object instanceof Block bl && jsv.isObject() && field.equals("consumes")){
|
||||
modifiedField(bl, "consumeBuilder", Reflect.<Seq<Consume>>get(Block.class, bl, "consumeBuilder").copy());
|
||||
modifiedField(bl, "consumers", Reflect.<Consume[]>get(Block.class, bl, "consumers"));
|
||||
boolean hadItems = bl.hasItems, hadLiquids = bl.hasLiquids, hadPower = bl.hasPower, acceptedItems = bl.acceptsItems;
|
||||
reset(() -> {
|
||||
bl.reinitializeConsumers();
|
||||
bl.hasItems = hadItems;
|
||||
bl.hasLiquids = hadLiquids;
|
||||
bl.hasPower = hadPower;
|
||||
bl.acceptsItems = acceptedItems;
|
||||
});
|
||||
after(bl::reinitializeConsumers);
|
||||
|
||||
try{
|
||||
parser.readBlockConsumers(bl, jsv);
|
||||
bl.reinitializeConsumers();
|
||||
}catch(Throwable e){
|
||||
Log.err(e);
|
||||
warn("Failed to read consumers for '@': @", bl, Strings.getSimpleMessage(e));
|
||||
|
|
|
|||
|
|
@ -716,6 +716,8 @@ public class Block extends UnlockableContent implements Senseable{
|
|||
super.afterPatch();
|
||||
barMap.clear();
|
||||
setBars();
|
||||
offset = ((size + 1) % 2) * tilesize / 2f;
|
||||
sizeOffset = -((size - 1) / 2);
|
||||
}
|
||||
|
||||
public boolean consumesItem(Item item){
|
||||
|
|
|
|||
|
|
@ -9,6 +9,7 @@ import mindustry.type.*;
|
|||
import mindustry.world.blocks.defense.turrets.*;
|
||||
import mindustry.world.blocks.production.*;
|
||||
import mindustry.world.blocks.units.*;
|
||||
import mindustry.world.consumers.*;
|
||||
import mindustry.world.meta.*;
|
||||
import org.junit.jupiter.api.*;
|
||||
import org.junit.jupiter.params.*;
|
||||
|
|
@ -62,7 +63,7 @@ public class PatcherTests{
|
|||
assertArrayEquals(new ItemStack[]{new ItemStack(Items.surgeAlloy, 10)}, plan.requirements);
|
||||
assertEquals(100f, plan.time);
|
||||
|
||||
Vars.state.patcher.unapply();
|
||||
resetAfter();
|
||||
|
||||
plan = ((UnitFactory)Blocks.groundFactory).plans.find(u -> u.unit == UnitTypes.flare);
|
||||
|
||||
|
|
@ -70,7 +71,35 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testUnitWeapons() throws Exception{
|
||||
void reconstructorPlans() throws Exception{
|
||||
var reconstructor = ((Reconstructor)Blocks.additiveReconstructor);
|
||||
var prev = reconstructor.upgrades;
|
||||
var prevConsumes = reconstructor.<ConsumeItems>findConsumer(c -> c instanceof ConsumeItems).items;
|
||||
|
||||
Vars.state.patcher.apply(Seq.with(
|
||||
"""
|
||||
block.additive-reconstructor.upgrades: [[dagger, flare]]
|
||||
block.additive-reconstructor.consumes: {
|
||||
remove: items
|
||||
items: [surge-alloy/10, copper/20]
|
||||
}
|
||||
"""
|
||||
));
|
||||
|
||||
assertNoWarnings();
|
||||
var plan = reconstructor.upgrades.get(0);
|
||||
assertArrayEquals(new UnitType[]{UnitTypes.dagger, UnitTypes.flare}, plan);
|
||||
assertArrayEquals(reconstructor.<ConsumeItems>findConsumer(c -> c instanceof ConsumeItems).items, ItemStack.with(Items.surgeAlloy, 10, Items.copper, 20));
|
||||
|
||||
resetAfter();
|
||||
|
||||
assertEquals(prev, reconstructor.upgrades);
|
||||
assertArrayEquals(reconstructor.<ConsumeItems>findConsumer(c -> c instanceof ConsumeItems).items, prevConsumes);
|
||||
|
||||
}
|
||||
|
||||
@Test
|
||||
void unitWeapons() throws Exception{
|
||||
UnitTypes.dagger.checkStats();
|
||||
UnitTypes.dagger.stats.add(Stat.charge, 999);
|
||||
assertNotNull(UnitTypes.dagger.stats.toMap().get(StatCat.general).get(Stat.charge));
|
||||
|
|
@ -85,6 +114,7 @@ public class PatcherTests{
|
|||
}
|
||||
"""));
|
||||
|
||||
assertNoWarnings();
|
||||
assertEquals(3, UnitTypes.dagger.weapons.size);
|
||||
assertEquals("navanax-weapon", UnitTypes.dagger.weapons.get(2).name);
|
||||
assertEquals(LightningBulletType.class, UnitTypes.dagger.weapons.get(2).bullet.getClass());
|
||||
|
|
@ -97,7 +127,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testUnitWeaponReassign() throws Exception{
|
||||
void uUnitWeaponReassign() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
unit.dagger.weapons: [
|
||||
{
|
||||
|
|
@ -122,7 +152,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testUnitAbilities() throws Exception{
|
||||
void unitAbilities() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
unit.dagger.abilities.+: {
|
||||
type: ShieldArcAbility
|
||||
|
|
@ -140,7 +170,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testUnitAbilitiesArray() throws Exception{
|
||||
void unitAbilitiesArray() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
unit.dagger.abilities.+: [
|
||||
{
|
||||
|
|
@ -167,7 +197,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testUnitTypeObject() throws Exception{
|
||||
void unitTypeObject() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
{
|
||||
"name": "object syntax",
|
||||
|
|
@ -177,11 +207,11 @@ public class PatcherTests{
|
|||
}
|
||||
"""));
|
||||
|
||||
assertEquals(new Seq<>(), Vars.state.patcher.patches.first().warnings);
|
||||
assertNoWarnings();
|
||||
}
|
||||
|
||||
@Test
|
||||
void testUnitFlagsArray() throws Exception{
|
||||
void unitFlagsArray() throws Exception{
|
||||
int oldLength = UnitTypes.dagger.targetFlags.length;
|
||||
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
|
|
@ -200,7 +230,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testUnitFlags() throws Exception{
|
||||
void unitFlags() throws Exception{
|
||||
int oldLength = UnitTypes.dagger.targetFlags.length;
|
||||
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
|
|
@ -216,7 +246,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testUnitType() throws Exception{
|
||||
void unitType() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
unit.dagger.type: legs
|
||||
"""));
|
||||
|
|
@ -230,7 +260,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testCannotPatch() throws Exception{
|
||||
void cannotPatch() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
block.conveyor.size: 2
|
||||
"""));
|
||||
|
|
@ -240,7 +270,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testGibberish() throws Exception{
|
||||
void gibberish() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
}[35209509()jfkjhadsf,
|
||||
,,,,,[]
|
||||
|
|
@ -251,7 +281,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testNoIdAssign() throws Exception{
|
||||
void noIdAssign() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
block.router.id: 9231
|
||||
"""));
|
||||
|
|
@ -260,7 +290,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testUnknownFieldWarn() throws Exception{
|
||||
void unknownFieldWarn() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
unit.dagger.weapons.+: {
|
||||
bullet: {
|
||||
|
|
@ -274,7 +304,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testObjectFloatMap() throws Exception{
|
||||
void objectFloatMap() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
block.mechanical-drill.drillMultipliers: {
|
||||
titanium: 2.0
|
||||
|
|
@ -288,7 +318,7 @@ public class PatcherTests{
|
|||
block.mechanical-drill.drillMultipliers.surge-alloy: 10
|
||||
"""));
|
||||
|
||||
assertEquals(new Seq<>(), Vars.state.patcher.patches.first().warnings);
|
||||
assertNoWarnings();
|
||||
assertEquals(2f, ((Drill)Blocks.mechanicalDrill).drillMultipliers.get(Items.titanium, 0f));
|
||||
assertEquals(3f, ((Drill)Blocks.mechanicalDrill).drillMultipliers.get(Items.copper, 0f));
|
||||
assertEquals(10f, ((Drill)Blocks.mechanicalDrill).drillMultipliers.get(Items.surgeAlloy, 0f));
|
||||
|
|
@ -300,7 +330,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testSpecificArrayRequirements() throws Exception{
|
||||
void specificArrayRequirements() throws Exception{
|
||||
ItemStack[] reqs = Blocks.scatter.requirements.clone();
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
block.scatter.requirements: {
|
||||
|
|
@ -309,17 +339,18 @@ public class PatcherTests{
|
|||
block.duo.requirements: [titanium/5, surge-alloy/20]
|
||||
"""));
|
||||
|
||||
assertEquals(new Seq<>(), Vars.state.patcher.patches.first().warnings);
|
||||
assertNoWarnings();
|
||||
assertEquals(Blocks.scatter.requirements[0], new ItemStack(Items.surgeAlloy, 10));
|
||||
assertEquals(Blocks.scatter.requirements[1], reqs[1]);
|
||||
assertEquals(Blocks.duo.requirements[0], new ItemStack(Items.titanium, 5));
|
||||
|
||||
|
||||
Vars.logic.reset();
|
||||
assertArrayEquals(reqs, Blocks.scatter.requirements);
|
||||
}
|
||||
|
||||
@Test
|
||||
void testAttributes() throws Exception{
|
||||
void attributes() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
block.grass.attributes: {
|
||||
oil: 99
|
||||
|
|
@ -327,7 +358,7 @@ public class PatcherTests{
|
|||
block.grass.attributes.heat: 77
|
||||
"""));
|
||||
|
||||
assertEquals(new Seq<>(), Vars.state.patcher.patches.first().warnings);
|
||||
assertNoWarnings();
|
||||
assertEquals(99, Blocks.grass.attributes.get(Attribute.oil));
|
||||
assertEquals(77, Blocks.grass.attributes.get(Attribute.heat));
|
||||
|
||||
|
|
@ -338,7 +369,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testNoResolution() throws Exception{
|
||||
void noResolution() throws Exception{
|
||||
String name = Pathfinder.class.getCanonicalName();
|
||||
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
|
|
@ -351,12 +382,12 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testSetMultiAdd() throws Exception{
|
||||
void setMultiAdd() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
unit.dagger.immunities.+: [slow, fast]
|
||||
"""));
|
||||
|
||||
assertEquals(new Seq<>(), Vars.state.patcher.patches.first().warnings);
|
||||
assertNoWarnings();
|
||||
assertTrue(UnitTypes.dagger.immunities.contains(StatusEffects.slow));
|
||||
assertTrue(UnitTypes.dagger.immunities.contains(StatusEffects.fast));
|
||||
|
||||
|
|
@ -367,7 +398,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testAmmoReassign() throws Exception{
|
||||
void ammoReassign() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
block.fuse.ammoTypes: {
|
||||
titanium: "-"
|
||||
|
|
@ -381,7 +412,7 @@ public class PatcherTests{
|
|||
}
|
||||
"""));
|
||||
|
||||
assertEquals(new Seq<>(), Vars.state.patcher.patches.first().warnings);
|
||||
assertNoWarnings();
|
||||
assertTrue(((ItemTurret)Blocks.fuse).ammoTypes.containsKey(Items.surgeAlloy));
|
||||
assertFalse(((ItemTurret)Blocks.fuse).ammoTypes.containsKey(Items.titanium));
|
||||
assertEquals(100, ((ItemTurret)Blocks.fuse).ammoTypes.get(Items.surgeAlloy).damage);
|
||||
|
|
@ -393,13 +424,13 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testIndexAccess() throws Exception{
|
||||
void indexAccess() throws Exception{
|
||||
float oldDamage = UnitTypes.dagger.weapons.first().bullet.damage;
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
unit.dagger.weapons.0.bullet.damage: 100
|
||||
"""));
|
||||
|
||||
assertEquals(new Seq<>(), Vars.state.patcher.patches.first().warnings);
|
||||
assertNoWarnings();
|
||||
assertEquals(100, UnitTypes.dagger.weapons.first().bullet.damage);
|
||||
|
||||
Vars.logic.reset();
|
||||
|
|
@ -408,7 +439,7 @@ public class PatcherTests{
|
|||
}
|
||||
|
||||
@Test
|
||||
void testAddWeapon() throws Exception{
|
||||
void addWeapon() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
unit.flare.weapons.+: {
|
||||
x: 0
|
||||
|
|
@ -421,13 +452,13 @@ public class PatcherTests{
|
|||
}
|
||||
"""));
|
||||
|
||||
assertEquals(new Seq<>(), Vars.state.patcher.patches.first().warnings);
|
||||
assertNoWarnings();
|
||||
assertEquals(3, UnitTypes.flare.weapons.size);
|
||||
assertEquals(100, UnitTypes.flare.weapons.peek().bullet.damage);
|
||||
}
|
||||
|
||||
@Test
|
||||
void testBigPatch() throws Exception{
|
||||
void bigPatch() throws Exception{
|
||||
Vars.state.patcher.apply(Seq.with("""
|
||||
item: {
|
||||
fissile-matter: {
|
||||
|
|
@ -485,6 +516,10 @@ public class PatcherTests{
|
|||
}
|
||||
"""));
|
||||
|
||||
assertNoWarnings();
|
||||
}
|
||||
|
||||
static void assertNoWarnings(){
|
||||
assertEquals(new Seq<>(), Vars.state.patcher.patches.first().warnings);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue