##// END OF EJS Templates
rhg: Exit with an error code if `files` finds nothing...
Simon Sapin -
r47479:63bfcddd default
parent child Browse files
Show More
@@ -1,71 +1,77
1 use crate::error::CommandError;
1 use crate::error::CommandError;
2 use crate::ui::Ui;
2 use crate::ui::Ui;
3 use clap::Arg;
3 use clap::Arg;
4 use hg::operations::list_rev_tracked_files;
4 use hg::operations::list_rev_tracked_files;
5 use hg::operations::Dirstate;
5 use hg::operations::Dirstate;
6 use hg::repo::Repo;
6 use hg::repo::Repo;
7 use hg::utils::current_dir;
7 use hg::utils::current_dir;
8 use hg::utils::files::{get_bytes_from_path, relativize_path};
8 use hg::utils::files::{get_bytes_from_path, relativize_path};
9 use hg::utils::hg_path::{HgPath, HgPathBuf};
9 use hg::utils::hg_path::{HgPath, HgPathBuf};
10
10
11 pub const HELP_TEXT: &str = "
11 pub const HELP_TEXT: &str = "
12 List tracked files.
12 List tracked files.
13
13
14 Returns 0 on success.
14 Returns 0 on success.
15 ";
15 ";
16
16
17 pub fn args() -> clap::App<'static, 'static> {
17 pub fn args() -> clap::App<'static, 'static> {
18 clap::SubCommand::with_name("files")
18 clap::SubCommand::with_name("files")
19 .arg(
19 .arg(
20 Arg::with_name("rev")
20 Arg::with_name("rev")
21 .help("search the repository as it is in REV")
21 .help("search the repository as it is in REV")
22 .short("-r")
22 .short("-r")
23 .long("--revision")
23 .long("--revision")
24 .value_name("REV")
24 .value_name("REV")
25 .takes_value(true),
25 .takes_value(true),
26 )
26 )
27 .about(HELP_TEXT)
27 .about(HELP_TEXT)
28 }
28 }
29
29
30 pub fn run(invocation: &crate::CliInvocation) -> Result<(), CommandError> {
30 pub fn run(invocation: &crate::CliInvocation) -> Result<(), CommandError> {
31 let relative = invocation.config.get(b"ui", b"relative-paths");
31 let relative = invocation.config.get(b"ui", b"relative-paths");
32 if relative.is_some() {
32 if relative.is_some() {
33 return Err(CommandError::unsupported(
33 return Err(CommandError::unsupported(
34 "non-default ui.relative-paths",
34 "non-default ui.relative-paths",
35 ));
35 ));
36 }
36 }
37
37
38 let rev = invocation.subcommand_args.value_of("rev");
38 let rev = invocation.subcommand_args.value_of("rev");
39
39
40 let repo = invocation.repo?;
40 let repo = invocation.repo?;
41 if let Some(rev) = rev {
41 if let Some(rev) = rev {
42 let files = list_rev_tracked_files(repo, rev).map_err(|e| (e, rev))?;
42 let files = list_rev_tracked_files(repo, rev).map_err(|e| (e, rev))?;
43 display_files(invocation.ui, repo, files.iter())
43 display_files(invocation.ui, repo, files.iter())
44 } else {
44 } else {
45 let distate = Dirstate::new(repo)?;
45 let distate = Dirstate::new(repo)?;
46 let files = distate.tracked_files()?;
46 let files = distate.tracked_files()?;
47 display_files(invocation.ui, repo, files)
47 display_files(invocation.ui, repo, files)
48 }
48 }
49 }
49 }
50
50
51 fn display_files<'a>(
51 fn display_files<'a>(
52 ui: &Ui,
52 ui: &Ui,
53 repo: &Repo,
53 repo: &Repo,
54 files: impl IntoIterator<Item = &'a HgPath>,
54 files: impl IntoIterator<Item = &'a HgPath>,
55 ) -> Result<(), CommandError> {
55 ) -> Result<(), CommandError> {
56 let cwd = HgPathBuf::from(get_bytes_from_path(hg::utils::current_dir()?));
56 let cwd = HgPathBuf::from(get_bytes_from_path(hg::utils::current_dir()?));
57 let working_directory = repo.working_directory_path();
57 let working_directory = repo.working_directory_path();
58 let working_directory = current_dir()?.join(working_directory); // Make it absolute
58 let working_directory = current_dir()?.join(working_directory); // Make it absolute
59 let working_directory =
59 let working_directory =
60 HgPathBuf::from(get_bytes_from_path(working_directory));
60 HgPathBuf::from(get_bytes_from_path(working_directory));
61
61
62 let mut stdout = ui.stdout_buffer();
62 let mut stdout = ui.stdout_buffer();
63
63
64 let mut any = false;
64 for file in files {
65 for file in files {
66 any = true;
65 let file = working_directory.join(file);
67 let file = working_directory.join(file);
66 stdout.write_all(relativize_path(&file, &cwd).as_ref())?;
68 stdout.write_all(relativize_path(&file, &cwd).as_ref())?;
67 stdout.write_all(b"\n")?;
69 stdout.write_all(b"\n")?;
68 }
70 }
69 stdout.flush()?;
71 stdout.flush()?;
70 Ok(())
72 if any {
73 Ok(())
74 } else {
75 Err(CommandError::Unsuccessful)
76 }
71 }
77 }
General Comments 0
You need to be logged in to leave comments. Login now