From d9218b46fcee183fe5c7f43e7d540177b88e277b Mon Sep 17 00:00:00 2001 From: "Lila S." Date: Wed, 25 Sep 2024 22:33:46 +0200 Subject: [PATCH 1/4] initial --- .../code/garment_bag_overrides.dm | 52 ++++ .../code/uniform_overrides.dm | 287 ------------------ .../modular_vending/code/_vending.dm | 82 +++++ .../code/doppler_vendors/de_forest}/vendor.dm | 2 +- .../imported_vendors}/readme.md | 0 .../imported_vendors}/vendor_containers.dm | 2 +- .../imported_vendors}/vendor_food.dm | 6 +- .../imported_vendors}/vendor_snacks.dm | 6 +- .../imported_vendors}/vendors.dm | 2 +- .../code/tg_vendors/autodrobe.dm | 81 +++++ .../code/tg_vendors/boozeomat.dm | 10 + .../code/tg_vendors/clothesmate.dm | 68 +++++ .../modular_vending/code/tg_vendors/cola.dm | 5 + .../code/tg_vendors/engivend.dm | 7 + .../modular_vending/code/tg_vendors/games.dm | 20 ++ .../code/tg_vendors/megaseed.dm | 4 + .../code/tg_vendors/wardrobes.dm | 130 ++++++++ .../icons/de_forest_vendors.dmi} | Bin .../icons/imported_quick_foods.dmi | Bin .../icons/imported_vendors.dmi | Bin tgstation.dme | 20 +- 21 files changed, 483 insertions(+), 301 deletions(-) create mode 100644 modular_doppler/modular_cosmetics/code/garment_bag_overrides.dm create mode 100644 modular_doppler/modular_vending/code/_vending.dm rename modular_doppler/{deforest_medical_items/code => modular_vending/code/doppler_vendors/de_forest}/vendor.dm (97%) rename modular_doppler/{vending_machines => modular_vending/code/doppler_vendors/imported_vendors}/readme.md (100%) rename modular_doppler/{vending_machines/code => modular_vending/code/doppler_vendors/imported_vendors}/vendor_containers.dm (98%) rename modular_doppler/{vending_machines/code => modular_vending/code/doppler_vendors/imported_vendors}/vendor_food.dm (98%) rename modular_doppler/{vending_machines/code => modular_vending/code/doppler_vendors/imported_vendors}/vendor_snacks.dm (98%) rename modular_doppler/{vending_machines/code => modular_vending/code/doppler_vendors/imported_vendors}/vendors.dm (99%) create mode 100644 modular_doppler/modular_vending/code/tg_vendors/autodrobe.dm create mode 100644 modular_doppler/modular_vending/code/tg_vendors/boozeomat.dm create mode 100644 modular_doppler/modular_vending/code/tg_vendors/clothesmate.dm create mode 100644 modular_doppler/modular_vending/code/tg_vendors/cola.dm create mode 100644 modular_doppler/modular_vending/code/tg_vendors/engivend.dm create mode 100644 modular_doppler/modular_vending/code/tg_vendors/games.dm create mode 100644 modular_doppler/modular_vending/code/tg_vendors/megaseed.dm create mode 100644 modular_doppler/modular_vending/code/tg_vendors/wardrobes.dm rename modular_doppler/{deforest_medical_items/icons/vendor.dmi => modular_vending/icons/de_forest_vendors.dmi} (100%) rename modular_doppler/{vending_machines => modular_vending}/icons/imported_quick_foods.dmi (100%) rename modular_doppler/{vending_machines => modular_vending}/icons/imported_vendors.dmi (100%) diff --git a/modular_doppler/modular_cosmetics/code/garment_bag_overrides.dm b/modular_doppler/modular_cosmetics/code/garment_bag_overrides.dm new file mode 100644 index 0000000000000..727cfdd4b964b --- /dev/null +++ b/modular_doppler/modular_cosmetics/code/garment_bag_overrides.dm @@ -0,0 +1,52 @@ +/obj/item/storage/bag/garment/captain/PopulateContents() + . = ..() + new /obj/item/clothing/under/misc/doppler_uniform/command(src) + new /obj/item/clothing/neck/doppler_mantle/command(src) + new /obj/item/clothing/head/beret/doppler_command/command(src) + new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/command(src) + +/obj/item/storage/bag/garment/hop/PopulateContents() + . = ..() + new /obj/item/clothing/under/misc/doppler_uniform/service(src) + new /obj/item/clothing/neck/doppler_mantle/service(src) + new /obj/item/clothing/head/beret/doppler_command/service(src) + new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/service(src) + +/obj/item/storage/bag/garment/hos/PopulateContents() + . = ..() + new /obj/item/clothing/under/misc/doppler_uniform/security(src) + new /obj/item/clothing/neck/doppler_mantle/security(src) + new /obj/item/clothing/head/beret/doppler_command/security(src) + new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/security(src) + +/obj/item/storage/bag/garment/warden/PopulateContents() + . = ..() + new /obj/item/clothing/under/misc/doppler_uniform/security(src) + +/obj/item/storage/bag/garment/research_director/PopulateContents() + . = ..() + new /obj/item/clothing/under/misc/doppler_uniform/science(src) + new /obj/item/clothing/neck/doppler_mantle/science(src) + new /obj/item/clothing/head/beret/doppler_command/science(src) + new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/science(src) + +/obj/item/storage/bag/garment/chief_medical/PopulateContents() + . = ..() + new /obj/item/clothing/under/misc/doppler_uniform/medical(src) + new /obj/item/clothing/neck/doppler_mantle/medical(src) + new /obj/item/clothing/head/beret/doppler_command/medical(src) + new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/medical(src) + +/obj/item/storage/bag/garment/engineering_chief/PopulateContents() + . = ..() + new /obj/item/clothing/under/misc/doppler_uniform/engineering(src) + new /obj/item/clothing/neck/doppler_mantle/engineering(src) + new /obj/item/clothing/head/beret/doppler_command/engineering(src) + new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/engineering(src) + +/obj/item/storage/bag/garment/quartermaster/PopulateContents() + . = ..() + new /obj/item/clothing/under/misc/doppler_uniform/cargo(src) + new /obj/item/clothing/neck/doppler_mantle/cargo(src) + new /obj/item/clothing/head/beret/doppler_command/cargo(src) + new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/cargo(src) diff --git a/modular_doppler/modular_cosmetics/code/uniform_overrides.dm b/modular_doppler/modular_cosmetics/code/uniform_overrides.dm index 649621053545c..9275f59afdf51 100644 --- a/modular_doppler/modular_cosmetics/code/uniform_overrides.dm +++ b/modular_doppler/modular_cosmetics/code/uniform_overrides.dm @@ -1,199 +1,3 @@ -/obj/item/storage/bag/garment/captain/PopulateContents() - . = ..() - new /obj/item/clothing/under/misc/doppler_uniform/command(src) - new /obj/item/clothing/neck/doppler_mantle/command(src) - new /obj/item/clothing/head/beret/doppler_command/command(src) - new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/command(src) - -/obj/item/storage/bag/garment/hop/PopulateContents() - . = ..() - new /obj/item/clothing/under/misc/doppler_uniform/service(src) - new /obj/item/clothing/neck/doppler_mantle/service(src) - new /obj/item/clothing/head/beret/doppler_command/service(src) - new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/service(src) - -/obj/item/storage/bag/garment/hos/PopulateContents() - . = ..() - new /obj/item/clothing/under/misc/doppler_uniform/security(src) - new /obj/item/clothing/neck/doppler_mantle/security(src) - new /obj/item/clothing/head/beret/doppler_command/security(src) - new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/security(src) - -/obj/item/storage/bag/garment/warden/PopulateContents() - . = ..() - new /obj/item/clothing/under/misc/doppler_uniform/security(src) - new /obj/item/clothing/neck/doppler_mantle/performer(src) - new /obj/item/clothing/head/beret/doppler_command/performer(src) - new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/performer(src) - -/obj/item/storage/bag/garment/research_director/PopulateContents() - . = ..() - new /obj/item/clothing/under/misc/doppler_uniform/science(src) - new /obj/item/clothing/neck/doppler_mantle/science(src) - new /obj/item/clothing/head/beret/doppler_command/science(src) - new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/science(src) - -/obj/item/storage/bag/garment/chief_medical/PopulateContents() - . = ..() - new /obj/item/clothing/under/misc/doppler_uniform/medical(src) - new /obj/item/clothing/neck/doppler_mantle/medical(src) - new /obj/item/clothing/head/beret/doppler_command/medical(src) - new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/medical(src) - -/obj/item/storage/bag/garment/engineering_chief/PopulateContents() - . = ..() - new /obj/item/clothing/under/misc/doppler_uniform/engineering(src) - new /obj/item/clothing/neck/doppler_mantle/engineering(src) - new /obj/item/clothing/head/beret/doppler_command/engineering(src) - new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/engineering(src) - -/obj/item/storage/bag/garment/quartermaster/PopulateContents() - . = ..() - new /obj/item/clothing/under/misc/doppler_uniform/cargo(src) - new /obj/item/clothing/neck/doppler_mantle/cargo(src) - new /obj/item/clothing/head/beret/doppler_command/cargo(src) - new /obj/item/clothing/head/utility/hardhat/welding/doppler_command/cargo(src) - - - -/// Job loadout overrides -// HEADS -/datum/outfit/job/cmo - uniform = /obj/item/clothing/under/misc/doppler_uniform/medical - head = /obj/item/clothing/head/beret/doppler_command/medical - neck = /obj/item/clothing/neck/doppler_mantle/medical - -/datum/outfit/job/rd - uniform = /obj/item/clothing/under/misc/doppler_uniform/science - head = /obj/item/clothing/head/utility/hardhat/welding/doppler_command/science - neck = /obj/item/clothing/neck/doppler_mantle/science - -/datum/outfit/job/ce - uniform = /obj/item/clothing/under/misc/doppler_uniform/engineering - head = /obj/item/clothing/head/utility/hardhat/welding/doppler_command/engineering - neck = /obj/item/clothing/neck/doppler_mantle/engineering - -/datum/outfit/job/quartermaster - uniform = /obj/item/clothing/under/misc/doppler_uniform/cargo - head = /obj/item/clothing/head/beret/doppler_command/cargo - neck = /obj/item/clothing/neck/doppler_mantle/cargo - -/datum/outfit/job/hop - uniform = /obj/item/clothing/under/misc/doppler_uniform/service - head = /obj/item/clothing/head/beret/doppler_command/service - neck = /obj/item/clothing/neck/doppler_mantle/service - -/datum/outfit/job/captain - uniform = /obj/item/clothing/under/misc/doppler_uniform/command - head = /obj/item/clothing/head/beret/doppler_command/command - neck = /obj/item/clothing/neck/doppler_mantle/command - -/datum/outfit/job/warden //not technically a head, but we make fun of them with pink drip bc lmao - uniform = /obj/item/clothing/under/misc/doppler_uniform/security - head = /obj/item/clothing/head/utility/hardhat/welding/doppler_command/performer - neck = /obj/item/clothing/neck/doppler_mantle/performer - -/datum/outfit/job/hos - uniform = /obj/item/clothing/under/misc/doppler_uniform/security - head = /obj/item/clothing/head/beret/doppler_command/security - neck = /obj/item/clothing/neck/doppler_mantle/security - -// MEDICAL -/datum/outfit/job/doctor - uniform = /obj/item/clothing/under/misc/doppler_uniform/medical - -/datum/outfit/job/chemist - uniform = /obj/item/clothing/under/misc/doppler_uniform/medical - -/datum/outfit/job/coroner - uniform = /obj/item/clothing/under/misc/doppler_uniform/medical - -/datum/outfit/job/paramedic - uniform = /obj/item/clothing/under/misc/doppler_uniform/medical - -// SCIENCE -/datum/outfit/job/scientist - uniform = /obj/item/clothing/under/misc/doppler_uniform/science - -/datum/outfit/job/roboticist - uniform = /obj/item/clothing/under/misc/doppler_uniform/science - -/datum/outfit/job/geneticist - uniform = /obj/item/clothing/under/misc/doppler_uniform/science - -// ENGINEERING -/datum/outfit/job/engineer - uniform = /obj/item/clothing/under/misc/doppler_uniform/engineering - -/datum/outfit/job/atmos - uniform = /obj/item/clothing/under/misc/doppler_uniform/engineering - -// CARGO -/datum/outfit/job/cargo_tech - uniform = /obj/item/clothing/under/misc/doppler_uniform/cargo - -/datum/outfit/job/miner - uniform = /obj/item/clothing/under/misc/doppler_uniform/cargo - -/datum/outfit/job/bitrunner - uniform = /obj/item/clothing/under/misc/doppler_uniform/cargo - -// SERVICE -/datum/outfit/job/cook - uniform = /obj/item/clothing/under/misc/doppler_uniform/service - -/datum/outfit/job/bartender - uniform = /obj/item/clothing/under/misc/doppler_uniform/service - -/datum/outfit/job/curator - uniform = /obj/item/clothing/under/misc/doppler_uniform/service - -/datum/outfit/job/psychologist - uniform = /obj/item/clothing/under/misc/doppler_uniform/service - -/datum/outfit/job/chaplain - uniform = /obj/item/clothing/under/misc/doppler_uniform/service - -// COMMAND -/datum/outfit/job/lawyer - uniform = /obj/item/clothing/under/misc/doppler_uniform/command - -/datum/outfit/job/bridge_assistant - uniform = /obj/item/clothing/under/misc/doppler_uniform/command - head = /obj/item/clothing/head/utility/hardhat/welding/doppler_command/performer - -/datum/outfit/job/human_ai - uniform = /obj/item/clothing/under/misc/doppler_uniform/command - head = /obj/item/clothing/head/utility/hardhat/welding/doppler_command/science - -/datum/outfit/job/veteran_advisor - uniform = /obj/item/clothing/under/misc/doppler_uniform/command - head = /obj/item/clothing/head/utility/hardhat/welding/doppler_command/security - -// PERFORMERS -/datum/outfit/job/botanist - uniform = /obj/item/clothing/under/misc/doppler_uniform/performer - -/datum/outfit/job/clown - uniform = /obj/item/clothing/under/misc/doppler_uniform/performer - -/datum/outfit/job/mime - uniform = /obj/item/clothing/under/misc/doppler_uniform/performer - -/datum/outfit/job/janitor - uniform = /obj/item/clothing/under/misc/doppler_uniform/performer - -// SECURITY -/datum/outfit/job/detective - uniform = /obj/item/clothing/under/misc/doppler_uniform/security - -/datum/outfit/job/security - uniform = /obj/item/clothing/under/misc/doppler_uniform/security - -// ASSISTANTS & OTHER UNASSIGNED CREW -/datum/outfit/job - uniform = /obj/item/clothing/under/misc/doppler_uniform/standard/suit/overalls - /datum/colored_assistant/grey jumpsuits = list(/obj/item/clothing/under/misc/doppler_uniform/standard/suit/overalls) jumpskirts = list(/obj/item/clothing/under/misc/doppler_uniform/standard/suit/overalls) // TODO: jumpskirt variants for all of these @@ -201,94 +5,3 @@ /datum/colored_assistant/random jumpsuits = list(/obj/item/clothing/under/misc/doppler_uniform/standard/suit/overalls/random) jumpskirts = list(/obj/item/clothing/under/misc/doppler_uniform/standard/suit/overalls/random) // DITTO: see above - - - -/// BESPOKE UNIFORMS IN APPROPRIATE WARDROBE VENDORS -// Medical -/obj/machinery/vending/wardrobe/medi_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/medical] = 3 - . = ..() - -/obj/machinery/vending/wardrobe/chem_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/medical] = 3 - . = ..() - -/obj/machinery/vending/wardrobe/viro_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/medical] = 3 - . = ..() - -// Science -/obj/machinery/vending/wardrobe/science_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/science] = 3 - . = ..() - -/obj/machinery/vending/wardrobe/gene_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/science] = 3 - . = ..() - -/obj/machinery/vending/wardrobe/robo_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/science] = 3 - . = ..() - -// Engineering -/obj/machinery/vending/wardrobe/engi_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/engineering] = 3 - . = ..() - -/obj/machinery/vending/wardrobe/atmos_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/engineering] = 3 - . = ..() - -// Cargo -/obj/machinery/vending/wardrobe/cargo_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/cargo] = 3 - . = ..() - -// Service -/obj/machinery/vending/wardrobe/bar_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/service] = 3 - . = ..() - -/obj/machinery/vending/wardrobe/chef_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/service] = 3 - . = ..() - -/obj/machinery/vending/wardrobe/curator_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/service] = 3 - . = ..() - -//PSYCH HAS NO DEDICATED WARDROBE - -/obj/machinery/vending/wardrobe/chap_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/service] = 3 - . = ..() - -// Command -/obj/machinery/vending/wardrobe/law_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/command] = 3 - . = ..() - -// Performers/casual crew -/obj/machinery/vending/wardrobe/hydro_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/performer] = 3 - . = ..() - -// Security -/obj/machinery/vending/wardrobe/sec_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/security] = 3 - . = ..() - -/obj/machinery/vending/wardrobe/det_wardrobe/Initialize(mapload) - products[/obj/item/clothing/under/misc/doppler_uniform/security] = 3 - . = ..() - -// Autodrobe -/obj/machinery/vending/autodrobe/Initialize(mapload) - premium[/obj/item/clothing/under/misc/doppler_uniform/standard] = 10 - premium[/obj/item/clothing/under/misc/doppler_uniform/standard/cozy] = 10 - premium[/obj/item/clothing/under/misc/doppler_uniform/standard/suit] = 10 - premium[/obj/item/clothing/under/misc/doppler_uniform/standard/overalls] = 10 - premium[/obj/item/clothing/under/misc/doppler_uniform/standard/cozy/overalls] = 10 - premium[/obj/item/clothing/under/misc/doppler_uniform/standard/suit/overalls] = 10 - . = ..() diff --git a/modular_doppler/modular_vending/code/_vending.dm b/modular_doppler/modular_vending/code/_vending.dm new file mode 100644 index 0000000000000..a9c79e743635e --- /dev/null +++ b/modular_doppler/modular_vending/code/_vending.dm @@ -0,0 +1,82 @@ +#define MINIMUM_CLOTHING_STOCK 5 + +/obj/machinery/vending + /// Additions to the `products` list of the vending machine, modularly. Will become null after Initialize, to free up memory. + var/list/products_doppler + /// Additions to the `product_categories` list of the vending machine, modularly. Will become null after Initialize, to free up memory. + var/list/product_categories_doppler + /// Additions to the `premium` list of the vending machine, modularly. Will become null after Initialize, to free up memory. + var/list/premium_doppler + /// Additions to the `contraband` list of the vending machine, modularly. Will become null after Initialize, to free up memory. + var/list/contraband_doppler + +/obj/machinery/vending/Initialize(mapload) + if(products_doppler) + // We need this, because duplicates screw up the spritesheet! + for(var/item_to_add in products_doppler) + products[item_to_add] = products_doppler[item_to_add] + + if(product_categories_doppler) + for(var/category in product_categories_doppler) + var/already_exists = FALSE + for(var/existing_category in product_categories) + if(existing_category["name"] == category["name"]) + existing_category["products"] += category["products"] + already_exists = TRUE + break + + if(!already_exists) + product_categories += list(category) + + if(premium_doppler) + // We need this, because duplicates screw up the spritesheet! + for(var/item_to_add in premium_doppler) + premium[item_to_add] = premium_doppler[item_to_add] + + if(contraband_doppler) + // We need this, because duplicates screw up the spritesheet! + for(var/item_to_add in contraband_doppler) + contraband[item_to_add] = contraband_doppler[item_to_add] + + // Time to make clothes amounts consistent! + for (var/obj/item/clothing/item in products) + if(products[item] < MINIMUM_CLOTHING_STOCK && allow_increase(item)) + products[item] = MINIMUM_CLOTHING_STOCK + + for (var/category in product_categories) + for(var/obj/item/clothing/item in category["products"]) + if(category["products"][item] < MINIMUM_CLOTHING_STOCK && allow_increase(item)) + category["products"][item] = MINIMUM_CLOTHING_STOCK + + for (var/obj/item/clothing/item in premium) + if(premium[item] < MINIMUM_CLOTHING_STOCK && allow_increase(item)) + premium[item] = MINIMUM_CLOTHING_STOCK + + QDEL_NULL(products_doppler) + QDEL_NULL(product_categories_doppler) + QDEL_NULL(premium_doppler) + QDEL_NULL(contraband_doppler) + return ..() + +/// This proc checks for forbidden traits cause it'd be pretty bad to have 5 insuls available to assistants roundstart at the vendor! +/obj/machinery/vending/proc/allow_increase(obj/item/clothing/clothing_path) + var/obj/item/clothing/clothing = new clothing_path() + + // Ignore earmuffs! + if(TRAIT_DEAF in clothing.clothing_traits) + return FALSE + // Don't touch sunglasses or welding helmets! + if(clothing.flash_protect == FLASH_PROTECTION_WELDER) + return FALSE + // Don't touch bodyarmour! + if(ispath(clothing, /obj/item/clothing/suit/armor)) + return FALSE + // Don't touch protective helmets, like riot helmets! + if(ispath(clothing, /obj/item/clothing/head/helmet)) + return FALSE + // Ignore all gloves, because it's almost impossible to check what they do... + if(ispath(clothing, /obj/item/clothing/gloves)) + return FALSE + return TRUE + +#undef MINIMUM_CLOTHING_STOCK diff --git a/modular_doppler/deforest_medical_items/code/vendor.dm b/modular_doppler/modular_vending/code/doppler_vendors/de_forest/vendor.dm similarity index 97% rename from modular_doppler/deforest_medical_items/code/vendor.dm rename to modular_doppler/modular_vending/code/doppler_vendors/de_forest/vendor.dm index a91b390d9333e..265bf226425eb 100644 --- a/modular_doppler/deforest_medical_items/code/vendor.dm +++ b/modular_doppler/modular_vending/code/doppler_vendors/de_forest/vendor.dm @@ -1,7 +1,7 @@ /obj/machinery/vending/deforest_medvend name = "\improper DeForest Med-Vend" desc = "A vending machine providing a selection of medical supplies." - icon = 'modular_doppler/deforest_medical_items/icons/vendor.dmi' + icon = 'modular_doppler/modular_vending/icons/de_forest_vendors.dmi' icon_state = "medvend" panel_type = "panel15" light_mask = "medvend-light-mask" diff --git a/modular_doppler/vending_machines/readme.md b/modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/readme.md similarity index 100% rename from modular_doppler/vending_machines/readme.md rename to modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/readme.md diff --git a/modular_doppler/vending_machines/code/vendor_containers.dm b/modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/vendor_containers.dm similarity index 98% rename from modular_doppler/vending_machines/code/vendor_containers.dm rename to modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/vendor_containers.dm index 7feb74dfbcfd6..f28cd8c1dc187 100644 --- a/modular_doppler/vending_machines/code/vendor_containers.dm +++ b/modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/vendor_containers.dm @@ -1,7 +1,7 @@ /obj/item/storage/box/foodpack name = "wrapped meal container" desc = "A generic brown paper food package, you aren't quite sure where this comes from." - icon = 'modular_doppler/vending_machines/icons/imported_quick_foods.dmi' + icon = 'modular_doppler/modular_vending/icons/imported_quick_foods.dmi' icon_state = "foodpack_generic_big" illustration = null custom_price = PAYCHECK_CREW * 1.8 diff --git a/modular_doppler/vending_machines/code/vendor_food.dm b/modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/vendor_food.dm similarity index 98% rename from modular_doppler/vending_machines/code/vendor_food.dm rename to modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/vendor_food.dm index 2e036b9ec31a2..129a1af0a3a8e 100644 --- a/modular_doppler/vending_machines/code/vendor_food.dm +++ b/modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/vendor_food.dm @@ -5,7 +5,7 @@ /obj/item/trash/empty_food_tray name = "empty plastic food tray" desc = "The condensation and what you can only hope are the leftovers of food make this a bit hard to reuse." - icon = 'modular_doppler/vending_machines/icons/imported_quick_foods.dmi' + icon = 'modular_doppler/modular_vending/icons/imported_quick_foods.dmi' icon_state = "foodtray_empty" custom_materials = list( /datum/material/plastic = HALF_SHEET_MATERIAL_AMOUNT, @@ -14,7 +14,7 @@ /obj/item/trash/empty_side_pack name = "empty side wrapper" desc = "Unfortunately, this no longer holds any sides to distract you from the other 'food'." - icon = 'modular_doppler/vending_machines/icons/imported_quick_foods.dmi' + icon = 'modular_doppler/modular_vending/icons/imported_quick_foods.dmi' icon_state = "foodpack_generic_trash" custom_materials = list( /datum/material/plastic = HALF_SHEET_MATERIAL_AMOUNT, @@ -41,7 +41,7 @@ /obj/item/food/vendor_tray_meal name = "\improper NT-Meal: Steak and Macaroni" desc = "A 'salisbury steak' drowning in something similar to a gravy, with a macaroni and cheese substitute mix sitting right beside it." - icon = 'modular_doppler/vending_machines/icons/imported_quick_foods.dmi' + icon = 'modular_doppler/modular_vending/icons/imported_quick_foods.dmi' icon_state = "foodtray_sad_steak" trash_type = /obj/item/trash/empty_food_tray food_reagents = list(/datum/reagent/consumable/nutriment = 8) diff --git a/modular_doppler/vending_machines/code/vendor_snacks.dm b/modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/vendor_snacks.dm similarity index 98% rename from modular_doppler/vending_machines/code/vendor_snacks.dm rename to modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/vendor_snacks.dm index 0b5fd481f2b4d..fc034a2874e74 100644 --- a/modular_doppler/vending_machines/code/vendor_snacks.dm +++ b/modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/vendor_snacks.dm @@ -3,7 +3,7 @@ /obj/item/food/vendor_snacks name = "\improper God's Strongest Snacks" desc = "You best hope you aren't a sinner. (You should never see this item please report it)" - icon = 'modular_doppler/vending_machines/icons/imported_quick_foods.dmi' + icon = 'modular_doppler/modular_vending/icons/imported_quick_foods.dmi' icon_state = "foodpack_generic" trash_type = /obj/item/trash/vendor_trash bite_consumption = 10 @@ -17,7 +17,7 @@ /obj/item/trash/vendor_trash name = "\improper God's Weakest Snacks" desc = "The leftovers of what was likely a great snack in a past time." - icon = 'modular_doppler/vending_machines/icons/imported_quick_foods.dmi' + icon = 'modular_doppler/modular_vending/icons/imported_quick_foods.dmi' icon_state = "foodpack_generic_trash" custom_materials = list( /datum/material/plastic = HALF_SHEET_MATERIAL_AMOUNT, @@ -86,7 +86,7 @@ /obj/item/reagent_containers/cup/glass/waterbottle/tea name = "bottle of tea" desc = "A bottle of tea brought to you in a convenient plastic bottle." - icon = 'modular_doppler/vending_machines/icons/imported_quick_foods.dmi' + icon = 'modular_doppler/modular_vending/icons/imported_quick_foods.dmi' icon_state = "tea_bottle" list_reagents = list(/datum/reagent/consumable/tea = 40) cap_icon_state = "bottle_cap_tea" diff --git a/modular_doppler/vending_machines/code/vendors.dm b/modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/vendors.dm similarity index 99% rename from modular_doppler/vending_machines/code/vendors.dm rename to modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/vendors.dm index 2af2490c47b3c..630e17790d0c0 100644 --- a/modular_doppler/vending_machines/code/vendors.dm +++ b/modular_doppler/modular_vending/code/doppler_vendors/imported_vendors/vendors.dm @@ -22,7 +22,7 @@ new vendor_refill(target_crate) /obj/machinery/vending/imported - icon = 'modular_doppler/vending_machines/icons/imported_vendors.dmi' + icon = 'modular_doppler/modular_vending/icons/imported_vendors.dmi' icon_state = null panel_type = "panel15" default_price = PAYCHECK_CREW * 0.5 diff --git a/modular_doppler/modular_vending/code/tg_vendors/autodrobe.dm b/modular_doppler/modular_vending/code/tg_vendors/autodrobe.dm new file mode 100644 index 0000000000000..698dfef8aa29d --- /dev/null +++ b/modular_doppler/modular_vending/code/tg_vendors/autodrobe.dm @@ -0,0 +1,81 @@ +/obj/machinery/vending/autodrobe + product_categories_doppler = list( + list( + "name" = "Costumes", + "icon" = "mask", + "products" = list( + /obj/item/clothing/head/costume/sombrero = 5, + ), + ), + list( + "name" = "Entertainers", + "icon" = "masks-theater", + "products" = list( + /obj/item/clothing/under/misc/doppler_uniform/performer = 3, + /obj/item/clothing/head/costume/jesteralt = 1, + /obj/item/clothing/under/rank/civilian/clown/jesteralt = 1, + ), + ), +/* list( + "name" = "Fancy", + "icon" = "user-tie", + "products" = list( + /obj/item/clothing/head/beret/badge = 5, + /obj/item/clothing/mask/masquerade = 25, + /obj/item/clothing/mask/masquerade/two_colors = 25, + /obj/item/clothing/mask/masquerade/feathered = 25, + /obj/item/clothing/mask/masquerade/two_colors/feathered = 25, + ), + ), */ + list( + "name" = "Service", + "icon" = "kitchen-set", + "products" = list( + /obj/item/clothing/under/costume/buttondown/slacks/service = 1, + /obj/item/clothing/under/costume/buttondown/skirt/service = 1, + /obj/item/clothing/neck/bowtie = 2, + /obj/item/clothing/accessory/waistcoat = 1, + /obj/item/clothing/under/suit/waiter = 1, + /obj/item/clothing/suit/apron = 1, + /obj/item/clothing/suit/apron/overalls = 1, + /obj/item/clothing/head/costume/maidheadband = 1, + /obj/item/clothing/under/costume/maid = 1, + /obj/item/clothing/gloves/maid = 1, + /obj/item/clothing/neck/maid = 1, + /obj/item/clothing/under/rank/civilian/janitor/maid = 1, + /obj/item/clothing/accessory/maidapron = 1, + // /obj/item/clothing/gloves/maid_arm_covers = 1, + /obj/item/clothing/neck/maid_neck_cover = 1, + // /obj/item/clothing/under/maid_costume = 1, + // /obj/item/clothing/head/maid_headband = 1, + ), + ), + list( + "name" = "Undersuit", + "icon" = "shirt", + "products" = list( + /obj/item/clothing/under/misc/doppler_uniform/standard = 5, + /obj/item/clothing/under/misc/doppler_uniform/standard/cozy = 5, + /obj/item/clothing/under/misc/doppler_uniform/standard/suit = 5, + /obj/item/clothing/under/misc/doppler_uniform/standard/overalls = 5, + /obj/item/clothing/under/misc/doppler_uniform/standard/cozy/overalls = 5, + /obj/item/clothing/under/misc/doppler_uniform/standard/suit/overalls = 5, + ), + ), + +/* list( + "name" = "Other", + "icon" = "star", + "products" = list( + + ), + ), */ + ) + +/* contraband_doppler = list( + + ) */ + +/* premium_doppler = list( + + ) */ diff --git a/modular_doppler/modular_vending/code/tg_vendors/boozeomat.dm b/modular_doppler/modular_vending/code/tg_vendors/boozeomat.dm new file mode 100644 index 0000000000000..9d782a07e8dc3 --- /dev/null +++ b/modular_doppler/modular_vending/code/tg_vendors/boozeomat.dm @@ -0,0 +1,10 @@ +/obj/machinery/vending/boozeomat + product_categories_doppler = list( + list( + "name" = "Synth", + "icon" = "robot", + "products" = list( + // /obj/item/reagent_containers/cup/soda_cans/doppler/synthanolcan = 6, + ), + ), + ) diff --git a/modular_doppler/modular_vending/code/tg_vendors/clothesmate.dm b/modular_doppler/modular_vending/code/tg_vendors/clothesmate.dm new file mode 100644 index 0000000000000..04e0c5b0599c3 --- /dev/null +++ b/modular_doppler/modular_vending/code/tg_vendors/clothesmate.dm @@ -0,0 +1,68 @@ +/obj/machinery/vending/clothing + product_categories_doppler = list( + list( + "name" = "Head", + "icon" = "hat-cowboy", + "products" = list( + /obj/item/clothing/head/fedora= 5, + /obj/item/clothing/head/fedora/beige = 5, + /obj/item/clothing/head/fedora/white = 5, + /obj/item/clothing/head/standalone_hood = 5, + // /obj/item/clothing/head/small_bow = 5, + // /obj/item/clothing/head/large_bow = 5, + // /obj/item/clothing/head/back_bow = 5, + // /obj/item/clothing/head/sweet_bow = 5, + ), + ), + + list( + "name" = "Accessories", + "icon" = "glasses", + "products" = list( + /obj/item/clothing/neck/ranger_poncho = 5, + /obj/item/clothing/neck/mantle/recolorable = 5, + /obj/item/clothing/neck/long_cape = 5, + /obj/item/clothing/neck/wide_cape = 5, + /obj/item/clothing/neck/robe_cape = 5, + /obj/item/clothing/neck/face_scarf = 5, + ), + ), + +/* list( + "name" = "Under", + "icon" = "shirt", + "products" = list( + + ), + ), */ + + list( + "name" = "Suits & Skirts", + "icon" = "vest", + "products" = list( + // /obj/item/clothing/under/dress/doppler/pinktutu = 5, + // /obj/item/clothing/under/dress/doppler/flower = 5, + // /obj/item/clothing/under/dress/doppler/strapless = 5, + // /obj/item/clothing/under/dress/doppler/pentagram = 5, + /obj/item/clothing/suit/jacket/doppler/departmental_jacket = 5, + ), + ), + +/* list( + "name" = "Shoes", + "icon" = "socks", + "products" = list( + ), + ), */ + +/* //Only put clothing in Special thats either Families or exteremly out-of-place + list( + "name" = "Special", + "icon" = "star", + "products" = list( + ) + ) */ + ) + +/* premium_doppler = list( //being here means you're artificially rare, congratulations + ) */ diff --git a/modular_doppler/modular_vending/code/tg_vendors/cola.dm b/modular_doppler/modular_vending/code/tg_vendors/cola.dm new file mode 100644 index 0000000000000..421602bd042c5 --- /dev/null +++ b/modular_doppler/modular_vending/code/tg_vendors/cola.dm @@ -0,0 +1,5 @@ +/obj/machinery/vending/cola + products_doppler = list( + /obj/item/reagent_containers/cup/soda_cans/doppler/lubricola = 10, + /obj/item/reagent_containers/cup/soda_cans/doppler/welding_fizz = 10, + ) diff --git a/modular_doppler/modular_vending/code/tg_vendors/engivend.dm b/modular_doppler/modular_vending/code/tg_vendors/engivend.dm new file mode 100644 index 0000000000000..999e4d4ab489a --- /dev/null +++ b/modular_doppler/modular_vending/code/tg_vendors/engivend.dm @@ -0,0 +1,7 @@ +/obj/machinery/vending/engivend + products_doppler = list( + /obj/item/clothing/glasses/meson/engine = 5, + /obj/item/construction/rcd/loaded = 3, + /obj/item/forcefield_projector = 4, + /obj/item/storage/bag/construction = 2, + ) diff --git a/modular_doppler/modular_vending/code/tg_vendors/games.dm b/modular_doppler/modular_vending/code/tg_vendors/games.dm new file mode 100644 index 0000000000000..a1d16bb0cead3 --- /dev/null +++ b/modular_doppler/modular_vending/code/tg_vendors/games.dm @@ -0,0 +1,20 @@ +/obj/machinery/vending/games + product_categories_doppler = list( + list( + "name" = "Toys", + "icon" = "hat-wizard", + "products" = list( + /obj/item/storage/briefcase/secure/wargame_kit = 3, + ), + ), + list( + "name" = "Hair", + "icon" = "scissors", + "products" = list( + // /obj/item/hairbrush = 3, + /obj/item/clothing/head/hair_tie = 3, + /obj/item/clothing/head/hair_tie/scrunchie = 3, + /obj/item/clothing/head/hair_tie/plastic_beads = 3, + ), + ) + ) diff --git a/modular_doppler/modular_vending/code/tg_vendors/megaseed.dm b/modular_doppler/modular_vending/code/tg_vendors/megaseed.dm new file mode 100644 index 0000000000000..5f09d759e9dd1 --- /dev/null +++ b/modular_doppler/modular_vending/code/tg_vendors/megaseed.dm @@ -0,0 +1,4 @@ +/obj/machinery/vending/hydroseeds //sneed + contraband_doppler = list( + /obj/item/seeds/tea/catnip = 3, + ) diff --git a/modular_doppler/modular_vending/code/tg_vendors/wardrobes.dm b/modular_doppler/modular_vending/code/tg_vendors/wardrobes.dm new file mode 100644 index 0000000000000..084868b7c6da6 --- /dev/null +++ b/modular_doppler/modular_vending/code/tg_vendors/wardrobes.dm @@ -0,0 +1,130 @@ +/obj/machinery/vending/wardrobe/medi_wardrobe + products_doppler = list( + /obj/item/clothing/under/misc/doppler_uniform/medical = 5, + /obj/item/radio/headset/headset_med = 3, + /obj/item/clothing/gloves/latex/nitrile = 2, + /obj/item/clothing/suit/toggle/labcoat/hospitalgown = 5, + // /obj/item/storage/belt/medbandolier = 2, + /obj/item/clothing/suit/jacket/doppler/departmental_jacket/med = 2, + ) + +/obj/machinery/vending/wardrobe/engi_wardrobe + products_doppler = list( + /obj/item/clothing/under/misc/doppler_uniform/engineering = 5, + /obj/item/radio/headset/headset_eng = 3, + /obj/item/clothing/under/misc/overalls = 3, + /obj/item/clothing/suit/jacket/doppler/departmental_jacket/engi = 3, + /obj/item/clothing/head/utility/hardhat/orange = 2, + /obj/item/clothing/head/utility/hardhat/welding/orange = 2, + /obj/item/clothing/head/utility/hardhat/dblue = 2, + /obj/item/clothing/head/utility/hardhat/welding/dblue = 2, + /obj/item/clothing/head/utility/hardhat/red = 2, + ) + +/obj/machinery/vending/wardrobe/atmos_wardrobe + products_doppler = list( + /obj/item/clothing/glasses/meson/engine = 2, + /obj/item/clothing/head/beret/atmos = 4, + ) + +/obj/machinery/vending/wardrobe/cargo_wardrobe + products_doppler = list( + /obj/item/clothing/suit/jacket/doppler/departmental_jacket/supply = 3, + /obj/item/clothing/under/misc/doppler_uniform/cargo = 5, + ) + +/obj/machinery/vending/wardrobe/robo_wardrobe + products_doppler = list( + /obj/item/clothing/head/beret/science/fancy/robo = 2, + /obj/item/tank/internals/anesthetic = 2, + /obj/item/clothing/mask/breath = 2, + /obj/item/reagent_containers/cup/bottle/morphine = 2, + /obj/item/reagent_containers/syringe = 2, +// /obj/item/reagent_containers/spray/hercuri/chilled = 2, +// /obj/item/reagent_containers/spray/dinitrogen_plasmide = 2, + /obj/item/clothing/gloves/color/black = 2, // fire resistant, allows the robo to painlessly mold metal. also it's down here because it's a treatment item + /obj/item/bonesetter = 2, // for dislocations + /obj/item/stack/medical/gauze = 4, // for ALL wounds + /obj/item/healthanalyzer/simple = 2, + /obj/item/storage/backpack/custom = 2, + /obj/item/storage/backpack/satchel/custom = 2, + /obj/item/storage/backpack/duffelbag/custom = 2, + ) + +/obj/machinery/vending/wardrobe/science_wardrobe + products_doppler = list( + /obj/item/clothing/under/misc/doppler_uniform/science = 5, + /obj/item/clothing/suit/jacket/doppler/departmental_jacket/sci = 3, + ) + +/obj/machinery/vending/wardrobe/sec_wardrobe + products_doppler = list( + /obj/item/clothing/under/misc/doppler_uniform/security = 5, + /obj/item/clothing/suit/jacket/doppler/departmental_jacket/sec = 3, + ) + + +/*/obj/machinery/vending/wardrobe/hydro_wardrobe + products_doppler = list( + ) */ + +/*/obj/machinery/vending/wardrobe/bar_wardrobe + products_doppler = list( + ) */ + +/obj/machinery/vending/wardrobe/chap_wardrobe + products_doppler = list( + /obj/item/clothing/suit/costume/nemes = 1, + /obj/item/clothing/head/costume/nemes = 1, + /obj/item/clothing/head/costume/pharaoh = 1, + ) + +/obj/machinery/vending/wardrobe/chef_wardrobe + products_doppler = list( + /obj/item/clothing/under/misc/doppler_uniform/service = 5, + ) + +/obj/machinery/vending/cart + products_doppler = list( + /obj/item/radio/headset/headset_srv = 3, + ) + +/obj/machinery/vending/wardrobe/chem_wardrobe + products_doppler = list( +// /obj/item/clothing/under/rank/medical/chemist/doppler/formal = 2, +// /obj/item/clothing/under/rank/medical/chemist/doppler/formal/skirt = 2, + /obj/item/clothing/head/beret/medical/chemist = 2, + ) + +/obj/machinery/vending/wardrobe/viro_wardrobe + products_doppler = list( + /obj/item/clothing/head/beret/medical/virologist = 2, + ) + +/obj/machinery/vending/wardrobe/det_wardrobe + products_doppler = list( + /obj/item/clothing/head/fedora/beige = 2, + /obj/item/clothing/head/fedora/white = 2, + ) + +/*/obj/machinery/vending/wardrobe/law_wardrobe + products_doppler = list( + ) */ + + +/// Removes given list of products. Must be called before build_inventory() to actually prevent the records from being created. +/obj/machinery/vending/proc/remove_products(list/paths_to_remove) + if(!length(paths_to_remove)) + return + for(var/typepath as anything in products) + for(var/to_remove as anything in paths_to_remove) + if(ispath(typepath, to_remove)) + products.Remove(typepath) + +/obj/machinery/vending/ + /// list of products to exclude when building the vending machine's inventory + var/list/excluded_products + +/obj/machinery/vending/Initialize(mapload) + remove_products(excluded_products) + return ..() diff --git a/modular_doppler/deforest_medical_items/icons/vendor.dmi b/modular_doppler/modular_vending/icons/de_forest_vendors.dmi similarity index 100% rename from modular_doppler/deforest_medical_items/icons/vendor.dmi rename to modular_doppler/modular_vending/icons/de_forest_vendors.dmi diff --git a/modular_doppler/vending_machines/icons/imported_quick_foods.dmi b/modular_doppler/modular_vending/icons/imported_quick_foods.dmi similarity index 100% rename from modular_doppler/vending_machines/icons/imported_quick_foods.dmi rename to modular_doppler/modular_vending/icons/imported_quick_foods.dmi diff --git a/modular_doppler/vending_machines/icons/imported_vendors.dmi b/modular_doppler/modular_vending/icons/imported_vendors.dmi similarity index 100% rename from modular_doppler/vending_machines/icons/imported_vendors.dmi rename to modular_doppler/modular_vending/icons/imported_vendors.dmi diff --git a/tgstation.dme b/tgstation.dme index 20bf564f7bb36..8bafbc64b943d 100644 --- a/tgstation.dme +++ b/tgstation.dme @@ -6523,7 +6523,6 @@ #include "modular_doppler\deforest_medical_items\code\medstation.dm" #include "modular_doppler\deforest_medical_items\code\storage_items.dm" #include "modular_doppler\deforest_medical_items\code\treatment_zone_projector.dm" -#include "modular_doppler\deforest_medical_items\code\vendor.dm" #include "modular_doppler\deforest_medical_items\code\vulnerable_status_effect.dm" #include "modular_doppler\deforest_medical_items\code\chemicals\demoneye.dm" #include "modular_doppler\deforest_medical_items\code\chemicals\twitch.dm" @@ -6644,6 +6643,7 @@ #include "modular_doppler\modular_antagonists\sapper_gang\code\creditminer.dm" #include "modular_doppler\modular_antagonists\sapper_gang\code\paper_premade.dm" #include "modular_doppler\modular_antagonists\sapper_gang\code\sapperpad.dm" +#include "modular_doppler\modular_cosmetics\code\garment_bag_overrides.dm" #include "modular_doppler\modular_cosmetics\code\jacket_pockets.dm" #include "modular_doppler\modular_cosmetics\code\towels.dm" #include "modular_doppler\modular_cosmetics\code\uniform_overrides.dm" @@ -6824,6 +6824,20 @@ #include "modular_doppler\modular_species\species_types\snails\snail_bodyparts.dm" #include "modular_doppler\modular_species\species_types\snails\organs\snail_heart.dm" #include "modular_doppler\modular_species\species_types\snails\organs\snail_liver.dm" +#include "modular_doppler\modular_vending\code\_vending.dm" +#include "modular_doppler\modular_vending\code\doppler_vendors\de_forest\vendor.dm" +#include "modular_doppler\modular_vending\code\doppler_vendors\imported_vendors\vendor_containers.dm" +#include "modular_doppler\modular_vending\code\doppler_vendors\imported_vendors\vendor_food.dm" +#include "modular_doppler\modular_vending\code\doppler_vendors\imported_vendors\vendor_snacks.dm" +#include "modular_doppler\modular_vending\code\doppler_vendors\imported_vendors\vendors.dm" +#include "modular_doppler\modular_vending\code\tg_vendors\autodrobe.dm" +#include "modular_doppler\modular_vending\code\tg_vendors\boozeomat.dm" +#include "modular_doppler\modular_vending\code\tg_vendors\clothesmate.dm" +#include "modular_doppler\modular_vending\code\tg_vendors\cola.dm" +#include "modular_doppler\modular_vending\code\tg_vendors\engivend.dm" +#include "modular_doppler\modular_vending\code\tg_vendors\games.dm" +#include "modular_doppler\modular_vending\code\tg_vendors\megaseed.dm" +#include "modular_doppler\modular_vending\code\tg_vendors\wardrobes.dm" #include "modular_doppler\modular_weapons\code\gunsets.dm" #include "modular_doppler\modular_weapons\company_and_or_faction_based\carwo_defense_systems\gunsets.dm" #include "modular_doppler\modular_weapons\manufacturer_examine\code\gun_company_additions.dm" @@ -6867,10 +6881,6 @@ #include "modular_doppler\time_clock\code\off_duty_component.dm" #include "modular_doppler\time_clock\code\sign.dm" #include "modular_doppler\tool_poweruse\items.dm" -#include "modular_doppler\vending_machines\code\vendor_containers.dm" -#include "modular_doppler\vending_machines\code\vendor_food.dm" -#include "modular_doppler\vending_machines\code\vendor_snacks.dm" -#include "modular_doppler\vending_machines\code\vendors.dm" #include "modular_doppler\verbs\code\communication.dm" #include "modular_doppler\verbs\code\do_checks.dm" #include "modular_doppler\verbs\code\do_verbs.dm" From 5355c9c681006fe519717cfc37c9a2be642e4c96 Mon Sep 17 00:00:00 2001 From: "Lila S." Date: Wed, 25 Sep 2024 23:44:34 +0200 Subject: [PATCH 2/4] hairbrush --- .../modular_items/hairbrush/code/hairbrush.dm | 56 ++++++++++++++++++ .../hairbrush/icons/hairbrush.dmi | Bin 0 -> 351 bytes .../hairbrush/icons/inhand_left.dmi | Bin 0 -> 296 bytes .../hairbrush/icons/inhand_right.dmi | Bin 0 -> 297 bytes .../modular_mood/code/mood_events/brushed.dm | 14 +++++ .../code/tg_vendors/clothesmate.dm | 1 - .../modular_vending/code/tg_vendors/games.dm | 2 +- tgstation.dme | 2 + 8 files changed, 73 insertions(+), 2 deletions(-) create mode 100644 modular_doppler/modular_items/hairbrush/code/hairbrush.dm create mode 100644 modular_doppler/modular_items/hairbrush/icons/hairbrush.dmi create mode 100644 modular_doppler/modular_items/hairbrush/icons/inhand_left.dmi create mode 100644 modular_doppler/modular_items/hairbrush/icons/inhand_right.dmi create mode 100644 modular_doppler/modular_mood/code/mood_events/brushed.dm diff --git a/modular_doppler/modular_items/hairbrush/code/hairbrush.dm b/modular_doppler/modular_items/hairbrush/code/hairbrush.dm new file mode 100644 index 0000000000000..dd31f7e954fa3 --- /dev/null +++ b/modular_doppler/modular_items/hairbrush/code/hairbrush.dm @@ -0,0 +1,56 @@ +/obj/item/hairbrush + name = "hairbrush" + desc = "A small, circular brush with an ergonomic grip for efficient brush application." + icon = 'modular_doppler/modular_items/hairbrush/icons/hairbrush.dmi' + icon_state = "brush" + inhand_icon_state = "inhand" + lefthand_file = 'modular_doppler/modular_items/hairbrush/icons/inhand_left.dmi' + righthand_file = 'modular_doppler/modular_items/hairbrush/icons/inhand_right.dmi' + w_class = WEIGHT_CLASS_TINY + var/brush_speed = 3 SECONDS + +/obj/item/hairbrush/attack(mob/target, mob/user) + if(target.stat == DEAD) + to_chat(usr, span_warning("There isn't much point brushing someone who can't appreciate it!")) + return + brush(target, user) + return COMPONENT_CANCEL_ATTACK_CHAIN + +/// Brushes someone, giving them a small mood boost +/obj/item/hairbrush/proc/brush(mob/living/target, mob/user) + if(ishuman(target)) + var/mob/living/carbon/human/human_target = target + var/obj/item/bodypart/head = human_target.get_bodypart(BODY_ZONE_HEAD) + + // Don't brush if you can't reach their head or cancel the action + if(!head) + to_chat(user, span_warning("[human_target] has no head!")) + return + if(human_target.is_mouth_covered(ITEM_SLOT_HEAD)) + to_chat(user, span_warning("You can't brush [human_target]'s hair while [human_target.p_their()] head is covered!")) + return + if(!do_after(user, brush_speed, human_target)) + return + + // Do 1 brute to their head if they're bald. Should've been more careful. + if(human_target.hairstyle == "Bald" || human_target.hairstyle == "Skinhead" && is_species(human_target, /datum/species/human)) //It can be assumed most anthros have hair on them! + human_target.visible_message(span_warning("[usr] scrapes the bristles uncomfortably over [human_target]'s scalp."), span_warning("You scrape the bristles uncomfortably over [human_target]'s scalp.")) + head.receive_damage(1) + return + + // Brush their hair + if(human_target == user) + human_target.visible_message(span_notice("[usr] brushes [usr.p_their()] hair!"), span_notice("You brush your hair.")) + human_target.add_mood_event("brushed", /datum/mood_event/brushed/self) + else + user.visible_message(span_notice("[usr] brushes [human_target]'s hair!"), span_notice("You brush [human_target]'s hair."), ignored_mobs=list(human_target)) + human_target.show_message(span_notice("[usr] brushes your hair!"), MSG_VISUAL) + human_target.add_mood_event("brushed", /datum/mood_event/brushed, user) + + else if(istype(target, /mob/living/basic/pet)) + if(!do_after(usr, brush_speed, target)) + return + to_chat(user, span_notice("[target] closes [target.p_their()] eyes as you brush [target.p_them()]!")) + var/mob/living/living_user = user + if(istype(living_user)) + living_user.add_mood_event("brushed", /datum/mood_event/brushed/pet, target) diff --git a/modular_doppler/modular_items/hairbrush/icons/hairbrush.dmi b/modular_doppler/modular_items/hairbrush/icons/hairbrush.dmi new file mode 100644 index 0000000000000000000000000000000000000000..04ac93a3a11b70c67b4a802bd5693fe7c9e264e7 GIT binary patch literal 351 zcmV-l0igbgP)*X%3%p{kzyn`1000001bW%=J06^y0W&i*HX?j#xbVOxyV{&P5 zbZKvH004NLQ&wJEB62Z z0DwtEK~yM_y^ygD#4rd&Z6z517guM6$Qj@yiwVM?;r8DkxciXqiqQG#89tQqUWv4w z-?jInF*srUAZ1ZFA!UUs1}U4F!5Fxqpg+?vj23#RUep!SV4zbOVXhk?t0%i8gjam4 xg#CQOsFZnwJ%gmwtkj1hpA3GFCTYySbp!W-7a(&7Q0)K!002ovPDHLkV1m?6m0SP- literal 0 HcmV?d00001 diff --git a/modular_doppler/modular_items/hairbrush/icons/inhand_left.dmi b/modular_doppler/modular_items/hairbrush/icons/inhand_left.dmi new file mode 100644 index 0000000000000000000000000000000000000000..f229f605918d46b08d13bbce6a4eb4bf2ebe4c86 GIT binary patch literal 296 zcmeAS@N?(olHy`uVBq!ia0vp^4j|0J3?w7mbKU|e{s5m4*8>L**q?ay@%7VJchBps zJtK0PGvSI(O!L@P<%>i^dNg>74h`Jjqbh)4RjMILP?2v6sS}N0W|B3Q-8wG}c!()OYRd zHdfudLSjjGxA9sHLvzt1W>12`3ceOI&gNza*OqFy{BB_p(Aoe`7sn8f&g29MR%Iar zp`Zmi4i1fz6d754npk8XI(V?kY!C=?*b}%oL8OOCiaF;gw^!$)mdJe@Bo=A}91J+H prsYiXp`=!(S)CR!=3FaS7<@9BwERxA`T)&l@O1TaS?83{1ORi&YV!a9 literal 0 HcmV?d00001 diff --git a/modular_doppler/modular_items/hairbrush/icons/inhand_right.dmi b/modular_doppler/modular_items/hairbrush/icons/inhand_right.dmi new file mode 100644 index 0000000000000000000000000000000000000000..d021f4ea64da7dda21814b7b3affc6b09c6e0b68 GIT binary patch literal 297 zcmeAS@N?(olHy`uVBq!ia0vp^4j|0J3?w7mbKU|e{s5m4*8>L**q?ay>hAfEub=9z zJu~Z`NH$Q4u_VYZn8D%MjWi%9yDB82#3i*jxhS)sBr`vcfuUkfa9BZ6>GvSI(O!L@P<%>i^dNg>74h`Jjqbh)4RjMILP?2v6sS}N0W|B3Q-8wG}c!()OYRd zHdfudLSjjGxA9sHLvzt1W>12`3ceOI&gNza*OqFy{BB_p(Aq#x7sn8f&g29MR%Lz; zfeGm$Y6~1r%xGY8Wd8F>r)5q9vxPv=0jGI87bl4HFl8}4;W^jgI!|yXhhfoykOw_$ q4n#0^3!X^jF Date: Thu, 26 Sep 2024 01:05:38 +0200 Subject: [PATCH 3/4] the rest --- .../loadout_categories/categories/heads.dm | 16 ++++++++ .../categories/undersuit.dm | 16 ++++++++ .../GAGS/greyscale_configs_head.dm | 38 ++++++++++++++++++ .../GAGS/greyscale_configs_under.dm | 22 ++++++++++ .../GAGS/icons/mob/under.dmi | Bin 809 -> 1025 bytes .../GAGS/icons/obj/under.dmi | Bin 415 -> 549 bytes .../GAGS/json_configs/head/back_bow.json | 10 +++++ .../GAGS/json_configs/head/large_bow.json | 10 +++++ .../GAGS/json_configs/head/small_bow.json | 18 +++++++++ .../GAGS/json_configs/head/sweet_bow.json | 10 +++++ .../json_configs/under/pentagram_dress.json | 10 +++++ .../json_configs/under/strapless_dress.json | 16 ++++++++ .../code/belt/med_bandolier.dm | 25 ++++++++++++ .../modular_cosmetics/code/head/bows.dm | 38 ++++++++++++++++++ .../modular_cosmetics/code/under/dresses.dm | 38 ++++++++++++++++++ .../code/under/medical_extra.dm | 18 +++++++++ .../icons/mob/belt/medical_extra.dmi | Bin 0 -> 761 bytes .../icons/mob/under/dresses.dmi | Bin 0 -> 2263 bytes .../icons/mob/under/medical_extra.dmi | Bin 0 -> 914 bytes .../icons/obj/belt/medical_extra.dmi | Bin 0 -> 494 bytes .../icons/obj/under/dresses.dmi | Bin 0 -> 2240 bytes .../icons/obj/under/medical_extra.dmi | Bin 0 -> 403 bytes .../modular_cosmetics/toggle_clothes.dm | 30 ++++++++++++++ .../modular_crafting/code/sheet_types.dm | 1 + .../code/tg_vendors/autodrobe.dm | 31 -------------- .../code/tg_vendors/clothesmate.dm | 16 ++++---- .../code/tg_vendors/engivend.dm | 1 - .../code/tg_vendors/wardrobes.dm | 6 +-- tgstation.dme | 5 +++ 29 files changed, 332 insertions(+), 43 deletions(-) create mode 100644 modular_doppler/modular_cosmetics/GAGS/json_configs/head/back_bow.json create mode 100644 modular_doppler/modular_cosmetics/GAGS/json_configs/head/large_bow.json create mode 100644 modular_doppler/modular_cosmetics/GAGS/json_configs/head/small_bow.json create mode 100644 modular_doppler/modular_cosmetics/GAGS/json_configs/head/sweet_bow.json create mode 100644 modular_doppler/modular_cosmetics/GAGS/json_configs/under/pentagram_dress.json create mode 100644 modular_doppler/modular_cosmetics/GAGS/json_configs/under/strapless_dress.json create mode 100644 modular_doppler/modular_cosmetics/code/belt/med_bandolier.dm create mode 100644 modular_doppler/modular_cosmetics/code/head/bows.dm create mode 100644 modular_doppler/modular_cosmetics/code/under/dresses.dm create mode 100644 modular_doppler/modular_cosmetics/code/under/medical_extra.dm create mode 100644 modular_doppler/modular_cosmetics/icons/mob/belt/medical_extra.dmi create mode 100644 modular_doppler/modular_cosmetics/icons/mob/under/dresses.dmi create mode 100644 modular_doppler/modular_cosmetics/icons/mob/under/medical_extra.dmi create mode 100644 modular_doppler/modular_cosmetics/icons/obj/belt/medical_extra.dmi create mode 100644 modular_doppler/modular_cosmetics/icons/obj/under/dresses.dmi create mode 100644 modular_doppler/modular_cosmetics/icons/obj/under/medical_extra.dmi create mode 100644 modular_doppler/modular_cosmetics/toggle_clothes.dm diff --git a/modular_doppler/loadout_categories/categories/heads.dm b/modular_doppler/loadout_categories/categories/heads.dm index c76eecc7b37a7..4d900d5cd620c 100644 --- a/modular_doppler/loadout_categories/categories/heads.dm +++ b/modular_doppler/loadout_categories/categories/heads.dm @@ -81,3 +81,19 @@ /datum/loadout_item/head/hair_tie_plastic name = "Hairtie (Plastic)" item_path = /obj/item/clothing/head/hair_tie/plastic_beads + +/datum/loadout_item/head/bow_large + name = "Bow (Large)" + item_path = /obj/item/clothing/head/bow + +/datum/loadout_item/head/bow_small + name = "Bow (Small)" + item_path = /obj/item/clothing/head/bow/small + +/datum/loadout_item/head/bow_back + name = "Bow (Back)" + item_path = /obj/item/clothing/head/bow/back + +/datum/loadout_item/head/bow_sweet + name = "Bow (Sweet)" + item_path = /obj/item/clothing/head/bow/sweet diff --git a/modular_doppler/loadout_categories/categories/undersuit.dm b/modular_doppler/loadout_categories/categories/undersuit.dm index 07e2c07ee8435..c5c3e717d2eb7 100644 --- a/modular_doppler/loadout_categories/categories/undersuit.dm +++ b/modular_doppler/loadout_categories/categories/undersuit.dm @@ -147,3 +147,19 @@ /datum/loadout_item/undersuit/dress/sailor name = "Heretical Dress" item_path = /obj/item/clothing/under/dress/sailor + +/datum/loadout_item/undersuit/dress/tutu + name = "Pink Tutu" + item_path = /obj/item/clothing/under/dress/doppler/pinktutu + +/datum/loadout_item/undersuit/dress/flower + name = "Flower Dress" + item_path = /obj/item/clothing/under/dress/doppler/flower + +/datum/loadout_item/undersuit/dress/penta + name = "Pentagram Dress" + item_path = /obj/item/clothing/under/dress/doppler/pentagram + +/datum/loadout_item/undersuit/dress/strapless + name = "Strapless Dress" + item_path = /obj/item/clothing/under/dress/doppler/strapless diff --git a/modular_doppler/modular_cosmetics/GAGS/greyscale_configs_head.dm b/modular_doppler/modular_cosmetics/GAGS/greyscale_configs_head.dm index 1152207b6afb6..8b08733a190bb 100644 --- a/modular_doppler/modular_cosmetics/GAGS/greyscale_configs_head.dm +++ b/modular_doppler/modular_cosmetics/GAGS/greyscale_configs_head.dm @@ -20,3 +20,41 @@ name = "Hood (Worn)" icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/mob/head.dmi' json_config = 'modular_doppler/modular_cosmetics/GAGS/json_configs/head/hood_worn.json' + + +//BOWS +/datum/greyscale_config/large_bow + name = "Large Bow" + icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/obj/head.dmi' + json_config = 'modular_doppler/modular_cosmetics/GAGS/json_configs/head/large_bow.json' + +/datum/greyscale_config/large_bow/worn + name = "Large Bow (Worn)" + icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/mob/head.dmi' + +/datum/greyscale_config/back_bow + name = "Back Bow" + icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/obj/head.dmi' + json_config = 'modular_doppler/modular_cosmetics/GAGS/json_configs/head/back_bow.json' + +/datum/greyscale_config/back_bow/worn + name = "Back Bow (Worn)" + icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/mob/head.dmi' + +/datum/greyscale_config/sweet_bow + name = "Sweet Bow" + icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/obj/head.dmi' + json_config = 'modular_doppler/modular_cosmetics/GAGS/json_configs/head/sweet_bow.json' + +/datum/greyscale_config/sweet_bow/worn + name = "Sweet Bow (Worn)" + icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/mob/head.dmi' + +/datum/greyscale_config/small_bow + name = "Small Bow" + icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/obj/head.dmi' + json_config = 'modular_doppler/modular_cosmetics/GAGS/json_configs/head/small_bow.json' + +/datum/greyscale_config/small_bow/worn + name = "Small Bow (Worn)" + icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/mob/head.dmi' diff --git a/modular_doppler/modular_cosmetics/GAGS/greyscale_configs_under.dm b/modular_doppler/modular_cosmetics/GAGS/greyscale_configs_under.dm index 3934ebd58a841..1e7b383302aa0 100644 --- a/modular_doppler/modular_cosmetics/GAGS/greyscale_configs_under.dm +++ b/modular_doppler/modular_cosmetics/GAGS/greyscale_configs_under.dm @@ -108,3 +108,25 @@ name = "'JUNCO' megacargo pants (Worn)" icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/mob/under.dmi' json_config = 'modular_doppler/modular_cosmetics/GAGS/json_configs/under/big_pants_worn.json' + +/////////// +//DRESSES// +/////////// + +/datum/greyscale_config/strapless_dress + name = "Strapless Dress" + icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/obj/under.dmi' + json_config = 'modular_doppler/modular_cosmetics/GAGS/json_configs/under/strapless_dress.json' + +/datum/greyscale_config/strapless_dress/worn + name = "Strapless Dress (Worn)" + icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/mob/under.dmi' + +/datum/greyscale_config/pentagram_dress + name = "Pentagram Strapped Dress" + icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/obj/under.dmi' + json_config = 'modular_doppler/modular_cosmetics/GAGS/json_configs/under/pentagram_dress.json' + +/datum/greyscale_config/pentagram_dress/worn + name = "Pentagram Strapped Dress (Worn)" + icon_file = 'modular_doppler/modular_cosmetics/GAGS/icons/mob/under.dmi' diff --git a/modular_doppler/modular_cosmetics/GAGS/icons/mob/under.dmi b/modular_doppler/modular_cosmetics/GAGS/icons/mob/under.dmi index 3912e615de3d4374614e52a51b996b38317d9f7b..51577e8a936360c7d514486094c2c5de94d7c394 100644 GIT binary patch delta 940 zcmV;d15^B|27w4-iBL{Q4GJ0x0000DNk~Le0001h0001h1Oos705K4J_y7O^Bv4FL zMZmzos;a8U$jFY4j^^g(|NsAVbaczj(eCcO;%QL^>YFH5dg?+ zMSRYx)gAx<0`o~kK~!jg?N~i;+b|TQ5ugUk#ZvMED#hqrCqZ_($`1&T?gavL_C`xy zx|!9aO_9BHQ=%;1Qbm8RR2IK`f^8TXI+SNGN4|GFet!VeqYw@b4h{~8K^TMq@DTWk z5Z)J>aN-F;8wPO{N0g7JF$jzX@d!qYM*|SJo5r{M1kNHZa28R4;M?@(_7mY#&yNTf zSK+w;T!ddKy|My#MDgk-x{2uszITcO6E6Td4#xpWn8d+2I!+)!foTwez@_KoE(G2s z<-Q$pI)B>D#Uu#7(}WM950-rEARO)HRvCScrY3!AybplMU=D0-@tXs1u9KfSw0%`v`_Gmz>5{Ah^3}B*%RgZ(JV=V z-S$k=ITpr102eH38$bmtt%*gI+Js?18kucVUuvNbdJzDu?S)#W3x8}%X1xeXE9OwC?hg&jf@F^#Gqwh84)?We zUK;j(&_af6nSZlfOBtm?PS+%0ZRM z$~ED31j0pAm?hnLRnAQU2d62^_6RQ8vcykK)v^!M16;K2flt-{34a0h$2`Mhd0w*s O0000ERLtq#Zz*gAGWo$}GGGr1B;vrPMzO3M=?p%qY#v zu!m9lsO;Wj@(c`2Wu7jMAr*7p&T`BqnQ}PZ3b!XhTQswUe*I<2aYi%K-E=VH>tCcdzxbO^WOd#z1IEq5&bbq z>k5#)AQXGQ|J&|Gd5tgYOQMoGf9CK7{aLa6=*6REvwfFJTy#xba*n;rh>1(}_S>+x z&ZcY(CHwWf9xDEjOUgSu{l91cd&9+h_1w&{7j>hb9((_fVcwmjOpQR>1?$4zUwc)g z9Hsf5m1FH4rk;-rbk9Cv_%mH~_n}&U&DIqRF@=)CVXH&a?VB$Yz5h9-dx2^l-;MX* lQ@w2W<^CyW+amsmIct%J?#?F;`+*6R!PC{xWt~$(69D}*JkS6D diff --git a/modular_doppler/modular_cosmetics/GAGS/icons/obj/under.dmi b/modular_doppler/modular_cosmetics/GAGS/icons/obj/under.dmi index d5c28418ee0b0234f6d468a306176ae3d9e6c14b..fdacc511c10104bd1cc7b3cadbcebf39cb5d07f0 100644 GIT binary patch delta 456 zcmV;(0XP1i1EmCFiBL{Q4GJ0x0000DNk~Le0000$0000$1Oos709Z$C?EnA(Bv4FL zMZmzo%gxcMs;bDy$nNg$=H}+5skZ@~0d!JMQvg8b z*k%9#0FaR-Xn(_17nc+z7UZNB7sn?h7N?S;JT<3;pz?y$yplw`CMzqr`niDp2>>ZA zM+%4g^Qiy;0TW3?K~zYI?UXTV!!Qs=l?+1NY6!u2Dwq!0f{cf3HQeMeMs$@S7?Cj$ zvO0^<7z&*_1ww}W%E(ji61c7{&9j$}d)%E2mJknqIe&>5J>xtsbfHlm!5dUWFiW#U zSxx|^MA$ZFgR*L&a#+y2=6y3q9YT_NEPO^`dtjFSD2q}fL9L;7RM13_8PsIS+~~4- zLBa{(OoZ5>K*Bx>$NoEyO+L$C(T8XOpt88d(_(>=%A!!G|hx|tS=X~ z{@{P1;$6cbg|(73df)e~;Duxb<+9YVf*M|qU>zBud@>CoGy-4$Yg_?DwmeYfDb=t50000|erq zz@T@pgtke8KoaZb@;}=340AqLq)ap_u%9fDIWEfZ#6k7hoQhJ%B-Q;- z&+S|>rK-H zg2M`mO22;zF8KKMiI%sn*10q1gExd4Tr__0Nawtd=1GR4p57f6#zDrHjlC4+JeqW5 zQiwvZrn#xAou;9_s=d1LR*%kZW7W+oB$mwVHeRb?XfArh>`72q!PjC&X?_Oha@pV) zpQh|*U|@3cba4!+nDchlM(vhDnPc_phjrD>6E3LUJ*KkylU~<~**r-TJ(lyFI?%UB zq}gTD4WH?*I?wqh_)7L2bhFxc=i8^4y6fIczSrIVUfcCPeb>v%dEbBjeOG<=u6dx2 z*xCAJjj|2BVh8vRxN#@2CoE>&z`Wri(+$QO9by|cRKM|lb#&o<4b>^9pZ@u_Pte$K z{~P(-^=eB>bT8zdDhaFQYHgaa?*{J)KHnMBe_LO^bv5~u^zTLLthO(l1k)qJ=*euw?VFivF3sLQr%Bt6}!IP^MAgo>R0mV*Bm;Ezd2tx{eSrD zluGct8S5_d?)YdU-^{sCK(Fia_8ZX&-VOSHVoQbf_Or9d%Y_@SYUgjNoZw?B{d%{h z^{Xe5;fy~oEuL?qKkLEC>8GEbkiR#{Z~5PoTldbYPd#94eRJBbKhB~T>g}F>pT@R& zd9He0jQann4}2L;6wS0X6=!B&xT$3pRJ*fBbUVbVEv~M_w7^e^dE38iu9^+RpV2+o^m8SWszHz@3Eh33BIa36huuArfPPI zNFVdQ&MBb@0783J4gdfE literal 0 HcmV?d00001 diff --git a/modular_doppler/modular_cosmetics/icons/mob/under/dresses.dmi b/modular_doppler/modular_cosmetics/icons/mob/under/dresses.dmi new file mode 100644 index 0000000000000000000000000000000000000000..40733fd98b75d7f6cebafd30a227d8ea53130d2a GIT binary patch literal 2263 zcmZ`*c{J1w7yhBFL&&bi5~5Tx6^)%?Ol24IS;i6uWr`UL8Z;!rWX)t9OPw}FNHii+ zc(Y8&o*|>5DeH`}d*?mpJLmi3`@TQ!ea>_4z31F>pYxn^(;V&L;-X5T004+1Y+=qk z^!+D<1$p@gIogm1#8_7(4i<>L5)pC(7jhi~0Qlm_o>~c_o}}PZ6IUj|*WmHygp=H$ftX9FEo4`nUA|Wq zEx}1i;+=B&-ZBEREhC+@3R$<WkB#)BDHk(y@~Ui|3CvFzxz^8fjbs zHFojZ%`)!JyVe|2hq>jMPmW!c)=_{8v;G@^Sz^-6&;;KDx-(82 zZAwRZqT=^=XwR&b%sWzOVO9hKdP4NrzQn#h@AY}6&l^rtkon$nvZ6$zK#h_e3Xqg& ztlY!5GsGzm*x!r6#@3ws1wPX&4_7BPy##+x9)7`!Z|NGMi|Q-jr}TXTI}`o#o=rkB z^xfP*3qT>F)x&r}0Y5z^AVoTj?YIWxnCpRw-Y0+8YsM2}S+_ z@)*e6%#n!Fp5CaG&^@GM6n`ohxx>5%<<$lbjD*WvXy@>$N=KW<{oL&saQ15p-3txd z+%2F~?UdF|zUr=@X^uK83Uv7l+%AT7VbdgN55ohz!bMe6@|a_+PDLQ`HPUm7pePyR z_qMQ}I3QOEwt_Zq-9A@37mec@;j-(MRIKj)`ifUJuQd{CBORY9(e#vB*>c$EN`I3E zg77Pb18sRbrBV+74)W#*o3BX?I zOE-X7U}a=h7E`)p#IZ+8Xv;`_4e)&a!{2w@3c zRW1>HixGn>acBRh^*z^n0Go1ol~fb6xCMr(zapqkoq ztG}6b;(h9NaJ9ogG2FuJPzD`>0I?Z?WgojDV4s<%-xu&P1cc9XvPd_|ZjDm-?-(1* zgz24~B)uFHdKBw-ub`9WWj!9qzj%70fUlpOTdv?d6sL8YiV%l|E`=V;d8gKc^Xe^ z80GwVLB|PFuk&2i;jIDy1*b|35L!zwTfbw1?c-y@#CeUMSH_fDh9-vu*U+?0t(W&0->-(Oi zxMR^sOt?+;jZ+qzx1>?;bl>asoR!rW>=;?c2Y=J6fgD<+x`_*1nVGTV9;xuj^x!ms zDCakyxsi6A{QwA81q!pSN|v1TDm%yImb5+f!=qNW?5BD;A?0yxMXawsE$O3AH^m6( zt6!KN#1(nAV}Lp)he{q!hnVkH%|!d#ic~wtyt*RGn{sWLbRI7!rH{@g)DA?y{>8a} zczg3EL=~es7rPRn^nqqVLjdHfKC4tb#;@$~N-p2qzQebtvN zwH!7q;_RpBZ#-F930!8gXL?(P`)9t0*w5DX03U`EiK8+r<+mN zs7t+o(Jba`9xhwcvg(TBL1~ZSfFJ$acCp?#CPXqUbhp;3x?v6*_^~Nn#{Yo~>Qo;x zWX#sevtCr2Xn$Z)nHp6YI&+T27IGLyFK(}g`ECxaK$sWDE25()Oo&B%C*`hg4N;ng<{v4 zALZX-N&Y6^Hg=Z@qELlawA){|k1jHjtDt2EE~}_2a!w(-Q}@KCoc^0UCIsd1#6ChUq(s`8>YgMdIf{9BD92I8km!ij(WiMl2~Q7v9YFpnUqfMKFOJL_ zVHYo;s^xRE;&BeRFD_(S)%v-%-29ur9gpjDBZ9r#3%~}igRVCi6S5=yEjn67a%pZ) zgk#*_QEh()AG+pcC+LoOT$Zf~g`3SO1fV|>mb#l>i96EwBmQ&n4Hbb6J5+H{k_7Kl O0T9;quosrT#J>Rp#X>&- literal 0 HcmV?d00001 diff --git a/modular_doppler/modular_cosmetics/icons/mob/under/medical_extra.dmi b/modular_doppler/modular_cosmetics/icons/mob/under/medical_extra.dmi new file mode 100644 index 0000000000000000000000000000000000000000..a0e8d3a92af423942e8025ab32e3c45c87909ffc GIT binary patch literal 914 zcmV;D18w|?P)V=-0C=2JR&a84_w-Y6@%7{?OD!tS%+FJ>RWQ*r;NmRLOex6#a*U0*I5Sc+ z(=$pSoZ^zil2jm5sURbzhGRvMa>T7i zeH^4C*Di?liq$OR2xO6V4UN2A8zyzfTBB=z_MB=`-Y?ZwkhY0wekBf%v7ZDI@b|^@ zTwIPPEb{yj@>P*5oDk#@U6IU|h~neLWiKU=U~_>B{E5Z`uuMniFk*S5aR$pO zO->=v89897_2;r15oNZ~3TCiup(_-;(>oLl7earL*`Q-9SY#+Lf(RazM1N&6eWP|I za6IX_6^M)o&MI<(inRi!fX9=L?MV7mkamJlJ_77$HCF6*-#+5ykS#l^+tNaNan&l|Pv z|4R_q?){+lKX2QA*uI4xllFhrw*R=jx9$H65Ug$ckNf{hT&1{R)wcgAXxo1fJgEny ok-Q;%(ytFj5-*dh5B~Rj2X(L%TM@369RL6T07*qoM6N<$f=`32DgXcg literal 0 HcmV?d00001 diff --git a/modular_doppler/modular_cosmetics/icons/obj/belt/medical_extra.dmi b/modular_doppler/modular_cosmetics/icons/obj/belt/medical_extra.dmi new file mode 100644 index 0000000000000000000000000000000000000000..1a62c581eb826f8b4ae5500e69340774c0039060 GIT binary patch literal 494 zcmVV=-0C=2JR&a84_w-Y6@%7{?OD!tS%+FJ>RWQ*r;NmRLOex6#a*U0*I5Sc+ z(=$pSoZ^zil2jm5DK|AGJ}EITB|j%KwMdDJGbOXA7$|PY#hF%=n41b=D=WDAxqyua z07EYwP&J0bTmS$8I7vi7RCt_YWcbf8pnz#$tsiy3r~`(h17!5A{(~^T0RMk2pJ;-a zoT?50S3 zlZ(d~-`;ZovpIML81(h@8ENVObjw|JqQq;2C!MKHE;EQ zj@<{~d473Y8A+Cd08t@;%jY1=$@Mu55ETNn@Hx>A097a;%Rv_XuX*|3_^t;~6ykG` z7`Z-&0Y*ZNQc& literal 0 HcmV?d00001 diff --git a/modular_doppler/modular_cosmetics/icons/obj/under/dresses.dmi b/modular_doppler/modular_cosmetics/icons/obj/under/dresses.dmi new file mode 100644 index 0000000000000000000000000000000000000000..691b03879a8ac8f6995d4201aeffc9f6249628bf GIT binary patch literal 2240 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 literal 0 HcmV?d00001 diff --git a/modular_doppler/modular_cosmetics/toggle_clothes.dm b/modular_doppler/modular_cosmetics/toggle_clothes.dm new file mode 100644 index 0000000000000..c67acf51d79c1 --- /dev/null +++ b/modular_doppler/modular_cosmetics/toggle_clothes.dm @@ -0,0 +1,30 @@ +/datum/component/toggle_clothes + var/toggled = FALSE + var/toggled_icon_state + +/datum/component/toggle_clothes/Initialize(toggled_icon_state) + if(!isclothing(parent)) + return COMPONENT_INCOMPATIBLE + + if(!toggled_icon_state) + return COMPONENT_INCOMPATIBLE + + src.toggled_icon_state = toggled_icon_state + + RegisterSignal(parent, COMSIG_CLICK_ALT, PROC_REF(clothing_toggle)) + RegisterSignal(parent, COMSIG_ATOM_EXAMINE, PROC_REF(handle_examine)) + +/datum/component/toggle_clothes/proc/handle_examine(datum/source, mob/user, list/examine_text) + SIGNAL_HANDLER + examine_text += span_notice("This item is toggleable! Alt Click to toggle!") + +/datum/component/toggle_clothes/proc/clothing_toggle(obj/item/clothing/source, mob/living/clicker) + SIGNAL_HANDLER + + toggled = !toggled + source.icon_state = (toggled ? toggled_icon_state : initial(source.icon_state)) + to_chat(clicker, "You toggle \the [source]!") + if(source.loc == clicker) + clicker.update_clothing(source.slot_flags) + source.update_appearance(UPDATE_ICON) + return CLICK_ACTION_SUCCESS diff --git a/modular_doppler/modular_crafting/code/sheet_types.dm b/modular_doppler/modular_crafting/code/sheet_types.dm index 7b90ade1d156a..d245b01445ab7 100644 --- a/modular_doppler/modular_crafting/code/sheet_types.dm +++ b/modular_doppler/modular_crafting/code/sheet_types.dm @@ -110,6 +110,7 @@ GLOBAL_LIST_INIT(doppler_leather_recipes, list( )) GLOBAL_LIST_INIT(doppler_leather_belt_recipes, list( + new/datum/stack_recipe("medical bandolier", /obj/item/storage/belt/med_bandolier, 5, category = CAT_CONTAINERS), new/datum/stack_recipe("xenoarch belt", /obj/item/storage/belt/utility/xenoarch, 4, category = CAT_CONTAINERS), )) diff --git a/modular_doppler/modular_vending/code/tg_vendors/autodrobe.dm b/modular_doppler/modular_vending/code/tg_vendors/autodrobe.dm index 698dfef8aa29d..5cb4dba1c3e29 100644 --- a/modular_doppler/modular_vending/code/tg_vendors/autodrobe.dm +++ b/modular_doppler/modular_vending/code/tg_vendors/autodrobe.dm @@ -16,17 +16,6 @@ /obj/item/clothing/under/rank/civilian/clown/jesteralt = 1, ), ), -/* list( - "name" = "Fancy", - "icon" = "user-tie", - "products" = list( - /obj/item/clothing/head/beret/badge = 5, - /obj/item/clothing/mask/masquerade = 25, - /obj/item/clothing/mask/masquerade/two_colors = 25, - /obj/item/clothing/mask/masquerade/feathered = 25, - /obj/item/clothing/mask/masquerade/two_colors/feathered = 25, - ), - ), */ list( "name" = "Service", "icon" = "kitchen-set", @@ -42,12 +31,8 @@ /obj/item/clothing/under/costume/maid = 1, /obj/item/clothing/gloves/maid = 1, /obj/item/clothing/neck/maid = 1, - /obj/item/clothing/under/rank/civilian/janitor/maid = 1, /obj/item/clothing/accessory/maidapron = 1, - // /obj/item/clothing/gloves/maid_arm_covers = 1, /obj/item/clothing/neck/maid_neck_cover = 1, - // /obj/item/clothing/under/maid_costume = 1, - // /obj/item/clothing/head/maid_headband = 1, ), ), list( @@ -62,20 +47,4 @@ /obj/item/clothing/under/misc/doppler_uniform/standard/suit/overalls = 5, ), ), - -/* list( - "name" = "Other", - "icon" = "star", - "products" = list( - - ), - ), */ ) - -/* contraband_doppler = list( - - ) */ - -/* premium_doppler = list( - - ) */ diff --git a/modular_doppler/modular_vending/code/tg_vendors/clothesmate.dm b/modular_doppler/modular_vending/code/tg_vendors/clothesmate.dm index 05d2331050786..27762e456f1a5 100644 --- a/modular_doppler/modular_vending/code/tg_vendors/clothesmate.dm +++ b/modular_doppler/modular_vending/code/tg_vendors/clothesmate.dm @@ -8,10 +8,10 @@ /obj/item/clothing/head/fedora/beige = 5, /obj/item/clothing/head/fedora/white = 5, /obj/item/clothing/head/standalone_hood = 5, - // /obj/item/clothing/head/small_bow = 5, - // /obj/item/clothing/head/large_bow = 5, - // /obj/item/clothing/head/back_bow = 5, - // /obj/item/clothing/head/sweet_bow = 5, + /obj/item/clothing/head/bow = 5, + /obj/item/clothing/head/bow/small = 5, + /obj/item/clothing/head/bow/back = 5, + /obj/item/clothing/head/bow/sweet = 5, ), ), @@ -39,10 +39,10 @@ "name" = "Suits & Skirts", "icon" = "vest", "products" = list( - // /obj/item/clothing/under/dress/doppler/pinktutu = 5, - // /obj/item/clothing/under/dress/doppler/flower = 5, - // /obj/item/clothing/under/dress/doppler/strapless = 5, - // /obj/item/clothing/under/dress/doppler/pentagram = 5, + /obj/item/clothing/under/dress/doppler/pinktutu = 5, + /obj/item/clothing/under/dress/doppler/flower = 5, + /obj/item/clothing/under/dress/doppler/strapless = 5, + /obj/item/clothing/under/dress/doppler/pentagram = 5, /obj/item/clothing/suit/jacket/doppler/departmental_jacket = 5, ), ), diff --git a/modular_doppler/modular_vending/code/tg_vendors/engivend.dm b/modular_doppler/modular_vending/code/tg_vendors/engivend.dm index 999e4d4ab489a..1552731a9df11 100644 --- a/modular_doppler/modular_vending/code/tg_vendors/engivend.dm +++ b/modular_doppler/modular_vending/code/tg_vendors/engivend.dm @@ -1,7 +1,6 @@ /obj/machinery/vending/engivend products_doppler = list( /obj/item/clothing/glasses/meson/engine = 5, - /obj/item/construction/rcd/loaded = 3, /obj/item/forcefield_projector = 4, /obj/item/storage/bag/construction = 2, ) diff --git a/modular_doppler/modular_vending/code/tg_vendors/wardrobes.dm b/modular_doppler/modular_vending/code/tg_vendors/wardrobes.dm index 084868b7c6da6..0f74e833e49ea 100644 --- a/modular_doppler/modular_vending/code/tg_vendors/wardrobes.dm +++ b/modular_doppler/modular_vending/code/tg_vendors/wardrobes.dm @@ -4,7 +4,7 @@ /obj/item/radio/headset/headset_med = 3, /obj/item/clothing/gloves/latex/nitrile = 2, /obj/item/clothing/suit/toggle/labcoat/hospitalgown = 5, - // /obj/item/storage/belt/medbandolier = 2, + /obj/item/storage/belt/med_bandolier = 2, /obj/item/clothing/suit/jacket/doppler/departmental_jacket/med = 2, ) @@ -91,8 +91,8 @@ /obj/machinery/vending/wardrobe/chem_wardrobe products_doppler = list( -// /obj/item/clothing/under/rank/medical/chemist/doppler/formal = 2, -// /obj/item/clothing/under/rank/medical/chemist/doppler/formal/skirt = 2, + /obj/item/clothing/under/rank/medical/chemist/pharmacologist = 2, + /obj/item/clothing/under/rank/medical/chemist/pharmacologist/skirt = 2, /obj/item/clothing/head/beret/medical/chemist = 2, ) diff --git a/tgstation.dme b/tgstation.dme index c51131bb9fd23..19b92d1626ff1 100644 --- a/tgstation.dme +++ b/tgstation.dme @@ -6643,16 +6643,19 @@ #include "modular_doppler\modular_antagonists\sapper_gang\code\creditminer.dm" #include "modular_doppler\modular_antagonists\sapper_gang\code\paper_premade.dm" #include "modular_doppler\modular_antagonists\sapper_gang\code\sapperpad.dm" +#include "modular_doppler\modular_cosmetics\toggle_clothes.dm" #include "modular_doppler\modular_cosmetics\code\garment_bag_overrides.dm" #include "modular_doppler\modular_cosmetics\code\jacket_pockets.dm" #include "modular_doppler\modular_cosmetics\code\towels.dm" #include "modular_doppler\modular_cosmetics\code\uniform_overrides.dm" +#include "modular_doppler\modular_cosmetics\code\belt\med_bandolier.dm" #include "modular_doppler\modular_cosmetics\code\face\basemasks.dm" #include "modular_doppler\modular_cosmetics\code\face\glasses.dm" #include "modular_doppler\modular_cosmetics\code\face\masks.dm" #include "modular_doppler\modular_cosmetics\code\hands\gloves.dm" #include "modular_doppler\modular_cosmetics\code\hands\rings.dm" #include "modular_doppler\modular_cosmetics\code\hats\doppler_command_hats.dm" +#include "modular_doppler\modular_cosmetics\code\head\bows.dm" #include "modular_doppler\modular_cosmetics\code\head\hair_tie.dm" #include "modular_doppler\modular_cosmetics\code\head\hats.dm" #include "modular_doppler\modular_cosmetics\code\head\head.dm" @@ -6671,6 +6674,8 @@ #include "modular_doppler\modular_cosmetics\code\suits\modsuit.dm" #include "modular_doppler\modular_cosmetics\code\suits\shirts.dm" #include "modular_doppler\modular_cosmetics\code\under\doppler_uniforms.dm" +#include "modular_doppler\modular_cosmetics\code\under\dresses.dm" +#include "modular_doppler\modular_cosmetics\code\under\medical_extra.dm" #include "modular_doppler\modular_cosmetics\code\under\miscellania.dm" #include "modular_doppler\modular_cosmetics\GAGS\greyscale_configs_face.dm" #include "modular_doppler\modular_cosmetics\GAGS\greyscale_configs_head.dm" From bdf6d28d690c28ceec2f97c1ff60f0356e49b3c8 Mon Sep 17 00:00:00 2001 From: "Lila S." Date: Fri, 27 Sep 2024 12:41:50 +0200 Subject: [PATCH 4/4] ci --- .../screenshot_antag_icons_blobinfection.png | Bin 6190 -> 6287 bytes .../screenshot_antag_icons_bloodbrother.png | Bin 2452 -> 2373 bytes .../screenshot_antag_icons_changeling.png | Bin 1755 -> 1797 bytes ...eenshot_antag_icons_stowawaychangeling.png | Bin 1755 -> 1797 bytes ...eenshot_humanoids__datum_species_jelly.png | Bin 3472 -> 3432 bytes ...noids__datum_species_jelly_luminescent.png | Bin 3461 -> 3428 bytes ...t_humanoids__datum_species_jelly_slime.png | Bin 3159 -> 3119 bytes ...manoids__datum_species_jelly_stargazer.png | Bin 3472 -> 3432 bytes ...enshot_humanoids__datum_species_lizard.png | Bin 1452 -> 1403 bytes ...reenshot_humanoids__datum_species_moth.png | Bin 1759 -> 1630 bytes 10 files changed, 0 insertions(+), 0 deletions(-) diff --git a/code/modules/unit_tests/screenshots/screenshot_antag_icons_blobinfection.png b/code/modules/unit_tests/screenshots/screenshot_antag_icons_blobinfection.png index 9a94c3d4314f3bc86ad60ae1144f11288ffdbe38..e3d7acbf5d891f24b1c97f51d6b646d419f1038c 100644 GIT binary patch delta 6188 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 KMNUMnLSTYN2`*Ux delta 6090 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 H=M(<}=1ZD` diff --git a/code/modules/unit_tests/screenshots/screenshot_antag_icons_changeling.png b/code/modules/unit_tests/screenshots/screenshot_antag_icons_changeling.png index 1fc5ed1581fe7853ef8a48044786a20b862595d1..c63a02c8370529ac59b59773e571f0ef3c4c487e 100644 GIT binary patch delta 1662 zcmYL}dpr~T9>>RGEV-PiNA47gQ*!UggSpgmsL*v$jGSc4rVF!SR^-w}M2)R2<~GZ% zr_xruSpWpZM8QztqnL{RA^!4#P zkEMvHsOY>4y6p>LfuTHJPWQDLJq@0&z1nco&puy$D4BX{rsk4+YR4RooN(;+%mFMa znVadG?KqtjzQf``b5Rencn2iRfSZoy4#iodV)og@zRtI&6u#%L!xta>35+d;vKhk- z7XIb!df`i9<1cE>M>M#KN!VH-4qq!`id>Sh@yLLBRN-i{xN+l9!nQB4R{skBU%CP0)ubny27mD?>Y@pQlH7i`u_4#%g~v2GR2sdnB1f4W1}+T%U{rPA#?_Y`#P`juphXZN1Gd0T!C!XQPI zitZ#rZ=g^r1aAWJ6|<9<4eIK6OZ)UeA(es)vSbJ4uf{)7XP1f(BtjhHGy+j(_pv1m zb@`j-RBnR_-sN}|j9(A>w^r$LUo4;OCmC(OZherZ>{ysco{`P>`gJ);r9JM^CqdOm z+mIB`1J=r2k=(MnsM?pew6-b%-7P5a$R!YRZHne?`s!9UYvx(Ou~9ptW+O-6|6E~2 zX6q$6Ex5$Sr3?%qR`~Sr-?i$IOo^H9&Xu6wP6`7ntC>W+4B%e+6;* z2&-~rW$8Y1&i_wBmcghb)6hmze;9<6M&Y^EBS|5K+a0z;+|qCVYIW#)8Z;Qz-(5AHAzx zaPhF?h_XokBEA@Vqx{yLprICxb?n?99uomWMHKZF``teYfWRLo6B*xQK09g43dGTi zeu-jbn-a>vv~O6GyPT4v0o*Sywo4 zPK?3+>K#ysP~GgF=`Eu^eX2wjnneg&CfQ&?v96)5CTpb(FV{x{j3X1`$GL7>S}M$H z?yNdpYwXZF02{Zyf}^Reh3If@MQG9CF zBJpW4SO&PN@UloV8h8O$~sEe_?ouh`x-jI`$l&W`K^5aV|f&>|$NB zt_o?%fLQslnGO2P^ON#RZ!iP%3#Q50!N~H-iK(%Mhi`kP7@6+i?OxHb@$Mf<<~VgT zsj^yC$*44oFh+Pi{IOXKKrTGjpJc3 zK~YscF~u3TsEZhuCGQujY)kpz68P-7M;5qJ1iO2Jm$Kl2HI%nvA}l(;{2BggmE3jR zFHO6JUTR7W3gXdrbRvGq82I~XC69RWs(TNi_!u)%+Pn~uN^+!#Eyk6+l08DvbyyV~|qZ0~Cu z41fBg(u+w;M8|m@j1&z}4BzAaJ~dup GDgOd;e>8po delta 1620 zcmYLJdpOf;9G}D}p~&UTHHVU^h?A5!a(P@!xt(NAyDv zCH|-LywutiDuDDaPf0AOwr&~=pgyWh%!LOOVRP?VzQ2_#Ek9thO%<)aLG`x_ zN;p>9Mq8i4>CFY1Ohx{ z|0KNKN3S?jW=fv3J4t6MyOO|)R0*9FNgKIkHGr{#7-2-OvGZ}*roiQSom!~b6@`t< z>)TeIzflmDpa-%3vFvdA3b?IO)2d(gTu2DUpwcvzYGPbv@C(cJo#5g`&--kgPl#hN z40p<21LvHJ9M6ORn#2PjawE};>5bcM)-b$AxuY;7nKlMeRGK&a-l^>etomepP4H=2 z_&hDwp2BQxhR!N@LN0f%eF>yD!m5R?(^2H?&o`R-)yKxEnGx+KOjx?9Vv1rV=BFl?_z^4=^l||V$3fpW%E@7M zEiP9MBd2zS^~Z24c~>m9AVOcTwAP;&WIqDtm>TZaA(lWd`m_F%`Ytkka*CJIIQ|4YFO~mtoOo8hkV*J^f^KVKb8;@(o%^ z0`uWamCTQ6^~FsVWLZoUATNY|2!U50M1Y^4HL~(@567}4@?Dsr5p#f*Qjj@K=hA0T zQD=%vL^I54e51DYrs`t!MHmY|n}J&ILAL02%_zbxUN`Kj5%kktrz{Y!_co{5M-b0_ zp>0MUoh=KWQIa8mfn8 z*Bf_dDphlj1|hvPx>1Q39pLSR>KitpGxIVV9%&bDXWrF?{*~{b&QTq5J3y}rJX-dv zsmV7iSH4__3Tjl#M_63%Mp8lp@Qc3joavl$r>5P}o9-7I!4M*eKa%BqEb>-e zNU_Hb<~RGSvDS`ihAqG z_(4{GA=PRliemRBneHxU%G6sBX~GC_;JzT z>OY)f7zZ9HMQ-hrj<0Hs8;&JiX`Om7n9^T+2u#Sy**QDPoxZo=XGPlfD6*%c2ZOX9 z>TOHtE@=JaKHRjO;Dz&cX;|rX3^d)G9Ut?sI_5;Xb1KEK{1@LmW}CcJDP`7S&n{jE zr@9jH{3_YO9&Dw~gC9@Y%9G!HAObPIL6k1q;Zeu>3t4jx#uid;r^I1jw`qsE32OO5 z!I-CDZ62MM!tgmXC(^8E~#V<-)g z?D=jI?FRy0NEi?OVu0siSC?;4u5C_*0^nI%#PPKYlsb>jWm^`Fl$5OTGwN(_$-!hr zNAO1mt{1-j^4CjrtpHKw6nfAZ)@+@}S0JH7))~63&(5yCN#);LiV=vZ^xKPzRV8Jw zFXbSE^h)8x&O?82MlvX$qJkYPmr^^Nv6?C>ZPs41m~rh|$SVQd_ofgeUQYJzc6i&r Gll}ukV>u=O diff --git a/code/modules/unit_tests/screenshots/screenshot_antag_icons_stowawaychangeling.png b/code/modules/unit_tests/screenshots/screenshot_antag_icons_stowawaychangeling.png index 1fc5ed1581fe7853ef8a48044786a20b862595d1..c63a02c8370529ac59b59773e571f0ef3c4c487e 100644 GIT binary patch delta 1662 zcmYL}dpr~T9>>RGEV-PiNA47gQ*!UggSpgmsL*v$jGSc4rVF!SR^-w}M2)R2<~GZ% zr_xruSpWpZM8QztqnL{RA^!4#P zkEMvHsOY>4y6p>LfuTHJPWQDLJq@0&z1nco&puy$D4BX{rsk4+YR4RooN(;+%mFMa znVadG?KqtjzQf``b5Rencn2iRfSZoy4#iodV)og@zRtI&6u#%L!xta>35+d;vKhk- z7XIb!df`i9<1cE>M>M#KN!VH-4qq!`id>Sh@yLLBRN-i{xN+l9!nQB4R{skBU%CP0)ubny27mD?>Y@pQlH7i`u_4#%g~v2GR2sdnB1f4W1}+T%U{rPA#?_Y`#P`juphXZN1Gd0T!C!XQPI zitZ#rZ=g^r1aAWJ6|<9<4eIK6OZ)UeA(es)vSbJ4uf{)7XP1f(BtjhHGy+j(_pv1m zb@`j-RBnR_-sN}|j9(A>w^r$LUo4;OCmC(OZherZ>{ysco{`P>`gJ);r9JM^CqdOm z+mIB`1J=r2k=(MnsM?pew6-b%-7P5a$R!YRZHne?`s!9UYvx(Ou~9ptW+O-6|6E~2 zX6q$6Ex5$Sr3?%qR`~Sr-?i$IOo^H9&Xu6wP6`7ntC>W+4B%e+6;* z2&-~rW$8Y1&i_wBmcghb)6hmze;9<6M&Y^EBS|5K+a0z;+|qCVYIW#)8Z;Qz-(5AHAzx zaPhF?h_XokBEA@Vqx{yLprICxb?n?99uomWMHKZF``teYfWRLo6B*xQK09g43dGTi zeu-jbn-a>vv~O6GyPT4v0o*Sywo4 zPK?3+>K#ysP~GgF=`Eu^eX2wjnneg&CfQ&?v96)5CTpb(FV{x{j3X1`$GL7>S}M$H z?yNdpYwXZF02{Zyf}^Reh3If@MQG9CF zBJpW4SO&PN@UloV8h8O$~sEe_?ouh`x-jI`$l&W`K^5aV|f&>|$NB zt_o?%fLQslnGO2P^ON#RZ!iP%3#Q50!N~H-iK(%Mhi`kP7@6+i?OxHb@$Mf<<~VgT zsj^yC$*44oFh+Pi{IOXKKrTGjpJc3 zK~YscF~u3TsEZhuCGQujY)kpz68P-7M;5qJ1iO2Jm$Kl2HI%nvA}l(;{2BggmE3jR zFHO6JUTR7W3gXdrbRvGq82I~XC69RWs(TNi_!u)%+Pn~uN^+!#Eyk6+l08DvbyyV~|qZ0~Cu z41fBg(u+w;M8|m@j1&z}4BzAaJ~dup GDgOd;e>8po delta 1620 zcmYLJdpOf;9G}D}p~&UTHHVU^h?A5!a(P@!xt(NAyDv zCH|-LywutiDuDDaPf0AOwr&~=pgyWh%!LOOVRP?VzQ2_#Ek9thO%<)aLG`x_ zN;p>9Mq8i4>CFY1Ohx{ z|0KNKN3S?jW=fv3J4t6MyOO|)R0*9FNgKIkHGr{#7-2-OvGZ}*roiQSom!~b6@`t< z>)TeIzflmDpa-%3vFvdA3b?IO)2d(gTu2DUpwcvzYGPbv@C(cJo#5g`&--kgPl#hN z40p<21LvHJ9M6ORn#2PjawE};>5bcM)-b$AxuY;7nKlMeRGK&a-l^>etomepP4H=2 z_&hDwp2BQxhR!N@LN0f%eF>yD!m5R?(^2H?&o`R-)yKxEnGx+KOjx?9Vv1rV=BFl?_z^4=^l||V$3fpW%E@7M zEiP9MBd2zS^~Z24c~>m9AVOcTwAP;&WIqDtm>TZaA(lWd`m_F%`Ytkka*CJIIQ|4YFO~mtoOo8hkV*J^f^KVKb8;@(o%^ z0`uWamCTQ6^~FsVWLZoUATNY|2!U50M1Y^4HL~(@567}4@?Dsr5p#f*Qjj@K=hA0T zQD=%vL^I54e51DYrs`t!MHmY|n}J&ILAL02%_zbxUN`Kj5%kktrz{Y!_co{5M-b0_ zp>0MUoh=KWQIa8mfn8 z*Bf_dDphlj1|hvPx>1Q39pLSR>KitpGxIVV9%&bDXWrF?{*~{b&QTq5J3y}rJX-dv zsmV7iSH4__3Tjl#M_63%Mp8lp@Qc3joavl$r>5P}o9-7I!4M*eKa%BqEb>-e zNU_Hb<~RGSvDS`ihAqG z_(4{GA=PRliemRBneHxU%G6sBX~GC_;JzT z>OY)f7zZ9HMQ-hrj<0Hs8;&JiX`Om7n9^T+2u#Sy**QDPoxZo=XGPlfD6*%c2ZOX9 z>TOHtE@=JaKHRjO;Dz&cX;|rX3^d)G9Ut?sI_5;Xb1KEK{1@LmW}CcJDP`7S&n{jE zr@9jH{3_YO9&Dw~gC9@Y%9G!HAObPIL6k1q;Zeu>3t4jx#uid;r^I1jw`qsE32OO5 z!I-CDZ62MM!tgmXC(^8E~#V<-)g z?D=jI?FRy0NEi?OVu0siSC?;4u5C_*0^nI%#PPKYlsb>jWm^`Fl$5OTGwN(_$-!hr zNAO1mt{1-j^4CjrtpHKw6nfAZ)@+@}S0JH7))~63&(5yCN#);LiV=vZ^xKPzRV8Jw zFXbSE^h)8x&O?82MlvX$qJkYPmr^^Nv6?C>ZPs41m~rh|$SVQd_ofgeUQYJzc6i&r Gll}ukV>u=O diff --git a/code/modules/unit_tests/screenshots/screenshot_humanoids__datum_species_jelly.png b/code/modules/unit_tests/screenshots/screenshot_humanoids__datum_species_jelly.png index ab2ee4cacb82a994c3f3cb0836b45f2641d8e0be..eaee84fed4942f7742b0e54449d4d7e6183ffee1 100644 GIT binary patch delta 3309 zcmVx~@#qak4J$=xSB$wyRT7v>&rN3%j$K;#jRk?NTenc2%H$AYUsIgHa5LA|VRY zL?HOV$J;;fJ|BqTy+CMZ_xDfo?!7s`bI&{X+?#t2ue7uj|9{UA*z=?M!jn0%;d1zT zdf~e97J9;`{b95f8x8`EF2_sc4ge_As1cg{l3hCRxO%|E8+USiJ-y)TJ%Mh!azj5N zCAffTe1g_{763ro6hF@VPFw~HG`bvLPcNwTI%S!r7FTZQ(Q3Yn^OtLtVN;~2FFcvU zRRJ!jFFctOHh)Em>$e(}%y#lD(C9exb6x^!y-rDi(zcq-%2u-(=P%b{hE%FGG#izQ z3HDbf%xPGfqDfRc)mTABIxm;y(@_-OYAOJw<;tD>W zuUh)&4e;^wR9QMZ&;L+W4#2**zy`$o0D#AHLa-!2JAW-8P%HKK*YchC000sbxPY|* z1R7nA?~Lb_d_G?rx8^O`qn>V@*tJI`o-h%~o7O7Ql3r3B{CANuHhdOmCD`S7k>|w!%KStPTSza#%4;`-j)0JV_z$m z%u7%SU0gvXzkkcN+%iqAL(c>PjV>oPd={>>w<|q8+;FeG3*^(%XvnpCxGBd6`SZBQ zD~h0<-;2)A8aeZ`iUFG!Z>5}Ey8r<1UtWV?sTdJ4QMlGK9uYB72$qWR z{^d3O0$sbXdGS_?)9hICi`E7qX3h*$secUv`m59i#LSri(b^!+{KFoE>h&$uM}^xU zoh-q=xcvYC>0}8S4An?mk%F4qYmiQ!PLI#5+yKK(BkJ`gDs<|k5qkoYe~t13x?Ouk zKVV#WMIA~`7vpc0+c@#FItfZAOK_^R8USFpX@qpL1Pc(f>2?4(RexHI z1qo4TFql|Qkv)In{3Mi|E{3?>4?D8<(*5FgKbTGzBXNEbXMUSYpkCiX1xv;BSy}cm6FF0I;)U<`Xt6S>; z03ZLjalkn8e06IbQqval3Jw>s<{vf)HW*A$SJlvwl__+n?<>E1m8Y(%8MP%q|cDGV*YM8*ffAecM1M2MnrmygKB#=C6A7v-G3gyQ{Uy$ z5m0TKZ{ysRv|9-oAXj2oMgV3M~tS}hh7 zUN{TI=jl*a)nMteMfiB@{l}t9wvEvvwxCr(*TMs8+oej z*;M?jNB~dP6)}Rkss;-Zq5wSE2>_t&o&{%WFG8_p zgR$Uebre=@&!!YxHuA`}M9^R`VeoV4)JZ%teptaQ!Q=-pfRo7$fHOaE4q{2 zf;oP)z~r|Dd-yqBiGL9c-sea2)Hl}PbSXMFVID4&o*mG}eDiY?=8c|aEcpr4RW)|; zbGi=@x_eW>(m*sAZXy4`F(jwN^9qlhq0&~QfV5jX%nrK`Fy85+UU@0znfxbCmP6v_ z#)+Sk2h{6~13rgpm-xAH5y=@1hFj0%w+EbJKuvk|Gs)_8Mt{_lSKF<~&&AJr2?*W2 zDFBFylmh^&FREefF!O}&-W0P9fJ2snqxe}Z0kZa)B*fjBZ-k6#Fn}6OBM|-*C(G%! zq4?`{M)b!B_WZ02Fqj1BcSlJ|{E%)p+OdFehE9{%aq+Ys_NM1K z8-Prnq^BQ$Y7NasrK9Tufd0w1n$1c8TBZ)f2wcI*05bE#95VT-{t|7OMy(Y4_-H*J zr=?@V<(w7Z3NMj6S}bOGirf(r5U6G95+VtN%>2+X*?(aILdfUy5fTuj?e6V`$khe) zO^w)ja380{q&?VqaG&z5x<=*X#Dn&x0U-fFT0Wl-Vg#=8?D{td071W+DbpAl(B0F6 z<7H=MF<~=R_R8Xl8-=+JQwM%Tk$pA#SzS$_dco2|G^c9(Y zYDL`4S%0d|`}YArrP`i7s%bGM9?MpB-oKCUckfYIAKX7bP9P8&TU(%SHp)b9+|M4I zJwW8<2JiO8c;r_M50R)-GI0{d@da3xxIl5>t5^@diSF+b{ePu?x{mYFGw061HSLuLJf2fYPhT(e z&BluWA|vBp*lLd=Y|&%9^B0k;tE!jkgNIOr3w3HsjFM-V0z&WmZrT%-^)oSOX%BRN4|X~RNJ$u^vq0}8|c57Daij8;&XnO{^1PF zo_{@+l`gCdP+6&`NKRgRMUQ=p4%2;a7A~O`;q!XO!~ne%pCX(GlfR+cR~0RTENm)W zFTlnK!^VKhNGd zw`qNLWbH*>-f_enScJ~c8c|uPA66fm|9=Itcc`dn^)xK_>J_Y9u@>t$tww5U!hjq= zc}4|*Cu#G>#>UZ@=QF`{djNR(lN12`SLLK{<%+e~{8a`{y>SBB@?vV^X2ml-Vc0)I z-<#B^%F-cme$rEY!BR2G@gz}ls>EKU0Unx6+C8ldvOeFMcw0!GA|? zduz050P#6LZ2qx716y8EhX#Y`adn7kz#Tn#`(p`a@FThq-GKf&0%T%9yc!Cu&jBPi z&vZX#%>c9A(I8x;9$|1h(UlEs8i16dk=#20vG|*XO9rIK#~SkJ2)tRiWPnZpz^o%+ zmeUOdn+7=gUg3b;J4uaAckV@myMF+ASy>2{ia{ze91Z3%yWnsUf~8{QWo02z?2Q+n z^Q4ypvyR~CdxbV-+Kd6aO5fpS?@&=df9^ftD_2-_myj3{g|I17l+;wC!C=CJBNiMw z@+I!}wj;FQ?NOQRv+(_&j?wiA4blDU-Oa@X&26nXb0`m8)f3QUy-(K>?0+hK$L3jJ z*j<2ZA=yw-FQ>hRGl%lvArzv;Y^KL7Kl0nB0;8kg|3(nx(Ghg?4-E{$qwa2$)bwAD zzWhlF3i7{&t*ws<)4^ly;7;rQk0co-7)i+{)pHyBKaU!D%DwG#mM$~3!fg$EZX5cf|_Tj=or0;y>W zc}Meq7_v~po)YiinUVf$1ZI_Y*z%TVgq48V=yd+1dtFV zKq3VEz;O2m-pd6s+#3ng={|pwd(OG<^PcCPbMCq4eL3aj<$w5phLb%vH58rCNr;xf z&&wM(^|$aSdiw9j+p)3Wq|)Sg^F06nS5!(wEL&uk4;;25U`o@S96v8_`1wqx%5F4i zpUDX}po>q!c-IU7=$PiunxD(2v6D)ZIe(GUM7VjYMM^IxubosH*8HrefKscG5+Kw@lSyhcnNV^48lprZwXRJs zO<%S$_ab`Pnq-WGXbEoKYLSWp0@PPjN=gJ#K!Ez@trn@Dk54XJo2*7axG)F+;O^oI z9*-wm^{4Id_41OLEtZNO6mkIeJq0EpM;`!iI9!AY1Ao=i1B29}fB-d*%L4$AYXTcE z7QjiR$?=Q&m6XThsS`K9C4Ts*ALkAnmI)?L!Lps(($i8F$@2eQEKP`>#o7rbNQj;V zrB)*i4-8T}^9BblkIMrG8~_ADg@NkGgt=0-4}h@%;ld!CIj9HU#RUa_IVclMo&rxd zcL2b-1Am8Q5BmGr@Y;<@&XeHg@*K<-3%}#8nSZypm+$N4gGo+KsL3B1rA)zCfRkU| zmqsSG<{tj%NwIZc0145O^u#~Bg@kBHdhh*v_~uf1dQ8NO+$*YUtUJX7S5()q;5Tz} zo9`IJ)`0;`69_CE4hKR0Q!NksAEMRRE_M-B=6|02^1gIzYeQi58hp^wM$}(7KykGM zD_@*1b9ZqC+4;03Z^FmflIzGlfs;y;W9sKiMPYvM@^r)9?mp`G!lkR2F;jr&f&(~g zY_byI*wR8mjT)?$mm=WIesuNRMMPjQl#8S|6`ukzVzK`0a#jwo0m&~$EM|NZMU~g@ zsec1m&X%9C0LPXV5`mr`XzlJn{E@jRw9Z3Hya1(g1D5kHL%yXFWW6IqAo=;*f+4=Z zL;Ue2RGoZXG1LpJuzcFWnxD}cuxsfag6rA`0QlhgW`v0ZKvfM&51$39Y7iz8;DhU% z2MxORVb{_<1gqXL^)c^opvmT-lAr{V`4duZjSh)RdsvH1H%B!(({(o#V z>I@9K$ecfUK?=$)ltR$$k9}E3sCq%SKMWU2k-Q*I`V@?xC*3L;^Hu+n;GF(D{{$S^&VV%q>v$>aZ(w3j~+_hg}1JQc=r_ z-=+X0X`{{n`Ibt!t)E2Iks^@40Ds`NeiGzcDk=5J`|SmJf5E9@q^2$A)bFVS037;p z$FO$fb^V??q^2$A6r3t%%s=KL*r+o=si>t^R=UyA{;xl~oTF6Kj@uLyibw08HP>_RCeLdHwk0EQO8*6tptdUcSvbK%*f zVZ=Y?BG}f^0e_##cr7Uf#qXD)%i4{}JWl|?oCC=?@!PKefGU4&YYKQ=F4{Ue?Cv-n zeGl#qxL>hSJ|v*G9MjpjSI8QC9GfGJ+y zunr91Ul&WU@pL9cAwsIIq`VrLRokg+U9%o}Sy^~3DFst#CpOQ5sXjh1n$0Ns=@QaE z-w36m7OPe-!J+;CpxR{Y+=PNt#aQ)u42n+VVc82WVycf1Bl|W5NPpkGgCpCUO(e~V z1u!(PND-8ZS}dGD8^F+;0027fnsM=34bpe-c&2^8NPha7ld*Ht6Ya_R?!MkZ!5Hu} z+6v3|W)tbVcW}tp5{X8g0VA&?LZ@=b_G21m2s%H2VVrbs0Ic~LZG}l=wpMrYZ9#88 zUZC^af<64Kj>Jfee1Ff6=dN#}!Rk=7qNx+W@TWk3@)b>;NF6uVnDLWPDr)WGXMHN% z>f(#$`UVs#PT-3}TRCrLd`3+6^Fzpt2mqaI&9O$Si!Ulpm!QjN92b680(2RTPpxaN zZ?IWE9&iLdD*<{sjZgd^t;|ty1V7^wA$JcS0sv;mN&o=WHGfL<_Lw;C9zF!U3;=q2 zOyhncAr*ugCI6NaDPm6m;_14AQDuj-Nl5zB+kfx--uS zrk)-=@9S&faJk|c!PC_C*yL^4uz_*oX7ry;4u25&t9t9>V&Z4wzv>(JIUH`;qX8?l zZTcDjv9U?>_SoYHQ#{h&`7__uRc0jy;OWlCPjyO8Le$KMa&4zLDJneoKdu9;_5zG| zf>l*oqJB>u4D;?_Robi6xtu6O2wk%tfBWh#-doFe*wd%ulY9&D$2YtvZeZ|Wrr_jv z5Pw|u$Bd7nFlSCEBVQN^P*tTR$e6tPh89PcoTBR17OkWl;c=`JB7l|P5hQ2+vTvyJ z4aKV=jtr&p1(=91<{D5{r6nw%wjloa66EC-Vqew~a9#Vrb?t+B(rx4~`-X}bTM3@S z7C;gsJ8zzJoAPI0))D086(aul5?DTML4Q@1c1(Y4ehXyplM!*s=~(#nD_Fm78!~oo zLTc*#VKD&tmP!CaVe^)jmhtH4Q$Zj00PylBD*y~0m6LVr*KNbDueYG&^>fIUloC63 zr9X8fjQKJ2y+H{@mIlcSQl6*_6A2*4P@trwyc!XqQ(1S44aoRE-G`B<(#Z=_uzxS> z2s#aY@RitpHQE$FaM>TbejJRz$}8*8s53wmA{=%S3=BQ}i3EM|BYh!#0|xU5kcnaI z)o5V64F^py#03P7f!k+F9Yq~dFfRt^i1Pc$TPF<4u) za+ps5K+hwfr_+rFn*yA9zi3$Ooqr6C&6s3GjE58Qva%2+5`fIea5U)K?1EFp2onjA zmz9NNfe&7K-iw+J^gMzy?-$v$X>$!YQ2q`ld!LK|24nAmU%SGrxr*eN*@&DbLRoD! z8g&NTKW)Z|(_f*>+Kq^Ux5uTkPs8``eM{vhG{z0icQ+Rov~?J9@kAc_s(&Y=wf7#C zM{uD09h-ZBG2a5@D4)8l+_L%j=ucK3KX3D4z^x>bTD27NrOpiHsagMKf-M3!N$x?yEa6f##-8L_N9%fce~e7ML|xQRftdR+qsKFETX##ebo#tf!#ehoZj} z*d;(urx9I7Bbw_Q&|Keuj14Qt+pjT^v0){}-(@t~ott1+aCEeo{Nsr1gq#TJ@AMH7 z(+9skN9GH#wPjy$bd;O`062O4TjI9rr*Th{BO%+HO*|j{0@Bv4z|-;-*upLWo|Y3Z gQLvS-z!v`l4Jw)tO%KrfnE(I)07*qoM6N<$f}mShg8%>k diff --git a/code/modules/unit_tests/screenshots/screenshot_humanoids__datum_species_jelly_luminescent.png b/code/modules/unit_tests/screenshots/screenshot_humanoids__datum_species_jelly_luminescent.png index 8fd0e16dbf400a8b1120e71033eb772c52e19a00..641c9050ee467b760c64889c1e9bfe9bea0ea529 100644 GIT binary patch delta 3305 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 delta 3339 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 delta 3034 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 diff --git a/code/modules/unit_tests/screenshots/screenshot_humanoids__datum_species_lizard.png b/code/modules/unit_tests/screenshots/screenshot_humanoids__datum_species_lizard.png index fe03a48eae3153115399ed1e6cfea1bd24927b4b..d5ac3a8f3500b3852aefa2a4f9247d1c01fa7e33 100644 GIT binary patch delta 1156 zcmV-~1bh3e3;PO?BmtI@B}N;TG61GJ7EC`ba$G*pSOBMqVksma(OVnllU$LNCldS;2t8Ez5d) zu7chF|L5*a)ZIPE(0<>IwTdtE@&c306XMU16oQWrag`*A;zvkDF@x)5v0NmY8)0-p zp$&ttjMeL>wYFx(5Lk^B0Oux<(k>TED`k9y2`i*EG7PCP;U*cAGWh)-Fu2Hnp0oVr zua`VavnakwH@A3ZmMC7+6$O)z8S;>yzjFB^OSh{nn=eE`40$1VhHaK*TQ(mIAmH;w zsnmA6RjOq0ovUzoSoWncy>yyM0BmcX3>*nw~M9bseo%sryF*idH;2R|;WI*TXuR`S0shBu3Dy$RONb~j+gK#<@=NXf zn|Jk>a*AVx5_yNi?r;E;oU9VR___=V%GytH>=Yw@5rnHL4)M2F1Q+?HExxL+SVGrz zMZ3u-_@?uf-{Vzz)YBNpfIR4MV=R@?$rJ0 z&c`ENOeZ*lp~9o|T``>i423w!lS-62pXp*Eu|4lj{?cFUX(!rgK1HKKA*m*c65i`x zYZey`omQx2o?y5_!Z1f*dNW5LElK!41UCr`Zizt86Bv7ihB$-1IPbl{+c5+V0|aU4 zZDe|TxrQpGT4e~Tig0Luxb${Jp^<)dl?w#;WCR2PHxPxkzt>@D_P)nya~nWkV)^^( zj#q=#;IKCt_7MOc3ZfE7;0?#O!48)GCO1QJjqx64-X8>mpk^41n)44S${es%i)DPk zazSXKv}U?13Kfy8mrrs0X}L~lgk>EF+PBrltT_d1W3*MQKe)Sp1Bi@|Ff!~`Idh}4 z^ckn!OPWR->^4nba5QrEfuhJ>(SBhOqC+wOfYWSxTs@+F%_u*O&yl4mF=R!{5`X~& zDQ6M3Sqg%j%}3MmjZ|!YU{JF0=uZ(a>>;$RIj2gMO8t$tT_hiS4TU<#K=~+U9|n&J z@DqBYGUPHi0x}J9q7teZK4rj{@YhDMJtYW~=3vMJ{klnv_9kVhB^ z2ntZa7yi+LDy~J5foFag@Sp2btnu5 zj~)a0CwFY&0>~r8d#}jJJir>XM@Lp`gkn`)n-?v41Wo~enTNK>TNs7t$!|_=drD5T zg>*i*?KyrNyyGyEs`;ptsX=P{9z*Q~49#3VF*L}(M0z6$xLiL+aJ@t&KtTUFf<7YQ zU66p`a|8oP5F-t?hkya*fN9P5Kmm9^^wi)d^Y?=et$CgxbZ|ZNe`=ug>vbUG!nWpL z0zwBD7<|1yJ}81c7;e4?1sXf9e&_G^_ZlXOn?v{+;%+y{-?(_01_E*jk4-S#GXDi| WU~5W37tnkF0000H)Ze9fb z=5fQ$3lR}R7zvgk-ULCgiCKa;p^CYAk!IV?X0y#w22XUpEw;H%xcM?oifxhL)s5?2 zPPNl+JSob30foiBEL>|Oh1uo19iE24i!v*yva)b=05`b?fq%}83rB-3N%yTdB>P(dD;vj0;=X)DBy~yTXofQ>LAQv@~N}*u)Au zY{7P)#yG_H4+k#7brrp5@0hRaI;z&;2w&GGH#Qnu1eLf!P!+3!+7;^lSrjEu7fFTm6__WXV+4)Q#MiQ&@ z$H`opi#mOXYCKOBXZt<Iw~R26@rO7=fo|2s9c5X=s#Vd4F}ec4sM_s|-P&6AlfRM%__J zj9+!GI|95i0y+ZS5`|R1_MvF?ror8&Z=g4>`CUHXd8;HiR4+r_3cyW)QvwO>alC6) ztLSfZFlL-F4&_bfgDxPRDSTKoCBWCAC~Thp6j$R zl7yKDLkAo9lLPFoA=uV_%dP;0+dcUkU3QLnTz_kcwWY(he$FR=ZDP9Sdjfn#-fW%W zU?|EEmJA#W_XM~~%|I}vU?8CGJB-Y~BS;f_;0O*jNqYsz2zLUA(;^|I*|dTzMUyq% z{q<{UxVAo6R6I=(Q_le=dv_3Um)hwAT(^qf6U&^dkxl9v(IGmZ`R-?+{G^W+QUGNH zw}1DFkir9^L3Pv=weC>ts;Ppzu&dVTGXJyz_sYs_K-TSZjl~?a${5LBWZB zDhX?jGv59wA)q1tkm}QgstYmj>-QRH{^IaP5^%Y88D*LP4A+ZO0t7UFM$kAUdbow#`=!G=9Cd6kJ$q{wbhy zaDnFQ^+wUfgSO8-I6+;vt6%fG-Ea;QMV}D<>uQJ_ly9{AH0=l|A>1y4wx9eTi&c+t T!ecC200000NkvXXu0mjf8B;r3 diff --git a/code/modules/unit_tests/screenshots/screenshot_humanoids__datum_species_moth.png b/code/modules/unit_tests/screenshots/screenshot_humanoids__datum_species_moth.png index a3e10254ea88ffcedaaacfcb06a8bace4ac71f4d..e39d53764434dbcc078fe1d63fba85bbace7b866 100644 GIT binary patch delta 1415 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