From ff68b7aaf7c66b846628f56f22074534ee661e56 Mon Sep 17 00:00:00 2001 From: Will Hedgecock Date: Mon, 4 Nov 2024 12:19:20 -0600 Subject: [PATCH] Remove panicable unwrap calls --- musicxml/src/elements/lyric.rs | 22 +++--- musicxml/src/elements/note.rs | 6 +- musicxml/src/elements/percussion.rs | 102 ++++++++++++++-------------- musicxml/src/elements/time.rs | 2 +- musicxml/src/parser/xml_parser.rs | 25 +++---- musicxml_macros/CHANGELOG.md | 20 +++++- 6 files changed, 99 insertions(+), 78 deletions(-) diff --git a/musicxml/src/elements/lyric.rs b/musicxml/src/elements/lyric.rs index 6270bb8..dfb0230 100644 --- a/musicxml/src/elements/lyric.rs +++ b/musicxml/src/elements/lyric.rs @@ -87,21 +87,23 @@ impl ContentDeserializer for TextLyric { "syllabic" => { if text_lyric.syllabic.is_none() { text_lyric.syllabic = Some(Syllabic::deserialize(el)?); - } else if !text_lyric.additional.is_empty() { - text_lyric.additional.last_mut().unwrap().syllabic = Some(Syllabic::deserialize(el)?); + } else if let Some(additional) = text_lyric.additional.last_mut() { + additional.syllabic = Some(Syllabic::deserialize(el)?); } } "text" => { if text_lyric.text.content.is_empty() { text_lyric.text = Text::deserialize(el)?; - } else if text_lyric.additional.is_empty() { - text_lyric.additional.push(AdditionalTextLyric { - elision: None, - syllabic: None, - text: Text::deserialize(el)?, - }); - } else if text_lyric.additional.last().unwrap().text.content.is_empty() { - text_lyric.additional.last_mut().unwrap().text = Text::deserialize(el)?; + } else if let Some(additional) = text_lyric.additional.last_mut() { + if additional.text.content.is_empty() { + additional.text = Text::deserialize(el)?; + } else { + text_lyric.additional.push(AdditionalTextLyric { + elision: None, + syllabic: None, + text: Text::deserialize(el)?, + }); + } } else { text_lyric.additional.push(AdditionalTextLyric { elision: None, diff --git a/musicxml/src/elements/note.rs b/musicxml/src/elements/note.rs index 1ef7369..e54f408 100644 --- a/musicxml/src/elements/note.rs +++ b/musicxml/src/elements/note.rs @@ -224,7 +224,7 @@ pub struct GraceInfo { impl ContentDeserializer for GraceInfo { fn deserialize(elements: &[XmlElement]) -> Result { Ok(GraceInfo { - grace: Grace::deserialize(elements.first().unwrap())?, + grace: Grace::deserialize(elements.first().ok_or("Missing sub-element")?)?, info: if elements.iter().any(|el| el.name == "cue") { GraceType::Cue(GraceCueInfo::deserialize(elements)?) } else { @@ -435,9 +435,9 @@ pub struct NoteContents { impl ContentDeserializer for NoteContents { fn deserialize(elements: &[XmlElement]) -> Result { let mut note_contents = NoteContents { - info: if elements.first().unwrap().name == "grace" { + info: if elements.first().ok_or("Missing sub-element")?.name == "grace" { NoteType::Grace(GraceInfo::deserialize(elements)?) - } else if elements.first().unwrap().name == "cue" { + } else if elements.first().ok_or("Missing sub-element")?.name == "cue" { NoteType::Cue(CueInfo::deserialize(elements)?) } else { NoteType::Normal(NormalInfo::deserialize(elements)?) diff --git a/musicxml/src/elements/percussion.rs b/musicxml/src/elements/percussion.rs index 04e6f22..776f39e 100644 --- a/musicxml/src/elements/percussion.rs +++ b/musicxml/src/elements/percussion.rs @@ -102,7 +102,7 @@ pub struct Percussion { impl ElementDeserializer for Percussion { fn deserialize(element: &XmlElement) -> Result { - let el = element.elements.first().unwrap(); + let el = element.elements.first().ok_or("No sub-element found in ")?; Ok(Percussion { attributes: PercussionAttributes::deserialize(&element.attributes)?, content: match el.name.as_str() { @@ -126,59 +126,59 @@ impl ElementDeserializer for Percussion { impl ElementSerializer for Percussion { fn serialize(element: &Self) -> XmlElement { let name; - let mut xml_element = XmlElement { + let mut xml_element = match &element.content { + PercussionContents::Glass(content) => { + name = String::from("glass"); + Glass::serialize(content) + } + PercussionContents::Metal(content) => { + name = String::from("metal"); + Metal::serialize(content) + } + PercussionContents::Wood(content) => { + name = String::from("wood"); + Wood::serialize(content) + } + PercussionContents::Pitched(content) => { + name = String::from("pitched"); + Pitched::serialize(content) + } + PercussionContents::Membrane(content) => { + name = String::from("membrane"); + Membrane::serialize(content) + } + PercussionContents::Effect(content) => { + name = String::from("effect"); + Effect::serialize(content) + } + PercussionContents::Timpani(content) => { + name = String::from("timpani"); + Timpani::serialize(content) + } + PercussionContents::Beater(content) => { + name = String::from("beater"); + Beater::serialize(content) + } + PercussionContents::Stick(content) => { + name = String::from("stick"); + Stick::serialize(content) + } + PercussionContents::StickLocation(content) => { + name = String::from("stick-location"); + StickLocation::serialize(content) + } + PercussionContents::OtherPercussion(content) => { + name = String::from("other-percussion"); + OtherPercussion::serialize(content) + } + }; + xml_element.name = name; + XmlElement { name: String::new(), attributes: PercussionAttributes::serialize(&element.attributes), - elements: vec![match &element.content { - PercussionContents::Glass(content) => { - name = String::from("glass"); - Glass::serialize(content) - } - PercussionContents::Metal(content) => { - name = String::from("metal"); - Metal::serialize(content) - } - PercussionContents::Wood(content) => { - name = String::from("wood"); - Wood::serialize(content) - } - PercussionContents::Pitched(content) => { - name = String::from("pitched"); - Pitched::serialize(content) - } - PercussionContents::Membrane(content) => { - name = String::from("membrane"); - Membrane::serialize(content) - } - PercussionContents::Effect(content) => { - name = String::from("effect"); - Effect::serialize(content) - } - PercussionContents::Timpani(content) => { - name = String::from("timpani"); - Timpani::serialize(content) - } - PercussionContents::Beater(content) => { - name = String::from("beater"); - Beater::serialize(content) - } - PercussionContents::Stick(content) => { - name = String::from("stick"); - Stick::serialize(content) - } - PercussionContents::StickLocation(content) => { - name = String::from("stick-location"); - StickLocation::serialize(content) - } - PercussionContents::OtherPercussion(content) => { - name = String::from("other-percussion"); - OtherPercussion::serialize(content) - } - }], + elements: vec![xml_element], text: String::new(), - }; - xml_element.elements.last_mut().unwrap().name = name; - xml_element + } } } diff --git a/musicxml/src/elements/time.rs b/musicxml/src/elements/time.rs index 804475c..3d7f773 100644 --- a/musicxml/src/elements/time.rs +++ b/musicxml/src/elements/time.rs @@ -97,7 +97,7 @@ impl ContentDeserializer for TimeContents { "beats" => time_beats = Some(Beats::deserialize(element)?), "beat-type" => { beats.push(TimeBeatContents { - beats: time_beats.unwrap(), + beats: time_beats.ok_or("Missing required element in