Implement GetService and FindService

This commit is contained in:
Filip Tibell 2023-03-22 12:43:23 +01:00
parent 1441544426
commit 34e417e57b
No known key found for this signature in database
2 changed files with 56 additions and 15 deletions

View file

@ -1,22 +1,58 @@
use mlua::prelude::*; use mlua::prelude::*;
use crate::shared::classes::add_class_restricted_method; use crate::shared::{classes::add_class_restricted_method, instance::class_is_a_service};
use super::Instance; use super::Instance;
pub const CLASS_NAME: &str = "DataModel"; pub const CLASS_NAME: &str = "DataModel";
pub fn add_methods<'lua, M: LuaUserDataMethods<'lua, Instance>>(methods: &mut M) { pub fn add_methods<'lua, M: LuaUserDataMethods<'lua, Instance>>(methods: &mut M) {
add_class_restricted_method( add_class_restricted_method(methods, CLASS_NAME, "GetService", data_model_get_service);
methods, add_class_restricted_method(methods, CLASS_NAME, "FindService", data_model_find_service);
CLASS_NAME, }
"GetService",
|_, _, _service_name: String| Ok(()), /**
); Gets or creates a service for this DataModel.
add_class_restricted_method(
methods, ### See Also
CLASS_NAME, * [`GetService`](https://create.roblox.com/docs/reference/engine/classes/ServiceProvider#GetService)
"FindService", on the Roblox Developer Hub
|_, _, _service_name: String| Ok(()), */
); fn data_model_get_service(_: &Lua, this: &Instance, service_name: String) -> LuaResult<Instance> {
if matches!(class_is_a_service(&service_name), None | Some(false)) {
Err(LuaError::RuntimeError(format!(
"'{}' is not a valid service name",
service_name
)))
} else if let Some(service) = this.find_child(|child| child.class == service_name) {
Ok(service)
} else {
let service = Instance::new_orphaned(service_name);
service.set_parent(Some(this.clone()));
Ok(service)
}
}
/**
Gets a service for this DataModel, if it exists.
### See Also
* [`FindService`](https://create.roblox.com/docs/reference/engine/classes/ServiceProvider#FindService)
on the Roblox Developer Hub
*/
fn data_model_find_service(
_: &Lua,
this: &Instance,
service_name: String,
) -> LuaResult<Option<Instance>> {
if matches!(class_is_a_service(&service_name), None | Some(false)) {
Err(LuaError::RuntimeError(format!(
"'{}' is not a valid service name",
service_name
)))
} else if let Some(service) = this.find_child(|child| child.class == service_name) {
Ok(Some(service))
} else {
Ok(None)
}
} }

View file

@ -589,11 +589,16 @@ impl Instance {
datatype_table.set( datatype_table.set(
"new", "new",
lua.create_function(|lua, class_name: String| { lua.create_function(|lua, class_name: String| {
if class_exists(&class_name) { if class_name == data_model::CLASS_NAME {
Err(LuaError::RuntimeError(format!(
"Failed to create Instance - '{}' class is restricted",
class_name
)))
} else if class_exists(&class_name) {
Instance::new_orphaned(class_name).to_lua(lua) Instance::new_orphaned(class_name).to_lua(lua)
} else { } else {
Err(LuaError::RuntimeError(format!( Err(LuaError::RuntimeError(format!(
"'{}' is not a valid class name", "Failed to create Instance - '{}' is not a valid class name",
class_name class_name
))) )))
} }