2021-10-07 22:20:23 +00:00
|
|
|
use std::collections::VecDeque;
|
|
|
|
use std::env::current_dir;
|
|
|
|
|
|
|
|
use nu_engine::CallExt;
|
|
|
|
use nu_protocol::ast::Call;
|
|
|
|
use nu_protocol::engine::{Command, EvaluationContext};
|
2021-10-25 04:01:02 +00:00
|
|
|
use nu_protocol::{
|
|
|
|
IntoPipelineData, PipelineData, ShellError, Signature, SyntaxShape, Value, ValueStream,
|
|
|
|
};
|
2021-10-07 22:20:23 +00:00
|
|
|
|
2021-10-25 04:01:02 +00:00
|
|
|
#[derive(Clone)]
|
2021-10-07 22:20:23 +00:00
|
|
|
pub struct Mkdir;
|
|
|
|
|
|
|
|
impl Command for Mkdir {
|
|
|
|
fn name(&self) -> &str {
|
|
|
|
"mkdir"
|
|
|
|
}
|
|
|
|
|
|
|
|
fn signature(&self) -> Signature {
|
|
|
|
Signature::build("mkdir")
|
|
|
|
.rest(
|
|
|
|
"rest",
|
|
|
|
SyntaxShape::Filepath,
|
|
|
|
"the name(s) of the path(s) to create",
|
|
|
|
)
|
|
|
|
.switch("show-created-paths", "show the path(s) created.", Some('s'))
|
|
|
|
}
|
|
|
|
|
|
|
|
fn usage(&self) -> &str {
|
|
|
|
"Make directories, creates intermediary directories as required."
|
|
|
|
}
|
|
|
|
|
|
|
|
fn run(
|
|
|
|
&self,
|
|
|
|
context: &EvaluationContext,
|
|
|
|
call: &Call,
|
2021-10-25 04:01:02 +00:00
|
|
|
_input: PipelineData,
|
|
|
|
) -> Result<PipelineData, ShellError> {
|
2021-10-07 22:20:23 +00:00
|
|
|
let path = current_dir()?;
|
|
|
|
let mut directories = call
|
|
|
|
.rest::<String>(context, 0)?
|
|
|
|
.into_iter()
|
|
|
|
.map(|dir| path.join(dir))
|
|
|
|
.peekable();
|
|
|
|
|
|
|
|
let show_created_paths = call.has_flag("show-created-paths");
|
|
|
|
let mut stream: VecDeque<Value> = VecDeque::new();
|
|
|
|
|
|
|
|
if directories.peek().is_none() {
|
|
|
|
return Err(ShellError::MissingParameter(
|
|
|
|
"requires directory paths".to_string(),
|
|
|
|
call.head,
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i, dir) in directories.enumerate() {
|
|
|
|
let span = call.positional[i].span;
|
|
|
|
let dir_res = std::fs::create_dir_all(&dir);
|
|
|
|
|
|
|
|
if let Err(reason) = dir_res {
|
|
|
|
return Err(ShellError::CreateNotPossible(
|
|
|
|
format!("failed to create directory: {}", reason),
|
|
|
|
call.positional[i].span,
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
if show_created_paths {
|
|
|
|
let val = format!("{:}", dir.to_string_lossy());
|
|
|
|
stream.push_back(Value::String { val, span });
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-25 04:01:02 +00:00
|
|
|
Ok(stream.into_iter().into_pipeline_data())
|
2021-10-07 22:20:23 +00:00
|
|
|
}
|
|
|
|
}
|