repo_path: change .split() and .parent() to return &RepoPath

This commit is contained in:
Yuya Nishihara 2023-11-27 12:26:19 +09:00
parent b4caef7fe0
commit 016fc2b5cc
2 changed files with 21 additions and 23 deletions

View file

@ -118,12 +118,10 @@ pub struct RepoPathComponentsIter<'a> {
value: &'a str, value: &'a str,
} }
impl RepoPathComponentsIter<'_> { impl<'a> RepoPathComponentsIter<'a> {
// TODO: add borrowed RepoPath type and implement as_path() instead /// Returns the remaining part as repository path.
fn to_path(&self) -> RepoPathBuf { pub fn as_path(&self) -> &'a RepoPath {
RepoPathBuf { RepoPath::from_internal_string_unchecked(self.value)
value: self.value.to_owned(),
}
} }
} }
@ -315,16 +313,16 @@ impl RepoPath {
} }
} }
// TODO: make it return borrowed RepoPath type /// Returns the parent path without the base name component.
pub fn parent(&self) -> Option<RepoPathBuf> { pub fn parent(&self) -> Option<&RepoPath> {
self.split().map(|(parent, _)| parent) self.split().map(|(parent, _)| parent)
} }
// TODO: make it return borrowed RepoPath type /// Splits this into the parent path and base name component.
pub fn split(&self) -> Option<(RepoPathBuf, &RepoPathComponent)> { pub fn split(&self) -> Option<(&RepoPath, &RepoPathComponent)> {
let mut components = self.components(); let mut components = self.components();
let basename = components.next_back()?; let basename = components.next_back()?;
Some((components.to_path(), basename)) Some((components.as_path(), basename))
} }
pub fn components(&self) -> RepoPathComponentsIter<'_> { pub fn components(&self) -> RepoPathComponentsIter<'_> {
@ -527,8 +525,8 @@ mod tests {
let subdir = dir.join(subdir_component); let subdir = dir.join(subdir_component);
assert_eq!(root.parent(), None); assert_eq!(root.parent(), None);
assert_eq!(dir.parent().as_deref(), Some(root)); assert_eq!(dir.parent(), Some(root));
assert_eq!(subdir.parent(), Some(dir)); assert_eq!(subdir.parent(), Some(dir.as_ref()));
} }
#[test] #[test]
@ -541,8 +539,8 @@ mod tests {
let file = dir.join(file_component); let file = dir.join(file_component);
assert_eq!(root.split(), None); assert_eq!(root.split(), None);
assert_eq!(dir.split(), Some((root.to_owned(), dir_component))); assert_eq!(dir.split(), Some((root, dir_component)));
assert_eq!(file.split(), Some((dir, file_component))); assert_eq!(file.split(), Some((dir.as_ref(), file_component)));
} }
#[test] #[test]

View file

@ -19,7 +19,7 @@ use std::sync::Arc;
use crate::backend; use crate::backend;
use crate::backend::{TreeId, TreeValue}; use crate::backend::{TreeId, TreeValue};
use crate::repo_path::RepoPathBuf; use crate::repo_path::{RepoPath, RepoPathBuf};
use crate::store::Store; use crate::store::Store;
use crate::tree::Tree; use crate::tree::Tree;
@ -79,7 +79,7 @@ impl TreeBuilder {
// Update entries in parent trees for file overrides // Update entries in parent trees for file overrides
for (path, file_override) in self.overrides { for (path, file_override) in self.overrides {
let (dir, basename) = path.split().unwrap(); let (dir, basename) = path.split().unwrap();
let tree = trees_to_write.get_mut(&dir).unwrap(); let tree = trees_to_write.get_mut(dir).unwrap();
match file_override { match file_override {
Override::Replace(value) => { Override::Replace(value) => {
tree.set(basename.to_owned(), value); tree.set(basename.to_owned(), value);
@ -95,7 +95,7 @@ impl TreeBuilder {
let store = &self.store; let store = &self.store;
while let Some((dir, tree)) = trees_to_write.pop_last() { while let Some((dir, tree)) = trees_to_write.pop_last() {
if let Some((parent, basename)) = dir.split() { if let Some((parent, basename)) = dir.split() {
let parent_tree = trees_to_write.get_mut(&parent).unwrap(); let parent_tree = trees_to_write.get_mut(parent).unwrap();
if tree.is_empty() { if tree.is_empty() {
if let Some(TreeValue::Tree(_)) = parent_tree.value(basename) { if let Some(TreeValue::Tree(_)) = parent_tree.value(basename) {
parent_tree.remove(basename); parent_tree.remove(basename);
@ -127,17 +127,17 @@ impl TreeBuilder {
fn populate_trees<'a>( fn populate_trees<'a>(
tree_cache: &'a mut BTreeMap<RepoPathBuf, Tree>, tree_cache: &'a mut BTreeMap<RepoPathBuf, Tree>,
store: &Arc<Store>, store: &Arc<Store>,
dir: RepoPathBuf, dir: &RepoPath,
) -> &'a Tree { ) -> &'a Tree {
// `if let Some(tree) = ...` doesn't pass lifetime check as of Rust 1.69.0 // `if let Some(tree) = ...` doesn't pass lifetime check as of Rust 1.69.0
if tree_cache.contains_key(&dir) { if tree_cache.contains_key(dir) {
return tree_cache.get(&dir).unwrap(); return tree_cache.get(dir).unwrap();
} }
let (parent, basename) = dir.split().expect("root must be populated"); let (parent, basename) = dir.split().expect("root must be populated");
let tree = populate_trees(tree_cache, store, parent) let tree = populate_trees(tree_cache, store, parent)
.sub_tree(basename) .sub_tree(basename)
.unwrap_or_else(|| Tree::null(store.clone(), dir.clone())); .unwrap_or_else(|| Tree::null(store.clone(), dir.to_owned()));
tree_cache.entry(dir).or_insert(tree) tree_cache.entry(dir.to_owned()).or_insert(tree)
} }
for path in self.overrides.keys() { for path in self.overrides.keys() {