From 19aec6327f1a34e6c4c5b874a2d5197611f6ea15 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Fri, 27 May 2016 12:23:26 +0200 Subject: [PATCH] Fix Store::get() --- libimagstore/src/store.rs | 36 +++++------------------------------- 1 file changed, 5 insertions(+), 31 deletions(-) diff --git a/libimagstore/src/store.rs b/libimagstore/src/store.rs index b7013b4d..2f6ace04 100644 --- a/libimagstore/src/store.rs +++ b/libimagstore/src/store.rs @@ -353,38 +353,12 @@ impl Store { /// Get an entry from the store if it exists. /// /// This executes the {pre,post}_retrieve_aspects hooks. - pub fn get<'a, S: IntoStoreId>(&'a self, id: S) -> Result>> - { - let id = self.storify_id(id.into_storeid()); - if let Err(e) = self.execute_hooks_for_id(self.pre_retrieve_aspects.clone(), &id) { - return Err(e); - } - - let mut entries = match self.entries.write() { - // Loosing the error here - Err(_) => return Err(SE::new(SEK::LockPoisoned, None)), - Ok(e) => e, - }; - - let mut se = match entries.get_mut(&id) { - Some(e) => e, - None => return Ok(None), - }; - - let entry = match se.get_entry() { - Ok(e) => e, - Err(e) => return Err(e), - }; - - se.status = StoreEntryStatus::Borrowed; - - let mut fle = FileLockEntry::new(self, entry, id); - - if let Err(e) = self.execute_hooks_for_mut_file(self.post_retrieve_aspects.clone(), &mut fle) { - Err(SE::new(SEK::HookExecutionError, Some(Box::new(e)))) - } else { - Ok(Some(fle)) + pub fn get<'a, S: IntoStoreId + Clone>(&'a self, id: S) -> Result>> { + if !self.storify_id(id.clone().into_storeid()).exists() { + debug!("Does not exist: {:?}", id.clone().into_storeid()); + return Ok(None); } + self.retrieve(id).map(Some) } /// Same as `Store::get()` but also tries older versions of the entry, returning an iterator