From 7934d7eccf0ea7b2597c23239a8f02519087b9c8 Mon Sep 17 00:00:00 2001 From: Wojciech Kozlowski Date: Sat, 18 Jan 2025 09:45:28 +0100 Subject: [PATCH] Correct artist id-info split --- src/core/collection/artist.rs | 62 +-------------------- src/core/musichoard/base.rs | 4 +- src/core/musichoard/library.rs | 8 +-- src/external/database/serde/deserialize.rs | 2 +- src/external/database/serde/serialize.rs | 2 +- src/external/database/sql/mod.rs | 2 +- src/testmod/full.rs | 8 +-- src/testmod/library.rs | 8 +-- src/tui/app/machine/search_state.rs | 2 +- src/tui/lib/external/musicbrainz/api/mod.rs | 2 +- tests/lib.rs | 4 +- tests/testlib.rs | 10 ++-- 12 files changed, 29 insertions(+), 85 deletions(-) diff --git a/src/core/collection/artist.rs b/src/core/collection/artist.rs index d67ca94..a605c10 100644 --- a/src/core/collection/artist.rs +++ b/src/core/collection/artist.rs @@ -22,13 +22,13 @@ pub struct Artist { #[derive(Clone, Debug, PartialEq, Eq)] pub struct ArtistMeta { pub id: ArtistId, - pub sort: Option, pub info: ArtistInfo, } /// Artist non-identifier metadata. #[derive(Clone, Debug, Default, PartialEq, Eq)] pub struct ArtistInfo { + pub sort: Option, pub properties: HashMap>, } @@ -152,7 +152,6 @@ impl ArtistMeta { pub fn new>(id: Id) -> Self { ArtistMeta { id: id.into(), - sort: None, info: ArtistInfo::default(), } } @@ -166,15 +165,7 @@ impl ArtistMeta { } pub fn get_sort_key(&self) -> (&str,) { - (self.sort.as_ref().unwrap_or(&self.id.name),) - } - - pub fn set_sort_key>(&mut self, sort: S) { - self.sort = Some(sort.into()); - } - - pub fn clear_sort_key(&mut self) { - self.sort.take(); + (self.info.sort.as_ref().unwrap_or(&self.id.name),) } } @@ -240,13 +231,13 @@ impl Merge for ArtistMeta { fn merge_in_place(&mut self, other: Self) { assert!(self.id.compatible(&other.id)); self.id.mb_ref = self.id.mb_ref.take().or(other.id.mb_ref); - self.sort = self.sort.take().or(other.sort); self.info.merge_in_place(other.info); } } impl Merge for ArtistInfo { fn merge_in_place(&mut self, other: Self) { + self.sort = self.sort.take().or(other.sort); self.properties.merge_in_place(other.properties); } } @@ -318,53 +309,6 @@ mod tests { static MUSICBUTLER: &str = "https://www.musicbutler.io/artist-page/483340948"; static MUSICBUTLER_2: &str = "https://www.musicbutler.io/artist-page/658903042/"; - #[test] - fn artist_sort_set_clear() { - let artist_id = ArtistId::new("an artist"); - let sort_id_1 = String::from("sort id 1"); - let sort_id_2 = String::from("sort id 2"); - - let mut artist = Artist::new(&artist_id.name); - - assert_eq!(artist.meta.id, artist_id); - assert_eq!(artist.meta.sort, None); - assert_eq!(artist.meta.get_sort_key(), (artist_id.name.as_str(),)); - assert!(artist.meta < ArtistMeta::new(sort_id_1.clone())); - assert!(artist.meta < ArtistMeta::new(sort_id_2.clone())); - assert!(artist < Artist::new(sort_id_1.clone())); - assert!(artist < Artist::new(sort_id_2.clone())); - - artist.meta.set_sort_key(sort_id_1.clone()); - - assert_eq!(artist.meta.id, artist_id); - assert_eq!(artist.meta.sort.as_ref(), Some(&sort_id_1)); - assert_eq!(artist.meta.get_sort_key(), (sort_id_1.as_str(),)); - assert!(artist.meta > ArtistMeta::new(artist_id.clone())); - assert!(artist.meta < ArtistMeta::new(sort_id_2.clone())); - assert!(artist > Artist::new(artist_id.clone())); - assert!(artist < Artist::new(sort_id_2.clone())); - - artist.meta.set_sort_key(sort_id_2.clone()); - - assert_eq!(artist.meta.id, artist_id); - assert_eq!(artist.meta.sort.as_ref(), Some(&sort_id_2)); - assert_eq!(artist.meta.get_sort_key(), (sort_id_2.as_str(),)); - assert!(artist.meta > ArtistMeta::new(artist_id.clone())); - assert!(artist.meta > ArtistMeta::new(sort_id_1.clone())); - assert!(artist > Artist::new(artist_id.clone())); - assert!(artist > Artist::new(sort_id_1.clone())); - - artist.meta.clear_sort_key(); - - assert_eq!(artist.meta.id, artist_id); - assert_eq!(artist.meta.sort, None); - assert_eq!(artist.meta.get_sort_key(), (artist_id.name.as_str(),)); - assert!(artist.meta < ArtistMeta::new(sort_id_1.clone())); - assert!(artist.meta < ArtistMeta::new(sort_id_2.clone())); - assert!(artist < Artist::new(sort_id_1.clone())); - assert!(artist < Artist::new(sort_id_2.clone())); - } - #[test] fn set_clear_musicbrainz_url() { let mut artist = Artist::new(ArtistId::new("an artist")); diff --git a/src/core/musichoard/base.rs b/src/core/musichoard/base.rs index edd63f1..f7d684e 100644 --- a/src/core/musichoard/base.rs +++ b/src/core/musichoard/base.rs @@ -216,13 +216,13 @@ mod tests { assert!(right.first().unwrap() > left.first().unwrap()); let artist_sort = Some(String::from("Album_Artist 0")); - right[0].meta.sort = artist_sort.clone(); + right[0].meta.info.sort = artist_sort.clone(); assert!(right.first().unwrap() < left.first().unwrap()); // The result of the merge should be the same list of artists, but with the last artist now // in first place. let mut expected = left.to_owned(); - expected.last_mut().as_mut().unwrap().meta.sort = artist_sort.clone(); + expected.last_mut().as_mut().unwrap().meta.info.sort = artist_sort.clone(); expected.rotate_right(1); let mut mh = MusicHoard { diff --git a/src/core/musichoard/library.rs b/src/core/musichoard/library.rs index 29a5ba0..e1e7f1d 100644 --- a/src/core/musichoard/library.rs +++ b/src/core/musichoard/library.rs @@ -92,17 +92,17 @@ impl MusicHoard { .or_insert_with(|| Artist::new(artist_id)), }; - if artist.meta.sort.is_some() { - if artist_sort.is_some() && (artist.meta.sort != artist_sort) { + if artist.meta.info.sort.is_some() { + if artist_sort.is_some() && (artist.meta.info.sort != artist_sort) { return Err(Error::CollectionError(format!( "multiple album_artist_sort found for artist '{}': '{}' != '{}'", artist.meta.id, - artist.meta.sort.as_ref().unwrap(), + artist.meta.info.sort.as_ref().unwrap(), artist_sort.as_ref().unwrap() ))); } } else if artist_sort.is_some() { - artist.meta.sort = artist_sort; + artist.meta.info.sort = artist_sort; } // Do a linear search as few artists have more than a handful of albums. Search from the diff --git a/src/external/database/serde/deserialize.rs b/src/external/database/serde/deserialize.rs index 0f4eb09..5d5a302 100644 --- a/src/external/database/serde/deserialize.rs +++ b/src/external/database/serde/deserialize.rs @@ -122,8 +122,8 @@ impl From for Artist { name: artist.name, mb_ref: artist.mb_ref.into(), }, - sort: artist.sort, info: ArtistInfo { + sort: artist.sort, properties: artist.properties, }, }, diff --git a/src/external/database/serde/serialize.rs b/src/external/database/serde/serialize.rs index dbb4145..8f99b4b 100644 --- a/src/external/database/serde/serialize.rs +++ b/src/external/database/serde/serialize.rs @@ -76,7 +76,7 @@ impl<'a> From<&'a Artist> for SerializeArtist<'a> { SerializeArtist { name: &artist.meta.id.name, mb_ref: (&artist.meta.id.mb_ref).into(), - sort: &artist.meta.sort, + sort: &artist.meta.info.sort, properties: &artist.meta.info.properties, albums: artist.albums.iter().map(Into::into).collect(), } diff --git a/src/external/database/sql/mod.rs b/src/external/database/sql/mod.rs index 711ee86..eecb94d 100644 --- a/src/external/database/sql/mod.rs +++ b/src/external/database/sql/mod.rs @@ -152,7 +152,7 @@ impl ISqlDatabaseBackend<'conn>> SqlDatabase { } impl ISqlDatabaseBackend<'conn>> IDatabase for SqlDatabase { - fn reset(&mut self) -> Result<(),SaveError> { + fn reset(&mut self) -> Result<(), SaveError> { let tx = self.backend.transaction()?; Self::drop_tables(&tx)?; diff --git a/src/testmod/full.rs b/src/testmod/full.rs index 4e5c1d2..d16c111 100644 --- a/src/testmod/full.rs +++ b/src/testmod/full.rs @@ -9,8 +9,8 @@ macro_rules! full_collection { "https://musicbrainz.org/artist/00000000-0000-0000-0000-000000000000" ).unwrap()), }, - sort: None, info: ArtistInfo { + sort: None, properties: HashMap::from([ (String::from("MusicButler"), vec![ String::from("https://www.musicbutler.io/artist-page/000000000"), @@ -139,8 +139,8 @@ macro_rules! full_collection { "https://musicbrainz.org/artist/11111111-1111-1111-1111-111111111111" ).unwrap()), }, - sort: None, info: ArtistInfo { + sort: None, properties: HashMap::from([ (String::from("MusicButler"), vec![ String::from("https://www.musicbutler.io/artist-page/111111111"), @@ -338,8 +338,8 @@ macro_rules! full_collection { name: "The Album_Artist ‘C’".to_string(), mb_ref: ArtistMbRef::CannotHaveMbid, }, - sort: Some("Album_Artist ‘C’, The".to_string()), info: ArtistInfo { + sort: Some("Album_Artist ‘C’, The".to_string()), properties: HashMap::new(), }, }, @@ -436,8 +436,8 @@ macro_rules! full_collection { name: "Album_Artist ‘D’".to_string(), mb_ref: ArtistMbRef::None, }, - sort: None, info: ArtistInfo { + sort: None, properties: HashMap::new(), }, }, diff --git a/src/testmod/library.rs b/src/testmod/library.rs index 90a1a69..f8cc7db 100644 --- a/src/testmod/library.rs +++ b/src/testmod/library.rs @@ -8,8 +8,8 @@ macro_rules! library_collection { name: "Album_Artist ‘A’".to_string(), mb_ref: ArtistMbRef::None, }, - sort: None, info: ArtistInfo { + sort: None, properties: HashMap::new(), }, }, @@ -119,8 +119,8 @@ macro_rules! library_collection { name: "Album_Artist ‘B’".to_string(), mb_ref: ArtistMbRef::None, }, - sort: None, info: ArtistInfo { + sort: None, properties: HashMap::new(), }, }, @@ -289,8 +289,8 @@ macro_rules! library_collection { name: "The Album_Artist ‘C’".to_string(), mb_ref: ArtistMbRef::None, }, - sort: Some("Album_Artist ‘C’, The".to_string()), info: ArtistInfo { + sort: Some("Album_Artist ‘C’, The".to_string()), properties: HashMap::new(), }, }, @@ -381,8 +381,8 @@ macro_rules! library_collection { name: "Album_Artist ‘D’".to_string(), mb_ref: ArtistMbRef::None, }, - sort: None, info: ArtistInfo { + sort: None, properties: HashMap::new(), }, }, diff --git a/src/tui/app/machine/search_state.rs b/src/tui/app/machine/search_state.rs index 1e4dc0d..a7f5701 100644 --- a/src/tui/app/machine/search_state.rs +++ b/src/tui/app/machine/search_state.rs @@ -162,7 +162,7 @@ impl IAppInteractSearchPrivate for AppMachine { let name = string::normalize_string_with(&probe.meta.id.name, !case_sens, !char_sens); let mut result = name.string.starts_with(search); - if let Some(ref probe_sort) = probe.meta.sort { + if let Some(ref probe_sort) = probe.meta.info.sort { if !result { let name = string::normalize_string_with(probe_sort, !case_sens, !char_sens); result = name.string.starts_with(search); diff --git a/src/tui/lib/external/musicbrainz/api/mod.rs b/src/tui/lib/external/musicbrainz/api/mod.rs index d648b8d..1ec116d 100644 --- a/src/tui/lib/external/musicbrainz/api/mod.rs +++ b/src/tui/lib/external/musicbrainz/api/mod.rs @@ -119,8 +119,8 @@ fn from_mb_artist_meta(meta: MbArtistMeta) -> (ArtistMeta, Option) { name: meta.name, mb_ref: ArtistMbRef::Some(meta.id.into()), }, - sort, info: ArtistInfo { + sort, properties: HashMap::new(), }, }, diff --git a/tests/lib.rs b/tests/lib.rs index 5900803..1abeee7 100644 --- a/tests/lib.rs +++ b/tests/lib.rs @@ -65,7 +65,7 @@ fn merge_library_then_database() { assert_eq!(music_hoard.get_collection(), &*COLLECTION); - sqldiff(&*COMPLETE_DB_TEST_FILE.as_os_str(), file.path().as_os_str()); + sqldiff(COMPLETE_DB_TEST_FILE.as_os_str(), file.path().as_os_str()); } #[test] @@ -91,5 +91,5 @@ fn merge_database_then_library() { assert_eq!(music_hoard.get_collection(), &*COLLECTION); - sqldiff(&*COMPLETE_DB_TEST_FILE.as_os_str(), file.path().as_os_str()); + sqldiff(COMPLETE_DB_TEST_FILE.as_os_str(), file.path().as_os_str()); } diff --git a/tests/testlib.rs b/tests/testlib.rs index 119042a..36a0035 100644 --- a/tests/testlib.rs +++ b/tests/testlib.rs @@ -22,8 +22,8 @@ pub static COLLECTION: Lazy> = Lazy::new(|| -> Collection { "https://musicbrainz.org/artist/baad262d-55ef-427a-83c7-f7530964f212" ).unwrap()), }, - sort: Some(String::from("Arkona")), info: ArtistInfo { + sort: Some(String::from("Arkona")), properties: HashMap::from([ (String::from("MusicButler"), vec![ String::from("https://www.musicbutler.io/artist-page/283448581"), @@ -217,8 +217,8 @@ pub static COLLECTION: Lazy> = Lazy::new(|| -> Collection { "https://musicbrainz.org/artist/8000598a-5edb-401c-8e6d-36b167feaf38" ).unwrap()), }, - sort: None, info: ArtistInfo { + sort: None, properties: HashMap::from([ (String::from("MusicButler"), vec![ String::from("https://www.musicbutler.io/artist-page/269358403"), @@ -472,8 +472,8 @@ pub static COLLECTION: Lazy> = Lazy::new(|| -> Collection { "https://musicbrainz.org/artist/3a901353-fccd-4afd-ad01-9c03f451b490" ).unwrap()), }, - sort: None, info: ArtistInfo { + sort: None, properties: HashMap::from([ (String::from("MusicButler"), vec![ String::from("https://www.musicbutler.io/artist-page/826588800"), @@ -631,8 +631,8 @@ pub static COLLECTION: Lazy> = Lazy::new(|| -> Collection { "https://musicbrainz.org/artist/c2c4d56a-d599-4a18-bd2f-ae644e2198cc" ).unwrap()), }, - sort: Some(String::from("Heaven’s Basement")), info: ArtistInfo { + sort: Some(String::from("Heaven’s Basement")), properties: HashMap::from([ (String::from("MusicButler"), vec![ String::from("https://www.musicbutler.io/artist-page/291158685"), @@ -770,8 +770,8 @@ pub static COLLECTION: Lazy> = Lazy::new(|| -> Collection { "https://musicbrainz.org/artist/65f4f0c5-ef9e-490c-aee3-909e7ae6b2ab" ).unwrap()), }, - sort: None, info: ArtistInfo { + sort: None, properties: HashMap::from([ (String::from("MusicButler"), vec![ String::from("https://www.musicbutler.io/artist-page/3996865"),