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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
use super::*;
impl TailwindAspect {
pub fn parse(kind: &[&str]) -> Result<Self> {
let name = match kind {
[name] => *name,
_ => return syntax_error!("unknown aspect-ratio elements"),
};
let out = match name {
"auto" => Self { kind: "auto", ratio: "auto" },
"square" => Self { kind: "square", ratio: "1/1" },
"video" => Self { kind: "video", ratio: "16/9" },
_ => return syntax_error!("unknown aspect-ratio elements"),
};
Ok(out)
}
}
impl TailwindColumns {
pub fn parse(kind: &[&str]) -> Result<Self> {
let name = match kind {
[name] => *name,
_ => return syntax_error!("unknown column elements"),
};
let out = match name {
"auto" => Self::Auto,
"3xs" => Self::Size(16),
"2xs" => Self::Size(18),
"xs" => Self::Size(20),
"sm" => Self::Size(24),
"md" => Self::Size(28),
"lg" => Self::Size(32),
"xl" => Self::Size(36),
"2xl" => Self::Size(42),
"3xl" => Self::Size(48),
"4xl" => Self::Size(56),
"5xl" => Self::Size(64),
"6xl" => Self::Size(72),
"7xl" => Self::Size(80),
_ => Self::Columns(parse_integer(name)?.1),
};
Ok(out)
}
}
impl TailwindBreak {
pub fn parse_before(kind: &[&str]) -> Result<Self> {
let out = match kind {
["auto"] => Self::Before("auto"),
["avoid"] => Self::Before("avoid"),
["all"] => Self::Before("all"),
["avoid", "page"] => Self::Before("avoid-page"),
["page"] => Self::Before("page"),
["left"] => Self::Before("left"),
["right"] => Self::Before("right"),
["column"] => Self::Before("column"),
_ => return syntax_error!("unknown break before elements"),
};
Ok(out)
}
pub fn parse_after(kind: &[&str]) -> Result<Self> {
let out = match kind {
["auto"] => Self::After("auto"),
["avoid"] => Self::After("avoid"),
["all"] => Self::After("all"),
["avoid", "page"] => Self::After("avoid-page"),
["page"] => Self::After("page"),
["left"] => Self::After("left"),
["right"] => Self::After("right"),
["column"] => Self::After("column"),
_ => return syntax_error!("unknown break after elements"),
};
Ok(out)
}
pub fn parse_inside(kind: &[&str]) -> Result<Self> {
let out = match kind {
["auto"] => Self::Inside("auto"),
["avoid"] => Self::Inside("avoid"),
["avoid", "page"] => Self::Inside("avoid-page"),
["avoid", "column"] => Self::Inside("avoid-column"),
_ => return syntax_error!("unknown break inside elements"),
};
Ok(out)
}
}
impl TailWindZIndex {
pub fn parse(kind: &[&str], neg: bool) -> Box<dyn TailwindInstance> {
match kind.len() {
1 => {}
r => panic!("break-inside expected 1 element but found {} elements", r),
}
let instance = match kind {
["auto"] => Self::Auto,
[r] => Self::parse_number(r, neg).expect("not number"),
_ => {
panic!("Unknown aspect-ratio pattern")
}
};
Box::new(instance)
}
#[inline]
fn parse_number(input: &str, neg: bool) -> Result<Self> {
let n = parse_integer(input)?.1;
match neg {
true => Ok(Self::Negative(n)),
false => Ok(Self::Positive(n)),
}
}
}
impl TailwindClear {
#[inline]
pub fn parse(kind: &[&str]) -> Result<Self> {
let out = match kind {
["left"] => Self::Left,
["right"] => Self::Right,
["both"] => Self::Both,
["none"] => Self::None,
_ => return syntax_error!("unknown clear elements"),
};
Ok(out)
}
}