diff --git a/code/__defines/subsystem-defines.dm b/code/__defines/subsystem-defines.dm
index 74bc9365e27..e175903a945 100644
--- a/code/__defines/subsystem-defines.dm
+++ b/code/__defines/subsystem-defines.dm
@@ -28,6 +28,18 @@
#define TIMER_ID_NULL -1
// -- SSatoms stuff --
+// Technically this check will fail if someone loads a map mid-round, but that's not enabled right now.
+#define SSATOMS_IS_PROBABLY_DONE (SSatoms.initialized == INITIALIZATION_INNEW_REGULAR)
+
+//type and all subtypes should always call Initialize in New()
+#define INITIALIZE_IMMEDIATE(X) ##X/New(loc, ...){\
+ ..();\
+ if(!initialized) {\
+ args[1] = TRUE;\
+ SSatoms.InitAtom(src, args);\
+ }\
+}
+
// SSatoms Initialization state.
#define INITIALIZATION_INSSATOMS 0 //New should not call Initialize
#define INITIALIZATION_INNEW_MAPLOAD 1 //New should call Initialize(TRUE)
diff --git a/code/controllers/subsystems/mob.dm b/code/controllers/subsystems/mob.dm
index 00641f6ab0e..d72bb78afe9 100644
--- a/code/controllers/subsystems/mob.dm
+++ b/code/controllers/subsystems/mob.dm
@@ -55,3 +55,10 @@
if (!.)
. = new /mob/living/carbon/human/dummy/mannequin
mannequins[ckey] = .
+
+ addtimer(CALLBACK(src, .proc/del_mannequin, ckey), 5 MINUTES, TIMER_UNIQUE | TIMER_OVERRIDE)
+
+/datum/controller/subsystem/mobs/proc/del_mannequin(ckey)
+ var/mannequin = mannequins[ckey]
+ qdel(mannequin)
+ mannequins -= ckey
diff --git a/code/game/turfs/simulated/floor.dm b/code/game/turfs/simulated/floor.dm
index 9090a743f27..04040875649 100644
--- a/code/game/turfs/simulated/floor.dm
+++ b/code/game/turfs/simulated/floor.dm
@@ -31,10 +31,11 @@
if(!floortype && initial_flooring)
floortype = initial_flooring
if(floortype)
- set_flooring(get_flooring_data(floortype))
+ set_flooring(get_flooring_data(floortype), mapload)
-/turf/simulated/floor/proc/set_flooring(var/decl/flooring/newflooring)
- make_plating(defer_icon_update = 1)
+/turf/simulated/floor/proc/set_flooring(decl/flooring/newflooring, mapload)
+ if (!mapload)
+ make_plating(defer_icon_update = 1)
flooring = newflooring
update_icon(1)
levelupdate()
diff --git a/code/modules/hydroponics/seed.dm b/code/modules/hydroponics/seed.dm
index a3300f23f00..a970056bcb8 100644
--- a/code/modules/hydroponics/seed.dm
+++ b/code/modules/hydroponics/seed.dm
@@ -24,8 +24,9 @@
var/has_mob_product
var/force_layer
-/datum/seed/New()
+/datum/seed/proc/setup_traits()
+/datum/seed/New()
set_trait(TRAIT_IMMUTABLE, 0) // If set, plant will never mutate. If -1, plant is highly mutable.
set_trait(TRAIT_HARVEST_REPEAT, 0) // If 1, this plant will fruit repeatedly.
set_trait(TRAIT_PRODUCES_POWER, 0) // Can be used to make a battery.
@@ -62,7 +63,9 @@
set_trait(TRAIT_NUTRIENT_CONSUMPTION, 0.25) // Plant eats this much per tick.
set_trait(TRAIT_PLANT_COLOUR, "#46B543") // Colour of the plant icon.
- addtimer(CALLBACK(src, .proc/update_growth_stages), 5)
+ setup_traits()
+
+ update_growth_stages()
/datum/seed/proc/get_trait(var/trait)
return traits["[trait]"]
diff --git a/code/modules/hydroponics/seed_datums.dm b/code/modules/hydroponics/seed_datums.dm
index 91e2c8aa0b8..b58be12a6c3 100644
--- a/code/modules/hydroponics/seed_datums.dm
+++ b/code/modules/hydroponics/seed_datums.dm
@@ -7,7 +7,7 @@
mutants = list("icechili")
kitchen_tag = "chili"
-/datum/seed/chili/New()
+/datum/seed/chili/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,5)
@@ -28,7 +28,7 @@
chems = list("frostoil" = list(3,5), "nutriment" = list(1,50))
kitchen_tag = "icechili"
-/datum/seed/chili/ice/New()
+/datum/seed/chili/ice/setup_traits()
..()
set_trait(TRAIT_MATURATION,4)
set_trait(TRAIT_PRODUCTION,4)
@@ -43,7 +43,7 @@
chems = list("nutriment" = list(1,10), "berryjuice" = list(10,10))
kitchen_tag = "berries"
-/datum/seed/berry/New()
+/datum/seed/berry/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_JUICY,1)
@@ -64,7 +64,7 @@
mutants = null
chems = list("nutriment" = list(1,10), "uranium" = list(3,5))
-/datum/seed/berry/glow/New()
+/datum/seed/berry/glow/setup_traits()
..()
set_trait(TRAIT_SPREAD,1)
set_trait(TRAIT_BIOLUM,1)
@@ -84,7 +84,7 @@
mutants = list("deathberries")
chems = list("nutriment" = list(1), "toxin" = list(3,5), "poisonberryjuice" = list(10,5))
-/datum/seed/berry/poison/New()
+/datum/seed/berry/poison/setup_traits()
..()
set_trait(TRAIT_PRODUCT_COLOUR,"#6DC961")
set_trait(TRAIT_WATER_CONSUMPTION, 3)
@@ -97,7 +97,7 @@
mutants = null
chems = list("nutriment" = list(1), "toxin" = list(3,3), "lexorin" = list(1,5))
-/datum/seed/berry/poison/death/New()
+/datum/seed/berry/poison/death/setup_traits()
..()
set_trait(TRAIT_YIELD,3)
set_trait(TRAIT_POTENCY,50)
@@ -114,7 +114,7 @@
kitchen_tag = "nettle"
kitchen_tag = "nettle"
-/datum/seed/nettle/New()
+/datum/seed/nettle/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,6)
@@ -134,7 +134,7 @@
chems = list("nutriment" = list(1,50), "pacid" = list(0,1))
kitchen_tag = "deathnettle"
-/datum/seed/nettle/death/New()
+/datum/seed/nettle/death/setup_traits()
..()
set_trait(TRAIT_MATURATION,8)
set_trait(TRAIT_YIELD,2)
@@ -150,7 +150,7 @@
chems = list("nutriment" = list(1,10), "tomatojuice" = list(10,10))
kitchen_tag = "tomato"
-/datum/seed/tomato/New()
+/datum/seed/tomato/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_JUICY,1)
@@ -173,7 +173,7 @@
chems = list("nutriment" = list(1,10), "blood" = list(1,5))
splat_type = /obj/effect/decal/cleanable/blood/splatter
-/datum/seed/tomato/blood/New()
+/datum/seed/tomato/blood/setup_traits()
..()
set_trait(TRAIT_YIELD,3)
set_trait(TRAIT_PRODUCT_COLOUR,"#FF0000")
@@ -186,7 +186,7 @@
can_self_harvest = 1
has_mob_product = /mob/living/simple_animal/tomato
-/datum/seed/tomato/killer/New()
+/datum/seed/tomato/killer/setup_traits()
..()
set_trait(TRAIT_YIELD,2)
set_trait(TRAIT_PRODUCT_COLOUR,"#A86747")
@@ -198,7 +198,7 @@
mutants = list("bluespacetomato")
chems = list("nutriment" = list(1,20), "lube" = list(1,5))
-/datum/seed/tomato/blue/New()
+/datum/seed/tomato/blue/setup_traits()
..()
set_trait(TRAIT_PRODUCT_COLOUR,"#4D86E8")
set_trait(TRAIT_PLANT_COLOUR,"#070AAD")
@@ -210,7 +210,7 @@
mutants = null
chems = list("nutriment" = list(1,20), "singulo" = list(10,5))
-/datum/seed/tomato/blue/teleport/New()
+/datum/seed/tomato/blue/teleport/setup_traits()
..()
set_trait(TRAIT_TELEPORTING,1)
set_trait(TRAIT_PRODUCT_COLOUR,"#00E5FF")
@@ -226,7 +226,7 @@
chems = list("nutriment" = list(1,10))
kitchen_tag = "eggplant"
-/datum/seed/eggplant/New()
+/datum/seed/eggplant/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,6)
@@ -246,7 +246,7 @@
chems = list("nutriment" = list(15,30))
kitchen_tag = "realeggplant"
-/datum/seed/realeggplant/New()
+/datum/seed/realeggplant/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,4)
@@ -268,7 +268,7 @@
chems = list("nutriment" = list(1,10))
kitchen_tag = "apple"
-/datum/seed/apple/New()
+/datum/seed/apple/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,6)
@@ -294,7 +294,7 @@
chems = list("nutriment" = list(1,10), "gold" = list(1,5))
kitchen_tag = "goldapple"
-/datum/seed/apple/gold/New()
+/datum/seed/apple/gold/setup_traits()
..()
set_trait(TRAIT_MATURATION,10)
set_trait(TRAIT_PRODUCTION,10)
@@ -311,7 +311,7 @@
chems = list("nutriment" = list(1), "space_drugs" = list(1,8), "kelotane" = list(1,8,1), "bicaridine" = list(1,10,1), "toxin" = list(1,10))
kitchen_tag = "ambrosia"
-/datum/seed/ambrosia/New()
+/datum/seed/ambrosia/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,6)
@@ -331,7 +331,7 @@
chems = list("nutriment" = list(1), "bicaridine" = list(1,8), "synaptizine" = list(1,8,1), "hyperzine" = list(1,10,1), "space_drugs" = list(1,10))
kitchen_tag = "ambrosiadeus"
-/datum/seed/ambrosia/deus/New()
+/datum/seed/ambrosia/deus/setup_traits()
..()
set_trait(TRAIT_PRODUCT_COLOUR,"#A3F0AD")
set_trait(TRAIT_PLANT_COLOUR,"#2A9C61")
@@ -347,7 +347,7 @@
splat_type = /obj/effect/plant
kitchen_tag = "mushroom"
-/datum/seed/mushroom/New()
+/datum/seed/mushroom/setup_traits()
..()
set_trait(TRAIT_MATURATION,7)
set_trait(TRAIT_PRODUCTION,1)
@@ -373,7 +373,7 @@
splat_type = /obj/effect/plant
kitchen_tag = "koisspore"
-/datum/seed/koisspore/New()
+/datum/seed/koisspore/setup_traits()
..()
set_trait(TRAIT_SPREAD,1)
set_trait(TRAIT_MATURATION,5)
@@ -396,7 +396,7 @@
display_name = "brown mold"
mutants = null
-/datum/seed/mushroom/mold/New()
+/datum/seed/mushroom/mold/setup_traits()
..()
set_trait(TRAIT_SPREAD,1)
set_trait(TRAIT_MATURATION,10)
@@ -414,7 +414,7 @@
chems = list("nutriment" = list(2,10))
kitchen_tag = "plumphelmet"
-/datum/seed/mushroom/plump/New()
+/datum/seed/mushroom/plump/setup_traits()
..()
set_trait(TRAIT_MATURATION,8)
set_trait(TRAIT_YIELD,4)
@@ -432,7 +432,7 @@
can_self_harvest = 1
has_mob_product = /mob/living/simple_animal/mushroom
-/datum/seed/mushroom/plump/walking/New()
+/datum/seed/mushroom/plump/walking/setup_traits()
..()
set_trait(TRAIT_MATURATION,5)
set_trait(TRAIT_YIELD,1)
@@ -446,7 +446,7 @@
mutants = list("libertycap","glowshroom")
chems = list("nutriment" = list(1,50), "psilocybin" = list(3,5))
-/datum/seed/mushroom/hallucinogenic/New()
+/datum/seed/mushroom/hallucinogenic/setup_traits()
..()
set_trait(TRAIT_MATURATION,10)
set_trait(TRAIT_PRODUCTION,5)
@@ -464,7 +464,7 @@
mutants = null
chems = list("nutriment" = list(1), "stoxin" = list(3,3), "space_drugs" = list(1,25))
-/datum/seed/mushroom/hallucinogenic/strong/New()
+/datum/seed/mushroom/hallucinogenic/strong/setup_traits()
..()
set_trait(TRAIT_PRODUCTION,1)
set_trait(TRAIT_POTENCY,15)
@@ -480,7 +480,7 @@
mutants = list("destroyingangel","plastic")
chems = list("nutriment" = list(1), "amatoxin" = list(3,3), "psilocybin" = list(1,25))
-/datum/seed/mushroom/poison/New()
+/datum/seed/mushroom/poison/setup_traits()
..()
set_trait(TRAIT_MATURATION,10)
set_trait(TRAIT_PRODUCTION,5)
@@ -498,7 +498,7 @@
mutants = null
chems = list("nutriment" = list(1,50), "amatoxin" = list(13,3), "psilocybin" = list(1,25))
-/datum/seed/mushroom/poison/death/New()
+/datum/seed/mushroom/poison/death/setup_traits()
..()
set_trait(TRAIT_MATURATION,12)
set_trait(TRAIT_YIELD,2)
@@ -515,7 +515,7 @@
chems = list("woodpulp" = list(10,1))
mutants = null
-/datum/seed/mushroom/towercap/New()
+/datum/seed/mushroom/towercap/setup_traits()
..()
set_trait(TRAIT_MATURATION,15)
set_trait(TRAIT_PRODUCT_ICON,"mushroom7")
@@ -530,7 +530,7 @@
mutants = null
chems = list("radium" = list(1,20))
-/datum/seed/mushroom/glowshroom/New()
+/datum/seed/mushroom/glowshroom/setup_traits()
..()
set_trait(TRAIT_SPREAD,1)
set_trait(TRAIT_MATURATION,15)
@@ -550,7 +550,7 @@
mutants = null
chems = list("plasticide" = list(1,10))
-/datum/seed/mushroom/plastic/New()
+/datum/seed/mushroom/plastic/setup_traits()
..()
set_trait(TRAIT_MATURATION,5)
set_trait(TRAIT_PRODUCTION,6)
@@ -568,7 +568,7 @@
display_name = "harebells"
chems = list("nutriment" = list(1,20))
-/datum/seed/flower/New()
+/datum/seed/flower/setup_traits()
..()
set_trait(TRAIT_MATURATION,7)
set_trait(TRAIT_PRODUCTION,1)
@@ -586,7 +586,7 @@
chems = list("nutriment" = list(1,20), "bicaridine" = list(1,10))
kitchen_tag = "poppy"
-/datum/seed/flower/poppy/New()
+/datum/seed/flower/poppy/setup_traits()
..()
set_trait(TRAIT_POTENCY,20)
set_trait(TRAIT_MATURATION,8)
@@ -604,7 +604,7 @@
seed_name = "sunflower"
display_name = "sunflowers"
-/datum/seed/flower/sunflower/New()
+/datum/seed/flower/sunflower/setup_traits()
..()
set_trait(TRAIT_MATURATION,6)
set_trait(TRAIT_PRODUCT_ICON,"flower2")
@@ -622,7 +622,7 @@
mutants = list("greengrapes")
chems = list("nutriment" = list(1,10), "sugar" = list(1,5), "grapejuice" = list(10,10))
-/datum/seed/grapes/New()
+/datum/seed/grapes/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,3)
@@ -643,7 +643,7 @@
mutants = null
chems = list("nutriment" = list(1,10), "kelotane" = list(3,5), "grapejuice" = list(10,10))
-/datum/seed/grapes/green/New()
+/datum/seed/grapes/green/setup_traits()
..()
set_trait(TRAIT_PRODUCT_COLOUR,"42ed2f")
@@ -655,7 +655,7 @@
chems = list("nutriment" = list(1,10))
kitchen_tag = "peanut"
-/datum/seed/peanuts/New()
+/datum/seed/peanuts/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,6)
@@ -674,7 +674,7 @@
chems = list("nutriment" = list(1,10))
kitchen_tag = "cabbage"
-/datum/seed/cabbage/New()
+/datum/seed/cabbage/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,3)
@@ -697,7 +697,7 @@
trash_type = /obj/item/weapon/bananapeel
kitchen_tag = "banana"
-/datum/seed/banana/New()
+/datum/seed/banana/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,6)
@@ -719,7 +719,7 @@
kitchen_tag = "corn"
trash_type = /obj/item/weapon/corncob
-/datum/seed/corn/New()
+/datum/seed/corn/setup_traits()
..()
set_trait(TRAIT_MATURATION,8)
set_trait(TRAIT_PRODUCTION,6)
@@ -740,7 +740,7 @@
chems = list("nutriment" = list(1,10), "potato" = list(10,10))
kitchen_tag = "potato"
-/datum/seed/potato/New()
+/datum/seed/potato/setup_traits()
..()
set_trait(TRAIT_PRODUCES_POWER,1)
set_trait(TRAIT_MATURATION,10)
@@ -759,7 +759,7 @@
chems = list("nutriment" = list(1,20), "soymilk" = list(10,20))
kitchen_tag = "soybeans"
-/datum/seed/soybean/New()
+/datum/seed/soybean/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,4)
@@ -777,7 +777,7 @@
chems = list("nutriment" = list(1,25), "flour" = list(15,15))
kitchen_tag = "wheat"
-/datum/seed/wheat/New()
+/datum/seed/wheat/setup_traits()
..()
set_trait(TRAIT_MATURATION,6)
set_trait(TRAIT_PRODUCTION,1)
@@ -797,7 +797,7 @@
chems = list("nutriment" = list(1,25), "rice" = list(10,15))
kitchen_tag = "rice"
-/datum/seed/rice/New()
+/datum/seed/rice/setup_traits()
..()
set_trait(TRAIT_MATURATION,6)
set_trait(TRAIT_PRODUCTION,1)
@@ -817,7 +817,7 @@
chems = list("nutriment" = list(1,20), "imidazoline" = list(3,5), "carrotjuice" = list(10,20))
kitchen_tag = "carrot"
-/datum/seed/carrots/New()
+/datum/seed/carrots/setup_traits()
..()
set_trait(TRAIT_MATURATION,10)
set_trait(TRAIT_PRODUCTION,1)
@@ -833,7 +833,7 @@
seed_name = "weed"
display_name = "weeds"
-/datum/seed/weeds/New()
+/datum/seed/weeds/setup_traits()
..()
set_trait(TRAIT_MATURATION,5)
set_trait(TRAIT_PRODUCTION,1)
@@ -852,7 +852,7 @@
chems = list("nutriment" = list(0,20), "sugar" = list(1,5))
kitchen_tag = "whitebeet"
-/datum/seed/whitebeets/New()
+/datum/seed/whitebeets/setup_traits()
..()
set_trait(TRAIT_MATURATION,6)
set_trait(TRAIT_PRODUCTION,6)
@@ -870,7 +870,7 @@
display_name = "sugarcanes"
chems = list("sugar" = list(4,5))
-/datum/seed/sugarcane/New()
+/datum/seed/sugarcane/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,3)
@@ -889,7 +889,7 @@
display_name = "watermelon vine"
chems = list("nutriment" = list(1,6), "watermelonjuice" = list(10,6))
-/datum/seed/watermelon/New()
+/datum/seed/watermelon/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_JUICY,1)
@@ -913,7 +913,7 @@
chems = list("nutriment" = list(1,6))
kitchen_tag = "pumpkin"
-/datum/seed/pumpkin/New()
+/datum/seed/pumpkin/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,6)
@@ -933,7 +933,7 @@
chems = list("nutriment" = list(1,20), "limejuice" = list(10,20))
kitchen_tag = "lime"
-/datum/seed/citrus/New()
+/datum/seed/citrus/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_JUICY,1)
@@ -953,7 +953,7 @@
chems = list("nutriment" = list(1,20), "lemonjuice" = list(10,20))
kitchen_tag = "lemon"
-/datum/seed/citrus/lemon/New()
+/datum/seed/citrus/lemon/setup_traits()
..()
set_trait(TRAIT_PRODUCES_POWER,1)
set_trait(TRAIT_PRODUCT_COLOUR,"#F0E226")
@@ -967,7 +967,7 @@
kitchen_tag = "orange"
chems = list("nutriment" = list(1,20), "orangejuice" = list(10,20))
-/datum/seed/citrus/orange/New()
+/datum/seed/citrus/orange/setup_traits()
..()
set_trait(TRAIT_PRODUCT_COLOUR,"#FFC20A")
set_trait(TRAIT_FLESH_COLOUR,"#FFC20A")
@@ -979,7 +979,7 @@
chems = list("nutriment" = list(1,20))
kitchen_tag = "grass"
-/datum/seed/grass/New()
+/datum/seed/grass/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,2)
@@ -998,7 +998,7 @@
display_name = "cacao tree"
chems = list("nutriment" = list(1,10), "coco" = list(4,5))
-/datum/seed/cocoa/New()
+/datum/seed/cocoa/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_MATURATION,5)
@@ -1019,7 +1019,7 @@
chems = list("nutriment" = list(1,15), "sugar" = list(1,15), "cherryjelly" = list(10,15))
kitchen_tag = "cherries"
-/datum/seed/cherries/New()
+/datum/seed/cherries/setup_traits()
..()
set_trait(TRAIT_HARVEST_REPEAT,1)
set_trait(TRAIT_JUICY,1)
@@ -1038,7 +1038,7 @@
display_name = "kudzu vines"
chems = list("nutriment" = list(1,50), "anti_toxin" = list(1,25))
-/datum/seed/kudzu/New()
+/datum/seed/kudzu/setup_traits()
..()
set_trait(TRAIT_MATURATION,6)
set_trait(TRAIT_PRODUCTION,6)
@@ -1059,7 +1059,7 @@
can_self_harvest = 1
has_mob_product = /mob/living/carbon/alien/diona
-/datum/seed/diona/New()
+/datum/seed/diona/setup_traits()
..()
set_trait(TRAIT_IMMUTABLE,1)
set_trait(TRAIT_ENDURANCE,8)
@@ -1079,7 +1079,7 @@
chems = list("bicaridine" = list(0,10))
kitchen_tag = "shand"
-/datum/seed/shand/New()
+/datum/seed/shand/setup_traits()
..()
set_trait(TRAIT_MATURATION,3)
set_trait(TRAIT_PRODUCTION,5)
@@ -1099,7 +1099,7 @@
chems = list("honey" = list(1,10), "kelotane" = list(3,5))
kitchen_tag = "mtear"
-/datum/seed/mtear/New()
+/datum/seed/mtear/setup_traits()
..()
set_trait(TRAIT_MATURATION,3)
set_trait(TRAIT_PRODUCTION,5)
@@ -1118,7 +1118,7 @@
display_name = "telriis grass"
chems = list("pwine" = list(1,5), "nutriment" = list(1,6))
-/datum/seed/telriis/New()
+/datum/seed/telriis/setup_traits()
..()
set_trait(TRAIT_PLANT_ICON,"telriis")
set_trait(TRAIT_ENDURANCE,50)
@@ -1133,7 +1133,7 @@
display_name = "thaa'dra lichen"
chems = list("frostoil" = list(1,5),"nutriment" = list(1,5))
-/datum/seed/thaadra/New()
+/datum/seed/thaadra/setup_traits()
..()
set_trait(TRAIT_PLANT_ICON,"thaadra")
set_trait(TRAIT_ENDURANCE,10)
@@ -1148,7 +1148,7 @@
display_name = "jurl'mah reeds"
chems = list("serotrotium" = list(1,5),"nutriment" = list(1,5))
-/datum/seed/jurlmah/New()
+/datum/seed/jurlmah/setup_traits()
..()
set_trait(TRAIT_PLANT_ICON,"jurlmah")
set_trait(TRAIT_ENDURANCE,12)
@@ -1163,7 +1163,7 @@
display_name = "amauri plant"
chems = list("zombiepowder" = list(1,10),"condensedcapsaicin" = list(1,5),"nutriment" = list(1,5))
-/datum/seed/amauri/New()
+/datum/seed/amauri/setup_traits()
..()
set_trait(TRAIT_PLANT_ICON,"amauri")
set_trait(TRAIT_ENDURANCE,10)
@@ -1178,7 +1178,7 @@
display_name = "gelthi plant"
chems = list("stoxin" = list(1,5),"capsaicin" = list(1,5),"nutriment" = list(1,5))
-/datum/seed/gelthi/New()
+/datum/seed/gelthi/setup_traits()
..()
set_trait(TRAIT_PLANT_ICON,"gelthi")
set_trait(TRAIT_ENDURANCE,15)
@@ -1193,7 +1193,7 @@
display_name = "vale bush"
chems = list("paracetamol" = list(1,5),"dexalin" = list(1,2),"nutriment"= list(1,5))
-/datum/seed/vale/New()
+/datum/seed/vale/setup_traits()
..()
set_trait(TRAIT_PLANT_ICON,"vale")
set_trait(TRAIT_ENDURANCE,15)
@@ -1208,7 +1208,7 @@
display_name = "surik vine"
chems = list("impedrezene" = list(1,3),"synaptizine" = list(1,2),"nutriment" = list(1,5))
-/datum/seed/surik/New()
+/datum/seed/surik/setup_traits()
..()
set_trait(TRAIT_PLANT_ICON,"surik")
set_trait(TRAIT_ENDURANCE,18)
@@ -1225,7 +1225,7 @@
force_layer = 3
chems = list("phoron" = list(1,3))
-/datum/seed/xenomorph/New()
+/datum/seed/xenomorph/setup_traits()
..()
set_trait(TRAIT_PLANT_ICON,"vine2")
set_trait(TRAIT_IMMUTABLE,1)
diff --git a/code/modules/mob/living/carbon/brain/brain_item.dm b/code/modules/mob/living/carbon/brain/brain_item.dm
index 286a5d9c32a..eb4ebd1de26 100644
--- a/code/modules/mob/living/carbon/brain/brain_item.dm
+++ b/code/modules/mob/living/carbon/brain/brain_item.dm
@@ -32,12 +32,15 @@
icon = 'icons/mob/alien.dmi'
icon_state = "chitin"
-/obj/item/organ/brain/New()
- ..()
+/obj/item/organ/brain/Initialize(mapload)
+ . = ..()
health = config.default_brain_health
- spawn(5)
- if(brainmob && brainmob.client)
- brainmob.client.screen.len = null //clear the hud
+ if (!mapload)
+ addtimer(CALLBACK(src, .proc/clear_screen), 5)
+
+/obj/item/organ/brain/proc/clear_screen()
+ if (brainmob && brainmob.client)
+ brainmob.client.screen.Cut()
/obj/item/organ/brain/Destroy()
if(brainmob)
diff --git a/code/modules/mob/living/carbon/human/human_species.dm b/code/modules/mob/living/carbon/human/human_species.dm
index c99f1036288..75c41cb39a8 100644
--- a/code/modules/mob/living/carbon/human/human_species.dm
+++ b/code/modules/mob/living/carbon/human/human_species.dm
@@ -2,11 +2,7 @@
real_name = "Test Dummy"
status_flags = GODMODE|CANPUSH
-/mob/living/carbon/human/dummy/mannequin/New(location, ...)
- ..()
- if (!initialized)
- args[1] = TRUE
- SSatoms.InitAtom(src, args)
+INITIALIZE_IMMEDIATE(/mob/living/carbon/human/dummy/mannequin)
/mob/living/carbon/human/dummy/mannequin/Initialize()
. = ..()
diff --git a/code/modules/mob/new_player/new_player.dm b/code/modules/mob/new_player/new_player.dm
index 52dfc47f312..85335c27223 100644
--- a/code/modules/mob/new_player/new_player.dm
+++ b/code/modules/mob/new_player/new_player.dm
@@ -114,13 +114,13 @@
new_player_panel_proc()
if(href_list["observe"])
- if (SSatoms.initialized < INITIALIZATION_INNEW_REGULAR)
+ if (!SSATOMS_IS_PROBABLY_DONE)
// Don't allow players to observe until initialization is more or less complete.
// Letting them join too early breaks things, they can wait.
- src << span("alert", "The server is still initializing, try observing again in a minute or so.")
- return
+ alert(src, "Please wait, the map is not initialized yet.")
+ return 0
- if(alert(src,"Are you sure you wish to observe? You will have to wait 30 minutes before being able to respawn!","Player Setup","Yes","No") == "Yes")
+ if(alert(src,"Are you sure you wish to observe? You will have to wait [config.respawn_delay] minutes before being able to respawn!","Player Setup","Yes","No") == "Yes")
if(!client) return 1
var/mob/dead/observer/observer = new /mob/dead/observer(src)
spawning = 1
diff --git a/code/modules/organs/organ.dm b/code/modules/organs/organ.dm
index 44694d6f5f9..b5ab7a5e9f8 100644
--- a/code/modules/organs/organ.dm
+++ b/code/modules/organs/organ.dm
@@ -27,6 +27,12 @@
var/force_skintone = FALSE // If true, icon generation will skip is-robotic checks. Used for synthskin limbs.
+/obj/item/organ/New(loc, ...)
+ ..()
+ if (!initialized && istype(loc, /mob/living/carbon/human/dummy/mannequin))
+ args[1] = TRUE
+ SSatoms.InitAtom(src, args)
+
/obj/item/organ/Destroy()
STOP_PROCESSING(SSprocessing, src)
if(!owner)
@@ -51,8 +57,9 @@
/obj/item/organ/proc/update_health()
return
-/obj/item/organ/New(var/mob/living/carbon/holder, var/internal)
- ..(holder)
+/obj/item/organ/Initialize(mapload, internal)
+ . = ..()
+ var/mob/living/carbon/holder = loc
create_reagents(5)
if(!max_damage)
max_damage = min_broken_damage * 2
diff --git a/code/modules/organs/organ_external.dm b/code/modules/organs/organ_external.dm
index 7db91b28752..3bf11af498d 100644
--- a/code/modules/organs/organ_external.dm
+++ b/code/modules/organs/organ_external.dm
@@ -165,18 +165,17 @@
damage = min(max_damage, (brute_dam + burn_dam))
return
-
-/obj/item/organ/external/New(var/mob/living/carbon/holder)
- ..(holder, 0)
+/obj/item/organ/external/Initialize(mapload)
+ . = ..(mapload, FALSE)
if(owner)
replaced(owner)
sync_colour_to_human(owner)
- addtimer(CALLBACK(src, .proc/get_icon), 1)
-
if ((status & ORGAN_PLANT))
cannot_break = 1
+ get_icon()
+
/obj/item/organ/external/replaced(var/mob/living/carbon/human/target)
owner = target
forceMove(owner)
diff --git a/code/modules/organs/organ_internal.dm b/code/modules/organs/organ_internal.dm
index 0a8556ede4a..1403a61a9e1 100644
--- a/code/modules/organs/organ_internal.dm
+++ b/code/modules/organs/organ_internal.dm
@@ -240,14 +240,14 @@ obj/item/organ/vaurca/neuralsocket/process()
var/volume = 50
var/manipulated_by = null
-/obj/item/organ/vaurca/preserve/New()
- ..()
+/obj/item/organ/vaurca/preserve/Initialize()
+ . = ..()
- src.air_contents = new /datum/gas_mixture()
- src.air_contents.adjust_gas("phoron", (ONE_ATMOSPHERE)*volume/(R_IDEAL_GAS_EQUATION*T20C))
- src.air_contents.volume = volume //liters
- src.air_contents.temperature = T20C
- src.distribute_pressure = ((pick(1.8,2.0,2.4,2.8)*ONE_ATMOSPHERE)*O2STANDARD)
+ air_contents = new /datum/gas_mixture()
+ air_contents.adjust_gas("phoron", (ONE_ATMOSPHERE)*volume/(R_IDEAL_GAS_EQUATION*T20C))
+ air_contents.volume = volume //liters
+ air_contents.temperature = T20C
+ distribute_pressure = ((pick(1.8,2.0,2.4,2.8)*ONE_ATMOSPHERE)*O2STANDARD)
START_PROCESSING(SSprocessing, src)
var/mob/living/carbon/location = loc
diff --git a/code/modules/organs/organ_stump.dm b/code/modules/organs/organ_stump.dm
index d59e7470337..a0d35476ea8 100644
--- a/code/modules/organs/organ_stump.dm
+++ b/code/modules/organs/organ_stump.dm
@@ -3,7 +3,7 @@
icon_name = ""
dislocated = -1
-/obj/item/organ/external/stump/New(var/mob/living/carbon/holder, var/internal, var/obj/item/organ/external/limb)
+/obj/item/organ/external/stump/Initialize(mapload, var/internal, var/obj/item/organ/external/limb)
if(istype(limb))
limb_name = limb.limb_name
body_part = limb.body_part
@@ -11,7 +11,7 @@
joint = limb.joint
parent_organ = limb.parent_organ
wounds = limb.wounds
- ..(holder, internal)
+ . = ..(mapload, internal)
if(istype(limb))
max_damage = limb.max_damage
if((limb.status & ORGAN_ROBOT) && (!parent || (parent.status & ORGAN_ROBOT)))
diff --git a/code/modules/organs/subtypes/machine.dm b/code/modules/organs/subtypes/machine.dm
index e0143d5d760..10b14a8ae9c 100644
--- a/code/modules/organs/subtypes/machine.dm
+++ b/code/modules/organs/subtypes/machine.dm
@@ -6,88 +6,88 @@
can_intake_reagents = 0
encased = "support frame"
-/obj/item/organ/external/head/ipc/New()
+/obj/item/organ/external/head/ipc/Initialize()
robotize("Hephaestus Integrated Limb")
- ..()
+ . = ..()
/obj/item/organ/external/chest/ipc
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/chest/ipc/New()
+/obj/item/organ/external/chest/ipc/Initialize()
robotize("Hephaestus Integrated Limb")
- ..()
+ . = ..()
/obj/item/organ/external/groin/ipc
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/groin/ipc/New()
+/obj/item/organ/external/groin/ipc/Initialize()
robotize("Hephaestus Integrated Limb")
- ..()
+ . = ..()
/obj/item/organ/external/arm/ipc
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/arm/ipc/New()
+/obj/item/organ/external/arm/ipc/Initialize()
robotize("Hephaestus Integrated Limb")
- ..()
+ . = ..()
/obj/item/organ/external/arm/right/ipc
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/arm/right/ipc/New()
+/obj/item/organ/external/arm/right/ipc/Initialize()
robotize("Hephaestus Integrated Limb")
- ..()
+ . = ..()
/obj/item/organ/external/leg/ipc
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/leg/ipc/New()
+/obj/item/organ/external/leg/ipc/Initialize()
robotize("Hephaestus Integrated Limb")
- ..()
+ . = ..()
/obj/item/organ/external/leg/right/ipc
dislocated = -1
-/obj/item/organ/external/leg/right/ipc/New()
+/obj/item/organ/external/leg/right/ipc/Initialize()
robotize("Hephaestus Integrated Limb")
- ..()
+ . = ..()
/obj/item/organ/external/foot/ipc
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/foot/ipc/New()
+/obj/item/organ/external/foot/ipc/Initialize()
robotize("Hephaestus Integrated Limb")
- ..()
+ . = ..()
/obj/item/organ/external/foot/right/ipc
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/foot/right/ipc/New()
+/obj/item/organ/external/foot/right/ipc/Initialize()
robotize("Hephaestus Integrated Limb")
- ..()
+ . = ..()
/obj/item/organ/external/hand/ipc
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/hand/ipc/New()
+/obj/item/organ/external/hand/ipc/Initialize()
robotize("Hephaestus Integrated Limb")
- ..()
+ . = ..()
/obj/item/organ/external/hand/right/ipc
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/hand/right/ipc/New()
+/obj/item/organ/external/hand/right/ipc/Initialize()
robotize("Hephaestus Integrated Limb")
- ..()
+ . = ..()
/obj/item/organ/cell
name = "microbattery"
@@ -98,12 +98,12 @@
parent_organ = "chest"
vital = 1
-/obj/item/organ/cell/New()
+/obj/item/organ/cell/Initialize()
robotize()
- ..()
+ . = ..()
/obj/item/organ/cell/replaced()
- ..()
+ . = ..()
// This is very ghetto way of rebooting an IPC. TODO better way.
if(owner && owner.stat == DEAD)
owner.stat = 0
@@ -116,9 +116,9 @@
icon_state = "camera"
dead_icon = "camera_broken"
-/obj/item/organ/eyes/optical_sensor/New()
+/obj/item/organ/eyes/optical_sensor/Initialize()
robotize()
- ..()
+ . = ..()
/obj/item/organ/ipc_tag
name = "identification tag"
@@ -128,9 +128,9 @@
icon_state = "gps-c"
dead_icon = "gps-c"
-/obj/item/organ/ipc_tag/New()
+/obj/item/organ/ipc_tag/Initialize()
robotize()
- ..()
+ . = ..()
// Used for an MMI or posibrain being installed into a human.
/obj/item/organ/mmi_holder
@@ -154,36 +154,40 @@
stored_mmi.loc = get_turf(src)
if(owner.mind)
owner.mind.transfer_to(stored_mmi.brainmob)
- ..()
+ . = ..()
var/mob/living/holder_mob = loc
if(istype(holder_mob))
holder_mob.drop_from_inventory(src)
qdel(src)
-/obj/item/organ/mmi_holder/New()
- ..()
+/obj/item/organ/mmi_holder/Initialize(mapload)
+ . = ..()
// This is very ghetto way of rebooting an IPC. TODO better way.
- spawn(1)
- if(owner && owner.stat == DEAD)
- owner.stat = 0
- owner.visible_message("\The [owner] twitches visibly!")
+ if (!mapload)
+ addtimer(CALLBACK(src, .proc/attempt_revive), 1)
-/obj/item/organ/mmi_holder/posibrain/New()
+/obj/item/organ/mmi_holder/proc/attempt_revive()
+ if (owner && owner.stat == DEAD)
+ owner.stat = 0
+ owner.visible_message("\The [owner] twitches visibly!")
+
+/obj/item/organ/mmi_holder/posibrain/Initialize()
robotize()
stored_mmi = new /obj/item/device/mmi/digital/posibrain(src)
- ..()
- spawn(1)
- if(owner)
- stored_mmi.name = "positronic brain ([owner.name])"
- stored_mmi.brainmob.real_name = owner.name
- stored_mmi.brainmob.name = stored_mmi.brainmob.real_name
- stored_mmi.icon_state = "posibrain-occupied"
- update_from_mmi()
- else
- stored_mmi.loc = get_turf(src)
- qdel(src)
+ . = ..()
+ addtimer(CALLBACK(src, .proc/setup_brain), 1)
+/obj/item/organ/mmi_holder/posibrain/proc/setup_brain()
+ if(owner)
+ stored_mmi.name = "positronic brain ([owner.name])"
+ stored_mmi.brainmob.real_name = owner.name
+ stored_mmi.brainmob.name = stored_mmi.brainmob.real_name
+ stored_mmi.icon_state = "posibrain-occupied"
+ update_from_mmi()
+ else
+ stored_mmi.loc = get_turf(src)
+ qdel(src)
//////////////
//Terminator//
@@ -205,9 +209,9 @@
vital = 0
emp_coeff = 0.1
-/obj/item/organ/data/New()
+/obj/item/organ/data/Initialize()
robotize()
- ..()
+ . = ..()
/obj/item/organ/cell/terminator
name = "shielded microbattery"
@@ -219,9 +223,9 @@
vital = 1
emp_coeff = 0.1
-/obj/item/organ/cell/New()
+/obj/item/organ/cell/Initialize()
robotize()
- ..()
+ . = ..()
/obj/item/organ/external/head/terminator
dislocated = -1
@@ -232,99 +236,99 @@
/obj/item/organ/eyes/optical_sensor/terminator
emp_coeff = 0.5
-/obj/item/organ/external/head/terminator/New()
+/obj/item/organ/external/head/terminator/Initialize()
robotize("Hephaestus Vulcanite Limb")
- ..()
+ . = ..()
/obj/item/organ/external/chest/terminator
dislocated = -1
encased = "reinforced support frame"
emp_coeff = 0.5
-/obj/item/organ/external/chest/terminator/New()
+/obj/item/organ/external/chest/terminator/Initialize()
robotize("Hephaestus Vulcanite Limb")
- ..()
+ . = ..()
/obj/item/organ/external/groin/terminator
dislocated = -1
encased = "reinforced support frame"
emp_coeff = 0.5
-/obj/item/organ/external/groin/terminator/New()
+/obj/item/organ/external/groin/terminator/Initialize()
robotize("Hephaestus Vulcanite Limb")
- ..()
+ . = ..()
/obj/item/organ/external/arm/terminator
dislocated = -1
encased = "reinforced support frame"
emp_coeff = 0.5
-/obj/item/organ/external/arm/terminator/New()
+/obj/item/organ/external/arm/terminator/Initialize()
robotize("Hephaestus Vulcanite Limb")
- ..()
+ . = ..()
/obj/item/organ/external/arm/right/terminator
dislocated = -1
encased = "reinforced support frame"
emp_coeff = 0.5
-/obj/item/organ/external/arm/right/terminator/New()
+/obj/item/organ/external/arm/right/terminator/Initialize()
robotize("Hephaestus Vulcanite Limb")
- ..()
+ . = ..()
/obj/item/organ/external/leg/terminator
dislocated = -1
encased = "reinforced support frame"
emp_coeff = 0.5
-/obj/item/organ/external/leg/terminator/New()
+/obj/item/organ/external/leg/terminator/Initialize()
robotize("Hephaestus Vulcanite Limb")
- ..()
+ . = ..()
/obj/item/organ/external/leg/right/terminator
dislocated = -1
encased = "reinforced support frame"
emp_coeff = 0.5
-/obj/item/organ/external/leg/right/terminator/New()
+/obj/item/organ/external/leg/right/terminator/Initialize()
robotize("Hephaestus Vulcanite Limb")
- ..()
+ . = ..()
/obj/item/organ/external/foot/terminator
dislocated = -1
encased = "reinforced support frame"
emp_coeff = 0.5
-/obj/item/organ/external/foot/terminator/New()
+/obj/item/organ/external/foot/terminator/Initialize()
robotize("Hephaestus Vulcanite Limb")
- ..()
+ . = ..()
/obj/item/organ/external/foot/right/terminator
dislocated = -1
encased = "reinforced support frame"
emp_coeff = 0.5
-/obj/item/organ/external/foot/right/terminator/New()
+/obj/item/organ/external/foot/right/terminator/Initialize()
robotize("Hephaestus Vulcanite Limb")
- ..()
+ . = ..()
/obj/item/organ/external/hand/terminator
dislocated = -1
encased = "reinforced support frame"
emp_coeff = 0.5
-/obj/item/organ/external/hand/terminator/New()
+/obj/item/organ/external/hand/terminator/Initialize()
robotize("Hephaestus Vulcanite Limb")
- ..()
+ . = ..()
/obj/item/organ/external/hand/right/terminator
dislocated = -1
encased = "reinforced support frame"
emp_coeff = 0.5
-/obj/item/organ/external/hand/right/terminator/New()
+/obj/item/organ/external/hand/right/terminator/Initialize()
robotize("Hephaestus Vulcanite Limb")
- ..()
+ . = ..()
//////////////
//Industrial//
@@ -335,89 +339,89 @@
can_intake_reagents = 0
encased = "support frame"
-/obj/item/organ/external/head/industrial/New()
+/obj/item/organ/external/head/industrial/Initialize()
robotize("Hephaestus Industrial Limb")
- ..()
+ . = ..()
/obj/item/organ/external/chest/industrial
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/chest/industrial/New()
+/obj/item/organ/external/chest/industrial/Initialize()
robotize("Hephaestus Industrial Limb")
- ..()
+ . = ..()
/obj/item/organ/external/groin/industrial
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/groin/industrial/New()
+/obj/item/organ/external/groin/industrial/Initialize()
robotize("Hephaestus Industrial Limb")
- ..()
+ . = ..()
/obj/item/organ/external/arm/industrial
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/arm/industrial/New()
+/obj/item/organ/external/arm/industrial/Initialize()
robotize("Hephaestus Industrial Limb")
- ..()
+ . = ..()
/obj/item/organ/external/arm/right/industrial
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/arm/right/industrial/New()
+/obj/item/organ/external/arm/right/industrial/Initialize()
robotize("Hephaestus Industrial Limb")
- ..()
+ . = ..()
/obj/item/organ/external/leg/industrial
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/leg/industrial/New()
+/obj/item/organ/external/leg/industrial/Initialize()
robotize("Hephaestus Industrial Limb")
- ..()
+ . = ..()
/obj/item/organ/external/leg/right/industrial
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/leg/right/industrial/New()
+/obj/item/organ/external/leg/right/industrial/Initialize()
robotize("Hephaestus Industrial Limb")
- ..()
+ . = ..()
/obj/item/organ/external/foot/industrial
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/foot/industrial/New()
+/obj/item/organ/external/foot/industrial/Initialize()
robotize("Hephaestus Industrial Limb")
- ..()
+ . = ..()
/obj/item/organ/external/foot/right/industrial
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/foot/right/industrial/New()
+/obj/item/organ/external/foot/right/industrial/Initialize()
robotize("Hephaestus Industrial Limb")
- ..()
+ . = ..()
/obj/item/organ/external/hand/industrial
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/hand/industrial/New()
+/obj/item/organ/external/hand/industrial/Initialize()
robotize("Hephaestus Industrial Limb")
- ..()
+ . = ..()
/obj/item/organ/external/hand/right/industrial
dislocated = -1
encased = "support frame"
-/obj/item/organ/external/hand/right/industrial/New()
+/obj/item/organ/external/hand/right/industrial/Initialize()
robotize("Hephaestus Industrial Limb")
- ..()
+ . = ..()
///////////////
//Shell limbs//
@@ -429,9 +433,9 @@
encased = "support frame"
force_skintone = TRUE
-/obj/item/organ/external/head/shell/New()
+/obj/item/organ/external/head/shell/Initialize()
robotize("Human Synthskin")
- ..()
+ . = ..()
/obj/item/organ/external/chest/shell
dislocated = -1
@@ -439,87 +443,87 @@
force_skintone = TRUE
-/obj/item/organ/external/chest/shell/New()
+/obj/item/organ/external/chest/shell/Initialize()
robotize("Human Synthskin")
- ..()
+ . = ..()
/obj/item/organ/external/groin/shell
dislocated = -1
encased = "support frame"
force_skintone = TRUE
-/obj/item/organ/external/groin/shell/New()
+/obj/item/organ/external/groin/shell/Initialize()
robotize("Human Synthskin")
- ..()
+ . = ..()
/obj/item/organ/external/arm/shell
dislocated = -1
encased = "support frame"
force_skintone = TRUE
-/obj/item/organ/external/arm/shell/New()
+/obj/item/organ/external/arm/shell/Initialize()
robotize("Human Synthskin")
- ..()
+ . = ..()
/obj/item/organ/external/arm/right/shell
dislocated = -1
encased = "support frame"
force_skintone = TRUE
-/obj/item/organ/external/arm/right/shell/New()
+/obj/item/organ/external/arm/right/shell/Initialize()
robotize("Human Synthskin")
- ..()
+ . = ..()
/obj/item/organ/external/leg/shell
dislocated = -1
encased = "support frame"
force_skintone = TRUE
-/obj/item/organ/external/leg/shell/New()
+/obj/item/organ/external/leg/shell/Initialize()
robotize("Human Synthskin")
- ..()
+ . = ..()
/obj/item/organ/external/leg/right/shell
dislocated = -1
encased = "support frame"
force_skintone = TRUE
-/obj/item/organ/external/leg/right/shell/New()
+/obj/item/organ/external/leg/right/shell/Initialize()
robotize("Human Synthskin")
- ..()
+ . = ..()
/obj/item/organ/external/foot/shell
dislocated = -1
encased = "support frame"
force_skintone = TRUE
-/obj/item/organ/external/foot/shell/New()
+/obj/item/organ/external/foot/shell/Initialize()
robotize("Human Synthskin")
- ..()
+ . = ..()
/obj/item/organ/external/foot/right/shell
dislocated = -1
encased = "support frame"
force_skintone = TRUE
-/obj/item/organ/external/foot/right/shell/New()
+/obj/item/organ/external/foot/right/shell/Initialize()
robotize("Human Synthskin")
- ..()
+ . = ..()
/obj/item/organ/external/hand/shell
dislocated = -1
encased = "support frame"
force_skintone = TRUE
-/obj/item/organ/external/hand/shell/New()
+/obj/item/organ/external/hand/shell/Initialize()
robotize("Human Synthskin")
- ..()
+ . = ..()
/obj/item/organ/external/hand/right/shell
dislocated = -1
encased = "support frame"
force_skintone = TRUE
-/obj/item/organ/external/hand/right/shell/New()
+/obj/item/organ/external/hand/right/shell/Initialize()
robotize("Human Synthskin")
- ..()
+ . = ..()
diff --git a/code/modules/spells/aoe_turf/conjure/grove.dm b/code/modules/spells/aoe_turf/conjure/grove.dm
index db452e7eb7b..b1e07ef0dcc 100644
--- a/code/modules/spells/aoe_turf/conjure/grove.dm
+++ b/code/modules/spells/aoe_turf/conjure/grove.dm
@@ -61,7 +61,7 @@
chems = list("bicaridine" = list(3,7), "dermaline" = list(3,7), "anti_toxin" = list(3,7), "tricordrazine" = list(3,7), "alkysine" = list(1,2), "imidazoline" = list(1,2), "peridaxon" = list(4,5))
kitchen_tag = "berries"
-/datum/seed/merlin_tear/New()
+/datum/seed/merlin_tear/setup_traits()
..()
set_trait(TRAIT_PLANT_ICON,"bush5")
set_trait(TRAIT_PRODUCT_ICON,"berry")