forked from StrafesNET/strafe-project
lol idk #1
@ -19,17 +19,16 @@ impl Context{
|
|||||||
pub const fn new(dom:WeakDom)->Self{
|
pub const fn new(dom:WeakDom)->Self{
|
||||||
Self{dom}
|
Self{dom}
|
||||||
}
|
}
|
||||||
pub fn script_singleton(source:String)->(Context,crate::runner::instance::Script,crate::place::Services){
|
pub fn script_singleton(source:String)->(Context,crate::runner::instance::Script,Services){
|
||||||
let script=InstanceBuilder::new("Script")
|
let script=InstanceBuilder::new("Script")
|
||||||
.with_property("Source",rbx_types::Variant::String(source));
|
.with_property("Source",rbx_types::Variant::String(source));
|
||||||
let script_ref=script.referent();
|
let script_ref=script.referent();
|
||||||
let (dom,services)=crate::place::new_place_with_instances_in_workspace(
|
let mut context=Self::new(WeakDom::new(
|
||||||
WeakDom::new(
|
|
||||||
InstanceBuilder::new("DataModel")
|
InstanceBuilder::new("DataModel")
|
||||||
.with_child(script)
|
.with_child(script)
|
||||||
)
|
));
|
||||||
);
|
let services=context.convert_into_place();
|
||||||
(Context{dom},crate::runner::instance::Script::new(script_ref),services)
|
(context,crate::runner::instance::Script::new(script_ref),services)
|
||||||
}
|
}
|
||||||
pub fn from_ref(dom:&WeakDom)->&Context{
|
pub fn from_ref(dom:&WeakDom)->&Context{
|
||||||
unsafe{&*(dom as *const WeakDom as *const Context)}
|
unsafe{&*(dom as *const WeakDom as *const Context)}
|
||||||
@ -46,4 +45,40 @@ impl Context{
|
|||||||
pub fn scripts(&self)->Vec<crate::runner::instance::Script>{
|
pub fn scripts(&self)->Vec<crate::runner::instance::Script>{
|
||||||
self.superclass_iter("LuaSourceContainer").map(crate::runner::instance::Script::new).collect()
|
self.superclass_iter("LuaSourceContainer").map(crate::runner::instance::Script::new).collect()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn find_services(&self)->Option<Services>{
|
||||||
|
Some(Services{
|
||||||
|
workspace:*self.dom.root().children().iter().find(|&&r|
|
||||||
|
self.dom.get_by_ref(r).is_some_and(|instance|instance.class=="Workspace")
|
||||||
|
)?,
|
||||||
|
game:self.dom.root_ref(),
|
||||||
|
})
|
||||||
|
}
|
||||||
|
pub fn convert_into_place(&mut self)->Services{
|
||||||
|
//snapshot root instances
|
||||||
|
let children=self.dom.root().children().to_owned();
|
||||||
|
|
||||||
|
//insert services
|
||||||
|
let game=self.dom.root_ref();
|
||||||
|
let workspace=self.dom.insert(game,
|
||||||
|
InstanceBuilder::new("Workspace")
|
||||||
|
.with_child(InstanceBuilder::new("Terrain"))
|
||||||
|
);
|
||||||
|
self.dom.insert(game,InstanceBuilder::new("Lighting"));
|
||||||
|
|
||||||
|
//transfer original root instances into workspace
|
||||||
|
for instance in children{
|
||||||
|
self.dom.transfer_within(instance,workspace);
|
||||||
|
}
|
||||||
|
|
||||||
|
Services{
|
||||||
|
game,
|
||||||
|
workspace,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct Services{
|
||||||
|
pub game:Ref,
|
||||||
|
pub workspace:Ref,
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
pub mod place;
|
|
||||||
pub mod runner;
|
pub mod runner;
|
||||||
pub mod context;
|
pub mod context;
|
||||||
|
|
||||||
|
47
src/place.rs
47
src/place.rs
@ -1,47 +0,0 @@
|
|||||||
use rbx_dom_weak::{InstanceBuilder,WeakDom};
|
|
||||||
use rbx_types::Ref;
|
|
||||||
|
|
||||||
pub struct Services{
|
|
||||||
pub game:Ref,
|
|
||||||
pub workspace:Ref,
|
|
||||||
}
|
|
||||||
impl Services{
|
|
||||||
pub fn find_in(dom:&WeakDom)->Option<Self>{
|
|
||||||
Some(Services{
|
|
||||||
workspace:*dom.root().children().iter().find(|&&r|
|
|
||||||
dom.get_by_ref(r).is_some_and(|instance|instance.class=="Workspace")
|
|
||||||
)?,
|
|
||||||
game:dom.root_ref(),
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn new_place_with_instances_in_workspace(mut instance_dom:WeakDom)->(WeakDom,Services){
|
|
||||||
//workspace
|
|
||||||
let workspace_bldr=InstanceBuilder::new("Workspace")
|
|
||||||
.with_child(InstanceBuilder::new("Terrain"));
|
|
||||||
let workspace=workspace_bldr.referent();
|
|
||||||
|
|
||||||
//game
|
|
||||||
let game_bldr=
|
|
||||||
InstanceBuilder::new("DataModel")
|
|
||||||
.with_child(workspace_bldr)
|
|
||||||
.with_child(InstanceBuilder::new("Lighting"));
|
|
||||||
let game=game_bldr.referent();
|
|
||||||
|
|
||||||
let mut dom=WeakDom::new(game_bldr);
|
|
||||||
|
|
||||||
//put instances in workspace
|
|
||||||
let children=instance_dom.root().children().to_owned();
|
|
||||||
for instance in children{
|
|
||||||
instance_dom.transfer(instance,&mut dom,workspace);
|
|
||||||
}
|
|
||||||
|
|
||||||
(
|
|
||||||
dom,
|
|
||||||
Services{
|
|
||||||
game,
|
|
||||||
workspace
|
|
||||||
}
|
|
||||||
)
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user