summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/channel/history.rs6
-rw-r--r--src/message/history.rs6
2 files changed, 10 insertions, 2 deletions
diff --git a/src/channel/history.rs b/src/channel/history.rs
index 4b9fcc7..dda7bb9 100644
--- a/src/channel/history.rs
+++ b/src/channel/history.rs
@@ -1,3 +1,5 @@
+use itertools::Itertools as _;
+
use super::{
event::{Created, Deleted, Event},
Channel, Id,
@@ -41,7 +43,9 @@ impl History {
// Event factories
impl History {
pub fn events(&self) -> impl Iterator<Item = Event> {
- [self.created()].into_iter().chain(self.deleted())
+ [self.created()]
+ .into_iter()
+ .merge_by(self.deleted(), Sequence::merge)
}
fn created(&self) -> Event {
diff --git a/src/message/history.rs b/src/message/history.rs
index 0424d0d..67e437a 100644
--- a/src/message/history.rs
+++ b/src/message/history.rs
@@ -1,3 +1,5 @@
+use itertools::Itertools as _;
+
use super::{
event::{Deleted, Event, Sent},
Id, Message,
@@ -57,6 +59,8 @@ impl History {
}
pub fn events(&self) -> impl Iterator<Item = Event> {
- [self.sent()].into_iter().chain(self.deleted())
+ [self.sent()]
+ .into_iter()
+ .merge_by(self.deleted(), Sequence::merge)
}
}