2023-03-22 10:20:47 +00:00
|
|
|
use mlua::prelude::*;
|
|
|
|
|
2024-05-12 12:30:32 +01:00
|
|
|
use crate::shared::{
|
2023-03-27 14:59:06 +01:00
|
|
|
classes::{
|
|
|
|
add_class_restricted_getter, add_class_restricted_method,
|
|
|
|
get_or_create_property_ref_instance,
|
|
|
|
},
|
|
|
|
instance::class_is_a_service,
|
|
|
|
};
|
2023-03-22 10:20:47 +00:00
|
|
|
|
|
|
|
use super::Instance;
|
|
|
|
|
2023-03-22 10:29:11 +00:00
|
|
|
pub const CLASS_NAME: &str = "DataModel";
|
|
|
|
|
2023-10-06 17:58:39 +01:00
|
|
|
pub fn add_fields<'lua, F: LuaUserDataFields<'lua, Instance>>(f: &mut F) {
|
|
|
|
add_class_restricted_getter(f, CLASS_NAME, "Workspace", data_model_get_workspace);
|
2023-03-27 14:59:06 +01:00
|
|
|
}
|
|
|
|
|
2023-03-25 19:54:15 +00:00
|
|
|
pub fn add_methods<'lua, M: LuaUserDataMethods<'lua, Instance>>(m: &mut M) {
|
|
|
|
add_class_restricted_method(m, CLASS_NAME, "GetService", data_model_get_service);
|
|
|
|
add_class_restricted_method(m, CLASS_NAME, "FindService", data_model_find_service);
|
2023-03-22 11:43:23 +00:00
|
|
|
}
|
|
|
|
|
2023-03-27 14:59:06 +01:00
|
|
|
/**
|
|
|
|
Get the workspace parented under this datamodel, or create it if it doesn't exist.
|
|
|
|
|
|
|
|
### See Also
|
|
|
|
* [`Terrain`](https://create.roblox.com/docs/reference/engine/classes/Workspace#Terrain)
|
|
|
|
on the Roblox Developer Hub
|
|
|
|
*/
|
|
|
|
fn data_model_get_workspace(_: &Lua, this: &Instance) -> LuaResult<Instance> {
|
|
|
|
get_or_create_property_ref_instance(this, "Workspace", "Workspace")
|
|
|
|
}
|
|
|
|
|
2023-03-22 11:43:23 +00:00
|
|
|
/**
|
2024-05-12 12:30:32 +01:00
|
|
|
Gets or creates a service for this `DataModel`.
|
2023-03-22 11:43:23 +00:00
|
|
|
|
|
|
|
### See Also
|
|
|
|
* [`GetService`](https://create.roblox.com/docs/reference/engine/classes/ServiceProvider#GetService)
|
|
|
|
on the Roblox Developer Hub
|
|
|
|
*/
|
|
|
|
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!(
|
2024-05-12 12:30:32 +01:00
|
|
|
"'{service_name}' is not a valid service name",
|
2023-03-22 11:43:23 +00:00
|
|
|
)))
|
|
|
|
} 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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2024-05-12 12:30:32 +01:00
|
|
|
Gets a service for this `DataModel`, if it exists.
|
2023-03-22 11:43:23 +00:00
|
|
|
|
|
|
|
### 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!(
|
2024-05-12 12:30:32 +01:00
|
|
|
"'{service_name}' is not a valid service name",
|
2023-03-22 11:43:23 +00:00
|
|
|
)))
|
|
|
|
} else if let Some(service) = this.find_child(|child| child.class == service_name) {
|
|
|
|
Ok(Some(service))
|
|
|
|
} else {
|
|
|
|
Ok(None)
|
|
|
|
}
|
2023-03-22 10:20:47 +00:00
|
|
|
}
|