##// END OF EJS Templates
hg-core: define a `ListTrackedFiles` `Operation`...
Antoine Cezar -
r45918:0f5286cc default
parent child Browse files
Show More
@@ -0,0 +1,85 b''
1 // list_tracked_files.rs
2 //
3 // Copyright 2020 Antoine Cezar <antoine.cezar@octobus.net>
4 //
5 // This software may be used and distributed according to the terms of the
6 // GNU General Public License version 2 or any later version.
7
8 use super::find_root;
9 use crate::dirstate::parsers::parse_dirstate;
10 use crate::utils::hg_path::HgPath;
11 use crate::{DirstateParseError, EntryState};
12 use rayon::prelude::*;
13 use std::convert::From;
14 use std::fmt;
15 use std::fs;
16 use std::io;
17 use std::path::PathBuf;
18
19 /// Kind of error encoutered by ListTrackedFiles
20 #[derive(Debug)]
21 pub enum ListTrackedFilesErrorKind {
22 ParseError(DirstateParseError),
23 }
24
25 /// A ListTrackedFiles error
26 #[derive(Debug)]
27 pub struct ListTrackedFilesError {
28 /// Kind of error encoutered by ListTrackedFiles
29 pub kind: ListTrackedFilesErrorKind,
30 }
31
32 impl std::error::Error for ListTrackedFilesError {}
33
34 impl fmt::Display for ListTrackedFilesError {
35 fn fmt(&self, _f: &mut fmt::Formatter<'_>) -> fmt::Result {
36 unimplemented!()
37 }
38 }
39
40 impl From<ListTrackedFilesErrorKind> for ListTrackedFilesError {
41 fn from(kind: ListTrackedFilesErrorKind) -> Self {
42 ListTrackedFilesError { kind }
43 }
44 }
45
46 /// List files under Mercurial control in the working directory
47 pub struct ListTrackedFiles {
48 root: PathBuf,
49 }
50
51 impl ListTrackedFiles {
52 pub fn new() -> Result<Self, find_root::FindRootError> {
53 let root = find_root::FindRoot::new().run()?;
54 Ok(ListTrackedFiles { root })
55 }
56
57 /// Load the tracked files data from disk
58 pub fn load(&self) -> Result<ListDirstateTrackedFiles, io::Error> {
59 let dirstate = &self.root.join(".hg/dirstate");
60 let content = fs::read(&dirstate)?;
61 Ok(ListDirstateTrackedFiles { content })
62 }
63 }
64
65 /// List files under Mercurial control in the working directory
66 /// by reading the dirstate
67 pub struct ListDirstateTrackedFiles {
68 content: Vec<u8>,
69 }
70
71 impl ListDirstateTrackedFiles {
72 pub fn run(&self) -> Result<Vec<&HgPath>, ListTrackedFilesError> {
73 let (_, entries, _) = parse_dirstate(&self.content)
74 .map_err(ListTrackedFilesErrorKind::ParseError)?;
75 let mut files: Vec<&HgPath> = entries
76 .into_iter()
77 .filter_map(|(path, entry)| match entry.state {
78 EntryState::Removed => None,
79 _ => Some(path),
80 })
81 .collect();
82 files.par_sort_unstable();
83 Ok(files)
84 }
85 }
@@ -1,13 +1,17 b''
1 1 //! A distinction is made between operations and commands.
2 2 //! An operation is what can be done whereas a command is what is exposed by
3 3 //! the cli. A single command can use several operations to achieve its goal.
4 4
5 5 mod dirstate_status;
6 6 mod find_root;
7 mod list_tracked_files;
7 8 pub use find_root::{FindRoot, FindRootError, FindRootErrorKind};
9 pub use list_tracked_files::{
10 ListTrackedFiles, ListTrackedFilesError, ListTrackedFilesErrorKind,
11 };
8 12
9 13 // TODO add an `Operation` trait when GAT have landed (rust #44265):
10 14 // there is no way to currently define a trait which can both return
11 15 // references to `self` and to passed data, which is what we would need.
12 16 // Generic Associated Types may fix this and allow us to have a unified
13 17 // interface.
General Comments 0
You need to be logged in to leave comments. Login now