lol idk #1

Open
Quaternions wants to merge 826 commits from StrafesNET/strafe-project:master into master
3 changed files with 15 additions and 6 deletions
Showing only changes of commit 7e09494146 - Show all commits

4
Cargo.lock generated
View File

@ -571,9 +571,9 @@ dependencies = [
[[package]] [[package]]
name = "roblox_emulator" name = "roblox_emulator"
version = "0.3.1" version = "0.4.0"
source = "sparse+https://git.itzana.me/api/packages/strafesnet/cargo/" source = "sparse+https://git.itzana.me/api/packages/strafesnet/cargo/"
checksum = "b58d7bb42d458984e629a012757474710fd0e429c2c824a2529574be5e7c2fd6" checksum = "df647d25a9bc8871a838a830ae90776cd31c44d1a74268bd783d1cadcd8fcd93"
dependencies = [ dependencies = [
"glam", "glam",
"mlua", "mlua",

View File

@ -18,5 +18,5 @@ rbx_dom_weak = { version = "2.7.0", registry = "strafesnet" }
rbx_mesh = "0.1.2" rbx_mesh = "0.1.2"
rbx_reflection_database = { version = "0.2.10", registry = "strafesnet" } rbx_reflection_database = { version = "0.2.10", registry = "strafesnet" }
rbx_xml = { version = "0.13.3", registry = "strafesnet" } rbx_xml = { version = "0.13.3", registry = "strafesnet" }
roblox_emulator = { version = "0.3.1", registry = "strafesnet" } roblox_emulator = { version = "0.4.0", registry = "strafesnet" }
strafesnet_common = { version = "0.5.1", registry = "strafesnet" } strafesnet_common = { version = "0.5.1", registry = "strafesnet" }

View File

@ -25,7 +25,9 @@ impl Model{
Self{dom} Self{dom}
} }
pub fn into_place(self)->Place{ pub fn into_place(self)->Place{
let (dom,services)=roblox_emulator::place::new_place_with_instances_in_workspace(self.dom); let Self{mut dom}=self;
let context=roblox_emulator::context::Context::from_mut(&mut dom);
let services=context.convert_into_place();
Place{dom,services} Place{dom,services}
} }
} }
@ -37,15 +39,22 @@ impl AsRef<WeakDom> for Model{
pub struct Place{ pub struct Place{
dom:WeakDom, dom:WeakDom,
services:roblox_emulator::place::Services, services:roblox_emulator::context::Services,
} }
impl Place{ impl Place{
fn new(dom:WeakDom)->Option<Self>{
let context=roblox_emulator::context::Context::from_ref(&dom);
Some(Self{
services:context.find_services()?,
dom,
})
}
pub fn run_scripts(&mut self){ pub fn run_scripts(&mut self){
let Place{dom,services}=self; let Place{dom,services}=self;
let runner=roblox_emulator::runner::Runner::new().unwrap(); let runner=roblox_emulator::runner::Runner::new().unwrap();
let context=roblox_emulator::context::Context::from_mut(dom); let context=roblox_emulator::context::Context::from_mut(dom);
let scripts=context.scripts(); let scripts=context.scripts();
let runnable=runner.runnable_context(context,services).unwrap(); let runnable=runner.runnable_context_with_services(context,services).unwrap();
for script in scripts{ for script in scripts{
if let Err(e)=runnable.run_script(script){ if let Err(e)=runnable.run_script(script){
println!("runner error: {e}"); println!("runner error: {e}");