mirror of
https://github.com/demostf/cutter.git
synced 2026-06-03 20:04:07 +02:00
remove baselines
This commit is contained in:
parent
eb16d2b06b
commit
46efe08321
1 changed files with 29 additions and 25 deletions
|
|
@ -16,13 +16,13 @@ impl ActiveEntities {
|
|||
pub fn handle_message(&mut self, msg: &PacketEntitiesMessage, state: &ParserState) {
|
||||
for entity in &msg.entities {
|
||||
if entity.pvs == PVS::Delete || entity.pvs == PVS::Leave {
|
||||
self.entities.remove(&entity.entity_index);
|
||||
self.remove_entity(entity.entity_index);
|
||||
} else {
|
||||
self.handle_entity(entity, state);
|
||||
}
|
||||
}
|
||||
for deleted in msg.removed_entities.iter() {
|
||||
self.entities.remove(deleted);
|
||||
self.remove_entity(*deleted);
|
||||
}
|
||||
if msg.updated_base_line {
|
||||
let old_index = msg.base_line as usize;
|
||||
|
|
@ -37,10 +37,36 @@ impl ActiveEntities {
|
|||
}
|
||||
}
|
||||
|
||||
fn remove_entity(&mut self, entity_index: EntityId) {
|
||||
self.entities.remove(&entity_index);
|
||||
self.baselines[0].remove(&entity_index);
|
||||
self.baselines[1].remove(&entity_index);
|
||||
}
|
||||
|
||||
fn handle_entity(&mut self, entity: &PacketEntity, state: &ParserState) {
|
||||
self.entities
|
||||
.entry(entity.entity_index)
|
||||
.and_modify(|existing| update_entity(existing, entity, state))
|
||||
.and_modify(|existing| {
|
||||
if existing.serial_number != entity.serial_number {
|
||||
*existing = entity.clone();
|
||||
existing.pvs = PVS::Enter;
|
||||
} else {
|
||||
assert_eq!(
|
||||
state.server_classes[usize::from(existing.server_class)],
|
||||
state.server_classes[usize::from(entity.server_class)]
|
||||
);
|
||||
for prop in &entity.props {
|
||||
match existing
|
||||
.props
|
||||
.iter_mut()
|
||||
.find(|existing| existing.index == prop.index)
|
||||
{
|
||||
Some(existing) => existing.value = prop.value.clone(),
|
||||
None => existing.props.push(prop.clone()),
|
||||
}
|
||||
}
|
||||
}
|
||||
})
|
||||
.or_insert_with(|| entity.clone());
|
||||
}
|
||||
|
||||
|
|
@ -72,25 +98,3 @@ fn encode_entities(mut entities: Vec<PacketEntity>) -> PacketEntitiesMessage {
|
|||
updated_base_line: false,
|
||||
}
|
||||
}
|
||||
|
||||
fn update_entity(old: &mut PacketEntity, new: &PacketEntity, _state: &ParserState) {
|
||||
if old.serial_number != new.serial_number {
|
||||
*old = new.clone();
|
||||
old.pvs = PVS::Enter;
|
||||
} else {
|
||||
assert_eq!(
|
||||
_state.server_classes[usize::from(old.server_class)],
|
||||
_state.server_classes[usize::from(new.server_class)]
|
||||
);
|
||||
for prop in &new.props {
|
||||
match old
|
||||
.props
|
||||
.iter_mut()
|
||||
.find(|existing| existing.index == prop.index)
|
||||
{
|
||||
Some(existing) => existing.value = prop.value.clone(),
|
||||
None => old.props.push(prop.clone()),
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue