mirror of
https://github.com/nushell/nushell.git
synced 2024-12-15 03:32:50 +01:00
107 lines
2.8 KiB
Rust
107 lines
2.8 KiB
Rust
use crate::commands::WholeStreamCommand;
|
|
use crate::prelude::*;
|
|
use nu_errors::ShellError;
|
|
use nu_protocol::{Signature, SyntaxShape};
|
|
use nu_source::Tagged;
|
|
use std::path::PathBuf;
|
|
|
|
pub struct Ls;
|
|
|
|
#[derive(Deserialize)]
|
|
pub struct LsArgs {
|
|
pub path: Option<Tagged<PathBuf>>,
|
|
pub all: bool,
|
|
pub full: bool,
|
|
#[serde(rename = "short-names")]
|
|
pub short_names: bool,
|
|
#[serde(rename = "with-symlink-targets")]
|
|
pub with_symlink_targets: bool,
|
|
#[serde(rename = "du")]
|
|
pub du: bool,
|
|
}
|
|
|
|
#[async_trait]
|
|
impl WholeStreamCommand for Ls {
|
|
fn name(&self) -> &str {
|
|
"ls"
|
|
}
|
|
|
|
fn signature(&self) -> Signature {
|
|
Signature::build("ls")
|
|
.optional(
|
|
"path",
|
|
SyntaxShape::Pattern,
|
|
"a path to get the directory contents from",
|
|
)
|
|
.switch("all", "also show hidden files", Some('a'))
|
|
.switch(
|
|
"full",
|
|
"list all available columns for each entry",
|
|
Some('f'),
|
|
)
|
|
.switch(
|
|
"short-names",
|
|
"only print the file names and not the path",
|
|
Some('s'),
|
|
)
|
|
.switch(
|
|
"with-symlink-targets",
|
|
"display the paths to the target files that symlinks point to",
|
|
Some('w'),
|
|
)
|
|
.switch(
|
|
"du",
|
|
"display the apparent directory size in place of the directory metadata size",
|
|
Some('d'),
|
|
)
|
|
}
|
|
|
|
fn usage(&self) -> &str {
|
|
"View the contents of the current or given path."
|
|
}
|
|
|
|
async fn run(
|
|
&self,
|
|
args: CommandArgs,
|
|
registry: &CommandRegistry,
|
|
) -> Result<OutputStream, ShellError> {
|
|
let name = args.call_info.name_tag.clone();
|
|
let ctrl_c = args.ctrl_c.clone();
|
|
let shell_manager = args.shell_manager.clone();
|
|
let (args, _) = args.process(®istry).await?;
|
|
shell_manager.ls(args, name, ctrl_c)
|
|
}
|
|
|
|
fn examples(&self) -> Vec<Example> {
|
|
vec![
|
|
Example {
|
|
description: "List all files in the current directory",
|
|
example: "ls",
|
|
result: None,
|
|
},
|
|
Example {
|
|
description: "List all files in a subdirectory",
|
|
example: "ls subdir",
|
|
result: None,
|
|
},
|
|
Example {
|
|
description: "List all rust files",
|
|
example: "ls *.rs",
|
|
result: None,
|
|
},
|
|
]
|
|
}
|
|
}
|
|
|
|
#[cfg(test)]
|
|
mod tests {
|
|
use super::Ls;
|
|
|
|
#[test]
|
|
fn examples_work_as_expected() {
|
|
use crate::examples::test as test_examples;
|
|
|
|
test_examples(Ls {})
|
|
}
|
|
}
|