css_ast/types/
opacity_value.rs1use super::prelude::*;
2use crate::{Percentage, Ranged};
3
4#[derive(IntoCursor, Peek, Parse, ToCursors, Debug, Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
5#[cfg_attr(feature = "serde", derive(serde::Serialize))]
6#[cfg_attr(feature = "visitable", derive(csskit_derives::Visitable), visit(self))]
7#[derive(csskit_derives::NodeWithMetadata)]
8pub enum OpacityValue {
9 Number(Ranged<T![Number], 0, 1>),
10 Percent(Ranged<Percentage, 0, 100>),
11}
12
13impl OpacityValue {
14 #[allow(non_upper_case_globals)]
15 pub const Zero: OpacityValue = OpacityValue::Number(Ranged(<T![Number]>::NUMBER_ZERO));
16}
17
18impl From<OpacityValue> for i32 {
19 fn from(value: OpacityValue) -> Self {
20 match value {
21 OpacityValue::Number(t) => t.0.into(),
22 OpacityValue::Percent(t) => {
23 let f: f32 = t.0.into();
24 f as i32
25 }
26 }
27 }
28}
29
30impl From<OpacityValue> for f32 {
31 fn from(value: OpacityValue) -> Self {
32 match value {
33 OpacityValue::Number(t) => t.0.into(),
34 OpacityValue::Percent(t) => t.0.into(),
35 }
36 }
37}
38
39#[cfg(test)]
40mod tests {
41 use super::*;
42 use crate::CssAtomSet;
43 use css_parse::{assert_parse, assert_parse_error};
44
45 #[test]
46 fn size_test() {
47 assert_eq!(std::mem::size_of::<OpacityValue>(), 16);
48 }
49
50 #[test]
51 fn test_writes() {
52 assert_parse!(CssAtomSet::ATOMS, OpacityValue, "0.1");
53 assert_parse!(CssAtomSet::ATOMS, OpacityValue, "1");
54 assert_parse!(CssAtomSet::ATOMS, OpacityValue, "50%");
55 }
56
57 #[test]
58 fn test_errors() {
59 assert_parse_error!(CssAtomSet::ATOMS, OpacityValue, "20");
60 assert_parse_error!(CssAtomSet::ATOMS, OpacityValue, "1000%");
61 }
62}