1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
use crate::lua_generator::{LuaGenerator, ToLua}; use crate::nodes::{ Block, Expression, }; #[derive(Clone, Debug, PartialEq, Eq)] pub struct NumericForStatement { identifier: String, start: Expression, end: Expression, step: Option<Expression>, block: Block, } impl NumericForStatement { pub fn new( identifier: String, start: Expression, end: Expression, step: Option<Expression>, block: Block ) -> Self { Self { identifier, start, end, step, block, } } pub fn get_block(&self) -> &Block { &self.block } pub fn mutate_block(&mut self) -> &mut Block { &mut self.block } pub fn mutate_start(&mut self) -> &mut Expression { &mut self.start } pub fn mutate_end(&mut self) -> &mut Expression { &mut self.end } pub fn mutate_step(&mut self) -> &mut Option<Expression> { &mut self.step } pub fn get_identifier(&self) -> &String { &self.identifier } pub fn set_identifier<S: Into<String>>(&mut self, identifier: S) { self.identifier = identifier.into(); } } impl ToLua for NumericForStatement { fn to_lua(&self, generator: &mut LuaGenerator) { generator.push_str("for"); generator.push_str(&self.identifier); generator.push_char('='); self.start.to_lua(generator); generator.push_char(','); self.end.to_lua(generator); if let Some(step) = &self.step { generator.push_char(','); step.to_lua(generator); } generator.push_str("do"); self.block.to_lua(generator); generator.push_str("end"); } } #[cfg(test)] mod test { use super::*; use crate::nodes::Expression; #[test] fn generate_empty_numeric_for() { let output = NumericForStatement::new( "i".to_owned(), Expression::Identifier("start".to_owned()), Expression::Identifier("max".to_owned()), None, Block::default() ).to_lua_string(); assert_eq!(output, "for i=start,max do end"); } #[test] fn generate_empty_numeric_for_with_step() { let output = NumericForStatement::new( "i".to_owned(), Expression::Identifier("start".to_owned()), Expression::Identifier("max".to_owned()), Some(Expression::Identifier("step".to_owned())), Block::default() ).to_lua_string(); assert_eq!(output, "for i=start,max,step do end"); } }