Show More
@@ -25,6 +25,25 use std::collections::HashSet; | |||
|
25 | 25 | use std::fs::{read_dir, DirEntry}; |
|
26 | 26 | use std::path::Path; |
|
27 | 27 | |
|
28 | /// Wrong type of file from a `BadMatch` | |
|
29 | /// Note: a lot of those don't exist on all platforms. | |
|
30 | #[derive(Debug)] | |
|
31 | pub enum BadType { | |
|
32 | CharacterDevice, | |
|
33 | BlockDevice, | |
|
34 | FIFO, | |
|
35 | Socket, | |
|
36 | Directory, | |
|
37 | Unknown, | |
|
38 | } | |
|
39 | ||
|
40 | /// Was explicitly matched but cannot be found/accessed | |
|
41 | #[derive(Debug)] | |
|
42 | pub enum BadMatch { | |
|
43 | OsError(i32), | |
|
44 | BadType(BadType), | |
|
45 | } | |
|
46 | ||
|
28 | 47 | /// Marker enum used to dispatch new status entries into the right collections. |
|
29 | 48 | /// Is similar to `crate::EntryState`, but represents the transient state of |
|
30 | 49 | /// entries during the lifetime of a command. |
@@ -36,6 +55,16 enum Dispatch { | |||
|
36 | 55 | Deleted, |
|
37 | 56 | Clean, |
|
38 | 57 | Unknown, |
|
58 | Ignored, | |
|
59 | /// Empty dispatch, the file is not worth listing | |
|
60 | None, | |
|
61 | /// Was explicitly matched but cannot be found/accessed | |
|
62 | Bad(BadMatch), | |
|
63 | Directory { | |
|
64 | /// True if the directory used to be a file in the dmap so we can say | |
|
65 | /// that it's been removed. | |
|
66 | was_file: bool, | |
|
67 | }, | |
|
39 | 68 | } |
|
40 | 69 | |
|
41 | 70 | type IoResult<T> = std::io::Result<T>; |
@@ -261,8 +290,9 pub struct DirstateStatus<'a> { | |||
|
261 | 290 | pub removed: Vec<&'a HgPath>, |
|
262 | 291 | pub deleted: Vec<&'a HgPath>, |
|
263 | 292 | pub clean: Vec<&'a HgPath>, |
|
264 | /* TODO ignored | |
|
265 | * TODO unknown */ | |
|
293 | pub ignored: Vec<&'a HgPath>, | |
|
294 | pub unknown: Vec<&'a HgPath>, | |
|
295 | pub bad: Vec<(&'a HgPath, BadMatch)>, | |
|
266 | 296 | } |
|
267 | 297 | |
|
268 | 298 | fn build_response<'a>( |
@@ -274,17 +304,24 fn build_response<'a>( | |||
|
274 | 304 | let mut removed = vec![]; |
|
275 | 305 | let mut deleted = vec![]; |
|
276 | 306 | let mut clean = vec![]; |
|
307 | let mut ignored = vec![]; | |
|
308 | let mut unknown = vec![]; | |
|
309 | let mut bad = vec![]; | |
|
277 | 310 | |
|
278 | 311 | for res in results.into_iter() { |
|
279 | 312 | let (filename, dispatch) = res?; |
|
280 | 313 | match dispatch { |
|
281 |
Dispatch::Unknown => |
|
|
314 | Dispatch::Unknown => unknown.push(filename), | |
|
282 | 315 | Dispatch::Unsure => lookup.push(filename), |
|
283 | 316 | Dispatch::Modified => modified.push(filename), |
|
284 | 317 | Dispatch::Added => added.push(filename), |
|
285 | 318 | Dispatch::Removed => removed.push(filename), |
|
286 | 319 | Dispatch::Deleted => deleted.push(filename), |
|
287 | 320 | Dispatch::Clean => clean.push(filename), |
|
321 | Dispatch::Ignored => ignored.push(filename), | |
|
322 | Dispatch::None => {} | |
|
323 | Dispatch::Bad(reason) => bad.push((filename, reason)), | |
|
324 | Dispatch::Directory { .. } => {} | |
|
288 | 325 | } |
|
289 | 326 | } |
|
290 | 327 | |
@@ -296,6 +333,9 fn build_response<'a>( | |||
|
296 | 333 | removed, |
|
297 | 334 | deleted, |
|
298 | 335 | clean, |
|
336 | ignored, | |
|
337 | unknown, | |
|
338 | bad, | |
|
299 | 339 | }, |
|
300 | 340 | )) |
|
301 | 341 | } |
General Comments 0
You need to be logged in to leave comments.
Login now