Mercurial > hg
changeset 47095:473abf4728bf
dirstate-tree: Empty shell for a second Rust DirstateMap implementation
For background see description of the previous changeset
"Make Rust DirstateMap bindings go through a trait object".
Add an empty shell for a opt-in second Rust implementation of the
`DirstateMap` type and the `status` function. For now all methods panic.
This can be seen in "action" with:
./hg status --config experimental.dirstate-tree.in-memory=1
Differential Revision: https://phab.mercurial-scm.org/D10364
author | Simon Sapin <simon.sapin@octobus.net> |
---|---|
date | Tue, 30 Mar 2021 09:56:04 +0200 |
parents | e061a1df32a8 |
children | 3c11c24b82b6 |
files | mercurial/configitems.py mercurial/dirstate.py rust/hg-core/src/dirstate_tree.rs rust/hg-core/src/dirstate_tree/dirstate_map.rs rust/hg-cpython/src/dirstate/dirstate_map.rs |
diffstat | 5 files changed, 234 insertions(+), 3 deletions(-) [+] |
line wrap: on
line diff
--- a/mercurial/configitems.py Thu Apr 08 14:58:44 2021 +0200 +++ b/mercurial/configitems.py Tue Mar 30 09:56:04 2021 +0200 @@ -959,6 +959,11 @@ ) coreconfigitem( b'experimental', + b'dirstate-tree.in-memory', + default=False, +) +coreconfigitem( + b'experimental', b'editortmpinhg', default=False, )
--- a/mercurial/dirstate.py Thu Apr 08 14:58:44 2021 +0200 +++ b/mercurial/dirstate.py Tue Mar 30 09:56:04 2021 +0200 @@ -1790,7 +1790,12 @@ Does not fill the Dirstatemap when called. This allows for optimizations where only setting/getting the parents is needed. """ - self._inner_rustmap = rustmod.DirstateMap(self._root) + use_dirstate_tree = self._ui.configbool( + b"experimental", + b"dirstate-tree.in-memory", + False, + ) + self._inner_rustmap = rustmod.DirstateMap(use_dirstate_tree) return self._inner_rustmap @property
--- a/rust/hg-core/src/dirstate_tree.rs Thu Apr 08 14:58:44 2021 +0200 +++ b/rust/hg-core/src/dirstate_tree.rs Tue Mar 30 09:56:04 2021 +0200 @@ -1,1 +1,2 @@ +pub mod dirstate_map; pub mod dispatch;
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/rust/hg-core/src/dirstate_tree/dirstate_map.rs Tue Mar 30 09:56:04 2021 +0200 @@ -0,0 +1,216 @@ +use std::path::PathBuf; +use std::time::Duration; + +use crate::matchers::Matcher; +use crate::utils::hg_path::{HgPath, HgPathBuf}; +use crate::CopyMapIter; +use crate::DirstateEntry; +use crate::DirstateError; +use crate::DirstateMapError; +use crate::DirstateParents; +use crate::DirstateStatus; +use crate::EntryState; +use crate::FastHashMap; +use crate::HgPathCow; +use crate::PatternFileWarning; +use crate::StateMapIter; +use crate::StatusError; +use crate::StatusOptions; + +pub struct DirstateMap { + // TODO +} + +impl DirstateMap { + pub fn new() -> Self { + todo!() + } +} + +impl super::dispatch::DirstateMapMethods for DirstateMap { + fn clear(&mut self) { + todo!() + } + + fn add_file( + &mut self, + _filename: &HgPath, + _old_state: EntryState, + _entry: DirstateEntry, + ) -> Result<(), DirstateMapError> { + todo!() + } + + fn remove_file( + &mut self, + _filename: &HgPath, + _old_state: EntryState, + _size: i32, + ) -> Result<(), DirstateMapError> { + todo!() + } + + fn drop_file( + &mut self, + _filename: &HgPath, + _old_state: EntryState, + ) -> Result<bool, DirstateMapError> { + todo!() + } + + fn clear_ambiguous_times( + &mut self, + _filenames: Vec<HgPathBuf>, + _now: i32, + ) { + todo!() + } + + fn non_normal_entries_contains(&mut self, _key: &HgPath) -> bool { + todo!() + } + + fn non_normal_entries_remove(&mut self, _key: &HgPath) -> bool { + todo!() + } + + fn non_normal_or_other_parent_paths( + &mut self, + ) -> Box<dyn Iterator<Item = &HgPathBuf> + '_> { + todo!() + } + + fn set_non_normal_other_parent_entries(&mut self, _force: bool) { + todo!() + } + + fn iter_non_normal_paths( + &mut self, + ) -> Box<dyn Iterator<Item = &HgPathBuf> + Send + '_> { + todo!() + } + + fn iter_non_normal_paths_panic( + &self, + ) -> Box<dyn Iterator<Item = &HgPathBuf> + Send + '_> { + todo!() + } + + fn iter_other_parent_paths( + &mut self, + ) -> Box<dyn Iterator<Item = &HgPathBuf> + Send + '_> { + todo!() + } + + fn has_tracked_dir( + &mut self, + _directory: &HgPath, + ) -> Result<bool, DirstateMapError> { + todo!() + } + + fn has_dir( + &mut self, + _directory: &HgPath, + ) -> Result<bool, DirstateMapError> { + todo!() + } + + fn parents( + &mut self, + _file_contents: &[u8], + ) -> Result<&DirstateParents, DirstateError> { + todo!() + } + + fn set_parents(&mut self, _parents: &DirstateParents) { + todo!() + } + + fn read<'a>( + &mut self, + _file_contents: &'a [u8], + ) -> Result<Option<&'a DirstateParents>, DirstateError> { + todo!() + } + + fn pack( + &mut self, + _parents: DirstateParents, + _now: Duration, + ) -> Result<Vec<u8>, DirstateError> { + todo!() + } + + fn build_file_fold_map(&mut self) -> &FastHashMap<HgPathBuf, HgPathBuf> { + todo!() + } + + fn set_all_dirs(&mut self) -> Result<(), DirstateMapError> { + todo!() + } + + fn set_dirs(&mut self) -> Result<(), DirstateMapError> { + todo!() + } + + fn status<'a>( + &'a self, + _matcher: &'a (dyn Matcher + Sync), + _root_dir: PathBuf, + _ignore_files: Vec<PathBuf>, + _options: StatusOptions, + ) -> Result< + ( + (Vec<HgPathCow<'a>>, DirstateStatus<'a>), + Vec<PatternFileWarning>, + ), + StatusError, + > { + todo!() + } + + fn copy_map_len(&self) -> usize { + todo!() + } + + fn copy_map_iter(&self) -> CopyMapIter<'_> { + todo!() + } + + fn copy_map_contains_key(&self, _key: &HgPath) -> bool { + todo!() + } + + fn copy_map_get(&self, _key: &HgPath) -> Option<&HgPathBuf> { + todo!() + } + + fn copy_map_remove(&mut self, _key: &HgPath) -> Option<HgPathBuf> { + todo!() + } + + fn copy_map_insert( + &mut self, + _key: HgPathBuf, + _value: HgPathBuf, + ) -> Option<HgPathBuf> { + todo!() + } + + fn len(&self) -> usize { + todo!() + } + + fn contains_key(&self, _key: &HgPath) -> bool { + todo!() + } + + fn get(&self, _key: &HgPath) -> Option<&DirstateEntry> { + todo!() + } + + fn iter(&self) -> StateMapIter<'_> { + todo!() + } +}
--- a/rust/hg-cpython/src/dirstate/dirstate_map.rs Thu Apr 08 14:58:44 2021 +0200 +++ b/rust/hg-cpython/src/dirstate/dirstate_map.rs Tue Mar 30 09:56:04 2021 +0200 @@ -50,8 +50,12 @@ py_class!(pub class DirstateMap |py| { @shared data inner: Box<dyn DirstateMapMethods + Send>; - def __new__(_cls, _root: PyObject) -> PyResult<Self> { - let inner = Box::new(RustDirstateMap::default()); + def __new__(_cls, use_dirstate_tree: bool) -> PyResult<Self> { + let inner = if use_dirstate_tree { + Box::new(hg::dirstate_tree::dirstate_map::DirstateMap::new()) as _ + } else { + Box::new(RustDirstateMap::default()) as _ + }; Self::create_instance(py, inner) }