mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-16 00:56:23 +00:00
repo_path: change .split() and .parent() to return &RepoPath
This commit is contained in:
parent
b4caef7fe0
commit
016fc2b5cc
2 changed files with 21 additions and 23 deletions
|
@ -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]
|
||||||
|
|
|
@ -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() {
|
||||||
|
|
Loading…
Reference in a new issue