Mercurial > public > mercurial-scm > hg
diff rust/hg-core/src/lib.rs @ 42536:2dcee6497b0b
rust-dirstate: add "dirs" Rust implementation
Following the work done in d1786c1d34fa and working towards the goal of a
complete Rust implementation of the dirstate, this rewrites the `dirs` class.
There is already a C implementation, which relies heavily on CPython hacks and
protocol violations for performance, so I don't expect this to perform as well
for now, as this is very straight-forward code.
The immediate benefits are new high-level documentation and some unit tests.
Differential Revision: https://phab.mercurial-scm.org/D6393
author | Rapha?l Gom?s <rgomes@octobus.net> |
---|---|
date | Thu, 16 May 2019 18:03:06 +0200 |
parents | 9609430d3625 |
children | 326fdce22fb2 |
line wrap: on
line diff
--- a/rust/hg-core/src/lib.rs Fri Jun 21 00:26:07 2019 +0530 +++ b/rust/hg-core/src/lib.rs Thu May 16 18:03:06 2019 +0200 @@ -15,8 +15,10 @@ pub mod discovery; pub mod testing; // unconditionally built, for use from integration tests pub use dirstate::{ + dirs_multiset::DirsMultiset, parsers::{pack_dirstate, parse_dirstate}, - CopyVec, CopyVecEntry, DirstateEntry, DirstateParents, DirstateVec, + CopyVec, CopyVecEntry, DirsIterable, DirstateEntry, DirstateParents, + DirstateVec, }; mod filepatterns; mod utils; @@ -73,6 +75,12 @@ BadSize(usize, usize), } +#[derive(Debug, PartialEq)] +pub enum DirstateMapError { + PathNotFound(Vec<u8>), + EmptyPath, +} + impl From<std::io::Error> for DirstatePackError { fn from(e: std::io::Error) -> Self { DirstatePackError::CorruptedEntry(e.to_string())