##// END OF EJS Templates
rhg: support rhg status --no-copies...
rhg: support rhg status --no-copies This makes `rhg st --rev A --rev B --no-copies` work without fallback to Python, where previously `--config ui.statuscopies=False` was necessary.

File last commit:

r53198:79e8118c default
r53238:c2814b69 default
Show More
owning.rs
101 lines | 2.5 KiB | application/rls-services+xml | RustLexer
use crate::DirstateParents;
use super::{
dirstate_map::{DirstateIdentity, DirstateMap},
DirstateError,
};
use self_cell::self_cell;
use std::ops::Deref;
self_cell!(
/// Keep a `DirstateMap<'owner>` next to the `owner` buffer that it
/// borrows.
pub struct OwningDirstateMap {
owner: Box<dyn Deref<Target = [u8]> + Send>,
#[covariant]
dependent: DirstateMap,
}
);
impl OwningDirstateMap {
pub fn new_empty<OnDisk>(
on_disk: OnDisk,
identity: Option<DirstateIdentity>,
) -> Self
where
OnDisk: Deref<Target = [u8]> + Send + 'static,
{
let on_disk = Box::new(on_disk);
OwningDirstateMap::new(on_disk, |bytes| {
let mut empty = DirstateMap::empty(bytes);
empty.identity = identity;
empty
})
}
pub fn new_v1<OnDisk>(
on_disk: OnDisk,
identity: Option<DirstateIdentity>,
) -> Result<(Self, DirstateParents), DirstateError>
where
OnDisk: Deref<Target = [u8]> + Send + 'static,
{
let on_disk = Box::new(on_disk);
let mut parents = DirstateParents::NULL;
Ok((
OwningDirstateMap::try_new(on_disk, |bytes| {
DirstateMap::new_v1(bytes, identity).map(|(dmap, p)| {
parents = p.unwrap_or(DirstateParents::NULL);
dmap
})
})?,
parents,
))
}
pub fn new_v2<OnDisk>(
on_disk: OnDisk,
data_size: usize,
metadata: &[u8],
uuid: Vec<u8>,
identity: Option<DirstateIdentity>,
) -> Result<Self, DirstateError>
where
OnDisk: Deref<Target = [u8]> + Send + 'static,
{
let on_disk = Box::new(on_disk);
OwningDirstateMap::try_new(on_disk, |bytes| {
DirstateMap::new_v2(bytes, data_size, metadata, uuid, identity)
})
}
pub fn with_dmap_mut<R>(
&mut self,
f: impl FnOnce(&mut DirstateMap) -> R,
) -> R {
self.with_dependent_mut(|_owner, dmap| f(dmap))
}
pub fn get_map(&self) -> &DirstateMap {
self.borrow_dependent()
}
pub fn on_disk(&self) -> &[u8] {
self.borrow_owner()
}
pub fn old_uuid(&self) -> Option<&[u8]> {
self.get_map().old_uuid.as_deref()
}
pub fn old_identity(&self) -> Option<DirstateIdentity> {
self.get_map().identity
}
pub fn old_data_size(&self) -> usize {
self.get_map().old_data_size
}
}