mirror of
https://github.com/nushell/nushell
synced 2025-01-13 13:49:21 +00:00
add --default
flag to input command (#14374)
# Description Closes: #14248 # User-Facing Changes Added a `--default` flag to input command, and it also added an extra output to prompt: ``` > let x = input -d 18 "input your age" input your age (default: 18) > $x 18 > let x = input -d 18 > $x 18 ``` # Tests + Formatting I don't think it's easy to add a test for it :-(
This commit is contained in:
parent
13ce9e4f64
commit
6773dfce8d
1 changed files with 20 additions and 2 deletions
|
@ -43,6 +43,12 @@ impl Command for Input {
|
||||||
"number of characters to read; suppresses output",
|
"number of characters to read; suppresses output",
|
||||||
Some('n'),
|
Some('n'),
|
||||||
)
|
)
|
||||||
|
.named(
|
||||||
|
"default",
|
||||||
|
SyntaxShape::String,
|
||||||
|
"default value if no input is provided",
|
||||||
|
Some('d'),
|
||||||
|
)
|
||||||
.switch("suppress-output", "don't print keystroke values", Some('s'))
|
.switch("suppress-output", "don't print keystroke values", Some('s'))
|
||||||
.category(Category::Platform)
|
.category(Category::Platform)
|
||||||
}
|
}
|
||||||
|
@ -72,8 +78,12 @@ impl Command for Input {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let default_val: Option<String> = call.get_flag(engine_state, stack, "default")?;
|
||||||
if let Some(prompt) = &prompt {
|
if let Some(prompt) = &prompt {
|
||||||
print!("{prompt}");
|
match &default_val {
|
||||||
|
None => print!("{prompt}"),
|
||||||
|
Some(val) => print!("{prompt} (default: {val})"),
|
||||||
|
}
|
||||||
let _ = std::io::stdout().flush();
|
let _ = std::io::stdout().flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -149,7 +159,10 @@ impl Command for Input {
|
||||||
if !suppress_output {
|
if !suppress_output {
|
||||||
std::io::stdout().write_all(b"\n")?;
|
std::io::stdout().write_all(b"\n")?;
|
||||||
}
|
}
|
||||||
Ok(Value::string(buf, call.head).into_pipeline_data())
|
match default_val {
|
||||||
|
Some(val) if buf.is_empty() => Ok(Value::string(val, call.head).into_pipeline_data()),
|
||||||
|
_ => Ok(Value::string(buf, call.head).into_pipeline_data()),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn examples(&self) -> Vec<Example> {
|
fn examples(&self) -> Vec<Example> {
|
||||||
|
@ -164,6 +177,11 @@ impl Command for Input {
|
||||||
example: "let user_input = (input --numchar 2)",
|
example: "let user_input = (input --numchar 2)",
|
||||||
result: None,
|
result: None,
|
||||||
},
|
},
|
||||||
|
Example {
|
||||||
|
description: "Get input from the user with default value, and assign to a variable",
|
||||||
|
example: "let user_input = (input --default 10)",
|
||||||
|
result: None,
|
||||||
|
},
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue