mirror of
https://github.com/nushell/nushell
synced 2025-01-20 09:04:21 +00:00
Cal command code cleanup (#1990)
* Cal command code cleanup * Reverting "index_map" back to "indexmap", since that is the convention used in the system
This commit is contained in:
parent
3d63901b3b
commit
1b6f94b46c
1 changed files with 34 additions and 74 deletions
|
@ -112,90 +112,48 @@ fn get_invalid_year_shell_error(year_tag: &Tag) -> ShellError {
|
||||||
}
|
}
|
||||||
|
|
||||||
struct MonthHelper {
|
struct MonthHelper {
|
||||||
day_number_month_starts_on: u32,
|
|
||||||
number_of_days_in_month: u32,
|
|
||||||
selected_year: i32,
|
selected_year: i32,
|
||||||
selected_month: u32,
|
selected_month: u32,
|
||||||
|
day_number_of_week_month_starts_on: u32,
|
||||||
|
number_of_days_in_month: u32,
|
||||||
|
quarter_number: u32,
|
||||||
|
month_name: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl MonthHelper {
|
impl MonthHelper {
|
||||||
pub fn new(selected_year: i32, selected_month: u32) -> Result<MonthHelper, ()> {
|
pub fn new(selected_year: i32, selected_month: u32) -> Result<MonthHelper, ()> {
|
||||||
let mut month_helper = MonthHelper {
|
let naive_date = NaiveDate::from_ymd_opt(selected_year, selected_month, 1).ok_or(())?;
|
||||||
day_number_month_starts_on: 0,
|
let number_of_days_in_month =
|
||||||
number_of_days_in_month: 0,
|
MonthHelper::calculate_number_of_days_in_month(selected_year, selected_month)?;
|
||||||
|
|
||||||
|
Ok(MonthHelper {
|
||||||
selected_year,
|
selected_year,
|
||||||
selected_month,
|
selected_month,
|
||||||
};
|
day_number_of_week_month_starts_on: naive_date.weekday().num_days_from_sunday(),
|
||||||
|
number_of_days_in_month,
|
||||||
let chosen_date_result_one = month_helper.update_day_number_month_starts_on();
|
quarter_number: ((selected_month - 1) / 3) + 1,
|
||||||
let chosen_date_result_two = month_helper.update_number_of_days_in_month();
|
month_name: naive_date.format("%B").to_string().to_ascii_lowercase(),
|
||||||
|
})
|
||||||
if chosen_date_result_one.is_ok() && chosen_date_result_two.is_ok() {
|
|
||||||
return Ok(month_helper);
|
|
||||||
}
|
|
||||||
|
|
||||||
Err(())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_month_name(&self) -> String {
|
fn calculate_number_of_days_in_month(
|
||||||
let month_name = match self.selected_month {
|
mut selected_year: i32,
|
||||||
1 => "january",
|
mut selected_month: u32,
|
||||||
2 => "february",
|
) -> Result<u32, ()> {
|
||||||
3 => "march",
|
|
||||||
4 => "april",
|
|
||||||
5 => "may",
|
|
||||||
6 => "june",
|
|
||||||
7 => "july",
|
|
||||||
8 => "august",
|
|
||||||
9 => "september",
|
|
||||||
10 => "october",
|
|
||||||
11 => "november",
|
|
||||||
_ => "december",
|
|
||||||
};
|
|
||||||
|
|
||||||
month_name.to_string()
|
|
||||||
}
|
|
||||||
|
|
||||||
fn update_day_number_month_starts_on(&mut self) -> Result<(), ()> {
|
|
||||||
let naive_date_result =
|
|
||||||
MonthHelper::get_naive_date(self.selected_year, self.selected_month);
|
|
||||||
|
|
||||||
match naive_date_result {
|
|
||||||
Ok(naive_date) => {
|
|
||||||
self.day_number_month_starts_on = naive_date.weekday().num_days_from_sunday();
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
_ => Err(()),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn update_number_of_days_in_month(&mut self) -> Result<(), ()> {
|
|
||||||
// Chrono does not provide a method to output the amount of days in a month
|
// Chrono does not provide a method to output the amount of days in a month
|
||||||
// This is a workaround taken from the example code from the Chrono docs here:
|
// This is a workaround taken from the example code from the Chrono docs here:
|
||||||
// https://docs.rs/chrono/0.3.0/chrono/naive/date/struct.NaiveDate.html#example-30
|
// https://docs.rs/chrono/0.3.0/chrono/naive/date/struct.NaiveDate.html#example-30
|
||||||
let (adjusted_year, adjusted_month) = if self.selected_month == 12 {
|
if selected_month == 12 {
|
||||||
(self.selected_year + 1, 1)
|
selected_year += 1;
|
||||||
|
selected_month = 1;
|
||||||
} else {
|
} else {
|
||||||
(self.selected_year, self.selected_month + 1)
|
selected_month += 1;
|
||||||
};
|
};
|
||||||
|
|
||||||
let naive_date_result = MonthHelper::get_naive_date(adjusted_year, adjusted_month);
|
let next_month_naive_date =
|
||||||
|
NaiveDate::from_ymd_opt(selected_year, selected_month, 1).ok_or(())?;
|
||||||
|
|
||||||
match naive_date_result {
|
Ok(next_month_naive_date.pred().day())
|
||||||
Ok(naive_date) => {
|
|
||||||
self.number_of_days_in_month = naive_date.pred().day();
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
_ => Err(()),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn get_naive_date(selected_year: i32, selected_month: u32) -> Result<NaiveDate, ()> {
|
|
||||||
if let Some(naive_date) = NaiveDate::from_ymd_opt(selected_year, selected_month, 1) {
|
|
||||||
return Ok(naive_date);
|
|
||||||
}
|
|
||||||
|
|
||||||
Err(())
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -268,7 +226,8 @@ fn add_month_to_table(
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
let day_limit = month_helper.number_of_days_in_month + month_helper.day_number_month_starts_on;
|
let day_limit =
|
||||||
|
month_helper.number_of_days_in_month + month_helper.day_number_of_week_month_starts_on;
|
||||||
let mut day_count: u32 = 1;
|
let mut day_count: u32 = 1;
|
||||||
|
|
||||||
let days_of_the_week = [
|
let days_of_the_week = [
|
||||||
|
@ -282,8 +241,8 @@ fn add_month_to_table(
|
||||||
];
|
];
|
||||||
|
|
||||||
let should_show_year_column = args.has("year");
|
let should_show_year_column = args.has("year");
|
||||||
let should_show_month_column = args.has("month");
|
|
||||||
let should_show_quarter_column = args.has("quarter");
|
let should_show_quarter_column = args.has("quarter");
|
||||||
|
let should_show_month_column = args.has("month");
|
||||||
let should_show_month_names = args.has("month-names");
|
let should_show_month_names = args.has("month-names");
|
||||||
|
|
||||||
while day_count <= day_limit {
|
while day_count <= day_limit {
|
||||||
|
@ -299,13 +258,13 @@ fn add_month_to_table(
|
||||||
if should_show_quarter_column {
|
if should_show_quarter_column {
|
||||||
indexmap.insert(
|
indexmap.insert(
|
||||||
"quarter".to_string(),
|
"quarter".to_string(),
|
||||||
UntaggedValue::int(((month_helper.selected_month - 1) / 3) + 1).into_value(tag),
|
UntaggedValue::int(month_helper.quarter_number).into_value(tag),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if should_show_month_column {
|
if should_show_month_column {
|
||||||
let month_value = if should_show_month_names {
|
let month_value = if should_show_month_names {
|
||||||
UntaggedValue::string(month_helper.get_month_name()).into_value(tag)
|
UntaggedValue::string(month_helper.month_name.clone()).into_value(tag)
|
||||||
} else {
|
} else {
|
||||||
UntaggedValue::int(month_helper.selected_month).into_value(tag)
|
UntaggedValue::int(month_helper.selected_month).into_value(tag)
|
||||||
};
|
};
|
||||||
|
@ -314,13 +273,14 @@ fn add_month_to_table(
|
||||||
}
|
}
|
||||||
|
|
||||||
for day in &days_of_the_week {
|
for day in &days_of_the_week {
|
||||||
let should_add_day_number_to_table =
|
let should_add_day_number_to_table = (day_count <= day_limit)
|
||||||
(day_count <= day_limit) && (day_count > month_helper.day_number_month_starts_on);
|
&& (day_count > month_helper.day_number_of_week_month_starts_on);
|
||||||
|
|
||||||
let mut value = UntaggedValue::nothing().into_value(tag);
|
let mut value = UntaggedValue::nothing().into_value(tag);
|
||||||
|
|
||||||
if should_add_day_number_to_table {
|
if should_add_day_number_to_table {
|
||||||
let day_count_with_offset = day_count - month_helper.day_number_month_starts_on;
|
let day_count_with_offset =
|
||||||
|
day_count - month_helper.day_number_of_week_month_starts_on;
|
||||||
|
|
||||||
value = UntaggedValue::int(day_count_with_offset).into_value(tag);
|
value = UntaggedValue::int(day_count_with_offset).into_value(tag);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue