read_fonts/generated/
generated_ltag.rs1#[allow(unused_imports)]
6use crate::codegen_prelude::*;
7
8impl<'a> MinByteRange<'a> for Ltag<'a> {
9 fn min_byte_range(&self) -> Range<usize> {
10 0..self.tag_ranges_byte_range().end
11 }
12 fn min_table_bytes(&self) -> &'a [u8] {
13 let range = self.min_byte_range();
14 self.data.as_bytes().get(range).unwrap_or_default()
15 }
16}
17
18impl TopLevelTable for Ltag<'_> {
19 const TAG: Tag = Tag::new(b"ltag");
21}
22
23impl<'a> FontRead<'a> for Ltag<'a> {
24 fn read(data: FontData<'a>) -> Result<Self, ReadError> {
25 #[allow(clippy::absurd_extreme_comparisons)]
26 if data.len() < Self::MIN_SIZE {
27 return Err(ReadError::OutOfBounds);
28 }
29 Ok(Self { data })
30 }
31}
32
33#[derive(Clone)]
35pub struct Ltag<'a> {
36 data: FontData<'a>,
37}
38
39#[allow(clippy::needless_lifetimes)]
40impl<'a> Ltag<'a> {
41 pub const MIN_SIZE: usize = (u32::RAW_BYTE_LEN + u32::RAW_BYTE_LEN + u32::RAW_BYTE_LEN);
42 basic_table_impls!(impl_the_methods);
43
44 pub fn version(&self) -> u32 {
46 let range = self.version_byte_range();
47 self.data.read_at(range.start).ok().unwrap()
48 }
49
50 pub fn flags(&self) -> u32 {
52 let range = self.flags_byte_range();
53 self.data.read_at(range.start).ok().unwrap()
54 }
55
56 pub fn num_tags(&self) -> u32 {
58 let range = self.num_tags_byte_range();
59 self.data.read_at(range.start).ok().unwrap()
60 }
61
62 pub fn tag_ranges(&self) -> &'a [FTStringRange] {
64 let range = self.tag_ranges_byte_range();
65 self.data.read_array(range).ok().unwrap_or_default()
66 }
67
68 pub fn version_byte_range(&self) -> Range<usize> {
69 let start = 0;
70 start..start + u32::RAW_BYTE_LEN
71 }
72
73 pub fn flags_byte_range(&self) -> Range<usize> {
74 let start = self.version_byte_range().end;
75 start..start + u32::RAW_BYTE_LEN
76 }
77
78 pub fn num_tags_byte_range(&self) -> Range<usize> {
79 let start = self.flags_byte_range().end;
80 start..start + u32::RAW_BYTE_LEN
81 }
82
83 pub fn tag_ranges_byte_range(&self) -> Range<usize> {
84 let num_tags = self.num_tags();
85 let start = self.num_tags_byte_range().end;
86 start..start + (num_tags as usize).saturating_mul(FTStringRange::RAW_BYTE_LEN)
87 }
88}
89
90#[cfg(feature = "experimental_traverse")]
91impl<'a> SomeTable<'a> for Ltag<'a> {
92 fn type_name(&self) -> &str {
93 "Ltag"
94 }
95 fn get_field(&self, idx: usize) -> Option<Field<'a>> {
96 match idx {
97 0usize => Some(Field::new("version", self.version())),
98 1usize => Some(Field::new("flags", self.flags())),
99 2usize => Some(Field::new("num_tags", self.num_tags())),
100 3usize => Some(Field::new(
101 "tag_ranges",
102 traversal::FieldType::array_of_records(
103 stringify!(FTStringRange),
104 self.tag_ranges(),
105 self.offset_data(),
106 ),
107 )),
108 _ => None,
109 }
110 }
111}
112
113#[cfg(feature = "experimental_traverse")]
114#[allow(clippy::needless_lifetimes)]
115impl<'a> std::fmt::Debug for Ltag<'a> {
116 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
117 (self as &dyn SomeTable<'a>).fmt(f)
118 }
119}
120
121#[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash, Copy, bytemuck :: AnyBitPattern)]
123#[repr(C)]
124#[repr(packed)]
125pub struct FTStringRange {
126 pub offset: BigEndian<u16>,
128 pub length: BigEndian<u16>,
130}
131
132impl FTStringRange {
133 pub fn offset(&self) -> u16 {
135 self.offset.get()
136 }
137
138 pub fn length(&self) -> u16 {
140 self.length.get()
141 }
142}
143
144impl FixedSize for FTStringRange {
145 const RAW_BYTE_LEN: usize = u16::RAW_BYTE_LEN + u16::RAW_BYTE_LEN;
146}
147
148#[cfg(feature = "experimental_traverse")]
149impl<'a> SomeRecord<'a> for FTStringRange {
150 fn traverse(self, data: FontData<'a>) -> RecordResolver<'a> {
151 RecordResolver {
152 name: "FTStringRange",
153 get_field: Box::new(move |idx, _data| match idx {
154 0usize => Some(Field::new("offset", self.offset())),
155 1usize => Some(Field::new("length", self.length())),
156 _ => None,
157 }),
158 data,
159 }
160 }
161}