From fa07bd9ddd80f94f9aacd0dd09c30d8a887c34c6 Mon Sep 17 00:00:00 2001 From: Ivan Enderlin Date: Mon, 25 Nov 2024 16:37:47 +0100 Subject: [PATCH] refactor: `EventCacheStore::handle_linked_chunk_updates` takes a `Vec`. This patch updates `EventCacheStore::handle_linked_chunk_updates` to take a `Vec>` instead of `&[Update]`. In fact, `linked_chunk::ObservableUpdates::take()` already returns a `Vec>`; we can simply forward this `Vec` up to here without any further clones. --- .../src/event_cache/store/memory_store.rs | 4 +- .../src/event_cache/store/traits.rs | 4 +- .../src/linked_chunk/relational.rs | 58 +++++++++---------- .../src/event_cache_store.rs | 2 +- 4 files changed, 31 insertions(+), 37 deletions(-) diff --git a/crates/matrix-sdk-base/src/event_cache/store/memory_store.rs b/crates/matrix-sdk-base/src/event_cache/store/memory_store.rs index ba9c3d24b80..213659c0f0d 100644 --- a/crates/matrix-sdk-base/src/event_cache/store/memory_store.rs +++ b/crates/matrix-sdk-base/src/event_cache/store/memory_store.rs @@ -85,11 +85,11 @@ impl EventCacheStore for MemoryStore { async fn handle_linked_chunk_updates( &self, room_id: &RoomId, - updates: &[Update], + updates: Vec>, ) -> Result<(), Self::Error> { let mut inner = self.inner.write().unwrap(); - Ok(inner.events.apply_updates(updates)) + Ok(inner.events.apply_updates(room_id, updates)) } async fn add_media_content( diff --git a/crates/matrix-sdk-base/src/event_cache/store/traits.rs b/crates/matrix-sdk-base/src/event_cache/store/traits.rs index 2584b8881ed..3c35862b3c5 100644 --- a/crates/matrix-sdk-base/src/event_cache/store/traits.rs +++ b/crates/matrix-sdk-base/src/event_cache/store/traits.rs @@ -46,7 +46,7 @@ pub trait EventCacheStore: AsyncTraitDeps { async fn handle_linked_chunk_updates( &self, room_id: &RoomId, - updates: &[Update], + updates: Vec>, ) -> Result<(), Self::Error>; /// Add a media file's content in the media store. @@ -146,7 +146,7 @@ impl EventCacheStore for EraseEventCacheStoreError { async fn handle_linked_chunk_updates( &self, room_id: &RoomId, - updates: &[Update], + updates: Vec>, ) -> Result<(), Self::Error> { self.0.handle_linked_chunk_updates(room_id, updates).await.map_err(Into::into) } diff --git a/crates/matrix-sdk-common/src/linked_chunk/relational.rs b/crates/matrix-sdk-common/src/linked_chunk/relational.rs index f7c2f9c7e24..56979ced5be 100644 --- a/crates/matrix-sdk-common/src/linked_chunk/relational.rs +++ b/crates/matrix-sdk-common/src/linked_chunk/relational.rs @@ -81,11 +81,7 @@ impl RelationalLinkedChunk { /// Apply [`Update`]s. That's the only way to write data inside this /// relational linked chunk. - pub fn apply_updates(&mut self, room_id: &RoomId, updates: &[Update]) - where - Item: Clone, - Gap: Clone, - { + pub fn apply_updates(&mut self, room_id: &RoomId, updates: Vec>) { for update in updates { match update { Update::NewItemsChunk { previous, new, next } => { @@ -96,8 +92,8 @@ impl RelationalLinkedChunk { insert_chunk(&mut self.chunks, room_id, previous, new, next); self.items.push(ItemRow { room_id: room_id.to_owned(), - position: Position::new(*new, 0), - item: Either::Gap(gap.clone()), + position: Position::new(new, 0), + item: Either::Gap(gap), }); } @@ -111,7 +107,7 @@ impl RelationalLinkedChunk { .filter_map( |(nth, ItemRow { room_id: room_id_candidate, position, .. })| { (room_id == room_id_candidate - && position.chunk_identifier() == *chunk_identifier) + && position.chunk_identifier() == chunk_identifier) .then_some(nth) }, ) @@ -122,14 +118,12 @@ impl RelationalLinkedChunk { } } - Update::PushItems { at, items } => { - let mut at = *at; - + Update::PushItems { mut at, items } => { for item in items { self.items.push(ItemRow { room_id: room_id.to_owned(), position: at, - item: Either::Item(item.clone()), + item: Either::Item(item), }); at.increment_index(); } @@ -147,7 +141,7 @@ impl RelationalLinkedChunk { } // Find the item to remove. - if position == at { + if *position == at { debug_assert!(entry_to_remove.is_none(), "Found the same entry twice"); entry_to_remove = Some(nth); @@ -191,21 +185,21 @@ impl RelationalLinkedChunk { fn insert_chunk( chunks: &mut Vec, room_id: &RoomId, - previous: &Option, - new: &ChunkIdentifier, - next: &Option, + previous: Option, + new: ChunkIdentifier, + next: Option, ) { // Find the previous chunk, and update its next chunk. if let Some(previous) = previous { let entry_for_previous_chunk = chunks .iter_mut() .find(|ChunkRow { room_id: room_id_candidate, chunk, .. }| { - room_id == room_id_candidate && chunk == previous + room_id == room_id_candidate && *chunk == previous }) .expect("Previous chunk should be present"); // Insert the chunk. - entry_for_previous_chunk.next_chunk = Some(*new); + entry_for_previous_chunk.next_chunk = Some(new); } // Find the next chunk, and update its previous chunk. @@ -213,33 +207,33 @@ impl RelationalLinkedChunk { let entry_for_next_chunk = chunks .iter_mut() .find(|ChunkRow { room_id: room_id_candidate, chunk, .. }| { - room_id == room_id_candidate && chunk == next + room_id == room_id_candidate && *chunk == next }) .expect("Next chunk should be present"); // Insert the chunk. - entry_for_next_chunk.previous_chunk = Some(*new); + entry_for_next_chunk.previous_chunk = Some(new); } // Insert the chunk. chunks.push(ChunkRow { room_id: room_id.to_owned(), - previous_chunk: *previous, - chunk: *new, - next_chunk: *next, + previous_chunk: previous, + chunk: new, + next_chunk: next, }); } fn remove_chunk( chunks: &mut Vec, room_id: &RoomId, - chunk_to_remove: &ChunkIdentifier, + chunk_to_remove: ChunkIdentifier, ) { let entry_nth_to_remove = chunks .iter() .enumerate() .find_map(|(nth, ChunkRow { room_id: room_id_candidate, chunk, .. })| { - (room_id == room_id_candidate && chunk == chunk_to_remove).then_some(nth) + (room_id == room_id_candidate && *chunk == chunk_to_remove).then_some(nth) }) .expect("Remove an unknown chunk"); @@ -294,7 +288,7 @@ mod tests { relational_linked_chunk.apply_updates( room_id, - &[ + vec![ // 0 Update::NewItemsChunk { previous: None, new: CId::new(0), next: None }, // 1 after 0 @@ -351,7 +345,7 @@ mod tests { relational_linked_chunk.apply_updates( room_id, - &[ + vec![ // 0 Update::NewItemsChunk { previous: None, new: CId::new(0), next: None }, // 1 after 0 @@ -408,7 +402,7 @@ mod tests { relational_linked_chunk.apply_updates( room_id, - &[ + vec![ // 0 Update::NewItemsChunk { previous: None, new: CId::new(0), next: None }, // 1 after 0 @@ -454,7 +448,7 @@ mod tests { relational_linked_chunk.apply_updates( room_id, - &[ + vec![ // new chunk (this is not mandatory for this test, but let's try to be realistic) Update::NewItemsChunk { previous: None, new: CId::new(0), next: None }, // new items on 0 @@ -541,7 +535,7 @@ mod tests { relational_linked_chunk.apply_updates( room_id, - &[ + vec![ // new chunk (this is not mandatory for this test, but let's try to be realistic) Update::NewItemsChunk { previous: None, new: CId::new(0), next: None }, // new items on 0 @@ -596,7 +590,7 @@ mod tests { relational_linked_chunk.apply_updates( room_id, - &[ + vec![ // new chunk Update::NewItemsChunk { previous: None, new: CId::new(0), next: None }, // new chunk @@ -670,7 +664,7 @@ mod tests { let mut relational_linked_chunk = RelationalLinkedChunk::::new(); relational_linked_chunk - .apply_updates(room_id, &[Update::StartReattachItems, Update::EndReattachItems]); + .apply_updates(room_id, vec![Update::StartReattachItems, Update::EndReattachItems]); // Nothing happened. assert!(relational_linked_chunk.chunks.is_empty()); diff --git a/crates/matrix-sdk-sqlite/src/event_cache_store.rs b/crates/matrix-sdk-sqlite/src/event_cache_store.rs index f6b62e76216..5ee8d92324e 100644 --- a/crates/matrix-sdk-sqlite/src/event_cache_store.rs +++ b/crates/matrix-sdk-sqlite/src/event_cache_store.rs @@ -186,7 +186,7 @@ impl EventCacheStore for SqliteEventCacheStore { async fn handle_linked_chunk_updates( &self, _room_id: &RoomId, - _updates: &[Update], + _updates: Vec>, ) -> Result<(), Self::Error> { todo!() }