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
use super::*;
use log::error;
use std::collections::BTreeSet;
impl Display for TailwindInstruction {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
for v in &self.variants {
write!(f, "{}", v)?
}
if self.negative {
write!(f, "-")?
}
write!(f, "{}{}", self.elements, self.arbitrary)
}
}
impl TailwindInstance for TailwindInstruction {
fn attributes(&self, ctx: &TailwindBuilder) -> BTreeSet<CssAttribute> {
let mut out = BTreeSet::default();
match self.get_instance() {
Ok(o) => out.extend(o.attributes(ctx)),
Err(e) => {
#[cfg(debug_assertions)]
error!("{:?}", e)
},
}
out
}
}
impl Display for TailwindVariant {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
if self.not {
write!(f, "not-")?
}
write!(f, "{}", self.names.join("-"))?;
match self.pseudo {
true => {
write!(f, "::")
},
false => {
write!(f, ":")
},
}
}
}
impl Display for TailwindElements {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
write!(f, "{}", self.inner.join("-"))
}
}
impl Display for TailwindArbitrary {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
match self.inner.is_empty() {
true => {
write!(f, "")
},
false => {
write!(f, "-[{}]", self.inner)
},
}
}
}