From 3244b87c7e2830723f59550be9749f095013705d Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Tue, 16 Feb 2016 22:50:59 +0100 Subject: [PATCH] Implement: execute_pre_create_hooks() --- libimagstore/src/store.rs | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/libimagstore/src/store.rs b/libimagstore/src/store.rs index 0dc3ee14..62165b64 100644 --- a/libimagstore/src/store.rs +++ b/libimagstore/src/store.rs @@ -419,7 +419,12 @@ impl Store { } pub fn execute_pre_create_hooks(&self, id: &StoreId) -> Result<()> { - unimplemented!() + let guard = self.pre_create_hooks.deref().lock(); + if guard.is_err() { return Err(StoreError::new(StoreErrorKind::PreHookExecuteError, None)) } + + guard.unwrap().deref().iter() + .fold(Ok(()), |acc, hook| acc.and_then(|_| hook.pre_create(id))) + .map_err(|e| StoreError::new(StoreErrorKind::PreHookExecuteError, Some(Box::new(e)))) } pub fn execute_post_create_hooks<'a>(&'a self, fle: FileLockEntry<'a>)