Struct ScriptInfo

Source
pub struct ScriptInfo<'a> {
    pub fields: Vec<(&'a str, &'a str)>,
    pub span: Span,
}
Expand description

Script Info section containing metadata and headers

Represents the [Script Info] section of an ASS file as key-value pairs with zero-copy string references. Provides convenient accessor methods for standard ASS metadata fields.

§Examples

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

let fields = vec![("Title", "Test Script"), ("ScriptType", "v4.00+")];
let info = ScriptInfo { fields, span: Span::new(0, 0, 0, 0) };

assert_eq!(info.title(), "Test Script");
assert_eq!(info.script_type(), Some("v4.00+"));

Fields§

§fields: Vec<(&'a str, &'a str)>

Key-value pairs as zero-copy spans

§span: Span

Span in source text where this script info section is defined

Implementations§

Source§

impl<'a> ScriptInfo<'a>

Source

pub fn get_field(&self, key: &str) -> Option<&'a str>

Get field value by key (case-sensitive)

Searches for the specified key in the script info fields and returns the associated value if found.

§Arguments
  • key - Field name to search for
§Returns

The field value if found, None otherwise

§Examples
let fields = vec![("Title", "Test"), ("Author", "User")];
let info = ScriptInfo { fields, span: Span::new(0, 0, 0, 0) };

assert_eq!(info.get_field("Title"), Some("Test"));
assert_eq!(info.get_field("Unknown"), None);
Source

pub fn title(&self) -> &str

Get script title, defaulting to <untitled>

Returns the “Title” field value or a default if not specified. This is a convenience method for the most commonly accessed field.

Source

pub fn script_type(&self) -> Option<&'a str>

Get script type version

Returns the “ScriptType” field which indicates the ASS version and feature compatibility (e.g., “v4.00+”, “v4.00”).

Source

pub fn play_resolution(&self) -> Option<(u32, u32)>

Get play resolution as (width, height)

Parses PlayResX and PlayResY fields to determine the intended video resolution for subtitle rendering.

§Returns

Tuple of (width, height) if both fields are present and valid, None if either field is missing or invalid.

Source

pub fn layout_resolution(&self) -> Option<(u32, u32)>

Get layout resolution as (width, height)

Layout resolution defines the coordinate system for positioning and scaling subtitles relative to the video resolution. Used by style analysis for proper layout calculations.

§Returns

Tuple of (width, height) if both fields are present and valid, None if either field is missing or invalid.

Source

pub fn wrap_style(&self) -> u8

Get wrap style setting

Returns the WrapStyle field which controls how long lines are wrapped. Defaults to 0 (smart wrapping) if not specified.

§Wrap Styles
  • 0: Smart wrapping (default)
  • 1: End-of-line wrapping
  • 2: No wrapping
  • 3: Smart wrapping with lower line longer
Source

pub fn to_ass_string(&self) -> String

Convert script info to ASS string representation

Generates the [Script Info] section with all fields.

§Examples
let fields = vec![("Title", "Test Script"), ("ScriptType", "v4.00+")];
let info = ScriptInfo { fields, span: Span::new(0, 0, 0, 0) };
let ass_string = info.to_ass_string();
assert!(ass_string.contains("[Script Info]"));
assert!(ass_string.contains("Title: Test Script"));
assert!(ass_string.contains("ScriptType: v4.00+"));
Source

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

Validate all spans in this ScriptInfo reference valid source

Debug helper to ensure zero-copy invariants are maintained. Validates that all string 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 ScriptInfo<'a>

Source§

fn clone(&self) -> ScriptInfo<'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 ScriptInfo<'a>

Source§

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

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

impl<'a> PartialEq for ScriptInfo<'a>

Source§

fn eq(&self, other: &ScriptInfo<'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 ScriptInfo<'a>

Source§

impl<'a> StructuralPartialEq for ScriptInfo<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for ScriptInfo<'a>

§

impl<'a> RefUnwindSafe for ScriptInfo<'a>

§

impl<'a> Send for ScriptInfo<'a>

§

impl<'a> Sync for ScriptInfo<'a>

§

impl<'a> Unpin for ScriptInfo<'a>

§

impl<'a> UnwindSafe for ScriptInfo<'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.