Skip to main content

Theme

Struct Theme 

Source
pub struct Theme {
    pub meta: ThemeMeta,
    /* private fields */
}
Expand description

A fully resolved theme ready for use.

Contains resolved palette colors, semantic tokens, composed styles, and gradients. Access colors by token name with color(), styles by name with style(), and gradients with gradient().

Fields§

§meta: ThemeMeta

Implementations§

Source§

impl Theme

Source

pub fn from_resolved(meta: ThemeMeta, resolved: ResolvedTheme) -> Self

Construct a Theme from pre-resolved data.

For most use cases, prefer load_from_str or load_from_file. Use this when you have already run the resolution pipeline yourself.

Source

pub fn builder(name: impl Into<String>) -> ThemeBuilder

Start building a theme programmatically.

See ThemeBuilder for the full builder API.

Source

pub fn color(&self, token: &str) -> OpalineColor

Look up a color by token name, falling back to palette, then FALLBACK.

Source

pub fn try_color(&self, token: &str) -> Option<OpalineColor>

Strict color lookup — returns None if the token doesn’t exist.

Source

pub fn has_token(&self, name: &str) -> bool

Check whether a token or palette name exists.

Source

pub fn token_names(&self) -> Vec<&str>

All token names defined in this theme.

Source

pub fn palette_names(&self) -> Vec<&str>

All palette color names defined in this theme.

Source

pub fn style(&self, name: &str) -> OpalineStyle

Look up a style by name, returning Default if missing.

Source

pub fn try_style(&self, name: &str) -> Option<&OpalineStyle>

Strict style lookup — returns None if the style doesn’t exist.

Source

pub fn has_style(&self, name: &str) -> bool

Check whether a named style exists.

Source

pub fn style_names(&self) -> Vec<&str>

All style names defined in this theme.

Source

pub fn gradient(&self, name: &str, t: f32) -> OpalineColor

Sample a named gradient at position t. Returns FALLBACK if the gradient doesn’t exist or the feature is disabled.

Source

pub fn try_gradient(&self, name: &str, t: f32) -> Option<OpalineColor>

Strict gradient sampling — returns None if the gradient doesn’t exist.

Source

pub fn get_gradient(&self, name: &str) -> Option<&Gradient>

Get a reference to a named gradient for manual sampling.

Source

pub fn has_gradient(&self, name: &str) -> bool

Check whether a named gradient exists.

Source

pub fn gradient_names(&self) -> Vec<&str>

All gradient names defined in this theme.

Source

pub fn is_dark(&self) -> bool

Whether this is a dark theme.

Source

pub fn is_light(&self) -> bool

Whether this is a light theme.

Source

pub fn register_default_token( &mut self, name: impl Into<String>, color: OpalineColor, )

Register a token only if the theme doesn’t already define it.

Use this for app-level derived tokens — TOML-defined values take priority so theme authors can override derivations.

Source

pub fn register_token(&mut self, name: impl Into<String>, color: OpalineColor)

Register a token, overwriting any existing value.

Source

pub fn register_default_style( &mut self, name: impl Into<String>, style: OpalineStyle, )

Register a style only if the theme doesn’t already define it.

Source

pub fn register_style(&mut self, name: impl Into<String>, style: OpalineStyle)

Register a style, overwriting any existing value.

Source§

impl Theme

Source

pub fn span<'a>( &self, style_name: &str, content: impl Into<Cow<'a, str>>, ) -> Span<'a>

Create a styled Span from a named style.

Source

pub fn line<'a>( &self, style_name: &str, content: impl Into<Cow<'a, str>>, ) -> Line<'a>

Create a styled Line from a named style.

Source

pub fn text<'a>( &self, style_name: &str, content: impl Into<Cow<'a, str>>, ) -> Text<'a>

Create a styled Text from a named style.

Source

pub fn gradient_text(&self, gradient_name: &str, content: &str) -> Line<'static>

Create a Line with per-character gradient coloring.

Trait Implementations§

Source§

impl Clone for Theme

Source§

fn clone(&self) -> Theme

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 Debug for Theme

Source§

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

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

impl Default for Theme

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl ThemeCliExt for Theme

Source§

fn cli_rgb(&self, token: &str) -> (u8, u8, u8)

Get a token color as an RGB tuple for use with .truecolor().
Source§

fn cli_colored(&self, text: &str, token: &str) -> ColoredString

Apply a token color as foreground on text.
Source§

fn cli_gradient(&self, text: &str, gradient_name: &str) -> String

Apply a named gradient across a string, returning ANSI-escaped output.

Auto Trait Implementations§

§

impl Freeze for Theme

§

impl RefUnwindSafe for Theme

§

impl Send for Theme

§

impl Sync for Theme

§

impl Unpin for Theme

§

impl UnsafeUnpin for Theme

§

impl UnwindSafe for Theme

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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
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.