From 11b6c810f4d532192b8d38212722965e1150ca8f Mon Sep 17 00:00:00 2001 From: Hoolean Date: Tue, 12 Nov 2024 22:13:14 +0000 Subject: [PATCH] Derive `data_maps_count` from length of `data_maps` on write --- resources/codegen_inputs/meta.rs | 1 + write-fonts/generated/generated_meta.rs | 8 ++------ 2 files changed, 3 insertions(+), 6 deletions(-) diff --git a/resources/codegen_inputs/meta.rs b/resources/codegen_inputs/meta.rs index 2b5a13c42..ec43b5d75 100644 --- a/resources/codegen_inputs/meta.rs +++ b/resources/codegen_inputs/meta.rs @@ -14,6 +14,7 @@ table Meta { #[compile(0)] reserved: u32, /// The number of data maps in the table. + #[compile(array_len($data_maps))] data_maps_count: u32, /// Array of data map records. #[count($data_maps_count)] diff --git a/write-fonts/generated/generated_meta.rs b/write-fonts/generated/generated_meta.rs index 41fae6693..edef6fe5d 100644 --- a/write-fonts/generated/generated_meta.rs +++ b/write-fonts/generated/generated_meta.rs @@ -9,17 +9,14 @@ use crate::codegen_prelude::*; #[derive(Clone, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)] #[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))] pub struct Meta { - /// The number of data maps in the table. - pub data_maps_count: u32, /// Array of data map records. pub data_maps: Vec, } impl Meta { /// Construct a new `Meta` - pub fn new(data_maps_count: u32, data_maps: Vec) -> Self { + pub fn new(data_maps: Vec) -> Self { Self { - data_maps_count, data_maps: data_maps.into_iter().map(Into::into).collect(), } } @@ -31,7 +28,7 @@ impl FontWrite for Meta { (1 as u32).write_into(writer); (0 as u32).write_into(writer); (0 as u32).write_into(writer); - self.data_maps_count.write_into(writer); + (array_len(&self.data_maps).unwrap() as u32).write_into(writer); self.data_maps.write_into(writer); } fn table_type(&self) -> TableType { @@ -60,7 +57,6 @@ impl<'a> FromObjRef> for Meta { fn from_obj_ref(obj: &read_fonts::tables::meta::Meta<'a>, _: FontData) -> Self { let offset_data = obj.offset_data(); Meta { - data_maps_count: obj.data_maps_count(), data_maps: obj.data_maps().to_owned_obj(offset_data), } }