mindustry logic execution, map- and schematic- parsing and rendering
Diffstat (limited to 'src/block/defense.rs')
| -rw-r--r-- | src/block/defense.rs | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/src/block/defense.rs b/src/block/defense.rs index 0dae9aa..b1548bc 100644 --- a/src/block/defense.rs +++ b/src/block/defense.rs @@ -2,6 +2,8 @@ use crate::block::simple::{cost, make_simple, BasicBlock}; use crate::block::*; make_simple!(HeatedBlock => |_, _, _, buff: &mut DataRead| read_heated(buff)); +make_simple!(RadarBlock => |_, _, _, buff: &mut DataRead| buff.skip(4)); +make_simple!(ShieldBlock => |_, _, _, buff: &mut DataRead| read_shield(buff)); make_register! { "mender" -> HeatedBlock::new(1, true, cost!(Copper: 25, Lead: 30)); "mend-projector" -> HeatedBlock::new(2, true, cost!(Copper: 50, Lead: 100, Titanium: 25, Silicon: 40)); @@ -10,14 +12,14 @@ make_register! { "force-projector" -> BasicBlock::new(3, true, cost!(Lead: 100, Titanium: 75, Silicon: 125)); "regen-projector" -> BasicBlock::new(3, true, cost!(Silicon: 80, Tungsten: 60, Oxide: 40, Beryllium: 80)); "shock-mine" -> BasicBlock::new(1, true, cost!(Lead: 25, Silicon: 12)); - "radar" -> BasicBlock::new(1, true, cost!(Silicon: 60, Graphite: 50, Beryllium: 10)); + "radar" -> RadarBlock::new(1, true, cost!(Silicon: 60, Graphite: 50, Beryllium: 10)); "build-tower" -> BasicBlock::new(3, true, cost!(Silicon: 150, Oxide: 40, Thorium: 60)); "shockwave-tower" -> BasicBlock::new(3, true, cost!(SurgeAlloy: 50, Silicon: 150, Oxide: 30, Tungsten: 100)); // barrier projector // editor only "barrier-projector" -> BasicBlock::new(3, true, &[]); - "shield-projector" -> BasicBlock::new(3, true, &[]); - "large-shield-projector" -> BasicBlock::new(4, true, &[]); + "shield-projector" -> ShieldBlock::new(3, true, &[]); + "large-shield-projector" -> ShieldBlock::new(4, true, &[]); } /// format: @@ -26,3 +28,10 @@ make_register! { fn read_heated(buff: &mut DataRead) -> Result<(), DataReadError> { buff.skip(8) } + +/// format: +/// - smoothing: [`f32`] +/// - broken: [`bool`] +fn read_shield(buff: &mut DataRead) -> Result<(), DataReadError> { + buff.skip(5) +} |