mirror of
https://github.com/SPLURT-Station/S.P.L.U.R.T-Station-13.git
synced 2025-12-10 09:54:52 +00:00
28 lines
1.4 KiB
Plaintext
28 lines
1.4 KiB
Plaintext
/*! How material datums work
|
|
Materials are now instanced datums, with an associative list of them being kept in SSmaterials. We only instance the materials once and then re-use these instances for everything.
|
|
These materials call on_applied() on whatever item they are applied to, common effects are adding components, changing color and changing description. This allows us to differentiate items based on the material they are made out of.area
|
|
*/
|
|
|
|
SUBSYSTEM_DEF(materials)
|
|
name = "Materials"
|
|
flags = SS_NO_FIRE
|
|
init_order = INIT_ORDER_MATERIALS
|
|
///Dictionary of material.type || material ref
|
|
var/list/materials = list()
|
|
///Dictionary of category || list of material refs
|
|
var/list/materials_by_category = list()
|
|
///List of stackcrafting recipes for materials using rigid materials
|
|
var/list/rigid_stack_recipes = list(new/datum/stack_recipe("chair", /obj/structure/chair/greyscale, one_per_turf = TRUE, on_floor = TRUE, applies_mats = TRUE))
|
|
|
|
/datum/controller/subsystem/materials/Initialize(timeofday)
|
|
InitializeMaterials()
|
|
return ..()
|
|
|
|
///Ran on initialize, populated the materials and materials_by_category dictionaries with their appropiate vars (See these variables for more info)
|
|
/datum/controller/subsystem/materials/proc/InitializeMaterials(timeofday)
|
|
for(var/type in subtypesof(/datum/material))
|
|
var/datum/material/ref = new type
|
|
materials[type] = ref
|
|
for(var/c in ref.categories)
|
|
materials_by_category[c] += list(ref)
|