fix overall correctness
This commit is contained in:
parent
e0ea0d6119
commit
cac4d698c3
@ -36,7 +36,8 @@ enum BufferState{
|
|||||||
pub struct MouseInterpolator{
|
pub struct MouseInterpolator{
|
||||||
buffer_state:BufferState,
|
buffer_state:BufferState,
|
||||||
// double timestamped timeline?
|
// double timestamped timeline?
|
||||||
physics_timeline:std::collections::VecDeque<TimedPhysicsInstruction>,
|
buffer:std::collections::VecDeque<TimedPhysicsInstruction>,
|
||||||
|
output:std::collections::VecDeque<TimedPhysicsInstruction>,
|
||||||
}
|
}
|
||||||
// Maybe MouseInterpolator manipulation is better expressed using impls
|
// Maybe MouseInterpolator manipulation is better expressed using impls
|
||||||
// and called from Instruction trait impls in session
|
// and called from Instruction trait impls in session
|
||||||
@ -56,7 +57,22 @@ impl MouseInterpolator{
|
|||||||
pub fn new()->MouseInterpolator{
|
pub fn new()->MouseInterpolator{
|
||||||
MouseInterpolator{
|
MouseInterpolator{
|
||||||
buffer_state:BufferState::Unbuffered,
|
buffer_state:BufferState::Unbuffered,
|
||||||
physics_timeline:std::collections::VecDeque::new(),
|
buffer:std::collections::VecDeque::new(),
|
||||||
|
output:std::collections::VecDeque::new(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fn push_mouse(&mut self,ins:TimedInstruction<MouseInstruction,PhysicsTimeInner>){
|
||||||
|
self.buffer.push_front(TimedInstruction{
|
||||||
|
time:ins.time,
|
||||||
|
instruction:PhysicsInputInstruction::Mouse(ins.instruction),
|
||||||
|
});
|
||||||
|
// flush buffer to output
|
||||||
|
if self.output.len()==0{
|
||||||
|
// swap buffers
|
||||||
|
core::mem::swap(&mut self.buffer,&mut self.output);
|
||||||
|
}else{
|
||||||
|
// append buffer contents to output
|
||||||
|
self.output.append(&mut self.buffer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
pub fn push_unbuffered_input(&mut self,ins:DoubleTimedUnbufferedInstruction){
|
pub fn push_unbuffered_input(&mut self,ins:DoubleTimedUnbufferedInstruction){
|
||||||
@ -140,27 +156,26 @@ impl MouseInterpolator{
|
|||||||
((None,ins_other),next_state)
|
((None,ins_other),next_state)
|
||||||
});
|
});
|
||||||
if let Some(ins)=ins_mouse{
|
if let Some(ins)=ins_mouse{
|
||||||
self.physics_timeline.push_front(TimedInstruction{
|
self.push_mouse(ins);
|
||||||
time:ins.time,
|
|
||||||
instruction:PhysicsInputInstruction::Mouse(ins.instruction),
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
if let Some(ins)=ins_other{
|
if let Some(ins)=ins_other{
|
||||||
self.physics_timeline.push_back(TimedInstruction{
|
let instruction=TimedInstruction{
|
||||||
time:ins.time,
|
time:ins.time,
|
||||||
instruction:PhysicsInputInstruction::Other(ins.instruction),
|
instruction:PhysicsInputInstruction::Other(ins.instruction),
|
||||||
});
|
};
|
||||||
|
if matches!(self.buffer_state,BufferState::Unbuffered){
|
||||||
|
self.output.push_back(instruction);
|
||||||
|
}else{
|
||||||
|
self.buffer.push_back(instruction);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fn is_first_ready(&self)->bool{
|
fn has_output(&self)->bool{
|
||||||
matches!(self.physics_timeline.back(),Some(TimedInstruction{
|
self.output.len()!=0
|
||||||
instruction:PhysicsInputInstruction::Mouse(_),
|
|
||||||
..
|
|
||||||
}))
|
|
||||||
}
|
}
|
||||||
pub fn buffered_instruction_with_timeout(&self,time_limit:SessionTime)->Option<TimedInstruction<StepInstruction,SessionTimeInner>>{
|
pub fn buffered_instruction_with_timeout(&self,time_limit:SessionTime)->Option<TimedInstruction<StepInstruction,SessionTimeInner>>{
|
||||||
match &self.buffer_state{
|
match &self.buffer_state{
|
||||||
BufferState::Unbuffered=>self.physics_timeline.front().map(|_|TimedInstruction{
|
BufferState::Unbuffered=>self.has_output().then_some(TimedInstruction{
|
||||||
time:time_limit,
|
time:time_limit,
|
||||||
instruction:StepInstruction::Pop,
|
instruction:StepInstruction::Pop,
|
||||||
}),
|
}),
|
||||||
@ -173,7 +188,7 @@ impl MouseInterpolator{
|
|||||||
time:timeout,
|
time:timeout,
|
||||||
instruction:StepInstruction::Timeout,
|
instruction:StepInstruction::Timeout,
|
||||||
})
|
})
|
||||||
}else if self.is_first_ready(){
|
}else if self.has_output(){
|
||||||
// emit Step
|
// emit Step
|
||||||
Some(TimedInstruction{
|
Some(TimedInstruction{
|
||||||
// this timestamp should not matter
|
// this timestamp should not matter
|
||||||
@ -191,31 +206,30 @@ impl MouseInterpolator{
|
|||||||
pub fn pop_buffered_instruction(&mut self,ins:StepInstruction)->Option<TimedInstruction<PhysicsInputInstruction,PhysicsTimeInner>>{
|
pub fn pop_buffered_instruction(&mut self,ins:StepInstruction)->Option<TimedInstruction<PhysicsInputInstruction,PhysicsTimeInner>>{
|
||||||
match ins{
|
match ins{
|
||||||
// could check if self.is_first_ready()
|
// could check if self.is_first_ready()
|
||||||
StepInstruction::Pop=>self.physics_timeline.pop_front(),
|
StepInstruction::Pop=>(),
|
||||||
StepInstruction::Timeout=>{
|
StepInstruction::Timeout=>{
|
||||||
let buffer_state=core::mem::replace(&mut self.buffer_state,BufferState::Unbuffered);
|
let buffer_state=core::mem::replace(&mut self.buffer_state,BufferState::Unbuffered);
|
||||||
match buffer_state{
|
match buffer_state{
|
||||||
BufferState::Unbuffered=>None,
|
BufferState::Unbuffered=>(),
|
||||||
BufferState::Initializing(_time,mouse_state)
|
BufferState::Initializing(_time,mouse_state)
|
||||||
|BufferState::Buffered(_time,mouse_state)=>{
|
|BufferState::Buffered(_time,mouse_state)=>{
|
||||||
// convert to BufferState::Unbuffered
|
// convert to BufferState::Unbuffered
|
||||||
// use the first instruction which should be a mouse instruction
|
// use the first instruction which should be a mouse instruction
|
||||||
// to push a ReplaceMouse instruction
|
// to push a ReplaceMouse instruction
|
||||||
// duplicate the current mouse
|
// duplicate the current mouse
|
||||||
Some(TimedInstruction{
|
self.push_mouse(TimedInstruction{
|
||||||
// This should be simulation_timer.time(timeout)
|
// This should be simulation_timer.time(timeout)
|
||||||
// but the timer is not accessible from this scope
|
// but the timer is not accessible from this scope
|
||||||
// and it's just here to say that the mouse isn't moving anyways.
|
// and it's just here to say that the mouse isn't moving anyways.
|
||||||
// I think this is a divide by zero bug, two identical mouse_states will occupy the interpolation state
|
// I think this is a divide by zero bug, two identical mouse_states will occupy the interpolation state
|
||||||
time:mouse_state.time,
|
time:mouse_state.time,
|
||||||
instruction:PhysicsInputInstruction::Mouse(
|
instruction:MouseInstruction::SetNextMouse(mouse_state),
|
||||||
MouseInstruction::SetNextMouse(mouse_state)
|
});
|
||||||
),
|
|
||||||
})
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
self.output.pop_front()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user