Comments
Patch
@@ -172,6 +172,20 @@
Ok(PyNone)
}
+ def set_possibly_dirty(&self, f: PyObject) -> PyResult<PyNone> {
+ self.inner(py).borrow_mut()
+ .set_possibly_dirty(
+ HgPath::new(f.extract::<PyBytes>(py)?.data(py)),
+ )
+ .or_else(|_| {
+ Err(PyErr::new::<exc::OSError, _>(
+ py,
+ "Dirstate error".to_string(),
+ ))
+ })?;
+ Ok(PyNone)
+ }
+
def reset_state(
&self,
f: PyObject,
@@ -427,6 +427,13 @@
_ => None,
}
}
+
+ fn as_entry_mut(&mut self) -> Option<&mut DirstateEntry> {
+ match self {
+ NodeData::Entry(entry) => Some(entry),
+ _ => None,
+ }
+ }
}
impl<'on_disk> DirstateMap<'on_disk> {
@@ -788,6 +795,24 @@
Ok(())
}
+ fn set_possibly_dirty(
+ &mut self,
+ filename: &HgPath,
+ ) -> Result<(), DirstateError> {
+ let node = Self::get_or_insert_node(
+ self.on_disk,
+ &mut self.unreachable_bytes,
+ &mut self.root,
+ filename,
+ WithBasename::to_cow_owned,
+ |_ancestor| {},
+ )?;
+ let entry = node.data.as_entry_mut().expect("entry should exist");
+ entry.set_possibly_dirty();
+ node.data = NodeData::Entry(*entry);
+ Ok(())
+ }
+
fn iter_nodes<'tree>(
&'tree self,
) -> impl Iterator<
@@ -926,6 +951,16 @@
})
}
+ pub fn set_possibly_dirty(
+ &mut self,
+ filename: &HgPath,
+ ) -> Result<(), DirstateError> {
+ if self.get(filename)?.is_none() {
+ return Err(DirstateMapError::PathNotFound(filename.into()).into());
+ }
+ self.with_dmap_mut(|map| map.set_possibly_dirty(filename))
+ }
+
pub fn reset_state(
&mut self,
filename: &HgPath,