nushell/crates/nu-cli/src/commands/rm.rs

65 lines
1.6 KiB
Rust
Raw Normal View History

use crate::commands::WholeStreamCommand;
use crate::context::CommandRegistry;
use crate::prelude::*;
use nu_errors::ShellError;
use nu_protocol::{Signature, SyntaxShape};
use nu_source::Tagged;
2019-08-02 21:15:07 +02:00
use std::path::PathBuf;
2019-07-17 21:51:18 +02:00
pub struct Remove;
#[derive(Deserialize)]
pub struct RemoveArgs {
pub rest: Vec<Tagged<PathBuf>>,
2019-08-21 19:03:59 +02:00
pub recursive: Tagged<bool>,
2020-04-11 08:53:53 +02:00
#[allow(unused)]
pub trash: Tagged<bool>,
}
impl WholeStreamCommand for Remove {
2019-07-17 21:51:18 +02:00
fn name(&self) -> &str {
"rm"
}
2019-08-02 21:15:07 +02:00
fn signature(&self) -> Signature {
Signature::build("rm")
2019-10-28 06:15:35 +01:00
.switch(
"trash",
"use the platform's recycle bin instead of permanently deleting",
Some('t'),
2019-10-28 06:15:35 +01:00
)
.switch("recursive", "delete subdirectories recursively", Some('r'))
.rest(SyntaxShape::Pattern, "the file path(s) to remove")
2019-08-02 21:15:07 +02:00
}
2019-07-17 21:51:18 +02:00
fn usage(&self) -> &str {
"Remove file(s)"
}
2019-08-02 21:15:07 +02:00
fn run(
&self,
args: CommandArgs,
registry: &CommandRegistry,
2019-08-24 21:36:19 +02:00
) -> Result<OutputStream, ShellError> {
args.process(registry, rm)?.run()
2019-07-17 21:51:18 +02:00
}
fn examples(&self) -> &[Example] {
&[
Example {
description: "Delete a file",
example: "rm file.txt",
},
Example {
description: "Move a file to the system trash",
example: "rm --trash file.txt",
},
]
}
2019-07-17 21:51:18 +02:00
}
fn rm(args: RemoveArgs, context: RunnableContext) -> Result<OutputStream, ShellError> {
2019-08-21 19:03:59 +02:00
let shell_manager = context.shell_manager.clone();
shell_manager.rm(args, &context)
2019-07-17 21:51:18 +02:00
}