# HG changeset patch # User Arseniy Alekseyev # Date 1713271905 -3600 # Node ID 32ba01b5669d33b3d8b144df751aee3b58b486ab # Parent a2afa35641c91c73c4f61a1b02f5eaf910470f7c match: share code between includematcher and patternmatcher No need to have this duplication. diff -r a2afa35641c9 -r 32ba01b5669d rust/hg-cpython/src/dirstate/status.rs --- a/rust/hg-cpython/src/dirstate/status.rs Fri Apr 05 17:57:26 2024 +0100 +++ b/rust/hg-cpython/src/dirstate/status.rs Tue Apr 16 13:51:45 2024 +0100 @@ -153,6 +153,33 @@ ) } +fn collect_kindpats( + py: Python, + matcher: PyObject, +) -> PyResult> { + matcher + .getattr(py, "_kindpats")? + .iter(py)? + .map(|k| { + let k = k?; + let syntax = parse_pattern_syntax( + &[ + k.get_item(py, 0)?.extract::(py)?.data(py), + &b":"[..], + ] + .concat(), + ) + .map_err(|e| handle_fallback(py, StatusError::Pattern(e)))?; + let pattern = k.get_item(py, 1)?.extract::(py)?; + let pattern = pattern.data(py); + let source = k.get_item(py, 2)?.extract::(py)?; + let source = get_path_from_bytes(source.data(py)); + let new = IgnorePattern::new(syntax, pattern, source); + Ok(new) + }) + .collect() +} + /// Transform a Python matcher into a Rust matcher. fn extract_matcher( py: Python, @@ -199,33 +226,7 @@ // Get the patterns from Python even though most of them are // redundant with those we will parse later on, as they include // those passed from the command line. - let ignore_patterns: PyResult> = matcher - .getattr(py, "_kindpats")? - .iter(py)? - .map(|k| { - let k = k?; - let syntax = parse_pattern_syntax( - &[ - k.get_item(py, 0)? - .extract::(py)? - .data(py), - &b":"[..], - ] - .concat(), - ) - .map_err(|e| { - handle_fallback(py, StatusError::Pattern(e)) - })?; - let pattern = k.get_item(py, 1)?.extract::(py)?; - let pattern = pattern.data(py); - let source = k.get_item(py, 2)?.extract::(py)?; - let source = get_path_from_bytes(source.data(py)); - let new = IgnorePattern::new(syntax, pattern, source); - Ok(new) - }) - .collect(); - - let ignore_patterns = ignore_patterns?; + let ignore_patterns = collect_kindpats(py, matcher)?; let matcher = IncludeMatcher::new(ignore_patterns) .map_err(|e| handle_fallback(py, e.into()))?; @@ -254,33 +255,9 @@ Ok(Box::new(DifferenceMatcher::new(m1, m2))) } "patternmatcher" => { - let ignore_patterns = matcher - .getattr(py, "_kindpats")? - .iter(py)? - .map(|k| { - let k = k?; - let syntax = parse_pattern_syntax( - &[ - k.get_item(py, 0)? - .extract::(py)? - .data(py), - &b":"[..], - ] - .concat(), - ) - .map_err(|e| { - handle_fallback(py, StatusError::Pattern(e)) - })?; - let pattern = k.get_item(py, 1)?.extract::(py)?; - let pattern = pattern.data(py); - let source = k.get_item(py, 2)?.extract::(py)?; - let source = get_path_from_bytes(source.data(py)); - let new = IgnorePattern::new(syntax, pattern, source); - Ok(new) - }) - .collect::>>()?; + let patterns = collect_kindpats(py, matcher)?; - let matcher = PatternMatcher::new(ignore_patterns) + let matcher = PatternMatcher::new(patterns) .map_err(|e| handle_fallback(py, e.into()))?; Ok(Box::new(matcher))