From patchwork Wed Aug 28 11:55:16 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Subject: D6765: rustfilepatterns: shorter code for concatenating slices From: phabricator X-Patchwork-Id: 41422 Message-Id: <8c844fd23da3ba34bdfd04f841234ae5@localhost.localdomain> To: Phabricator Cc: mercurial-devel@mercurial-scm.org Date: Wed, 28 Aug 2019 11:55:16 +0000 valentin.gatienbaron updated this revision to Diff 16330. REPOSITORY rHG Mercurial CHANGES SINCE LAST UPDATE https://phab.mercurial-scm.org/D6765?vs=16328&id=16330 CHANGES SINCE LAST ACTION https://phab.mercurial-scm.org/D6765/new/ REVISION DETAIL https://phab.mercurial-scm.org/D6765 AFFECTED FILES rust/hg-core/src/filepatterns.rs CHANGE DETAILS To: valentin.gatienbaron, #hg-reviewers, Alphare, kevincox Cc: durin42, kevincox, mercurial-devel diff --git a/rust/hg-core/src/filepatterns.rs b/rust/hg-core/src/filepatterns.rs --- a/rust/hg-core/src/filepatterns.rs +++ b/rust/hg-core/src/filepatterns.rs @@ -158,26 +158,20 @@ if pattern[0] == b'^' { return pattern.to_owned(); } - let mut res = b".*".to_vec(); - res.extend(pattern); - res + [b".*", pattern].concat() } PatternSyntax::Path | PatternSyntax::RelPath => { if pattern == b"." { return vec![]; } - let mut pattern = escape_pattern(pattern); - pattern.extend(b"(?:/|$)"); - pattern + [escape_pattern(pattern).as_slice(), b"(?:/|$)"].concat() } PatternSyntax::RootFiles => { let mut res = if pattern == b"." { vec![] } else { // Pattern is a directory name. - let mut as_vec: Vec = escape_pattern(pattern); - as_vec.push(b'/'); - as_vec + [escape_pattern(pattern).as_slice(), b"/"].concat() }; // Anything after the pattern must be a non-directory. @@ -185,24 +179,16 @@ res } PatternSyntax::RelGlob => { - let mut res: Vec = vec![]; let glob_re = glob_to_re(pattern); if let Some(rest) = glob_re.drop_prefix(b"[^/]*") { - res.extend(b".*"); - res.extend(rest); + [b".*", rest, globsuffix].concat() } else { - res.extend(b"(?:|.*/)"); - res.extend(glob_re); + [b"(?:|.*/)", glob_re.as_slice(), globsuffix].concat() } - res.extend(globsuffix.iter()); - res } PatternSyntax::Glob | PatternSyntax::RootGlob => { - let mut res: Vec = vec![]; - res.extend(glob_to_re(pattern)); - res.extend(globsuffix.iter()); - res + [glob_to_re(pattern).as_slice(), globsuffix].concat() } } }