Skip to main content

Expression

Enum Expression 

Source
pub enum Expression {
    Literal(Length),
    Percentage(Percentage),
    Add(Box<Expression>, Box<Expression>),
    Sub(Box<Expression>, Box<Expression>),
    Mul(Box<Expression>, f64),
    Div(Box<Expression>, f64),
}
Expand description

Mathematical expression for CSS calc() values

Supports:

  • Literals (absolute lengths)
  • Percentages (relative to base value)
  • Binary operations: +, -, *, /
  • Nested expressions

§Examples

use fop_types::{Expression, Length, Percentage, expression::EvalContext};

// Parse calc(100% - 20pt)
let expr = Expression::parse("calc(100% - 20pt)").unwrap();

// Evaluate with context
let ctx = EvalContext {
    base_width: Some(Length::from_pt(200.0)),
    base_height: None,
    font_size: Length::from_pt(12.0),
};
let result = expr.evaluate(&ctx).unwrap();
assert_eq!(result, Length::from_pt(180.0));

Variants§

§

Literal(Length)

A literal length value

§

Percentage(Percentage)

A percentage value (needs base to resolve)

§

Add(Box<Expression>, Box<Expression>)

Addition of two expressions

§

Sub(Box<Expression>, Box<Expression>)

Subtraction of two expressions

§

Mul(Box<Expression>, f64)

Multiplication of expression by scalar

§

Div(Box<Expression>, f64)

Division of expression by scalar

Implementations§

Source§

impl Expression

Source

pub fn parse(input: &str) -> Result<Self>

Parse a calc() expression from a string

§Examples
use fop_types::Expression;

let expr = Expression::parse("calc(100% - 20pt)").unwrap();
let expr2 = Expression::parse("calc(50% + 10mm)").unwrap();
let expr3 = Expression::parse("calc((100% - 40pt) / 2)").unwrap();
Source

pub fn evaluate(&self, context: &EvalContext) -> Result<Length>

Evaluate the expression to a concrete length

§Examples
use fop_types::{Expression, Length, expression::EvalContext};

let expr = Expression::parse("calc(100% - 20pt)").unwrap();
let ctx = EvalContext::with_width(Length::from_pt(200.0), Length::from_pt(12.0));
let result = expr.evaluate(&ctx).unwrap();
assert_eq!(result, Length::from_pt(180.0));

Trait Implementations§

Source§

impl Clone for Expression

Source§

fn clone(&self) -> Expression

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 Expression

Source§

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

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

impl Display for Expression

Source§

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

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

impl PartialEq for Expression

Source§

fn eq(&self, other: &Expression) -> 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 StructuralPartialEq for Expression

Auto Trait Implementations§

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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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.