// 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::*;
#[derive(Debug, Clone, Copy)]
#[doc(hidden)]
pub struct BasicTableMarker {
simple_records_byte_len: usize,
array_records_byte_len: usize,
}
impl BasicTableMarker {
fn simple_count_byte_range(&self) -> Range<usize> {
let start = 0;
start..start + u16::RAW_BYTE_LEN
}
fn simple_records_byte_range(&self) -> Range<usize> {
let start = self.simple_count_byte_range().end;
start..start + self.simple_records_byte_len
}
fn arrays_inner_count_byte_range(&self) -> Range<usize> {
let start = self.simple_records_byte_range().end;
start..start + u16::RAW_BYTE_LEN
}
fn array_records_count_byte_range(&self) -> Range<usize> {
let start = self.arrays_inner_count_byte_range().end;
start..start + u32::RAW_BYTE_LEN
}
fn array_records_byte_range(&self) -> Range<usize> {
let start = self.array_records_count_byte_range().end;
start..start + self.array_records_byte_len
}
}
impl<'a> FontRead<'a> for BasicTable<'a> {
fn read(data: FontData<'a>) -> Result<Self, ReadError> {
let mut cursor = data.cursor();
let simple_count: u16 = cursor.read()?;
let simple_records_byte_len = (simple_count as usize)
.checked_mul(SimpleRecord::RAW_BYTE_LEN)
.ok_or(ReadError::OutOfBounds)?;
cursor.advance_by(simple_records_byte_len);
let arrays_inner_count: u16 = cursor.read()?;
let array_records_count: u32 = cursor.read()?;
let array_records_byte_len = (array_records_count as usize)
.checked_mul(<ContainsArrays as ComputeSize>::compute_size(
&arrays_inner_count,
)?)
.ok_or(ReadError::OutOfBounds)?;
cursor.advance_by(array_records_byte_len);
cursor.finish(BasicTableMarker {
simple_records_byte_len,
array_records_byte_len,
})
}
}
pub type BasicTable<'a> = TableRef<'a, BasicTableMarker>;
impl<'a> BasicTable<'a> {
pub fn simple_count(&self) -> u16 {
let range = self.shape.simple_count_byte_range();
self.data.read_at(range.start).unwrap()
}
pub fn simple_records(&self) -> &'a [SimpleRecord] {
let range = self.shape.simple_records_byte_range();
self.data.read_array(range).unwrap()
}
pub fn arrays_inner_count(&self) -> u16 {
let range = self.shape.arrays_inner_count_byte_range();
self.data.read_at(range.start).unwrap()
}
pub fn array_records_count(&self) -> u32 {
let range = self.shape.array_records_count_byte_range();
self.data.read_at(range.start).unwrap()
}
pub fn array_records(&self) -> ComputedArray<'a, ContainsArrays<'a>> {
let range = self.shape.array_records_byte_range();
self.data
.read_with_args(range, &self.arrays_inner_count())
.unwrap()
}
}
#[cfg(feature = "traversal")]
impl<'a> SomeTable<'a> for BasicTable<'a> {
fn type_name(&self) -> &str {
"BasicTable"
}
fn get_field(&self, idx: usize) -> Option<Field<'a>> {
match idx {
0usize => Some(Field::new("simple_count", self.simple_count())),
1usize => Some(Field::new(
"simple_records",
traversal::FieldType::array_of_records(
stringify!(SimpleRecord),
self.simple_records(),
self.offset_data(),
),
)),
2usize => Some(Field::new("arrays_inner_count", self.arrays_inner_count())),
3usize => Some(Field::new(
"array_records_count",
self.array_records_count(),
)),
4usize => Some(Field::new(
"array_records",
traversal::FieldType::computed_array(
"ContainsArrays",
self.array_records(),
self.offset_data(),
),
)),
_ => None,
}
}
}
#[cfg(feature = "traversal")]
impl<'a> std::fmt::Debug for BasicTable<'a> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
(self as &dyn SomeTable<'a>).fmt(f)
}
}
#[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash, Copy, bytemuck :: AnyBitPattern)]
#[repr(C)]
#[repr(packed)]
pub struct SimpleRecord {
pub val1: BigEndian<u16>,
pub va2: BigEndian<u32>,
}
impl SimpleRecord {
pub fn val1(&self) -> u16 {
self.val1.get()
}
pub fn va2(&self) -> u32 {
self.va2.get()
}
}
impl FixedSize for SimpleRecord {
const RAW_BYTE_LEN: usize = u16::RAW_BYTE_LEN + u32::RAW_BYTE_LEN;
}
#[cfg(feature = "traversal")]
impl<'a> SomeRecord<'a> for SimpleRecord {
fn traverse(self, data: FontData<'a>) -> RecordResolver<'a> {
RecordResolver {
name: "SimpleRecord",
get_field: Box::new(move |idx, _data| match idx {
0usize => Some(Field::new("val1", self.val1())),
1usize => Some(Field::new("va2", self.va2())),
_ => None,
}),
data,
}
}
}
#[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash)]
pub struct ContainsArrays<'a> {
pub scalars: &'a [BigEndian<u16>],
pub records: &'a [SimpleRecord],
}
impl<'a> ContainsArrays<'a> {
pub fn scalars(&self) -> &'a [BigEndian<u16>] {
self.scalars
}
pub fn records(&self) -> &'a [SimpleRecord] {
self.records
}
}
impl ReadArgs for ContainsArrays<'_> {
type Args = u16;
}
impl ComputeSize for ContainsArrays<'_> {
#[allow(clippy::needless_question_mark)]
fn compute_size(args: &u16) -> Result<usize, ReadError> {
let array_len = *args;
let mut result = 0usize;
result = result
.checked_add(
(array_len as usize)
.checked_mul(u16::RAW_BYTE_LEN)
.ok_or(ReadError::OutOfBounds)?,
)
.ok_or(ReadError::OutOfBounds)?;
result = result
.checked_add(
(array_len as usize)
.checked_mul(SimpleRecord::RAW_BYTE_LEN)
.ok_or(ReadError::OutOfBounds)?,
)
.ok_or(ReadError::OutOfBounds)?;
Ok(result)
}
}
impl<'a> FontReadWithArgs<'a> for ContainsArrays<'a> {
fn read_with_args(data: FontData<'a>, args: &u16) -> Result<Self, ReadError> {
let mut cursor = data.cursor();
let array_len = *args;
Ok(Self {
scalars: cursor.read_array(array_len as usize)?,
records: cursor.read_array(array_len as usize)?,
})
}
}
impl<'a> ContainsArrays<'a> {
/// A constructor that requires additional arguments.
///
/// This type requires some external state in order to be
/// parsed.
pub fn read(data: FontData<'a>, array_len: u16) -> Result<Self, ReadError> {
let args = array_len;
Self::read_with_args(data, &args)
}
}
#[cfg(feature = "traversal")]
impl<'a> SomeRecord<'a> for ContainsArrays<'a> {
fn traverse(self, data: FontData<'a>) -> RecordResolver<'a> {
RecordResolver {
name: "ContainsArrays",
get_field: Box::new(move |idx, _data| match idx {
0usize => Some(Field::new("scalars", self.scalars())),
1usize => Some(Field::new(
"records",
traversal::FieldType::array_of_records(
stringify!(SimpleRecord),
self.records(),
_data,
),
)),
_ => None,
}),
data,
}
}
}
#[derive(Clone, Debug, Copy, bytemuck :: AnyBitPattern)]
#[repr(C)]
#[repr(packed)]
pub struct ContainsOffsets {
pub off_array_count: BigEndian<u16>,
pub array_offset: BigEndian<Offset16>,
pub other_offset: BigEndian<Offset32>,
}
impl ContainsOffsets {
pub fn off_array_count(&self) -> u16 {
self.off_array_count.get()
}
pub fn array_offset(&self) -> Offset16 {
self.array_offset.get()
}
///
/// The `data` argument should be retrieved from the parent table
/// By calling its `offset_data` method.
pub fn array<'a>(&self, data: FontData<'a>) -> Result<&'a [SimpleRecord], ReadError> {
let args = self.off_array_count();
self.array_offset().resolve_with_args(data, &args)
}
pub fn other_offset(&self) -> Offset32 {
self.other_offset.get()
}
///
/// The `data` argument should be retrieved from the parent table
/// By calling its `offset_data` method.
pub fn other<'a>(&self, data: FontData<'a>) -> Result<BasicTable<'a>, ReadError> {
self.other_offset().resolve(data)
}
}
impl FixedSize for ContainsOffsets {
const RAW_BYTE_LEN: usize = u16::RAW_BYTE_LEN + Offset16::RAW_BYTE_LEN + Offset32::RAW_BYTE_LEN;
}
#[cfg(feature = "traversal")]
impl<'a> SomeRecord<'a> for ContainsOffsets {
fn traverse(self, data: FontData<'a>) -> RecordResolver<'a> {
RecordResolver {
name: "ContainsOffsets",
get_field: Box::new(move |idx, _data| match idx {
0usize => Some(Field::new("off_array_count", self.off_array_count())),
1usize => Some(Field::new(
"array_offset",
traversal::FieldType::offset_to_array_of_records(
self.array_offset(),
self.array(_data),
stringify!(SimpleRecord),
_data,
),
)),
2usize => Some(Field::new(
"other_offset",
FieldType::offset(self.other_offset(), self.other(_data)),
)),
_ => None,
}),
data,
}
}
}