use crate::integer::Time; #[derive(Debug)] pub struct TimedInstruction{ pub time:Time, pub instruction:I, } /// Ensure all emitted instructions are processed before consuming external instructions pub trait InstructionEmitter{ type TimeInner; fn next_instruction(&self,time_limit:Time)->Option>; } /// Apply an atomic state update pub trait InstructionConsumer{ type TimeInner; fn process_instruction(&mut self,instruction:TimedInstruction); } /// If the object produces its own instructions, allow exhaustively feeding them back in pub trait InstructionFeedback:InstructionEmitter+InstructionConsumer where Time:Copy, { fn process_exhaustive(&mut self,time_limit:Time){ while let Some(instruction)=self.next_instruction(time_limit){ self.process_instruction(instruction); } } } impl InstructionFeedback for X where Time:Copy, X:InstructionEmitter+InstructionConsumer, {} //PROPER PRIVATE FIELDS!!! pub struct InstructionCollector{ time:Time, instruction:Option, } impl InstructionCollector where Time:Copy+PartialOrd, { pub const fn new(time:Time)->Self{ Self{ time, instruction:None } } #[inline] pub const fn time(&self)->Time{ self.time } pub fn collect(&mut self,instruction:Option>){ match instruction{ Some(unwrap_instruction)=>{ if unwrap_instruction.time(), } } pub fn instruction(self)->Option>{ //STEAL INSTRUCTION AND DESTROY INSTRUCTIONCOLLECTOR match self.instruction{ Some(instruction)=>Some(TimedInstruction{ time:self.time, instruction }), None=>None, } } }