From c499429aea74e0ef393335f0df559cfd89b88394 Mon Sep 17 00:00:00 2001 From: Colin Rofls Date: Wed, 14 Dec 2022 18:12:28 -0500 Subject: [PATCH] Fix incorrect size calculation for MacRoman strings We were counting bytes and not chars. --- write-fonts/src/tables/name.rs | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/write-fonts/src/tables/name.rs b/write-fonts/src/tables/name.rs index 8ec727e2a..94349d0f4 100644 --- a/write-fonts/src/tables/name.rs +++ b/write-fonts/src/tables/name.rs @@ -98,7 +98,7 @@ impl NameStringWriter<'_> { match self.encoding { Encoding::Utf16Be => self.string.chars().map(|c| c.len_utf16() as u16 * 2).sum(), // this will be correct assuming we pass validation - Encoding::MacRoman => self.string.len().try_into().unwrap(), + Encoding::MacRoman => self.string.chars().count().try_into().unwrap(), Encoding::Unknown => 0, } } @@ -222,6 +222,19 @@ mod tests { assert_eq!(loaded.name_record()[2].name_id, 1030); } + /// ensure we are counting characters and not bytes + #[test] + fn mac_str_length() { + let name = NameRecord::new(1, 0, 0, 9, String::from("cé").into()); + let mut table = Name::default(); + table.name_record.insert(name); + let bytes = crate::dump_table(&table).unwrap(); + let load = crate::read::tables::name::Name::read(FontData::new(&bytes)).unwrap(); + + let data = load.name_record()[0].string(load.string_data()).unwrap(); + assert_eq!(data.chars().collect::(), "cé"); + } + #[test] fn roundtrip() { #[rustfmt::skip]