mirror of
https://github.com/nushell/nushell.git
synced 2025-05-01 08:34:26 +02:00
Came from [this discussion](https://discord.com/channels/601130461678272522/1348791953784836147/1349699872059691038) on discord with @fdncred # Description Small refactoring where I rename commands from "SubCommand" to its proper name. Motivations: better clarity (although subjective), better searchable, consistency. The only commands I didn't touch were "split list" and "ansi gradient" because of name clashes. # User-Facing Changes None # Tests + Formatting cargo fmt and clippy OK # After Submitting nothing required
56 lines
1.5 KiB
Rust
56 lines
1.5 KiB
Rust
use chrono_tz::TZ_VARIANTS;
|
|
use nu_engine::command_prelude::*;
|
|
|
|
#[derive(Clone)]
|
|
pub struct DateListTimezones;
|
|
|
|
impl Command for DateListTimezones {
|
|
fn name(&self) -> &str {
|
|
"date list-timezone"
|
|
}
|
|
|
|
fn signature(&self) -> Signature {
|
|
Signature::build("date list-timezone")
|
|
.input_output_types(vec![(Type::Nothing, Type::table())])
|
|
.category(Category::Date)
|
|
}
|
|
|
|
fn description(&self) -> &str {
|
|
"List supported time zones."
|
|
}
|
|
|
|
fn search_terms(&self) -> Vec<&str> {
|
|
vec!["UTC", "GMT", "tz"]
|
|
}
|
|
|
|
fn run(
|
|
&self,
|
|
engine_state: &EngineState,
|
|
_stack: &mut Stack,
|
|
call: &Call,
|
|
_input: PipelineData,
|
|
) -> Result<PipelineData, ShellError> {
|
|
let head = call.head;
|
|
|
|
Ok(TZ_VARIANTS
|
|
.iter()
|
|
.map(move |x| {
|
|
Value::record(
|
|
record! { "timezone" => Value::string(x.name(), head) },
|
|
head,
|
|
)
|
|
})
|
|
.into_pipeline_data(head, engine_state.signals().clone()))
|
|
}
|
|
|
|
fn examples(&self) -> Vec<Example> {
|
|
vec![Example {
|
|
example: "date list-timezone | where timezone =~ Shanghai",
|
|
description: "Show time zone(s) that contains 'Shanghai'",
|
|
result: Some(Value::test_list(vec![Value::test_record(record! {
|
|
"timezone" => Value::test_string("Asia/Shanghai"),
|
|
})])),
|
|
}]
|
|
}
|
|
}
|