forked from StrafesNET/strafe-project
deduplicate more find code
This commit is contained in:
parent
3a716373db
commit
7b8f091ab3
@ -29,6 +29,13 @@ fn get_full_name(dom:&rbx_dom_weak::WeakDom,instance:&rbx_dom_weak::Instance)->S
|
|||||||
full_name
|
full_name
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn find_first_child<'a>(dom:&'a rbx_dom_weak::WeakDom,instance:&rbx_dom_weak::Instance,name:&str)->Option<&'a rbx_dom_weak::Instance>{
|
||||||
|
instance.children().iter().filter_map(|&r|dom.get_by_ref(r)).find(|inst|inst.name==name)
|
||||||
|
}
|
||||||
|
pub fn find_first_descendant<'a>(dom:&'a rbx_dom_weak::WeakDom,instance:&rbx_dom_weak::Instance,name:&str)->Option<&'a rbx_dom_weak::Instance>{
|
||||||
|
dom.descendants_of(instance.referent()).find(|&inst|inst.name==name)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn find_first_child_of_class<'a>(dom:&'a rbx_dom_weak::WeakDom,instance:&rbx_dom_weak::Instance,class:&str)->Option<&'a rbx_dom_weak::Instance>{
|
pub fn find_first_child_of_class<'a>(dom:&'a rbx_dom_weak::WeakDom,instance:&rbx_dom_weak::Instance,class:&str)->Option<&'a rbx_dom_weak::Instance>{
|
||||||
instance.children().iter().filter_map(|&r|dom.get_by_ref(r)).find(|inst|inst.class==class)
|
instance.children().iter().filter_map(|&r|dom.get_by_ref(r)).find(|inst|inst.class==class)
|
||||||
}
|
}
|
||||||
@ -171,10 +178,8 @@ impl Instance{
|
|||||||
let instance=this.get(dom)?;
|
let instance=this.get(dom)?;
|
||||||
Ok(
|
Ok(
|
||||||
match search_descendants.unwrap_or(false){
|
match search_descendants.unwrap_or(false){
|
||||||
true=>dom.descendants_of(this.referent()).find(|inst|inst.name==name_str),
|
true=>find_first_descendant(dom,instance,name_str),
|
||||||
false=>instance.children().iter().filter_map(|&r|
|
false=>find_first_child(dom,instance,name_str),
|
||||||
dom.get_by_ref(r)
|
|
||||||
).find(|inst|inst.name==name_str),
|
|
||||||
}
|
}
|
||||||
.map(|instance|
|
.map(|instance|
|
||||||
Instance::new(instance.referent())
|
Instance::new(instance.referent())
|
||||||
@ -192,7 +197,9 @@ impl Instance{
|
|||||||
true=>find_first_descendant_of_class(dom,this.get(dom)?,class_str),
|
true=>find_first_descendant_of_class(dom,this.get(dom)?,class_str),
|
||||||
false=>find_first_child_of_class(dom,this.get(dom)?,class_str),
|
false=>find_first_child_of_class(dom,this.get(dom)?,class_str),
|
||||||
}
|
}
|
||||||
.map(|inst|(Instance::new(inst.referent())))
|
.map(|instance|
|
||||||
|
Instance::new(instance.referent())
|
||||||
|
)
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
@ -232,13 +239,9 @@ impl Instance{
|
|||||||
}
|
}
|
||||||
//find a child with a matching name
|
//find a child with a matching name
|
||||||
Ok(
|
Ok(
|
||||||
instance.children()
|
find_first_child(dom,instance,index_str)
|
||||||
.iter()
|
.map(|instance|Instance::new(instance.referent()))
|
||||||
.find(|&&r|
|
.into_lua(lua)
|
||||||
dom.get_by_ref(r)
|
|
||||||
.is_some_and(|instance|instance.name==index_str)
|
|
||||||
)
|
|
||||||
.map(|&referent|Instance::new(referent)).into_lua(lua)
|
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
@ -320,15 +323,11 @@ impl DataModel{
|
|||||||
dom(lua,|dom|{
|
dom(lua,|dom|{
|
||||||
match service.as_str(){
|
match service.as_str(){
|
||||||
"Lighting"=>{
|
"Lighting"=>{
|
||||||
let referent=dom.root()
|
let referent=find_first_child_of_class(dom,dom.root(),"Lighting")
|
||||||
.children()
|
.map(|instance|instance.referent())
|
||||||
.iter()
|
.unwrap_or_else(||
|
||||||
.find(|&&c|
|
dom.insert(dom.root_ref(),InstanceBuilder::new("Lighting"))
|
||||||
dom.get_by_ref(c).is_some_and(|c|c.class=="Lighting")
|
);
|
||||||
).map(|r|*r)
|
|
||||||
.unwrap_or_else(||
|
|
||||||
dom.insert(dom.root_ref(),InstanceBuilder::new("Lighting"))
|
|
||||||
);
|
|
||||||
Lighting::new(referent).into_lua(lua)
|
Lighting::new(referent).into_lua(lua)
|
||||||
},
|
},
|
||||||
other=>Err::<mlua::Value,_>(mlua::Error::runtime(format!("Service '{other}' not supported"))),
|
other=>Err::<mlua::Value,_>(mlua::Error::runtime(format!("Service '{other}' not supported"))),
|
||||||
|
Loading…
Reference in New Issue
Block a user