#[allow(unused_imports)]
use crate::codegen_prelude::*;
#[derive(Clone, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct Cff2Header {
pub header_size: u8,
pub top_dict_length: u16,
pub _padding: Vec<u8>,
pub top_dict_data: Vec<u8>,
pub trailing_data: Vec<u8>,
}
impl Cff2Header {
pub fn new(
header_size: u8,
top_dict_length: u16,
_padding: Vec<u8>,
top_dict_data: Vec<u8>,
trailing_data: Vec<u8>,
) -> Self {
Self {
header_size,
top_dict_length,
_padding,
top_dict_data,
trailing_data,
}
}
}
impl FontWrite for Cff2Header {
#[allow(clippy::unnecessary_cast)]
fn write_into(&self, writer: &mut TableWriter) {
(2 as u8).write_into(writer);
(0 as u8).write_into(writer);
self.header_size.write_into(writer);
self.top_dict_length.write_into(writer);
self._padding.write_into(writer);
self.top_dict_data.write_into(writer);
self.trailing_data.write_into(writer);
}
fn table_type(&self) -> TableType {
TableType::Named("Cff2Header")
}
}
impl Validate for Cff2Header {
fn validate_impl(&self, ctx: &mut ValidationCtx) {
ctx.in_table("Cff2Header", |ctx| {
ctx.in_field("top_dict_data", |ctx| {
if self.top_dict_data.len() > (u16::MAX as usize) {
ctx.report("array exceeds max length");
}
});
})
}
}
impl<'a> FromObjRef<read_fonts::ps::cff::v2::Cff2Header<'a>> for Cff2Header {
fn from_obj_ref(obj: &read_fonts::ps::cff::v2::Cff2Header<'a>, _: FontData) -> Self {
let offset_data = obj.offset_data();
Cff2Header {
header_size: obj.header_size(),
top_dict_length: obj.top_dict_length(),
_padding: obj._padding().to_owned_obj(offset_data),
top_dict_data: obj.top_dict_data().to_owned_obj(offset_data),
trailing_data: obj.trailing_data().to_owned_obj(offset_data),
}
}
}
#[allow(clippy::needless_lifetimes)]
impl<'a> FromTableRef<read_fonts::ps::cff::v2::Cff2Header<'a>> for Cff2Header {}
impl<'a> FontRead<'a> for Cff2Header {
fn read(data: FontData<'a>) -> Result<Self, ReadError> {
<read_fonts::ps::cff::v2::Cff2Header as FontRead>::read(data).map(|x| x.to_owned_table())
}
}
#[derive(Clone, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct Index {
pub count: u32,
pub off_size: u8,
pub offsets: Vec<u8>,
pub data: Vec<u8>,
}
impl Index {
pub fn new(count: u32, off_size: u8, offsets: Vec<u8>, data: Vec<u8>) -> Self {
Self {
count,
off_size,
offsets,
data,
}
}
}
impl FontWrite for Index {
fn write_into(&self, writer: &mut TableWriter) {
self.count.write_into(writer);
self.off_size.write_into(writer);
self.offsets.write_into(writer);
self.data.write_into(writer);
}
fn table_type(&self) -> TableType {
TableType::Named("Index")
}
}
impl Validate for Index {
fn validate_impl(&self, _ctx: &mut ValidationCtx) {}
}
impl<'a> FromObjRef<read_fonts::ps::cff::v2::Index<'a>> for Index {
fn from_obj_ref(obj: &read_fonts::ps::cff::v2::Index<'a>, _: FontData) -> Self {
let offset_data = obj.offset_data();
Index {
count: obj.count(),
off_size: obj.off_size(),
offsets: obj.offsets().to_owned_obj(offset_data),
data: obj.data().to_owned_obj(offset_data),
}
}
}
#[allow(clippy::needless_lifetimes)]
impl<'a> FromTableRef<read_fonts::ps::cff::v2::Index<'a>> for Index {}
impl<'a> FontRead<'a> for Index {
fn read(data: FontData<'a>) -> Result<Self, ReadError> {
<read_fonts::ps::cff::v2::Index as FontRead>::read(data).map(|x| x.to_owned_table())
}
}