From beabbc1582bea4c0cb8edecdf513ef55270a2010 Mon Sep 17 00:00:00 2001 From: wilson Date: Tue, 25 Jun 2024 16:37:15 +0800 Subject: [PATCH] fix lyrics not cleared after switching song --- src/lyrics.rs | 8 ++++---- src/main.rs | 19 ++++++++++--------- 2 files changed, 14 insertions(+), 13 deletions(-) diff --git a/src/lyrics.rs b/src/lyrics.rs index 131132c..6ab2538 100644 --- a/src/lyrics.rs +++ b/src/lyrics.rs @@ -35,8 +35,8 @@ pub trait LyricsTrait { type Error; fn new(layout: LyricsLayout) -> std::result::Result where Self: Sized; - fn begin(&mut self, _lyrics: impl IntoIterator) -> Result<(), Self::Error> { Ok(()) } - fn end(&mut self) -> Result<(), Self::Error> { Ok(()) } + fn set_lyrics(&mut self, _lyrics: impl IntoIterator) -> Result<(), Self::Error> { Ok(()) } + fn clear(&mut self) -> Result<(), Self::Error> { Ok(()) } fn update(&mut self, _time: Duration) -> Result<(), Self::Error> { Ok(()) } fn set_layout(&mut self, _layout: LyricsLayout) -> Result<(), Self::Error> { Ok(()) } } @@ -198,7 +198,7 @@ mod xosd { } #[inline(always)] - fn begin(&mut self, lyrics: impl IntoIterator) -> Result<()> { + fn set_lyrics(&mut self, lyrics: impl IntoIterator) -> Result<()> { self.lines = lyrics.into_iter().collect(); self.lines.sort_by_key(|&(t, _)| t); self.index = Some(0); @@ -208,7 +208,7 @@ mod xosd { } #[inline(always)] - fn end(&mut self) -> Result<()> { + fn clear(&mut self) -> Result<()> { self.index = None; self.update_text()?; diff --git a/src/main.rs b/src/main.rs index 4a57058..18aa0c3 100644 --- a/src/main.rs +++ b/src/main.rs @@ -252,7 +252,7 @@ impl App { println!("STATUS: Idle"); - app.end_lyrics(); + app.clear_lyrics(); } } _ => {} @@ -307,7 +307,7 @@ impl App { self.request_duration = true; self.show_lyrics(song); } - "STOP" => { self.player.stop(); self.end_lyrics() } + "STOP" => { self.player.stop(); self.clear_lyrics() } "REPLAY" => if let Some(song) = self.playlist.get_history().get_current().cloned() { self.play(&song) } "PREV" => if let Some(song) = self.playlist.look_back() { self.play(&song); } "SKIP" => self.player.skip(), @@ -382,7 +382,7 @@ impl App { if comb == self.stop_player { ["STOP"].gui_write_if(self); self.player.stop(); - self.end_lyrics(); + self.clear_lyrics(); } if comb == self.volume_increase { @@ -596,10 +596,13 @@ impl App { match Tag::read_from_path(path) { Ok(tag) => { if let Some(l) = tag.synchronised_lyrics().find(|l| l.lang == "eng") { - if let Err(e) = lyrics.begin(l.content.iter().map(|(t, s)| (Duration::from_millis((*t).into()), s.clone()))) { + if let Err(e) = lyrics.set_lyrics(l.content.iter().map(|(t, s)| (Duration::from_millis((*t).into()), s.clone()))) { println!("RUST-ERROR: Failed to display lyrics {}", e) } } + else { + self.clear_lyrics(); + } } Err(e) => println!("RUST-ERROR: Failed to read tag from {} ({})", path, e) } @@ -607,12 +610,10 @@ impl App { } #[inline(always)] - fn end_lyrics(&mut self) { - println!("ended"); - + fn clear_lyrics(&mut self) { if let Some(lyrics) = &mut self.lyrics { - if let Err(e) = lyrics.end() { - println!("RUST-ERROR: Failed to reset lyrics {}", e) + if let Err(e) = lyrics.clear() { + println!("RUST-ERROR: Failed to clear lyrics {}", e) } } }