Struct Font

Source
pub struct Font<'a> {
    pub filename: &'a str,
    pub data_lines: Vec<&'a str>,
    pub span: Span,
}
Expand description

Embedded font from [Fonts\] section

Represents a font file embedded in the ASS script using UU-encoding. Provides lazy decoding to avoid processing overhead unless the font data is actually needed.

§Examples

use ass_core::parser::ast::{Font, Span};

let font = Font {
    filename: "custom.ttf",
    data_lines: vec!["begin 644 custom.ttf", "M'XL..."],
    span: Span::new(0, 0, 0, 0),
};

// Decode when needed
let decoded = font.decode_data()?;

Fields§

§filename: &'a str

Font filename as it appears in the [Fonts\] section

§data_lines: Vec<&'a str>

UU-encoded font data lines as zero-copy spans

§span: Span

Span in source text where this font is defined

Implementations§

Source§

impl Font<'_>

Source

pub fn decode_data(&self) -> Result<Vec<u8>, CoreError>

Decode UU-encoded font data with lazy evaluation

Converts the UU-encoded data lines to raw binary font data. This is expensive so it’s only done when explicitly requested.

§Returns

Decoded binary font data on success, error if UU-decoding fails

§Errors

Returns an error if the UU-encoded data is malformed or cannot be decoded.

§Examples
match font.decode_data() {
    Ok(data) => println!("Font size: {} bytes", data.len()),
    Err(e) => eprintln!("Decode error: {}", e),
}
Source

pub fn to_ass_string(&self) -> String

Convert font to ASS string representation

Generates the font entry as it appears in the [Fonts\] section.

§Examples
let font = Font {
    filename: "custom.ttf",
    data_lines: vec!["begin 644 custom.ttf", "M'XL...", "end"],
    span: Span::new(0, 0, 0, 0),
};
let ass_string = font.to_ass_string();
assert!(ass_string.starts_with("fontname: custom.ttf\n"));
assert!(ass_string.contains("M'XL..."));
Source

pub fn validate_spans(&self, source_range: &Range<usize>) -> bool

Validate all spans in this Font reference valid source

Debug helper to ensure zero-copy invariants are maintained. Validates that filename and all data line references point to memory within the specified source range.

Only available in debug builds to avoid performance overhead.

Trait Implementations§

Source§

impl<'a> Clone for Font<'a>

Source§

fn clone(&self) -> Font<'a>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<'a> Debug for Font<'a>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a> PartialEq for Font<'a>

Source§

fn eq(&self, other: &Font<'a>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<'a> Eq for Font<'a>

Source§

impl<'a> StructuralPartialEq for Font<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for Font<'a>

§

impl<'a> RefUnwindSafe for Font<'a>

§

impl<'a> Send for Font<'a>

§

impl<'a> Sync for Font<'a>

§

impl<'a> Unpin for Font<'a>

§

impl<'a> UnwindSafe for Font<'a>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.