read_fonts/generated/
generated_vmtx.rs1#[allow(unused_imports)]
6use crate::codegen_prelude::*;
7
8impl<'a> MinByteRange<'a> for Vmtx<'a> {
9 fn min_byte_range(&self) -> Range<usize> {
10 0..self.top_side_bearings_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 Vmtx<'_> {
19 const TAG: Tag = Tag::new(b"vmtx");
21}
22
23impl ReadArgs for Vmtx<'_> {
24 type Args = u16;
25}
26
27impl<'a> FontReadWithArgs<'a> for Vmtx<'a> {
28 fn read_with_args(data: FontData<'a>, args: &u16) -> Result<Self, ReadError> {
29 let number_of_long_ver_metrics = *args;
30
31 #[allow(clippy::absurd_extreme_comparisons)]
32 if data.len() < Self::MIN_SIZE {
33 return Err(ReadError::OutOfBounds);
34 }
35 Ok(Self {
36 data,
37 number_of_long_ver_metrics,
38 })
39 }
40}
41
42impl<'a> Vmtx<'a> {
43 pub fn read(data: FontData<'a>, number_of_long_ver_metrics: u16) -> Result<Self, ReadError> {
48 let args = number_of_long_ver_metrics;
49 Self::read_with_args(data, &args)
50 }
51}
52
53#[derive(Clone)]
55pub struct Vmtx<'a> {
56 data: FontData<'a>,
57 number_of_long_ver_metrics: u16,
58}
59
60#[allow(clippy::needless_lifetimes)]
61impl<'a> Vmtx<'a> {
62 pub const MIN_SIZE: usize = 0;
63 basic_table_impls!(impl_the_methods);
64
65 pub fn v_metrics(&self) -> &'a [LongMetric] {
68 let range = self.v_metrics_byte_range();
69 self.data.read_array(range).ok().unwrap_or_default()
70 }
71
72 pub fn top_side_bearings(&self) -> &'a [BigEndian<i16>] {
74 let range = self.top_side_bearings_byte_range();
75 self.data.read_array(range).ok().unwrap_or_default()
76 }
77
78 pub(crate) fn number_of_long_ver_metrics(&self) -> u16 {
79 self.number_of_long_ver_metrics
80 }
81
82 pub fn v_metrics_byte_range(&self) -> Range<usize> {
83 let number_of_long_ver_metrics = self.number_of_long_ver_metrics();
84 let start = 0;
85 start
86 ..start
87 + (transforms::to_usize(number_of_long_ver_metrics))
88 .saturating_mul(LongMetric::RAW_BYTE_LEN)
89 }
90
91 pub fn top_side_bearings_byte_range(&self) -> Range<usize> {
92 let start = self.v_metrics_byte_range().end;
93 start..start + self.data.len().saturating_sub(start) / i16::RAW_BYTE_LEN * i16::RAW_BYTE_LEN
94 }
95}
96
97#[allow(clippy::absurd_extreme_comparisons)]
98const _: () = assert!(FontData::default_data_long_enough(Vmtx::MIN_SIZE));
99
100impl Default for Vmtx<'_> {
101 fn default() -> Self {
102 Self {
103 data: FontData::default_table_data(),
104 number_of_long_ver_metrics: Default::default(),
105 }
106 }
107}
108
109#[cfg(feature = "experimental_traverse")]
110impl<'a> SomeTable<'a> for Vmtx<'a> {
111 fn type_name(&self) -> &str {
112 "Vmtx"
113 }
114 fn get_field(&self, idx: usize) -> Option<Field<'a>> {
115 match idx {
116 0usize => Some(Field::new(
117 "v_metrics",
118 traversal::FieldType::array_of_records(
119 stringify!(LongMetric),
120 self.v_metrics(),
121 self.offset_data(),
122 ),
123 )),
124 1usize => Some(Field::new("top_side_bearings", self.top_side_bearings())),
125 _ => None,
126 }
127 }
128}
129
130#[cfg(feature = "experimental_traverse")]
131#[allow(clippy::needless_lifetimes)]
132impl<'a> std::fmt::Debug for Vmtx<'a> {
133 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
134 (self as &dyn SomeTable<'a>).fmt(f)
135 }
136}