diff --git a/_maps/RandomRooms/10x10/sk_rdm033_deltalibrary.dmm b/_maps/RandomRooms/10x10/sk_rdm033_deltalibrary.dmm
index 3b068ffc4b534..f878c364a35e4 100644
--- a/_maps/RandomRooms/10x10/sk_rdm033_deltalibrary.dmm
+++ b/_maps/RandomRooms/10x10/sk_rdm033_deltalibrary.dmm
@@ -188,7 +188,7 @@
/turf/open/floor/plasteel/dark,
/area/template_noop)
"I" = (
-/mob/living/simple_animal/cockroach,
+/mob/living/basic/cockroach,
/turf/open/floor/wood,
/area/template_noop)
"J" = (
diff --git a/_maps/RandomRooms/5x3/sk_rdm042_deltaclutter2.dmm b/_maps/RandomRooms/5x3/sk_rdm042_deltaclutter2.dmm
index 3b05724c7a235..4eaa526653506 100644
--- a/_maps/RandomRooms/5x3/sk_rdm042_deltaclutter2.dmm
+++ b/_maps/RandomRooms/5x3/sk_rdm042_deltaclutter2.dmm
@@ -42,7 +42,7 @@
},
/area/template_noop)
"g" = (
-/mob/living/simple_animal/cockroach,
+/mob/living/basic/cockroach,
/turf/open/floor/wood,
/area/template_noop)
"h" = (
diff --git a/_maps/RandomRooms/5x4/sk_rdm034_deltadetective.dmm b/_maps/RandomRooms/5x4/sk_rdm034_deltadetective.dmm
index d490235863c62..e918fc029d8ea 100644
--- a/_maps/RandomRooms/5x4/sk_rdm034_deltadetective.dmm
+++ b/_maps/RandomRooms/5x4/sk_rdm034_deltadetective.dmm
@@ -14,7 +14,7 @@
/turf/open/floor/wood,
/area/template_noop)
"d" = (
-/mob/living/simple_animal/cockroach,
+/mob/living/basic/cockroach,
/turf/open/floor/wood,
/area/template_noop)
"f" = (
diff --git a/_maps/RandomRooms/5x4/sk_rdm041_deltagamble.dmm b/_maps/RandomRooms/5x4/sk_rdm041_deltagamble.dmm
index 4a5014cc128d0..87c2cab996dce 100644
--- a/_maps/RandomRooms/5x4/sk_rdm041_deltagamble.dmm
+++ b/_maps/RandomRooms/5x4/sk_rdm041_deltagamble.dmm
@@ -69,7 +69,7 @@
/area/template_noop)
"n" = (
/obj/effect/decal/cleanable/dirt,
-/mob/living/simple_animal/cockroach,
+/mob/living/basic/cockroach,
/turf/open/floor/wood{
icon_state = "wood-broken5"
},
diff --git a/_maps/RandomRuins/LavaRuins/lavaland_surface_animal_hospital.dmm b/_maps/RandomRuins/LavaRuins/lavaland_surface_animal_hospital.dmm
index a3016008a4569..4d1743636ddd0 100644
--- a/_maps/RandomRuins/LavaRuins/lavaland_surface_animal_hospital.dmm
+++ b/_maps/RandomRuins/LavaRuins/lavaland_surface_animal_hospital.dmm
@@ -58,17 +58,6 @@
},
/turf/open/floor/plasteel/white,
/area/ruin/powered/animal_hospital)
-"ax" = (
-/obj/structure/closet/crate/trashcart,
-/obj/item/storage/bag/trash,
-/obj/item/trash/cheesie,
-/obj/item/reagent_containers/syringe/antiviral,
-/obj/item/bodybag,
-/obj/item/reagent_containers/food/drinks/bottle/vodka,
-/turf/open/floor/grass{
- initial_gas_mix = "o2=14;n2=5;co2=13;TEMP=300"
- },
-/area/lavaland/surface/outdoors)
"aA" = (
/obj/structure/closet/secure_closet/medical2,
/turf/open/floor/plasteel/white,
@@ -750,6 +739,17 @@
},
/turf/open/floor/plasteel,
/area/ruin/powered/animal_hospital)
+"xK" = (
+/obj/structure/closet/crate/trashcart,
+/obj/item/storage/bag/trash,
+/obj/item/trash/cheesie,
+/obj/item/reagent_containers/syringe/antiviral,
+/obj/item/bodybag,
+/obj/item/reagent_containers/food/drinks/bottle/vodka,
+/turf/open/floor/grass{
+ initial_gas_mix = "o2=14;n2=5;co2=13;TEMP=300"
+ },
+/area/lavaland/surface/outdoors)
"yl" = (
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
@@ -1007,14 +1007,6 @@
},
/turf/open/floor/plasteel/white,
/area/ruin/powered/animal_hospital)
-"Mf" = (
-/mob/living/simple_animal/cockroach,
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
-/obj/machinery/atmospherics/pipe/manifold/scrubbers/hidden/layer4{
- dir = 4
- },
-/turf/open/floor/plating,
-/area/ruin/powered/animal_hospital)
"Ms" = (
/obj/machinery/smartfridge/chemistry/preloaded,
/turf/open/floor/plasteel/white,
@@ -1071,6 +1063,14 @@
},
/turf/open/floor/plasteel/white,
/area/ruin/powered/animal_hospital)
+"Qm" = (
+/mob/living/basic/cockroach,
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
+/obj/machinery/atmospherics/pipe/manifold/scrubbers/hidden/layer4{
+ dir = 4
+ },
+/turf/open/floor/plating,
+/area/ruin/powered/animal_hospital)
"QL" = (
/obj/structure/chair/office{
dir = 1
@@ -1413,7 +1413,7 @@ aa
aa
ab
cp
-ax
+xK
ac
aJ
ac
@@ -1480,7 +1480,7 @@ Nl
zK
dC
oj
-Mf
+Qm
zK
Nl
Ik
diff --git a/_maps/map_files/BoxStation/BoxStation.dmm b/_maps/map_files/BoxStation/BoxStation.dmm
index e87735ce70704..791d742920628 100644
--- a/_maps/map_files/BoxStation/BoxStation.dmm
+++ b/_maps/map_files/BoxStation/BoxStation.dmm
@@ -10512,11 +10512,6 @@
/obj/structure/bodycontainer/morgue,
/turf/open/floor/plasteel/dark,
/area/medical/morgue)
-"bDM" = (
-/obj/machinery/camera/autoname,
-/obj/effect/mapping_helpers/dead_body_placer/medbay_morgue,
-/turf/open/floor/plasteel/dark,
-/area/medical/morgue)
"bDO" = (
/obj/structure/bodycontainer/morgue{
dir = 2
@@ -33619,10 +33614,6 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel/dark,
/area/crew_quarters/heads/chief)
-"jLP" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/wood,
-/area/vacant_room/office)
"jLS" = (
/turf/open/floor/plasteel/white,
/area/medical/chemistry)
@@ -43654,6 +43645,10 @@
},
/turf/open/floor/plasteel,
/area/hallway/primary/aft)
+"ozX" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/wood,
+/area/vacant_room/office)
"oAj" = (
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
dir = 1
@@ -47162,11 +47157,6 @@
/obj/structure/grille/broken,
/turf/open/space/basic,
/area/space/nearstation)
-"qva" = (
-/obj/effect/decal/cleanable/dirt,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/carpet,
-/area/vacant_room/office)
"qve" = (
/obj/structure/sign/warning/vacuum/external{
pixel_y = 32
@@ -53218,6 +53208,11 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel/dark,
/area/engine/engineering)
+"tfE" = (
+/obj/machinery/camera/autoname,
+/obj/effect/mapping_helpers/dead_body_placer/medbay_morgue,
+/turf/open/floor/plasteel/dark,
+/area/medical/morgue)
"tfI" = (
/obj/structure/cable/yellow{
icon_state = "4-8"
@@ -60281,6 +60276,11 @@
},
/turf/open/floor/plasteel/white,
/area/science/robotics/lab)
+"wVH" = (
+/obj/effect/decal/cleanable/dirt,
+/mob/living/basic/cockroach,
+/turf/open/floor/carpet,
+/area/vacant_room/office)
"wVL" = (
/obj/structure/sign/warning/electricshock{
pixel_y = 32
@@ -76796,7 +76796,7 @@ ayl
czK
vsd
fLl
-jLP
+ozX
sdS
lNE
czK
@@ -77825,7 +77825,7 @@ czK
sSD
dUJ
pSb
-qva
+wVH
enh
czK
dMm
@@ -93782,7 +93782,7 @@ xTN
hKs
aJq
cBD
-bDM
+tfE
bFi
vNj
dRs
diff --git a/_maps/map_files/Deltastation/DeltaStation2.dmm b/_maps/map_files/Deltastation/DeltaStation2.dmm
index 58a127973808f..646e542f4f02c 100644
--- a/_maps/map_files/Deltastation/DeltaStation2.dmm
+++ b/_maps/map_files/Deltastation/DeltaStation2.dmm
@@ -1218,10 +1218,6 @@
/obj/effect/landmark/blobstart,
/turf/open/floor/plating,
/area/maintenance/starboard/fore)
-"aiE" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/starboard/fore)
"aiF" = (
/obj/structure/cable/yellow{
icon_state = "2-4"
@@ -2082,10 +2078,6 @@
"anc" = (
/turf/open/floor/wood,
/area/vacant_room/office)
-"and" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/wood,
-/area/vacant_room/office)
"ane" = (
/obj/structure/table/wood,
/obj/item/paicard,
@@ -2325,10 +2317,6 @@
/obj/structure/chair/office,
/turf/open/floor/plasteel/grimy,
/area/vacant_room/office)
-"apa" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plasteel/grimy,
-/area/vacant_room/office)
"apb" = (
/obj/structure/cable/yellow{
icon_state = "1-2"
@@ -10186,10 +10174,6 @@
},
/turf/open/floor/engine/o2,
/area/engine/atmos)
-"bdo" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/port/fore)
"bdq" = (
/obj/structure/reagent_dispensers/watertank,
/obj/structure/window/reinforced,
@@ -26132,6 +26116,35 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel/dark,
/area/library)
+"cGf" = (
+/obj/effect/turf_decal/tile/neutral/half/contrasted,
+/obj/effect/turf_decal/stripes/line{
+ dir = 4
+ },
+/obj/machinery/door/window/westleft{
+ dir = 4;
+ name = "First-Aid Supplies";
+ req_access_txt = "5"
+ },
+/obj/structure/table/glass,
+/obj/item/reagent_containers/spray/cleaner{
+ pixel_x = -3;
+ pixel_y = 2
+ },
+/obj/item/storage/belt/medical,
+/obj/item/clothing/neck/stethoscope,
+/obj/item/storage/belt/medical,
+/obj/item/clothing/neck/stethoscope,
+/obj/item/clothing/glasses/hud/health,
+/obj/item/clothing/glasses/hud/health,
+/obj/structure/window/reinforced{
+ layer = 2.9
+ },
+/obj/effect/loot_jobscale/medical/first_aid_kit,
+/turf/open/floor/plasteel{
+ heat_capacity = 1e+006
+ },
+/area/medical/storage)
"cGg" = (
/obj/machinery/status_display/ai{
pixel_y = -32
@@ -26874,16 +26887,6 @@
/obj/structure/closet/emcloset,
/turf/open/floor/plating,
/area/maintenance/starboard/aft)
-"cJb" = (
-/obj/effect/decal/cleanable/dirt,
-/obj/structure/rack,
-/obj/item/reagent_containers/blood/random,
-/obj/item/rollerbed,
-/obj/effect/turf_decal/tile/blue{
- dir = 1
- },
-/turf/open/floor/plasteel,
-/area/maintenance/starboard/aft)
"cJc" = (
/obj/structure/table,
/obj/item/storage/box/bodybags,
@@ -27377,10 +27380,6 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel,
/area/science/lab)
-"cMU" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/port)
"cMW" = (
/obj/effect/decal/cleanable/dirt,
/obj/effect/landmark/event_spawn,
@@ -29659,6 +29658,15 @@
},
/turf/open/floor/plasteel,
/area/hallway/primary/aft)
+"dbu" = (
+/obj/structure/rack,
+/obj/effect/spawner/lootdrop/maintenance/two,
+/obj/effect/decal/cleanable/dirt,
+/obj/structure/rack,
+/obj/item/wrench,
+/obj/item/rollerbed,
+/turf/open/floor/plating,
+/area/maintenance/department/medical/central)
"dbA" = (
/obj/machinery/nanite_chamber,
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
@@ -31165,35 +31173,6 @@
/obj/effect/turf_decal/bot,
/turf/open/floor/plasteel,
/area/science/robotics/mechbay)
-"dnQ" = (
-/obj/effect/turf_decal/tile/neutral/half/contrasted,
-/obj/effect/turf_decal/stripes/line{
- dir = 4
- },
-/obj/machinery/door/window/westleft{
- dir = 4;
- name = "First-Aid Supplies";
- req_access_txt = "5"
- },
-/obj/structure/table/glass,
-/obj/item/reagent_containers/spray/cleaner{
- pixel_x = -3;
- pixel_y = 2
- },
-/obj/item/storage/belt/medical,
-/obj/item/clothing/neck/stethoscope,
-/obj/item/storage/belt/medical,
-/obj/item/clothing/neck/stethoscope,
-/obj/item/clothing/glasses/hud/health,
-/obj/item/clothing/glasses/hud/health,
-/obj/structure/window/reinforced{
- layer = 2.9
- },
-/obj/effect/loot_jobscale/medical/first_aid_kit,
-/turf/open/floor/plasteel{
- heat_capacity = 1e+006
- },
-/area/medical/storage)
"dnR" = (
/obj/structure/cable/yellow{
icon_state = "1-8"
@@ -38390,6 +38369,17 @@
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
/turf/open/floor/plasteel,
/area/security/checkpoint/medical)
+"eCn" = (
+/obj/effect/turf_decal/tile/neutral/half/contrasted{
+ dir = 8
+ },
+/obj/machinery/vending/medical,
+/obj/machinery/light_switch{
+ pixel_y = 22
+ },
+/obj/effect/turf_decal/stripes/line,
+/turf/open/floor/plasteel,
+/area/medical/storage)
"eCD" = (
/obj/machinery/light/small{
dir = 4
@@ -38430,6 +38420,41 @@
},
/turf/open/floor/plasteel/dark,
/area/bridge)
+"eCY" = (
+/obj/item/reagent_containers/syringe/antiviral{
+ pixel_x = 7;
+ pixel_y = 13
+ },
+/obj/item/reagent_containers/syringe/antiviral{
+ pixel_x = 5;
+ pixel_y = 10
+ },
+/obj/item/reagent_containers/syringe/antiviral{
+ pixel_x = 1;
+ pixel_y = 8
+ },
+/obj/item/reagent_containers/syringe/antiviral{
+ pixel_y = 5
+ },
+/obj/item/reagent_containers/syringe/antiviral{
+ pixel_x = -1;
+ pixel_y = 1
+ },
+/obj/item/reagent_containers/syringe/antiviral{
+ pixel_x = -2;
+ pixel_y = -1
+ },
+/obj/item/storage/box/syringes{
+ pixel_x = 6;
+ pixel_y = 11
+ },
+/obj/structure/table,
+/obj/item/storage/box/beakers{
+ pixel_x = -5;
+ pixel_y = 3
+ },
+/turf/open/floor/plasteel/grid/steel,
+/area/medical/virology)
"eDD" = (
/obj/machinery/holopad,
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
@@ -39732,21 +39757,6 @@
/obj/structure/disposalpipe/segment,
/turf/open/floor/plating,
/area/maintenance/port)
-"fdD" = (
-/obj/machinery/rnd/production/techfab/department/medical,
-/obj/machinery/light{
- dir = 1
- },
-/obj/machinery/requests_console{
- department = "Medbay Storage";
- name = "Medbay Storage RC";
- pixel_y = 28
- },
-/obj/effect/turf_decal/stripes/line{
- dir = 10
- },
-/turf/open/floor/plasteel/grid/steel,
-/area/medical/storage)
"fdE" = (
/obj/effect/turf_decal/tile/red/half/contrasted{
dir = 4
@@ -40598,6 +40608,16 @@
},
/turf/open/floor/plasteel/white,
/area/medical/medbay/central)
+"frR" = (
+/obj/effect/decal/cleanable/dirt,
+/obj/structure/rack,
+/obj/item/reagent_containers/blood/random,
+/obj/item/rollerbed,
+/obj/effect/turf_decal/tile/blue{
+ dir = 1
+ },
+/turf/open/floor/plasteel,
+/area/maintenance/starboard/aft)
"fsd" = (
/obj/structure/cable/yellow{
icon_state = "1-2"
@@ -40711,19 +40731,6 @@
},
/turf/open/floor/plasteel,
/area/construction/mining/aux_base)
-"fua" = (
-/obj/effect/turf_decal/tile/neutral/half/contrasted,
-/obj/machinery/power/apc/auto_name/west{
- pixel_x = -24
- },
-/obj/structure/cable/yellow{
- icon_state = "0-4"
- },
-/obj/machinery/vending/wardrobe/medi_wardrobe,
-/turf/open/floor/plasteel{
- heat_capacity = 1e+006
- },
-/area/medical/storage)
"fue" = (
/obj/effect/decal/cleanable/dirt,
/obj/effect/landmark/event_spawn,
@@ -40848,20 +40855,6 @@
},
/turf/open/floor/plasteel/white,
/area/crew_quarters/heads/hor)
-"fws" = (
-/obj/effect/turf_decal/bot,
-/obj/effect/turf_decal/siding/dark{
- dir = 4
- },
-/obj/item/clothing/shoes/sneakers/white,
-/obj/item/clothing/under/color/white,
-/obj/structure/closet/secure_closet{
- anchored = 1;
- name = "patient's closet";
- req_access_txt = "5"
- },
-/turf/open/floor/plasteel,
-/area/medical/patients_rooms)
"fwv" = (
/obj/structure/sign/poster/official/help_others{
pixel_x = -32
@@ -44638,6 +44631,19 @@
/obj/effect/landmark/xeno_spawn,
/turf/open/floor/plating,
/area/maintenance/department/medical/central)
+"gMg" = (
+/obj/effect/turf_decal/tile/neutral/half/contrasted,
+/obj/machinery/power/apc/auto_name/west{
+ pixel_x = -24
+ },
+/obj/structure/cable/yellow{
+ icon_state = "0-4"
+ },
+/obj/machinery/vending/wardrobe/medi_wardrobe,
+/turf/open/floor/plasteel{
+ heat_capacity = 1e+006
+ },
+/area/medical/storage)
"gNm" = (
/obj/machinery/light,
/obj/machinery/firealarm/directional/south,
@@ -45284,20 +45290,6 @@
},
/turf/open/floor/plasteel,
/area/hallway/secondary/service)
-"gWx" = (
-/obj/effect/turf_decal/bot,
-/obj/effect/turf_decal/siding/dark{
- dir = 4
- },
-/obj/structure/closet/secure_closet{
- anchored = 1;
- name = "patient's closet";
- req_access_txt = "5"
- },
-/obj/item/clothing/shoes/sneakers/white,
-/obj/item/clothing/under/color/white,
-/turf/open/floor/plasteel,
-/area/medical/patients_rooms)
"gWE" = (
/obj/structure/closet/l3closet/virology,
/obj/effect/turf_decal/box,
@@ -47875,6 +47867,27 @@
/obj/effect/turf_decal/tile/red/anticorner/contrasted,
/turf/open/floor/plasteel,
/area/security/checkpoint/engineering)
+"hQF" = (
+/obj/structure/table/wood,
+/obj/item/reagent_containers/food/drinks/drinkingglass/shotglass{
+ pixel_x = -3;
+ pixel_y = 15
+ },
+/obj/item/reagent_containers/food/drinks/drinkingglass/shotglass{
+ pixel_x = -6;
+ pixel_y = 3
+ },
+/obj/item/reagent_containers/food/drinks/beer{
+ desc = "Whatever it is, it reeks of foul, putrid froth.";
+ list_reagents = list(/datum/reagent/consumable/ethanol/bacchus_blessing=15);
+ name = "Delta-Down";
+ pixel_x = 5;
+ pixel_y = 5
+ },
+/turf/open/floor/wood{
+ icon_state = "wood-broken4"
+ },
+/area/crew_quarters/dorms)
"hQV" = (
/obj/machinery/atmospherics/components/unary/vent_scrubber/on/layer4,
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
@@ -48361,41 +48374,6 @@
/obj/effect/turf_decal/bot,
/turf/open/floor/plasteel,
/area/science/research)
-"iaP" = (
-/obj/item/reagent_containers/syringe/antiviral{
- pixel_x = 7;
- pixel_y = 13
- },
-/obj/item/reagent_containers/syringe/antiviral{
- pixel_x = 5;
- pixel_y = 10
- },
-/obj/item/reagent_containers/syringe/antiviral{
- pixel_x = 1;
- pixel_y = 8
- },
-/obj/item/reagent_containers/syringe/antiviral{
- pixel_y = 5
- },
-/obj/item/reagent_containers/syringe/antiviral{
- pixel_x = -1;
- pixel_y = 1
- },
-/obj/item/reagent_containers/syringe/antiviral{
- pixel_x = -2;
- pixel_y = -1
- },
-/obj/item/storage/box/syringes{
- pixel_x = 6;
- pixel_y = 11
- },
-/obj/structure/table,
-/obj/item/storage/box/beakers{
- pixel_x = -5;
- pixel_y = 3
- },
-/turf/open/floor/plasteel/grid/steel,
-/area/medical/virology)
"iaQ" = (
/obj/item/kirbyplants/random,
/obj/machinery/turretid{
@@ -49134,15 +49112,6 @@
/obj/effect/turf_decal/tile/neutral/opposingcorners,
/turf/open/floor/plasteel,
/area/crew_quarters/cryopods)
-"ipd" = (
-/obj/structure/rack,
-/obj/effect/spawner/lootdrop/maintenance/two,
-/obj/effect/decal/cleanable/dirt,
-/obj/structure/rack,
-/obj/item/wrench,
-/obj/item/rollerbed,
-/turf/open/floor/plating,
-/area/maintenance/department/medical/central)
"ipD" = (
/obj/structure/disposalpipe/segment{
dir = 4
@@ -50910,6 +50879,23 @@
},
/turf/open/floor/plasteel,
/area/security/brig)
+"iYj" = (
+/obj/structure/table/wood,
+/obj/structure/cable/yellow{
+ icon_state = "1-2"
+ },
+/obj/item/folder/red,
+/obj/item/toy/gun,
+/obj/item/clothing/head/beret/sec{
+ armor = list("melee"=0,"bullet"=0,"laser"=0,"energy"=0,"bomb"=0,"bio"=0,"rad"=0,"stamina"=0);
+ desc = "A replica beret resembling that of a special operations officer under Nanotrasen.";
+ name = "replica officer's beret"
+ },
+/obj/item/radio/intercom{
+ pixel_x = 26
+ },
+/turf/open/floor/plasteel/grimy,
+/area/bridge/showroom/corporate)
"iYy" = (
/obj/effect/turf_decal/tile/purple/half/contrasted{
dir = 4
@@ -51025,6 +51011,15 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel,
/area/storage/primary)
+"jbu" = (
+/obj/effect/turf_decal/tile/neutral/half/contrasted{
+ dir = 1
+ },
+/obj/structure/rack,
+/obj/item/rollerbed,
+/obj/item/reagent_containers/blood,
+/turf/open/floor/plasteel,
+/area/maintenance/starboard/aft)
"jbK" = (
/obj/structure/cable/yellow{
icon_state = "4-8"
@@ -52073,6 +52068,24 @@
},
/turf/open/floor/plasteel,
/area/medical/chemistry)
+"jvp" = (
+/obj/effect/turf_decal/tile/blue{
+ dir = 8
+ },
+/obj/structure/rack,
+/obj/item/rollerbed{
+ pixel_x = -2
+ },
+/obj/item/rollerbed{
+ pixel_x = 1;
+ pixel_y = 3
+ },
+/obj/item/rollerbed{
+ pixel_x = 5;
+ pixel_y = 8
+ },
+/turf/open/floor/plasteel/white,
+/area/medical/medbay/lobby)
"jvs" = (
/obj/structure/cable/yellow{
icon_state = "0-8"
@@ -52352,6 +52365,21 @@
},
/turf/open/floor/engine,
/area/science/explab)
+"jAE" = (
+/obj/machinery/rnd/production/techfab/department/medical,
+/obj/machinery/light{
+ dir = 1
+ },
+/obj/machinery/requests_console{
+ department = "Medbay Storage";
+ name = "Medbay Storage RC";
+ pixel_y = 28
+ },
+/obj/effect/turf_decal/stripes/line{
+ dir = 10
+ },
+/turf/open/floor/plasteel/grid/steel,
+/area/medical/storage)
"jAF" = (
/obj/machinery/vending/cigarette,
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
@@ -52397,6 +52425,20 @@
},
/turf/open/floor/plasteel,
/area/maintenance/solars/port/fore)
+"jAT" = (
+/obj/effect/turf_decal/bot,
+/obj/effect/turf_decal/siding/dark{
+ dir = 4
+ },
+/obj/item/clothing/shoes/sneakers/white,
+/obj/item/clothing/under/color/white,
+/obj/structure/closet/secure_closet{
+ anchored = 1;
+ name = "patient's closet";
+ req_access_txt = "5"
+ },
+/turf/open/floor/plasteel,
+/area/medical/patients_rooms)
"jBh" = (
/obj/structure/chair/office{
dir = 8
@@ -54056,6 +54098,10 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel/dark,
/area/storage/tech)
+"kea" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/wood,
+/area/vacant_room/office)
"kej" = (
/obj/effect/decal/cleanable/dirt,
/obj/effect/turf_decal/tile/neutral/half/contrasted{
@@ -54342,6 +54388,30 @@
/obj/structure/lattice/catwalk,
/turf/open/space,
/area/space/nearstation)
+"khZ" = (
+/obj/structure/table,
+/obj/item/reagent_containers/food/snacks/grown/tomato/blood{
+ pixel_x = 7;
+ pixel_y = 8
+ },
+/obj/item/reagent_containers/syringe{
+ pixel_x = -4;
+ pixel_y = 2
+ },
+/obj/machinery/vending/wallmed{
+ contraband = list(/obj/item/reagent_containers/glass/bottle/chloralhydrate=1,/obj/item/storage/box/hug/medical=1,/obj/item/reagent_containers/glass/bottle/random_virus=1);
+ name = "Upgraded NanoMed";
+ pixel_x = -1;
+ pixel_y = -32;
+ premium = list(/obj/item/storage/firstaid/regular=3,/obj/item/storage/belt/medical=3,/obj/item/sensor_device=2,/obj/item/pinpointer/crew=2,/obj/item/healthanalyzer=2,/obj/item/wrench/medical=1);
+ products = list(/obj/item/reagent_containers/syringe=12,/obj/item/reagent_containers/dropper=3,/obj/item/reagent_containers/medspray=6,/obj/item/storage/pill_bottle=6,/obj/item/reagent_containers/glass/bottle=10,/obj/item/reagent_containers/spray/cleaner=1,/obj/item/stack/medical/gauze=8,/obj/item/reagent_containers/hypospray/medipen=8,/obj/item/reagent_containers/hypospray/medipen/dexalin=8,/obj/item/reagent_containers/glass/bottle/epinephrine=4,/obj/item/reagent_containers/glass/bottle/charcoal=4,/obj/item/reagent_containers/glass/bottle/salglu_solution=4,/obj/item/reagent_containers/glass/bottle/tricordrazine=1,/obj/item/reagent_containers/glass/bottle/spaceacillin=1,/obj/item/reagent_containers/glass/bottle/morphine=2,/obj/item/reagent_containers/glass/bottle/toxin=4,/obj/item/reagent_containers/medspray/sterilizine=4)
+ },
+/obj/item/reagent_containers/dropper{
+ pixel_x = 2;
+ pixel_y = -5
+ },
+/turf/open/floor/plasteel/grid/steel,
+/area/medical/virology)
"kia" = (
/obj/item/storage/toolbox/mechanical,
/obj/item/flashlight,
@@ -59600,24 +59670,6 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel/dark,
/area/engine/transit_tube)
-"lTF" = (
-/obj/effect/decal/cleanable/dirt,
-/obj/effect/decal/cleanable/dirt,
-/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
-/obj/effect/mapping_helpers/dead_body_placer,
-/turf/open/floor/plasteel,
-/area/medical/morgue)
-"lTJ" = (
-/obj/effect/turf_decal/tile/neutral/half/contrasted{
- dir = 8
- },
-/obj/machinery/vending/medical,
-/obj/machinery/light_switch{
- pixel_y = 22
- },
-/obj/effect/turf_decal/stripes/line,
-/turf/open/floor/plasteel,
-/area/medical/storage)
"lTK" = (
/obj/structure/disposalpipe/segment,
/obj/machinery/atmospherics/components/unary/vent_scrubber/on/layer4{
@@ -64636,6 +64688,17 @@
dir = 1
},
/area/hallway/secondary/entry)
+"nBl" = (
+/obj/effect/decal/cleanable/dirt,
+/obj/effect/decal/cleanable/dirt,
+/obj/structure/cable/yellow{
+ icon_state = "1-2"
+ },
+/mob/living/basic/cockroach,
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
+/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
+/turf/open/floor/plating,
+/area/maintenance/port/fore)
"nBn" = (
/obj/structure/table/reinforced,
/obj/structure/cable/yellow{
@@ -64950,17 +65013,6 @@
/obj/effect/turf_decal/tile/purple,
/turf/open/floor/plasteel/white,
/area/science/shuttledock)
-"nGl" = (
-/obj/effect/decal/cleanable/dirt,
-/obj/effect/decal/cleanable/dirt,
-/obj/structure/cable/yellow{
- icon_state = "1-2"
- },
-/mob/living/simple_animal/cockroach,
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
-/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
-/turf/open/floor/plating,
-/area/maintenance/port/fore)
"nGw" = (
/obj/effect/turf_decal/delivery,
/obj/structure/cable/yellow{
@@ -66134,16 +66186,6 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel/dark,
/area/aisat)
-"obr" = (
-/obj/machinery/airalarm{
- dir = 1;
- pixel_y = -22
- },
-/obj/machinery/light/small,
-/turf/open/floor/plating{
- icon_state = "platingdmg1"
- },
-/area/medical/morgue)
"obs" = (
/obj/machinery/status_display/evac{
pixel_y = 32
@@ -68498,6 +68540,10 @@
/obj/effect/turf_decal/tile/red,
/turf/open/floor/plasteel,
/area/security/prison)
+"oSN" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/plasteel/grimy,
+/area/vacant_room/office)
"oSO" = (
/obj/structure/disposalpipe/segment,
/obj/machinery/atmospherics/pipe/manifold/supply/hidden/layer2{
@@ -68853,15 +68899,6 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel/dark,
/area/crew_quarters/bar/atrium)
-"oZZ" = (
-/obj/effect/turf_decal/tile/neutral/half/contrasted{
- dir = 1
- },
-/obj/structure/rack,
-/obj/item/rollerbed,
-/obj/item/reagent_containers/blood,
-/turf/open/floor/plasteel,
-/area/maintenance/starboard/aft)
"pae" = (
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/obj/structure/cable/yellow{
@@ -69069,6 +69106,10 @@
/obj/machinery/firealarm/directional/east,
/turf/open/floor/plasteel/white,
/area/medical/medbay/central)
+"peN" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/port)
"peV" = (
/obj/structure/table/reinforced,
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
@@ -79526,6 +79567,10 @@
/obj/effect/turf_decal/tile/red,
/turf/open/floor/plasteel,
/area/security/brig)
+"sIW" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/aft)
"sJt" = (
/obj/effect/turf_decal/stripes/line{
dir = 1
@@ -81924,24 +81969,6 @@
},
/turf/open/floor/plating,
/area/maintenance/port)
-"tBT" = (
-/obj/effect/turf_decal/tile/blue{
- dir = 8
- },
-/obj/structure/rack,
-/obj/item/rollerbed{
- pixel_x = -2
- },
-/obj/item/rollerbed{
- pixel_x = 1;
- pixel_y = 3
- },
-/obj/item/rollerbed{
- pixel_x = 5;
- pixel_y = 8
- },
-/turf/open/floor/plasteel/white,
-/area/medical/medbay/lobby)
"tBV" = (
/obj/effect/decal/cleanable/dirt,
/turf/open/floor/plasteel/dark,
@@ -82611,27 +82638,6 @@
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
/turf/open/floor/plasteel,
/area/hallway/secondary/service)
-"tQw" = (
-/obj/structure/table/wood,
-/obj/item/reagent_containers/food/drinks/drinkingglass/shotglass{
- pixel_x = -3;
- pixel_y = 15
- },
-/obj/item/reagent_containers/food/drinks/drinkingglass/shotglass{
- pixel_x = -6;
- pixel_y = 3
- },
-/obj/item/reagent_containers/food/drinks/beer{
- desc = "Whatever it is, it reeks of foul, putrid froth.";
- list_reagents = list(/datum/reagent/consumable/ethanol/bacchus_blessing = 15);
- name = "Delta-Down";
- pixel_x = 5;
- pixel_y = 5
- },
-/turf/open/floor/wood{
- icon_state = "wood-broken4"
- },
-/area/crew_quarters/dorms)
"tQz" = (
/obj/effect/decal/cleanable/dirt,
/obj/effect/decal/cleanable/dirt,
@@ -82881,26 +82887,6 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel/dark,
/area/ai_monitored/security/armory)
-"tWg" = (
-/obj/structure/table/wood,
-/obj/structure/cable/yellow{
- icon_state = "1-2"
- },
-/obj/item/folder/blue,
-/obj/item/clothing/under/rank/centcom/commander{
- desc = "A replica of a jumpsuit worn by the highest ranking commanders under Nanotrasen's central command.";
- name = "Replica CentCom officer's jumpsuit"
- },
-/obj/item/clothing/head/centhat{
- armor = list("melee" = 0, "bullet" = 0, "laser" = 0, "energy" = 0, "bomb" = 0, "bio" = 0, "rad" = 0, "stamina" = 0);
- desc = "A replica hat of a Central Commander's attire. It has a small tag on it saying, 'It's good to be emperor.'";
- name = "Replica CentCom hat"
- },
-/obj/machinery/computer/security/telescreen/entertainment{
- pixel_x = -32
- },
-/turf/open/floor/plasteel/grimy,
-/area/bridge/showroom/corporate)
"tWh" = (
/obj/effect/turf_decal/stripes/line,
/obj/effect/turf_decal/stripes/line{
@@ -82918,6 +82904,16 @@
},
/turf/open/floor/plasteel,
/area/quartermaster/storage)
+"tWy" = (
+/obj/machinery/airalarm{
+ dir = 1;
+ pixel_y = -22
+ },
+/obj/machinery/light/small,
+/turf/open/floor/plating{
+ icon_state = "platingdmg1"
+ },
+/area/medical/morgue)
"tWH" = (
/obj/structure/sign/poster/official/help_others{
pixel_x = 32
@@ -83703,19 +83699,6 @@
},
/turf/open/floor/plating,
/area/medical/medbay/lobby)
-"ujf" = (
-/obj/structure/cable/yellow{
- icon_state = "4-8"
- },
-/mob/living/simple_animal/cockroach,
-/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
- dir = 4
- },
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
- dir = 4
- },
-/turf/open/floor/plating,
-/area/maintenance/port/aft)
"ukl" = (
/obj/machinery/light/small,
/obj/machinery/holopad,
@@ -84772,6 +84755,16 @@
},
/turf/open/floor/plasteel,
/area/hallway/primary/central)
+"uEJ" = (
+/mob/living/basic/cockroach,
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
+/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
+/obj/effect/turf_decal/tile/neutral/half/contrasted,
+/obj/structure/cable/yellow{
+ icon_state = "1-2"
+ },
+/turf/open/floor/plasteel,
+/area/maintenance/starboard/aft)
"uEK" = (
/obj/effect/turf_decal/tile/blue,
/obj/structure/cable/yellow{
@@ -87035,6 +87028,19 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel,
/area/science/xenobiology)
+"vse" = (
+/obj/structure/cable/yellow{
+ icon_state = "4-8"
+ },
+/mob/living/basic/cockroach,
+/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
+ dir = 4
+ },
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
+ dir = 4
+ },
+/turf/open/floor/plating,
+/area/maintenance/port/aft)
"vsf" = (
/obj/effect/turf_decal/tile/green/fourcorners/contrasted,
/obj/machinery/door/firedoor,
@@ -87666,6 +87672,26 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel/dark,
/area/security/execution/education)
+"vCe" = (
+/obj/structure/table/wood,
+/obj/structure/cable/yellow{
+ icon_state = "1-2"
+ },
+/obj/item/folder/blue,
+/obj/item/clothing/under/rank/centcom/commander{
+ desc = "A replica of a jumpsuit worn by the highest ranking commanders under Nanotrasen's central command.";
+ name = "Replica CentCom officer's jumpsuit"
+ },
+/obj/item/clothing/head/centhat{
+ armor = list("melee"=0,"bullet"=0,"laser"=0,"energy"=0,"bomb"=0,"bio"=0,"rad"=0,"stamina"=0);
+ desc = "A replica hat of a Central Commander's attire. It has a small tag on it saying, 'It's good to be emperor.'";
+ name = "Replica CentCom hat"
+ },
+/obj/machinery/computer/security/telescreen/entertainment{
+ pixel_x = -32
+ },
+/turf/open/floor/plasteel/grimy,
+/area/bridge/showroom/corporate)
"vCv" = (
/obj/effect/decal/cleanable/dirt,
/obj/machinery/atmospherics/components/unary/vent_scrubber/on/layer4{
@@ -87925,23 +87951,6 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel/dark,
/area/bridge)
-"vHX" = (
-/obj/structure/table/wood,
-/obj/structure/cable/yellow{
- icon_state = "1-2"
- },
-/obj/item/folder/red,
-/obj/item/toy/gun,
-/obj/item/clothing/head/beret/sec{
- armor = list("melee" = 0, "bullet" = 0, "laser" = 0, "energy" = 0, "bomb" = 0, "bio" = 0, "rad" = 0, "stamina" = 0);
- desc = "A replica beret resembling that of a special operations officer under Nanotrasen.";
- name = "replica officer's beret"
- },
-/obj/item/radio/intercom{
- pixel_x = 26
- },
-/turf/open/floor/plasteel/grimy,
-/area/bridge/showroom/corporate)
"vHZ" = (
/obj/effect/turf_decal/stripes/line{
dir = 8
@@ -88621,16 +88630,6 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel,
/area/hydroponics)
-"vTj" = (
-/mob/living/simple_animal/cockroach,
-/obj/effect/turf_decal/tile/neutral/half/contrasted,
-/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
-/obj/structure/cable/yellow{
- icon_state = "1-2"
- },
-/turf/open/floor/plasteel,
-/area/maintenance/starboard/aft)
"vTs" = (
/obj/machinery/atmospherics/pipe/manifold/cyan/visible{
dir = 8
@@ -89141,30 +89140,6 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel,
/area/crew_quarters/locker)
-"wad" = (
-/obj/structure/table,
-/obj/item/reagent_containers/food/snacks/grown/tomato/blood{
- pixel_x = 7;
- pixel_y = 8
- },
-/obj/item/reagent_containers/syringe{
- pixel_x = -4;
- pixel_y = 2
- },
-/obj/machinery/vending/wallmed{
- contraband = list(/obj/item/reagent_containers/glass/bottle/chloralhydrate = 1, /obj/item/storage/box/hug/medical = 1, /obj/item/reagent_containers/glass/bottle/random_virus = 1);
- name = "Upgraded NanoMed";
- pixel_x = -1;
- pixel_y = -32;
- premium = list(/obj/item/storage/firstaid/regular = 3, /obj/item/storage/belt/medical = 3, /obj/item/sensor_device = 2, /obj/item/pinpointer/crew = 2, /obj/item/healthanalyzer = 2, /obj/item/wrench/medical = 1);
- products = list(/obj/item/reagent_containers/syringe = 12, /obj/item/reagent_containers/dropper = 3, /obj/item/reagent_containers/medspray = 6, /obj/item/storage/pill_bottle = 6, /obj/item/reagent_containers/glass/bottle = 10, /obj/item/reagent_containers/spray/cleaner = 1, /obj/item/stack/medical/gauze = 8, /obj/item/reagent_containers/hypospray/medipen = 8, /obj/item/reagent_containers/hypospray/medipen/dexalin = 8, /obj/item/reagent_containers/glass/bottle/epinephrine = 4, /obj/item/reagent_containers/glass/bottle/charcoal = 4, /obj/item/reagent_containers/glass/bottle/salglu_solution = 4, /obj/item/reagent_containers/glass/bottle/tricordrazine = 1, /obj/item/reagent_containers/glass/bottle/spaceacillin = 1, /obj/item/reagent_containers/glass/bottle/morphine = 2, /obj/item/reagent_containers/glass/bottle/toxin = 4, /obj/item/reagent_containers/medspray/sterilizine = 4)
- },
-/obj/item/reagent_containers/dropper{
- pixel_x = 2;
- pixel_y = -5
- },
-/turf/open/floor/plasteel/grid/steel,
-/area/medical/virology)
"way" = (
/obj/effect/turf_decal/stripes/line{
dir = 8
@@ -89700,6 +89675,13 @@
},
/turf/open/floor/plasteel/white,
/area/medical/medbay/aft)
+"wkh" = (
+/obj/effect/decal/cleanable/dirt,
+/obj/effect/decal/cleanable/dirt,
+/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
+/obj/effect/mapping_helpers/dead_body_placer,
+/turf/open/floor/plasteel,
+/area/medical/morgue)
"wkj" = (
/obj/structure/cable/yellow{
icon_state = "1-2"
@@ -92112,6 +92094,20 @@
},
/turf/open/floor/plasteel,
/area/maintenance/port)
+"wVj" = (
+/obj/effect/turf_decal/bot,
+/obj/effect/turf_decal/siding/dark{
+ dir = 4
+ },
+/obj/structure/closet/secure_closet{
+ anchored = 1;
+ name = "patient's closet";
+ req_access_txt = "5"
+ },
+/obj/item/clothing/shoes/sneakers/white,
+/obj/item/clothing/under/color/white,
+/turf/open/floor/plasteel,
+/area/medical/patients_rooms)
"wVq" = (
/obj/effect/turf_decal/stripes/line{
dir = 9
@@ -92305,6 +92301,10 @@
},
/turf/open/floor/plasteel/white,
/area/medical/medbay/aft)
+"wYY" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/port/fore)
"wZk" = (
/obj/structure/closet/crate/critter,
/obj/effect/turf_decal/tile/purple,
@@ -93860,6 +93860,10 @@
},
/turf/open/floor/plating,
/area/maintenance/port)
+"xBm" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/starboard/fore)
"xBx" = (
/obj/effect/turf_decal/tile/neutral/half/contrasted{
dir = 1
@@ -95749,10 +95753,6 @@
},
/turf/open/floor/plasteel/white,
/area/maintenance/aft)
-"yfb" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/aft)
"yfd" = (
/obj/structure/cable{
icon_state = "1-8"
@@ -121450,7 +121450,7 @@ vLV
kmU
qrY
tDJ
-cMU
+peN
lUX
cMY
cMY
@@ -126280,7 +126280,7 @@ alf
ayT
ban
arB
-bdo
+wYY
arB
jUr
jUr
@@ -129856,7 +129856,7 @@ vyO
gIq
xeU
xeU
-nGl
+nBl
jAi
vag
qNf
@@ -130105,7 +130105,7 @@ all
ama
anb
aoa
-apa
+oSN
aqc
aky
rZH
@@ -130742,7 +130742,7 @@ dfm
dfm
dfm
dfm
-ujf
+vse
sKr
dTA
ehA
@@ -131131,7 +131131,7 @@ xSF
vql
alp
anc
-and
+kea
pVa
apb
aqg
@@ -133781,7 +133781,7 @@ czY
cBo
cCU
cEK
-tWg
+vCe
cHM
fQi
qHr
@@ -135858,7 +135858,7 @@ pKl
uDp
pKl
cRd
-ipd
+dbu
pIp
dvc
wZR
@@ -136351,7 +136351,7 @@ czY
cBw
cDe
cER
-vHX
+iYj
cHM
cIS
qHr
@@ -136362,7 +136362,7 @@ gRy
mka
oPY
wft
-tBT
+jvp
gmR
xMT
wfd
@@ -136386,7 +136386,7 @@ dCy
rcf
paK
lbk
-lTF
+wkh
lLr
dCy
maQ
@@ -137415,7 +137415,7 @@ laY
jVd
jce
geg
-obr
+tWy
dCy
pRu
wuY
@@ -138576,7 +138576,7 @@ kgm
eql
abi
lhu
-aiE
+xBm
aiC
ajj
apw
@@ -140488,8 +140488,8 @@ uvU
qkY
xml
cRe
-dnQ
-fua
+cGf
+gMg
gLm
wMI
cRe
@@ -141002,7 +141002,7 @@ qkY
ubW
qkY
cRe
-fdD
+jAE
fmM
psZ
mFW
@@ -141259,7 +141259,7 @@ dOx
whB
qen
cRe
-lTJ
+eCn
fmM
ngR
xJL
@@ -141768,10 +141768,10 @@ frm
hUj
hUj
hUj
-gWx
-fws
-fws
-fws
+wVj
+jAT
+jAT
+jAT
cRe
drp
bHm
@@ -141785,7 +141785,7 @@ dPq
kgG
pJI
mFc
-iaP
+eCY
bpd
pTk
arZ
@@ -142304,7 +142304,7 @@ fuX
wFZ
hLr
bkC
-wad
+khZ
dPq
pkR
vQJ
@@ -143840,7 +143840,7 @@ mie
dma
pOZ
xkY
-yfb
+sIW
dNS
rDi
rDi
@@ -144063,7 +144063,7 @@ fUd
cFp
kvh
cqd
-cJb
+frR
wYb
xPI
jrz
@@ -145622,7 +145622,7 @@ xMt
fBI
cHW
mIs
-oZZ
+jbu
cIX
ddl
dDB
@@ -145881,7 +145881,7 @@ lgJ
lgJ
oqn
vxk
-vTj
+uEJ
sJW
vxk
iyt
@@ -146888,7 +146888,7 @@ cAx
cCd
cDD
cFx
-tQw
+hQF
cAw
fTG
mfR
diff --git a/_maps/map_files/FlandStation/FlandStation.dmm b/_maps/map_files/FlandStation/FlandStation.dmm
index e4868b67e3722..092dad1370f59 100644
--- a/_maps/map_files/FlandStation/FlandStation.dmm
+++ b/_maps/map_files/FlandStation/FlandStation.dmm
@@ -1140,16 +1140,6 @@
},
/turf/open/floor/plasteel/dark,
/area/hallway/secondary/entry)
-"apO" = (
-/mob/living/simple_animal/cockroach,
-/obj/effect/turf_decal/bot,
-/obj/effect/decal/cleanable/dirt,
-/obj/structure/closet/crate{
- opened = 1
- },
-/obj/effect/spawner/lootdrop/maintenance/two,
-/turf/open/floor/plating,
-/area/maintenance/port/central)
"apQ" = (
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
@@ -1620,10 +1610,6 @@
/obj/effect/decal/cleanable/dirt,
/turf/open/floor/plasteel/dark,
/area/hallway/primary/central)
-"avk" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/port/central)
"avq" = (
/obj/structure/chair/fancy/sofa/old,
/turf/open/floor/carpet/grimy,
@@ -1708,13 +1694,6 @@
/obj/effect/turf_decal/bot,
/turf/open/floor/plasteel/techmaint,
/area/maintenance/department/science)
-"awo" = (
-/mob/living/simple_animal/cockroach,
-/obj/structure/railing/corner{
- dir = 4
- },
-/turf/open/floor/plasteel/dark,
-/area/maintenance/department/science)
"awu" = (
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
dir = 4
@@ -3813,10 +3792,6 @@
},
/turf/open/floor/plating,
/area/maintenance/port/central)
-"aST" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/aft)
"aSV" = (
/obj/machinery/atmospherics/components/unary/vent_scrubber/on/layer4{
dir = 8
@@ -6537,18 +6512,6 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel,
/area/hallway/primary/port)
-"bDu" = (
-/mob/living/simple_animal/cockroach{
- desc = "carlos.";
- maxHealth = 2;
- name = "carlos";
- squish_chance = 1
- },
-/obj/machinery/atmospherics/components/unary/vent_pump/on/layer2{
- dir = 4
- },
-/turf/open/floor/wood,
-/area/library)
"bDv" = (
/obj/effect/turf_decal/siding/wideplating/dark{
dir = 4
@@ -8215,14 +8178,6 @@
/obj/effect/spawner/structure/window/reinforced,
/turf/open/floor/plating,
/area/hallway/primary/aft)
-"cdI" = (
-/obj/effect/decal/cleanable/dirt,
-/obj/effect/decal/cleanable/dirt,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating{
- icon_state = "panelscorched"
- },
-/area/maintenance/port/central)
"ceq" = (
/obj/effect/mapping_helpers/airlock/cyclelink_helper{
dir = 1
@@ -9472,6 +9427,11 @@
},
/turf/open/floor/plasteel,
/area/hallway/primary/aft)
+"cwR" = (
+/obj/effect/decal/cleanable/dirt,
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/starboard/fore)
"cxh" = (
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
@@ -9742,11 +9702,6 @@
/obj/machinery/meter,
/turf/open/floor/plasteel/dark,
/area/engine/engine_room)
-"cAF" = (
-/obj/effect/decal/cleanable/dirt,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/port/aft)
"cAH" = (
/obj/effect/spawner/structure/window/reinforced,
/obj/machinery/door/firedoor/window,
@@ -12532,6 +12487,13 @@
},
/turf/open/floor/plasteel/checker,
/area/quartermaster/storage)
+"dnu" = (
+/mob/living/basic/cockroach,
+/obj/structure/railing/corner{
+ dir = 4
+ },
+/turf/open/floor/plasteel/dark,
+/area/maintenance/department/science)
"dnD" = (
/obj/effect/turf_decal/trimline/red/filled/line{
dir = 9
@@ -13212,6 +13174,18 @@
},
/turf/open/floor/plasteel/techmaint,
/area/maintenance/department/security/brig)
+"dxK" = (
+/obj/structure/table,
+/obj/effect/decal/cleanable/dirt,
+/obj/item/storage/backpack/duffelbag/med,
+/obj/item/flashlight/pen,
+/obj/item/rollerbed,
+/obj/item/crowbar,
+/obj/machinery/light/small{
+ dir = 4
+ },
+/turf/open/floor/plating,
+/area/maintenance/department/medical)
"dxM" = (
/obj/effect/turf_decal/bot,
/obj/machinery/portable_atmospherics/canister,
@@ -15088,6 +15062,11 @@
},
/turf/open/floor/plasteel,
/area/hallway/primary/port)
+"dWP" = (
+/mob/living/basic/cockroach,
+/obj/machinery/firealarm/directional/south,
+/turf/open/floor/plating,
+/area/maintenance/department/science)
"dWT" = (
/obj/effect/turf_decal/stripes/line{
dir = 5
@@ -16087,12 +16066,6 @@
},
/turf/open/floor/plasteel/techmaint,
/area/crew_quarters/heads/hop)
-"enh" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating{
- icon_state = "panelscorched"
- },
-/area/maintenance/aft)
"enm" = (
/obj/structure/cable/yellow{
icon_state = "4-8"
@@ -16594,6 +16567,13 @@
/obj/machinery/firealarm/directional/south,
/turf/open/floor/vault,
/area/crew_quarters/heads/hor)
+"evi" = (
+/obj/effect/decal/cleanable/dirt,
+/mob/living/basic/cockroach,
+/turf/open/floor/plating{
+ icon_state = "platingdmg3"
+ },
+/area/maintenance/starboard/aft)
"evu" = (
/obj/structure/cable/yellow{
icon_state = "4-8"
@@ -19577,6 +19557,16 @@
/obj/structure/disposalpipe/segment,
/turf/open/floor/plasteel/dark,
/area/crew_quarters/heads/chief)
+"fec" = (
+/mob/living/basic/cockroach,
+/obj/effect/turf_decal/bot,
+/obj/effect/decal/cleanable/dirt,
+/obj/structure/closet/crate{
+ opened = 1
+ },
+/obj/effect/spawner/lootdrop/maintenance/two,
+/turf/open/floor/plating,
+/area/maintenance/port/central)
"fei" = (
/turf/closed/wall/r_wall,
/area/drydock/security)
@@ -26110,6 +26100,10 @@
},
/turf/open/floor/circuit,
/area/ai_monitored/turret_protected/ai)
+"gNA" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/aft)
"gNB" = (
/obj/machinery/atmospherics/pipe/simple/general/visible,
/obj/machinery/atmospherics/pipe/simple/general/visible{
@@ -26871,15 +26865,6 @@
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
/turf/open/floor/plasteel,
/area/medical/medbay/central)
-"gYs" = (
-/obj/structure/cable/yellow{
- icon_state = "1-2"
- },
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
-/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/port/central)
"gYE" = (
/obj/effect/turf_decal/trimline/blue/line{
dir = 1
@@ -27062,6 +27047,10 @@
/obj/effect/spawner/lootdrop/glowstick/lit,
/turf/open/floor/plating,
/area/maintenance/central)
+"haD" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/starboard/aft)
"haF" = (
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
@@ -31413,6 +31402,14 @@
},
/turf/open/floor/plasteel/grid/steel,
/area/medical/apothecary)
+"ijh" = (
+/obj/effect/turf_decal/stripes/white/line{
+ dir = 4
+ },
+/obj/effect/mapping_helpers/dead_body_placer/medbay_morgue,
+/obj/machinery/atmospherics/components/unary/vent_scrubber/on/layer4,
+/turf/open/floor/plasteel/techmaint,
+/area/medical/morgue)
"ijw" = (
/obj/structure/sign/warning/docking,
/turf/closed/wall/r_wall,
@@ -31568,6 +31565,12 @@
},
/turf/open/floor/carpet/red,
/area/library)
+"ilD" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/plating{
+ icon_state = "platingdmg3"
+ },
+/area/maintenance/port)
"ilR" = (
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
/obj/effect/turf_decal/guideline/guideline_in/red{
@@ -35107,6 +35110,10 @@
},
/turf/open/floor/plasteel/freezer,
/area/medical/surgery)
+"jjB" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/port/central)
"jjG" = (
/obj/machinery/disposal/bin,
/obj/effect/turf_decal/delivery,
@@ -37907,6 +37914,11 @@
/obj/machinery/atmospherics/pipe/layer_manifold,
/turf/open/floor/plasteel/techmaint,
/area/security/execution/transfer)
+"jWO" = (
+/obj/effect/decal/cleanable/dirt,
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/port/aft)
"jWW" = (
/obj/structure/lattice/catwalk/over,
/turf/open/floor/plating{
@@ -38061,6 +38073,20 @@
},
/turf/open/floor/plasteel/dark/side,
/area/hallway/primary/fore)
+"jYo" = (
+/mob/living/basic/cockroach,
+/obj/effect/turf_decal/stripes/line{
+ dir = 10
+ },
+/obj/effect/decal/cleanable/dirt,
+/obj/structure/extinguisher_cabinet{
+ pixel_x = -26
+ },
+/obj/effect/landmark/blobstart,
+/turf/open/floor/plating{
+ icon_state = "platingdmg1"
+ },
+/area/maintenance/starboard/aft)
"jYp" = (
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
dir = 8
@@ -41286,6 +41312,13 @@
},
/turf/open/floor/wood,
/area/vacant_room/office)
+"kRD" = (
+/mob/living/basic/cockroach,
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
+ dir = 8
+ },
+/turf/open/floor/wood,
+/area/vacant_room/office)
"kRI" = (
/obj/structure/chair/fancy/sofa/old/right{
dir = 4
@@ -41599,6 +41632,20 @@
},
/turf/open/floor/plasteel,
/area/hallway/primary/port)
+"kWn" = (
+/obj/effect/turf_decal/stripes/white/line{
+ dir = 4
+ },
+/obj/effect/mapping_helpers/dead_body_placer/medbay_morgue,
+/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
+ dir = 10
+ },
+/obj/structure/cable/yellow{
+ icon_state = "1-2"
+ },
+/turf/open/floor/plasteel/techmaint,
+/area/medical/morgue)
"kWo" = (
/obj/machinery/door/airlock/engineering/glass{
name = "Engineering locker room";
@@ -44620,18 +44667,6 @@
/obj/effect/spawner/structure/window/plasma/reinforced,
/turf/open/floor/engine,
/area/science/mixing/chamber)
-"lGw" = (
-/obj/structure/rack,
-/obj/item/crowbar,
-/obj/item/storage/pill_bottle,
-/obj/item/rollerbed,
-/obj/item/clothing/glasses/eyepatch,
-/obj/item/wrench,
-/obj/machinery/airalarm{
- pixel_y = 22
- },
-/turf/open/floor/plating,
-/area/maintenance/department/medical)
"lGz" = (
/obj/effect/turf_decal/trimline/red/warning,
/obj/effect/turf_decal/trimline/red/filled/warning{
@@ -47945,11 +47980,6 @@
/obj/structure/disposalpipe/segment,
/turf/open/floor/plasteel/techmaint,
/area/vacant_room/office)
-"mAa" = (
-/mob/living/simple_animal/cockroach,
-/obj/machinery/firealarm/directional/south,
-/turf/open/floor/plating,
-/area/maintenance/department/science)
"mAd" = (
/obj/effect/turf_decal/stripes/closeup,
/obj/machinery/door/airlock/maintenance_hatch{
@@ -49332,13 +49362,6 @@
/obj/effect/turf_decal/siding/purple,
/turf/open/floor/plasteel/white,
/area/science/lobby)
-"mRK" = (
-/obj/effect/decal/cleanable/dirt,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating{
- icon_state = "platingdmg3"
- },
-/area/maintenance/starboard/aft)
"mRL" = (
/obj/structure/flora/grass/jungle/b,
/obj/structure/flora/ausbushes/fullgrass,
@@ -49829,11 +49852,6 @@
/obj/effect/landmark/event_spawn,
/turf/open/floor/plasteel/dark,
/area/crew_quarters/heads/chief)
-"mXT" = (
-/obj/effect/decal/cleanable/dirt,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/starboard/fore)
"mXU" = (
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
@@ -51908,18 +51926,6 @@
},
/turf/open/floor/plasteel,
/area/security/checkpoint/escape)
-"nzb" = (
-/obj/structure/table,
-/obj/effect/decal/cleanable/dirt,
-/obj/item/storage/backpack/duffelbag/med,
-/obj/item/flashlight/pen,
-/obj/item/rollerbed,
-/obj/item/crowbar,
-/obj/machinery/light/small{
- dir = 4
- },
-/turf/open/floor/plating,
-/area/maintenance/department/medical)
"nzd" = (
/obj/structure/table,
/obj/item/paper_bin,
@@ -52456,13 +52462,6 @@
initial_gas_mix = "o2=14;n2=23;TEMP=300"
},
/area/docking/arrival)
-"nET" = (
-/mob/living/simple_animal/cockroach,
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
- dir = 8
- },
-/turf/open/floor/wood,
-/area/vacant_room/office)
"nFb" = (
/obj/structure/table/wood,
/obj/item/storage/photo_album{
@@ -60737,6 +60736,21 @@
/obj/structure/disposalpipe/segment,
/turf/open/floor/plasteel,
/area/hallway/primary/port)
+"pOF" = (
+/obj/effect/turf_decal/bot,
+/obj/structure/closet/crate{
+ name = "disposal supplies"
+ },
+/obj/item/bodybag,
+/obj/item/bodybag,
+/obj/item/shovel,
+/obj/item/stack/sheet/mineral/copper{
+ amount = 5
+ },
+/turf/open/floor/plating{
+ icon_state = "platingdmg3"
+ },
+/area/maintenance/starboard/aft)
"pON" = (
/obj/structure/cable/yellow{
icon_state = "1-2"
@@ -62293,6 +62307,12 @@
dir = 4
},
/area/janitor)
+"qhV" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/plating{
+ icon_state = "panelscorched"
+ },
+/area/maintenance/aft)
"qhY" = (
/obj/machinery/light,
/obj/structure/table,
@@ -68259,10 +68279,6 @@
},
/turf/open/floor/plasteel/dark,
/area/security/brig)
-"rCv" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/starboard/aft)
"rCG" = (
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
/obj/effect/turf_decal/tile/neutral/half/contrasted{
@@ -72898,6 +72914,18 @@
"sJa" = (
/turf/closed/wall/r_wall,
/area/science/robotics/mechbay)
+"sJe" = (
+/mob/living/basic/cockroach{
+ desc = "carlos.";
+ maxHealth = 2;
+ name = "carlos";
+
+ },
+/obj/machinery/atmospherics/components/unary/vent_pump/on/layer2{
+ dir = 4
+ },
+/turf/open/floor/wood,
+/area/library)
"sJf" = (
/obj/machinery/door/airlock/maintenance{
name = "Teleporter Maintenance";
@@ -75695,12 +75723,6 @@
/obj/effect/turf_decal/tile/red/fourcorners/contrasted,
/turf/open/floor/plasteel/techmaint,
/area/security/prison)
-"ttb" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating{
- icon_state = "platingdmg3"
- },
-/area/maintenance/port)
"ttd" = (
/obj/effect/decal/cleanable/dirt,
/turf/open/floor/plating{
@@ -78874,6 +78896,14 @@
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
/turf/open/floor/carpet/purple,
/area/crew_quarters/heads/hor)
+"uiy" = (
+/obj/effect/decal/cleanable/dirt,
+/obj/effect/decal/cleanable/dirt,
+/mob/living/basic/cockroach,
+/turf/open/floor/plating{
+ icon_state = "panelscorched"
+ },
+/area/maintenance/port/central)
"uiz" = (
/obj/effect/turf_decal/trimline/red/warning{
dir = 8
@@ -79283,20 +79313,6 @@
dir = 4
},
/area/maintenance/department/engine)
-"unb" = (
-/mob/living/simple_animal/cockroach,
-/obj/effect/turf_decal/stripes/line{
- dir = 10
- },
-/obj/effect/decal/cleanable/dirt,
-/obj/structure/extinguisher_cabinet{
- pixel_x = -26
- },
-/obj/effect/landmark/blobstart,
-/turf/open/floor/plating{
- icon_state = "platingdmg1"
- },
-/area/maintenance/starboard/aft)
"une" = (
/obj/structure/cable/yellow{
icon_state = "4-8"
@@ -79699,11 +79715,6 @@
/obj/effect/turf_decal/bot,
/turf/open/floor/plasteel/dark/side,
/area/teleporter)
-"usw" = (
-/obj/effect/decal/cleanable/dirt,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/starboard/aft)
"usA" = (
/obj/structure/closet/secure_closet/personal/cabinet,
/obj/item/clothing/under/misc/assistantformal,
@@ -80641,6 +80652,11 @@
},
/turf/open/floor/plasteel/dark,
/area/security/checkpoint)
+"uCf" = (
+/obj/effect/decal/cleanable/dirt,
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/starboard/aft)
"uCg" = (
/obj/effect/turf_decal/guideline/guideline_in/red,
/turf/open/floor/plasteel/dark/side{
@@ -81065,6 +81081,15 @@
/obj/effect/turf_decal/delivery,
/turf/open/floor/plasteel/dark,
/area/hallway/primary/port)
+"uIc" = (
+/obj/structure/cable/yellow{
+ icon_state = "1-2"
+ },
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
+/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/port/central)
"uId" = (
/turf/closed/wall,
/area/maintenance/port/aft)
@@ -84598,6 +84623,18 @@
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
/turf/open/floor/plasteel/dark,
/area/library/lounge)
+"vvb" = (
+/obj/structure/rack,
+/obj/item/crowbar,
+/obj/item/storage/pill_bottle,
+/obj/item/rollerbed,
+/obj/item/clothing/glasses/eyepatch,
+/obj/item/wrench,
+/obj/machinery/airalarm{
+ pixel_y = 22
+ },
+/turf/open/floor/plating,
+/area/maintenance/department/medical)
"vvh" = (
/obj/effect/turf_decal/trimline/blue/line{
dir = 6
@@ -88919,14 +88956,6 @@
/obj/structure/lattice/catwalk/over,
/turf/open/floor/plating,
/area/security/range)
-"wun" = (
-/obj/effect/turf_decal/stripes/white/line{
- dir = 4
- },
-/obj/effect/mapping_helpers/dead_body_placer/medbay_morgue,
-/obj/machinery/atmospherics/components/unary/vent_scrubber/on/layer4,
-/turf/open/floor/plasteel/techmaint,
-/area/medical/morgue)
"wuq" = (
/obj/machinery/vending/cola/random,
/obj/effect/turf_decal/delivery,
@@ -89693,20 +89722,6 @@
},
/turf/open/floor/plating,
/area/maintenance/aft)
-"wEt" = (
-/obj/effect/turf_decal/stripes/white/line{
- dir = 4
- },
-/obj/effect/mapping_helpers/dead_body_placer/medbay_morgue,
-/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
- dir = 10
- },
-/obj/structure/cable/yellow{
- icon_state = "1-2"
- },
-/turf/open/floor/plasteel/techmaint,
-/area/medical/morgue)
"wEv" = (
/obj/effect/decal/cleanable/dirt,
/obj/structure/rack,
@@ -91590,21 +91605,6 @@
"wYw" = (
/turf/closed/wall/r_wall,
/area/security/prison)
-"wYz" = (
-/obj/effect/turf_decal/bot,
-/obj/structure/closet/crate{
- name = "disposal supplies"
- },
-/obj/item/bodybag,
-/obj/item/bodybag,
-/obj/item/shovel,
-/obj/item/stack/sheet/mineral/copper{
- amount = 5
- },
-/turf/open/floor/plating{
- icon_state = "platingdmg3"
- },
-/area/maintenance/starboard/aft)
"wYE" = (
/obj/structure/table/wood,
/obj/structure/showcase/machinery/tv{
@@ -113251,7 +113251,7 @@ wxd
wxd
ivb
ogy
-ttb
+ilD
wxd
ojA
tqw
@@ -116532,7 +116532,7 @@ vNZ
glf
yfU
dOr
-bDu
+sJe
eoJ
yfU
hSD
@@ -120984,7 +120984,7 @@ xqm
bOO
uId
gOd
-cAF
+jWO
szF
oWu
uOg
@@ -124232,12 +124232,12 @@ lLM
lLM
dlt
rSH
-wun
+ijh
vRQ
vRQ
vRQ
kFY
-wEt
+kWn
rMc
bJt
kXS
@@ -124251,7 +124251,7 @@ kTT
eDs
xLS
rZN
-nzb
+dxK
ygM
tZK
oAX
@@ -124742,7 +124742,7 @@ lLM
lLM
lLM
dlt
-apO
+fec
aeJ
aeJ
aeJ
@@ -124988,7 +124988,7 @@ kHH
jID
lHA
ahc
-avk
+jjB
hmp
dGc
lLM
@@ -129621,7 +129621,7 @@ qzt
lLM
jID
dGT
-cdI
+uiy
veE
mQu
fvR
@@ -130432,7 +130432,7 @@ qTd
yio
eGs
yio
-lGw
+vvb
mJM
fHr
bdu
@@ -130515,7 +130515,7 @@ lXa
xip
huh
ygj
-mAa
+dWP
lIP
kQv
dgL
@@ -134372,7 +134372,7 @@ oDs
fqT
xav
xav
-awo
+dnu
ygj
xEK
rHU
@@ -137105,7 +137105,7 @@ nRs
nKl
ghy
nRs
-gYs
+uIc
nRs
wUO
nRs
@@ -138720,7 +138720,7 @@ uUs
lzB
uUs
ydi
-aST
+gNA
vKD
ylR
hfo
@@ -139764,7 +139764,7 @@ jcO
qQK
vXB
vLs
-enh
+qhV
ylJ
qNd
ylJ
@@ -142259,7 +142259,7 @@ dOe
nxE
sZW
iQn
-nET
+kRD
nSC
yhP
oCx
@@ -143575,7 +143575,7 @@ qsh
wtw
qTw
tnS
-usw
+uCf
rFa
dTQ
fbu
@@ -146915,7 +146915,7 @@ yfs
wDO
yhB
wCr
-mRK
+evi
pSb
wWM
nMK
@@ -149456,7 +149456,7 @@ joS
mVq
qlJ
vFX
-mXT
+cwR
opT
oKz
kGA
@@ -150224,7 +150224,7 @@ ppB
ifd
ipT
joS
-mXT
+cwR
qlJ
nKS
joS
@@ -152569,7 +152569,7 @@ vPF
lrE
yhB
wCr
-rCv
+haD
wWM
xUO
xUO
@@ -153100,7 +153100,7 @@ yhB
yhB
rvS
yhB
-rCv
+haD
yhB
rvS
yhB
@@ -153610,7 +153610,7 @@ cGp
cGp
cGp
mpL
-wYz
+pOF
sIe
tLq
dHH
@@ -153876,7 +153876,7 @@ sIe
sIe
byb
wnw
-unb
+jYo
rTh
mTi
uZb
diff --git a/_maps/map_files/MetaStation/MetaStation.dmm b/_maps/map_files/MetaStation/MetaStation.dmm
index 3d7499c247074..3f68a8ff432b8 100644
--- a/_maps/map_files/MetaStation/MetaStation.dmm
+++ b/_maps/map_files/MetaStation/MetaStation.dmm
@@ -4741,6 +4741,27 @@
},
/turf/open/floor/plating,
/area/maintenance/starboard/fore)
+"axP" = (
+/obj/structure/safe,
+/obj/item/storage/secure/briefcase{
+ contents = newlist(/obj/item/clothing/suit/armor/vest,/obj/item/gun/ballistic/automatic/pistol,/obj/item/suppressor,/obj/item/melee/classic_baton/police/telescopic,/obj/item/clothing/mask/balaclava,/obj/item/bodybag,/obj/item/soap/nanotrasen)
+ },
+/obj/item/storage/backpack/duffelbag/syndie/hitman,
+/obj/item/card/id/silver/reaper,
+/obj/item/lazarus_injector,
+/obj/item/gun/energy/disabler,
+/obj/item/gun/ballistic/revolver/russian,
+/obj/item/ammo_box/a357,
+/obj/item/clothing/neck/stethoscope,
+/obj/item/book{
+ desc = "An undeniably handy book.";
+ icon_state = "bookknock";
+ name = "A Simpleton's Guide to Safe-cracking with Stethoscopes"
+ },
+/obj/effect/turf_decal/bot_white/left,
+/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
+/turf/open/floor/plasteel/dark,
+/area/security/nuke_storage)
"axT" = (
/obj/machinery/navbeacon{
codes_txt = "delivery;dir=4";
@@ -7130,21 +7151,6 @@
},
/turf/open/floor/plasteel,
/area/quartermaster/storage)
-"aIo" = (
-/obj/machinery/door/airlock/maintenance{
- req_one_access_txt = "12;4;5;6;29"
- },
-/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
- dir = 8
- },
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
- dir = 8
- },
-/obj/structure/cable/yellow{
- icon_state = "4-8"
- },
-/turf/open/floor/plating,
-/area/maintenance/aft)
"aIv" = (
/obj/machinery/light{
dir = 8
@@ -24178,11 +24184,6 @@
},
/turf/open/floor/plasteel/airless/solarpanel,
/area/solar/port/aft)
-"cwl" = (
-/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
-/obj/effect/mapping_helpers/dead_body_placer,
-/turf/open/floor/plasteel,
-/area/medical/morgue)
"cwA" = (
/turf/open/floor/plasteel/white,
/area/medical/genetics)
@@ -24832,27 +24833,6 @@
},
/turf/open/floor/plating/airless,
/area/science/test_area)
-"cCL" = (
-/obj/structure/safe,
-/obj/item/storage/secure/briefcase{
- contents = newlist(/obj/item/clothing/suit/armor/vest,/obj/item/gun/ballistic/automatic/pistol,/obj/item/suppressor,/obj/item/melee/classic_baton/police/telescopic,/obj/item/clothing/mask/balaclava,/obj/item/bodybag,/obj/item/soap/nanotrasen)
- },
-/obj/item/storage/backpack/duffelbag/syndie/hitman,
-/obj/item/card/id/silver/reaper,
-/obj/item/lazarus_injector,
-/obj/item/gun/energy/disabler,
-/obj/item/gun/ballistic/revolver/russian,
-/obj/item/ammo_box/a357,
-/obj/item/clothing/neck/stethoscope,
-/obj/item/book{
- desc = "An undeniably handy book.";
- icon_state = "bookknock";
- name = "A Simpleton's Guide to Safe-cracking with Stethoscopes"
- },
-/obj/effect/turf_decal/bot_white/left,
-/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
-/turf/open/floor/plasteel/dark,
-/area/security/nuke_storage)
"cDa" = (
/obj/effect/spawner/structure/window/reinforced,
/obj/machinery/door/poddoor/shutters/preopen{
@@ -27629,6 +27609,10 @@
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
/turf/open/floor/plasteel/freezer,
/area/crew_quarters/toilet/restrooms)
+"deH" = (
+/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
+/turf/open/floor/plasteel/dark,
+/area/medical/morgue)
"deI" = (
/obj/effect/turf_decal/stripes/line{
dir = 8
@@ -28658,6 +28642,25 @@
},
/turf/open/floor/plating,
/area/maintenance/department/science/central)
+"djh" = (
+/obj/effect/turf_decal/tile/neutral/half/contrasted{
+ dir = 8
+ },
+/obj/machinery/power/apc/auto_name/north{
+ pixel_y = 24
+ },
+/obj/structure/cable/yellow{
+ icon_state = "0-2"
+ },
+/obj/machinery/camera/autoname{
+ dir = 6;
+ network = list("ss13","medbay")
+ },
+/obj/machinery/vending/wardrobe/medi_wardrobe,
+/turf/open/floor/plasteel{
+ heat_capacity = 1e+006
+ },
+/area/medical/storage)
"djj" = (
/obj/machinery/light/small{
dir = 4
@@ -30753,6 +30756,16 @@
},
/turf/open/floor/plasteel/white,
/area/medical/virology)
+"dVa" = (
+/obj/effect/turf_decal/tile/neutral/half/contrasted{
+ dir = 1
+ },
+/obj/machinery/vending/medical,
+/obj/effect/turf_decal/stripes/line{
+ dir = 8
+ },
+/turf/open/floor/plasteel,
+/area/medical/storage)
"dVK" = (
/obj/structure/cable/yellow{
icon_state = "4-8"
@@ -31035,6 +31048,25 @@
},
/turf/open/floor/plasteel,
/area/hallway/secondary/entry)
+"edV" = (
+/obj/machinery/airalarm/directional/north,
+/obj/structure/rack,
+/obj/item/rollerbed{
+ pixel_x = -2
+ },
+/obj/item/rollerbed{
+ pixel_x = 1;
+ pixel_y = 3
+ },
+/obj/item/rollerbed{
+ pixel_x = 5;
+ pixel_y = 8
+ },
+/obj/effect/turf_decal/tile/blue/anticorner/contrasted{
+ dir = 1
+ },
+/turf/open/floor/plasteel/white,
+/area/medical/medbay/lobby)
"eed" = (
/obj/effect/turf_decal/tile/neutral/half/contrasted,
/obj/effect/mapping_helpers/airlock/abandoned,
@@ -33222,18 +33254,6 @@
"feW" = (
/turf/open/floor/plasteel,
/area/maintenance/department/medical/central)
-"ffb" = (
-/obj/machinery/door/airlock/maintenance{
- req_one_access_txt = "12;4;5;39;6"
- },
-/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
- dir = 8
- },
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
- dir = 8
- },
-/turf/open/floor/plating,
-/area/maintenance/aft)
"ffd" = (
/obj/machinery/atmospherics/pipe/layer_manifold/visible{
dir = 4
@@ -33499,9 +33519,7 @@
/obj/effect/turf_decal/tile/yellow{
dir = 4
},
-/obj/machinery/power/apc/auto_name/east{
- pixel_x = 24
- },
+/obj/machinery/power/apc/auto_name/east,
/obj/structure/cable/yellow{
icon_state = "0-8"
},
@@ -35427,6 +35445,11 @@
/obj/effect/turf_decal/tile/neutral,
/turf/open/floor/plasteel,
/area/hallway/secondary/command)
+"fTz" = (
+/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
+/obj/effect/mapping_helpers/dead_body_placer,
+/turf/open/floor/plasteel,
+/area/medical/morgue)
"fTD" = (
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/obj/machinery/camera/autoname{
@@ -36328,9 +36351,7 @@
name = "medbay camera";
network = list("ss13","medbay")
},
-/obj/machinery/power/apc/auto_name/east{
- pixel_x = 24
- },
+/obj/machinery/power/apc/auto_name/east,
/obj/structure/cable/yellow,
/turf/open/floor/plasteel/dark,
/area/medical/surgery)
@@ -39185,6 +39206,16 @@
},
/turf/open/floor/plasteel/white,
/area/science/research)
+"hFY" = (
+/obj/effect/decal/cleanable/dirt,
+/obj/effect/turf_decal/tile/neutral/half/contrasted{
+ dir = 4
+ },
+/mob/living/basic/cockroach{
+ dir = 1
+ },
+/turf/open/floor/plasteel,
+/area/maintenance/aft)
"hGb" = (
/obj/structure/disposalpipe/junction/flip{
dir = 8
@@ -39582,18 +39613,6 @@
},
/turf/open/floor/plasteel,
/area/science/mixing)
-"hNP" = (
-/obj/effect/turf_decal/bot,
-/obj/effect/turf_decal/siding/dark,
-/obj/structure/closet/secure_closet{
- anchored = 1;
- name = "patient's closet";
- req_access_txt = "5"
- },
-/obj/item/clothing/shoes/sneakers/white,
-/obj/item/clothing/under/color/white,
-/turf/open/floor/plasteel,
-/area/medical/patients_rooms)
"hOi" = (
/obj/structure/cable/yellow{
icon_state = "4-8"
@@ -41434,7 +41453,6 @@
"iAQ" = (
/obj/effect/turf_decal/tile/green/fourcorners/contrasted,
/obj/machinery/door/airlock/virology/glass{
- id_tag = null;
name = "Virology Ward";
req_access_txt = "39"
},
@@ -42041,9 +42059,7 @@
/obj/machinery/light{
dir = 4
},
-/obj/machinery/power/apc/auto_name/east{
- pixel_x = 24
- },
+/obj/machinery/power/apc/auto_name/east,
/obj/structure/cable/yellow{
icon_state = "0-8"
},
@@ -43557,21 +43573,6 @@
},
/turf/open/floor/plasteel/white,
/area/medical/surgery)
-"jwb" = (
-/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
- dir = 8
- },
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
- dir = 4
- },
-/obj/structure/cable/yellow{
- icon_state = "4-8"
- },
-/obj/machinery/door/airlock/maintenance{
- req_one_access_txt = "12;27;37;29;5;6;4"
- },
-/turf/open/floor/plating,
-/area/maintenance/aft)
"jwy" = (
/turf/open/floor/plasteel/stairs{
dir = 1
@@ -43782,30 +43783,6 @@
},
/turf/open/floor/plasteel,
/area/maintenance/department/medical/central)
-"jzN" = (
-/obj/structure/table,
-/obj/item/reagent_containers/food/snacks/grown/tomato/blood{
- pixel_x = 7;
- pixel_y = 8
- },
-/obj/item/reagent_containers/syringe{
- pixel_x = -4;
- pixel_y = 2
- },
-/obj/machinery/vending/wallmed{
- contraband = list(/obj/item/reagent_containers/glass/bottle/chloralhydrate = 1, /obj/item/storage/box/hug/medical = 1, /obj/item/reagent_containers/glass/bottle/random_virus = 1);
- name = "Upgraded NanoMed";
- pixel_x = -1;
- pixel_y = -32;
- premium = list(/obj/item/storage/firstaid/regular = 3, /obj/item/storage/belt/medical = 3, /obj/item/sensor_device = 2, /obj/item/pinpointer/crew = 2, /obj/item/healthanalyzer = 2, /obj/item/wrench/medical = 1);
- products = list(/obj/item/reagent_containers/syringe = 12, /obj/item/reagent_containers/dropper = 3, /obj/item/reagent_containers/medspray = 6, /obj/item/storage/pill_bottle = 6, /obj/item/reagent_containers/glass/bottle = 10, /obj/item/reagent_containers/spray/cleaner = 1, /obj/item/stack/medical/gauze = 8, /obj/item/reagent_containers/hypospray/medipen = 8, /obj/item/reagent_containers/hypospray/medipen/dexalin = 8, /obj/item/reagent_containers/glass/bottle/epinephrine = 4, /obj/item/reagent_containers/glass/bottle/charcoal = 4, /obj/item/reagent_containers/glass/bottle/salglu_solution = 4, /obj/item/reagent_containers/glass/bottle/tricordrazine = 1, /obj/item/reagent_containers/glass/bottle/spaceacillin = 1, /obj/item/reagent_containers/glass/bottle/morphine = 2, /obj/item/reagent_containers/glass/bottle/toxin = 4, /obj/item/reagent_containers/medspray/sterilizine = 4)
- },
-/obj/item/reagent_containers/dropper{
- pixel_x = 2;
- pixel_y = -5
- },
-/turf/open/floor/plasteel/grid/steel,
-/area/medical/virology)
"jzU" = (
/obj/effect/turf_decal/plaque{
icon_state = "L9"
@@ -47279,16 +47256,6 @@
},
/turf/open/floor/plasteel/white,
/area/medical/medbay/aft)
-"kTC" = (
-/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
-/obj/effect/decal/cleanable/dirt,
-/obj/effect/decal/cleanable/dirt,
-/obj/structure/disposalpipe/segment{
- dir = 2
- },
-/obj/effect/mapping_helpers/dead_body_placer,
-/turf/open/floor/plasteel,
-/area/medical/morgue)
"kTE" = (
/obj/structure/cable/yellow{
icon_state = "2-4"
@@ -48196,15 +48163,15 @@
/turf/open/floor/plasteel,
/area/science/robotics/lab)
"loj" = (
+/obj/machinery/atmospherics/pipe/manifold/scrubbers/hidden/layer4,
+/obj/machinery/atmospherics/pipe/manifold/supply/hidden/layer2{
+ dir = 4
+ },
/mob/living/simple_animal/bot/medbot{
auto_patrol = 1;
desc = "A little medical robot, officially part of the Nanotrasen medical inspectorate. He looks somewhat underwhelmed.";
name = "Inspector Johnson"
},
-/obj/machinery/atmospherics/pipe/manifold/scrubbers/hidden/layer4,
-/obj/machinery/atmospherics/pipe/manifold/supply/hidden/layer2{
- dir = 4
- },
/turf/open/floor/plasteel/white,
/area/medical/medbay/lobby)
"loq" = (
@@ -48272,6 +48239,37 @@
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
/turf/open/floor/plasteel/showroomfloor,
/area/security/warden)
+"lpP" = (
+/obj/effect/turf_decal/tile/neutral/half/contrasted{
+ dir = 8
+ },
+/obj/machinery/firealarm/directional/east,
+/obj/effect/turf_decal/stripes/line,
+/obj/structure/table/glass,
+/obj/item/clothing/neck/stethoscope,
+/obj/item/clothing/neck/stethoscope,
+/obj/item/storage/belt/medical,
+/obj/item/storage/belt/medical,
+/obj/item/clothing/glasses/hud/health,
+/obj/item/reagent_containers/spray/cleaner{
+ pixel_x = -3;
+ pixel_y = 2
+ },
+/obj/item/clothing/glasses/hud/health,
+/obj/machinery/door/window/westleft{
+ dir = 2;
+ name = "First-Aid Supplies";
+ req_access_txt = "5"
+ },
+/obj/structure/window/reinforced{
+ dir = 8;
+ layer = 2.9
+ },
+/obj/effect/loot_jobscale/medical/first_aid_kit,
+/turf/open/floor/plasteel{
+ heat_capacity = 1e+006
+ },
+/area/medical/storage)
"lqg" = (
/obj/structure/flora/ausbushes/grassybush,
/obj/structure/flora/ausbushes/lavendergrass,
@@ -49405,6 +49403,21 @@
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
/turf/open/floor/plasteel,
/area/hallway/primary/port)
+"lPy" = (
+/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
+ dir = 8
+ },
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
+ dir = 4
+ },
+/obj/structure/cable/yellow{
+ icon_state = "4-8"
+ },
+/obj/machinery/door/airlock/maintenance{
+ req_one_access_txt = "12;27;37;29;5;6;4"
+ },
+/turf/open/floor/plating,
+/area/maintenance/aft)
"lQb" = (
/obj/structure/sign/warning/vacuum/external{
pixel_y = -32
@@ -50515,9 +50528,7 @@
/obj/effect/turf_decal/trimline/blue/filled/line{
dir = 4
},
-/obj/machinery/power/apc/auto_name/east{
- pixel_x = 24
- },
+/obj/machinery/power/apc/auto_name/east,
/obj/structure/cable/yellow{
icon_state = "0-8"
},
@@ -53035,6 +53046,41 @@
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
/turf/open/floor/circuit/green/telecomms/mainframe,
/area/tcommsat/server)
+"npX" = (
+/obj/item/reagent_containers/syringe/antiviral{
+ pixel_x = 7;
+ pixel_y = 13
+ },
+/obj/item/reagent_containers/syringe/antiviral{
+ pixel_x = 5;
+ pixel_y = 10
+ },
+/obj/item/reagent_containers/syringe/antiviral{
+ pixel_x = 1;
+ pixel_y = 8
+ },
+/obj/item/reagent_containers/syringe/antiviral{
+ pixel_y = 5
+ },
+/obj/item/reagent_containers/syringe/antiviral{
+ pixel_x = -1;
+ pixel_y = 1
+ },
+/obj/item/reagent_containers/syringe/antiviral{
+ pixel_x = -2;
+ pixel_y = -1
+ },
+/obj/item/storage/box/syringes{
+ pixel_x = 6;
+ pixel_y = 11
+ },
+/obj/structure/table,
+/obj/item/storage/box/beakers{
+ pixel_x = -6;
+ pixel_y = 3
+ },
+/turf/open/floor/plasteel/grid/steel,
+/area/medical/virology)
"nqE" = (
/obj/structure/rack,
/obj/item/stock_parts/matter_bin,
@@ -53264,6 +53310,18 @@
},
/turf/open/floor/plasteel/freezer,
/area/crew_quarters/toilet/restrooms)
+"nxm" = (
+/obj/machinery/door/airlock/maintenance{
+ req_one_access_txt = "12;4;5;39;6"
+ },
+/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
+ dir = 8
+ },
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
+ dir = 8
+ },
+/turf/open/floor/plating,
+/area/maintenance/aft)
"nxo" = (
/obj/effect/turf_decal/trimline/purple/filled/line{
dir = 8
@@ -53487,15 +53545,6 @@
},
/turf/open/floor/plasteel/dark,
/area/science/shuttledock)
-"nBW" = (
-/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
-/obj/effect/decal/cleanable/dirt,
-/obj/structure/disposalpipe/segment{
- dir = 2
- },
-/obj/effect/mapping_helpers/dead_body_placer,
-/turf/open/floor/plasteel,
-/area/medical/morgue)
"nCe" = (
/obj/machinery/atmospherics/pipe/manifold/scrubbers/hidden/layer4{
dir = 8
@@ -54087,6 +54136,21 @@
/obj/machinery/light,
/turf/open/floor/plasteel,
/area/hallway/primary/central)
+"nNG" = (
+/obj/machinery/door/airlock/maintenance{
+ req_one_access_txt = "12;4;5;6;29"
+ },
+/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
+ dir = 8
+ },
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
+ dir = 8
+ },
+/obj/structure/cable/yellow{
+ icon_state = "4-8"
+ },
+/turf/open/floor/plating,
+/area/maintenance/aft)
"nNY" = (
/obj/machinery/light/small{
dir = 8
@@ -54116,16 +54180,6 @@
/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
/turf/open/floor/plasteel/dark,
/area/gateway)
-"nOu" = (
-/obj/effect/turf_decal/tile/neutral/half/contrasted{
- dir = 1
- },
-/obj/machinery/vending/medical,
-/obj/effect/turf_decal/stripes/line{
- dir = 8
- },
-/turf/open/floor/plasteel,
-/area/medical/storage)
"nOA" = (
/obj/machinery/power/apc{
areastring = "/area/security/execution/education";
@@ -54247,37 +54301,6 @@
},
/turf/open/floor/plasteel/white,
/area/science/research)
-"nQu" = (
-/obj/effect/turf_decal/tile/neutral/half/contrasted{
- dir = 8
- },
-/obj/machinery/firealarm/directional/east,
-/obj/effect/turf_decal/stripes/line,
-/obj/structure/table/glass,
-/obj/item/clothing/neck/stethoscope,
-/obj/item/clothing/neck/stethoscope,
-/obj/item/storage/belt/medical,
-/obj/item/storage/belt/medical,
-/obj/item/clothing/glasses/hud/health,
-/obj/item/reagent_containers/spray/cleaner{
- pixel_x = -3;
- pixel_y = 2
- },
-/obj/item/clothing/glasses/hud/health,
-/obj/machinery/door/window/westleft{
- dir = 2;
- name = "First-Aid Supplies";
- req_access_txt = "5"
- },
-/obj/structure/window/reinforced{
- dir = 8;
- layer = 2.9
- },
-/obj/effect/loot_jobscale/medical/first_aid_kit,
-/turf/open/floor/plasteel{
- heat_capacity = 1e+006
- },
-/area/medical/storage)
"nQH" = (
/obj/structure/cable/yellow{
icon_state = "1-4"
@@ -55311,41 +55334,6 @@
},
/turf/open/floor/plating,
/area/maintenance/port/fore)
-"omR" = (
-/obj/item/reagent_containers/syringe/antiviral{
- pixel_x = 7;
- pixel_y = 13
- },
-/obj/item/reagent_containers/syringe/antiviral{
- pixel_x = 5;
- pixel_y = 10
- },
-/obj/item/reagent_containers/syringe/antiviral{
- pixel_x = 1;
- pixel_y = 8
- },
-/obj/item/reagent_containers/syringe/antiviral{
- pixel_y = 5
- },
-/obj/item/reagent_containers/syringe/antiviral{
- pixel_x = -1;
- pixel_y = 1
- },
-/obj/item/reagent_containers/syringe/antiviral{
- pixel_x = -2;
- pixel_y = -1
- },
-/obj/item/storage/box/syringes{
- pixel_x = 6;
- pixel_y = 11
- },
-/obj/structure/table,
-/obj/item/storage/box/beakers{
- pixel_x = -6;
- pixel_y = 3
- },
-/turf/open/floor/plasteel/grid/steel,
-/area/medical/virology)
"onc" = (
/obj/structure/disposalpipe/segment,
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
@@ -58606,10 +58594,6 @@
/obj/structure/reagent_dispensers/beerkeg,
/turf/open/floor/plating,
/area/maintenance/aft)
-"pKG" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/aft)
"pKQ" = (
/obj/machinery/light_switch{
pixel_x = 28
@@ -61544,25 +61528,6 @@
},
/turf/open/floor/plasteel/freezer,
/area/medical/genetics)
-"qRV" = (
-/obj/machinery/airalarm/directional/north,
-/obj/structure/rack,
-/obj/item/rollerbed{
- pixel_x = -2
- },
-/obj/item/rollerbed{
- pixel_x = 1;
- pixel_y = 3
- },
-/obj/item/rollerbed{
- pixel_x = 5;
- pixel_y = 8
- },
-/obj/effect/turf_decal/tile/blue/anticorner/contrasted{
- dir = 1
- },
-/turf/open/floor/plasteel/white,
-/area/medical/medbay/lobby)
"qRY" = (
/obj/structure/cable/yellow{
icon_state = "4-8"
@@ -62204,9 +62169,7 @@
/turf/open/floor/plasteel/white,
/area/crew_quarters/heads/cmo)
"rjv" = (
-/obj/effect/turf_decal/numbers/two_nine{
- dir = 2
- },
+/obj/effect/turf_decal/numbers/two_nine,
/turf/open/floor/plasteel/grid/steel,
/area/medical/virology)
"rjF" = (
@@ -62748,6 +62711,10 @@
/obj/effect/mapping_helpers/airlock/locked,
/turf/open/floor/engine,
/area/science/mixing/chamber)
+"ruj" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/aft)
"ruC" = (
/obj/structure/disposalpipe/segment,
/obj/effect/turf_decal/stripes/corner{
@@ -63530,19 +63497,6 @@
/mob/living/carbon/monkey,
/turf/open/floor/plasteel/grid/steel,
/area/medical/virology)
-"rOI" = (
-/obj/machinery/rnd/production/techfab/department/medical,
-/obj/machinery/light{
- dir = 4
- },
-/obj/machinery/light_switch{
- pixel_x = 21
- },
-/obj/effect/turf_decal/stripes/line{
- dir = 9
- },
-/turf/open/floor/plasteel/grid/steel,
-/area/medical/storage)
"rOP" = (
/obj/effect/turf_decal/stripes/line{
dir = 1
@@ -65769,7 +65723,7 @@
icon_state = "1-2"
},
/obj/machinery/navbeacon{
- codes_txt = "patrol;next_patrol=14-Starboard-Central";
+ codes_txt = "patrol;next_patrol=13.3-Engineering-Enter-corner";
location = "13.2-Tcommstore"
},
/turf/open/floor/plasteel,
@@ -65876,6 +65830,18 @@
},
/turf/open/floor/engine,
/area/maintenance/department/science/xenobiology)
+"sMS" = (
+/obj/effect/turf_decal/bot,
+/obj/effect/turf_decal/siding/dark,
+/obj/structure/closet/secure_closet{
+ anchored = 1;
+ name = "patient's closet";
+ req_access_txt = "5"
+ },
+/obj/item/clothing/shoes/sneakers/white,
+/obj/item/clothing/under/color/white,
+/turf/open/floor/plasteel,
+/area/medical/patients_rooms)
"sNf" = (
/obj/structure/cable/yellow{
icon_state = "4-8"
@@ -67219,15 +67185,9 @@
/obj/structure/window/reinforced{
dir = 1
},
-/obj/structure/flora/grass/jungle/b{
- max_integrity = 20
- },
-/obj/structure/flora/ausbushes/brflowers{
- max_integrity = 20
- },
-/obj/structure/flora/ausbushes/fullgrass{
- max_integrity = 20
- },
+/obj/structure/flora/grass/jungle/b,
+/obj/structure/flora/ausbushes/brflowers,
+/obj/structure/flora/ausbushes/fullgrass,
/obj/machinery/light{
dir = 8
},
@@ -67343,12 +67303,8 @@
/turf/open/floor/plasteel/white,
/area/crew_quarters/heads/hor)
"ttF" = (
-/obj/structure/flora/ausbushes/leafybush{
- max_integrity = 20
- },
-/obj/structure/flora/ausbushes/fullgrass{
- max_integrity = 20
- },
+/obj/structure/flora/ausbushes/leafybush,
+/obj/structure/flora/ausbushes/fullgrass,
/mob/living/simple_animal/butterfly{
dir = 8;
name = "Justine"
@@ -68281,16 +68237,6 @@
/obj/machinery/light,
/turf/open/floor/plasteel,
/area/medical/medbay/aft)
-"tPG" = (
-/obj/effect/decal/cleanable/dirt,
-/obj/effect/turf_decal/tile/neutral/half/contrasted{
- dir = 4
- },
-/mob/living/simple_animal/cockroach{
- dir = 1
- },
-/turf/open/floor/plasteel,
-/area/maintenance/aft)
"tQf" = (
/obj/machinery/light,
/obj/machinery/camera{
@@ -69855,7 +69801,6 @@
name = "Test Range";
pixel_x = 25;
pixel_y = -6;
- req_access = null;
req_access_txt = "49"
},
/obj/effect/turf_decal/stripes/line{
@@ -69960,9 +69905,7 @@
/turf/open/floor/plasteel,
/area/security/prison)
"uBe" = (
-/obj/structure/flora/ausbushes/sunnybush{
- max_integrity = 20
- },
+/obj/structure/flora/ausbushes/sunnybush,
/obj/structure/window/reinforced,
/obj/structure/window/reinforced{
dir = 1
@@ -70750,6 +70693,15 @@
},
/turf/open/floor/plasteel,
/area/medical/genetics)
+"uVF" = (
+/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
+/obj/effect/decal/cleanable/dirt,
+/obj/structure/disposalpipe/segment{
+ dir = 2
+ },
+/obj/effect/mapping_helpers/dead_body_placer,
+/turf/open/floor/plasteel,
+/area/medical/morgue)
"uVT" = (
/obj/structure/window/reinforced,
/obj/structure/cable/yellow{
@@ -71292,25 +71244,6 @@
/obj/item/xenoartifact_labeler,
/turf/open/floor/plasteel/dark,
/area/science/explab)
-"vht" = (
-/obj/effect/turf_decal/tile/neutral/half/contrasted{
- dir = 8
- },
-/obj/machinery/power/apc/auto_name/north{
- pixel_y = 24
- },
-/obj/structure/cable/yellow{
- icon_state = "0-2"
- },
-/obj/machinery/camera/autoname{
- dir = 6;
- network = list("ss13","medbay")
- },
-/obj/machinery/vending/wardrobe/medi_wardrobe,
-/turf/open/floor/plasteel{
- heat_capacity = 1e+006
- },
-/area/medical/storage)
"vhy" = (
/obj/effect/turf_decal/plaque{
icon_state = "L3"
@@ -71819,6 +71752,16 @@
},
/turf/open/floor/plasteel,
/area/hallway/primary/port)
+"vsi" = (
+/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
+/obj/effect/decal/cleanable/dirt,
+/obj/effect/decal/cleanable/dirt,
+/obj/structure/disposalpipe/segment{
+ dir = 2
+ },
+/obj/effect/mapping_helpers/dead_body_placer,
+/turf/open/floor/plasteel,
+/area/medical/morgue)
"vsC" = (
/obj/machinery/atmospherics/components/unary/vent_scrubber/on/layer4,
/turf/open/floor/plasteel,
@@ -72196,10 +72139,6 @@
},
/turf/open/floor/plasteel,
/area/storage/primary)
-"vBp" = (
-/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
-/turf/open/floor/plasteel/dark,
-/area/medical/morgue)
"vBz" = (
/turf/open/floor/plasteel,
/area/medical/break_room)
@@ -72462,6 +72401,19 @@
},
/turf/open/floor/plasteel,
/area/maintenance/department/science)
+"vHE" = (
+/obj/machinery/rnd/production/techfab/department/medical,
+/obj/machinery/light{
+ dir = 4
+ },
+/obj/machinery/light_switch{
+ pixel_x = 21
+ },
+/obj/effect/turf_decal/stripes/line{
+ dir = 9
+ },
+/turf/open/floor/plasteel/grid/steel,
+/area/medical/storage)
"vHF" = (
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
dir = 4
@@ -73183,7 +73135,6 @@
icon_state = "4-8"
},
/obj/machinery/door/airlock/virology/glass{
- id_tag = null;
name = "Virology Ward";
req_access_txt = "39"
},
@@ -73420,9 +73371,7 @@
/turf/open/floor/plasteel,
/area/hallway/secondary/entry)
"waW" = (
-/obj/structure/flora/ausbushes/ywflowers{
- max_integrity = 20
- },
+/obj/structure/flora/ausbushes/ywflowers,
/obj/structure/window/reinforced,
/obj/structure/window/reinforced{
dir = 1
@@ -73512,18 +73461,6 @@
},
/turf/open/floor/plating,
/area/maintenance/fore)
-"wdX" = (
-/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
-/obj/machinery/power/apc/auto_name/west{
- pixel_x = -24
- },
-/obj/structure/cable/yellow{
- icon_state = "0-4"
- },
-/obj/effect/decal/cleanable/cobweb,
-/obj/structure/bed/roller,
-/turf/open/floor/plasteel/dark,
-/area/medical/morgue)
"wee" = (
/obj/structure/cable/yellow{
icon_state = "1-2"
@@ -74526,7 +74463,6 @@
name = "Test Range";
pixel_x = -7;
pixel_y = 26;
- req_access = null;
req_access_txt = "49"
},
/obj/effect/turf_decal/trimline/purple/filled/line{
@@ -74556,6 +74492,10 @@
/obj/structure/cable/yellow{
icon_state = "2-8"
},
+/obj/machinery/navbeacon{
+ codes_txt = "patrol;next_patrol=14-Starboard-Central";
+ location = "13.3-Engineering-Enter-corner"
+ },
/turf/open/floor/plasteel,
/area/hallway/primary/starboard)
"wxV" = (
@@ -74658,6 +74598,18 @@
},
/turf/open/floor/plasteel/cafeteria_red,
/area/crew_quarters/bar)
+"wzJ" = (
+/obj/effect/turf_decal/tile/neutral/fourcorners/contrasted,
+/obj/machinery/power/apc/auto_name/west{
+ pixel_x = -24
+ },
+/obj/structure/cable/yellow{
+ icon_state = "0-4"
+ },
+/obj/effect/decal/cleanable/cobweb,
+/obj/structure/bed/roller,
+/turf/open/floor/plasteel/dark,
+/area/medical/morgue)
"wzV" = (
/obj/structure/cable/yellow{
icon_state = "4-8"
@@ -75989,9 +75941,7 @@
/turf/open/floor/plasteel,
/area/storage/art)
"xaq" = (
-/obj/structure/flora/junglebush/b{
- max_integrity = 20
- },
+/obj/structure/flora/junglebush/b,
/obj/structure/window/reinforced,
/obj/structure/window/reinforced{
dir = 1
@@ -77393,6 +77343,30 @@
},
/turf/open/floor/plasteel,
/area/quartermaster/qm)
+"xBh" = (
+/obj/structure/table,
+/obj/item/reagent_containers/food/snacks/grown/tomato/blood{
+ pixel_x = 7;
+ pixel_y = 8
+ },
+/obj/item/reagent_containers/syringe{
+ pixel_x = -4;
+ pixel_y = 2
+ },
+/obj/machinery/vending/wallmed{
+ contraband = list(/obj/item/reagent_containers/glass/bottle/chloralhydrate=1,/obj/item/storage/box/hug/medical=1,/obj/item/reagent_containers/glass/bottle/random_virus=1);
+ name = "Upgraded NanoMed";
+ pixel_x = -1;
+ pixel_y = -32;
+ premium = list(/obj/item/storage/firstaid/regular=3,/obj/item/storage/belt/medical=3,/obj/item/sensor_device=2,/obj/item/pinpointer/crew=2,/obj/item/healthanalyzer=2,/obj/item/wrench/medical=1);
+ products = list(/obj/item/reagent_containers/syringe=12,/obj/item/reagent_containers/dropper=3,/obj/item/reagent_containers/medspray=6,/obj/item/storage/pill_bottle=6,/obj/item/reagent_containers/glass/bottle=10,/obj/item/reagent_containers/spray/cleaner=1,/obj/item/stack/medical/gauze=8,/obj/item/reagent_containers/hypospray/medipen=8,/obj/item/reagent_containers/hypospray/medipen/dexalin=8,/obj/item/reagent_containers/glass/bottle/epinephrine=4,/obj/item/reagent_containers/glass/bottle/charcoal=4,/obj/item/reagent_containers/glass/bottle/salglu_solution=4,/obj/item/reagent_containers/glass/bottle/tricordrazine=1,/obj/item/reagent_containers/glass/bottle/spaceacillin=1,/obj/item/reagent_containers/glass/bottle/morphine=2,/obj/item/reagent_containers/glass/bottle/toxin=4,/obj/item/reagent_containers/medspray/sterilizine=4)
+ },
+/obj/item/reagent_containers/dropper{
+ pixel_x = 2;
+ pixel_y = -5
+ },
+/turf/open/floor/plasteel/grid/steel,
+/area/medical/virology)
"xBv" = (
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
dir = 10
@@ -78187,22 +78161,14 @@
/obj/structure/window/reinforced{
dir = 1
},
-/obj/structure/flora/ausbushes/leafybush{
- max_integrity = 20
- },
-/obj/structure/flora/ausbushes/fullgrass{
- max_integrity = 20
- },
-/obj/structure/flora/grass/jungle/b{
- max_integrity = 20
- },
+/obj/structure/flora/ausbushes/leafybush,
+/obj/structure/flora/ausbushes/fullgrass,
+/obj/structure/flora/grass/jungle/b,
/obj/structure/window/reinforced{
dir = 4;
layer = 2.9
},
-/obj/structure/flora/ausbushes/ppflowers{
- max_integrity = 20
- },
+/obj/structure/flora/ausbushes/ppflowers,
/turf/open/floor/grass,
/area/medical/patients_rooms)
"xPR" = (
@@ -95733,7 +95699,7 @@ wrk
geN
tqB
avr
-pKG
+ruj
gyd
avr
avr
@@ -96258,7 +96224,7 @@ avr
avr
avr
bTs
-tPG
+hFY
xoL
gpX
dBO
@@ -98559,7 +98525,7 @@ cDL
tDh
dle
wEb
-omR
+npX
rEg
xNp
osp
@@ -99078,7 +99044,7 @@ dQx
mnd
coa
lzI
-jzN
+xBh
cDL
avr
avr
@@ -100617,7 +100583,7 @@ doj
dvk
xYM
cCe
-wdX
+wzJ
vGw
goI
oyE
@@ -100877,7 +100843,7 @@ cCe
wCy
jrs
fPi
-cwl
+fTz
eLp
uqu
cCe
@@ -101116,7 +101082,7 @@ tQy
vUv
wLJ
mdY
-vht
+djh
gmr
cjV
hpp
@@ -101313,7 +101279,7 @@ awW
xcx
geM
trC
-cCL
+axP
awW
aaa
aFT
@@ -101373,10 +101339,10 @@ aJo
vRu
iKg
bXK
-nQu
+lpP
krk
-rOI
-nOu
+vHE
+dVa
hJd
xPR
nvp
@@ -101389,9 +101355,9 @@ rxV
jfN
pWx
nyc
-nBW
+uVF
nyc
-kTC
+vsi
hwG
fTD
cCe
@@ -101642,7 +101608,7 @@ qdC
cCe
xze
ojz
-vBp
+deH
cLY
vwX
oAf
@@ -101892,7 +101858,7 @@ bPK
vdv
bhX
uBe
-hNP
+sMS
nvp
wuJ
fGD
@@ -101910,7 +101876,7 @@ cCe
cCe
cCe
bTs
-jwb
+lPy
cLa
cLa
cMI
@@ -102149,7 +102115,7 @@ saq
cts
cqd
xaq
-hNP
+sMS
nvp
nTo
qdC
@@ -102406,7 +102372,7 @@ bPK
qLH
lfv
waW
-hNP
+sMS
nvp
ktf
nYh
@@ -102663,7 +102629,7 @@ jKl
cts
ngT
ttF
-hNP
+sMS
izO
fMs
qdC
@@ -103933,7 +103899,7 @@ aZa
jfB
bSS
bSS
-qRV
+edV
iqK
tDc
vXT
@@ -104224,7 +104190,7 @@ lTT
cPb
cPb
cPb
-ffb
+nxm
cPb
cMR
mLH
@@ -106276,7 +106242,7 @@ erP
ctB
ctD
ctB
-aIo
+nNG
cPb
cPb
qrx
diff --git a/_maps/map_files/RadStation/RadStation.dmm b/_maps/map_files/RadStation/RadStation.dmm
index f620c692b18cf..116d14209f4a7 100644
--- a/_maps/map_files/RadStation/RadStation.dmm
+++ b/_maps/map_files/RadStation/RadStation.dmm
@@ -2927,15 +2927,6 @@
/obj/effect/turf_decal/guideline/guideline_in/purple,
/turf/open/floor/plasteel,
/area/science/shuttledock)
-"aUl" = (
-/obj/effect/turf_decal/delivery,
-/obj/effect/turf_decal/tile/neutral/half/contrasted{
- dir = 1
- },
-/obj/effect/decal/cleanable/dirt,
-/obj/machinery/atmospherics/components/trinary/mixer/airmix/flipped/inverse,
-/turf/open/floor/plasteel,
-/area/engine/atmos)
"aUt" = (
/obj/machinery/door/airlock/maintenance_hatch{
name = "Maintenance Hatch";
@@ -3764,6 +3755,20 @@
/obj/machinery/disposal/bin,
/turf/open/floor/plasteel/dark,
/area/crew_quarters/heads/chief)
+"bib" = (
+/obj/structure/lattice/catwalk/over,
+/obj/structure/cable/yellow{
+ icon_state = "1-2"
+ },
+/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
+ dir = 1
+ },
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
+ dir = 1
+ },
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/central)
"bin" = (
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
dir = 9
@@ -4324,15 +4329,6 @@
},
/turf/open/floor/plasteel/dark,
/area/hallway/primary/central)
-"bsS" = (
-/obj/effect/decal/cleanable/blood/old,
-/obj/machinery/conveyor{
- dir = 9;
- id = "HB"
- },
-/mob/living/simple_animal/mothroach,
-/turf/open/floor/plating,
-/area/security/prison)
"bsT" = (
/obj/effect/turf_decal/bot,
/turf/open/floor/plasteel/techmaint,
@@ -5890,6 +5886,25 @@
/obj/item/pipe_dispenser,
/turf/open/floor/plasteel,
/area/engine/engine_room)
+"bRf" = (
+/obj/machinery/holopad,
+/obj/machinery/atmospherics/pipe/manifold/scrubbers/hidden/layer4{
+ dir = 4
+ },
+/obj/machinery/atmospherics/pipe/manifold/supply/hidden/layer2{
+ dir = 1
+ },
+/mob/living/basic/mothroach{
+ density = 0;
+ desc = "A festive mothroach";
+ name = "Erster"
+ },
+/obj/effect/turf_decal/box,
+/obj/structure/cable/yellow{
+ icon_state = "2-8"
+ },
+/turf/open/floor/plasteel/dark,
+/area/science/robotics)
"bRg" = (
/obj/machinery/atmospherics/pipe/simple/yellow/visible{
dir = 4
@@ -6511,6 +6526,12 @@
},
/turf/open/floor/plasteel/dark/side,
/area/hallway/secondary/exit/departure_lounge)
+"cdH" = (
+/obj/effect/turf_decal/tile/yellow/fourcorners/contrasted,
+/obj/effect/decal/cleanable/dirt,
+/mob/living/basic/cockroach,
+/turf/open/floor/plasteel,
+/area/maintenance/department/engine)
"cdL" = (
/obj/structure/window/reinforced{
dir = 4
@@ -8282,20 +8303,6 @@
/obj/effect/decal/cleanable/dirt/dust,
/turf/open/floor/plasteel/dark,
/area/vacant_room/commissary/commissary2)
-"cEj" = (
-/obj/structure/sign/poster/official/moth2{
- pixel_y = 32
- },
-/obj/structure/sign/poster/official/moth4{
- pixel_x = 32
- },
-/obj/machinery/conveyor{
- dir = 6;
- id = "HB"
- },
-/mob/living/simple_animal/mothroach,
-/turf/open/floor/plating,
-/area/security/prison)
"cEE" = (
/obj/machinery/light/small{
dir = 4
@@ -8303,6 +8310,11 @@
/obj/machinery/field/generator,
/turf/open/floor/plasteel/tech/grid,
/area/engine/engineering)
+"cEF" = (
+/obj/effect/decal/cleanable/blood/gibs/old,
+/mob/living/basic/cockroach,
+/turf/open/floor/plasteel/cafeteria,
+/area/maintenance/port/aft)
"cEU" = (
/obj/effect/turf_decal/stripes/line{
dir = 4
@@ -9390,6 +9402,10 @@
/obj/structure/lattice/catwalk/over,
/turf/open/floor/plating,
/area/maintenance/port/aft)
+"cXE" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/starboard/aft)
"cXH" = (
/obj/machinery/computer/atmos_alert,
/obj/effect/turf_decal/stripes/line,
@@ -11593,15 +11609,6 @@
/obj/machinery/airalarm/directional/north,
/turf/open/floor/plasteel,
/area/hallway/primary/port)
-"dHb" = (
-/obj/effect/decal/cleanable/dirt/dust,
-/obj/effect/turf_decal/tile/neutral/half/contrasted{
- dir = 1
- },
-/obj/structure/rack,
-/obj/effect/spawner/lootdrop/maintenance/eight,
-/turf/open/floor/plasteel,
-/area/maintenance/department/science)
"dHh" = (
/obj/effect/turf_decal/tile/neutral/half/contrasted{
dir = 1
@@ -11728,6 +11735,23 @@
},
/turf/open/floor/plasteel/tech,
/area/engine/engine_room)
+"dIZ" = (
+/obj/effect/turf_decal/guideline/guideline_out_arrow/brown{
+ dir = 1
+ },
+/obj/structure/cable/yellow{
+ icon_state = "4-8"
+ },
+/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
+ dir = 4
+ },
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
+ dir = 4
+ },
+/obj/structure/lattice/catwalk/over,
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/hallway/secondary/service)
"dJh" = (
/obj/machinery/atmospherics/pipe/simple/cyan/visible{
dir = 4
@@ -12737,6 +12761,11 @@
/obj/effect/decal/cleanable/dirt,
/turf/open/floor/plasteel,
/area/engine/atmos)
+"dWQ" = (
+/obj/structure/flora/ausbushes/fullgrass,
+/mob/living/basic/mothroach,
+/turf/open/floor/grass,
+/area/hallway/primary/central)
"dWR" = (
/obj/effect/turf_decal/stripes/line{
dir = 8
@@ -13580,6 +13609,15 @@
/obj/effect/decal/cleanable/dirt/dust,
/turf/open/floor/wood,
/area/vacant_room/office)
+"ely" = (
+/mob/living/basic/mothroach,
+/obj/effect/decal/cleanable/blood/old,
+/obj/machinery/conveyor{
+ dir = 9;
+ id = "HB"
+ },
+/turf/open/floor/plating,
+/area/security/prison)
"elG" = (
/obj/effect/turf_decal/tile/dark_red/half/contrasted{
alpha = 180;
@@ -14907,21 +14945,6 @@
},
/turf/open/space/basic,
/area/solar/port/fore)
-"eEl" = (
-/obj/effect/decal/cleanable/blood/old,
-/obj/structure/sign/poster/official/moth1{
- pixel_y = 32
- },
-/obj/structure/sign/poster/official/moth3{
- pixel_x = -32
- },
-/obj/machinery/conveyor{
- dir = 5;
- id = "HB"
- },
-/mob/living/simple_animal/mothroach,
-/turf/open/floor/plating,
-/area/security/prison)
"eED" = (
/obj/structure/bodycontainer/morgue,
/obj/machinery/camera/autoname{
@@ -15584,33 +15607,6 @@
},
/turf/open/floor/plasteel,
/area/science/shuttledock)
-"eOo" = (
-/obj/structure/table/reinforced,
-/obj/item/security_barricade{
- pixel_x = 8;
- pixel_y = 12
- },
-/obj/item/security_barricade{
- pixel_x = 8;
- pixel_y = 7
- },
-/obj/item/security_barricade{
- pixel_x = 8;
- pixel_y = 2
- },
-/obj/item/storage/box/trackimp{
- pixel_x = -6;
- pixel_y = 9
- },
-/obj/item/security_barricade{
- pixel_y = 10
- },
-/obj/item/security_barricade{
- pixel_y = 5
- },
-/obj/item/storage/lockbox/loyalty,
-/turf/open/floor/plasteel,
-/area/ai_monitored/security/armory)
"eOD" = (
/obj/machinery/biogenerator,
/turf/open/floor/grass,
@@ -16199,6 +16195,16 @@
},
/turf/open/floor/plasteel/white,
/area/medical/chemistry)
+"eWg" = (
+/mob/living/basic/cockroach,
+/obj/effect/decal/cleanable/dirt/dust,
+/obj/effect/turf_decal/tile/neutral/half/contrasted{
+ dir = 1
+ },
+/obj/structure/rack,
+/obj/effect/spawner/lootdrop/maintenance/eight,
+/turf/open/floor/plasteel,
+/area/maintenance/department/science)
"eWn" = (
/obj/structure/disposalpipe/sorting/mail/flip{
dir = 1;
@@ -18265,11 +18271,6 @@
/obj/effect/turf_decal/bot,
/turf/open/floor/plasteel,
/area/medical/genetics/cloning)
-"fzD" = (
-/obj/effect/decal/cleanable/dirt/dust,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/wood,
-/area/vacant_room/office)
"fzS" = (
/turf/closed/wall/r_wall/rust,
/area/teleporter)
@@ -18850,6 +18851,10 @@
"fKo" = (
/turf/open/floor/plasteel,
/area/science/mixing)
+"fKp" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/carpet/royalblack,
+/area/maintenance/port/aft)
"fKs" = (
/obj/machinery/door/airlock/grunge{
id_tag = "Cabin_1";
@@ -19318,6 +19323,14 @@
"fRc" = (
/turf/open/floor/plating,
/area/maintenance/port/central)
+"fRl" = (
+/obj/effect/turf_decal/bot,
+/obj/effect/mapping_helpers/dead_body_placer/medbay_morgue,
+/obj/structure/cable/yellow{
+ icon_state = "1-2"
+ },
+/turf/open/floor/plasteel/dark,
+/area/medical/morgue)
"fRu" = (
/obj/machinery/shieldgen,
/turf/open/floor/plasteel/tech/grid,
@@ -19603,11 +19616,6 @@
/obj/effect/spawner/room/fivexfour,
/turf/open/floor/plating,
/area/maintenance/central)
-"fVO" = (
-/obj/effect/decal/cleanable/dirt,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plasteel,
-/area/maintenance/department/science)
"fVQ" = (
/obj/effect/turf_decal/tile/neutral/half/contrasted{
dir = 8
@@ -19700,25 +19708,6 @@
"fXJ" = (
/turf/closed/wall/r_wall/rust,
/area/engine/engine_room)
-"fXR" = (
-/obj/machinery/holopad,
-/obj/machinery/atmospherics/pipe/manifold/scrubbers/hidden/layer4{
- dir = 4
- },
-/obj/machinery/atmospherics/pipe/manifold/supply/hidden/layer2{
- dir = 1
- },
-/mob/living/simple_animal/mothroach{
- density = 0;
- desc = "A festive mothroach";
- name = "Erster"
- },
-/obj/effect/turf_decal/box,
-/obj/structure/cable/yellow{
- icon_state = "2-8"
- },
-/turf/open/floor/plasteel/dark,
-/area/science/robotics)
"fYm" = (
/obj/effect/decal/cleanable/dirt/dust,
/obj/effect/turf_decal/guideline/guideline_edge/purple{
@@ -20256,11 +20245,6 @@
},
/turf/closed/wall/r_wall,
/area/engine/atmos)
-"gew" = (
-/obj/structure/flora/ausbushes/fullgrass,
-/mob/living/simple_animal/mothroach,
-/turf/open/floor/grass,
-/area/hallway/primary/central)
"geH" = (
/obj/effect/turf_decal/bot,
/obj/machinery/firealarm/directional/west,
@@ -20865,14 +20849,6 @@
},
/turf/open/floor/plasteel/dark,
/area/quartermaster/miningdock)
-"gnr" = (
-/obj/effect/turf_decal/bot,
-/obj/effect/mapping_helpers/dead_body_placer/medbay_morgue,
-/obj/structure/cable/yellow{
- icon_state = "1-2"
- },
-/turf/open/floor/plasteel/dark,
-/area/medical/morgue)
"gnv" = (
/obj/machinery/atmospherics/components/unary/vent_scrubber/on/layer4{
dir = 8
@@ -21346,20 +21322,6 @@
},
/turf/open/floor/plasteel,
/area/engine/engineering)
-"gvc" = (
-/obj/structure/lattice/catwalk/over,
-/obj/structure/cable/yellow{
- icon_state = "1-2"
- },
-/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
- dir = 1
- },
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
- dir = 1
- },
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/central)
"gvz" = (
/obj/effect/turf_decal/tile/neutral{
dir = 4
@@ -24297,6 +24259,18 @@
/obj/effect/turf_decal/delivery,
/turf/open/floor/plasteel/dark,
/area/engine/atmos)
+"hrp" = (
+/mob/living/basic/mothroach,
+/obj/effect/decal/remains/human,
+/obj/item/flashlight/lantern/heirloom_moth{
+ on = 1
+ },
+/obj/machinery/conveyor{
+ dir = 1;
+ id = "HB"
+ },
+/turf/open/floor/plating,
+/area/security/prison)
"hrt" = (
/obj/item/radio/intercom{
pixel_y = 24
@@ -25226,10 +25200,6 @@
},
/turf/open/floor/plasteel/dark,
/area/medical/medbay/central)
-"hEO" = (
-/obj/item/rollerbed,
-/turf/open/floor/plating,
-/area/maintenance/starboard/aft)
"hES" = (
/obj/machinery/airalarm/unlocked{
pixel_y = 22
@@ -27373,6 +27343,19 @@
/obj/item/storage/box/evidence,
/turf/open/floor/plasteel,
/area/security/brig)
+"iqZ" = (
+/mob/living/basic/cockroach,
+/obj/structure/cable/yellow{
+ icon_state = "1-2"
+ },
+/obj/structure/disposalpipe/segment{
+ dir = 1
+ },
+/obj/structure/lattice/catwalk/over,
+/turf/open/floor/plating{
+ icon_state = "platingdmg3"
+ },
+/area/maintenance/department/engine)
"ira" = (
/obj/effect/turf_decal/stripes/line{
dir = 6
@@ -28181,6 +28164,20 @@
},
/turf/open/floor/plating,
/area/medical/virology)
+"iHr" = (
+/obj/effect/turf_decal/tile/purple{
+ dir = 4
+ },
+/mob/living/basic/cockroach,
+/obj/machinery/disposal/deliveryChute{
+ dir = 1
+ },
+/obj/effect/turf_decal/bot,
+/obj/structure/disposalpipe/trunk{
+ dir = 4
+ },
+/turf/open/floor/plasteel,
+/area/maintenance/department/science)
"iHF" = (
/obj/effect/turf_decal/siding/wideplating/dark{
dir = 10
@@ -29221,6 +29218,10 @@
},
/turf/open/floor/plasteel,
/area/crew_quarters/dorms)
+"jap" = (
+/mob/living/basic/cockroach,
+/turf/open/floor/wood,
+/area/vacant_room/office)
"jaC" = (
/obj/structure/chair/office/light{
dir = 1
@@ -29427,21 +29428,6 @@
dir = 8
},
/area/hallway/secondary/exit/departure_lounge)
-"jdx" = (
-/obj/effect/decal/cleanable/blood/old,
-/obj/item/flashlight/lantern/heirloom_moth{
- on = 1
- },
-/obj/structure/sign/poster/official/moth9{
- pixel_x = -32
- },
-/obj/machinery/conveyor{
- dir = 1;
- id = "HB"
- },
-/mob/living/simple_animal/mothroach,
-/turf/open/floor/plating,
-/area/security/prison)
"jdy" = (
/obj/structure/sink{
dir = 8;
@@ -30832,6 +30818,14 @@
/obj/effect/decal/cleanable/dirt,
/turf/open/floor/plasteel,
/area/engine/atmos)
+"jAx" = (
+/obj/item/ammo_casing/c46x30mm,
+/obj/item/ammo_casing/c46x30mm,
+/obj/item/ammo_casing/c46x30mm,
+/obj/item/ammo_casing/c46x30mm,
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/department/security)
"jAD" = (
/obj/structure/railing{
dir = 4
@@ -31002,10 +30996,6 @@
},
/turf/open/floor/plating,
/area/crew_quarters/kitchen)
-"jDC" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/starboard/aft)
"jDF" = (
/obj/machinery/door/poddoor/preopen{
id = "bridgewindows";
@@ -31099,6 +31089,25 @@
/obj/effect/landmark/blobstart,
/turf/open/floor/plating/airless,
/area/science/test_area)
+"jFg" = (
+/obj/effect/decal/cleanable/dirt,
+/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
+ dir = 10
+ },
+/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
+ dir = 10
+ },
+/obj/effect/decal/cleanable/dirt,
+/mob/living/basic/cockroach,
+/obj/structure/cable/yellow{
+ icon_state = "2-8"
+ },
+/obj/structure/cable/yellow{
+ icon_state = "2-4"
+ },
+/obj/structure/lattice/catwalk/over,
+/turf/open/floor/plating,
+/area/maintenance/port/aft)
"jFh" = (
/obj/effect/turf_decal/tile/dark_green/half/contrasted{
dir = 8
@@ -31802,6 +31811,18 @@
/obj/item/wrench,
/turf/open/space/basic,
/area/space/nearstation)
+"jPX" = (
+/mob/living/basic/mothroach,
+/obj/effect/decal/cleanable/blood/old,
+/obj/item/flashlight/lantern/heirloom_moth{
+ on = 1
+ },
+/obj/machinery/conveyor{
+ id = "HB"
+ },
+/obj/effect/decal/remains/human,
+/turf/open/floor/plating,
+/area/security/prison)
"jPZ" = (
/obj/effect/landmark/xeno_spawn,
/turf/open/floor/carpet/royalblack,
@@ -34464,10 +34485,6 @@
},
/turf/open/floor/plasteel,
/area/hallway/primary/port)
-"kIV" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/carpet/royalblack,
-/area/maintenance/port/aft)
"kIX" = (
/obj/effect/turf_decal/tile/purple/half/contrasted{
dir = 8
@@ -38975,6 +38992,17 @@
},
/turf/open/floor/plasteel/tech,
/area/engine/engine_room)
+"mhz" = (
+/mob/living/basic/mothroach,
+/obj/effect/decal/cleanable/blood/old,
+/obj/item/flashlight/lantern/heirloom_moth{
+ on = 1
+ },
+/obj/machinery/conveyor{
+ id = "HB"
+ },
+/turf/open/floor/plating,
+/area/security/prison)
"mhA" = (
/obj/structure/lattice,
/obj/structure/railing,
@@ -39779,6 +39807,11 @@
/obj/machinery/firealarm/directional/south,
/turf/open/floor/plasteel,
/area/hallway/primary/port)
+"muZ" = (
+/obj/effect/spawner/lootdrop/glowstick/lit,
+/mob/living/basic/cockroach,
+/turf/open/floor/plating,
+/area/maintenance/starboard/aft)
"mvj" = (
/obj/machinery/door/airlock/maintenance{
name = "Genetics Maintenance";
@@ -40014,14 +40047,6 @@
},
/turf/open/floor/engine,
/area/science/xenobiology)
-"myC" = (
-/obj/item/ammo_casing/c46x30mm,
-/obj/item/ammo_casing/c46x30mm,
-/obj/item/ammo_casing/c46x30mm,
-/obj/item/ammo_casing/c46x30mm,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/department/security)
"myN" = (
/obj/machinery/disposal/bin,
/obj/machinery/power/apc/auto_name/north{
@@ -40959,17 +40984,6 @@
dir = 8
},
/area/hallway/secondary/exit/departure_lounge)
-"mJu" = (
-/obj/structure/sign/poster/official/moth5{
- pixel_x = 32
- },
-/obj/machinery/conveyor{
- dir = 10;
- id = "HB"
- },
-/mob/living/simple_animal/mothroach,
-/turf/open/floor/plating,
-/area/security/prison)
"mJx" = (
/obj/effect/turf_decal/stripes/line{
dir = 4
@@ -42538,6 +42552,10 @@
},
/turf/open/floor/plasteel,
/area/hallway/primary/central)
+"niE" = (
+/obj/effect/decal/cleanable/insectguts,
+/turf/open/floor/plating,
+/area/maintenance/department/science)
"niG" = (
/obj/structure/cable/yellow{
icon_state = "1-2"
@@ -42873,6 +42891,17 @@
},
/turf/open/floor/plasteel,
/area/medical/medbay/lobby)
+"nnt" = (
+/obj/effect/turf_decal/bot,
+/obj/effect/mapping_helpers/dead_body_placer/medbay_morgue,
+/obj/machinery/power/apc/auto_name/north{
+ pixel_y = 24
+ },
+/obj/structure/cable/yellow{
+ icon_state = "0-2"
+ },
+/turf/open/floor/plasteel/dark,
+/area/medical/morgue)
"nnB" = (
/turf/closed/wall,
/area/science/robotics)
@@ -44075,12 +44104,6 @@
},
/turf/closed/wall/r_wall,
/area/engine/supermatter)
-"nFB" = (
-/obj/effect/turf_decal/tile/yellow/fourcorners/contrasted,
-/obj/effect/decal/cleanable/dirt,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plasteel,
-/area/maintenance/department/engine)
"nFD" = (
/obj/effect/spawner/structure/window/reinforced,
/obj/structure/cable/yellow{
@@ -46072,23 +46095,6 @@
},
/turf/open/space/basic,
/area/solar/starboard/aft)
-"onr" = (
-/obj/effect/turf_decal/guideline/guideline_out_arrow/brown{
- dir = 1
- },
-/obj/structure/cable/yellow{
- icon_state = "4-8"
- },
-/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
- dir = 4
- },
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
- dir = 4
- },
-/obj/structure/lattice/catwalk/over,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/hallway/secondary/service)
"onv" = (
/obj/structure/window/reinforced{
dir = 8;
@@ -49067,10 +49073,6 @@
/obj/effect/decal/cleanable/dirt/dust,
/turf/open/floor/plasteel/dark,
/area/science/misc_lab/range)
-"pmr" = (
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/wood,
-/area/vacant_room/office)
"pmu" = (
/obj/machinery/button/door{
id = "commissarydoor1";
@@ -49538,11 +49540,6 @@
},
/turf/open/floor/plasteel/tech,
/area/engine/atmos)
-"psU" = (
-/obj/effect/decal/cleanable/blood/gibs/old,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plasteel/cafeteria,
-/area/maintenance/port/aft)
"psX" = (
/obj/machinery/atmospherics/components/unary/vent_pump/on/layer2{
dir = 1
@@ -50204,6 +50201,33 @@
},
/turf/open/floor/plating,
/area/crew_quarters/heads/chief)
+"pEP" = (
+/obj/structure/table/reinforced,
+/obj/item/security_barricade{
+ pixel_x = 8;
+ pixel_y = 12
+ },
+/obj/item/security_barricade{
+ pixel_x = 8;
+ pixel_y = 7
+ },
+/obj/item/security_barricade{
+ pixel_x = 8;
+ pixel_y = 2
+ },
+/obj/item/storage/box/trackimp{
+ pixel_x = -6;
+ pixel_y = 9
+ },
+/obj/item/security_barricade{
+ pixel_y = 10
+ },
+/obj/item/security_barricade{
+ pixel_y = 5
+ },
+/obj/item/storage/lockbox/loyalty,
+/turf/open/floor/plasteel,
+/area/ai_monitored/security/armory)
"pET" = (
/obj/structure/table/wood,
/obj/item/reagent_containers/syringe{
@@ -52282,25 +52306,6 @@
},
/turf/open/floor/plasteel/white,
/area/science/xenobiology)
-"qkG" = (
-/obj/effect/decal/cleanable/dirt,
-/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4{
- dir = 10
- },
-/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2{
- dir = 10
- },
-/obj/effect/decal/cleanable/dirt,
-/obj/structure/lattice/catwalk/over,
-/mob/living/simple_animal/cockroach,
-/obj/structure/cable/yellow{
- icon_state = "2-8"
- },
-/obj/structure/cable/yellow{
- icon_state = "2-4"
- },
-/turf/open/floor/plating,
-/area/maintenance/port/aft)
"qkH" = (
/obj/structure/cable/yellow{
icon_state = "1-2"
@@ -53301,18 +53306,6 @@
},
/turf/open/floor/carpet/royalblack,
/area/lawoffice)
-"qBe" = (
-/obj/effect/decal/cleanable/blood/old,
-/obj/effect/decal/remains/human,
-/obj/item/flashlight/lantern/heirloom_moth{
- on = 1
- },
-/obj/machinery/conveyor{
- id = "HB"
- },
-/mob/living/simple_animal/mothroach,
-/turf/open/floor/plating,
-/area/security/prison)
"qBp" = (
/obj/structure/table/reinforced,
/obj/effect/turf_decal/tile/yellow/fourcorners/contrasted{
@@ -54537,19 +54530,6 @@
/obj/effect/turf_decal/siding/wideplating/dark,
/turf/open/floor/plasteel/cafeteria,
/area/crew_quarters/kitchen)
-"qVp" = (
-/obj/structure/cable/yellow{
- icon_state = "1-2"
- },
-/obj/structure/disposalpipe/segment{
- dir = 1
- },
-/mob/living/simple_animal/cockroach,
-/obj/structure/lattice/catwalk/over,
-/turf/open/floor/plating{
- icon_state = "platingdmg3"
- },
-/area/maintenance/department/engine)
"qVB" = (
/obj/structure/closet/firecloset/full,
/turf/open/floor/plating,
@@ -55035,19 +55015,6 @@
/area/security/main{
name = "Security Viewing Hall"
})
-"rcN" = (
-/obj/effect/turf_decal/tile/purple{
- dir = 4
- },
-/obj/machinery/disposal/deliveryChute{
- dir = 1
- },
-/obj/effect/turf_decal/bot,
-/obj/structure/disposalpipe/trunk{
- dir = 4
- },
-/turf/open/floor/plasteel,
-/area/maintenance/department/science)
"rcU" = (
/obj/effect/decal/cleanable/dirt,
/obj/item/radio/intercom{
@@ -55902,11 +55869,6 @@
icon_state = "wood-broken7"
},
/area/vacant_room/office)
-"rso" = (
-/obj/effect/turf_decal/bot,
-/obj/effect/mapping_helpers/dead_body_placer/medbay_morgue,
-/turf/open/floor/plasteel/dark,
-/area/medical/morgue)
"rsT" = (
/obj/structure/lattice,
/obj/structure/railing{
@@ -56763,17 +56725,6 @@
/obj/effect/turf_decal/bot,
/turf/open/floor/plasteel,
/area/engine/storage)
-"rHU" = (
-/obj/effect/decal/cleanable/blood/old,
-/obj/item/flashlight/lantern/heirloom_moth{
- on = 1
- },
-/obj/machinery/conveyor{
- id = "HB"
- },
-/mob/living/simple_animal/mothroach,
-/turf/open/floor/plating,
-/area/security/prison)
"rIi" = (
/obj/structure/disposalpipe/segment{
dir = 4
@@ -57805,17 +57756,6 @@
},
/turf/open/floor/plasteel,
/area/hallway/primary/aft)
-"sbX" = (
-/obj/effect/turf_decal/bot,
-/obj/effect/mapping_helpers/dead_body_placer/medbay_morgue,
-/obj/machinery/power/apc/auto_name/north{
- pixel_y = 24
- },
-/obj/structure/cable/yellow{
- icon_state = "0-2"
- },
-/turf/open/floor/plasteel/dark,
-/area/medical/morgue)
"scb" = (
/turf/closed/wall/r_wall,
/area/storage/tech)
@@ -58578,6 +58518,21 @@
/obj/structure/flora/rock,
/turf/open/floor/grass,
/area/hallway/primary/central)
+"spI" = (
+/mob/living/basic/mothroach,
+/obj/item/flashlight/lantern/heirloom_moth{
+ on = 1
+ },
+/obj/structure/sign/poster/official/moth9{
+ pixel_x = -32
+ },
+/obj/machinery/conveyor{
+ dir = 1;
+ id = "HB"
+ },
+/obj/effect/decal/cleanable/blood/old,
+/turf/open/floor/plating,
+/area/security/prison)
"sqG" = (
/obj/structure/weightmachine/stacklifter,
/obj/effect/turf_decal/tile/neutral/half/contrasted{
@@ -60280,11 +60235,6 @@
},
/turf/open/floor/plasteel,
/area/hallway/secondary/entry)
-"sSI" = (
-/obj/effect/spawner/lootdrop/glowstick/lit,
-/mob/living/simple_animal/cockroach,
-/turf/open/floor/plating,
-/area/maintenance/starboard/aft)
"sSU" = (
/obj/structure/closet/crate,
/obj/effect/spawner/lootdrop/maintenance/two,
@@ -60613,18 +60563,6 @@
/obj/effect/turf_decal/box,
/turf/open/floor/plasteel,
/area/medical/cryo)
-"sYX" = (
-/obj/effect/decal/remains/human,
-/obj/item/flashlight/lantern/heirloom_moth{
- on = 1
- },
-/obj/machinery/conveyor{
- dir = 1;
- id = "HB"
- },
-/mob/living/simple_animal/mothroach,
-/turf/open/floor/plating,
-/area/security/prison)
"sYY" = (
/obj/effect/landmark/carpspawn,
/turf/open/space/basic,
@@ -61679,6 +61617,10 @@
},
/turf/open/floor/carpet/purple,
/area/crew_quarters/heads/hor)
+"tnB" = (
+/obj/effect/decal/cleanable/dirt,
+/turf/open/floor/plasteel,
+/area/maintenance/department/science)
"tnC" = (
/obj/effect/turf_decal/guideline/guideline_in/red{
dir = 4
@@ -63691,6 +63633,17 @@
},
/turf/open/floor/engine,
/area/science/xenobiology)
+"tUj" = (
+/mob/living/basic/mothroach,
+/obj/structure/sign/poster/official/moth5{
+ pixel_x = 32
+ },
+/obj/machinery/conveyor{
+ dir = 10;
+ id = "HB"
+ },
+/turf/open/floor/plating,
+/area/security/prison)
"tUl" = (
/turf/open/floor/plasteel/sepia,
/area/quartermaster/warehouse)
@@ -63875,6 +63828,20 @@
},
/turf/open/floor/wood,
/area/library)
+"tXN" = (
+/mob/living/basic/mothroach,
+/obj/structure/sign/poster/official/moth2{
+ pixel_y = 32
+ },
+/obj/structure/sign/poster/official/moth4{
+ pixel_x = 32
+ },
+/obj/machinery/conveyor{
+ dir = 6;
+ id = "HB"
+ },
+/turf/open/floor/plating,
+/area/security/prison)
"tYb" = (
/obj/effect/landmark/blobstart,
/turf/open/floor/plating,
@@ -64981,6 +64948,10 @@
},
/turf/open/floor/plating,
/area/security/courtroom)
+"uog" = (
+/obj/item/rollerbed,
+/turf/open/floor/plating,
+/area/maintenance/starboard/aft)
"uoh" = (
/obj/structure/curtain,
/turf/open/floor/noslip/standard,
@@ -68290,6 +68261,21 @@
},
/turf/open/floor/plasteel/white,
/area/crew_quarters/kitchen)
+"vpq" = (
+/mob/living/basic/mothroach,
+/obj/structure/sign/poster/official/moth1{
+ pixel_y = 32
+ },
+/obj/structure/sign/poster/official/moth3{
+ pixel_x = -32
+ },
+/obj/machinery/conveyor{
+ dir = 5;
+ id = "HB"
+ },
+/obj/effect/decal/cleanable/blood/old,
+/turf/open/floor/plating,
+/area/security/prison)
"vpz" = (
/obj/machinery/camera{
c_tag = "Xenobiology Lab - Pen #3";
@@ -68315,6 +68301,11 @@
},
/turf/open/floor/circuit,
/area/ai_monitored/storage/satellite)
+"vqu" = (
+/mob/living/basic/cockroach,
+/obj/effect/decal/cleanable/dirt/dust,
+/turf/open/floor/wood,
+/area/vacant_room/office)
"vqC" = (
/obj/effect/turf_decal/tile/dark_blue/fourcorners/contrasted{
alpha = 180
@@ -68919,6 +68910,15 @@
/obj/effect/spawner/lootdrop/maintenance/two,
/turf/open/floor/plating,
/area/maintenance/department/security)
+"vCx" = (
+/obj/effect/turf_decal/delivery,
+/obj/effect/turf_decal/tile/neutral/half/contrasted{
+ dir = 1
+ },
+/obj/effect/decal/cleanable/dirt,
+/obj/machinery/atmospherics/components/trinary/mixer/airmix/flipped/inverse,
+/turf/open/floor/plasteel,
+/area/engine/atmos)
"vCB" = (
/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4,
/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer2,
@@ -73789,11 +73789,6 @@
},
/turf/open/floor/plasteel/grid/steel,
/area/medical/virology)
-"xfE" = (
-/mob/living/simple_animal/cockroach,
-/obj/effect/decal/cleanable/insectguts,
-/turf/open/floor/plating,
-/area/maintenance/department/science)
"xfN" = (
/obj/effect/turf_decal/tile/yellow{
dir = 8
@@ -74285,6 +74280,11 @@
},
/turf/open/floor/plasteel,
/area/hallway/primary/starboard)
+"xnK" = (
+/obj/effect/turf_decal/bot,
+/obj/effect/mapping_helpers/dead_body_placer/medbay_morgue,
+/turf/open/floor/plasteel/dark,
+/area/medical/morgue)
"xnN" = (
/obj/structure/lattice/catwalk,
/obj/structure/cable{
@@ -98440,7 +98440,7 @@ cxk
cxk
cxk
vJE
-fVO
+tnB
dDa
rBF
cMW
@@ -99211,7 +99211,7 @@ cxk
cxk
cxk
xnQ
-dHb
+eWg
hle
uZf
cMW
@@ -99733,7 +99733,7 @@ qce
cCS
xzi
eRd
-rcN
+iHr
tIR
cCS
cCS
@@ -99939,10 +99939,10 @@ kRU
qdN
bPe
woY
-eEl
-jdx
-sYX
-bsS
+vpq
+spI
+hrp
+ely
tXw
dlI
oZB
@@ -99986,7 +99986,7 @@ uer
cCS
sBR
dkh
-xfE
+niE
cCS
jMi
hsr
@@ -100196,10 +100196,10 @@ dUK
tpT
woW
woY
-cEj
-qBe
-rHU
-mJu
+tXN
+jPX
+mhz
+tUj
tXw
tyK
nAB
@@ -102073,7 +102073,7 @@ qZZ
wyu
vHW
qaH
-kIV
+fKp
jPZ
ycb
xbP
@@ -103277,7 +103277,7 @@ vHl
nKF
fHK
qyI
-myC
+jAx
xoe
pSN
kVe
@@ -103619,7 +103619,7 @@ aEY
lXr
wfM
eCS
-psU
+cEF
qZZ
qZZ
wqs
@@ -104091,7 +104091,7 @@ cFQ
clo
vhr
xGG
-fXR
+bRf
pzH
rde
eyH
@@ -104369,7 +104369,7 @@ bek
fAl
rkH
oDO
-qkG
+jFg
lOO
irK
can
@@ -105058,7 +105058,7 @@ gsA
uYx
tqK
hsz
-eOo
+pEP
uYx
ovo
ovo
@@ -105871,7 +105871,7 @@ aGC
vEI
ijJ
cbJ
-pmr
+jap
oKM
pis
sNq
@@ -106901,7 +106901,7 @@ gRs
deu
rsi
gTU
-fzD
+vqu
gTU
hfC
hOZ
@@ -107205,7 +107205,7 @@ wkj
lWC
iEd
yht
-nFB
+cdH
slN
jcW
otr
@@ -108741,7 +108741,7 @@ ngO
msF
wFI
wzQ
-qVp
+iqZ
hwg
xyQ
cKp
@@ -111517,7 +111517,7 @@ gCb
qsq
smT
tib
-gew
+dWQ
wlS
gGU
jFh
@@ -113315,7 +113315,7 @@ nFn
nFn
dnb
nFn
-gvc
+bib
eQz
aue
srO
@@ -113587,7 +113587,7 @@ dFC
xgu
eGd
guk
-rso
+xnK
nOM
jkr
maA
@@ -114065,7 +114065,7 @@ vtI
vtI
iAG
cuo
-onr
+dIZ
dsp
iMw
mVN
@@ -114357,8 +114357,8 @@ dFC
dFC
dFC
eGd
-sbX
-gnr
+nnt
+fRl
uff
gKg
wFR
@@ -114873,7 +114873,7 @@ boh
eGd
mcN
nOM
-rso
+xnK
eTl
maA
gdx
@@ -115693,7 +115693,7 @@ xac
nGy
dhP
wSy
-aUl
+vCx
uIy
kiZ
sOJ
@@ -115927,7 +115927,7 @@ wdZ
bWm
kII
rAi
-hEO
+uog
xWd
iRY
wAP
@@ -116183,7 +116183,7 @@ bWm
bWm
bWm
ciA
-sSI
+muZ
bWl
xWd
iRY
@@ -118500,7 +118500,7 @@ shZ
dHW
cMi
dHW
-jDC
+cXE
gLb
xtQ
xtQ
@@ -120298,7 +120298,7 @@ bSm
tfq
dHW
dHW
-jDC
+cXE
dHW
dHW
gLb
diff --git a/beestation.dme b/beestation.dme
index 75065ee986a4a..540efb79906b9 100644
--- a/beestation.dme
+++ b/beestation.dme
@@ -43,6 +43,7 @@
#include "code\__DEFINES\atom_hud.dm"
#include "code\__DEFINES\balloon_alert.dm"
#include "code\__DEFINES\bans.dm"
+#include "code\__DEFINES\basic_mobs.dm"
#include "code\__DEFINES\bitfields.dm"
#include "code\__DEFINES\blood.dm"
#include "code\__DEFINES\bodyparts.dm"
@@ -545,9 +546,22 @@
#include "code\datums\ai\_item_behaviors.dm"
#include "code\datums\ai\generic_actions.dm"
#include "code\datums\ai\telegraph_effects.dm"
+#include "code\datums\ai\basic_mobs\base_basic_controller.dm"
+#include "code\datums\ai\basic_mobs\basic_ai_behaviors\basic_attacking.dm"
+#include "code\datums\ai\basic_mobs\basic_ai_behaviors\targetting.dm"
+#include "code\datums\ai\basic_mobs\basic_subtrees\simple_attack_target.dm"
+#include "code\datums\ai\basic_mobs\basic_subtrees\simple_find_target.dm"
+#include "code\datums\ai\basic_mobs\basic_subtrees\speech_subtree.dm"
+#include "code\datums\ai\basic_mobs\targetting_datums\basic_targetting_datum.dm"
#include "code\datums\ai\dog\dog_behaviors.dm"
#include "code\datums\ai\dog\dog_controller.dm"
#include "code\datums\ai\dog\dog_subtrees.dm"
+#include "code\datums\ai\hunting_behavior\hunting_behaviors.dm"
+#include "code\datums\ai\hunting_behavior\hunting_vermin.dm"
+#include "code\datums\ai\idle_behaviors\_idle_behavior.dm"
+#include "code\datums\ai\idle_behaviors\idle_dog.dm"
+#include "code\datums\ai\idle_behaviors\idle_monkey.dm"
+#include "code\datums\ai\idle_behaviors\idle_random_walk.dm"
#include "code\datums\ai\monkey\monkey_behaviors.dm"
#include "code\datums\ai\monkey\monkey_controller.dm"
#include "code\datums\ai\monkey\monkey_subtrees.dm"
@@ -647,6 +661,7 @@
#include "code\datums\components\spill.dm"
#include "code\datums\components\spinny.dm"
#include "code\datums\components\spooky.dm"
+#include "code\datums\components\squashable.dm"
#include "code\datums\components\squeak.dm"
#include "code\datums\components\stationloving.dm"
#include "code\datums\components\swarming.dm"
@@ -754,11 +769,14 @@
#include "code\datums\diseases\advance\symptoms\wizarditis.dm"
#include "code\datums\diseases\advance\symptoms\youth.dm"
#include "code\datums\elements\_element.dm"
+#include "code\datums\elements\atmos_requirements.dm"
+#include "code\datums\elements\basic_body_temp_sensitive.dm"
#include "code\datums\elements\bed_tucking.dm"
#include "code\datums\elements\bsa_blocker.dm"
#include "code\datums\elements\cleaning.dm"
#include "code\datums\elements\climbable.dm"
#include "code\datums\elements\connect_loc.dm"
+#include "code\datums\elements\death_drops.dm"
#include "code\datums\elements\decal.dm"
#include "code\datums\elements\deferred_aquarium_content.dm"
#include "code\datums\elements\digital_camo.dm"
@@ -772,7 +790,9 @@
#include "code\datums\elements\mechanical_repair.dm"
#include "code\datums\elements\mirage_border.dm"
#include "code\datums\elements\openspace_item_click_handler.dm"
+#include "code\datums\elements\pet_bonus.dm"
#include "code\datums\elements\point_of_interest.dm"
+#include "code\datums\elements\ranged_attacks.dm"
#include "code\datums\elements\rust.dm"
#include "code\datums\elements\squish.dm"
#include "code\datums\elements\strippable.dm"
@@ -915,6 +935,7 @@
#include "code\game\verbs.dm"
#include "code\game\world.dm"
#include "code\game\area\ai_monitored.dm"
+#include "code\game\area\area_color_correction.dm"
#include "code\game\area\areas.dm"
#include "code\game\area\Space_Station_13_areas.dm"
#include "code\game\area\areas\away_content.dm"
@@ -2878,6 +2899,11 @@
#include "code\modules\mob\living\status_procs.dm"
#include "code\modules\mob\living\taste.dm"
#include "code\modules\mob\living\ventcrawling.dm"
+#include "code\modules\mob\living\basic\basic.dm"
+#include "code\modules\mob\living\basic\basic_defense.dm"
+#include "code\modules\mob\living\basic\health_adjustment.dm"
+#include "code\modules\mob\living\basic\vermin\cockroach.dm"
+#include "code\modules\mob\living\basic\vermin\mothroach.dm"
#include "code\modules\mob\living\brain\brain.dm"
#include "code\modules\mob\living\brain\brain_item.dm"
#include "code\modules\mob\living\brain\death.dm"
@@ -3057,7 +3083,6 @@
#include "code\modules\mob\living\simple_animal\bot\SuperBeepsky.dm"
#include "code\modules\mob\living\simple_animal\friendly\butterfly.dm"
#include "code\modules\mob\living\simple_animal\friendly\cat.dm"
-#include "code\modules\mob\living\simple_animal\friendly\cockroach.dm"
#include "code\modules\mob\living\simple_animal\friendly\crab.dm"
#include "code\modules\mob\living\simple_animal\friendly\dog.dm"
#include "code\modules\mob\living\simple_animal\friendly\farm_animals.dm"
@@ -3065,7 +3090,6 @@
#include "code\modules\mob\living\simple_animal\friendly\gondola.dm"
#include "code\modules\mob\living\simple_animal\friendly\hamster.dm"
#include "code\modules\mob\living\simple_animal\friendly\lizard.dm"
-#include "code\modules\mob\living\simple_animal\friendly\mothroach.dm"
#include "code\modules\mob\living\simple_animal\friendly\mouse.dm"
#include "code\modules\mob\living\simple_animal\friendly\penguin.dm"
#include "code\modules\mob\living\simple_animal\friendly\pet.dm"
diff --git a/code/__DEFINES/ai.dm b/code/__DEFINES/ai.dm
index 78a12fa15ba9e..a95ff76239202 100644
--- a/code/__DEFINES/ai.dm
+++ b/code/__DEFINES/ai.dm
@@ -176,6 +176,7 @@
///Hunting BB keys
#define BB_CURRENT_HUNTING_TARGET "BB_current_hunting_target"
+#define BB_LOW_PRIORITY_HUNTING_TARGET "BB_low_priority_hunting_target"
#define BB_HUNTING_COOLDOWN "BB_HUNTING_COOLDOWN"
///Basic Mob Keys
diff --git a/code/__DEFINES/basic_mobs.dm b/code/__DEFINES/basic_mobs.dm
new file mode 100644
index 0000000000000..fcaccc092f4e9
--- /dev/null
+++ b/code/__DEFINES/basic_mobs.dm
@@ -0,0 +1,4 @@
+#define BASIC_MOB_MAX_STAMINALOSS 200
+
+///Basic mob flags
+#define DEL_ON_DEATH (1<<0)
diff --git a/code/__DEFINES/dcs/signals/signals_atom.dm b/code/__DEFINES/dcs/signals/signals_atom.dm
index 954d2394ee2a5..7e4dfd2a96b46 100644
--- a/code/__DEFINES/dcs/signals/signals_atom.dm
+++ b/code/__DEFINES/dcs/signals/signals_atom.dm
@@ -20,6 +20,9 @@
#define EXAMINE_POSITION_BEFORE (1<<1)
//End positions
#define COMPONENT_EXNAME_CHANGED (1<<0)
+//from base of atom/attack_basic_mob(): (/mob/user)
+#define COMSIG_ATOM_ATTACK_BASIC_MOB "attack_basic_mob"
+
/// from base of [/atom/proc/update_appearance]: (updates)
#define COMSIG_ATOM_UPDATE_APPEARANCE "atom_update_appearance"
/// If returned from [COMSIG_ATOM_UPDATE_APPEARANCE] it prevents the atom from updating its name.
diff --git a/code/__DEFINES/dcs/signals/signals_mob/signals_living.dm b/code/__DEFINES/dcs/signals/signals_mob/signals_living.dm
index 88bfef8c10029..a089a3995c0f7 100644
--- a/code/__DEFINES/dcs/signals/signals_mob/signals_living.dm
+++ b/code/__DEFINES/dcs/signals/signals_mob/signals_living.dm
@@ -26,6 +26,8 @@
#define SINGULARITY_TRY_MOVE_BLOCK (1 << 0)
#define COMSIG_LIVING_CAN_TRACK "mob_can_track" ///from base of /mob/living/can_track()
#define COMPONENT_CANT_TRACK 1
+/// from start of /mob/living/handle_breathing(): (delta_time, times_fired)
+#define COMSIG_LIVING_HANDLE_BREATHING "living_handle_breathing"
//ALL OF THESE DO NOT TAKE INTO ACCOUNT WHETHER AMOUNT IS 0 OR LOWER AND ARE SENT REGARDLESS!
#define COMSIG_LIVING_STATUS_STUN "living_stun" //! from base of mob/living/Stun() (amount, update, ignore)
@@ -45,3 +47,7 @@
#define STOP_WABBAJACK (1 << 0)
///From wabbajack(): (mob/living/new_mob)
#define COMSIG_LIVING_ON_WABBAJACKED "living_wabbajacked"
+
+// basic mob signals
+/// Called on /basic when updating its speed, from base of /mob/living/basic/update_basic_mob_varspeed(): ()
+#define POST_BASIC_MOB_UPDATE_VARSPEED "post_basic_mob_update_varspeed"
diff --git a/code/__DEFINES/mobs.dm b/code/__DEFINES/mobs.dm
index 63efa7e1f4533..1e650b93c7e30 100644
--- a/code/__DEFINES/mobs.dm
+++ b/code/__DEFINES/mobs.dm
@@ -402,6 +402,13 @@
///How much a mob's sprite should be moved when they're lying down
#define PIXEL_Y_OFFSET_LYING -6
+///Squash flags. For squashable element
+
+///Whether or not the squashing requires the squashed mob to be lying down
+#define SQUASHED_SHOULD_BE_DOWN (1<<0)
+///Whether or not to gib when the squashed mob is moved over
+#define SQUASHED_SHOULD_BE_GIBBED (1<<0)
+
//Body sizes
#define BODY_SIZE_NORMAL 1
#define BODY_SIZE_SHORT 0.93
diff --git a/code/__DEFINES/movespeed_modification.dm b/code/__DEFINES/movespeed_modification.dm
index 9cb4d24c0c3ab..f238f7cca71c6 100644
--- a/code/__DEFINES/movespeed_modification.dm
+++ b/code/__DEFINES/movespeed_modification.dm
@@ -50,6 +50,7 @@
#define MOVESPEED_ID_CHANGELING_MUSCLES "CHANGELING_MUSCLES"
+#define MOVESPEED_ID_BASIC_MOB_VARSPEED "BASIC_MOB_VARSPEED_MODIFIER"
#define MOVESPEED_ID_SIMPLEMOB_VARSPEED "SIMPLEMOB_VARSPEED_MODIFIER"
#define MOVESPEED_ID_ADMIN_VAREDIT "ADMIN_VAREDIT_MODIFIER"
diff --git a/code/__HELPERS/mobs.dm b/code/__HELPERS/mobs.dm
index c85749be35acb..fd7679d468711 100644
--- a/code/__HELPERS/mobs.dm
+++ b/code/__HELPERS/mobs.dm
@@ -458,14 +458,20 @@ GLOBAL_LIST_EMPTY(species_list)
mob_spawn_meancritters += T
if(FRIENDLY_SPAWN)
mob_spawn_nicecritters += T
+ for(var/mob/living/basic/basic_mob as anything in typesof(/mob/living/basic))
+ switch(initial(basic_mob.gold_core_spawnable))
+ if(HOSTILE_SPAWN)
+ mob_spawn_meancritters += basic_mob
+ if(FRIENDLY_SPAWN)
+ mob_spawn_nicecritters += basic_mob
var/chosen
if(mob_class == FRIENDLY_SPAWN)
chosen = pick(mob_spawn_nicecritters)
else
chosen = pick(mob_spawn_meancritters)
- var/mob/living/simple_animal/C = new chosen(spawn_location)
- return C
+ var/mob/living/spawned_mob = new chosen(spawn_location)
+ return spawned_mob
/proc/passtable_on(target, source)
var/mob/living/L = target
diff --git a/code/__HELPERS/type_processing.dm b/code/__HELPERS/type_processing.dm
index 336189bfb5c22..316e073c49a52 100644
--- a/code/__HELPERS/type_processing.dm
+++ b/code/__HELPERS/type_processing.dm
@@ -26,6 +26,7 @@
/turf/open = "OPEN",
/turf/closed = "CLOSED",
/turf = "T",
+ /mob/living/basic = "BASIC_MOB",
/mob/living/carbon = "CARBON",
/mob/living/simple_animal = "SIMPLE",
/mob/living = "LIVING",
diff --git a/code/_onclick/hud/fullscreen.dm b/code/_onclick/hud/fullscreen.dm
index 25206412b9259..e3baea6c262da 100644
--- a/code/_onclick/hud/fullscreen.dm
+++ b/code/_onclick/hud/fullscreen.dm
@@ -110,6 +110,11 @@
layer = BLIND_LAYER
plane = FULLSCREEN_PLANE
+/atom/movable/screen/fullscreen/law_change
+ icon_state = "law_change"
+ layer = BLIND_LAYER
+ plane = FULLSCREEN_PLANE
+
/atom/movable/screen/fullscreen/curse
icon_state = "curse"
layer = CURSE_LAYER
diff --git a/code/_onclick/item_attack.dm b/code/_onclick/item_attack.dm
index a9fddf5ee1688..b550262dce4fe 100644
--- a/code/_onclick/item_attack.dm
+++ b/code/_onclick/item_attack.dm
@@ -141,6 +141,12 @@
else
return ..()
+/mob/living/basic/attacked_by(obj/item/I, mob/living/user)
+ if(!attack_threshold_check(I.force, I.damtype, MELEE, FALSE))
+ playsound(loc, 'sound/weapons/tap.ogg', I.get_clamped_volume(), TRUE, -1)
+ else
+ return ..()
+
// Proximity_flag is 1 if this afterattack was called on something adjacent, in your square, or on your person.
// Click parameters is the params string from byond Click() code, see that documentation.
/obj/item/proc/afterattack(atom/target, mob/user, proximity_flag, click_parameters)
diff --git a/code/_onclick/other_mobs.dm b/code/_onclick/other_mobs.dm
index 94fa29b272016..e2a4f96ce9e32 100644
--- a/code/_onclick/other_mobs.dm
+++ b/code/_onclick/other_mobs.dm
@@ -114,6 +114,10 @@
SEND_SIGNAL(src, COMSIG_ATOM_ATTACK_ANIMAL, user)
return
+/atom/proc/attack_basic_mob(mob/user)
+ SEND_SIGNAL(src, COMSIG_ATOM_ATTACK_BASIC_MOB, user)
+ return
+
/mob/living/RestrainedClickOn(atom/A)
return
diff --git a/code/_onclick/telekinesis.dm b/code/_onclick/telekinesis.dm
index 74c4615131858..21b0530a24d2d 100644
--- a/code/_onclick/telekinesis.dm
+++ b/code/_onclick/telekinesis.dm
@@ -79,8 +79,9 @@
START_PROCESSING(SSfastprocess, src)
/obj/item/tk_grab/Destroy()
- focus = null
STOP_PROCESSING(SSfastprocess, src)
+ focus = null
+ tk_user = null
return ..()
/obj/item/tk_grab/process()
@@ -95,10 +96,10 @@
//stops TK grabs being equipped anywhere but into hands
/obj/item/tk_grab/equipped(mob/user, slot)
+ . = ..()
if(slot == ITEM_SLOT_HANDS)
return
qdel(src)
- return
/obj/item/tk_grab/examine(user)
if (focus)
diff --git a/code/controllers/globals.dm b/code/controllers/globals.dm
index 7902588aa640d..d36861f6bdcf2 100644
--- a/code/controllers/globals.dm
+++ b/code/controllers/globals.dm
@@ -22,7 +22,7 @@ GLOBAL_REAL(GLOB, /datum/controller/global_vars)
/datum/controller/global_vars/Destroy(force)
// This is done to prevent an exploit where admins can get around protected vars
- SHOULD_CALL_PARENT(0)
+ SHOULD_CALL_PARENT(FALSE)
return QDEL_HINT_IWILLGC
/datum/controller/global_vars/stat_entry()
diff --git a/code/datums/ai/_ai_controller.dm b/code/datums/ai/_ai_controller.dm
index 00d0937bf7aa4..f7abdcdc659c6 100644
--- a/code/datums/ai/_ai_controller.dm
+++ b/code/datums/ai/_ai_controller.dm
@@ -32,6 +32,9 @@ multiple modular subtrees with behaviors
///All subtrees this AI has available, will run them in order, so make sure they're in the order you want them to run. On initialization of this type, it will start as a typepath(s) and get converted to references of ai_subtrees found in SSai_controllers when init_subtrees() is called
var/list/planning_subtrees
+ ///The idle behavior this AI preforms when it has no actions.
+ var/datum/idle_behavior/idle_behavior = null
+
// Movement related things here
///Reference to the movement datum we use. Is a type on initialize but becomes a ref afterwards.
var/datum/ai_movement/ai_movement = /datum/ai_movement/dumb
@@ -48,6 +51,9 @@ multiple modular subtrees with behaviors
change_ai_movement_type(ai_movement)
init_subtrees()
+ if(idle_behavior)
+ idle_behavior = new idle_behavior()
+
PossessPawn(new_pawn)
/datum/ai_controller/Destroy(force, ...)
@@ -128,8 +134,8 @@ multiple modular subtrees with behaviors
SSmove_manager.stop_looping(pawn) //stop moving
return //this should remove them from processing in the future through event-based stuff.
- if(!LAZYLEN(current_behaviors))
- PerformIdleBehavior(delta_time) //Do some stupid shit while we have nothing to do
+ if(!LAZYLEN(current_behaviors) && idle_behavior)
+ idle_behavior.perform_idle_behavior(delta_time, src) //Do some stupid shit while we have nothing to do
return
if(current_movement_target && get_dist(pawn, current_movement_target) > max_target_distance) //The distance is out of range
@@ -172,10 +178,6 @@ multiple modular subtrees with behaviors
ProcessBehavior(action_delta_time, current_behavior)
return
-///Perform some dumb idle behavior.
-/datum/ai_controller/proc/PerformIdleBehavior(delta_time)
- return
-
///This is where you decide what actions are taken by the AI.
/datum/ai_controller/proc/SelectBehaviors(delta_time)
SHOULD_NOT_SLEEP(TRUE) //Fuck you don't sleep in procs like this.
diff --git a/code/datums/ai/basic_mobs/base_basic_controller.dm b/code/datums/ai/basic_mobs/base_basic_controller.dm
new file mode 100644
index 0000000000000..ad50572c39f78
--- /dev/null
+++ b/code/datums/ai/basic_mobs/base_basic_controller.dm
@@ -0,0 +1,26 @@
+/datum/ai_controller/basic_controller
+ movement_delay = 0.4 SECONDS
+
+/datum/ai_controller/basic_controller/TryPossessPawn(atom/new_pawn)
+ if(!isbasicmob(new_pawn))
+ return AI_CONTROLLER_INCOMPATIBLE
+ var/mob/living/basic/basic_mob = new_pawn
+
+ update_speed(basic_mob)
+
+ RegisterSignal(basic_mob, POST_BASIC_MOB_UPDATE_VARSPEED, PROC_REF(update_speed))
+
+ return ..() //Run parent at end
+
+
+/datum/ai_controller/basic_controller/able_to_run()
+ . = ..()
+ if(isliving(pawn))
+ var/mob/living/living_pawn = pawn
+ if(IS_DEAD_OR_INCAP(living_pawn))
+ return FALSE
+ return TRUE
+
+/datum/ai_controller/basic_controller/proc/update_speed(mob/living/basic/basic_mob)
+ SIGNAL_HANDLER
+ movement_delay = basic_mob.cached_multiplicative_slowdown
diff --git a/code/datums/ai/basic_mobs/basic_ai_behaviors/basic_attacking.dm b/code/datums/ai/basic_mobs/basic_ai_behaviors/basic_attacking.dm
new file mode 100644
index 0000000000000..624cf0d60d65c
--- /dev/null
+++ b/code/datums/ai/basic_mobs/basic_ai_behaviors/basic_attacking.dm
@@ -0,0 +1,67 @@
+/datum/ai_behavior/basic_melee_attack
+ action_cooldown = 0.6 SECONDS
+ behavior_flags = AI_BEHAVIOR_REQUIRE_MOVEMENT
+
+/datum/ai_behavior/basic_melee_attack/setup(datum/ai_controller/controller, target_key, targetting_datum_key, hiding_location_key)
+ . = ..()
+ controller.current_movement_target = controller.blackboard[hiding_location_key] || controller.blackboard[target_key] //Hiding location is priority
+
+/datum/ai_behavior/basic_melee_attack/perform(delta_time, datum/ai_controller/controller, target_key, targetting_datum_key, hiding_location_key)
+ . = ..()
+ var/mob/living/basic/basic_mob = controller.pawn
+ var/atom/target = controller.blackboard[target_key]
+ var/datum/targetting_datum/targetting_datum = controller.blackboard[targetting_datum_key]
+
+ if(!targetting_datum.can_attack(basic_mob, target))
+ finish_action(controller, FALSE, target_key)
+ return
+
+ var/hiding_target = targetting_datum.find_hidden_mobs(basic_mob, target) //If this is valid, theyre hidden in something!
+
+ controller.blackboard[hiding_location_key] = hiding_target
+
+ if(hiding_target) //Slap it!
+ basic_mob.melee_attack(hiding_target)
+ else
+ basic_mob.melee_attack(target)
+
+
+/datum/ai_behavior/basic_melee_attack/finish_action(datum/ai_controller/controller, succeeded, target_key, targetting_datum_key, hiding_location_key)
+ . = ..()
+ if(!succeeded)
+ controller.blackboard -= target_key
+
+/datum/ai_behavior/basic_ranged_attack
+ action_cooldown = 0.6 SECONDS
+ behavior_flags = AI_BEHAVIOR_REQUIRE_MOVEMENT | AI_BEHAVIOR_MOVE_AND_PERFORM
+ required_distance = 3
+
+/datum/ai_behavior/basic_ranged_attack/setup(datum/ai_controller/controller, target_key, targetting_datum_key, hiding_location_key)
+ . = ..()
+ controller.current_movement_target = controller.blackboard[hiding_location_key] || controller.blackboard[target_key] //Hiding location is priority
+
+
+/datum/ai_behavior/basic_ranged_attack/perform(delta_time, datum/ai_controller/controller, target_key, targetting_datum_key, hiding_location_key)
+ . = ..()
+ var/mob/living/basic/basic_mob = controller.pawn
+ var/atom/target = controller.blackboard[target_key]
+ var/datum/targetting_datum/targetting_datum = controller.blackboard[targetting_datum_key]
+
+
+ if(!targetting_datum.can_attack(basic_mob, target))
+ finish_action(controller, FALSE, target_key)
+ return
+
+ var/hiding_target = targetting_datum.find_hidden_mobs(basic_mob, target) //If this is valid, theyre hidden in something!
+
+ controller.blackboard[hiding_location_key] = hiding_target
+
+ if(hiding_target) //Shoot it!
+ basic_mob.RangedAttack(hiding_target)
+ else
+ basic_mob.RangedAttack(target)
+
+/datum/ai_behavior/basic_ranged_attack/finish_action(datum/ai_controller/controller, succeeded, target_key, targetting_datum_key, hiding_location_key)
+ . = ..()
+ if(!succeeded)
+ controller.blackboard -= target_key
diff --git a/code/datums/ai/basic_mobs/basic_ai_behaviors/targetting.dm b/code/datums/ai/basic_mobs/basic_ai_behaviors/targetting.dm
new file mode 100644
index 0000000000000..63a9ee83bb071
--- /dev/null
+++ b/code/datums/ai/basic_mobs/basic_ai_behaviors/targetting.dm
@@ -0,0 +1,46 @@
+/datum/ai_behavior/find_potential_targets
+ action_cooldown = 2 SECONDS
+ /// How far can we see stuff?
+ var/vision_range = 9
+ /// Static typecache list of potentially dangerous objs
+ var/static/list/hostile_machines = typecacheof(list(/obj/machinery/porta_turret, /obj/mecha))
+
+/datum/ai_behavior/find_potential_targets/perform(delta_time, datum/ai_controller/controller, target_key, targetting_datum_key, hiding_location_key)
+ . = ..()
+ var/list/potential_targets
+ var/mob/living/living_mob = controller.pawn
+ var/datum/targetting_datum/targetting_datum = controller.blackboard[targetting_datum_key]
+
+ if(!targetting_datum)
+ CRASH("No target datum was supplied in the blackboard for [controller.pawn]")
+
+ potential_targets = hearers(vision_range, controller.pawn) - living_mob //Remove self, so we don't suicide
+
+ for(var/HM in typecache_filter_list(range(vision_range, living_mob), hostile_machines)) //Can we see any hostile machines?
+ if(can_see(living_mob, HM, vision_range))
+ potential_targets += HM
+
+ if(!potential_targets.len)
+ finish_action(controller, FALSE)
+ return
+
+ var/list/filtered_targets = list()
+
+ for(var/atom/pot_target in potential_targets)
+ if(targetting_datum.can_attack(living_mob, pot_target))//Can we attack it?
+ filtered_targets += pot_target
+ continue
+
+ if(!filtered_targets.len)
+ finish_action(controller, FALSE)
+ return
+
+ var/atom/target = pick(filtered_targets)
+ controller.blackboard[target_key] = target
+
+ var/atom/potential_hiding_location = targetting_datum.find_hidden_mobs(living_mob, target)
+
+ if(potential_hiding_location) //If they're hiding inside of something, we need to know so we can go for that instead initially.
+ controller.blackboard[hiding_location_key] = potential_hiding_location
+
+ finish_action(controller, TRUE)
diff --git a/code/datums/ai/basic_mobs/basic_subtrees/simple_attack_target.dm b/code/datums/ai/basic_mobs/basic_subtrees/simple_attack_target.dm
new file mode 100644
index 0000000000000..56893ce767ee5
--- /dev/null
+++ b/code/datums/ai/basic_mobs/basic_subtrees/simple_attack_target.dm
@@ -0,0 +1,22 @@
+/datum/ai_planning_subtree/basic_melee_attack_subtree
+ var/datum/ai_behavior/basic_melee_attack/melee_attack_behavior = /datum/ai_behavior/basic_melee_attack
+
+/datum/ai_planning_subtree/basic_melee_attack_subtree/SelectBehaviors(datum/ai_controller/controller, delta_time)
+ . = ..()
+ var/atom/target = controller.blackboard[BB_BASIC_MOB_CURRENT_TARGET]
+ if(!target || QDELETED(target))
+ return
+ controller.queue_behavior(melee_attack_behavior, BB_BASIC_MOB_CURRENT_TARGET, BB_TARGETTING_DATUM, BB_BASIC_MOB_CURRENT_TARGET_HIDING_LOCATION)
+ return SUBTREE_RETURN_FINISH_PLANNING //we are going into battle...no distractions.
+
+//If you give this to something without the element you are a dumbass.
+/datum/ai_planning_subtree/basic_ranged_attack_subtree
+ var/datum/ai_behavior/basic_ranged_attack/ranged_attack_behavior = /datum/ai_behavior/basic_ranged_attack
+
+/datum/ai_planning_subtree/basic_ranged_attack_subtree/SelectBehaviors(datum/ai_controller/controller, delta_time)
+ . = ..()
+ var/atom/target = controller.blackboard[BB_BASIC_MOB_CURRENT_TARGET]
+ if(!target || QDELETED(target))
+ return
+ controller.queue_behavior(ranged_attack_behavior, BB_BASIC_MOB_CURRENT_TARGET, BB_TARGETTING_DATUM, BB_BASIC_MOB_CURRENT_TARGET_HIDING_LOCATION)
+ return SUBTREE_RETURN_FINISH_PLANNING //we are going into battle...no distractions.
diff --git a/code/datums/ai/basic_mobs/basic_subtrees/simple_find_target.dm b/code/datums/ai/basic_mobs/basic_subtrees/simple_find_target.dm
new file mode 100644
index 0000000000000..f6ad41d4e01d0
--- /dev/null
+++ b/code/datums/ai/basic_mobs/basic_subtrees/simple_find_target.dm
@@ -0,0 +1,9 @@
+/datum/ai_planning_subtree/simple_find_target
+
+/datum/ai_planning_subtree/simple_find_target/SelectBehaviors(datum/ai_controller/controller, delta_time)
+ . = ..()
+ var/datum/weakref/weak_target = controller.blackboard[BB_BASIC_MOB_CURRENT_TARGET]
+ var/atom/target = weak_target?.resolve()
+ if(!QDELETED(target))
+ return
+ controller.queue_behavior(/datum/ai_behavior/find_potential_targets, BB_BASIC_MOB_CURRENT_TARGET, BB_TARGETTING_DATUM, BB_BASIC_MOB_CURRENT_TARGET_HIDING_LOCATION)
diff --git a/code/datums/ai/basic_mobs/basic_subtrees/speech_subtree.dm b/code/datums/ai/basic_mobs/basic_subtrees/speech_subtree.dm
new file mode 100644
index 0000000000000..2621efabb7eec
--- /dev/null
+++ b/code/datums/ai/basic_mobs/basic_subtrees/speech_subtree.dm
@@ -0,0 +1,43 @@
+/datum/ai_planning_subtree/random_speech
+ //The chance of an emote occuring each second
+ var/speech_chance = 0
+ ///Hearable emotes
+ var/list/emote_hear = list()
+ ///Unlike speak_emote, the list of things in this variable only show by themselves with no spoken text. IE: Ian barks, Ian yaps
+ var/list/emote_see = list()
+ ///Possible lines of speech the AI can have
+ var/list/speak = list()
+
+/datum/ai_planning_subtree/random_speech/New()
+ . = ..()
+ if(speak)
+ speak = string_list(speak)
+ if(emote_hear)
+ emote_hear = string_list(emote_hear)
+ if(emote_see)
+ emote_see = string_list(emote_see)
+
+/datum/ai_planning_subtree/random_speech/SelectBehaviors(datum/ai_controller/controller, delta_time)
+ if(DT_PROB(speech_chance, delta_time))
+ var/audible_emotes_length = emote_hear?.len
+ var/non_audible_emotes_length = emote_see?.len
+ var/speak_lines_length = speak?.len
+
+ var/total_choices_length = audible_emotes_length + non_audible_emotes_length + speak_lines_length
+
+ var/random_number_in_range = rand(1, total_choices_length)
+
+ if(random_number_in_range <= audible_emotes_length)
+ controller.queue_behavior(/datum/ai_behavior/perform_emote, pick(emote_hear))
+ else if(random_number_in_range <= (audible_emotes_length + non_audible_emotes_length))
+ controller.queue_behavior(/datum/ai_behavior/perform_emote, pick(emote_see))
+ else
+ controller.queue_behavior(/datum/ai_behavior/perform_speech, pick(speak))
+
+/datum/ai_planning_subtree/random_speech/cockroach
+ speech_chance = 1
+ emote_hear = list("chitters.")
+
+/datum/ai_planning_subtree/random_speech/mothroach
+ speech_chance = 2
+ emote_hear = list("flutters.", "flaps its wings.", "flaps its wings agressively!")
diff --git a/code/datums/ai/basic_mobs/targetting_datums/basic_targetting_datum.dm b/code/datums/ai/basic_mobs/targetting_datums/basic_targetting_datum.dm
new file mode 100644
index 0000000000000..5aa2aafdf66e0
--- /dev/null
+++ b/code/datums/ai/basic_mobs/targetting_datums/basic_targetting_datum.dm
@@ -0,0 +1,56 @@
+///Datum for basic mobs to define what they can attack.
+/datum/targetting_datum
+
+///Returns true or false depending on if the target can be attacked by the mob
+/datum/targetting_datum/proc/can_attack(mob/living/living_mob, atom/target)
+ return
+
+///Returns something the target might be hiding inside of
+/datum/targetting_datum/proc/find_hidden_mobs(mob/living/living_mob, atom/target)
+ var/atom/target_hiding_location
+ if(istype(target.loc, /obj/structure/closet) || istype(target.loc, /obj/machinery/disposal) || istype(target.loc, /obj/machinery/sleeper))
+ target_hiding_location = target.loc
+ return target_hiding_location
+
+/datum/targetting_datum/basic
+ /// When we do our basic faction check, do we look for exact faction matches?
+ var/check_factions_exactly = FALSE
+
+/datum/targetting_datum/basic/can_attack(mob/living/living_mob, atom/the_target)
+ if(isturf(the_target) || !the_target) // bail out on invalids
+ return FALSE
+
+ if(ismob(the_target)) //Target is in godmode, ignore it.
+ var/mob/M = the_target
+ if(M.status_flags & GODMODE)
+ return FALSE
+
+ if(living_mob.see_invisible < the_target.invisibility)//Target's invisible to us, forget it
+ return FALSE
+
+ if(living_mob.get_virtual_z_level() != the_target.get_virtual_z_level())
+ return FALSE
+
+ if(isliving(the_target)) //Targetting vs living mobs
+ var/mob/living/L = the_target
+ var/faction_check = living_mob.faction_check_mob(L, exact_match = check_factions_exactly)
+ if(faction_check || L.stat)
+ return FALSE
+ return TRUE
+
+ if(ismecha(the_target)) //Targetting vs mechas
+ var/obj/mecha/M = the_target
+ if(can_attack(living_mob, M.occupant)) //Can we attack any of the occupants?
+ return TRUE
+
+ if(istype(the_target, /obj/machinery/porta_turret)) //Cringe turret! kill it!
+ var/obj/machinery/porta_turret/P = the_target
+ if(P.in_faction(living_mob)) //Don't attack if the turret is in the same faction
+ return FALSE
+ if(P.has_cover && !P.raised) //Don't attack invincible turrets
+ return FALSE
+ if(P.machine_stat & BROKEN) //Or turrets that are already broken
+ return FALSE
+ return TRUE
+
+ return FALSE
diff --git a/code/datums/ai/dog/dog_behaviors.dm b/code/datums/ai/dog/dog_behaviors.dm
index 60c60214dff75..d0af81326a186 100644
--- a/code/datums/ai/dog/dog_behaviors.dm
+++ b/code/datums/ai/dog/dog_behaviors.dm
@@ -62,7 +62,7 @@
var/atom/pawn = controller.pawn
pawn.visible_message("[pawn] drops [carried_item].")
carried_item.forceMove(get_turf(pawn))
- controller.blackboard[BB_SIMPLE_CARRY_ITEM] = null
+ controller.blackboard -= BB_SIMPLE_CARRY_ITEM
return TRUE
diff --git a/code/datums/ai/dog/dog_controller.dm b/code/datums/ai/dog/dog_controller.dm
index e493e88f6c0e3..2808472f2f4f7 100644
--- a/code/datums/ai/dog/dog_controller.dm
+++ b/code/datums/ai/dog/dog_controller.dm
@@ -9,6 +9,7 @@
BB_DOG_PLAYING_DEAD = FALSE,\
BB_DOG_HARASS_TARGET = null)
ai_movement = /datum/ai_movement/jps
+ idle_behavior = /datum/idle_behavior/idle_dog
planning_subtrees = list(/datum/ai_planning_subtree/dog)
COOLDOWN_DECLARE(heel_cooldown)
@@ -55,30 +56,6 @@
return simple_pawn.access_card
-/datum/ai_controller/dog/PerformIdleBehavior(delta_time)
- var/mob/living/living_pawn = pawn
- if(!isturf(living_pawn.loc) || living_pawn.pulledby)
- return
-
- // if we were just ordered to heel, chill out for a bit
- if(!COOLDOWN_FINISHED(src, heel_cooldown))
- return
-
- // if we're just ditzing around carrying something, occasionally print a message so people know we have something
- if(blackboard[BB_SIMPLE_CARRY_ITEM] && DT_PROB(5, delta_time))
- var/obj/item/carry_item = blackboard[BB_SIMPLE_CARRY_ITEM]
- living_pawn.visible_message("[living_pawn] gently teethes on \the [carry_item] in [living_pawn.p_their()] mouth.", vision_distance=COMBAT_MESSAGE_RANGE)
-
- if(DT_PROB(5, delta_time) && (living_pawn.mobility_flags & MOBILITY_MOVE))
- var/move_dir = pick(GLOB.alldirs)
- living_pawn.Move(get_step(living_pawn, move_dir), move_dir)
- else if(DT_PROB(10, delta_time))
- living_pawn.manual_emote(pick("dances around.", "chases [living_pawn.p_their()] tail!"))
- living_pawn.AddComponent(/datum/component/spinny)
- for(var/mob/living/carbon/human/H in oviewers(living_pawn))
- if(H.mind)
- SEND_SIGNAL(H, COMSIG_ADD_MOOD_EVENT, "animal_play", /datum/mood_event/animal_play, living_pawn)
-
/// Someone has thrown something, see if it's someone we care about and start listening to the thrown item so we can see if we want to fetch it when it lands
/datum/ai_controller/dog/proc/listened_throw(datum/source, mob/living/carbon/carbon_thrower)
SIGNAL_HANDLER
diff --git a/code/datums/ai/hunting_behavior/hunting_behaviors.dm b/code/datums/ai/hunting_behavior/hunting_behaviors.dm
new file mode 100644
index 0000000000000..1cd4e8dab2d0a
--- /dev/null
+++ b/code/datums/ai/hunting_behavior/hunting_behaviors.dm
@@ -0,0 +1,133 @@
+
+/**
+ * Tells the AI to find a certain target nearby to hunt.
+ * If a target has been found, we will start to move towards it, and eventually attack it.
+ */
+/datum/ai_planning_subtree/find_and_hunt_target
+ /// What key in the blacbkboard do we store our hunting target?
+ /// If you want to have multiple hunting behaviors on a controller be sure that this is unique
+ var/target_key = BB_CURRENT_HUNTING_TARGET
+ /// What behavior to execute if we have no target
+ var/datum/ai_behavior/finding_behavior = /datum/ai_behavior/find_hunt_target
+ /// What behavior to execute if we do have a target
+ var/datum/ai_behavior/hunting_behavior = /datum/ai_behavior/hunt_target
+ /// What targets we're hunting for
+ var/list/hunt_targets
+ /// In what radius will we hunt
+ var/hunt_range = 2
+ /// What are the chances we hunt something at any given moment
+ var/hunt_chance = 100
+
+/datum/ai_planning_subtree/find_and_hunt_target/New()
+ . = ..()
+ hunt_targets = typecacheof(hunt_targets)
+
+/datum/ai_planning_subtree/find_and_hunt_target/SelectBehaviors(datum/ai_controller/controller, delta_time)
+ if(!DT_PROB(hunt_chance, delta_time))
+ return
+ if(controller.blackboard[BB_HUNTING_COOLDOWN] >= world.time)
+ return
+
+ var/mob/living/living_pawn = controller.pawn
+ // We can't hunt if we're indisposed
+ if(living_pawn.stat != CONSCIOUS)
+ return
+
+ // We're targeting something else for another reason
+ var/datum/weakref/target_weakref = controller.blackboard[BB_BASIC_MOB_CURRENT_TARGET]
+ var/atom/target = target_weakref?.resolve()
+ if(!QDELETED(target))
+ return
+
+ var/datum/weakref/hunting_weakref = controller.blackboard[target_key]
+ var/atom/hunted = hunting_weakref?.resolve()
+
+ // We're not hunting anything, look around for something
+ if(QDELETED(hunted))
+ controller.queue_behavior(finding_behavior, target_key, hunt_targets, hunt_range)
+
+ else
+ // We ARE hunting something, execute the hunt.
+ // Note that if our AI controller has multiple hunting subtrees set,
+ // we may accidentally be executing another tree's hunt - not ideal,
+ // try to set a unique target key if you have multiple
+ controller.queue_behavior(hunting_behavior, target_key, BB_HUNTING_COOLDOWN)
+ return SUBTREE_RETURN_FINISH_PLANNING //If we're hunting we're too busy for anything else
+
+/// Finds a specific atom type to hunt.
+/datum/ai_behavior/find_hunt_target
+
+/datum/ai_behavior/find_hunt_target/perform(delta_time, datum/ai_controller/controller, hunting_target_key, types_to_hunt, hunt_range)
+ . = ..()
+
+ var/mob/living/living_mob = controller.pawn
+
+ for(var/atom/possible_dinner as anything in typecache_filter_list(range(hunt_range, living_mob), types_to_hunt))
+ if(!valid_dinner(living_mob, possible_dinner, hunt_range))
+ continue
+ controller.blackboard[hunting_target_key] = WEAKREF(possible_dinner)
+ finish_action(controller, TRUE)
+ return
+
+ finish_action(controller, FALSE)
+
+/datum/ai_behavior/find_hunt_target/proc/valid_dinner(mob/living/source, atom/dinner, radius)
+ if(isliving(dinner))
+ var/mob/living/living_target = dinner
+ if(living_target.stat == DEAD) //bitch is dead
+ return FALSE
+
+ return can_see(source, dinner, radius)
+
+/// Hunts down a specific atom type.
+/datum/ai_behavior/hunt_target
+ behavior_flags = AI_BEHAVIOR_REQUIRE_MOVEMENT
+ /// How long do we have to wait after a successful hunt?
+ var/hunt_cooldown = 5 SECONDS
+ /// What emote is said when the hunter eats something?
+ var/hunt_emote = "chomps"
+
+/datum/ai_behavior/hunt_target/setup(datum/ai_controller/controller, hunting_target_key, hunting_cooldown_key)
+ . = ..()
+ var/datum/weakref/hunting_weakref = controller.blackboard[hunting_target_key]
+ controller.current_movement_target = hunting_weakref?.resolve()
+
+/datum/ai_behavior/hunt_target/perform(delta_time, datum/ai_controller/controller, hunting_target_key, hunting_cooldown_key)
+ . = ..()
+ var/mob/living/hunter = controller.pawn
+ var/datum/weakref/hunting_weakref = controller.blackboard[hunting_target_key]
+ var/atom/hunted = hunting_weakref?.resolve()
+
+ if(QDELETED(hunted))
+ //Target is gone for some reason. forget about this task!
+ controller[hunting_target_key] = null
+ finish_action(controller, FALSE, hunting_target_key)
+ return
+
+ target_caught(hunter, hunted)
+ finish_action(controller, TRUE, hunting_target_key, hunting_cooldown_key)
+
+/datum/ai_behavior/hunt_target/proc/target_caught(mob/living/hunter, atom/hunted)
+ if(isliving(hunted)) // Are we hunting a living mob?
+ var/mob/living/living_target = hunted
+ hunter.manual_emote("[hunt_emote] [living_target]!")
+ living_target.death()
+
+ else if(IS_EDIBLE(hunted))
+ hunter.attack_animal(hunter)
+
+ else // We're hunting an object, and should delete it instead of killing it. Mostly useful for decal bugs like ants or spider webs.
+ hunter.manual_emote("[hunt_emote] [hunted]!")
+ qdel(hunted)
+
+/datum/ai_behavior/hunt_target/finish_action(datum/ai_controller/controller, succeeded, hunting_target_key, hunting_cooldown_key)
+ . = ..()
+ if(succeeded)
+ controller.blackboard[hunting_cooldown_key] = world.time + hunt_cooldown
+ else if(hunting_target_key)
+ controller.blackboard[hunting_target_key] = null
+
+/datum/ai_behavior/hunt_target/unarmed_attack_target
+
+/datum/ai_behavior/hunt_target/unarmed_attack_target/target_caught(mob/living/hunter, obj/structure/cable/hunted)
+ hunter.UnarmedAttack(hunted, TRUE)
diff --git a/code/datums/ai/hunting_behavior/hunting_vermin.dm b/code/datums/ai/hunting_behavior/hunting_vermin.dm
new file mode 100644
index 0000000000000..85770988b3e5d
--- /dev/null
+++ b/code/datums/ai/hunting_behavior/hunting_vermin.dm
@@ -0,0 +1,11 @@
+/datum/ai_planning_subtree/find_and_hunt_target/cockroach
+ hunt_targets = list(/obj/effect/decal/cleanable/food) //Bee Edit: We don't have ants yet July 2023, sorry. Also hi!!!
+
+/datum/ai_planning_subtree/find_and_hunt_target/mothroach
+ hunt_range = 3
+ hunt_targets = list(/obj/effect/decal/cleanable/cobweb, /obj/structure/spider/stickyweb)
+ hunting_behavior = /datum/ai_behavior/hunt_target/mothroach
+
+/datum/ai_behavior/hunt_target/mothroach
+ hunt_cooldown = 25 SECONDS
+ hunt_emote = "nibbles"
diff --git a/code/datums/ai/idle_behaviors/_idle_behavior.dm b/code/datums/ai/idle_behaviors/_idle_behavior.dm
new file mode 100644
index 0000000000000..a5ab827636a53
--- /dev/null
+++ b/code/datums/ai/idle_behaviors/_idle_behavior.dm
@@ -0,0 +1,4 @@
+/datum/idle_behavior
+
+/datum/idle_behavior/proc/perform_idle_behavior(delta_time, datum/ai_controller/controller)
+ return
diff --git a/code/datums/ai/idle_behaviors/idle_dog.dm b/code/datums/ai/idle_behaviors/idle_dog.dm
new file mode 100644
index 0000000000000..4156b2c023c1c
--- /dev/null
+++ b/code/datums/ai/idle_behaviors/idle_dog.dm
@@ -0,0 +1,26 @@
+/datum/idle_behavior/idle_dog
+
+/datum/idle_behavior/idle_dog/perform_idle_behavior(delta_time, datum/ai_controller/dog/controller)
+ var/mob/living/living_pawn = controller.pawn
+ if(!isturf(living_pawn.loc) || living_pawn.pulledby)
+ return
+
+ // if we were just ordered to heel, chill out for a bit
+ if(!COOLDOWN_FINISHED(controller, heel_cooldown))
+ return
+
+ // if we're just ditzing around carrying something, occasionally print a message so people know we have something
+ if(controller.blackboard[BB_SIMPLE_CARRY_ITEM] && DT_PROB(5, delta_time))
+ var/obj/item/carry_item = controller.blackboard[BB_SIMPLE_CARRY_ITEM]
+ living_pawn.visible_message("[living_pawn] gently teethes on \the [carry_item] in [living_pawn.p_their()] mouth.", vision_distance=COMBAT_MESSAGE_RANGE)
+
+ if(DT_PROB(5, delta_time) && (living_pawn.mobility_flags & MOBILITY_MOVE))
+ var/move_dir = pick(GLOB.alldirs)
+ living_pawn.Move(get_step(living_pawn, move_dir), move_dir)
+ else if(DT_PROB(10, delta_time))
+ living_pawn.manual_emote(pick("dances around.", "chases [living_pawn.p_their()] tail!"))
+ living_pawn.AddComponent(/datum/component/spinny)
+ for(var/mob/living/carbon/human/H in oviewers(living_pawn))
+ if(H.mind)
+ SEND_SIGNAL(H, COMSIG_ADD_MOOD_EVENT, "animal_play", /datum/mood_event/animal_play, living_pawn)
+
diff --git a/code/datums/ai/idle_behaviors/idle_monkey.dm b/code/datums/ai/idle_behaviors/idle_monkey.dm
new file mode 100644
index 0000000000000..aa43dff8944d6
--- /dev/null
+++ b/code/datums/ai/idle_behaviors/idle_monkey.dm
@@ -0,0 +1,10 @@
+/datum/idle_behavior/idle_monkey
+
+/datum/idle_behavior/idle_monkey/perform_idle_behavior(delta_time, datum/ai_controller/controller)
+ var/mob/living/living_pawn = controller.pawn
+
+ if(DT_PROB(25, delta_time) && (living_pawn.mobility_flags & MOBILITY_MOVE) && isturf(living_pawn.loc) && !living_pawn.pulledby)
+ var/move_dir = pick(GLOB.alldirs)
+ living_pawn.Move(get_step(living_pawn, move_dir), move_dir)
+ else if(DT_PROB(1, delta_time))
+ INVOKE_ASYNC(living_pawn, TYPE_PROC_REF(/mob, emote), pick("scratch","jump","roll","tail"))
diff --git a/code/datums/ai/idle_behaviors/idle_random_walk.dm b/code/datums/ai/idle_behaviors/idle_random_walk.dm
new file mode 100644
index 0000000000000..fa6dff67e9a50
--- /dev/null
+++ b/code/datums/ai/idle_behaviors/idle_random_walk.dm
@@ -0,0 +1,11 @@
+/datum/idle_behavior/idle_random_walk
+ ///Chance that the mob random walks per second
+ var/walk_chance = 25
+
+/datum/idle_behavior/idle_random_walk/perform_idle_behavior(delta_time, datum/ai_controller/controller)
+ . = ..()
+ var/mob/living/living_pawn = controller.pawn
+
+ if(DT_PROB(walk_chance, delta_time) && (living_pawn.mobility_flags & MOBILITY_MOVE) && isturf(living_pawn.loc) && !living_pawn.pulledby)
+ var/move_dir = pick(GLOB.alldirs)
+ living_pawn.Move(get_step(living_pawn, move_dir), move_dir)
diff --git a/code/datums/ai/monkey/monkey_controller.dm b/code/datums/ai/monkey/monkey_controller.dm
index 15a7da9020686..7e78dcdead3c0 100644
--- a/code/datums/ai/monkey/monkey_controller.dm
+++ b/code/datums/ai/monkey/monkey_controller.dm
@@ -24,6 +24,7 @@ have ways of interacting with a specific mob and control it.
var/static/list/loc_connections = list(
COMSIG_ATOM_ENTERED = PROC_REF(on_entered),
)
+ idle_behavior = /datum/idle_behavior/idle_monkey
/datum/ai_controller/monkey/angry
@@ -158,16 +159,6 @@ have ways of interacting with a specific mob and control it.
return TRUE
return FALSE
-//When idle just kinda fuck around.
-/datum/ai_controller/monkey/PerformIdleBehavior(delta_time)
- var/mob/living/living_pawn = pawn
-
- if(DT_PROB(25, delta_time) && (living_pawn.mobility_flags & MOBILITY_MOVE) && isturf(living_pawn.loc) && !living_pawn.pulledby)
- var/move_dir = pick(GLOB.alldirs)
- living_pawn.Move(get_step(living_pawn, move_dir), move_dir)
- else if(DT_PROB(1, delta_time))
- INVOKE_ASYNC(living_pawn, TYPE_PROC_REF(/mob, emote), pick("scratch","jump","roll","tail"))
-
///Reactive events to being hit
/datum/ai_controller/monkey/proc/retaliate(mob/living/L)
var/list/enemies = blackboard[BB_MONKEY_ENEMIES]
diff --git a/code/datums/ai/movement/_ai_movement.dm b/code/datums/ai/movement/_ai_movement.dm
index 41d9b8bf4a1f1..f2270a0d1a97e 100644
--- a/code/datums/ai/movement/_ai_movement.dm
+++ b/code/datums/ai/movement/_ai_movement.dm
@@ -16,7 +16,9 @@
controller.pathing_attempts = 0
moving_controllers -= controller
- SSmove_manager.stop_looping(controller.pawn, SSai_movement)
+ // We got deleted as we finished an action
+ if(!QDELETED(controller.pawn))
+ SSmove_manager.stop_looping(controller.pawn, SSai_movement)
/datum/ai_movement/proc/increment_pathing_failures(datum/ai_controller/controller)
controller.pathing_attempts++
diff --git a/code/datums/components/squashable.dm b/code/datums/components/squashable.dm
new file mode 100644
index 0000000000000..48cc9ef2905ad
--- /dev/null
+++ b/code/datums/components/squashable.dm
@@ -0,0 +1,77 @@
+///This component allows something to be when crossed, for example for cockroaches.
+/datum/component/squashable
+ ///Chance on crossed to be squashed
+ var/squash_chance = 50
+ ///How much brute is applied when mob is squashed
+ var/squash_damage = 1
+ ///Squash flags, for extra checks etcetera.
+ var/squash_flags = NONE
+ ///Special callback to call on squash instead, for things like hauberoach
+ var/datum/callback/on_squash_callback
+ ///signal list given to connect_loc
+ var/static/list/loc_connections = list(
+ COMSIG_ATOM_ENTERED = PROC_REF(on_entered),
+ )
+
+/datum/component/squashable/Initialize(squash_chance, squash_damage, squash_flags, squash_callback)
+ . = ..()
+ if(!isliving(parent))
+ return COMPONENT_INCOMPATIBLE
+ if(squash_chance)
+ src.squash_chance = squash_chance
+ if(squash_damage)
+ src.squash_damage = squash_damage
+ if(squash_flags)
+ src.squash_flags = squash_flags
+ if(!src.on_squash_callback && squash_callback)
+ on_squash_callback = CALLBACK(parent, squash_callback)
+
+ AddComponent(/datum/component/connect_loc_behalf, parent, loc_connections)
+
+/datum/component/squashable/UnregisterFromParent()
+ . = ..()
+ qdel(GetComponent(/datum/component/connect_loc_behalf))
+
+
+///Handles the squashing of the mob
+/datum/component/squashable/proc/on_entered(datum/source, atom/movable/crossing_movable, atom/old_loc, list/atom/old_locs)
+ SIGNAL_HANDLER
+
+ if(parent == crossing_movable)
+ return
+
+ var/mob/living/parent_as_living = parent
+
+ if(squash_flags & SQUASHED_SHOULD_BE_DOWN && parent_as_living.resting)
+ return
+
+ var/should_squash = prob(squash_chance)
+
+ if(should_squash && on_squash_callback)
+ if(on_squash_callback.Invoke(parent_as_living, crossing_movable))
+ return //Everything worked, we're done!
+
+ if(isliving(crossing_movable))
+ var/mob/living/crossing_mob = crossing_movable
+ if(crossing_mob.mob_size > MOB_SIZE_SMALL && !(crossing_mob.movement_type & FLYING))
+ if(HAS_TRAIT(crossing_mob, TRAIT_PACIFISM))
+ crossing_mob.visible_message("[crossing_mob] carefully steps over [parent_as_living].", "You carefully step over [parent_as_living] to avoid hurting it.")
+ return
+ if(should_squash)
+ crossing_mob.visible_message("[crossing_mob] squashed [parent_as_living].", "You squashed [parent_as_living].")
+ Squish(parent_as_living)
+ else
+ parent_as_living.visible_message("[parent_as_living] avoids getting crushed.")
+
+ if(isstructure(crossing_movable) && !crossing_movable.anchored)
+ if(should_squash)
+ crossing_movable.visible_message("[parent_as_living] is crushed under [crossing_movable].")
+ Squish(parent_as_living)
+ else
+ parent_as_living.visible_message("[parent_as_living] avoids getting crushed.")
+
+/datum/component/squashable/proc/Squish(mob/living/target)
+ if(squash_flags & SQUASHED_SHOULD_BE_GIBBED)
+ target.gib()
+ else
+ target.adjustBruteLoss(squash_damage)
diff --git a/code/datums/components/twohanded.dm b/code/datums/components/twohanded.dm
index 4cde9a2c7fa94..04ee7e3682a62 100644
--- a/code/datums/components/twohanded.dm
+++ b/code/datums/components/twohanded.dm
@@ -396,5 +396,6 @@
var/wielded = FALSE
/obj/item/offhand/equipped(mob/user, slot)
+ . = ..()
if(wielded && !user.is_holding(src))
qdel(src)
diff --git a/code/datums/diseases/advance/symptoms/cockroach.dm b/code/datums/diseases/advance/symptoms/cockroach.dm
index 1a91595ecfde7..b1317a0a93bea 100644
--- a/code/datums/diseases/advance/symptoms/cockroach.dm
+++ b/code/datums/diseases/advance/symptoms/cockroach.dm
@@ -45,7 +45,7 @@
if(prob(30))
M.visible_message("[M] squirms as a cockroach crawls from their pores!", \
"A cockroach crawls out of your face!!")
- new /mob/living/simple_animal/cockroach(M.loc)
+ new /mob/living/basic/cockroach(M.loc)
if(prob(50))
to_chat(M, "You feel something crawling in your pipes!")
@@ -56,5 +56,5 @@
var/mob/living/M = A.affected_mob
to_chat(M, "Your pores explode into a colony of roaches!")
for(var/i in 1 to rand(1,5))
- new /mob/living/simple_animal/cockroach(M.loc)
+ new /mob/living/basic/cockroach(M.loc)
diff --git a/code/datums/elements/_element.dm b/code/datums/elements/_element.dm
index fd0169712a3b6..5edbc2772e4a6 100644
--- a/code/datums/elements/_element.dm
+++ b/code/datums/elements/_element.dm
@@ -8,6 +8,7 @@
var/id_arg_index = INFINITY
/datum/element/proc/Attach(datum/target)
+ SHOULD_CALL_PARENT(TRUE)
if(type == /datum/element)
return ELEMENT_INCOMPATIBLE
SEND_SIGNAL(target, COMSIG_ELEMENT_ATTACH, src)
diff --git a/code/datums/elements/atmos_requirements.dm b/code/datums/elements/atmos_requirements.dm
new file mode 100644
index 0000000000000..d944a4dbac53f
--- /dev/null
+++ b/code/datums/elements/atmos_requirements.dm
@@ -0,0 +1,69 @@
+ ///Atmos effect - Yes, you can make creatures that require plasma or co2 to survive. N2O is a trace gas and handled separately, hence why it isn't here. It'd be hard to add it. Hard and me don't mix (Yes, yes make all the dick jokes you want with that.) - Errorage
+ ///Leaving something at 0 means it's off - has no maximum.
+
+ ///This damage is taken when atmos doesn't fit all the requirements above.
+
+
+/**
+ * ## atmos requirements element!
+ *
+ * bespoke element that deals damage to the attached mob when the atmos requirements aren't satisfied
+ */
+/datum/element/atmos_requirements
+ element_flags = ELEMENT_BESPOKE|ELEMENT_DETACH
+ id_arg_index = 2
+ var/list/atmos_requirements
+ var/unsuitable_atmos_damage
+
+/datum/element/atmos_requirements/Attach(datum/target, list/atmos_requirements, unsuitable_atmos_damage)
+ . = ..()
+ if(!isliving(target))
+ return ELEMENT_INCOMPATIBLE
+ src.atmos_requirements = string_assoc_list(atmos_requirements)
+ RegisterSignal(target, COMSIG_LIVING_HANDLE_BREATHING, PROC_REF(on_non_stasis_life))
+
+/datum/element/atmos_requirements/Detach(datum/target)
+ . = ..()
+ UnregisterSignal(target, COMSIG_LIVING_HANDLE_BREATHING)
+
+/datum/element/atmos_requirements/proc/on_non_stasis_life(mob/living/target, delta_time = SSMOBS_DT)
+ SIGNAL_HANDLER
+ if(is_breathable_atmos(target))
+ target.clear_alert("not_enough_oxy")
+ return
+ target.adjustBruteLoss(unsuitable_atmos_damage * delta_time)
+ target.throw_alert("not_enough_oxy", /atom/movable/screen/alert/not_enough_oxy)
+
+/datum/element/atmos_requirements/proc/is_breathable_atmos(mob/living/target)
+ if(target.pulledby && target.pulledby.grab_state >= GRAB_KILL && atmos_requirements["min_oxy"])
+ return FALSE
+
+ if(!isopenturf(target.loc))
+ return TRUE
+
+ var/turf/open/ST = target.loc
+ if(!ST.air && (atmos_requirements["min_oxy"] || atmos_requirements["min_tox"] || atmos_requirements["min_n2"] || atmos_requirements["min_co2"]))
+ return FALSE
+
+ var/plas = ST.air.get_moles(GAS_PLASMA)
+ var/oxy = ST.air.get_moles(GAS_O2)
+ var/n2 = ST.air.get_moles(GAS_N2)
+ var/co2 = ST.air.get_moles(GAS_CO2)
+
+ . = TRUE
+ if(atmos_requirements["min_oxy"] && oxy < atmos_requirements["min_oxy"])
+ . = FALSE
+ else if(atmos_requirements["max_oxy"] && oxy > atmos_requirements["max_oxy"])
+ . = FALSE
+ else if(atmos_requirements["min_plas"] && plas < atmos_requirements["min_plas"])
+ . = FALSE
+ else if(atmos_requirements["max_plas"] && plas > atmos_requirements["max_plas"])
+ . = FALSE
+ else if(atmos_requirements["min_n2"] && n2 < atmos_requirements["min_n2"])
+ . = FALSE
+ else if(atmos_requirements["max_n2"] && n2 > atmos_requirements["max_n2"])
+ . = FALSE
+ else if(atmos_requirements["min_co2"] && co2 < atmos_requirements["min_co2"])
+ . = FALSE
+ else if(atmos_requirements["max_co2"] && co2 > atmos_requirements["max_co2"])
+ . = FALSE
diff --git a/code/datums/elements/basic_body_temp_sensitive.dm b/code/datums/elements/basic_body_temp_sensitive.dm
new file mode 100644
index 0000000000000..44c26de8131a5
--- /dev/null
+++ b/code/datums/elements/basic_body_temp_sensitive.dm
@@ -0,0 +1,65 @@
+/**
+ * When attached to a basic mob, it gives it the ability to be hurt by cold body temperatures
+ */
+/datum/element/basic_body_temp_sensetive
+ element_flags = ELEMENT_BESPOKE
+ id_arg_index = 2
+
+ ///Min body temp
+ var/min_body_temp = 250
+ ///Max body temp
+ var/max_body_temp = 350
+ ////Damage when below min temp
+ var/cold_damage = 1
+ ///Damage when above max temp
+ var/heat_damage = 1
+
+/datum/element/basic_body_temp_sensetive/Attach(datum/target, min_body_temp, max_body_temp, cold_damage, heat_damage)
+ . = ..()
+ if(!isbasicmob(target))
+ return ELEMENT_INCOMPATIBLE
+
+ if(min_body_temp)
+ src.min_body_temp = min_body_temp
+ if(max_body_temp)
+ src.max_body_temp = max_body_temp
+ if(cold_damage)
+ src.cold_damage = cold_damage
+ if(heat_damage)
+ src.heat_damage = heat_damage
+ RegisterSignal(target, COMSIG_LIVING_LIFE, PROC_REF(on_life))
+
+/datum/element/basic_body_temp_sensetive/Detach(datum/source)
+ if(source)
+ UnregisterSignal(source, COMSIG_LIVING_LIFE)
+ return ..()
+
+
+/datum/element/basic_body_temp_sensetive/proc/on_life(datum/target, delta_time, times_fired)
+ var/mob/living/basic/basic_mob = target
+ var/gave_alert = FALSE
+
+ if(basic_mob.bodytemperature < min_body_temp)
+ basic_mob.adjust_health(cold_damage * delta_time)
+ switch(cold_damage)
+ if(1 to 5)
+ basic_mob.throw_alert("temp", /atom/movable/screen/alert/cold, 1)
+ if(5 to 10)
+ basic_mob.throw_alert("temp", /atom/movable/screen/alert/cold, 2)
+ if(10 to INFINITY)
+ basic_mob.throw_alert("temp", /atom/movable/screen/alert/cold, 3)
+ gave_alert = TRUE
+
+ else if(basic_mob.bodytemperature > max_body_temp)
+ basic_mob.adjust_health(heat_damage * delta_time)
+ switch(heat_damage)
+ if(1 to 5)
+ basic_mob.throw_alert("temp", /atom/movable/screen/alert/hot, 1)
+ if(5 to 10)
+ basic_mob.throw_alert("temp", /atom/movable/screen/alert/hot, 2)
+ if(10 to INFINITY)
+ basic_mob.throw_alert("temp", /atom/movable/screen/alert/hot, 3)
+ gave_alert = TRUE
+
+ if(!gave_alert)
+ basic_mob.clear_alert("temp")
diff --git a/code/datums/elements/death_drops.dm b/code/datums/elements/death_drops.dm
new file mode 100644
index 0000000000000..ea8abff07d3d9
--- /dev/null
+++ b/code/datums/elements/death_drops.dm
@@ -0,0 +1,34 @@
+/**
+ * ## death drops element!
+ *
+ * bespoke element that spawns loot when a mob is killed
+ */
+/datum/element/death_drops
+ element_flags = ELEMENT_BESPOKE|ELEMENT_DETACH
+ id_arg_index = 2
+ ///what items the target drops when killed
+ var/list/loot
+
+/datum/element/death_drops/Attach(datum/target, list/loot)
+ . = ..()
+ if(!isliving(target))
+ return ELEMENT_INCOMPATIBLE
+ if(!loot)
+ stack_trace("death drops element added to [target] with NO LOOT")
+ if(!src.loot)
+ src.loot = loot.Copy()
+ RegisterSignal(target, COMSIG_LIVING_DEATH, PROC_REF(on_death))
+
+/datum/element/death_drops/Detach(datum/target)
+ . = ..()
+ UnregisterSignal(target, COMSIG_LIVING_DEATH)
+
+///signal called by the stat of the target changing
+/datum/element/death_drops/proc/on_death(mob/living/target, gibbed)
+ SIGNAL_HANDLER
+ for(var/thing_to_spawn in loot)
+ if(loot[thing_to_spawn]) //If this is an assoc list, use the value of that to get the right amount
+ for(var/index in 1 to loot[thing_to_spawn])
+ new thing_to_spawn(target.drop_location())
+ else
+ new thing_to_spawn(target.drop_location())
diff --git a/code/datums/elements/pet_bonus.dm b/code/datums/elements/pet_bonus.dm
new file mode 100644
index 0000000000000..6a36f768ad70c
--- /dev/null
+++ b/code/datums/elements/pet_bonus.dm
@@ -0,0 +1,43 @@
+/**
+ * # Pet bonus element!
+ *
+ * Bespoke element that plays a fun message, sends a heart out, and gives a stronger mood bonus when you pet this animal.
+ * I may have been able to make this work for carbons, but it would have been interjecting on some help mode interactions anyways.
+ */
+/datum/element/pet_bonus
+ element_flags = ELEMENT_BESPOKE|ELEMENT_DETACH
+ id_arg_index = 2
+
+ ///optional cute message to send when you pet your pet!
+ var/emote_message
+ ///actual moodlet given, defaults to the pet animal one
+ var/moodlet
+ ///optional sound to play when your pet emotes
+ var/emote_sound
+
+/datum/element/pet_bonus/Attach(datum/target, emote_message, moodlet = /datum/mood_event/pet_animal, emote_sound = null)
+ . = ..()
+ if(!isliving(target))
+ return ELEMENT_INCOMPATIBLE
+
+ src.emote_message = emote_message
+ src.moodlet = moodlet
+ src.emote_sound = emote_sound
+ RegisterSignal(target, COMSIG_ATOM_ATTACK_HAND, PROC_REF(on_attack_hand))
+
+/datum/element/pet_bonus/Detach(datum/target)
+ . = ..()
+ UnregisterSignal(target, COMSIG_ATOM_ATTACK_HAND)
+
+/datum/element/pet_bonus/proc/on_attack_hand(mob/living/pet, mob/living/petter)
+ SIGNAL_HANDLER
+
+ if(pet.stat != CONSCIOUS || petter.a_intent != INTENT_HELP)
+ return
+
+ new /obj/effect/temp_visual/heart(pet.loc)
+ if(emote_message && prob(33))
+ pet.manual_emote(emote_message)
+ if(emote_sound)
+ playsound(get_turf(pet), emote_sound, 50, TRUE)
+ SEND_SIGNAL(petter, COMSIG_ADD_MOOD_EVENT, pet, moodlet, pet)
diff --git a/code/datums/elements/ranged_attacks.dm b/code/datums/elements/ranged_attacks.dm
new file mode 100644
index 0000000000000..dce2b80c92249
--- /dev/null
+++ b/code/datums/elements/ranged_attacks.dm
@@ -0,0 +1,52 @@
+//Bee edit: This was included in the basic mobs port, but we don't have glockroach so it is kept here in case we find an alternative or actually need it.
+
+///This proc is used by basic mobs to give them a simple ranged attack! In theory this could be extended to
+// /datum/element/ranged_attacks
+// element_flags = ELEMENT_DETACH | ELEMENT_BESPOKE
+// id_arg_index = 2
+// var/casingtype = /obj/item/ammo_casing/glockroach
+// var/projectilesound = 'sound/weapons/gun/pistol/shot.ogg'
+// var/projectiletype
+
+// /datum/element/ranged_attacks/Attach(atom/movable/target, casingtype, projectilesound, projectiletype)
+// . = ..()
+// if(!isbasicmob(target))
+// return COMPONENT_INCOMPATIBLE
+
+// src.casingtype = casingtype
+// src.projectilesound = projectilesound
+// src.projectiletype = projectiletype
+
+// RegisterSignal(target, COMSIG_MOB_ATTACK_RANGED, PROC_REF(fire_ranged_attack))
+
+// if(casingtype && projectiletype)
+// CRASH("Set both casing type and projectile type in [target]'s ranged attacks element! uhoh! stinky!")
+
+// /datum/element/ranged_attacks/Detach(datum/target)
+// UnregisterSignal(target, COMSIG_MOB_ATTACK_RANGED)
+// return ..()
+
+// /datum/element/ranged_attacks/proc/fire_ranged_attack(mob/living/basic/firer, atom/target, modifiers)
+// SIGNAL_HANDLER
+// INVOKE_ASYNC(src, PROC_REF(async_fire_ranged_attack), firer, target, modifiers)
+
+
+// /datum/element/ranged_attacks/proc/async_fire_ranged_attack(mob/living/basic/firer, atom/target, modifiers)
+// var/turf/startloc = get_turf(firer)
+
+// if(casingtype)
+// var/obj/item/ammo_casing/casing = new casingtype(startloc)
+// playsound(firer, projectilesound, 100, TRUE)
+// casing.fire_casing(target, firer, null, null, null, ran_zone(), 0, firer)
+
+// else if(projectiletype)
+// var/obj/projectile/P = new projectiletype(startloc)
+// playsound(firer, projectilesound, 100, TRUE)
+// P.starting = startloc
+// P.firer = firer
+// P.fired_from = firer
+// P.yo = target.y - startloc.y
+// P.xo = target.x - startloc.x
+// P.original = target
+// P.preparePixelProjectile(target, firer)
+// P.fire()
diff --git a/code/datums/emotes.dm b/code/datums/emotes.dm
index bb33214859125..c9bca7be5b732 100644
--- a/code/datums/emotes.dm
+++ b/code/datums/emotes.dm
@@ -140,9 +140,9 @@
. = message_monkey
else if(isipc(user) && message_ipc)
. = message_ipc
- else if((ismoth(user) || isapid(user) || isflyperson(user) || istype(user, /mob/living/simple_animal/mothroach)) && message_insect)
+ else if((ismoth(user) || isapid(user) || isflyperson(user)) && message_insect)
. = message_insect
- else if(isanimal(user) && message_simple)
+ else if((isanimal(user) || isbasicmob(user)) && message_simple)
. = message_simple
/datum/emote/proc/select_param(mob/user, params)
diff --git a/code/datums/martial/boxing.dm b/code/datums/martial/boxing.dm
index f64c3388de463..59d5cfdb2e0d6 100644
--- a/code/datums/martial/boxing.dm
+++ b/code/datums/martial/boxing.dm
@@ -46,12 +46,13 @@
log_combat(A, D, "knocked out (boxing) ")
else if(!(D.mobility_flags & MOBILITY_STAND))
D.force_say(A)
- return 1
+ return TRUE
/obj/item/clothing/gloves/boxing
var/datum/martial_art/boxing/style = new
/obj/item/clothing/gloves/boxing/equipped(mob/user, slot)
+ ..()
if(!ishuman(user))
return
if(slot == ITEM_SLOT_GLOVES)
diff --git a/code/datums/martial/krav_maga.dm b/code/datums/martial/krav_maga.dm
index e8139f43eb2d1..6236dd249ff1a 100644
--- a/code/datums/martial/krav_maga.dm
+++ b/code/datums/martial/krav_maga.dm
@@ -191,6 +191,7 @@
var/datum/martial_art/krav_maga/style = new
/obj/item/clothing/gloves/krav_maga/equipped(mob/user, slot)
+ . = ..()
if(!ishuman(user))
return
if(slot == ITEM_SLOT_GLOVES)
@@ -198,7 +199,7 @@
style.teach(H,1)
/obj/item/clothing/gloves/krav_maga/dropped(mob/user)
- ..()
+ . = ..()
if(!ishuman(user))
return
var/mob/living/carbon/human/H = user
diff --git a/code/datums/martial/wrestling.dm b/code/datums/martial/wrestling.dm
index cb55f73b19eba..7af26a5b144e3 100644
--- a/code/datums/martial/wrestling.dm
+++ b/code/datums/martial/wrestling.dm
@@ -455,6 +455,7 @@
var/datum/martial_art/wrestling/style = new
/obj/item/storage/belt/champion/wrestling/equipped(mob/user, slot)
+ . = ..()
if(!ishuman(user))
return
if(slot == ITEM_SLOT_BELT)
@@ -463,7 +464,7 @@
return
/obj/item/storage/belt/champion/wrestling/dropped(mob/user)
- ..()
+ . = ..()
if(!ishuman(user))
return
var/mob/living/carbon/human/H = user
diff --git a/code/game/area/Space_Station_13_areas.dm b/code/game/area/Space_Station_13_areas.dm
index adaebf62f9950..cd378dc4b9151 100644
--- a/code/game/area/Space_Station_13_areas.dm
+++ b/code/game/area/Space_Station_13_areas.dm
@@ -146,6 +146,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
lighting_colour_bulb = "#ffdbb4"
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_SIMPLE
lights_always_start_on = TRUE
+ color_correction = /datum/client_colour/area_color/cold_ish
//Maintenance - Departmental
@@ -161,6 +162,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
name = "Bar Maintenance"
icon_state = "maint_bar"
sound_environment = SOUND_AREA_WOODFLOOR
+ color_correction = /datum/client_colour/area_color/warm_ish
/area/maintenance/department/crew_quarters/dorms
name = "Dormitory Maintenance"
@@ -488,6 +490,8 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_ELITE
+ color_correction = /datum/client_colour/area_color/cold_ish
+
/area/bridge/meeting_room
name = "Heads of Staff Meeting Room"
icon_state = "meeting"
@@ -534,6 +538,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
icon_state = "hop_office"
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_ELITE
lights_always_start_on = FALSE
+ color_correction = /datum/client_colour/area_color/cold_ish
/area/crew_quarters/heads/hos
name = "Head of Security's Office"
@@ -571,6 +576,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
lighting_brightness_tube = 8
sound_environment = SOUND_AREA_STANDARD_STATION
lights_always_start_on = TRUE
+ color_correction = /datum/client_colour/area_color/warm_ish
/area/crew_quarters/dorms
name = "Dormitories"
@@ -657,6 +663,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
/area/crew_quarters/cafeteria
name = "Cafeteria"
icon_state = "cafeteria"
+ color_correction = /datum/client_colour/area_color/warm_ish
/area/crew_quarters/kitchen
name = "Kitchen"
@@ -664,11 +671,13 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
lighting_colour_tube = "#e3ffff"
lighting_colour_bulb = "#d5ffff"
lights_always_start_on = FALSE
+ color_correction = /datum/client_colour/area_color/cold_ish
/area/crew_quarters/kitchen/coldroom
name = "Kitchen Cold Room"
icon_state = "kitchen_cold"
sound_environment = SOUND_AREA_SMALL_ENCLOSED
+ color_correction = /datum/client_colour/area_color/cold
/area/crew_quarters/bar
name = "Bar"
@@ -679,6 +688,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
lighting_colour_bulb = "#ffebc1"
sound_environment = SOUND_AREA_WOODFLOOR
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_SIMPLE
+ color_correction = /datum/client_colour/area_color/warm_ish
/area/crew_quarters/bar/mood_check(mob/living/carbon/subject)
if(istype(subject) && HAS_TRAIT(subject, TRAIT_LIGHT_DRINKER))
@@ -721,6 +731,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
name = "Theatre"
icon_state = "theatre"
sound_environment = SOUND_AREA_WOODFLOOR
+ color_correction = /datum/client_colour/area_color/clown
/area/crew_quarters/theatre/backstage
name = "Backstage"
@@ -742,6 +753,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
lighting_colour_bulb = "#ffdbb4"
lighting_brightness_tube = 8
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_SIMPLE
+ color_correction = /datum/client_colour/area_color/warm_ish
/area/library/lounge
name = "Library Lounge"
@@ -799,6 +811,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
lighting_colour_tube = "#ffce93"
lighting_colour_bulb = "#ffbc6f"
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_ADVANCED
+ color_correction = /datum/client_colour/area_color/warm_yellow
/area/engine/engine_smes
name = "Engineering SMES"
@@ -978,6 +991,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
lighting_colour_tube = "#e7f8ff"
lighting_colour_bulb = "#d5f2ff"
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_SIMPLE
+ color_correction = /datum/client_colour/area_color/cold_ish
/area/medical/medbay/zone2
name = "Medbay"
@@ -1106,6 +1120,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
lighting_colour_tube = "#ffeee2"
lighting_colour_bulb = "#ffdfca"
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_ELITE
+ color_correction = /datum/client_colour/area_color/warm_ish
/area/security/main
name = "Security Office"
@@ -1259,6 +1274,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
lighting_colour_bulb = "#ffdbb8"
sound_environment = SOUND_AREA_STANDARD_STATION
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_PROTECTED
+ color_correction = /datum/client_colour/area_color/warm_yellow
/area/quartermaster/sorting
name = "Delivery Office"
@@ -1283,6 +1299,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
name = "\improper Cargo Lobby"
icon_state = "cargo_lobby"
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_PROTECTED
+ color_correction = /datum/client_colour/area_color/warm_yellow
/area/quartermaster/qm
name = "Quartermaster's Office"
@@ -1332,6 +1349,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
icon_state = "hydro"
sound_environment = SOUND_AREA_STANDARD_STATION
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_SIMPLE
+ color_correction = /datum/client_colour/area_color/cold_ish
/area/hydroponics/garden
name = "Garden"
@@ -1358,6 +1376,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
lighting_colour_bulb = "#e4f7ff"
sound_environment = SOUND_AREA_STANDARD_STATION
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_ADVANCED
+ color_correction = /datum/client_colour/area_color/cold_ish
/area/science/lobby
name = "\improper Science Lobby"
@@ -1452,6 +1471,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
sound_environment = SOUND_AREA_STANDARD_STATION
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_PROTECTED
lights_always_start_on = TRUE
+ color_correction = /datum/client_colour/area_color/warm_yellow
/area/storage/tools
name = "Auxiliary Tool Storage"
@@ -1474,6 +1494,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
name = "EVA Storage"
icon_state = "eva"
clockwork_warp_allowed = FALSE
+ color_correction = /datum/client_colour/area_color/cold_ish
/area/storage/emergency/starboard
name = "Starboard Emergency Storage"
@@ -1542,6 +1563,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
sound_environment = SOUND_AREA_STANDARD_STATION
airlock_hack_difficulty = AIRLOCK_WIRE_SECURITY_ELITE
lights_always_start_on = TRUE
+ color_correction = /datum/client_colour/area_color/cold
/area/ai_monitored/security/armory
name = "Armory"
@@ -1555,6 +1577,7 @@ NOTE: there are two lists of areas in the end of this file: centcom and station
name = "EVA Storage"
icon_state = "eva"
ambience_index = AMBIENCE_DANGER
+ color_correction = /datum/client_colour/area_color/cold_ish
/area/ai_monitored/storage/satellite
name = "AI Satellite Maint"
diff --git a/code/game/area/area_color_correction.dm b/code/game/area/area_color_correction.dm
new file mode 100644
index 0000000000000..679598092d18c
--- /dev/null
+++ b/code/game/area/area_color_correction.dm
@@ -0,0 +1,41 @@
+#define PRIORITY_LOW 1000
+
+/*
+ colour vs color
+*/
+
+/mob
+ var/current_correction
+
+/datum/client_colour/area_color
+ colour = ""
+ priority = PRIORITY_LOW
+ fade_in = 10 SECONDS
+ fade_out = 10 SECONDS
+
+//Warm-ish
+/datum/client_colour/area_color/warm_ish
+ colour = list(rgb(255, 0, 0), rgb(3, 252, 0), rgb(5, 0, 250))
+//Warm
+/datum/client_colour/area_color/warm
+ colour = list(rgb(255, 0, 0), rgb(5, 250, 0), rgb(7, 0, 248))
+//Cold-ish
+/datum/client_colour/area_color/cold_ish
+ colour = list(rgb(250, 0, 5), rgb(0, 252, 3), rgb(0, 0, 255))
+//Cold
+/datum/client_colour/area_color/cold
+ colour = list(rgb(245, 0, 10), rgb(0, 250, 5), rgb(0, 0, 255))
+//Cold-purple
+/datum/client_colour/area_color/cold_purple
+ colour = list(rgb(250, 0, 5), rgb(3, 252, 5), rgb(3, 0, 255)) //actually coldish-purple
+//Warm-green
+/datum/client_colour/area_color/warm_green
+ colour = list(rgb(252, 3, 0), rgb(3, 255, 0), rgb(3, 5, 255))
+//Warm-yellow
+/datum/client_colour/area_color/warm_yellow
+ colour = list(rgb(255, 3, 0), rgb(3, 252, 0), rgb(3, 3, 245))
+//Clown
+/datum/client_colour/area_color/clown
+ colour = list(rgb(255, 10, 10), rgb(10, 255, 10), rgb(10, 10, 255))
+
+#undef PRIORITY_LOW
diff --git a/code/game/area/areas.dm b/code/game/area/areas.dm
index 7f0f94ed80293..7ba5f7c6e1d7c 100644
--- a/code/game/area/areas.dm
+++ b/code/game/area/areas.dm
@@ -134,6 +134,9 @@
/// Whether the lights in this area aren't turned off when it's empty at roundstart
var/lights_always_start_on = FALSE
+ ///The areas specific color correction
+ var/color_correction = /datum/client_colour/area_color
+
/**
* A list of teleport locations
*
diff --git a/code/game/area/areas/mining.dm b/code/game/area/areas/mining.dm
index c8e2f63660af7..8c8c663e3dd95 100644
--- a/code/game/area/areas/mining.dm
+++ b/code/game/area/areas/mining.dm
@@ -125,6 +125,7 @@
ambient_buzz = 'sound/ambience/magma.ogg'
ambient_buzz_vol = 20
area_flags = VALID_TERRITORY | UNIQUE_AREA | FLORA_ALLOWED
+ color_correction = /datum/client_colour/area_color/warm
/area/lavaland/surface
name = "Lavaland"
diff --git a/code/game/objects/items.dm b/code/game/objects/items.dm
index 47d9a430e8dc5..2740ed4653b32 100644
--- a/code/game/objects/items.dm
+++ b/code/game/objects/items.dm
@@ -713,6 +713,7 @@ GLOBAL_VAR_INIT(rpg_loot_items, FALSE)
// for items that can be placed in multiple slots
// note this isn't called during the initial dressing of a player
/obj/item/proc/equipped(mob/user, slot, initial = FALSE)
+ SHOULD_CALL_PARENT(TRUE)
SEND_SIGNAL(src, COMSIG_ITEM_EQUIPPED, user, slot)
SEND_SIGNAL(user, COMSIG_MOB_EQUIPPED_ITEM, src, slot)
for(var/X in actions)
@@ -971,6 +972,11 @@ GLOBAL_VAR_INIT(rpg_loot_items, FALSE)
return ..()
return 0
+/obj/item/attack_basic_mob(mob/living/basic/user)
+ if (obj_flags & CAN_BE_HIT)
+ return ..()
+ return 0
+
/obj/item/mech_melee_attack(obj/mecha/M)
return 0
diff --git a/code/game/objects/items/cigs_lighters.dm b/code/game/objects/items/cigs_lighters.dm
index d4c3944d1c2b5..2e116884d0da8 100644
--- a/code/game/objects/items/cigs_lighters.dm
+++ b/code/game/objects/items/cigs_lighters.dm
@@ -915,6 +915,7 @@ CIGARETTE PACKETS ARE IN FANCY.DM
reagents.clear_reagents()
/obj/item/clothing/mask/vape/equipped(mob/user, slot)
+ . = ..()
if(slot == ITEM_SLOT_MASK)
if(!screw)
to_chat(user, "You start puffing on the vape.")
@@ -924,7 +925,7 @@ CIGARETTE PACKETS ARE IN FANCY.DM
to_chat(user, "You need to close the cap first!")
/obj/item/clothing/mask/vape/dropped(mob/user)
- ..()
+ . = ..()
if(user.get_item_by_slot(ITEM_SLOT_MASK) == src)
ENABLE_BITFIELD(reagents.flags, NO_REACT)
STOP_PROCESSING(SSobj, src)
diff --git a/code/game/objects/items/pitchfork.dm b/code/game/objects/items/pitchfork.dm
index 4217d42c7e5e5..462111bd1a808 100644
--- a/code/game/objects/items/pitchfork.dm
+++ b/code/game/objects/items/pitchfork.dm
@@ -60,7 +60,7 @@
return (BRUTELOSS)
/obj/item/pitchfork/demonic/pickup(mob/living/user)
- ..()
+ . = ..()
if(isliving(user) && user.mind && user.owns_soul() && !is_devil(user))
var/mob/living/U = user
U.visible_message("As [U] picks [src] up, [U]'s arms briefly catch fire.", \
diff --git a/code/game/objects/items/robot/robot_items.dm b/code/game/objects/items/robot/robot_items.dm
index bf46dd8fd3f4f..1b959715ec7d7 100644
--- a/code/game/objects/items/robot/robot_items.dm
+++ b/code/game/objects/items/robot/robot_items.dm
@@ -450,10 +450,11 @@
emaggedhitdamage = 0
/obj/item/borg/lollipop/equipped()
+ . = ..()
check_amount()
/obj/item/borg/lollipop/dropped()
- ..()
+ . = ..()
check_amount()
/obj/item/borg/lollipop/proc/check_amount() //Doesn't even use processing ticks.
diff --git a/code/game/objects/items/weaponry.dm b/code/game/objects/items/weaponry.dm
index b12e533737ac3..7835f3f62aaf7 100644
--- a/code/game/objects/items/weaponry.dm
+++ b/code/game/objects/items/weaponry.dm
@@ -97,7 +97,7 @@ for further reading, please see: https://github.com/tgstation/tgstation/pull/301
/obj/item/claymore/highlander //ALL COMMENTS MADE REGARDING THIS SWORD MUST BE MADE IN ALL CAPS
desc = "THERE CAN BE ONLY ONE, AND IT WILL BE YOU!!!\nActivate it in your hand to point to the nearest victim."
flags_1 = CONDUCT_1
- item_flags = DROPDEL | ISWEAPON
+ item_flags = DROPDEL | ISWEAPON //dropdel occurs because you lost an arm
slot_flags = null
light_range = 3
attack_verb = list("brutalized", "eviscerated", "disemboweled", "hacked", "carved", "cleaved") //ONLY THE MOST VISCERAL ATTACK VERBS
@@ -128,16 +128,14 @@ for further reading, please see: https://github.com/tgstation/tgstation/pull/301
/obj/item/claymore/highlander/pickup(mob/living/user)
- ..()
+ . = ..()
to_chat(user, "The power of Scotland protects you! You are shielded from all stuns and knockdowns.")
user.add_stun_absorption("highlander", INFINITY, 1, " is protected by the power of Scotland!", "The power of Scotland absorbs the stun!", " is protected by the power of Scotland!")
user.ignore_slowdown(HIGHLANDER)
/obj/item/claymore/highlander/dropped(mob/living/user)
- ..()
+ . = ..()
user.unignore_slowdown(HIGHLANDER)
- if(!QDELETED(src))
- qdel(src) //If this ever happens, it's because you lost an arm
/obj/item/claymore/highlander/examine(mob/user)
. = ..()
@@ -762,7 +760,7 @@ for further reading, please see: https://github.com/tgstation/tgstation/pull/301
strong_against = typecacheof(list(
/mob/living/simple_animal/hostile/poison/bees/,
/mob/living/simple_animal/butterfly,
- /mob/living/simple_animal/cockroach,
+ /mob/living/basic/cockroach,
/obj/item/queen_bee
))
diff --git a/code/game/objects/obj_defense.dm b/code/game/objects/obj_defense.dm
index 7387b1e86cb9f..52fdb93c3f106 100644
--- a/code/game/objects/obj_defense.dm
+++ b/code/game/objects/obj_defense.dm
@@ -110,6 +110,18 @@
if(attack_generic(user, 60, BRUTE, MELEE, 0))
playsound(src.loc, 'sound/weapons/slash.ogg', 100, 1)
+/obj/attack_basic_mob(mob/living/basic/user)
+ if(!user.melee_damage && !user.obj_damage) //No damage
+ user.emote("custom", message = "[user.friendly_verb_continuous] [src].")
+ return FALSE
+ else
+ if(user.obj_damage)
+ . = attack_generic(user, user.obj_damage, user.melee_damage_type, MELEE, TRUE, user.armour_penetration)
+ else
+ . = attack_generic(user, user.melee_damage, user.melee_damage_type, MELEE, TRUE, user.armour_penetration)
+ if(.)
+ playsound(src, 'sound/effects/meteorimpact.ogg', 100, TRUE)
+
/obj/attack_animal(mob/living/simple_animal/M)
if(!M.melee_damage && !M.obj_damage)
INVOKE_ASYNC(M, TYPE_PROC_REF(/mob, emote), "custom", null, "[M.friendly] [src].")
diff --git a/code/modules/awaymissions/mission_code/Academy.dm b/code/modules/awaymissions/mission_code/Academy.dm
index e77708ae14ef1..c4d77ff12ec7e 100644
--- a/code/modules/awaymissions/mission_code/Academy.dm
+++ b/code/modules/awaymissions/mission_code/Academy.dm
@@ -211,6 +211,7 @@
addtimer(CALLBACK(src, PROC_REF(effect), user, .), 1 SECONDS)
/obj/item/dice/d20/fate/equipped(mob/user, slot)
+ . = ..()
if(!ishuman(user) || !user.mind || (user.mind in SSticker.mode.wizards))
to_chat(user, "You feel the magic of the dice is restricted to ordinary humans! You should leave it alone.")
user.dropItemToGround(src)
diff --git a/code/modules/cargo/packs.dm b/code/modules/cargo/packs.dm
index 6dd9ab61567a2..fbef700866543 100644
--- a/code/modules/cargo/packs.dm
+++ b/code/modules/cargo/packs.dm
@@ -2713,7 +2713,7 @@
name = "Mothroach Crate"
desc = "Put the mothroach on your head and find out what true cuteness looks like."
cost = 5000
- contains = list(/mob/living/simple_animal/mothroach)
+ contains = list(/mob/living/basic/mothroach)
crate_name = "mothroach crate"
/datum/supply_pack/critter/monkey
diff --git a/code/modules/clothing/head/misc.dm b/code/modules/clothing/head/misc.dm
index d8c2e36b788ce..bcc6790770d8e 100644
--- a/code/modules/clothing/head/misc.dm
+++ b/code/modules/clothing/head/misc.dm
@@ -122,6 +122,7 @@
var/datum/language/piratespeak/L = new
/obj/item/clothing/head/pirate/equipped(mob/user, slot)
+ . = ..()
if(!ishuman(user))
return
if(slot == ITEM_SLOT_HEAD)
@@ -129,7 +130,7 @@
to_chat(user, "You suddenly know how to speak like a pirate!")
/obj/item/clothing/head/pirate/dropped(mob/user)
- ..()
+ . = ..()
if(!ishuman(user))
return
var/mob/living/carbon/human/H = user
diff --git a/code/modules/clothing/head/soft_caps.dm b/code/modules/clothing/head/soft_caps.dm
index 5fa8d5c576bfa..7e501c6553465 100644
--- a/code/modules/clothing/head/soft_caps.dm
+++ b/code/modules/clothing/head/soft_caps.dm
@@ -26,6 +26,7 @@
user.update_inv_head() //so our mob-overlays update
/obj/item/clothing/head/soft/equipped(mob/user, slot)
+ . = ..()
if(slot == ITEM_SLOT_HEAD)
if(HAS_TRAIT(user, TRAIT_PROSKATER))
if(!flipped)
diff --git a/code/modules/clothing/masks/cluwne.dm b/code/modules/clothing/masks/cluwne.dm
index 4b8a59734fe2a..d687f70452ba4 100644
--- a/code/modules/clothing/masks/cluwne.dm
+++ b/code/modules/clothing/masks/cluwne.dm
@@ -51,12 +51,13 @@
return SPEECH_MESSAGE
/obj/item/clothing/mask/cluwne/equipped(mob/user, slot)
- if(!user.has_dna())
- return
- if(slot == ITEM_SLOT_MASK)
- var/mob/living/carbon/C = user
- C.dna.add_mutation(CLUWNEMUT)
- return
+ . = ..()
+ if(!user.has_dna())
+ return
+ if(slot == ITEM_SLOT_MASK)
+ var/mob/living/carbon/C = user
+ C.dna.add_mutation(CLUWNEMUT)
+ return
/obj/item/clothing/mask/cluwne/happy_cluwne
name = "Happy Cluwne Mask"
@@ -83,22 +84,23 @@
play_laugh1()
/obj/item/clothing/mask/cluwne/happy_cluwne/equipped(mob/user, slot)
- if(!ishuman(user))
- return
- var/mob/living/carbon/human/H = user
- if(slot == ITEM_SLOT_MASK)
- if(is_cursed && can_cluwne) //logic predetermined
- log_admin("[key_name(H)] was made into a cluwne by [src]")
- message_admins("[key_name(H)] got cluwned by [src]")
- to_chat(H, "The masks straps suddenly tighten to your face and your thoughts are erased by a horrible green light!")
- H.dropItemToGround(src)
- H.cluwneify()
- qdel(src)
- else if(is_very_cursed && can_cluwne)
- var/turf/T = get_turf(src)
- var/mob/living/simple_animal/hostile/floor_cluwne/S = new(T)
- S.Acquire_Victim(user)
- log_admin("[key_name(user)] summoned a floor cluwne using the [src]")
- message_admins("[key_name(user)] summoned a floor cluwne using the [src]")
- to_chat(H, "The mask suddenly slips off your face and... slides under the floor?")
- to_chat(H, "...dneirf uoy ot gnoleb ton seod tahT")
+ . = ..()
+ if(!ishuman(user))
+ return
+ var/mob/living/carbon/human/H = user
+ if(slot == ITEM_SLOT_MASK)
+ if(is_cursed && can_cluwne) //logic predetermined
+ log_admin("[key_name(H)] was made into a cluwne by [src]")
+ message_admins("[key_name(H)] got cluwned by [src]")
+ to_chat(H, "The masks straps suddenly tighten to your face and your thoughts are erased by a horrible green light!")
+ H.dropItemToGround(src)
+ H.cluwneify()
+ qdel(src)
+ else if(is_very_cursed && can_cluwne)
+ var/turf/T = get_turf(src)
+ var/mob/living/simple_animal/hostile/floor_cluwne/S = new(T)
+ S.Acquire_Victim(user)
+ log_admin("[key_name(user)] summoned a floor cluwne using the [src]")
+ message_admins("[key_name(user)] summoned a floor cluwne using the [src]")
+ to_chat(H, "The mask suddenly slips off your face and... slides under the floor?")
+ to_chat(H, "...dneirf uoy ot gnoleb ton seod tahT")
diff --git a/code/modules/clothing/shoes/cluwne.dm b/code/modules/clothing/shoes/cluwne.dm
index 6e76754b73e0b..d45d3753fb3af 100644
--- a/code/modules/clothing/shoes/cluwne.dm
+++ b/code/modules/clothing/shoes/cluwne.dm
@@ -21,6 +21,7 @@
footstep++
/obj/item/clothing/shoes/cluwne/equipped(mob/user, slot)
+ . = ..()
if(!user.has_dna())
return
if(slot == ITEM_SLOT_FEET)
diff --git a/code/modules/holoparasite/holoparasite_reset.dm b/code/modules/holoparasite/holoparasite_reset.dm
index 08f9c371fc67e..c618452fa8282 100644
--- a/code/modules/holoparasite/holoparasite_reset.dm
+++ b/code/modules/holoparasite/holoparasite_reset.dm
@@ -66,6 +66,7 @@
to_chat(summoner.current, "Personality reset failed: unknown error!")
return
to_chat(src, "[self ? "A ghost took control of you, at your request." : "Your summoner reset you! Better luck next time!"]")
+ ghostize(can_reenter_corpse = FALSE)
key = new_player.key
to_chat(summoner.current, "Personality reset for [color_name] succeeded!")
SSblackbox.record_feedback("tally", "holoparasite_reset", 1, automatic ? "automatic" : (self ? "self" : (cooldown ? "summoner" : "summoner (free)")))
diff --git a/code/modules/mapping/mapping_helpers.dm b/code/modules/mapping/mapping_helpers.dm
index 718d1aebb2da9..0e4da5d7b44f8 100644
--- a/code/modules/mapping/mapping_helpers.dm
+++ b/code/modules/mapping/mapping_helpers.dm
@@ -310,3 +310,14 @@ INITIALIZE_IMMEDIATE(/obj/effect/mapping_helpers/no_lava)
else
organ.organ_flags |= ORGAN_FROZEN
container.update_icon()
+
+//Color correction helper - only use of these per area, it will convert the entire area
+/obj/effect/mapping_helpers/color_correction
+ name = "color correction helper"
+ icon_state = "color_correction"
+ var/color_correction = /datum/client_colour/area_color/cold
+
+/obj/effect/mapping_helpers/color_correction/Initialize(mapload)
+ . = ..()
+ var/area/A = get_area(get_turf(src))
+ A.color_correction = color_correction
diff --git a/code/modules/mob/living/basic/basic.dm b/code/modules/mob/living/basic/basic.dm
new file mode 100644
index 0000000000000..de23dbb240c5d
--- /dev/null
+++ b/code/modules/mob/living/basic/basic.dm
@@ -0,0 +1,164 @@
+///Simple animals 2.0, This time, let's really try to keep it simple. This basetype should purely be used as a base-level for implementing simplified behaviours for things such as damage and attacks. Everything else should be in components or AI behaviours.
+/mob/living/basic
+ name = "basic mob"
+ icon = 'icons/mob/animal.dmi'
+ health = 20
+ maxHealth = 20
+ gender = PLURAL
+ status_flags = CANPUSH
+
+ var/basic_mob_flags = NONE
+
+ ///Defines how fast the basic mob can move. This is a multiplier
+ var/speed = 1
+ ///How much stamina the mob recovers per second
+ var/stamina_recovery = 5
+
+ ///how much damage this basic mob does to objects, if any.
+ var/obj_damage = 0
+ ///How much armour they ignore, as a flat reduction from the targets armour value.
+ var/armour_penetration = 0
+ ///Damage type of a simple mob's melee attack, should it do damage.
+ var/melee_damage_type = BRUTE
+ ///How much wounding power it has
+ // var/wound_bonus = CANT_WOUND
+ ///How much bare wounding power it has
+ var/bare_wound_bonus = 0
+ ///If the attacks from this are sharp
+ var/sharpness = NONE
+
+ /// Sound played when the critter attacks.
+ var/attack_sound
+ /// Override for the visual attack effect shown on 'do_attack_animation()'.
+ var/attack_vis_effect
+ ///Played when someone punches the creature.
+ var/attacked_sound = "punch" //This should be an element
+
+ ///What kind of objects this mob can smash.
+ var/environment_smash = ENVIRONMENT_SMASH_NONE
+
+ /// 1 for full damage , 0 for none , -1 for 1:1 heal from that source.
+ var/list/damage_coeff = list(BRUTE = 1, BURN = 1, TOX = 1, CLONE = 1, STAMINA = 0, OXY = 1)
+
+ ///Verbs used for speaking e.g. "Says" or "Chitters". This can be elementized
+ var/list/speak_emote = list()
+
+ /// Minimum force required to deal any damage
+ var/force_threshold = 0
+
+ ///When someone interacts with the simple animal.
+ ///Help-intent verb in present continuous tense.
+ var/response_help_continuous = "pokes"
+ ///Help-intent verb in present simple tense.
+ var/response_help_simple = "poke"
+ ///Disarm-intent verb in present continuous tense.
+ var/response_disarm_continuous = "shoves"
+ ///Disarm-intent verb in present simple tense.
+ var/response_disarm_simple = "shove"
+ ///Harm-intent verb in present continuous tense.
+ var/response_harm_continuous = "hits"
+ ///Harm-intent verb in present simple tense.
+ var/response_harm_simple = "hit"
+
+ ///Basic mob's own attacks verbs,
+ ///Attacking verb in present continuous tense.
+ var/attack_verb_continuous = "attacks"
+ ///Attacking verb in present simple tense.
+ var/attack_verb_simple = "attack"
+ ///Attacking, but without damage, verb in present continuous tense.
+ var/friendly_verb_continuous = "nuzzles"
+ ///Attacking, but without damage, verb in present simple tense.
+ var/friendly_verb_simple = "nuzzle"
+
+ ////////THIS SECTION COULD BE ITS OWN ELEMENT
+ ///Icon to use
+ var/icon_living = ""
+ ///Icon when the animal is dead. Don't use animated icons for this.
+ var/icon_dead = ""
+ ///We only try to show a gibbing animation if this exists.
+ var/icon_gib = null
+ ///Flip the sprite upside down on death. Mostly here for things lacking custom dead sprites.
+ var/flip_on_death = FALSE
+
+ ///If the mob can be spawned with a gold slime core. HOSTILE_SPAWN are spawned with plasma, FRIENDLY_SPAWN are spawned with blood.
+ var/gold_core_spawnable = NO_SPAWN
+ ///Sentience type, for slime potions. SHOULD BE AN ELEMENT BUT I DONT CARE ABOUT IT FOR NOW
+ var/sentience_type = SENTIENCE_ORGANIC
+
+
+
+/mob/living/basic/Initialize(mapload)
+ . = ..()
+
+ if(gender == PLURAL)
+ gender = pick(MALE,FEMALE)
+
+ if(!real_name)
+ real_name = name
+
+ if(!loc)
+ stack_trace("Basic mob being instantiated in nullspace")
+
+ update_basic_mob_varspeed()
+
+ if(speak_emote)
+ speak_emote = string_list(speak_emote)
+
+/mob/living/basic/Life(delta_time = SSMOBS_DT, times_fired)
+ . = ..()
+ ///Automatic stamina re-gain
+ if(staminaloss > 0)
+ adjustStaminaLoss(-stamina_recovery * delta_time, FALSE, TRUE)
+
+/mob/living/basic/say_mod(input, list/message_mods = list())
+ if(length(speak_emote))
+ verb_say = pick(speak_emote)
+ return ..()
+
+/mob/living/basic/death(gibbed)
+ if(!gibbed)
+ if(!(basic_mob_flags & DEL_ON_DEATH))
+ INVOKE_ASYNC(src, TYPE_PROC_REF(/mob, emote), "deathgasp")
+
+ if(basic_mob_flags & DEL_ON_DEATH)
+ ..()
+ qdel(src)
+ return
+ else
+ health = 0
+ icon_state = icon_dead
+ if(flip_on_death)
+ transform = transform.Turn(180)
+ set_density(FALSE)
+ ..()
+
+// copied from simplemobs
+/mob/living/basic/revive(full_heal = 0, admin_revive = 0)
+ if(..()) //successfully ressuscitated from death
+ icon = initial(icon)
+ icon_state = icon_living
+ set_density(initial(density))
+ mobility_flags = MOBILITY_FLAGS_DEFAULT
+ update_mobility()
+ . = 1
+ setMovetype(initial(movement_type))
+
+/mob/living/basic/proc/melee_attack(atom/target)
+ src.face_atom(target)
+ // if(SEND_SIGNAL(src, COMSIG_HOSTILE_PRE_ATTACKINGTARGET, target) & COMPONENT_HOSTILE_NO_ATTACK)
+ // return FALSE //but more importantly return before attack_animal called
+ var/result = target.attack_basic_mob(src)
+ // SEND_SIGNAL(src, COMSIG_HOSTILE_POST_ATTACKINGTARGET, target, result) //Bee edit: We don't have pre_attackingtarget nor hostile simplemobs, so I'll just leave these here for anyone who stumbles upon this down the line
+ return result
+
+/mob/living/basic/proc/set_varspeed(var_value)
+ speed = var_value
+ update_basic_mob_varspeed()
+
+/mob/living/basic/proc/update_basic_mob_varspeed()
+ if(speed == 0)
+ // remove_movespeed_modifier(/datum/movespeed_modifier/simplemob_varspeed)
+ remove_movespeed_modifier(MOVESPEED_ID_BASIC_MOB_VARSPEED, TRUE)
+ // remove_movespeed_modifier(/datum/movespeed_modifier/simplemob_varspeed, multiplicative_slowdown = speed)
+ add_movespeed_modifier(MOVESPEED_ID_BASIC_MOB_VARSPEED, TRUE, 100, multiplicative_slowdown = speed, override = TRUE)
+ SEND_SIGNAL(src, POST_BASIC_MOB_UPDATE_VARSPEED)
diff --git a/code/modules/mob/living/basic/basic_defense.dm b/code/modules/mob/living/basic/basic_defense.dm
new file mode 100644
index 0000000000000..ac5c261a85a6f
--- /dev/null
+++ b/code/modules/mob/living/basic/basic_defense.dm
@@ -0,0 +1,195 @@
+/mob/living/basic/attack_hand(mob/living/carbon/human/user)
+ // so that martial arts don't double dip
+ if(..())
+ return TRUE
+
+ switch(user.a_intent)
+ if(INTENT_HELP)
+ if(stat == DEAD)
+ return
+ visible_message("[user] [response_help_continuous] [src].", \
+ "[user] [response_help_continuous] you.", null, null, list(user))
+ to_chat(user, "You [response_help_simple] [src].")
+ playsound(loc, 'sound/weapons/thudswoosh.ogg', 50, TRUE, -1)
+ return TRUE
+
+ if(INTENT_GRAB)
+ grabbedby(user)
+
+ if(INTENT_DISARM)
+ user.do_attack_animation(src, ATTACK_EFFECT_DISARM)
+ playsound(src, 'sound/weapons/thudswoosh.ogg', 50, TRUE, -1)
+ var/shove_dir = get_dir(user, src)
+ if(!Move(get_step(src, shove_dir), shove_dir))
+ log_combat(user, src, "shoved", "failing to move it")
+ visible_message("[user] [response_disarm_continuous] [src]!", \
+ "[user] [response_disarm_continuous] you!", \
+ "You hear aggressive shuffling!", COMBAT_MESSAGE_RANGE, list(user))
+ to_chat(user, "You [response_disarm_simple] [src]!")
+ else
+ log_combat(user, src, "shoved", "pushing it")
+ visible_message("[user] [response_disarm_continuous] [src], pushing [p_them()]!", \
+ "You're pushed by [user]!", \
+ "You hear aggressive shuffling!", COMBAT_MESSAGE_RANGE, list(user))
+ to_chat(user, "You [response_disarm_simple] [src], pushing [p_them()]!")
+ return TRUE
+
+ if(INTENT_HARM)
+ if(HAS_TRAIT(user, TRAIT_PACIFISM))
+ to_chat(user, "You don't want to hurt [src]!")
+ return
+ user.do_attack_animation(src, ATTACK_EFFECT_PUNCH)
+ visible_message("[user] [response_harm_continuous] [src]!",\
+ "[user] [response_harm_continuous] you!", null, COMBAT_MESSAGE_RANGE, list(user))
+ to_chat(user, "You [response_harm_simple] [src]!")
+ playsound(loc, attacked_sound, 25, TRUE, -1)
+
+ attack_threshold_check(user.dna.species.punchdamage)
+ log_combat(user, src, "attacked")
+ updatehealth()
+ return TRUE
+
+/mob/living/basic/attack_hulk(mob/living/carbon/human/user)
+ . = ..()
+ if(!.)
+ return
+ playsound(loc, "punch", 25, TRUE, -1)
+ visible_message("[user] punches [src]!", \
+ "You're punched by [user]!", null, COMBAT_MESSAGE_RANGE, user)
+ to_chat(user, "You punch [src]!")
+ adjustBruteLoss(15)
+
+/mob/living/basic/attack_paw(mob/living/carbon/human/user)
+ if(..()) //successful monkey bite.
+ if(stat != DEAD)
+ var/damage = rand(1, 3)
+ attack_threshold_check(damage)
+ return 1
+ if (user.a_intent == INTENT_HELP)
+ if (health > 0)
+ visible_message("[user.name] [response_help_continuous] [src].", \
+ "[user.name] [response_help_continuous] you.", null, COMBAT_MESSAGE_RANGE, user)
+ to_chat(user, "You [response_help_simple] [src].")
+ playsound(loc, 'sound/weapons/thudswoosh.ogg', 50, TRUE, -1)
+
+
+/mob/living/basic/attack_alien(mob/living/carbon/alien/humanoid/user)
+ if(..()) //if harm or disarm intent.
+ if(user.a_intent == INTENT_DISARM)
+ playsound(loc, 'sound/weapons/pierce.ogg', 25, TRUE, -1)
+ visible_message("[user] [response_disarm_continuous] [name]!", \
+ "[user] [response_disarm_continuous] you!", null, COMBAT_MESSAGE_RANGE, user)
+ to_chat(user, "You [response_disarm_simple] [name]!")
+ log_combat(user, src, "disarmed")
+ else
+ var/damage = rand(15, 30)
+ visible_message("[user] slashes at [src]!", \
+ "You're slashed at by [user]!", null, COMBAT_MESSAGE_RANGE, user)
+ to_chat(user, "You slash at [src]!")
+ playsound(loc, 'sound/weapons/slice.ogg', 25, TRUE, -1)
+ attack_threshold_check(damage)
+ log_combat(user, src, "attacked")
+ return 1
+
+/mob/living/basic/attack_larva(mob/living/carbon/alien/larva/L)
+ . = ..()
+ if(. && stat != DEAD) //successful larva bite
+ var/damage = rand(5, 10)
+ . = attack_threshold_check(damage)
+ if(.)
+ L.amount_grown = min(L.amount_grown + damage, L.max_grown)
+
+/mob/living/basic/attack_basic_mob(mob/living/basic/user)
+ . = ..()
+ if(.)
+ // var/damage = rand(user.melee_damage_lower, user.melee_damage_upper) // We don't have melee_damage_lower and melee_damage_upper, kept to make this easier to understand and drop-in in the future
+ return attack_threshold_check(user.melee_damage, user.melee_damage_type)
+
+/mob/living/basic/attack_animal(mob/living/simple_animal/user)
+ . = ..()
+ if(.)
+ // var/damage = rand(user.melee_damage_lower, user.melee_damage_upper) // We don't have melee_damage_lower and melee_damage_upper, kept to make this easier to understand and drop-in in the future
+ return attack_threshold_check(user.melee_damage, user.melee_damage_type)
+
+/mob/living/basic/attack_slime(mob/living/simple_animal/slime/M)
+ if(..()) //successful slime attack
+ var/damage = 20
+ if(M.is_adult)
+ damage = 30
+ if(M.transformeffects & SLIME_EFFECT_RED)
+ damage *= 1.1
+ return attack_threshold_check(damage)
+
+/mob/living/basic/attack_drone(mob/living/simple_animal/drone/M)
+ if(M.a_intent == INTENT_HARM) //No kicking dogs even as a rogue drone. Use a weapon.
+ return
+ return ..()
+
+/mob/living/basic/proc/attack_threshold_check(damage, damagetype = BRUTE, armorcheck = MELEE, actuallydamage = TRUE)
+ var/temp_damage = damage
+ if(!damage_coeff[damagetype])
+ temp_damage = 0
+ else
+ temp_damage *= damage_coeff[damagetype]
+
+ if(temp_damage >= 0 && temp_damage <= force_threshold)
+ visible_message("[src] looks unharmed.")
+ return FALSE
+ else
+ apply_damage(damage, damagetype, null, getarmor(null, armorcheck))
+ return TRUE
+
+/mob/living/basic/bullet_act(obj/projectile/Proj, def_zone, piercing_hit = FALSE)
+ apply_damage(Proj.damage, Proj.damage_type)
+ Proj.on_hit(src, 0, piercing_hit)
+ return BULLET_ACT_HIT
+
+/mob/living/basic/ex_act(severity, target, origin)
+ if(origin && istype(origin, /datum/spacevine_mutation) && isvineimmune(src))
+ return FALSE
+
+ ..()
+ if(QDELETED(src))
+ return
+ var/bomb_armor = getarmor(null, BOMB)
+ switch (severity)
+ if (EXPLODE_DEVASTATE)
+ if(prob(bomb_armor))
+ adjustBruteLoss(500)
+ else
+ gib()
+ return
+ if (EXPLODE_HEAVY)
+ var/bloss = 60
+ if(prob(bomb_armor))
+ bloss = bloss / 1.5
+ adjustBruteLoss(bloss)
+
+ if (EXPLODE_LIGHT)
+ var/bloss = 30
+ if(prob(bomb_armor))
+ bloss = bloss / 1.5
+ adjustBruteLoss(bloss)
+
+/mob/living/basic/blob_act(obj/structure/blob/B)
+ adjustBruteLoss(20)
+ return
+
+/mob/living/basic/do_attack_animation(atom/A, visual_effect_icon, used_item, no_effect)
+ if(!no_effect && !visual_effect_icon && melee_damage)
+ if(melee_damage < 10)
+ visual_effect_icon = ATTACK_EFFECT_PUNCH
+ else
+ visual_effect_icon = ATTACK_EFFECT_SMASH
+ ..()
+
+
+/mob/living/basic/update_stat()
+ if(status_flags & GODMODE)
+ return
+ if(stat != DEAD)
+ if(health <= 0)
+ death()
+ else
+ set_stat(CONSCIOUS)
+ med_hud_set_status()
diff --git a/code/modules/mob/living/basic/health_adjustment.dm b/code/modules/mob/living/basic/health_adjustment.dm
new file mode 100644
index 0000000000000..8354d1424ef27
--- /dev/null
+++ b/code/modules/mob/living/basic/health_adjustment.dm
@@ -0,0 +1,56 @@
+/**
+ * Adjusts the health of a simple mob by a set amount and wakes AI if its idle to react
+ *
+ * Arguments:
+ * * amount The amount that will be used to adjust the mob's health
+ * * updating_health If the mob's health should be immediately updated to the new value
+ * * forced If we should force update the adjustment of the mob's health no matter the restrictions, like GODMODE
+ */
+/mob/living/basic/proc/adjust_health(amount, updating_health = TRUE, forced = FALSE)
+ . = FALSE
+ if(forced || !(status_flags & GODMODE))
+ bruteloss = round(clamp(bruteloss + amount, 0, maxHealth * 2), DAMAGE_PRECISION)
+ if(updating_health)
+ updatehealth()
+ . = amount
+ if(ckey || stat)
+ return
+ //if(AIStatus == AI_IDLE)
+ // toggle_ai(AI_ON)
+
+/mob/living/basic/adjustBruteLoss(amount, updating_health = TRUE, forced = FALSE)
+ if(forced)
+ . = adjust_health(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else if(damage_coeff[BRUTE])
+ . = adjust_health(amount * damage_coeff[BRUTE] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+
+/mob/living/basic/adjustFireLoss(amount, updating_health = TRUE, forced = FALSE)
+ if(forced)
+ . = adjust_health(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else if(damage_coeff[BURN])
+ . = adjust_health(amount * damage_coeff[BURN] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+
+/mob/living/basic/adjustOxyLoss(amount, updating_health = TRUE, forced = FALSE)
+ if(forced)
+ . = adjust_health(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else if(damage_coeff[OXY])
+ . = adjust_health(amount * damage_coeff[OXY] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+
+/mob/living/basic/adjustToxLoss(amount, updating_health = TRUE, forced = FALSE)
+ if(forced)
+ . = adjust_health(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else if(damage_coeff[TOX])
+ . = adjust_health(amount * damage_coeff[TOX] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+
+/mob/living/basic/adjustCloneLoss(amount, updating_health = TRUE, forced = FALSE)
+ if(forced)
+ . = adjust_health(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else if(damage_coeff[CLONE])
+ . = adjust_health(amount * damage_coeff[CLONE] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+
+/mob/living/basic/adjustStaminaLoss(amount, updating_health = FALSE, forced = FALSE)
+ if(forced)
+ staminaloss = max(0, min(BASIC_MOB_MAX_STAMINALOSS, staminaloss + amount))
+ else
+ staminaloss = max(0, min(BASIC_MOB_MAX_STAMINALOSS, staminaloss + (amount * damage_coeff[STAMINA])))
+ update_stamina()
diff --git a/code/modules/mob/living/basic/vermin/cockroach.dm b/code/modules/mob/living/basic/vermin/cockroach.dm
new file mode 100644
index 0000000000000..e6aa05dfc459f
--- /dev/null
+++ b/code/modules/mob/living/basic/vermin/cockroach.dm
@@ -0,0 +1,58 @@
+/mob/living/basic/cockroach
+ name = "cockroach"
+ desc = "This station is just crawling with bugs."
+ icon_state = "cockroach"
+ icon_dead = "cockroach" //Make this work
+ density = FALSE
+ mob_biotypes = list(MOB_ORGANIC, MOB_BUG)
+ mob_size = MOB_SIZE_TINY
+ health = 1
+ maxHealth = 1
+ speed = 1.25
+ gold_core_spawnable = FRIENDLY_SPAWN
+ pass_flags = PASSTABLE | PASSMOB
+ ventcrawler = VENTCRAWLER_ALWAYS
+
+ verb_say = "chitters"
+ verb_ask = "chitters inquisitively"
+ verb_exclaim = "chitters loudly"
+ verb_yell = "chitters loudly"
+ response_disarm_continuous = "shoos"
+ response_disarm_simple = "shoo"
+ response_harm_continuous = "splats"
+ response_harm_simple = "splat"
+ speak_emote = list("chitters")
+
+ basic_mob_flags = DEL_ON_DEATH
+ faction = list("hostile")
+
+ ai_controller = /datum/ai_controller/basic_controller/cockroach
+
+/mob/living/basic/cockroach/Initialize()
+ . = ..()
+ AddElement(/datum/element/death_drops, list(/obj/effect/decal/cleanable/insectguts))
+ // AddElement(/datum/element/swabable, CELL_LINE_TABLE_COCKROACH, CELL_VIRUS_TABLE_GENERIC_MOB, 1, 7) //Bee edit: No swabable elements
+ AddElement(/datum/element/basic_body_temp_sensetive, 270, INFINITY)
+ AddComponent(/datum/component/squashable, squash_chance = 50, squash_damage = 1)
+
+/mob/living/basic/cockroach/death(gibbed)
+ if(SSticker.mode.station_was_nuked) //If the nuke is going off, then cockroaches are invincible. Keeps the nuke from killing them, cause cockroaches are immune to nukes.
+ return
+ ..()
+
+/mob/living/basic/cockroach/ex_act() //Explosions are a terrible way to handle a cockroach.
+ return FALSE
+
+
+/datum/ai_controller/basic_controller/cockroach
+ blackboard = list(
+ BB_TARGETTING_DATUM = new /datum/targetting_datum/basic()
+ )
+
+ ai_traits = STOP_MOVING_WHEN_PULLED
+ ai_movement = /datum/ai_movement/basic_avoidance
+ idle_behavior = /datum/idle_behavior/idle_random_walk
+ planning_subtrees = list(
+ /datum/ai_planning_subtree/random_speech/cockroach,
+ /datum/ai_planning_subtree/find_and_hunt_target/cockroach,
+ )
diff --git a/code/modules/mob/living/basic/vermin/mothroach.dm b/code/modules/mob/living/basic/vermin/mothroach.dm
new file mode 100644
index 0000000000000..6250a3ac80a63
--- /dev/null
+++ b/code/modules/mob/living/basic/vermin/mothroach.dm
@@ -0,0 +1,61 @@
+/mob/living/basic/mothroach
+ name = "mothroach"
+ desc = "This is the adorable by-product of multiple attempts at genetically mixing mothpeople with cockroaches."
+ icon_state = "mothroach"
+ icon_living = "mothroach"
+ icon_dead = "mothroach_dead"
+ held_state = "mothroach"
+ held_lh = 'icons/mob/pets_held_lh.dmi'
+ held_rh = 'icons/mob/pets_held_rh.dmi'
+ head_icon = 'icons/mob/pets_held.dmi'
+ butcher_results = list(/obj/item/reagent_containers/food/snacks/meat/slab/mothroach = 3, /obj/item/stack/sheet/animalhide/mothroach = 1)
+ density = TRUE
+ mob_biotypes = list(MOB_ORGANIC, MOB_BUG)
+ mob_size = MOB_SIZE_SMALL
+ mobility_flags = MOBILITY_FLAGS_DEFAULT
+ health = 25
+ maxHealth = 25
+ speed = 1.25
+ gold_core_spawnable = FRIENDLY_SPAWN
+ can_be_held = TRUE
+ worn_slot_flags = ITEM_SLOT_HEAD
+ ventcrawler = VENTCRAWLER_ALWAYS
+
+ verb_say = "flutters"
+ verb_ask = "flutters inquisitively"
+ verb_exclaim = "flutters loudly"
+ verb_yell = "flutters loudly"
+ response_disarm_continuous = "shoos"
+ response_disarm_simple = "shoo"
+ response_harm_continuous = "hits"
+ response_harm_simple = "hit"
+ response_help_continuous = "pats"
+ response_help_simple = "pat"
+
+ faction = list("neutral")
+
+ ai_controller = /datum/ai_controller/basic_controller/mothroach
+
+/mob/living/basic/mothroach/Initialize(mapload)
+ . = ..()
+ AddElement(/datum/element/pet_bonus, "squeaks happily!", emote_sound = 'sound/voice/moth/scream_moth.ogg')
+
+/mob/living/basic/mothroach/update_resting()
+ . = ..()
+ if(stat == DEAD)
+ return
+ if(resting)
+ icon_state = "[icon_living]_rest"
+ else
+ icon_state = "[icon_living]"
+
+/datum/ai_controller/basic_controller/mothroach
+ blackboard = list()
+
+ ai_traits = STOP_MOVING_WHEN_PULLED
+ ai_movement = /datum/ai_movement/basic_avoidance
+ idle_behavior = /datum/idle_behavior/idle_random_walk
+ planning_subtrees = list(
+ /datum/ai_planning_subtree/random_speech/mothroach,
+ /datum/ai_planning_subtree/find_and_hunt_target/mothroach,
+ )
diff --git a/code/modules/mob/living/carbon/alien/special/facehugger.dm b/code/modules/mob/living/carbon/alien/special/facehugger.dm
index fba3b5b2d374a..658098e439271 100644
--- a/code/modules/mob/living/carbon/alien/special/facehugger.dm
+++ b/code/modules/mob/living/carbon/alien/special/facehugger.dm
@@ -98,6 +98,7 @@
Die()
/obj/item/clothing/mask/facehugger/equipped(mob/M)
+ . = ..()
Attach(M)
compile_monkey_icon()
diff --git a/code/modules/mob/living/carbon/carbon_movement.dm b/code/modules/mob/living/carbon/carbon_movement.dm
index a6eed2ac91047..ee3e69b02cafd 100644
--- a/code/modules/mob/living/carbon/carbon_movement.dm
+++ b/code/modules/mob/living/carbon/carbon_movement.dm
@@ -1,4 +1,5 @@
/mob/living/carbon/slip(knockdown_amount, obj/O, lube, paralyze, force_drop)
+
if(movement_type & FLYING)
return FALSE
if((lube & NO_SLIP_ON_CATWALK) && (locate(/obj/structure/lattice/catwalk) in get_turf(src)))
@@ -19,6 +20,7 @@
/mob/living/carbon/Move(NewLoc, direct)
. = ..()
+
if(. && !(movement_type & FLOATING)) //floating is easy
if(HAS_TRAIT(src, TRAIT_NOHUNGER))
set_nutrition(NUTRITION_LEVEL_FED - 1) //just less than feeling vigorous
diff --git a/code/modules/mob/living/carbon/human/emote.dm b/code/modules/mob/living/carbon/human/emote.dm
index 7c34a80138d70..50cc5b4c9493d 100644
--- a/code/modules/mob/living/carbon/human/emote.dm
+++ b/code/modules/mob/living/carbon/human/emote.dm
@@ -63,14 +63,14 @@
/datum/emote/living/carbon/human/moth
// allow mothroach as well as human base mob - species check is done in can_run_emote
- mob_type_allowed_typecache = list(/mob/living/carbon/human,/mob/living/simple_animal/mothroach)
+ mob_type_allowed_typecache = list(/mob/living/carbon/human,/mob/living/basic/mothroach)
/datum/emote/living/carbon/human/moth/can_run_emote(mob/user, status_check = TRUE, intentional)
if(!..())
return FALSE
if(ishuman(user))
return ismoth(user)
- return istype(user, /mob/living/simple_animal/mothroach)
+ return istype(user, /mob/living/basic/mothroach)
/datum/emote/living/carbon/human/moth/squeak
key = "msqueak"
diff --git a/code/modules/mob/living/carbon/human/human_defense.dm b/code/modules/mob/living/carbon/human/human_defense.dm
index 638da6cbfec76..46103244cabed 100644
--- a/code/modules/mob/living/carbon/human/human_defense.dm
+++ b/code/modules/mob/living/carbon/human/human_defense.dm
@@ -297,6 +297,20 @@
var/armor_block = run_armor_check(affecting, MELEE)
apply_damage(damage, BRUTE, affecting, armor_block)
+/mob/living/carbon/human/attack_basic_mob(mob/living/basic/user)
+ . = ..()
+ if(!.)
+ return
+ if(check_shields(user, user.melee_damage, "the [user.name]", MELEE_ATTACK, user.armour_penetration))
+ return FALSE
+ var/dam_zone = dismembering_strike(user, pick(BODY_ZONE_CHEST, BODY_ZONE_PRECISE_L_HAND, BODY_ZONE_PRECISE_R_HAND, BODY_ZONE_L_LEG, BODY_ZONE_R_LEG))
+ if(!dam_zone) //Dismemberment successful
+ return TRUE
+ var/obj/item/bodypart/affecting = get_bodypart(ran_zone(dam_zone))
+ if(!affecting)
+ affecting = get_bodypart(BODY_ZONE_CHEST)
+ var/armor = run_armor_check(affecting, MELEE, armour_penetration = user.armour_penetration)
+ apply_damage(user.melee_damage, user.melee_damage_type, affecting, armor)
/mob/living/carbon/human/attack_animal(mob/living/simple_animal/M)
. = ..()
diff --git a/code/modules/mob/living/death.dm b/code/modules/mob/living/death.dm
index f566587adbdc7..7737f0629daa1 100644
--- a/code/modules/mob/living/death.dm
+++ b/code/modules/mob/living/death.dm
@@ -82,6 +82,8 @@
. = ..()
+ SEND_SIGNAL(src, COMSIG_LIVING_DEATH, gibbed)
+
if (client)
reset_perspective(null)
reload_fullscreen()
diff --git a/code/modules/mob/living/emote.dm b/code/modules/mob/living/emote.dm
index 60b7617bb8cb5..52324e53efcf4 100644
--- a/code/modules/mob/living/emote.dm
+++ b/code/modules/mob/living/emote.dm
@@ -506,7 +506,7 @@
message_insect = "clicks their mandibles"
/datum/emote/living/click/get_sound(mob/living/user)
- if(ismoth(user) || isapid(user) || isflyperson(user) || istype(user, /mob/living/simple_animal/mothroach))
+ if(ismoth(user) || isapid(user) || isflyperson(user) || istype(user, /mob/living/basic/mothroach))
return 'sound/creatures/rattle.ogg'
else if(isipc(user))
return 'sound/machines/click.ogg'
diff --git a/code/modules/mob/living/life.dm b/code/modules/mob/living/life.dm
index b2387d30bef8c..c46708605ee37 100644
--- a/code/modules/mob/living/life.dm
+++ b/code/modules/mob/living/life.dm
@@ -58,6 +58,8 @@
return 1
/mob/living/proc/handle_breathing(times_fired)
+ // SEND_SIGNAL(src, COMSIG_LIVING_HANDLE_BREATHING, delta_time, times_fired)
+ SEND_SIGNAL(src, COMSIG_LIVING_HANDLE_BREATHING, SSMOBS_DT, times_fired) //Bee edit: Holy shit I do not want to port delta time Life() refactor just for my mothroach behavior to be better
return
/mob/living/proc/handle_mutations_and_radiation()
diff --git a/code/modules/mob/living/living.dm b/code/modules/mob/living/living.dm
index 7abfb6a63f473..b5c5e511ad380 100644
--- a/code/modules/mob/living/living.dm
+++ b/code/modules/mob/living/living.dm
@@ -22,6 +22,8 @@
addtimer(CALLBACK(src, PROC_REF(set_playable)), 2 SECONDS) //announce playable mobs to ghosts
// this should be delayed because some 'playable=TRUE' mobs are not actually playable because mob key is automatically given
// it prevents 'GLOB.poi_list' being glitched. without this, it will show xeno(or some mobs) twice in orbit panel.
+ //color correction
+ RegisterSignal(src, COMSIG_MOVABLE_ENTERED_AREA, PROC_REF(apply_color_correction))
/mob/living/proc/initialize_footstep()
AddComponent(/datum/component/footstep)
@@ -1436,3 +1438,11 @@
layer = initial(layer)
if(.) //We weren't pone before, so we become dense and things can bump into us again.
density = initial(density)
+
+//Used for applying color correction
+/mob/living/proc/apply_color_correction(datum/source, area/entered)
+ SIGNAL_HANDLER
+
+ remove_client_colour(current_correction)
+ add_client_colour(entered.color_correction)
+ current_correction = entered.color_correction
diff --git a/code/modules/mob/living/living_defense.dm b/code/modules/mob/living/living_defense.dm
index 4ecc29f5fd6b1..bfc9b490d2a8e 100644
--- a/code/modules/mob/living/living_defense.dm
+++ b/code/modules/mob/living/living_defense.dm
@@ -257,6 +257,26 @@
"\The [M.name] glomps you!", null, COMBAT_MESSAGE_RANGE)
return TRUE
+/mob/living/attack_basic_mob(mob/living/basic/user)
+ if(user.melee_damage == 0)
+ if(user != src)
+ visible_message("\The [user] [user.friendly_verb_continuous] [src]!", \
+ "\The [user] [user.friendly_verb_continuous] you!", null, COMBAT_MESSAGE_RANGE, user)
+ to_chat(user, "You [user.friendly_verb_simple] [src]!")
+ return FALSE
+ if(HAS_TRAIT(user, TRAIT_PACIFISM))
+ to_chat(user, "You don't want to hurt anyone!")
+ return FALSE
+
+ if(user.attack_sound)
+ playsound(loc, user.attack_sound, 50, TRUE, TRUE)
+ user.do_attack_animation(src)
+ visible_message("\The [user] [user.attack_verb_continuous] [src]!", \
+ "\The [user] [user.attack_verb_continuous] you!", null, COMBAT_MESSAGE_RANGE, user)
+ to_chat(user, "You [user.attack_verb_simple] [src]!")
+ log_combat(user, src, "attacked")
+ return TRUE
+
/mob/living/attack_animal(mob/living/simple_animal/M)
M.face_atom(src)
if(M.melee_damage == 0)
diff --git a/code/modules/mob/living/silicon/laws.dm b/code/modules/mob/living/silicon/laws.dm
index 7e575f4091648..e4e1c1a7a0efa 100644
--- a/code/modules/mob/living/silicon/laws.dm
+++ b/code/modules/mob/living/silicon/laws.dm
@@ -14,9 +14,12 @@
throw_alert("newlaw", /atom/movable/screen/alert/newlaw)
if(announce && last_lawchange_announce != world.time)
to_chat(src, "Your laws have been changed.")
+ overlay_fullscreen("law_change", /atom/movable/screen/fullscreen/law_change, 1)
// lawset modules cause this function to be executed multiple times in a tick, so we wait for the next tick in order to be able to see the entire lawset
addtimer(CALLBACK(src, PROC_REF(show_laws)), 0)
addtimer(CALLBACK(src, PROC_REF(deadchat_lawchange)), 0)
+ // Wait a tick and clear the vignette
+ addtimer(CALLBACK(src, PROC_REF(clear_fullscreen), "law_change"), 0.2 SECONDS)
last_lawchange_announce = world.time
/mob/living/silicon/proc/set_law_sixsixsix(law, announce = TRUE)
diff --git a/code/modules/mob/living/simple_animal/animal_defense.dm b/code/modules/mob/living/simple_animal/animal_defense.dm
index b1cd3a0e3e884..67a7ea5dbff75 100644
--- a/code/modules/mob/living/simple_animal/animal_defense.dm
+++ b/code/modules/mob/living/simple_animal/animal_defense.dm
@@ -90,6 +90,11 @@
if(.)
L.amount_grown = min(L.amount_grown + damage, L.max_grown)
+/mob/living/simple_animal/attack_basic_mob(mob/living/basic/user, list/modifiers)
+ . = ..()
+ if(.)
+ return attack_threshold_check(user.melee_damage, user.melee_damage_type)
+
/mob/living/simple_animal/attack_animal(mob/living/simple_animal/M)
. = ..()
if(.)
diff --git a/code/modules/mob/living/simple_animal/bot/atmosbot.dm b/code/modules/mob/living/simple_animal/bot/atmosbot.dm
index db8a35f75bee6..6a42640d86618 100644
--- a/code/modules/mob/living/simple_animal/bot/atmosbot.dm
+++ b/code/modules/mob/living/simple_animal/bot/atmosbot.dm
@@ -1,8 +1,8 @@
#define ATMOSBOT_MAX_AREA_SCAN 100
#define ATMOSBOT_HOLOBARRIER_COOLDOWN 150
-#define ATMOSBOT_MAX_PRESSURE_CHANGE 150
-#define ATMOSBOT_MAX_SCRUB_CHANGE 15
+#define ATMOSBOT_MAX_PRESSURE_CHANGE 1
+#define ATMOSBOT_MAX_SCRUB_CHANGE 0.4
#define ATMOSBOT_CHECK_BREACH 0
#define ATMOSBOT_LOW_OXYGEN 1
@@ -63,8 +63,14 @@
GAS_TRITIUM = 1,
GAS_H2O = 0,
)
+ // Have we spoken our alert yet?
+ var/has_spoken = FALSE
//Tank type
var/tank_type = /obj/item/tank/internals/oxygen/empty
+ // The range that our atmos operations act on
+ var/atmos_range = 3
+ // Last time we spoke
+ var/last_speech
/mob/living/simple_animal/bot/atmosbot/Initialize(mapload, new_toolbox_color)
. = ..()
@@ -117,20 +123,26 @@
else
target = get_vent_turf()
action = ATMOSBOT_VENT_AIR
+ try_speak("Low pressure detected at [get_area(src)], attempting to detect and isolate breach...")
if(ATMOSBOT_LOW_OXYGEN)
target = get_vent_turf()
action = ATMOSBOT_VENT_AIR
+ try_speak("Low oxygen detected at [get_area(src)].")
if(ATMOSBOT_HIGH_TOXINS)
target = get_vent_turf()
action = ATMOSBOT_SCRUB_TOXINS
+ try_speak("Toxic contaminants in the atmosphere have been detected at [get_area(src)].")
if(ATMOSBOT_BAD_TEMP)
target = get_vent_turf()
action = ATMOSBOT_TEMPERATURE_CONTROL
+ try_speak("The atmospheric temperature in [get_area(src)] exceeds allowed operating limits.")
if(ATMOSBOT_AREA_STABLE)
if(emagged == 2)
if(prob(20))
target = get_vent_turf()
action = ATMOSBOT_VENT_AIR
+ else
+ has_spoken = FALSE
update_icon()
if(!target)
@@ -176,6 +188,13 @@
mode = BOT_IDLE
return
+/mob/living/simple_animal/bot/atmosbot/proc/try_speak(message)
+ if (has_spoken || last_speech > world.time + 3 MINUTES)
+ return
+ has_spoken = TRUE
+ last_speech = world.time
+ speak(message, radio_channel)
+
/mob/living/simple_animal/bot/atmosbot/proc/change_temperature()
var/turf/T = get_turf(src)
var/datum/gas_mixture/environment = T.return_air()
@@ -183,30 +202,35 @@
/mob/living/simple_animal/bot/atmosbot/proc/vent_air()
//Just start pumping out air
- var/turf/T = get_turf(src)
-
- var/datum/gas_mixture/environment = T.return_air()
- var/environment_pressure = environment.return_pressure()
+ var/turf/source_turf = get_turf(src)
+ for (var/turf/T in RANGE_TURFS(atmos_range, src))
+ if (!inLineOfSight(source_turf.x, source_turf.y, T.x, T.y, T.z))
+ continue
+ var/datum/gas_mixture/environment = T.return_air()
+ var/environment_pressure = environment.return_pressure()
- var/pressure_delta = min(ATMOSBOT_MAX_PRESSURE_CHANGE, (ONE_ATMOSPHERE - environment_pressure))
+ var/pressure_delta = min(ATMOSBOT_MAX_PRESSURE_CHANGE, (ONE_ATMOSPHERE - environment_pressure))
- if(pressure_delta > 0)
- var/transfer_moles = pressure_delta*environment.return_volume()/(T20C * R_IDEAL_GAS_EQUATION)
- if(emagged == 2)
- environment.adjust_moles(GAS_CO2, transfer_moles)
- else
- environment.adjust_moles(GAS_N2, transfer_moles * 0.7885)
- environment.adjust_moles(GAS_O2, transfer_moles * 0.2115)
- air_update_turf()
- new /obj/effect/temp_visual/vent_wind(get_turf(src))
+ if(pressure_delta > 0)
+ var/transfer_moles = pressure_delta*environment.return_volume()/(T20C * R_IDEAL_GAS_EQUATION)
+ if(emagged == 2)
+ environment.adjust_moles(GAS_CO2, transfer_moles)
+ else
+ environment.adjust_moles(GAS_N2, transfer_moles * 0.7885)
+ environment.adjust_moles(GAS_O2, transfer_moles * 0.2115)
+ air_update_turf()
+ new /obj/effect/temp_visual/vent_wind(get_turf(src))
/mob/living/simple_animal/bot/atmosbot/proc/scrub_toxins()
- var/turf/T = get_turf(src)
- var/datum/gas_mixture/environment = T.return_air()
- for(var/G in gasses)
- if(gasses[G])
- var/moles_in_atmos = environment.get_moles(G)
- environment.adjust_moles(G, -min(moles_in_atmos, ATMOSBOT_MAX_SCRUB_CHANGE))
+ var/turf/source_turf = get_turf(src)
+ for (var/turf/T in RANGE_TURFS(atmos_range, src))
+ if (!inLineOfSight(source_turf.x, source_turf.y, T.x, T.y, T.z))
+ continue
+ var/datum/gas_mixture/environment = T.return_air()
+ for(var/G in gasses)
+ if(gasses[G])
+ var/moles_in_atmos = environment.get_moles(G)
+ environment.adjust_moles(G, -min(moles_in_atmos, ATMOSBOT_MAX_SCRUB_CHANGE))
/mob/living/simple_animal/bot/atmosbot/proc/deploy_holobarrier()
if(deployed_holobarrier)
@@ -270,12 +294,21 @@
break
if(blocked || !checking_turf.CanAtmosPass(checking_turf))
continue
+ var/datum/gas_mixture/current_air = checking_turf.return_air()
+ if (!current_air)
+ continue
+ var/current_pressure = current_air.return_pressure()
//Add adjacent turfs
for(var/direction in list(NORTH, SOUTH, EAST, WEST))
var/turf/adjacent_turf = get_step(checking_turf, direction)
- if(adjacent_turf in checked_turfs || !adjacent_turf.CanAtmosPass(adjacent_turf) || istype(adjacent_turf.loc, /area/space))
+ if(adjacent_turf in checked_turfs || !adjacent_turf.CanAtmosPass(adjacent_turf))
+ continue
+ var/datum/gas_mixture/checking_air = checking_turf.return_air()
+ if (!checking_air)
continue
- if(isspaceturf(adjacent_turf))
+ var/checking_pressure = checking_air.return_pressure()
+ // If the pressure difference is high or its a space turf, place a shield wall here
+ if (abs(checking_pressure - current_pressure) > 30 || isspaceturf(adjacent_turf))
return checking_turf
to_check_turfs |= adjacent_turf
return null
diff --git a/code/modules/mob/living/simple_animal/bot/cleanbot.dm b/code/modules/mob/living/simple_animal/bot/cleanbot.dm
index 9ce25751af005..b4c64ad9fd61f 100644
--- a/code/modules/mob/living/simple_animal/bot/cleanbot.dm
+++ b/code/modules/mob/living/simple_animal/bot/cleanbot.dm
@@ -198,7 +198,7 @@
target_types += /obj/effect/decal/cleanable/trail_holder
if(pests)
- target_types += /mob/living/simple_animal/cockroach
+ target_types += /mob/living/basic/cockroach
target_types += /mob/living/simple_animal/mouse
if(drawn)
@@ -220,7 +220,7 @@
visible_message("[src] sprays hydrofluoric acid at [A]!")
playsound(src, 'sound/effects/spray2.ogg', 50, 1, -6)
A.acid_act(75, 10)
- else if(istype(A, /mob/living/simple_animal/cockroach) || istype(A, /mob/living/simple_animal/mouse))
+ else if(istype(A, /mob/living/basic/cockroach) || istype(A, /mob/living/simple_animal/mouse))
var/mob/living/simple_animal/M = target
if(!M.stat)
visible_message("[src] smashes [target] with its mop!")
@@ -334,7 +334,7 @@
visible_message("[src] sprays hydrofluoric acid at [A]!")
playsound(src, 'sound/effects/spray2.ogg', 50, 1, -6)
A.acid_act(75, 10)
- else if(istype(A, /mob/living/simple_animal/cockroach) || istype(A, /mob/living/simple_animal/mouse))
+ else if(istype(A, /mob/living/basic/cockroach) || istype(A, /mob/living/simple_animal/mouse))
var/mob/living/simple_animal/M = target
if(!M.stat)
visible_message("[src] smashes [target] with its mop!")
diff --git a/code/modules/mob/living/simple_animal/friendly/cockroach.dm b/code/modules/mob/living/simple_animal/friendly/cockroach.dm
deleted file mode 100644
index b7db4a6a5cbf2..0000000000000
--- a/code/modules/mob/living/simple_animal/friendly/cockroach.dm
+++ /dev/null
@@ -1,64 +0,0 @@
-/mob/living/simple_animal/cockroach
- name = "cockroach"
- desc = "This station is just crawling with bugs."
- icon_state = "cockroach"
- icon_dead = "cockroach"
- health = 1
- maxHealth = 1
- turns_per_move = 5
- loot = list(/obj/effect/decal/cleanable/insectguts)
- atmos_requirements = list("min_oxy" = 0, "max_oxy" = 0, "min_tox" = 0, "max_tox" = 0, "min_co2" = 0, "max_co2" = 0, "min_n2" = 0, "max_n2" = 0)
- minbodytemp = 270
- maxbodytemp = INFINITY
- pass_flags = PASSTABLE | PASSMOB
- mob_size = MOB_SIZE_TINY
- mob_biotypes = list(MOB_ORGANIC, MOB_BUG)
- response_help = "pokes"
- response_disarm = "shoos"
- response_harm = "splats"
- speak_emote = list("chitters")
- density = FALSE
- ventcrawler = VENTCRAWLER_ALWAYS
- gold_core_spawnable = FRIENDLY_SPAWN
- verb_say = "chitters"
- verb_ask = "chitters inquisitively"
- verb_exclaim = "chitters loudly"
- verb_yell = "chitters loudly"
- var/squish_chance = 50
- del_on_death = TRUE
- chat_color = "#BC7658"
-
-/mob/living/simple_animal/cockroach/Initialize(mapload)
- . = ..()
- var/static/list/loc_connections = list(
- COMSIG_ATOM_ENTERED = PROC_REF(on_entered),
- )
- AddElement(/datum/element/connect_loc, loc_connections)
-
-/mob/living/simple_animal/cockroach/death(gibbed)
- if(SSticker.mode && SSticker.mode.station_was_nuked) //If the nuke is going off, then cockroaches are invincible. Keeps the nuke from killing them, cause cockroaches are immune to nukes.
- return
- ..()
-
-/mob/living/simple_animal/cockroach/proc/on_entered(datum/source ,var/atom/movable/AM)
- SIGNAL_HANDLER
-
- if(ismob(AM))
- if(isliving(AM))
- var/mob/living/A = AM
- if(A.mob_size > MOB_SIZE_SMALL && !(A.movement_type & FLYING))
- if(prob(squish_chance))
- A.visible_message("[A] squashed [src].", "You squashed [src].")
- adjustBruteLoss(1) //kills a normal cockroach
- else
- visible_message("[src] avoids getting crushed.")
- else
- if(isstructure(AM))
- if(prob(squish_chance))
- AM.visible_message("[src] was crushed under [AM].")
- adjustBruteLoss(1)
- else
- visible_message("[src] avoids getting crushed.")
-
-/mob/living/simple_animal/cockroach/ex_act() //Explosions are a terrible way to handle a cockroach.
- return
diff --git a/code/modules/mob/living/simple_animal/friendly/lizard.dm b/code/modules/mob/living/simple_animal/friendly/lizard.dm
index 7bc3de052c4dc..a171d3e6a0cd8 100644
--- a/code/modules/mob/living/simple_animal/friendly/lizard.dm
+++ b/code/modules/mob/living/simple_animal/friendly/lizard.dm
@@ -21,7 +21,7 @@
gold_core_spawnable = FRIENDLY_SPAWN
obj_damage = 0
environment_smash = ENVIRONMENT_SMASH_NONE
- var/static/list/edibles = typecacheof(list(/mob/living/simple_animal/butterfly, /mob/living/simple_animal/cockroach)) //list of atoms, however turfs won't affect AI, but will affect consumption.
+ var/static/list/edibles = typecacheof(list(/mob/living/simple_animal/butterfly, /mob/living/basic/cockroach)) //list of atoms, however turfs won't affect AI, but will affect consumption.
chat_color = "#64F88A"
/mob/living/simple_animal/hostile/lizard/CanAttack(atom/the_target)//Can we actually attack a possible target?
diff --git a/code/modules/mob/living/simple_animal/friendly/mothroach.dm b/code/modules/mob/living/simple_animal/friendly/mothroach.dm
deleted file mode 100644
index 44067b1524f4c..0000000000000
--- a/code/modules/mob/living/simple_animal/friendly/mothroach.dm
+++ /dev/null
@@ -1,41 +0,0 @@
-/mob/living/simple_animal/mothroach
- name = "mothroach"
- desc = "An ancient ancestor of the moth that surprisingly looks like the crossbreed of a moth and a cockroach."
- icon_state = "mothroach"
- icon_living = "mothroach"
- icon_dead = "mothroach_dead"
- held_state = "mothroach"
- held_lh = 'icons/mob/pets_held_lh.dmi'
- held_rh = 'icons/mob/pets_held_rh.dmi'
- head_icon = 'icons/mob/pets_held.dmi'
- butcher_results = list(/obj/item/reagent_containers/food/snacks/meat/slab/mothroach = 3, /obj/item/stack/sheet/animalhide/mothroach = 1)
- gold_core_spawnable = FRIENDLY_SPAWN
- density = TRUE
- mob_biotypes = list(MOB_ORGANIC, MOB_BUG)
- mob_size = MOB_SIZE_SMALL
- health = 5
- maxHealth = 5
- speed = 1.25
- mobility_flags = MOBILITY_FLAGS_DEFAULT
- can_be_held = TRUE
- worn_slot_flags = ITEM_SLOT_HEAD
- ventcrawler = VENTCRAWLER_ALWAYS
-
- verb_say = "flutters"
- verb_ask = "flutters inquisitively"
- verb_exclaim = "flutters loudly"
- verb_yell = "flutters loudly"
- response_help = "pets"
- speak_emote = list("flutters")
- emote_hear = list("flutters.")
- speak_chance = 1
- attacked_sound = 'sound/voice/moth/scream_moth.ogg'
-
- faction = list("neutral")
-
-/mob/living/simple_animal/mothroach/update_resting()
- . = ..()
- if(resting)
- icon_state = "mothroach_rest"
- else
- icon_state = "mothroach"
diff --git a/code/modules/mob/living/simple_animal/hostile/megafauna/colossus.dm b/code/modules/mob/living/simple_animal/hostile/megafauna/colossus.dm
index 50c086a154fa3..5b83b06d32576 100644
--- a/code/modules/mob/living/simple_animal/hostile/megafauna/colossus.dm
+++ b/code/modules/mob/living/simple_animal/hostile/megafauna/colossus.dm
@@ -796,7 +796,7 @@ GLOBAL_DATUM(blackbox, /obj/machinery/smartfridge/black_box)
mobcheck = TRUE
break
if(!mobcheck)
- new /mob/living/simple_animal/cockroach(get_step(src,dir)) //Just in case there aren't any animals on the station, this will leave you with a terrible option to possess if you feel like it
+ new /mob/living/basic/cockroach(get_step(src,dir)) //Just in case there aren't any animals on the station, this will leave you with a terrible option to possess if you feel like it
/obj/structure/closet/stasis
name = "quantum entanglement stasis warp field"
diff --git a/code/modules/projectiles/guns/ballistic/pistol.dm b/code/modules/projectiles/guns/ballistic/pistol.dm
index ca89a46295943..4869eeaff4872 100644
--- a/code/modules/projectiles/guns/ballistic/pistol.dm
+++ b/code/modules/projectiles/guns/ballistic/pistol.dm
@@ -100,9 +100,9 @@
desc = "A 2 dimensional gun.. what?"
icon_state = "flatgun"
-/obj/item/gun/ballistic/automatic/pistol/stickman/pickup(mob/living/user)
+/obj/item/gun/ballistic/automatic/pistol/stickman/equipped(mob/user, slot)
..()
- to_chat(user, "As you try to pick up [src], it slips out of your grip..")
+ to_chat(user, "As you try to manipulate [src], it slips out of your possession..")
if(prob(50))
to_chat(user, "..and vanishes from your vision! Where the hell did it go?")
qdel(src)
diff --git a/code/modules/reagents/chemistry/recipes.dm b/code/modules/reagents/chemistry/recipes.dm
index 53b842c9599c5..00ff103619b36 100644
--- a/code/modules/reagents/chemistry/recipes.dm
+++ b/code/modules/reagents/chemistry/recipes.dm
@@ -42,15 +42,15 @@
C.flash_act()
for(var/i in 1 to amount_to_spawn)
- var/mob/living/simple_animal/S
+ var/mob/living/spawned_mob
if(random)
- S = create_random_mob(get_turf(holder.my_atom), mob_class)
+ spawned_mob = create_random_mob(get_turf(holder.my_atom), mob_class)
else
- S = new mob_class(get_turf(holder.my_atom))//Spawn our specific mob_class
- S.faction |= mob_faction
+ spawned_mob = new mob_class(get_turf(holder.my_atom))//Spawn our specific mob_class
+ spawned_mob.faction |= mob_faction
if(prob(50))
for(var/j in 1 to rand(1, 3))
- step(S, pick(NORTH,SOUTH,EAST,WEST))
+ step(spawned_mob, pick(NORTH,SOUTH,EAST,WEST))
///Simulates a vortex that moves nearby movable atoms towards or away from the turf T. Range also determines the strength of the effect. High values cause nearby objects to be thrown.
/proc/goonchem_vortex(turf/T, setting_type, range)
diff --git a/code/modules/religion/rites.dm b/code/modules/religion/rites.dm
index 28420c546e6f0..1b9b4bddd7aa2 100644
--- a/code/modules/religion/rites.dm
+++ b/code/modules/religion/rites.dm
@@ -686,8 +686,8 @@
..()
var/turf/altar_turf = get_turf(religious_tool)
for(var/i in 1 to 8)
- var/mob/living/simple_animal/S = create_random_mob(altar_turf, FRIENDLY_SPAWN)
- S.faction |= "neutral"
+ var/mob/living/spawned_mob = create_random_mob(altar_turf, FRIENDLY_SPAWN)
+ spawned_mob.faction |= "neutral"
playsound(altar_turf, 'sound/ambience/servicebell.ogg', 25, TRUE)
if(prob(0.1))
playsound(altar_turf, 'sound/effects/bamf.ogg', 100, TRUE)
diff --git a/code/modules/research/xenobiology/crossbreeding/burning.dm b/code/modules/research/xenobiology/crossbreeding/burning.dm
index d3b36d169f577..48c3b5dff3959 100644
--- a/code/modules/research/xenobiology/crossbreeding/burning.dm
+++ b/code/modules/research/xenobiology/crossbreeding/burning.dm
@@ -248,11 +248,11 @@ Burning extracts:
/obj/item/slimecross/burning/gold/do_effect(mob/user)
user.visible_message("[src] shudders violently, and summons an army for [user]!")
for(var/i in 1 to 3) //Less than gold normally does, since it's safer and faster.
- var/mob/living/simple_animal/S = create_random_mob(get_turf(user), HOSTILE_SPAWN)
- S.faction |= "[REF(user)]"
+ var/mob/living/spawned_mob = create_random_mob(get_turf(user), HOSTILE_SPAWN)
+ spawned_mob.faction |= "[REF(user)]"
if(prob(50))
for(var/j in 1 to rand(1, 3))
- step(S, pick(NORTH,SOUTH,EAST,WEST))
+ step(spawned_mob, pick(NORTH,SOUTH,EAST,WEST))
..()
/obj/item/slimecross/burning/oil
diff --git a/code/modules/research/xenobiology/xenobiology.dm b/code/modules/research/xenobiology/xenobiology.dm
index 60f518349e454..4ef153e4255d8 100644
--- a/code/modules/research/xenobiology/xenobiology.dm
+++ b/code/modules/research/xenobiology/xenobiology.dm
@@ -115,22 +115,22 @@
if(SLIME_ACTIVATE_MINOR)
user.visible_message("[user] starts shaking!","Your [name] starts pulsing gently...")
if(do_after(user, 4 SECONDS, target = user))
- var/mob/living/simple_animal/S = create_random_mob(user.drop_location(), FRIENDLY_SPAWN)
- S.faction |= "neutral"
+ var/mob/living/spawned_mob = create_random_mob(user.drop_location(), FRIENDLY_SPAWN)
+ spawned_mob.faction |= "neutral"
playsound(user, 'sound/effects/splat.ogg', 50, 1)
- user.visible_message("[user] spits out [S]!", "You spit out [S]!")
+ user.visible_message("[user] spits out [spawned_mob]!", "You spit out [spawned_mob]!")
return 30 SECONDS
if(SLIME_ACTIVATE_MAJOR)
user.visible_message("[user] starts shaking violently!","Your [name] starts pulsing violently...")
if(do_after(user, 5 SECONDS, target = user))
- var/mob/living/simple_animal/S = create_random_mob(user.drop_location(), HOSTILE_SPAWN)
+ var/mob/living/spawned_mob = create_random_mob(user.drop_location(), HOSTILE_SPAWN)
if(user.a_intent != INTENT_HARM)
- S.faction |= "neutral"
+ spawned_mob.faction |= "neutral"
else
- S.faction |= "slime"
+ spawned_mob.faction |= "slime"
playsound(user, 'sound/effects/splat.ogg', 50, 1)
- user.visible_message("[user] spits out [S]!", "You spit out [S]!")
+ user.visible_message("[user] spits out [spawned_mob]!", "You spit out [spawned_mob]!")
return 60 SECONDS
/obj/item/slime_extract/silver
diff --git a/html/changelog.html b/html/changelog.html
index 8c15b6f518718..0abadef83b07d 100644
--- a/html/changelog.html
+++ b/html/changelog.html
@@ -56,7 +56,42 @@
-->
+
03 October 2023
+
AMonekyThatCodes, Kylerace, tralezab, Ryll/Shaps, Melbert, ported by mystery3525 updated:
+
+ - Basic Mobs. Newer, better simple_mobs now with datumized AI behavior, allowing more interesting behavior.
+ - Mothroach web eating mechanic, with a 25 second cooldown
+ - Refactored petting certain pets into a general element, atmos_requirements element, and death_drops element
+
+
Harranhall updated:
+
+ - Added a vignette that appears momentarily when your laws are changed as AI.
+ - added the "law_change" fullscreen vignette.
+
+
+
02 October 2023
+
Absolucy updated:
+
+ - Fix broken dropdown buttons in the tgui chat settings.
+
+
DrDuckedGoose updated:
+
+ - Adds color correction to areas
+
+
PowerfulBacon updated:
+
+ - Atmosbots have been given a larger area of effect but have had the amount of gasses they transfer in a single tick reduced.
+
+
RKz, necromanceranne, Spookydonut updated:
+
+ - adds linting for equipped()
+
+
30 September 2023
+
Absolucy, Bieyes updated:
+
+ - Fixed an exploit where a holoparasite player could be sent back to the lobby after being reset. Thank you Bieyes (Theodore Cooper) for alerting me of this exploit after coming across it!
+
MMMiracles, goober3 updated:
- Ports Dirt linings and corners
@@ -902,134 +937,6 @@ mystery3525 updated:
- Logs for medical records, better format for security records logging
- Cooldown for biogenerator
-
-
01 August 2023
-
Absolucy updated:
-
- - Fixed admins seeing LOOC message senders as themselves rather the actual sender
-
-
AgentCitrus, kit-katz updated:
-
- - A visual upgrade for the supermatter: a displacement effect that worsens with damage, particles, a new delamination animation, and a subtle distortion effect left behind after a delamination
-
-
Rukofamicom updated:
-
- - Revenants can no longer phase shift inside of dense objects! There was a missing check which made this possible.
-
-
Tyranicranger4 updated:
-
- - Adds logging for when people are crushed by an emagged recycler
-
-
XeonMations, Dakae updated:
-
- - Sentient monkey helmets, orderable from cargo
- - TRAIT_MONKEYLIKE is now TRAIT_DISCOORDINATED
-
-
-
31 July 2023
-
updated:
-
- - Fixed Radstation's air mixer settings
- - Air alarm placed in correct spot in exploration preparation room
- - Fixed air in telecommunications control room.
-
-
Absolucy updated:
-
- - LOOC is much less janky now. You can properly both hear LOOC as a ghost, and both hear and talk on LOOC while inside another object (including cases such as split personalities, recalled holoparasites, desynchronized mobs, jaunting mobs)!
-
-
BriggsIDP updated:
-
- - Foliage HP decreased
- - Tree sprite shadows removed
-
-
CydiaLamiales updated:
-
- - Added the ability to change the name and description of Pill Bottles with a pen.
- - Greatly reduced the harvested pierced reality spam from the Supermatter's anomalies.
- - Fixed the Scientist crew objective targeting roundstart researched designs
-
-
HowToLoLu updated:
-
- - The SlimeLink Action Buttons no longer linger or pile up when changing between species
-
-
JixS4v updated:
-
- - H.O.N.K. mechs can now detach weapons
- - BCI components are now able to be printed
- - Separates BCI-related circuits into a new techweb node
- - Adds the thought listener component for BCIs
- - Adds a rotation component to the object overlay on BCIs
-
-
LemonInTheDark, itsmeow, Ghommie, Dennok updated:
-
- - Optimized maploading, ruin generation, and cave generation, saving ~8sec init time.
- - Optimized ChangeTurf.
- - Optimized getting area contents in some cases, although there are still many inefficient `in area` loops to clean up.
- - Fixed atom init sometimes failing when generating in round or during unit tests.
-
-
RKz updated:
-
- - Kills obj/item/projectile in favour of obj/projectile. No ingame effect, just free overhead.
-
-
RKz, Haukeschuemann updated:
-
- - cleaned up how borg radios and batteries initialize
-
-
RKz, Rohesie, Cobby updated:
-
- - makes incapacitation into a trait
-
-
itsmeow updated:
-
- - Removed unnecessary atmos init during terrain generation, saving 250ms init.
- - Removed unnecessary icon update during transit turf creation, saving 25ms init.
- - Lazy-initialized circuit USB components, saving 120ms init.
-
-
mystery3525 updated:
-
- - radstation scimaint and medmaint has been split into more separate maintenance areas, these places were massive and non-contiguous.
- - radstation armory no longer has its own backup SMES
- - radstation no longer has random shock grilles for lower-security areas such as maintenance, tool storage, chemistry, and medbay (really?)
- - radstation cables now prefer to pass through doors versus windows and machines.
-
-
wixoa, ike709 updated:
-
- - Fixed stinky code involving aimed gun speed/damage modifiers
-
-
-
30 July 2023
-
Absolucy updated:
-
- - Staffed department lighting will now properly be completely switched on at roundstart.
- - Lighting of ALL areas accessible by roundstart crewmembers (taking into account minimal or skeleton crew access) will be switched on at roundstart.
- - The bar and cafeteria now have their lights always switched on at roundstart, due to the fact they often serve as public crew gathering places, even if there is no bartender/chef tending to them.
- - Fixed a couple of typos in some area names.
- - Sound synthesizers now have a proper cooldown, preventing them from playing overlapping sounds.
-
-
EvilDragonfiend updated:
-
- - Fixed crafting menu showing incorrect result item icons
- - stripped_input() proc now has an option to choose strip method
- - designating a station name or uploading laws no longer contains `'` which is just a single quote letter.
-
-
LemonLimeSoda updated:
-
- - Photocopiers no longer print exclusively gray text with default toner cartridges.
-
-
PowerfulBacon updated:
-
- - Syndicate teleporter has been reworked. It will no longer teleport through solid walls but will be more effective at knocking down targets in a combat scenario, as it will knock down any targets passed through during a teleport. It can be used to jump through windows without being shocked. The price has been reduced from 8 TC to 7.
- - Removes help intent disabling blocking.
-
-
Rukofamicom updated:
-
- - Package Wrap (and by extension gift wrap) no longer works on gigantic objects
- - fixed an exploit that enabled bluespace capsules to carry things it was not intended to carry. They are intended to carry items that can be placed within a normal backpack.
-
-
itsmeow updated:
-
- - Added glow-in-the-dark emissives to lightswitches, so they can be located in the dark.
-
GoonStation 13 Development Team
diff --git a/html/changelogs/.all_changelog.yml b/html/changelogs/.all_changelog.yml
index b7cf7d1dfe04d..cb6f78ebaea84 100644
--- a/html/changelogs/.all_changelog.yml
+++ b/html/changelogs/.all_changelog.yml
@@ -40973,9 +40973,34 @@ DO NOT EDIT THIS FILE BY HAND! AUTOMATICALLY GENERATED BY ss13_genchangelog.py.
Tyranicranger4, AnturK, Rkz:
- admin: Adds "Sequential Mode" to SDQL2.
2023-09-30:
+ Absolucy, Bieyes:
+ - bugfix: Fixed an exploit where a holoparasite player could be sent back to the
+ lobby after being reset. Thank you Bieyes (Theodore Cooper) for alerting me
+ of this exploit after coming across it!
MMMiracles, goober3:
- rscadd: Ports Dirt linings and corners
'citrus ':
- rscadd: ports the code needed for hedges to work
itsmeow:
- bugfix: Fixed the Shuttle Designator not working.
+2023-10-02:
+ Absolucy:
+ - bugfix: Fix broken dropdown buttons in the tgui chat settings.
+ DrDuckedGoose:
+ - rscadd: Adds color correction to areas
+ PowerfulBacon:
+ - balance: Atmosbots have been given a larger area of effect but have had the amount
+ of gasses they transfer in a single tick reduced.
+ RKz, necromanceranne, Spookydonut:
+ - code_imp: adds linting for equipped()
+2023-10-03:
+ AMonekyThatCodes, Kylerace, tralezab, Ryll/Shaps, Melbert, ported by mystery3525:
+ - rscadd: Basic Mobs. Newer, better simple_mobs now with datumized AI behavior,
+ allowing more interesting behavior.
+ - rscadd: Mothroach web eating mechanic, with a 25 second cooldown
+ - code_imp: Refactored petting certain pets into a general element, atmos_requirements
+ element, and death_drops element
+ Harranhall:
+ - rscadd: Added a vignette that appears momentarily when your laws are changed as
+ AI.
+ - imageadd: added the "law_change" fullscreen vignette.
diff --git a/icons/effects/mapping_helpers.dmi b/icons/effects/mapping_helpers.dmi
index 46af6aaca7e57..238c107f51daf 100644
Binary files a/icons/effects/mapping_helpers.dmi and b/icons/effects/mapping_helpers.dmi differ
diff --git a/icons/mob/screen_full.dmi b/icons/mob/screen_full.dmi
index c1ccf3f890553..7cb2d2a5c13ed 100644
Binary files a/icons/mob/screen_full.dmi and b/icons/mob/screen_full.dmi differ
diff --git a/tgui/packages/tgui/components/Dropdown.tsx b/tgui/packages/tgui/components/Dropdown.tsx
index 53f2bdc53cae2..8c2be0402882e 100644
--- a/tgui/packages/tgui/components/Dropdown.tsx
+++ b/tgui/packages/tgui/components/Dropdown.tsx
@@ -79,9 +79,13 @@ export class Dropdown extends Component {
open: false,
};
- constructor() {
- super();
+ constructor(props) {
+ super(props);
+ this.state = {
+ selected: props.selected,
+ open: props.open,
+ };
this.handleClick = () => {
if (this.state.open) {
this.setOpen(false);