// THIS FILE IS AUTOGENERATED. // Any changes to this file will be overwritten. // For more information about how codegen works, see font-codegen/README.md #[allow(unused_imports)] use crate::codegen_prelude::*; /// The [anchor point](https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6ankr.html) table. #[derive(Debug, Clone, Copy)] #[doc(hidden)] pub struct AnkrMarker {} impl AnkrMarker { pub fn version_byte_range(&self) -> Range { let start = 0; start..start + u16::RAW_BYTE_LEN } pub fn flags_byte_range(&self) -> Range { let start = self.version_byte_range().end; start..start + u16::RAW_BYTE_LEN } pub fn lookup_table_offset_byte_range(&self) -> Range { let start = self.flags_byte_range().end; start..start + Offset32::RAW_BYTE_LEN } pub fn glyph_data_table_offset_byte_range(&self) -> Range { let start = self.lookup_table_offset_byte_range().end; start..start + u32::RAW_BYTE_LEN } } impl MinByteRange for AnkrMarker { fn min_byte_range(&self) -> Range { 0..self.glyph_data_table_offset_byte_range().end } } impl TopLevelTable for Ankr<'_> { /// `ankr` const TAG: Tag = Tag::new(b"ankr"); } impl<'a> FontRead<'a> for Ankr<'a> { fn read(data: FontData<'a>) -> Result { let mut cursor = data.cursor(); cursor.advance::(); cursor.advance::(); cursor.advance::(); cursor.advance::(); cursor.finish(AnkrMarker {}) } } /// The [anchor point](https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6ankr.html) table. pub type Ankr<'a> = TableRef<'a, AnkrMarker>; #[allow(clippy::needless_lifetimes)] impl<'a> Ankr<'a> { /// Version number (set to zero). pub fn version(&self) -> u16 { let range = self.shape.version_byte_range(); self.data.read_at(range.start).unwrap() } /// Flags (currently unused; set to zero). pub fn flags(&self) -> u16 { let range = self.shape.flags_byte_range(); self.data.read_at(range.start).unwrap() } /// Offset to the table's lookup table; currently this is always `0x0000000C`. /// /// Lookup values are two byte offsets into the glyph data table. pub fn lookup_table_offset(&self) -> Offset32 { let range = self.shape.lookup_table_offset_byte_range(); self.data.read_at(range.start).unwrap() } /// Attempt to resolve [`lookup_table_offset`][Self::lookup_table_offset]. pub fn lookup_table(&self) -> Result, ReadError> { let data = self.data; self.lookup_table_offset().resolve(data) } /// Offset to the glyph data table. pub fn glyph_data_table_offset(&self) -> u32 { let range = self.shape.glyph_data_table_offset_byte_range(); self.data.read_at(range.start).unwrap() } } #[cfg(feature = "experimental_traverse")] impl<'a> SomeTable<'a> for Ankr<'a> { fn type_name(&self) -> &str { "Ankr" } fn get_field(&self, idx: usize) -> Option> { match idx { 0usize => Some(Field::new("version", self.version())), 1usize => Some(Field::new("flags", self.flags())), 2usize => Some(Field::new( "lookup_table_offset", FieldType::offset(self.lookup_table_offset(), self.lookup_table()), )), 3usize => Some(Field::new( "glyph_data_table_offset", self.glyph_data_table_offset(), )), _ => None, } } } #[cfg(feature = "experimental_traverse")] #[allow(clippy::needless_lifetimes)] impl<'a> std::fmt::Debug for Ankr<'a> { fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { (self as &dyn SomeTable<'a>).fmt(f) } } #[derive(Debug, Clone, Copy)] #[doc(hidden)] pub struct GlyphDataEntryMarker { anchor_points_byte_len: usize, } impl GlyphDataEntryMarker { pub fn num_points_byte_range(&self) -> Range { let start = 0; start..start + u32::RAW_BYTE_LEN } pub fn anchor_points_byte_range(&self) -> Range { let start = self.num_points_byte_range().end; start..start + self.anchor_points_byte_len } } impl MinByteRange for GlyphDataEntryMarker { fn min_byte_range(&self) -> Range { 0..self.anchor_points_byte_range().end } } impl<'a> FontRead<'a> for GlyphDataEntry<'a> { fn read(data: FontData<'a>) -> Result { let mut cursor = data.cursor(); let num_points: u32 = cursor.read()?; let anchor_points_byte_len = (num_points as usize) .checked_mul(AnchorPoint::RAW_BYTE_LEN) .ok_or(ReadError::OutOfBounds)?; cursor.advance_by(anchor_points_byte_len); cursor.finish(GlyphDataEntryMarker { anchor_points_byte_len, }) } } pub type GlyphDataEntry<'a> = TableRef<'a, GlyphDataEntryMarker>; #[allow(clippy::needless_lifetimes)] impl<'a> GlyphDataEntry<'a> { /// Number of anchor points for this glyph. pub fn num_points(&self) -> u32 { let range = self.shape.num_points_byte_range(); self.data.read_at(range.start).unwrap() } /// Individual anchor points. pub fn anchor_points(&self) -> &'a [AnchorPoint] { let range = self.shape.anchor_points_byte_range(); self.data.read_array(range).unwrap() } } #[cfg(feature = "experimental_traverse")] impl<'a> SomeTable<'a> for GlyphDataEntry<'a> { fn type_name(&self) -> &str { "GlyphDataEntry" } fn get_field(&self, idx: usize) -> Option> { match idx { 0usize => Some(Field::new("num_points", self.num_points())), 1usize => Some(Field::new( "anchor_points", traversal::FieldType::array_of_records( stringify!(AnchorPoint), self.anchor_points(), self.offset_data(), ), )), _ => None, } } } #[cfg(feature = "experimental_traverse")] #[allow(clippy::needless_lifetimes)] impl<'a> std::fmt::Debug for GlyphDataEntry<'a> { fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { (self as &dyn SomeTable<'a>).fmt(f) } } /// Individual anchor point. #[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash, Copy, bytemuck :: AnyBitPattern)] #[repr(C)] #[repr(packed)] pub struct AnchorPoint { pub x: BigEndian, pub y: BigEndian, } impl AnchorPoint { pub fn x(&self) -> i16 { self.x.get() } pub fn y(&self) -> i16 { self.y.get() } } impl FixedSize for AnchorPoint { const RAW_BYTE_LEN: usize = i16::RAW_BYTE_LEN + i16::RAW_BYTE_LEN; } #[cfg(feature = "experimental_traverse")] impl<'a> SomeRecord<'a> for AnchorPoint { fn traverse(self, data: FontData<'a>) -> RecordResolver<'a> { RecordResolver { name: "AnchorPoint", get_field: Box::new(move |idx, _data| match idx { 0usize => Some(Field::new("x", self.x())), 1usize => Some(Field::new("y", self.y())), _ => None, }), data, } } }