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
use crate::error::*;
use crate::ordinal::{Ordinal, OrdinalSet};
use crate::time_unit::TimeUnitField;
use std::borrow::Cow;
#[derive(Clone, Debug, Eq)]
pub struct Months {
ordinals: Option<OrdinalSet>,
}
impl TimeUnitField for Months {
fn from_optional_ordinal_set(ordinal_set: Option<OrdinalSet>) -> Self {
Months {
ordinals: ordinal_set,
}
}
fn name() -> Cow<'static, str> {
Cow::from("Months")
}
fn inclusive_min() -> Ordinal {
1
}
fn inclusive_max() -> Ordinal {
12
}
fn ordinal_from_name(name: &str) -> Result<Ordinal, Error> {
let ordinal = match name.to_lowercase().as_ref() {
"jan" | "january" => 1,
"feb" | "february" => 2,
"mar" | "march" => 3,
"apr" | "april" => 4,
"may" => 5,
"jun" | "june" => 6,
"jul" | "july" => 7,
"aug" | "august" => 8,
"sep" | "september" => 9,
"oct" | "october" => 10,
"nov" | "november" => 11,
"dec" | "december" => 12,
_ => {
return Err(
ErrorKind::Expression(format!("'{}' is not a valid month name.", name)).into(),
)
}
};
Ok(ordinal)
}
fn ordinals(&self) -> OrdinalSet {
match self.ordinals.clone() {
Some(ordinal_set) => ordinal_set,
None => Months::supported_ordinals(),
}
}
}
impl PartialEq for Months {
fn eq(&self, other: &Months) -> bool {
self.ordinals() == other.ordinals()
}
}