##// END OF EJS Templates
matchers: fix the bug in rust PatternMatcher that made it cut off early...
Arseniy Alekseyev -
r52459:529a6558 stable
parent child Browse files
Show More
@@ -17,7 +17,7 use crate::{
17 17 PatternFileWarning, PatternResult,
18 18 },
19 19 utils::{
20 files::find_dirs,
20 files::{dir_ancestors, find_dirs},
21 21 hg_path::{HgPath, HgPathBuf, HgPathError},
22 22 Escaped,
23 23 },
@@ -354,7 +354,7 impl<'a> Matcher for PatternMatcher<'a>
354 354 if self.prefix && self.files.contains(directory) {
355 355 return VisitChildrenSet::Recursive;
356 356 }
357 let path_or_parents_in_set = find_dirs(directory)
357 let path_or_parents_in_set = dir_ancestors(directory)
358 358 .any(|parent_dir| self.files.contains(parent_dir));
359 359 if self.dirs.contains(directory) || path_or_parents_in_set {
360 360 VisitChildrenSet::This
@@ -2298,7 +2298,7 mod tests {
2298 2298 #[test]
2299 2299 fn test_pattern_matcher_visit_children_set() {
2300 2300 let tree = make_example_tree();
2301 let _pattern_dir1_glob_c =
2301 let pattern_dir1_glob_c =
2302 2302 PatternMatcher::new(vec![IgnorePattern::new(
2303 2303 PatternSyntax::Glob,
2304 2304 b"dir1/*.c",
@@ -2327,10 +2327,6 mod tests {
2327 2327 )])
2328 2328 .unwrap()
2329 2329 };
2330 // // TODO: re-enable this test when the corresponding bug is
2331 // fixed if false {
2332 // tree.check_matcher(&pattern_dir1_glob_c);
2333 // }
2334 2330 let files = vec![HgPathBuf::from_bytes(b"dir/subdir/b.txt")];
2335 2331 let file_dir_subdir_b = FileMatcher::new(files).unwrap();
2336 2332
@@ -2393,6 +2389,7 mod tests {
2393 2389
2394 2390 tree.check_matcher(&pattern_dir1(), 25);
2395 2391 tree.check_matcher(&pattern_dir1_a, 1);
2392 tree.check_matcher(&pattern_dir1_glob_c, 2);
2396 2393 tree.check_matcher(&pattern_relglob_c(), 14);
2397 2394 tree.check_matcher(&AlwaysMatcher, 112);
2398 2395 tree.check_matcher(&NeverMatcher, 0);
@@ -120,6 +120,10 pub fn find_dirs(path: &HgPath) -> Ances
120 120 dirs
121 121 }
122 122
123 pub fn dir_ancestors(path: &HgPath) -> Ancestors {
124 Ancestors { next: Some(path) }
125 }
126
123 127 /// Returns an iterator yielding ancestor directories of the given repository
124 128 /// path.
125 129 ///
@@ -842,19 +842,19 Check the output
842 842 C clean
843 843 C subdir/clean
844 844
845 Test various matchers interatction with dirstate code:
846
845 847 $ hg status path:subdir
846 848 M subdir/modified
847 849 R subdir/removed
848 850 ! subdir/deleted
849 851 ? subdir/unknown
850 852
851 FIXME: it's a bug in rhg that the status below is empty:
852
853 853 $ hg status 'glob:subdir/*'
854 M subdir/modified (no-rhg !)
855 R subdir/removed (no-rhg !)
856 ! subdir/deleted (no-rhg !)
857 ? subdir/unknown (no-rhg !)
854 M subdir/modified
855 R subdir/removed
856 ! subdir/deleted
857 ? subdir/unknown
858 858
859 859 FIXME: it's a bug (both in rhg and in Python) that the status below is wrong,
860 860 in rhg it's empty, in Python it's missing the unknown file:
General Comments 0
You need to be logged in to leave comments. Login now