From 07dcb01a5eb4791239058b1d7b461f4f2e076b23 Mon Sep 17 00:00:00 2001 From: Nikolaus Waxweiler Date: Thu, 30 Sep 2021 18:16:15 +0100 Subject: [PATCH] MetaInfo: creator is optional now --- examples/normalize.rs | 2 +- src/font.rs | 10 ++++++---- tests/save.rs | 2 +- 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/examples/normalize.rs b/examples/normalize.rs index 2639613c..d080f280 100644 --- a/examples/normalize.rs +++ b/examples/normalize.rs @@ -51,7 +51,7 @@ fn main() { || k == "com.schriftgestaltung.customParameter.GSFontMaster.paramOver" }); - ufo.meta.creator = "org.linebender.norad".to_string(); + ufo.meta.creator = Some("org.linebender.norad".to_string()); if let Err(e) = ufo.save(arg) { eprintln!("Saving UFO failed: {}", e); std::process::exit(1); diff --git a/src/font.rs b/src/font.rs index 1863d07c..3caa05cd 100644 --- a/src/font.rs +++ b/src/font.rs @@ -64,7 +64,7 @@ pub enum FormatVersion { #[derive(Debug, Clone, Serialize, Deserialize, PartialEq)] #[serde(rename_all = "camelCase")] pub struct MetaInfo { - pub creator: String, + pub creator: Option, pub format_version: FormatVersion, #[serde(default, skip_serializing_if = "is_zero")] pub format_version_minor: u32, @@ -77,7 +77,7 @@ fn is_zero(v: &u32) -> bool { impl Default for MetaInfo { fn default() -> Self { MetaInfo { - creator: DEFAULT_METAINFO_CREATOR.to_string(), + creator: Some(DEFAULT_METAINFO_CREATOR.to_string()), format_version: FormatVersion::V3, format_version_minor: 0, } @@ -260,7 +260,7 @@ impl Font { // we want to always set ourselves as the creator when serializing, // but we also don't have mutable access to self. - if self.meta.creator == DEFAULT_METAINFO_CREATOR { + if self.meta.creator == Some(DEFAULT_METAINFO_CREATOR.into()) { write::write_xml_to_file(&path.join(METAINFO_FILE), &self.meta, options)?; } else { write::write_xml_to_file(&path.join(METAINFO_FILE), &MetaInfo::default(), options)?; @@ -630,7 +630,7 @@ mod tests { fn metainfo() { let path = "testdata/MutatorSansLightWide.ufo/metainfo.plist"; let meta: MetaInfo = plist::from_file(path).expect("failed to load metainfo"); - assert_eq!(meta.creator, "org.robofab.ufoLib"); + assert_eq!(meta.creator, Some("org.robofab.ufoLib".into())); } #[test] @@ -643,6 +643,7 @@ mod tests { &[ Token::Struct { name: "MetaInfo", len: 2 }, Token::Str("creator"), + Token::Some, Token::Str(DEFAULT_METAINFO_CREATOR), Token::Str("formatVersion"), Token::U8(3), @@ -656,6 +657,7 @@ mod tests { &[ Token::Struct { name: "MetaInfo", len: 3 }, Token::Str("creator"), + Token::Some, Token::Str(DEFAULT_METAINFO_CREATOR), Token::Str("formatVersion"), Token::U8(3), diff --git a/tests/save.rs b/tests/save.rs index f4225b67..3b2e066a 100644 --- a/tests/save.rs +++ b/tests/save.rs @@ -16,7 +16,7 @@ fn save_default() { let loaded = Font::load(dir).unwrap(); assert!(loaded.meta.format_version == FormatVersion::V3); - assert!(loaded.meta.creator == "org.linebender.norad"); + assert!(loaded.meta.creator == Some("org.linebender.norad".into())); assert_eq!(loaded.layers.len(), 1); }