From ede3365f6428a527127b9972a62bb3191a0950e0 Mon Sep 17 00:00:00 2001 From: Kenneth Loeffler Date: Thu, 5 Oct 2023 19:10:11 -0700 Subject: [PATCH] Use TerrainMaterials::from_str to parse material variant name (#118) --- src/roblox/instance/terrain.rs | 53 +++++++--------------------------- 1 file changed, 10 insertions(+), 43 deletions(-) diff --git a/src/roblox/instance/terrain.rs b/src/roblox/instance/terrain.rs index 2c52acfa..fad8e3d7 100644 --- a/src/roblox/instance/terrain.rs +++ b/src/roblox/instance/terrain.rs @@ -10,33 +10,6 @@ use super::Instance; pub const CLASS_NAME: &str = "Terrain"; -fn material_from_name(material_name: &str) -> Option { - match material_name { - "Grass" => Some(TerrainMaterials::Grass), - "Slate" => Some(TerrainMaterials::Slate), - "Concrete" => Some(TerrainMaterials::Concrete), - "Brick" => Some(TerrainMaterials::Brick), - "Sand" => Some(TerrainMaterials::Sand), - "WoodPlanks" => Some(TerrainMaterials::WoodPlanks), - "Rock" => Some(TerrainMaterials::Rock), - "Glacier" => Some(TerrainMaterials::Glacier), - "Snow" => Some(TerrainMaterials::Snow), - "Sandstone" => Some(TerrainMaterials::Sandstone), - "Mud" => Some(TerrainMaterials::Mud), - "Basalt" => Some(TerrainMaterials::Basalt), - "Ground" => Some(TerrainMaterials::Ground), - "CrackedLava" => Some(TerrainMaterials::CrackedLava), - "Asphalt" => Some(TerrainMaterials::Asphalt), - "Cobblestone" => Some(TerrainMaterials::Cobblestone), - "Ice" => Some(TerrainMaterials::Ice), - "LeafyGrass" => Some(TerrainMaterials::LeafyGrass), - "Salt" => Some(TerrainMaterials::Salt), - "Limestone" => Some(TerrainMaterials::Limestone), - "Pavement" => Some(TerrainMaterials::Pavement), - _ => None, - } -} - pub fn add_methods<'lua, M: LuaUserDataMethods<'lua, Instance>>(methods: &mut M) { add_class_restricted_method( methods, @@ -79,14 +52,12 @@ fn terrain_get_material_color(_: &Lua, this: &Instance, material: EnumItem) -> L ))); } - if let Some(terrain_material) = material_from_name(&material.name) { - Ok(material_colors.get_color(terrain_material).into()) - } else { - Err(LuaError::RuntimeError(format!( - "{} is not a valid Terrain material", - &material.name - ))) - } + let terrain_material = material + .name + .parse::() + .map_err(|err| LuaError::RuntimeError(err.to_string()))?; + + Ok(material_colors.get_color(terrain_material).into()) } /** @@ -112,14 +83,10 @@ fn terrain_set_material_color( ))); } - let terrain_material = if let Some(terrain_material) = material_from_name(&material.name) { - terrain_material - } else { - return Err(LuaError::RuntimeError(format!( - "{} is not a valid Terrain material", - &material.name - ))); - }; + let terrain_material = material + .name + .parse::() + .map_err(|err| LuaError::RuntimeError(err.to_string()))?; material_colors.set_color(terrain_material, color.into()); this.set_property("MaterialColors", Variant::MaterialColors(material_colors));