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
// This file is part of ICU4X. For terms of use, please see the file
// called LICENSE at the top level of the ICU4X source tree
// (online at: https://github.com/unicode-org/icu4x/blob/main/LICENSE ).

//! Experimental.

//! Options for [`UnitsFormatter`](crate::dimension::units::formatter::UnitsFormatter).

/// A collection of configuration options that determine the formatting behavior of
/// [`UnitsFormatter`](crate::dimension::units::formatter::UnitsFormatter).
#[derive(Copy, Debug, Eq, PartialEq, Clone, Default)]
#[non_exhaustive]
pub struct UnitsFormatterOptions {
    /// The width of the units format.
    pub width: Width,
}

impl From<Width> for UnitsFormatterOptions {
    fn from(width: Width) -> Self {
        Self { width }
    }
}

#[derive(Debug, Eq, PartialEq, Clone, Copy, Default)]
#[non_exhaustive]
pub enum Width {
    /// Format the units with the long units format.
    ///
    /// For example, 1 hour formats as "1 hour" in en-US.
    Long,

    /// Format the units with the short units format.
    ///
    /// For example, 1 hour formats as "1 hr" in en-US.
    #[default]
    Short,

    /// Format the units with the narrow units format.
    ///
    /// The narrow symbol may be ambiguous, so it should be evident from context which
    /// units is being represented.
    ///
    /// For example, 1 hour formats as "1 h" in most locales.
    Narrow,
}

impl From<Width> for tinystr::TinyStr8 {
    fn from(width: Width) -> Self {
        match width {
            Width::Long => "long".parse().unwrap(),
            Width::Short => "short".parse().unwrap(),
            Width::Narrow => "narrow".parse().unwrap(),
        }
    }
}