From dfc67e70512cd6052c729dde3129f6716efec544 Mon Sep 17 00:00:00 2001 From: Martin von Zweigbergk Date: Wed, 13 Nov 2024 21:28:16 -0800 Subject: [PATCH] simple_op_heads_store: propagate errors when trying to remove op head Any errors other than `NotFound` are unexpected. --- lib/src/simple_op_heads_store.rs | 25 +++++++++++++++++-------- 1 file changed, 17 insertions(+), 8 deletions(-) diff --git a/lib/src/simple_op_heads_store.rs b/lib/src/simple_op_heads_store.rs index 81339e041e..f7765a4bf2 100644 --- a/lib/src/simple_op_heads_store.rs +++ b/lib/src/simple_op_heads_store.rs @@ -61,13 +61,18 @@ impl SimpleOpHeadsStore { std::fs::write(self.dir.join(id.hex()), "") } - fn remove_op_head(&self, id: &OperationId) { - // It's fine if the old head was not found. It probably means - // that we're on a distributed file system where the locking - // doesn't work. We'll probably end up with two current - // heads. We'll detect that next time we load the view. - // TODO: Propagate other errors than NotFound - std::fs::remove_file(self.dir.join(id.hex())).ok(); + fn remove_op_head(&self, id: &OperationId) -> io::Result<()> { + std::fs::remove_file(self.dir.join(id.hex())).or_else(|err| { + if err.kind() == io::ErrorKind::NotFound { + // It's fine if the old head was not found. It probably means + // that we're on a distributed file system where the locking + // doesn't work. We'll probably end up with two current + // heads. We'll detect that next time we load the view. + Ok(()) + } else { + Err(err) + } + }) } } @@ -98,7 +103,11 @@ impl OpHeadsStore for SimpleOpHeadsStore { source: err.into(), })?; for old_id in old_ids { - self.remove_op_head(old_id); + self.remove_op_head(old_id) + .map_err(|err| OpHeadsStoreError::Write { + new_op_id: new_id.clone(), + source: err.into(), + })?; } Ok(()) }