forked from parcel-bundler/lightningcss
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtraits.rs
More file actions
115 lines (99 loc) · 3.53 KB
/
traits.rs
File metadata and controls
115 lines (99 loc) · 3.53 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
//! Traits for parsing and serializing CSS.
use crate::context::PropertyHandlerContext;
use crate::declaration::{DeclarationBlock, DeclarationList};
use crate::error::{ParserError, PrinterError};
use crate::printer::Printer;
use crate::properties::{Property, PropertyId};
use crate::stylesheet::{ParserOptions, PrinterOptions};
use crate::targets::Browsers;
use crate::vendor_prefix::VendorPrefix;
use cssparser::*;
/// Trait for things that can be parsed from CSS syntax.
pub trait Parse<'i>: Sized {
/// Parse a value of this type using an existing parser.
fn parse<'t>(input: &mut Parser<'i, 't>) -> Result<Self, ParseError<'i, ParserError<'i>>>;
/// Parse a value from a string.
///
/// (This is a convenience wrapper for `parse` and probably should not be overridden.)
fn parse_string(input: &'i str) -> Result<Self, ParseError<'i, ParserError<'i>>> {
let mut input = ParserInput::new(input);
let mut parser = Parser::new(&mut input);
let result = Self::parse(&mut parser)?;
parser.expect_exhausted()?;
Ok(result)
}
}
pub(crate) trait ParseWithOptions<'i>: Sized {
fn parse_with_options<'t>(
input: &mut Parser<'i, 't>,
options: &ParserOptions,
) -> Result<Self, ParseError<'i, ParserError<'i>>>;
}
impl<'i, T: Parse<'i>> ParseWithOptions<'i> for T {
#[inline]
fn parse_with_options<'t>(
input: &mut Parser<'i, 't>,
_options: &ParserOptions,
) -> Result<Self, ParseError<'i, ParserError<'i>>> {
T::parse(input)
}
}
/// Trait for things the can serialize themselves in CSS syntax.
pub trait ToCss {
/// Serialize `self` in CSS syntax, writing to `dest`.
fn to_css<W>(&self, dest: &mut Printer<W>) -> Result<(), PrinterError>
where
W: std::fmt::Write;
/// Serialize `self` in CSS syntax and return a string.
///
/// (This is a convenience wrapper for `to_css` and probably should not be overridden.)
#[inline]
fn to_css_string(&self, options: PrinterOptions) -> Result<String, PrinterError> {
let mut s = String::new();
let mut printer = Printer::new(&mut s, options);
self.to_css(&mut printer)?;
Ok(s)
}
}
impl<'a, T> ToCss for &'a T
where
T: ToCss + ?Sized,
{
fn to_css<W>(&self, dest: &mut Printer<W>) -> Result<(), PrinterError>
where
W: std::fmt::Write,
{
(*self).to_css(dest)
}
}
pub(crate) trait PropertyHandler<'i>: Sized {
fn handle_property(
&mut self,
property: &Property<'i>,
dest: &mut DeclarationList<'i>,
context: &mut PropertyHandlerContext<'i, '_>,
) -> bool;
fn finalize(&mut self, dest: &mut DeclarationList<'i>, context: &mut PropertyHandlerContext<'i, '_>);
}
pub(crate) mod private {
pub trait TryAdd<T> {
fn try_add(&self, other: &T) -> Option<T>;
}
}
pub(crate) trait FromStandard<T>: Sized {
fn from_standard(val: &T) -> Option<Self>;
}
pub(crate) trait FallbackValues: Sized {
fn get_fallbacks(&mut self, targets: Browsers) -> Vec<Self>;
}
/// Trait for shorthand properties.
pub(crate) trait Shorthand<'i>: Sized {
/// Returns a shorthand from the longhand properties defined in the given declaration block.
fn from_longhands(decls: &DeclarationBlock<'i>, vendor_prefix: VendorPrefix) -> Option<(Self, bool)>;
/// Returns a list of longhand property ids for this shorthand.
fn longhands(vendor_prefix: VendorPrefix) -> Vec<PropertyId<'static>>;
/// Returns a longhand property for this shorthand.
fn longhand(&self, property_id: &PropertyId) -> Option<Property<'i>>;
/// Updates this shorthand from a longhand property.
fn set_longhand(&mut self, property: &Property<'i>) -> Result<(), ()>;
}