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
use super::*;
#[doc = include_str!("readme.md")]
#[derive(Copy, Debug, Clone)]
pub struct TailwindTracking {
kind: Tracking,
}
#[derive(Copy, Debug, Clone)]
enum Tracking {
Normal,
Length(LengthUnit),
Global(CssBehavior),
}
impl Display for Tracking {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
match self {
Self::Normal => write!(f, "normal"),
Self::Global(g) => write!(f, "{}", g),
Self::Length(l) => write!(f, "[{}]", l),
}
}
}
impl Display for TailwindTracking {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
write!(f, "tracking-{}", self.kind)
}
}
impl TailwindInstance for TailwindTracking {
fn attributes(&self, _: &TailwindBuilder) -> BTreeSet<CssAttribute> {
let spacing = match self.kind {
Tracking::Length(n) => n.get_properties(),
_ => self.kind.to_string(),
};
css_attributes! {
"letter-spacing" => spacing
}
}
}
impl TailwindTracking {
pub const Normal: Self = Self { kind: Tracking::Normal };
pub const Inherit: Self = Self { kind: Tracking::Global(CssBehavior::Inherit) };
pub const Initial: Self = Self { kind: Tracking::Global(CssBehavior::Initial) };
pub const Unset: Self = Self { kind: Tracking::Global(CssBehavior::Unset) };
pub fn parse(input: &[&str], arbitrary: &TailwindArbitrary) -> Result<Self> {
debug_assert!(arbitrary.is_none(), "forbidden arbitrary after tracking");
match input {
["tighter"] => em(-0.05),
["tight"] => em(-0.025),
["none"] => em(0.0),
["wide"] => em(0.025),
["wider" | "relaxed"] => em(0.05),
["widest" | "loose"] => em(0.1),
["normal"] => Ok(Self::Normal),
["inherit"] => Ok(Self::Inherit),
["initial"] => Ok(Self::Initial),
["unset"] => Ok(Self::Unset),
[] => Self::parse_arbitrary(arbitrary),
[n] => Self::parse_arbitrary(&TailwindArbitrary::from(*n)),
_ => syntax_error!("Unknown tracking instructions: {}", input.join("-")),
}
}
pub fn parse_arbitrary(arbitrary: &TailwindArbitrary) -> Result<Self> {
Ok(Self { kind: Tracking::Length(arbitrary.as_length()?) })
}
}
#[inline(always)]
fn em(n: f32) -> Result<TailwindTracking> {
Ok(TailwindTracking { kind: Tracking::Length(LengthUnit::em(n)) })
}