Merge pull request #893 from matthiasbeyer/libimagruby/impl-retrieve-for-mod
Impl Store::retrieve_for_module() interface function
This commit is contained in:
commit
4d1282d163
1 changed files with 24 additions and 1 deletions
|
@ -386,7 +386,30 @@ methods!(
|
||||||
// On error: Nil + Exception
|
// On error: Nil + Exception
|
||||||
//
|
//
|
||||||
fn retrieve_for_module(name: RString) -> AnyObject {
|
fn retrieve_for_module(name: RString) -> AnyObject {
|
||||||
unimplemented!()
|
use entry::FileLockEntryHandle as FLEH;
|
||||||
|
use ruru::Array;
|
||||||
|
|
||||||
|
let name = typecheck!(name or return any NilClass::new()).to_string();
|
||||||
|
|
||||||
|
call_on_store! {
|
||||||
|
store <- itself wrapped inside STORE_WRAPPER,
|
||||||
|
operation {
|
||||||
|
match store.retrieve_for_module(&name) {
|
||||||
|
Err(e) => {
|
||||||
|
trace_error(&e);
|
||||||
|
VM::raise(Class::from_existing("RuntimeError"), e.description());
|
||||||
|
NilClass::new().to_any_object()
|
||||||
|
},
|
||||||
|
Ok(iter) => {
|
||||||
|
let store_handle = itself.get_data(&*STORE_WRAPPER).clone();
|
||||||
|
iter.map(|sid| FLEH::new(store_handle.clone(), sid).wrap())
|
||||||
|
.fold(Array::new(), |mut a, e| a.push(e))
|
||||||
|
.to_any_object()
|
||||||
|
},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
on fail return NilClass::new().to_any_object()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update a FileLockEntry in the store
|
// Update a FileLockEntry in the store
|
||||||
|
|
Loading…
Reference in a new issue