diff --git a/_maps/map_files/BoxStation/BoxStation.dmm b/_maps/map_files/BoxStation/BoxStation.dmm index f50c765385a6..a6b4289fe7db 100644 --- a/_maps/map_files/BoxStation/BoxStation.dmm +++ b/_maps/map_files/BoxStation/BoxStation.dmm @@ -6295,27 +6295,6 @@ }, /turf/open/floor/plasteel, /area/commons/dorms) -"auS" = ( -/obj/machinery/requests_console{ - announcementConsole = 1; - department = "Cargo Bay"; - departmentType = 2; - pixel_x = -30 - }, -/obj/effect/turf_decal/tile/brown{ - dir = 1 - }, -/obj/effect/turf_decal/tile/brown{ - dir = 4 - }, -/obj/effect/turf_decal/tile/brown{ - dir = 8 - }, -/obj/machinery/keycard_auth{ - pixel_y = 25 - }, -/turf/open/floor/plasteel, -/area/cargo/qm) "auT" = ( /obj/structure/cable{ icon_state = "4-8" @@ -31646,13 +31625,6 @@ }, /turf/open/floor/plating, /area/maintenance/port/aft) -"bUv" = ( -/obj/structure/cable{ - icon_state = "4-8" - }, -/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden, -/turf/open/floor/plating, -/area/maintenance/port/aft) "bUx" = ( /obj/structure/disposalpipe/junction/yjunction{ dir = 1 @@ -34769,13 +34741,6 @@ /obj/machinery/atmospherics/pipe/simple/supply/hidden, /turf/closed/wall, /area/maintenance/starboard/aft) -"ccV" = ( -/obj/effect/decal/cleanable/dirt, -/obj/machinery/atmospherics/pipe/simple/supply/hidden{ - dir = 10 - }, -/turf/open/floor/plating, -/area/maintenance/starboard/aft) "ccW" = ( /obj/effect/decal/cleanable/blood/old, /obj/machinery/atmospherics/pipe/simple/supply/hidden{ @@ -37852,12 +37817,6 @@ /obj/structure/disposalpipe/segment, /turf/open/floor/plating, /area/maintenance/aft) -"cln" = ( -/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ - dir = 9 - }, -/turf/open/floor/plating, -/area/maintenance/aft) "clo" = ( /obj/structure/disposalpipe/segment, /obj/machinery/atmospherics/pipe/manifold/scrubbers/hidden{ @@ -45837,6 +45796,14 @@ }, /turf/open/floor/carpet, /area/medical/psychology) +"eRu" = ( +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/aft) "eRz" = ( /obj/structure/lattice, /obj/structure/grille, @@ -47612,6 +47579,13 @@ }, /turf/open/floor/plating, /area/service/kitchen) +"gop" = ( +/obj/machinery/atmospherics/pipe/simple/supply/hidden{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port) "got" = ( /obj/structure/closet, /obj/item/poster/random_contraband, @@ -49881,6 +49855,10 @@ }, /turf/open/floor/plasteel/dark, /area/security/prison) +"isC" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/wood/wood_large, +/area/service/abandoned_gambling_den) "itD" = ( /obj/machinery/atmospherics/pipe/simple/supply/hidden{ dir = 4 @@ -50424,6 +50402,11 @@ }, /turf/open/floor/plasteel, /area/security/prison/upper) +"iVB" = ( +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/fore) "iVH" = ( /obj/machinery/atmospherics/pipe/simple/supply/hidden{ dir = 4 @@ -51430,6 +51413,14 @@ /obj/effect/decal/cleanable/dirt/dust, /turf/open/floor/plating, /area/maintenance/port/fore) +"jJq" = ( +/obj/effect/decal/cleanable/dirt, +/obj/machinery/atmospherics/pipe/simple/supply/hidden{ + dir = 10 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/aft) "jJC" = ( /obj/machinery/computer/arcade/battle, /obj/structure/window{ @@ -51772,6 +51763,12 @@ }, /turf/open/floor/plating, /area/maintenance/starboard/fore) +"kai" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating{ + icon_state = "platingdmg1" + }, +/area/maintenance/starboard/aft) "kaq" = ( /turf/closed/wall/mineral/titanium, /area/space/nearstation) @@ -52446,6 +52443,10 @@ }, /turf/open/floor/wood, /area/service/theater) +"kEe" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/aft) "kEm" = ( /mob/living/simple_animal/opossum/poppy, /turf/open/floor/plating, @@ -52562,6 +52563,12 @@ }, /turf/open/floor/plating, /area/maintenance/fore) +"kJl" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating{ + icon_state = "panelscorched" + }, +/area/maintenance/starboard/fore) "kJE" = ( /obj/machinery/atmospherics/pipe/simple/scrubbers/visible, /obj/machinery/atmospherics/pipe/simple/cyan/visible{ @@ -54347,6 +54354,30 @@ }, /turf/open/floor/plasteel, /area/security/prison/upper) +"mlG" = ( +/obj/machinery/requests_console{ + announcementConsole = 1; + department = "Cargo Bay"; + departmentType = 2; + pixel_x = -30 + }, +/obj/effect/turf_decal/tile/brown{ + dir = 1 + }, +/obj/effect/turf_decal/tile/brown{ + dir = 4 + }, +/obj/effect/turf_decal/tile/brown{ + dir = 8 + }, +/obj/machinery/keycard_auth{ + pixel_y = 25 + }, +/obj/machinery/computer/bounty{ + dir = 4 + }, +/turf/open/floor/plasteel, +/area/cargo/qm) "mml" = ( /obj/effect/turf_decal/tile/red{ dir = 1 @@ -58126,6 +58157,13 @@ }, /turf/open/floor/plasteel/dark, /area/security/prison) +"pJP" = ( +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ + dir = 9 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/aft) "pKV" = ( /turf/closed/wall/r_wall, /area/science/research) @@ -58713,6 +58751,10 @@ /obj/item/toy/plush/random, /turf/open/floor/carpet/blue, /area/medical/psychology) +"qlD" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/fore) "qlV" = ( /obj/item/mop{ name = "Ain't Much" @@ -62909,6 +62951,10 @@ /obj/item/smithing/stundild, /turf/open/floor/plasteel/dark, /area/security/warden) +"tZZ" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/aft) "uaw" = ( /obj/machinery/power/apc{ areastring = "/area/maintenance/bar"; @@ -62935,6 +62981,15 @@ }, /turf/open/floor/wood/wood_large, /area/service/chapel/main) +"ubP" = ( +/obj/machinery/atmospherics/pipe/simple/supply/hidden{ + dir = 4 + }, +/obj/machinery/computer/bounty{ + dir = 8 + }, +/turf/open/floor/plasteel, +/area/cargo/office) "udT" = ( /obj/machinery/atmospherics/pipe/manifold/purple/visible, /turf/open/floor/plasteel, @@ -66422,6 +66477,10 @@ /obj/structure/lattice, /turf/open/space, /area/space) +"xdq" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/aft) "xdQ" = ( /obj/machinery/atmospherics/pipe/simple/supply/hidden{ dir = 4 @@ -81223,7 +81282,7 @@ lPA alU ugq rMh -ayy +iVB aAe aBJ aCs @@ -81983,7 +82042,7 @@ aaf aaf alU arO -amC +qlD aom ank auT @@ -83304,7 +83363,7 @@ bbI bcK aPz bdB -aWv +gop bfh aPz aPz @@ -86620,7 +86679,7 @@ amC uBf amC aKY -amC +qlD aAY aBQ aDp @@ -87445,7 +87504,7 @@ aaa bCq bHE bHE -bHE +xdq bHE bCq bVy @@ -87943,7 +88002,7 @@ bjr bjr bub bxu -auS +mlG bzP bAS bxu @@ -88490,7 +88549,7 @@ bCq cqn cAh chT -bHE +xdq bHE ckv bHE @@ -90014,7 +90073,7 @@ aoV aoV bLv bPZ -bHE +xdq bHE cTF bHE @@ -90509,7 +90568,7 @@ bnG bnz bpA bbR -bkM +ubP jlm bud eyM @@ -91816,7 +91875,7 @@ bLv aaa aaa bTB -bUv +eRu bES bES bES @@ -105953,7 +106012,7 @@ bMa bTZ bKH bzs -bAw +kEe bXZ bHX bZN @@ -108024,7 +108083,7 @@ cbK ciG bLS ckm -cln +pJP cmh cnd cnE @@ -109744,7 +109803,7 @@ apC aqy anf anf -aty +kJl auF alP aAt @@ -113853,7 +113912,7 @@ wKe hda hda hda -hda +isC qbq asB atD @@ -114709,7 +114768,7 @@ diq clr bnt cOe -cOe +tZZ bMB cOT aaa @@ -118809,7 +118868,7 @@ cNW rSf cNW wly -ccV +jJq noa iQg ccU @@ -119053,7 +119112,7 @@ vHY bEs rmX xIa -vxh +kai cOe bPP bPP diff --git a/_maps/map_files/BoxedInStation/BoxedInStation.dmm b/_maps/map_files/BoxedInStation/BoxedInStation.dmm index 8a2762bbe761..ef3fdc288418 100644 --- a/_maps/map_files/BoxedInStation/BoxedInStation.dmm +++ b/_maps/map_files/BoxedInStation/BoxedInStation.dmm @@ -10914,7 +10914,7 @@ /area/service/kitchen) "fGo" = ( /obj/machinery/vending/dinnerware{ - contraband = list(/obj/item/kitchen/rollingpin = 2, /obj/item/kitchen/knife/butcher = 2, /obj/item/reagent_containers/food/condiment/flour = 4) + contraband = list(/obj/item/kitchen/rollingpin=2,/obj/item/kitchen/knife/butcher=2,/obj/item/reagent_containers/food/condiment/flour=4) }, /obj/machinery/power/apc{ areastring = "/area/service/kitchen"; @@ -13326,11 +13326,11 @@ /area/service/bar) "gUI" = ( /obj/machinery/vending/dinnerware{ - contraband = list(/obj/item/reagent_containers/food/condiment/flour = 4); + contraband = list(/obj/item/reagent_containers/food/condiment/flour=4); desc = "This vendor is full of condiments to put on food."; name = "\improper Condiments Vendor"; product_ads = "Get your sauces here!;No slave labour was used to make these products!;Nanotrasen Approved?!"; - products = list(/obj/item/storage/bag/tray = 8, /obj/item/reagent_containers/food/drinks/drinkingglass = 10, /obj/item/storage/box/cups = 5, /obj/item/reagent_containers/food/condiment/pack/ketchup = 20, /obj/item/reagent_containers/food/condiment/pack/mustard = 20, /obj/item/reagent_containers/food/condiment/pack/hotsauce = 20, /obj/item/reagent_containers/food/condiment/pack/astrotame = 20, /obj/item/reagent_containers/food/condiment/saltshaker = 20, /obj/item/reagent_containers/food/condiment/peppermill = 20) + products = list(/obj/item/storage/bag/tray=8,/obj/item/reagent_containers/food/drinks/drinkingglass=10,/obj/item/storage/box/cups=5,/obj/item/reagent_containers/food/condiment/pack/ketchup=20,/obj/item/reagent_containers/food/condiment/pack/mustard=20,/obj/item/reagent_containers/food/condiment/pack/hotsauce=20,/obj/item/reagent_containers/food/condiment/pack/astrotame=20,/obj/item/reagent_containers/food/condiment/saltshaker=20,/obj/item/reagent_containers/food/condiment/peppermill=20) }, /turf/open/floor/plasteel/cafeteria, /area/service/kitchen) @@ -18857,6 +18857,10 @@ }, /turf/open/floor/plating, /area/hallway/secondary/exit) +"jMk" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/fore) "jMy" = ( /obj/structure/cable{ icon_state = "4-8" @@ -31800,6 +31804,10 @@ }, /turf/open/floor/plasteel, /area/engineering/main) +"qyg" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/central/secondary) "qyp" = ( /obj/structure/disposalpipe/segment{ dir = 6 @@ -46274,6 +46282,13 @@ dir = 4 }, /area/service/theater) +"xIk" = ( +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/fore) "xIu" = ( /obj/effect/spawner/structure/window, /obj/machinery/door/firedoor, @@ -66642,7 +66657,7 @@ kED kED gXk dQv -lRs +jMk gXk kED cwy @@ -68912,7 +68927,7 @@ oCD mhf nzv lRs -dQv +xIk lRs seE qaQ @@ -70455,7 +70470,7 @@ vBu vBu cTZ aye -mjY +qyg mjY jzy mjY @@ -73255,7 +73270,7 @@ nOA pAn mjY kZA -mjY +qyg mjY rTW aye diff --git a/_maps/map_files/CogStation/CogStation.dmm b/_maps/map_files/CogStation/CogStation.dmm index cf2c4a53bab5..f85f83092bbc 100644 --- a/_maps/map_files/CogStation/CogStation.dmm +++ b/_maps/map_files/CogStation/CogStation.dmm @@ -1678,12 +1678,6 @@ }, /turf/open/floor/plasteel, /area/commons/lounge) -"aen" = ( -/obj/machinery/atmospherics/pipe/simple/general/visible{ - dir = 9 - }, -/turf/open/floor/plating, -/area/maintenance/fore) "aeo" = ( /obj/effect/decal/cleanable/dirt, /obj/item/circuitboard/machine/sleeper, @@ -5124,20 +5118,6 @@ }, /turf/open/floor/carpet/arcade, /area/commons/arcade) -"ani" = ( -/obj/machinery/disposal/bin, -/obj/effect/turf_decal/tile/red, -/obj/effect/turf_decal/tile/red{ - dir = 8 - }, -/obj/structure/disposalpipe/trunk{ - dir = 8 - }, -/obj/structure/sign/poster/official/bless_this_spess{ - pixel_y = -32 - }, -/turf/open/floor/plasteel, -/area/security/brig) "anj" = ( /obj/machinery/holopad, /obj/effect/turf_decal/bot, @@ -68150,6 +68130,13 @@ /obj/machinery/atmospherics/pipe/layer_manifold, /turf/open/floor/plating, /area/engineering/atmos) +"dXW" = ( +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/aft) "dYm" = ( /obj/machinery/portable_atmospherics/canister/oxygen, /obj/effect/turf_decal/stripes/line{ @@ -68888,6 +68875,10 @@ /obj/structure/chair/stool, /turf/open/floor/plasteel, /area/cargo/office) +"iEf" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/central) "iLw" = ( /obj/machinery/door/airlock/security/glass{ name = "Advanced Interrogation" @@ -69175,6 +69166,16 @@ }, /turf/open/floor/plating, /area/cargo/storage) +"kPi" = ( +/obj/machinery/atmospherics/pipe/simple/cyan/hidden{ + dir = 4 + }, +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/fore) "kTm" = ( /obj/effect/decal/cleanable/dirt, /obj/effect/landmark/start/prisoner, @@ -69337,6 +69338,20 @@ }, /turf/closed/wall/mineral/wood, /area/commons/fitness/cogpool) +"maU" = ( +/obj/machinery/disposal/bin, +/obj/effect/turf_decal/tile/red, +/obj/effect/turf_decal/tile/red{ + dir = 8 + }, +/obj/structure/disposalpipe/trunk{ + dir = 8 + }, +/obj/structure/sign/poster/official/bless_this_spess{ + pixel_y = -32 + }, +/turf/open/floor/plasteel, +/area/security/brig) "mfj" = ( /obj/machinery/firealarm{ pixel_y = 26 @@ -70601,6 +70616,15 @@ }, /turf/open/floor/plasteel, /area/cargo/storage) +"ulg" = ( +/obj/structure/disposalpipe/segment, +/obj/structure/cable{ + icon_state = "1-2" + }, +/obj/machinery/atmospherics/pipe/simple/orange/hidden, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/fore) "unW" = ( /obj/effect/landmark/navigate_destination/med, /turf/open/floor/plasteel/white, @@ -70978,6 +71002,13 @@ /obj/structure/filingcabinet, /turf/open/floor/carpet, /area/medical/psychology) +"wUe" = ( +/obj/machinery/atmospherics/pipe/simple/general/visible{ + dir = 9 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/fore) "wUI" = ( /obj/effect/turf_decal/tile/neutral, /obj/structure/table, @@ -71172,6 +71203,16 @@ }, /turf/open/floor/plasteel, /area/security/brig) +"xWP" = ( +/obj/structure/disposalpipe/segment{ + dir = 4 + }, +/obj/machinery/atmospherics/pipe/simple/cyan/hidden{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/fore) "xXs" = ( /obj/structure/cable{ icon_state = "4-8" @@ -95231,7 +95272,7 @@ adb anU aeQ aeM -ani +maU aew aeJ aeJ @@ -98104,7 +98145,7 @@ aQL aQL aQL aTS -aRW +iEf bcR bjG blk @@ -98581,7 +98622,7 @@ amS amS aDE amS -amS +ulg aKR apY bRa @@ -103448,7 +103489,7 @@ hzz aaa acb acS -aen +wUe afi agg ahj @@ -107053,7 +107094,7 @@ ajw ajw ajw awN -bGc +xWP bGl ahA aiQ @@ -111936,7 +111977,7 @@ ahP ahP akj ahP -aif +kPi aiB afK ahU @@ -113319,7 +113360,7 @@ bqM btL bBm btC -bPm +dXW bta btV cfG diff --git a/_maps/map_files/Deltastation/DeltaStation2.dmm b/_maps/map_files/Deltastation/DeltaStation2.dmm index 9913253ba6be..8c11405f4151 100644 --- a/_maps/map_files/Deltastation/DeltaStation2.dmm +++ b/_maps/map_files/Deltastation/DeltaStation2.dmm @@ -70379,6 +70379,20 @@ /obj/effect/turf_decal/caution/stand_clear, /turf/open/floor/plasteel, /area/hallway/secondary/entry) +"ehA" = ( +/obj/structure/cable/white{ + icon_state = "1-2" + }, +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden, +/obj/effect/turf_decal/tile/neutral{ + dir = 1 + }, +/obj/effect/turf_decal/tile/neutral{ + dir = 8 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plasteel, +/area/maintenance/starboard/aft) "ehG" = ( /obj/item/radio/intercom{ name = "Station Intercom"; @@ -77296,27 +77310,6 @@ }, /turf/open/floor/plasteel, /area/cargo/storage) -"gFF" = ( -/obj/machinery/light{ - dir = 4 - }, -/obj/machinery/newscaster{ - pixel_y = -32 - }, -/obj/item/radio/intercom{ - dir = 8; - name = "Station Intercom (General)"; - pixel_x = 28 - }, -/obj/effect/turf_decal/tile/brown, -/obj/effect/turf_decal/tile/brown{ - dir = 4 - }, -/obj/effect/turf_decal/tile/brown{ - dir = 8 - }, -/turf/open/floor/plasteel, -/area/cargo/office) "gFG" = ( /obj/machinery/door/airlock/maintenance_hatch{ name = "Maintenance Hatch"; @@ -82289,6 +82282,12 @@ /obj/effect/decal/cleanable/dirt, /turf/open/floor/plating, /area/service/abandoned_gambling_den) +"ijo" = ( +/obj/effect/decal/cleanable/dirt, +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/aft) "ijN" = ( /obj/structure/table/wood, /obj/machinery/computer/med_data/laptop, @@ -91624,25 +91623,6 @@ /obj/effect/turf_decal/vg_decals/atmos/plasma, /turf/open/floor/engine/plasma, /area/engineering/atmos) -"lkx" = ( -/obj/machinery/requests_console{ - department = "Quartermaster's Desk"; - name = "Quartermaster RC"; - pixel_x = 32; - pixel_y = -32 - }, -/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ - dir = 4 - }, -/obj/machinery/light_switch{ - pixel_x = 23 - }, -/obj/effect/turf_decal/tile/brown, -/obj/effect/turf_decal/tile/brown{ - dir = 4 - }, -/turf/open/floor/plasteel, -/area/cargo/qm) "lkF" = ( /obj/structure/closet/secure_closet/engineering_electrical, /obj/machinery/light_switch{ @@ -109280,6 +109260,30 @@ /obj/effect/turf_decal/delivery, /turf/open/floor/plasteel, /area/service/hydroponics/garden/abandoned) +"rpU" = ( +/obj/machinery/light{ + dir = 4 + }, +/obj/machinery/newscaster{ + pixel_y = -32 + }, +/obj/item/radio/intercom{ + dir = 8; + name = "Station Intercom (General)"; + pixel_x = 28 + }, +/obj/effect/turf_decal/tile/brown, +/obj/effect/turf_decal/tile/brown{ + dir = 4 + }, +/obj/effect/turf_decal/tile/brown{ + dir = 8 + }, +/obj/machinery/computer/bounty{ + dir = 8 + }, +/turf/open/floor/plasteel, +/area/cargo/office) "rpV" = ( /obj/machinery/status_display/evac, /turf/closed/wall, @@ -112599,6 +112603,28 @@ /obj/structure/lattice/catwalk, /turf/open/space, /area/solars/starboard/aft) +"stl" = ( +/obj/machinery/requests_console{ + department = "Quartermaster's Desk"; + name = "Quartermaster RC"; + pixel_x = 32; + pixel_y = -32 + }, +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ + dir = 4 + }, +/obj/machinery/light_switch{ + pixel_x = 23 + }, +/obj/effect/turf_decal/tile/brown, +/obj/effect/turf_decal/tile/brown{ + dir = 4 + }, +/obj/machinery/computer/bounty{ + dir = 8 + }, +/turf/open/floor/plasteel, +/area/cargo/qm) "sts" = ( /obj/structure/table/wood, /obj/item/folder, @@ -114990,6 +115016,20 @@ }, /turf/open/floor/plasteel, /area/maintenance/port/fore) +"til" = ( +/obj/effect/decal/cleanable/dirt, +/obj/structure/cable/white{ + icon_state = "4-8" + }, +/obj/effect/turf_decal/tile/neutral{ + dir = 1 + }, +/obj/effect/turf_decal/tile/neutral{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plasteel, +/area/maintenance/starboard) "tin" = ( /obj/machinery/light{ dir = 1 @@ -123172,6 +123212,15 @@ }, /turf/open/floor/plasteel, /area/commons/dorms) +"whu" = ( +/obj/structure/cable/white{ + icon_state = "1-2" + }, +/obj/effect/decal/cleanable/dirt, +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/aft) "whB" = ( /obj/effect/turf_decal/delivery, /turf/open/floor/plasteel, @@ -171324,7 +171373,7 @@ nOU tnL xRR hbT -gFF +rpU vhK bdV bdU @@ -173658,7 +173707,7 @@ aaa aad aaa bHq -bJb +til bHq rNA poQ @@ -175948,7 +175997,7 @@ sOq keW fJF lgx -lkx +stl vdx sOq aad @@ -178850,7 +178899,7 @@ dkG dmf dnL dpE -dpE +ehA dsS dtV dvK @@ -179091,13 +179140,13 @@ gTM vrH fzU cPP -cRr +ijo cRr cUU cWB cYf cZR -dbB +whu dbB deM dfN diff --git a/_maps/map_files/FestiveBall/FestiveStation.dmm b/_maps/map_files/FestiveBall/FestiveStation.dmm index be7263f8c4a5..feb2ee2f1373 100644 --- a/_maps/map_files/FestiveBall/FestiveStation.dmm +++ b/_maps/map_files/FestiveBall/FestiveStation.dmm @@ -2634,36 +2634,11 @@ /obj/machinery/light/floor, /turf/open/floor/festive/wooden/wooden1, /area/command/corporate_showroom) -"agT" = ( -/obj/structure/table/wood/fancy/green, -/obj/structure/window/reinforced{ - dir = 8 - }, -/obj/item/clothing/under/syndicate/baseball, -/obj/item/clothing/head/beret/sec{ - armor = list("melee" = 0, "bullet" = 0, "laser" = 0, "energy" = 0, "bomb" = 0, "bio" = 0, "rad" = 0); - desc = "A replica beret resembling that of a special operations officer under Nanotrasen."; - name = "replica officer's beret" - }, -/turf/open/floor/festive/wooden/wooden1, -/area/command/corporate_showroom) "agU" = ( /obj/structure/showcase/mecha/marauder, /obj/machinery/light/floor, /turf/open/floor/festive/wooden/wooden1, /area/command/corporate_showroom) -"agV" = ( -/obj/structure/table/wood/fancy/red, -/obj/structure/window/reinforced{ - dir = 4 - }, -/obj/item/clothing/head/centhat{ - armor = list("melee" = 0, "bullet" = 0, "laser" = 0, "energy" = 0, "bomb" = 0, "bio" = 0, "rad" = 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" - }, -/turf/open/floor/festive/wooden/wooden1, -/area/command/corporate_showroom) "agW" = ( /obj/structure/table/wood/fancy/green, /obj/item/folder/blue, @@ -20379,13 +20354,6 @@ }, /turf/open/floor/festive/alleyway, /area/edina/street/secondary/command) -"baX" = ( -/obj/machinery/computer/prisoner/management, -/obj/structure/sign/poster/official/bless_this_spess{ - pixel_y = 32 - }, -/turf/open/floor/wood, -/area/security/warden) "baY" = ( /obj/effect/landmark/start/botanist, /turf/open/floor/plasteel, @@ -35552,14 +35520,6 @@ }, /turf/open/floor/wood, /area/service/bar/atrium) -"bKt" = ( -/obj/machinery/vending/dinnerware{ - desc = "A vending machine stocked full of condiments to put on food."; - name = "\improper Condiments Dispenser"; - products = list(/obj/item/storage/bag/tray = 10, /obj/item/kitchen/fork = 6, /obj/item/kitchen/knife = 6, /obj/item/reagent_containers/food/drinks/drinkingglass = 20, /obj/item/clothing/suit/apron/chef = 2, /obj/item/storage/box/cups = 10, /obj/item/reagent_containers/food/condiment/pack/ketchup = 20, /obj/item/reagent_containers/food/condiment/pack/mustard = 20, /obj/item/reagent_containers/food/condiment/pack/hotsauce = 20, /obj/item/reagent_containers/food/condiment/pack/astrotame = 20, /obj/item/reagent_containers/food/condiment/saltshaker = 20, /obj/item/reagent_containers/food/condiment/peppermill = 20, /obj/item/reagent_containers/glass/bowl = 30) - }, -/turf/open/floor/wood, -/area/service/bar/atrium) "bKu" = ( /obj/structure/chair/sofa/right{ dir = 4 @@ -35852,10 +35812,6 @@ /obj/structure/fence, /turf/open/floor/plating/dirt/space, /area/edina) -"bKZ" = ( -/obj/effect/festive/street/sidewalke, -/turf/open/floor/festive/cobblestone, -/area/edina/street/primary/progress) "bLa" = ( /obj/effect/turf_decal/weather/snow/corner{ dir = 1 @@ -43300,53 +43256,6 @@ /obj/structure/reagent_dispensers/keg/milk, /turf/open/floor/plasteel/freezer, /area/service/kitchen/coldroom) -"cbt" = ( -/obj/structure/closet/crate/freezer{ - desc = "A small crate with a cooling system, keeps fresh produce chilled."; - name = "Food Chiller" - }, -/obj/item/reagent_containers/food/condiment/flour{ - desc = "A large sack of flour for restaurants, not the home-baker!"; - list_reagents = list(/datum/reagent/consumable/flour = 90); - name = "Large Flour Sack" - }, -/obj/item/reagent_containers/food/condiment/flour{ - desc = "A large sack of flour for restaurants, not the home-baker!"; - list_reagents = list(/datum/reagent/consumable/flour = 90); - name = "Large Flour Sack" - }, -/obj/item/reagent_containers/food/condiment/flour{ - desc = "A large sack of flour for restaurants, not the home-baker!"; - list_reagents = list(/datum/reagent/consumable/flour = 90); - name = "Large Flour Sack" - }, -/obj/item/reagent_containers/food/condiment/flour{ - desc = "A large sack of flour for restaurants, not the home-baker!"; - list_reagents = list(/datum/reagent/consumable/flour = 90); - name = "Large Flour Sack" - }, -/obj/item/reagent_containers/food/condiment/rice{ - desc = "A huge sack of rice. Probably for restaurants that actually go through such a huge volume of it easily, not for the home cook."; - list_reagents = list(/datum/reagent/consumable/rice = 90); - name = "Large Rice Sack" - }, -/obj/item/reagent_containers/food/condiment/rice{ - desc = "A huge sack of rice. Probably for restaurants that actually go through such a huge volume of it easily, not for the home cook."; - list_reagents = list(/datum/reagent/consumable/rice = 90); - name = "Large Rice Sack" - }, -/obj/item/reagent_containers/food/condiment/rice{ - desc = "A huge sack of rice. Probably for restaurants that actually go through such a huge volume of it easily, not for the home cook."; - list_reagents = list(/datum/reagent/consumable/rice = 90); - name = "Large Rice Sack" - }, -/obj/item/reagent_containers/food/condiment/rice{ - desc = "A huge sack of rice. Probably for restaurants that actually go through such a huge volume of it easily, not for the home cook."; - list_reagents = list(/datum/reagent/consumable/rice = 90); - name = "Large Rice Sack" - }, -/turf/open/floor/plasteel/freezer, -/area/service/kitchen/coldroom) "cbu" = ( /obj/structure/sign/poster/official/twelve_gauge{ pixel_y = 32 @@ -53426,6 +53335,13 @@ }, /turf/open/floor/wood, /area/maintenance/bar) +"dny" = ( +/obj/machinery/computer/prisoner/management, +/obj/structure/sign/poster/official/bless_this_spess{ + pixel_y = 32 + }, +/turf/open/floor/wood, +/area/security/warden) "dnQ" = ( /mob/living/simple_animal/pet/penguin/emperor/shamebrero, /turf/open/floor/holofloor/ice, @@ -54049,6 +53965,53 @@ /obj/effect/decal/festive/christmas_ivy_string, /turf/open/floor/circuit/off, /area/science) +"hGn" = ( +/obj/structure/closet/crate/freezer{ + desc = "A small crate with a cooling system, keeps fresh produce chilled."; + name = "Food Chiller" + }, +/obj/item/reagent_containers/food/condiment/flour{ + desc = "A large sack of flour for restaurants, not the home-baker!"; + list_reagents = list(/datum/reagent/consumable/flour=90); + name = "Large Flour Sack" + }, +/obj/item/reagent_containers/food/condiment/flour{ + desc = "A large sack of flour for restaurants, not the home-baker!"; + list_reagents = list(/datum/reagent/consumable/flour=90); + name = "Large Flour Sack" + }, +/obj/item/reagent_containers/food/condiment/flour{ + desc = "A large sack of flour for restaurants, not the home-baker!"; + list_reagents = list(/datum/reagent/consumable/flour=90); + name = "Large Flour Sack" + }, +/obj/item/reagent_containers/food/condiment/flour{ + desc = "A large sack of flour for restaurants, not the home-baker!"; + list_reagents = list(/datum/reagent/consumable/flour=90); + name = "Large Flour Sack" + }, +/obj/item/reagent_containers/food/condiment/rice{ + desc = "A huge sack of rice. Probably for restaurants that actually go through such a huge volume of it easily, not for the home cook."; + list_reagents = list(/datum/reagent/consumable/rice=90); + name = "Large Rice Sack" + }, +/obj/item/reagent_containers/food/condiment/rice{ + desc = "A huge sack of rice. Probably for restaurants that actually go through such a huge volume of it easily, not for the home cook."; + list_reagents = list(/datum/reagent/consumable/rice=90); + name = "Large Rice Sack" + }, +/obj/item/reagent_containers/food/condiment/rice{ + desc = "A huge sack of rice. Probably for restaurants that actually go through such a huge volume of it easily, not for the home cook."; + list_reagents = list(/datum/reagent/consumable/rice=90); + name = "Large Rice Sack" + }, +/obj/item/reagent_containers/food/condiment/rice{ + desc = "A huge sack of rice. Probably for restaurants that actually go through such a huge volume of it easily, not for the home cook."; + list_reagents = list(/datum/reagent/consumable/rice=90); + name = "Large Rice Sack" + }, +/turf/open/floor/plasteel/freezer, +/area/service/kitchen/coldroom) "hHy" = ( /obj/structure/closet/crate, /obj/item/storage/fancy/candle_box, @@ -54105,6 +54068,10 @@ /obj/effect/turf_decal/weather/snow/corner, /turf/open/floor/festive/sidewalk, /area/edina) +"hVw" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/festive/cobblestone, +/area/edina/street/primary/progress) "hXd" = ( /obj/vehicle/ridden/janicart, /obj/item/key/janitor, @@ -54927,6 +54894,19 @@ /mob/living/simple_animal/pet/fox, /turf/open/floor/grass, /area/edina) +"nNk" = ( +/obj/structure/table/wood/fancy/green, +/obj/structure/window/reinforced{ + dir = 8 + }, +/obj/item/clothing/under/syndicate/baseball, +/obj/item/clothing/head/beret/sec{ + armor = list("melee"=0,"bullet"=0,"laser"=0,"energy"=0,"bomb"=0,"bio"=0,"rad"=0); + desc = "A replica beret resembling that of a special operations officer under Nanotrasen."; + name = "replica officer's beret" + }, +/turf/open/floor/festive/wooden/wooden1, +/area/command/corporate_showroom) "nOZ" = ( /turf/closed/wall/r_wall, /area/engineering/engine_smes) @@ -55019,6 +54999,14 @@ /obj/structure/fireplace, /turf/open/floor/wood, /area/commons/dorms) +"ooy" = ( +/obj/machinery/vending/dinnerware{ + desc = "A vending machine stocked full of condiments to put on food."; + name = "\improper Condiments Dispenser"; + products = list(/obj/item/storage/bag/tray=10,/obj/item/kitchen/fork=6,/obj/item/kitchen/knife=6,/obj/item/reagent_containers/food/drinks/drinkingglass=20,/obj/item/clothing/suit/apron/chef=2,/obj/item/storage/box/cups=10,/obj/item/reagent_containers/food/condiment/pack/ketchup=20,/obj/item/reagent_containers/food/condiment/pack/mustard=20,/obj/item/reagent_containers/food/condiment/pack/hotsauce=20,/obj/item/reagent_containers/food/condiment/pack/astrotame=20,/obj/item/reagent_containers/food/condiment/saltshaker=20,/obj/item/reagent_containers/food/condiment/peppermill=20,/obj/item/reagent_containers/glass/bowl=30) + }, +/turf/open/floor/wood, +/area/service/bar/atrium) "orN" = ( /obj/machinery/light/small, /turf/open/floor/mineral/titanium/blue, @@ -55219,6 +55207,11 @@ }, /turf/open/floor/wood, /area/commons/dorms) +"ptw" = ( +/obj/effect/festive/street/sidewalke, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/festive/cobblestone, +/area/edina/street/primary/progress) "pwQ" = ( /obj/structure/table/wood, /obj/item/phone, @@ -55289,6 +55282,10 @@ /obj/machinery/light/small, /turf/open/floor/plasteel/dark, /area/service/hydroponics) +"pPZ" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/festive/alleyway, +/area/science) "pQk" = ( /obj/effect/turf_decal/stripes/line{ dir = 8 @@ -56245,6 +56242,10 @@ /obj/effect/decal/cleanable/cobweb/cobweb2, /turf/open/floor/plasteel, /area/edina) +"wjE" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/festive/sidewalk, +/area/edina/street/primary/progress) "wlp" = ( /obj/machinery/door/window/westleft{ dir = 2; @@ -56570,6 +56571,18 @@ }, /turf/open/floor/grass/snow/edina, /area/edina/backstreet/supply) +"xOm" = ( +/obj/structure/table/wood/fancy/red, +/obj/structure/window/reinforced{ + dir = 4 + }, +/obj/item/clothing/head/centhat{ + armor = list("melee"=0,"bullet"=0,"laser"=0,"energy"=0,"bomb"=0,"bio"=0,"rad"=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" + }, +/turf/open/floor/festive/wooden/wooden1, +/area/command/corporate_showroom) "xQh" = ( /obj/structure/table, /obj/machinery/reagentgrinder{ @@ -86380,7 +86393,7 @@ cuQ cuT cuV hya -aKT +pPZ pqA aLX aLX @@ -87079,7 +87092,7 @@ aeJ afl afl ago -agT +nNk ahu afl afl @@ -87593,7 +87606,7 @@ aeJ afl afl agq -agV +xOm ahw afl afl @@ -88691,7 +88704,7 @@ aOl aQL aMG cuU -bFg +wjE bQz bTV bVm @@ -99240,7 +99253,7 @@ ccI bFS bHi bIR -bKt +ooy aqp aqp bFS @@ -100723,7 +100736,7 @@ aoR aLE anQ anl -baX +dny arE asS atG @@ -104140,7 +104153,7 @@ bWF bWH bWH cdK -cbt +hGn bTM bKV bWy @@ -105914,7 +105927,7 @@ bAF bAF bAF bAF -bAF +hVw bAF bWE bFg @@ -106166,7 +106179,7 @@ aPA aQj bAJ bGa -bKZ +ptw bAJ bAJ bAJ @@ -107201,7 +107214,7 @@ bAF bAF bAF bAF -bAF +hVw bFg ccD bzs @@ -107712,7 +107725,7 @@ bBU bFg bAF bAF -bAF +hVw bAF bAF bAF diff --git a/_maps/map_files/KiloStation/KiloStation.dmm b/_maps/map_files/KiloStation/KiloStation.dmm index 398bd92c8f99..1d316f8ad54b 100644 --- a/_maps/map_files/KiloStation/KiloStation.dmm +++ b/_maps/map_files/KiloStation/KiloStation.dmm @@ -8113,6 +8113,7 @@ /obj/machinery/atmospherics/pipe/simple/supply/hidden{ dir = 4 }, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating{ icon_state = "platingdmg1" }, @@ -10039,6 +10040,7 @@ /obj/structure/disposalpipe/segment{ dir = 4 }, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating, /area/maintenance/port/fore) "aqZ" = ( @@ -33122,6 +33124,7 @@ }, /obj/effect/decal/cleanable/dirt, /obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating{ icon_state = "platingdmg1" }, @@ -33229,6 +33232,7 @@ /obj/structure/cable{ icon_state = "1-4" }, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating{ icon_state = "platingdmg1" }, @@ -51993,6 +51997,7 @@ pixel_y = -32 }, /obj/effect/decal/cleanable/dirt, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating{ icon_state = "panelscorched" }, @@ -70940,6 +70945,7 @@ /obj/structure/disposalpipe/segment{ dir = 4 }, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating{ icon_state = "panelscorched" }, @@ -76941,6 +76947,7 @@ /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer1{ dir = 6 }, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating{ icon_state = "platingdmg1" }, @@ -84438,6 +84445,13 @@ }, /turf/open/floor/plasteel/showroomfloor, /area/ai_monitored/security/armory) +"jIi" = ( +/obj/effect/decal/cleanable/dirt, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating{ + icon_state = "panelscorched" + }, +/area/maintenance/port) "jNK" = ( /obj/effect/spawner/structure/window/reinforced, /obj/machinery/door/poddoor/shutters/preopen{ @@ -84646,6 +84660,13 @@ icon_state = "wood-broken7" }, /area/maintenance/port/fore) +"kQV" = ( +/obj/effect/decal/cleanable/dirt, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating{ + icon_state = "platingdmg3" + }, +/area/maintenance/starboard/aft) "kRh" = ( /obj/effect/turf_decal/tile/neutral{ dir = 1 @@ -85554,6 +85575,21 @@ /obj/machinery/atmospherics/pipe/heat_exchanging/simple, /turf/open/space/basic, /area/space/nearstation) +"tpQ" = ( +/obj/machinery/atmospherics/pipe/simple/supply/hidden{ + dir = 4 + }, +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer1{ + dir = 8 + }, +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating{ + icon_state = "platingdmg1" + }, +/area/maintenance/fore) "tCi" = ( /obj/effect/decal/cleanable/glass, /turf/open/floor/wood{ @@ -100308,7 +100344,7 @@ bhU aEw bxq cux -cnL +jIi awD agp bHg @@ -116722,7 +116758,7 @@ alg alU cEX apb -cFf +tpQ cEh ahh ccU @@ -122175,7 +122211,7 @@ bNU bQE bSz bUU -bGH +kQV bNh awX awO diff --git a/_maps/map_files/LambdaStation/lambda.dmm b/_maps/map_files/LambdaStation/lambda.dmm index 100f99b8a9e7..d843cd2eb1f2 100644 --- a/_maps/map_files/LambdaStation/lambda.dmm +++ b/_maps/map_files/LambdaStation/lambda.dmm @@ -67046,6 +67046,10 @@ }, /turf/open/floor/plasteel, /area/science/mixing) +"kGJ" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/fore) "kJN" = ( /obj/machinery/atmospherics/pipe/simple/supply/hidden/layer1, /obj/structure/table, @@ -70940,6 +70944,16 @@ }, /turf/open/floor/plasteel, /area/maintenance/disposal/incinerator) +"sdE" = ( +/obj/structure/disposalpipe/segment{ + dir = 4 + }, +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/fore) "sfN" = ( /obj/machinery/light/small{ dir = 4 @@ -72146,6 +72160,13 @@ }, /turf/open/floor/plasteel, /area/engineering/atmos) +"uKy" = ( +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/fore) "uKJ" = ( /obj/effect/turf_decal/stripes/line{ dir = 4 @@ -91039,7 +91060,7 @@ aiI avs ahd acw -acw +kGJ acw cUe abY @@ -96161,7 +96182,7 @@ aaA aaA aaA abY -acw +kGJ bJa abY ahd @@ -99523,7 +99544,7 @@ cMf atH acw acw -acw +kGJ acw acw aeG @@ -101584,7 +101605,7 @@ aaQ aaQ aaQ aaQ -acw +kGJ aeG abY aaA @@ -102839,7 +102860,7 @@ aaA aaA aaA abY -acD +sdE acw adu aec @@ -103129,7 +103150,7 @@ aaQ aDg aDg aDg -aeG +uKy acw abY aaA @@ -104159,7 +104180,7 @@ bfS aDg aUL cOb -acw +kGJ aeH adr adr @@ -108487,7 +108508,7 @@ abh bjq acw afB -acw +kGJ acw acw aoT diff --git a/_maps/map_files/MetaStation/MetaStation.dmm b/_maps/map_files/MetaStation/MetaStation.dmm index 9d86501872ef..d96866553e84 100644 --- a/_maps/map_files/MetaStation/MetaStation.dmm +++ b/_maps/map_files/MetaStation/MetaStation.dmm @@ -3965,11 +3965,6 @@ /obj/effect/landmark/blobstart, /turf/open/floor/plating, /area/maintenance/fore) -"amu" = ( -/obj/machinery/atmospherics/pipe/simple/supply/hidden, -/obj/effect/turf_decal/stripes/line, -/turf/open/floor/plating, -/area/maintenance/fore) "amv" = ( /obj/effect/turf_decal/tile/neutral{ dir = 1 @@ -18273,6 +18268,30 @@ /obj/effect/turf_decal/tile/neutral, /turf/open/floor/plasteel, /area/hallway/primary/central) +"buy" = ( +/obj/structure/noticeboard{ + desc = "A board for pinning important notices upon. Probably helpful for keeping track of requests."; + name = "requests board"; + pixel_x = 32; + pixel_y = 32 + }, +/obj/machinery/requests_console{ + department = "Cargo Bay"; + departmentType = 2; + pixel_y = 30 + }, +/obj/effect/turf_decal/tile/brown{ + dir = 1 + }, +/obj/effect/turf_decal/tile/brown{ + dir = 4 + }, +/obj/effect/turf_decal/tile/brown{ + dir = 8 + }, +/obj/machinery/computer/bounty, +/turf/open/floor/plasteel, +/area/cargo/office) "buK" = ( /obj/machinery/atmospherics/pipe/simple/supply/hidden, /obj/structure/disposalpipe/segment, @@ -18629,16 +18648,6 @@ /obj/machinery/light/small, /turf/open/floor/plasteel, /area/security/prison/upper) -"bvY" = ( -/obj/structure/cable/yellow{ - icon_state = "1-2" - }, -/obj/machinery/atmospherics/pipe/simple/supply/hidden, -/obj/effect/turf_decal/stripes/line{ - dir = 1 - }, -/turf/open/floor/plating, -/area/maintenance/port) "bwh" = ( /obj/machinery/atmospherics/pipe/simple/supply/hidden, /obj/structure/extinguisher_cabinet{ @@ -23732,18 +23741,6 @@ }, /turf/open/floor/plating, /area/maintenance/starboard) -"bYu" = ( -/obj/item/cigbutt, -/obj/machinery/atmospherics/pipe/simple/supply/hidden, -/obj/structure/cable/yellow{ - icon_state = "1-2" - }, -/obj/effect/turf_decal/stripes/line, -/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ - dir = 4 - }, -/turf/open/floor/plating, -/area/maintenance/starboard) "bYC" = ( /obj/effect/spawner/structure/window/reinforced, /turf/open/floor/plating, @@ -49914,6 +49911,14 @@ }, /turf/open/floor/plasteel/dark, /area/engineering/storage/tech) +"eAg" = ( +/obj/structure/cable/yellow{ + icon_state = "1-2" + }, +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port) "eAn" = ( /obj/structure/cable/yellow{ icon_state = "1-8" @@ -55002,29 +55007,6 @@ /obj/effect/landmark/start/peacekeeper, /turf/open/floor/plasteel, /area/hallway/secondary/exit/departure_lounge) -"hvk" = ( -/obj/structure/noticeboard{ - desc = "A board for pinning important notices upon. Probably helpful for keeping track of requests."; - name = "requests board"; - pixel_x = 32; - pixel_y = 32 - }, -/obj/machinery/requests_console{ - department = "Cargo Bay"; - departmentType = 2; - pixel_y = 30 - }, -/obj/effect/turf_decal/tile/brown{ - dir = 1 - }, -/obj/effect/turf_decal/tile/brown{ - dir = 4 - }, -/obj/effect/turf_decal/tile/brown{ - dir = 8 - }, -/turf/open/floor/plasteel, -/area/cargo/office) "hvn" = ( /obj/structure/cable/yellow{ icon_state = "4-8" @@ -58102,6 +58084,19 @@ }, /turf/open/floor/plating, /area/engineering/atmos) +"jcr" = ( +/obj/item/cigbutt, +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/structure/cable/yellow{ + icon_state = "1-2" + }, +/obj/effect/turf_decal/stripes/line, +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard) "jcA" = ( /turf/open/floor/plating, /area/engineering/break_room) @@ -63951,21 +63946,6 @@ }, /turf/open/floor/plating, /area/maintenance/starboard/aft) -"mjR" = ( -/obj/machinery/airalarm{ - pixel_y = 23 - }, -/obj/machinery/light{ - dir = 1 - }, -/obj/effect/turf_decal/tile/brown{ - dir = 1 - }, -/obj/effect/turf_decal/tile/brown{ - dir = 4 - }, -/turf/open/floor/plasteel, -/area/cargo/qm) "mjX" = ( /obj/structure/cable/yellow{ icon_state = "4-8" @@ -65663,6 +65643,10 @@ dir = 1 }, /area/engineering/main) +"nis" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/fore) "nix" = ( /obj/machinery/light/small{ dir = 8 @@ -66577,15 +66561,6 @@ /obj/structure/lattice/catwalk, /turf/open/space, /area/solars/starboard/fore) -"nLT" = ( -/obj/structure/cable/yellow{ - icon_state = "1-2" - }, -/obj/machinery/atmospherics/pipe/manifold/supply/hidden{ - dir = 8 - }, -/turf/open/floor/plating, -/area/maintenance/starboard) "nMV" = ( /obj/machinery/atmospherics/components/unary/vent_scrubber/on{ dir = 8 @@ -74551,6 +74526,17 @@ }, /turf/open/floor/plasteel/dark, /area/command/teleporter) +"rRh" = ( +/obj/structure/cable/yellow{ + icon_state = "1-2" + }, +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/effect/turf_decal/stripes/line{ + dir = 1 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port) "rRz" = ( /obj/item/storage/box/beakers{ pixel_x = 2; @@ -78347,6 +78333,16 @@ /obj/effect/turf_decal/delivery, /turf/open/floor/plasteel, /area/service/kitchen) +"tWL" = ( +/obj/structure/cable/yellow{ + icon_state = "1-2" + }, +/obj/machinery/atmospherics/pipe/manifold/supply/hidden{ + dir = 8 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard) "tXp" = ( /obj/machinery/status_display/evac{ pixel_y = 32 @@ -79208,6 +79204,10 @@ }, /turf/open/floor/plating, /area/engineering/main) +"uum" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard) "uun" = ( /obj/machinery/vending/assist, /turf/open/floor/plasteel, @@ -80800,6 +80800,19 @@ }, /turf/open/floor/plasteel/dark, /area/engineering/atmos) +"vtm" = ( +/obj/structure/cable/yellow{ + icon_state = "4-8" + }, +/obj/machinery/atmospherics/pipe/simple/supply/hidden{ + dir = 4 + }, +/obj/structure/disposalpipe/segment{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/aft) "vtn" = ( /obj/structure/cable/yellow{ icon_state = "4-8" @@ -81630,6 +81643,22 @@ }, /turf/open/floor/plasteel, /area/security/checkpoint/science/research) +"vUG" = ( +/obj/machinery/airalarm{ + pixel_y = 23 + }, +/obj/machinery/light{ + dir = 1 + }, +/obj/effect/turf_decal/tile/brown{ + dir = 1 + }, +/obj/effect/turf_decal/tile/brown{ + dir = 4 + }, +/obj/machinery/computer/bounty, +/turf/open/floor/plasteel, +/area/cargo/qm) "vWf" = ( /obj/machinery/atmospherics/pipe/simple/supply/hidden{ dir = 4 @@ -85006,6 +85035,12 @@ }, /turf/open/floor/carpet, /area/service/theater) +"xCA" = ( +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/effect/turf_decal/stripes/line, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/fore) "xCC" = ( /obj/machinery/atmospherics/components/unary/vent_pump/on, /obj/effect/decal/cleanable/dirt, @@ -104884,7 +104919,7 @@ bnW bqp bsC pzt -bvY +rRh bxT bzC bzC @@ -104897,7 +104932,7 @@ bzC bzC bzC bPM -bzC +eAg bzC bSp alC @@ -106414,7 +106449,7 @@ aUj aVN aXn aSX -hvk +buy jSM ikm xhk @@ -106919,7 +106954,7 @@ vwK dne aLc dne -mjR +vUG hDb hMN lYW @@ -118785,7 +118820,7 @@ bZq caG abt bSS -ceZ +vtm cgo cgo cgo @@ -120518,7 +120553,7 @@ ahS aje ajP ald -amu +xCA anE aoQ agq @@ -123669,7 +123704,7 @@ caU ccD cdV cfj -apc +uum chC dvY dvY @@ -124930,7 +124965,7 @@ bpc dhQ btw buX -nLT +tWL bGp btw dCV @@ -125668,7 +125703,7 @@ bai ate dDL axP -dnS +nis ocS pUr lmt @@ -126233,7 +126268,7 @@ apc alq alq bXb -bYu +jcr bZD caY ccI diff --git a/_maps/map_files/OmegaStation/OmegaStation.dmm b/_maps/map_files/OmegaStation/OmegaStation.dmm index da7fe90c31a3..0d44c8f23bc9 100644 --- a/_maps/map_files/OmegaStation/OmegaStation.dmm +++ b/_maps/map_files/OmegaStation/OmegaStation.dmm @@ -11905,17 +11905,6 @@ /obj/item/taperecorder, /turf/open/floor/wood, /area/security/detectives_office) -"avI" = ( -/obj/structure/cable/white{ - icon_state = "2-4" - }, -/obj/machinery/atmospherics/pipe/manifold/scrubbers/hidden{ - dir = 8 - }, -/turf/open/floor/plating{ - icon_state = "platingdmg1" - }, -/area/maintenance/port/fore) "avJ" = ( /obj/structure/cable/white{ icon_state = "4-8" @@ -27894,15 +27883,6 @@ /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden, /turf/closed/wall/r_wall, /area/science/robotics/lab) -"bai" = ( -/obj/machinery/atmospherics/pipe/simple/supply/hidden, -/obj/structure/cable/white{ - icon_state = "1-2" - }, -/turf/open/floor/plating{ - icon_state = "platingdmg1" - }, -/area/maintenance/starboard) "baj" = ( /obj/structure/sign/warning/vacuum{ pixel_x = -32; @@ -29465,15 +29445,6 @@ }, /turf/open/floor/plating, /area/security/checkpoint) -"bdi" = ( -/obj/machinery/atmospherics/pipe/manifold/supply/hidden{ - dir = 8 - }, -/obj/structure/cable/white{ - icon_state = "1-2" - }, -/turf/open/floor/plating, -/area/maintenance/starboard/fore) "bdj" = ( /obj/machinery/atmospherics/pipe/simple/supply/hidden, /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ @@ -34978,6 +34949,16 @@ dir = 4 }, /area/maintenance/starboard/aft) +"dUm" = ( +/obj/machinery/atmospherics/pipe/manifold/supply/hidden{ + dir = 8 + }, +/obj/structure/cable/white{ + icon_state = "1-2" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/fore) "dXv" = ( /obj/item/transfer_valve{ pixel_x = -5 @@ -35210,6 +35191,18 @@ /obj/item/pipe_dispenser, /turf/open/floor/plasteel, /area/engineering/atmos) +"eTB" = ( +/obj/structure/cable/white{ + icon_state = "2-4" + }, +/obj/machinery/atmospherics/pipe/manifold/scrubbers/hidden{ + dir = 8 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating{ + icon_state = "platingdmg1" + }, +/area/maintenance/port/fore) "eUz" = ( /obj/machinery/door/firedoor, /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden, @@ -35911,6 +35904,19 @@ }, /turf/open/floor/plasteel, /area/service/bar/atrium) +"huF" = ( +/obj/effect/turf_decal/tile/brown{ + dir = 1 + }, +/obj/effect/turf_decal/tile/brown, +/obj/effect/turf_decal/tile/brown{ + dir = 8 + }, +/obj/machinery/computer/bounty{ + dir = 4 + }, +/turf/open/floor/plasteel, +/area/cargo/storage) "hvC" = ( /obj/structure/disposalpipe/segment{ dir = 9 @@ -37465,6 +37471,19 @@ }, /turf/open/floor/plasteel, /area/science/mixing) +"nud" = ( +/obj/structure/cable/white{ + icon_state = "4-8" + }, +/obj/machinery/atmospherics/pipe/simple/supply/hidden{ + dir = 4 + }, +/obj/effect/turf_decal/trimline/green/line{ + dir = 1 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/aft) "nvk" = ( /obj/structure/table/wood, /turf/open/floor/wood, @@ -37598,6 +37617,10 @@ }, /turf/open/floor/plating, /area/science/mixing) +"ohb" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/fore) "ohM" = ( /obj/machinery/door/poddoor{ id = "toxinsdriver"; @@ -38226,16 +38249,6 @@ }, /turf/open/floor/plasteel, /area/science/mixing) -"qAY" = ( -/obj/effect/turf_decal/tile/brown{ - dir = 1 - }, -/obj/effect/turf_decal/tile/brown, -/obj/effect/turf_decal/tile/brown{ - dir = 8 - }, -/turf/open/floor/plasteel, -/area/cargo/storage) "qEl" = ( /obj/machinery/atmospherics/pipe/simple/scrubbers/visible{ dir = 4 @@ -38314,6 +38327,18 @@ /obj/machinery/photocopier, /turf/open/floor/wood, /area/service/lawoffice) +"qSk" = ( +/obj/machinery/atmospherics/pipe/simple/supply/hidden{ + dir = 4 + }, +/obj/structure/cable/white{ + icon_state = "4-8" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating{ + icon_state = "platingdmg3" + }, +/area/maintenance/starboard/aft) "qSs" = ( /turf/open/floor/plasteel/dark/side{ dir = 6 @@ -38423,6 +38448,16 @@ }, /turf/open/floor/plasteel, /area/engineering/atmos) +"rzP" = ( +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/structure/cable/white{ + icon_state = "1-2" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating{ + icon_state = "platingdmg1" + }, +/area/maintenance/starboard) "rCw" = ( /obj/effect/turf_decal/tile/purple{ dir = 4 @@ -41901,6 +41936,14 @@ dir = 8 }, /area/engineering/atmos) +"xbD" = ( +/obj/structure/cable/white{ + icon_state = "1-2" + }, +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/aft) "xdr" = ( /obj/effect/turf_decal/sand/plating, /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ @@ -42084,6 +42127,16 @@ }, /turf/open/floor/plasteel/dark/corner, /area/engineering/atmos) +"xyZ" = ( +/obj/machinery/atmospherics/pipe/simple/supply/hidden{ + dir = 4 + }, +/obj/structure/cable/white{ + icon_state = "4-8" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/aft) "xAj" = ( /obj/machinery/atmospherics/pipe/simple/scrubbers/visible, /obj/effect/decal/cleanable/dirt, @@ -75081,7 +75134,7 @@ ars asI atK auD -avI +eTB awM axr ayk @@ -75836,7 +75889,7 @@ aAc aAm acH acH -ars +ohb swZ ain aqG @@ -75881,7 +75934,7 @@ aKl aKl aFM aFM -aFM +xbD aKl aFM bbn @@ -77426,7 +77479,7 @@ aDo aKn aLy aFM -aFM +xbD aPP lFj aSm @@ -79745,7 +79798,7 @@ bcd bcU bdQ aSh -hIu +nud bfA bfV bgG @@ -87909,7 +87962,7 @@ bcG bcM bcT bym -bdi +dUm bdF bxw aQU @@ -88211,7 +88264,7 @@ aPy aQA sOM sOU -sOV +xyZ sKa aVC aWt @@ -88435,7 +88488,7 @@ aiI ajI akL alA -qAY +huF ado aoc apc @@ -88483,7 +88536,7 @@ bxW bdw bep aZl -sPI +qSk bfP pej bhi @@ -88708,7 +88761,7 @@ oyD sEl sEL aXb -bai +rzP aSC aYt aRz diff --git a/_maps/map_files/PubbyStation/PubbyStation.dmm b/_maps/map_files/PubbyStation/PubbyStation.dmm index 8ead601af43f..4c4d336cb273 100644 --- a/_maps/map_files/PubbyStation/PubbyStation.dmm +++ b/_maps/map_files/PubbyStation/PubbyStation.dmm @@ -36547,12 +36547,6 @@ }, /turf/open/floor/plasteel, /area/science/mixing) -"bIO" = ( -/obj/machinery/status_display/supply{ - pixel_x = -32 - }, -/turf/open/floor/plasteel, -/area/cargo/office) "bIP" = ( /obj/machinery/atmospherics/pipe/simple/supply/hidden{ dir = 4 @@ -48209,6 +48203,10 @@ }, /turf/open/floor/plasteel, /area/hallway/primary/aft) +"cqr" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/department/cargo) "cqs" = ( /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ dir = 4 @@ -49672,6 +49670,13 @@ }, /turf/open/floor/plating, /area/maintenance/department/chapel/monastery) +"cvQ" = ( +/obj/structure/disposalpipe/segment{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/department/engine) "cvR" = ( /obj/machinery/meter, /obj/machinery/atmospherics/pipe/manifold/cyan/hidden{ @@ -50066,6 +50071,15 @@ }, /turf/closed/wall, /area/service/library/lounge) +"cyF" = ( +/obj/machinery/status_display/supply{ + pixel_x = -32 + }, +/obj/machinery/computer/bounty{ + dir = 4 + }, +/turf/open/floor/plasteel, +/area/cargo/office) "cyQ" = ( /obj/machinery/vending/games, /turf/open/floor/plasteel/dark, @@ -53157,6 +53171,16 @@ }, /turf/open/floor/plasteel/dark/telecomms, /area/tcommsat/server) +"gpX" = ( +/obj/effect/turf_decal/tile/brown, +/obj/effect/turf_decal/tile/brown{ + dir = 4 + }, +/obj/machinery/computer/bounty{ + dir = 8 + }, +/turf/open/floor/plasteel, +/area/cargo/qm) "gqi" = ( /obj/structure/bookcase/random/religion, /turf/open/floor/plasteel/dark, @@ -55830,13 +55854,6 @@ }, /turf/open/floor/plating, /area/maintenance/department/security/brig) -"kFy" = ( -/obj/effect/turf_decal/tile/brown, -/obj/effect/turf_decal/tile/brown{ - dir = 4 - }, -/turf/open/floor/plasteel, -/area/cargo/qm) "kFD" = ( /obj/structure/closet/l3closet, /obj/machinery/light{ @@ -56619,6 +56636,19 @@ }, /turf/open/floor/carpet, /area/command/blueshielquarters) +"lUl" = ( +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/structure/disposalpipe/segment{ + dir = 4 + }, +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/department/cargo) "lUz" = ( /obj/structure/girder, /turf/open/floor/plating, @@ -56941,6 +56971,10 @@ }, /turf/open/floor/plasteel, /area/hallway/primary/aft) +"mqu" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/department/crew_quarters/bar) "mqS" = ( /obj/structure/cable{ icon_state = "1-2" @@ -58322,6 +58356,14 @@ /obj/structure/window/reinforced, /turf/open/floor/plasteel, /area/science/xenobiology) +"osz" = ( +/obj/structure/cable{ + icon_state = "1-2" + }, +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/department/engine) "osC" = ( /obj/structure/disposalpipe/segment{ dir = 4 @@ -58540,6 +58582,14 @@ }, /turf/open/floor/plating, /area/commons/storage/emergency/starboard) +"oFy" = ( +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/structure/cable{ + icon_state = "1-2" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/department/cargo) "oFI" = ( /obj/structure/closet, /obj/effect/decal/cleanable/blood/old, @@ -59839,13 +59889,6 @@ }, /turf/open/floor/plating, /area/tcommsat/computer) -"qyF" = ( -/obj/structure/cable{ - icon_state = "1-2" - }, -/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden, -/turf/open/floor/plating, -/area/maintenance/department/engine) "qAk" = ( /obj/machinery/atmospherics/components/unary/vent_scrubber/on{ dir = 8 @@ -64986,6 +65029,14 @@ }, /turf/open/floor/plasteel, /area/science/xenobiology) +"xXh" = ( +/obj/structure/cable{ + icon_state = "1-2" + }, +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/department/engine) "xYV" = ( /obj/machinery/atmospherics/components/unary/outlet_injector/on{ dir = 1 @@ -86813,7 +86864,7 @@ bva aaa bIZ cbb -bSq +cvQ ccO bva xgh @@ -87546,7 +87597,7 @@ bmd bwt bvb bpu -bvb +osz bvb btQ bvb @@ -88852,7 +88903,7 @@ npE nSj cXW bPt -qyF +xXh bQU bva bva @@ -94715,7 +94766,7 @@ aKT aKT aKT aOy -aLL +mqu aLL aRP aSM @@ -101406,7 +101457,7 @@ aVp aWs aPW aYn -bIO +cyF bas aLf bcx @@ -105008,7 +105059,7 @@ aZo baB bbH bcC -kFy +gpX beL bfD bbE @@ -108844,7 +108895,7 @@ hUt aFi aFi aFi -aJs +lUl aFi aFi bHI @@ -110144,7 +110195,7 @@ aEj aEj aEj aTx -aFi +cqr aGO bcI aFi @@ -111436,7 +111487,7 @@ rWE baG eZA tDn -aFi +cqr nZw aFi gfi @@ -114271,7 +114322,7 @@ fwI eCK wQU xah -fwI +oFy fwI bqO btB diff --git a/_maps/map_files/SmolStation/SmolStation.dmm b/_maps/map_files/SmolStation/SmolStation.dmm index 7533233b12c7..38aaa19c8f47 100644 --- a/_maps/map_files/SmolStation/SmolStation.dmm +++ b/_maps/map_files/SmolStation/SmolStation.dmm @@ -538,7 +538,7 @@ /area/security/brig) "auc" = ( /obj/machinery/vending/dinnerware{ - contraband = list(/obj/item/kitchen/rollingpin = 2, /obj/item/kitchen/knife/butcher = 2, /obj/item/reagent_containers/food/condiment/flour = 4) + contraband = list(/obj/item/kitchen/rollingpin=2,/obj/item/kitchen/knife/butcher=2,/obj/item/reagent_containers/food/condiment/flour=4) }, /obj/machinery/camera{ c_tag = "Kitchen"; @@ -4995,6 +4995,10 @@ }, /turf/open/floor/plasteel, /area/commons/storage/primary) +"dsH" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/central) "dsJ" = ( /obj/effect/turf_decal/tile/neutral, /obj/effect/turf_decal/tile/neutral{ @@ -6894,6 +6898,10 @@ /obj/structure/reagent_dispensers/fueltank, /turf/open/floor/plasteel, /area/commons/storage/tools) +"eTA" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/fore) "eTM" = ( /obj/effect/turf_decal/tile/blue{ dir = 8 @@ -7134,6 +7142,19 @@ /obj/machinery/power/tracker, /turf/open/floor/plasteel/airless/solarpanel, /area/space/nearstation) +"fhi" = ( +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer3{ + dir = 4 + }, +/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer1{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/central) "fjd" = ( /obj/structure/cable{ icon_state = "1-2" @@ -14964,6 +14985,15 @@ /obj/effect/spawner/structure/window/reinforced, /turf/open/floor/plating, /area/security/brig) +"kOh" = ( +/obj/machinery/atmospherics/pipe/simple/supply/hidden/layer1, +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer3, +/obj/structure/cable{ + icon_state = "1-2" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/fore) "kOz" = ( /obj/machinery/computer/rdconsole/core{ dir = 4 @@ -17898,6 +17928,7 @@ /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer3{ dir = 4 }, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating, /area/maintenance/central) "mXP" = ( @@ -24431,6 +24462,10 @@ }, /turf/open/space/basic, /area/space) +"siQ" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/aft) "sjb" = ( /obj/machinery/atmospherics/pipe/simple/supply/hidden/layer1{ dir = 6 @@ -27505,6 +27540,10 @@ /obj/effect/turf_decal/tile/brown, /turf/open/floor/plasteel, /area/cargo/qm) +"uuT" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/fore) "uuY" = ( /obj/machinery/light/small, /obj/machinery/camera{ @@ -61569,7 +61608,7 @@ lOA lOA lOA lOA -lOA +uuT kQV blb nPv @@ -64197,7 +64236,7 @@ tZL fOl erD hJA -wmr +fhi kea kea kea @@ -64471,7 +64510,7 @@ inK inK kea iQG -iQG +siQ hMW sew hLz @@ -66992,7 +67031,7 @@ sHB oqW jhl wGd -tgK +dsH jhl saE wyw @@ -69277,7 +69316,7 @@ eNc jEc ceL jpY -eNc +eTA eNc eNc qas @@ -69548,7 +69587,7 @@ nSL nSL nSL nSL -nSL +kOh nSL nSL nSL diff --git a/_maps/map_files/SpookyStation/SpookyStation.dmm b/_maps/map_files/SpookyStation/SpookyStation.dmm index 0db822f4f7c6..406c42a2499b 100644 --- a/_maps/map_files/SpookyStation/SpookyStation.dmm +++ b/_maps/map_files/SpookyStation/SpookyStation.dmm @@ -16726,6 +16726,14 @@ /obj/effect/turf_decal/delivery, /turf/open/floor/plasteel, /area/eventmap/inside) +"oWI" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/spooktime/cobble/roadmid, +/area/eventmap/outside) +"phL" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/spooktime/cobble/roadsideS, +/area/eventmap/outside) "sDL" = ( /obj/structure/sign/poster/contraband/yes_erp, /turf/closed/wall/mineral/wood, @@ -38243,8 +38251,8 @@ aRd aGM aRo aRD -aWA -aKq +oWI +phL aaN aaN aaN @@ -38500,8 +38508,8 @@ apR ayO aWA aRt -aWA -aKq +oWI +phL aaN aaN aaN @@ -38757,8 +38765,8 @@ apR ayO aWA aRt -aWA -aKq +oWI +phL aaN aaN aaN @@ -39014,8 +39022,8 @@ awm ayO aWA aRt -aWA -aKq +oWI +phL aaN aaN aYI @@ -39271,8 +39279,8 @@ apR ayO aWA aRt -aWA -aKq +oWI +phL aaN aaN aaN @@ -39528,8 +39536,8 @@ apR ayO aWA aRt -aWA -aKq +oWI +phL aaN aaN aaN diff --git a/_maps/map_files/SyndicateStation/SyndicateBoxStation.dmm b/_maps/map_files/SyndicateStation/SyndicateBoxStation.dmm index ea70d19af761..53198a774044 100644 --- a/_maps/map_files/SyndicateStation/SyndicateBoxStation.dmm +++ b/_maps/map_files/SyndicateStation/SyndicateBoxStation.dmm @@ -38700,6 +38700,7 @@ /obj/machinery/atmospherics/pipe/simple/supply/hidden{ dir = 6 }, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating, /area/maintenance/port/aft) "bUv" = ( @@ -41781,6 +41782,7 @@ /obj/machinery/atmospherics/pipe/simple/supply/hidden{ dir = 6 }, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating, /area/maintenance/starboard/aft) "ccq" = ( @@ -46505,6 +46507,7 @@ /area/maintenance/disposal/incinerator) "cqv" = ( /obj/effect/decal/cleanable/cobweb/cobweb2, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating, /area/maintenance/port/aft) "cqw" = ( @@ -52217,6 +52220,14 @@ /obj/structure/alien/weeds, /turf/open/floor/mineral/plastitanium, /area/commons/dorms) +"eYX" = ( +/obj/structure/cable{ + icon_state = "1-2" + }, +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/fore) "eZa" = ( /obj/effect/landmark/start/paramedic, /turf/open/floor/mineral/plastitanium, @@ -52983,6 +52994,18 @@ /obj/structure/lattice, /turf/open/space/basic, /area/space/nearstation) +"fSu" = ( +/obj/structure/disposalpipe/segment, +/obj/structure/cable{ + icon_state = "1-2" + }, +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/machinery/light{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/aft) "fSO" = ( /obj/machinery/atmospherics/pipe/simple/scrubbers/visible, /obj/machinery/atmospherics/pipe/simple/orange/visible{ @@ -54460,6 +54483,10 @@ /obj/effect/turf_decal/tile/green, /turf/open/floor/mineral/plastitanium, /area/hallway/primary/starboard) +"ivb" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/fore) "ivD" = ( /turf/open/floor/plating, /area/space) @@ -55501,6 +55528,10 @@ }, /turf/open/floor/mineral/plastitanium, /area/engineering/atmos) +"jZP" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/fore) "jZT" = ( /obj/structure/cable{ icon_state = "4-8" @@ -62943,6 +62974,12 @@ }, /turf/open/floor/plating, /area/maintenance/fore) +"vgM" = ( +/obj/structure/disposalpipe/segment, +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/fore/secondary) "vhy" = ( /obj/machinery/atmospherics/pipe/simple/supply/hidden{ dir = 4 @@ -64668,6 +64705,10 @@ }, /turf/open/floor/mineral/plastitanium/red, /area/security/brig) +"xHS" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/aft) "xJC" = ( /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ dir = 10 @@ -84646,7 +84687,7 @@ fmJ ygb kiW qlV -amC +ivb ntt nBI qlV @@ -85750,7 +85791,7 @@ cqn cAh chT bHE -bHE +xHS ckv bHE bCq @@ -86764,7 +86805,7 @@ bRg bCq bHE bVG -bHE +xHS bHE bCq mqZ @@ -89580,7 +89621,7 @@ bCn bGq bGq bGq -rGq +fSu bLw bGq bGq @@ -89603,7 +89644,7 @@ bVI bVI aJq xgk -bHE +xHS kEm bHE bHE @@ -99282,7 +99323,7 @@ ahT ahT ahT ahT -ahT +vgM ahT alL ahT @@ -106489,7 +106530,7 @@ apB aqx art anf -anf +jZP auF apC awH @@ -110092,7 +110133,7 @@ aFn aBB awM ayg -ayg +eYX ayg ayg aCl diff --git a/_maps/map_files/TauStation/TauStation.dmm b/_maps/map_files/TauStation/TauStation.dmm index 4d10f2a5f49e..7d378ae1b3bc 100644 --- a/_maps/map_files/TauStation/TauStation.dmm +++ b/_maps/map_files/TauStation/TauStation.dmm @@ -9301,6 +9301,19 @@ /obj/structure/lattice/catwalk, /turf/open/space/basic, /area/space/nearstation) +"dlX" = ( +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ + dir = 4 + }, +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/structure/disposalpipe/segment{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/department/science) "dmd" = ( /obj/machinery/atmospherics/pipe/simple/supply/hidden, /obj/effect/turf_decal/tile/neutral{ @@ -24862,6 +24875,15 @@ }, /turf/open/floor/engine, /area/science/xenobiology) +"izV" = ( +/obj/structure/cable{ + icon_state = "1-2" + }, +/obj/structure/disposalpipe/segment, +/obj/machinery/atmospherics/pipe/simple/supply/hidden, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/department/medical) "iAi" = ( /obj/machinery/portable_atmospherics/canister/oxygen, /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden, @@ -26676,6 +26698,16 @@ }, /turf/closed/wall, /area/maintenance/department/engine) +"jju" = ( +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ + dir = 4 + }, +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/fore) "jjE" = ( /obj/effect/spawner/structure/window, /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden, @@ -35201,6 +35233,13 @@ }, /turf/open/floor/plasteel/dark, /area/hallway/primary/port) +"miK" = ( +/obj/machinery/atmospherics/pipe/simple/supply/hidden{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/aft) "miN" = ( /obj/structure/cable{ icon_state = "4-8" @@ -51663,6 +51702,7 @@ /obj/structure/cable{ icon_state = "2-8" }, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating, /area/maintenance/department/science) "rXk" = ( @@ -57062,6 +57102,10 @@ }, /turf/open/floor/plating/beach/sand, /area/service/library/artgallery/museum) +"tND" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/aft) "tNF" = ( /obj/structure/cable{ icon_state = "1-8" @@ -61184,6 +61228,19 @@ }, /turf/open/floor/plasteel/white, /area/science/xenobiology) +"vja" = ( +/obj/structure/disposalpipe/segment{ + dir = 4 + }, +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/machinery/atmospherics/pipe/simple/scrubbers/hidden{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/department/medical) "vjp" = ( /obj/structure/window/reinforced, /obj/machinery/aug_manipulator, @@ -65490,6 +65547,13 @@ }, /turf/open/floor/plating, /area/maintenance/department/medical) +"wAu" = ( +/obj/structure/cable{ + icon_state = "1-2" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/fore) "wAv" = ( /obj/machinery/power/apc{ areastring = "/area/security/checkpoint/medical"; @@ -69362,6 +69426,10 @@ "xNa" = ( /turf/closed/wall/r_wall, /area/science/lab) +"xNf" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/department/science) "xNy" = ( /obj/item/sharpener{ pixel_x = 6 @@ -92986,7 +93054,7 @@ ycW qkf wLl wLl -ycW +izV ycW ycW wfF @@ -94534,7 +94602,7 @@ ybK ybK ybK ybK -ygg +vja vmP aBv ocO @@ -98400,7 +98468,7 @@ yde trt owJ uTQ -ygg +vja xXs evJ xXs @@ -106920,7 +106988,7 @@ dvp fph sdb aYi -wBz +tND uiQ uiQ uiQ @@ -107901,7 +107969,7 @@ hce hce xYK fLy -wim +dlX mxU xhN jGo @@ -107939,7 +108007,7 @@ qEt oCl wBP tpI -aib +miK sdb nhq dvp @@ -110999,7 +111067,7 @@ yji bQB mxU mMc -xUV +xNf xUV fOc whY @@ -111712,7 +111780,7 @@ vmU eBz thT eBz -vfB +jju eBz vyq wbQ @@ -117842,7 +117910,7 @@ hpl qJe fbk pkR -ptR +wAu ptR ptR ptR diff --git a/_maps/splurt_maps/map_files/Smexistation/Snaxi_Splurt.dmm b/_maps/splurt_maps/map_files/Smexistation/Snaxi_Splurt.dmm index 9e3065d6a0da..bbdc64980427 100644 --- a/_maps/splurt_maps/map_files/Smexistation/Snaxi_Splurt.dmm +++ b/_maps/splurt_maps/map_files/Smexistation/Snaxi_Splurt.dmm @@ -289,13 +289,13 @@ "abk" = ( /obj/structure/closet/secure_closet/freezer/fridge, /obj/item/reagent_containers/food/condiment/flour{ - list_reagents = list(/datum/reagent/consumable/flour = 90); + list_reagents = list(/datum/reagent/consumable/flour=90); name = "large flour sack"; possible_transfer_amounts = list(1,5,10,15,30,60,90); volume = 90 }, /obj/item/reagent_containers/food/condiment/flour{ - list_reagents = list(/datum/reagent/consumable/flour = 90); + list_reagents = list(/datum/reagent/consumable/flour=90); name = "large flour sack"; possible_transfer_amounts = list(1,5,10,15,30,60,90); volume = 90 @@ -303,7 +303,7 @@ /obj/item/reagent_containers/food/condiment/mayonnaise, /obj/item/reagent_containers/food/condiment/milk, /obj/item/reagent_containers/food/condiment/rice{ - list_reagents = list(/datum/reagent/consumable/rice = 90); + list_reagents = list(/datum/reagent/consumable/rice=90); name = "large rice sack"; possible_transfer_amounts = list(1,5,10,15,20,25,30,50,60,90) }, @@ -556,6 +556,11 @@ }, /turf/open/floor/plasteel/white, /area/medical/medbay/central) +"adG" = ( +/obj/effect/decal/cleanable/dirt/dust, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/aft) "adH" = ( /obj/structure/transit_tube/curved/flipped, /turf/open/floor/plating/snowed/smoothed/icemoon, @@ -4909,6 +4914,10 @@ }, /turf/open/floor/plasteel, /area/cargo/miningdock) +"brv" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/aft) "brB" = ( /obj/effect/spawner/structure/window/reinforced, /obj/machinery/door/poddoor/preopen{ @@ -8936,6 +8945,7 @@ /obj/structure/cable{ icon_state = "1-8" }, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating, /area/maintenance/aft/secondary) "crw" = ( @@ -8944,7 +8954,7 @@ req_access_txt = "3" }, /obj/effect/spawner/lootdrop/armory_contraband{ - loot = list(/obj/item/gun/ballistic/automatic/pistol = 5, /obj/item/gun/ballistic/shotgun/automatic/combat = 5, /obj/item/gun/ballistic/revolver/mateba, /obj/item/gun/ballistic/automatic/pistol/deagle, /obj/item/storage/box/syndie_kit/throwing_weapons = 3) + loot = list(/obj/item/gun/ballistic/automatic/pistol=5,/obj/item/gun/ballistic/shotgun/automatic/combat=5,/obj/item/gun/ballistic/revolver/mateba,/obj/item/gun/ballistic/automatic/pistol/deagle,/obj/item/storage/box/syndie_kit/throwing_weapons=3) }, /obj/effect/decal/cleanable/dirt/dust, /turf/open/floor/plasteel/dark, @@ -18523,7 +18533,7 @@ input_tag = "mix_in2"; name = "Aux Gas Mix Tank Control"; output_tag = "mix_out2"; - sensors = list("mix_sensor2" = "Aux Gas Mix Tank ") + sensors = list("mix_sensor2"="Aux Gas Mix Tank ") }, /turf/open/floor/plasteel, /area/engineering/atmos) @@ -28123,6 +28133,10 @@ /obj/structure/girder/displaced, /turf/open/floor/plating/snowed/smoothed/icemoon, /area/icemoon/surface/outdoors) +"kKU" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/engineering/storage) "kKY" = ( /obj/structure/cable{ icon_state = "1-2" @@ -28362,7 +28376,7 @@ /area/engineering/main) "kPA" = ( /obj/effect/spawner/lootdrop{ - loot = list(/obj/item/gun/ballistic/revolver/russian = 5, /obj/item/storage/box/syndie_kit/throwing_weapons, /obj/item/toy/cards/deck/syndicate = 2); + loot = list(/obj/item/gun/ballistic/revolver/russian=5,/obj/item/storage/box/syndie_kit/throwing_weapons,/obj/item/toy/cards/deck/syndicate=2); name = "gambling valuables spawner" }, /obj/structure/table/wood/poker, @@ -41504,7 +41518,7 @@ /area/engineering/break_room) "qzP" = ( /obj/machinery/vending/dinnerware{ - contraband = list(/obj/item/kitchen/rollingpin = 2, /obj/item/kitchen/knife/butcher = 2, /obj/item/reagent_containers/food/condiment/flour = 4) + contraband = list(/obj/item/kitchen/rollingpin=2,/obj/item/kitchen/knife/butcher=2,/obj/item/reagent_containers/food/condiment/flour=4) }, /turf/open/floor/plasteel/freezer, /area/service/kitchen/coldroom) @@ -44091,6 +44105,10 @@ /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer3, /turf/open/floor/plasteel, /area/hallway/primary/starboard/aft) +"rGN" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/central) "rGP" = ( /obj/machinery/turnstile{ dir = 8; @@ -50728,6 +50746,10 @@ }, /turf/open/floor/plating, /area/hallway/secondary/exit/departure_lounge) +"uFI" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/starboard/aft) "uFT" = ( /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer3{ dir = 10 @@ -52569,6 +52591,7 @@ dir = 1; light_color = "#ffc1c1" }, +/obj/effect/landmark/start/stowaway, /turf/open/floor/plating, /area/maintenance/aft) "vvH" = ( @@ -55129,6 +55152,10 @@ }, /turf/open/floor/plating, /area/security/checkpoint/supply) +"wvA" = ( +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/aft/secondary) "wvL" = ( /obj/machinery/cryopod{ dir = 1 @@ -56498,7 +56525,7 @@ "xcL" = ( /obj/structure/table, /obj/effect/spawner/lootdrop{ - loot = list(/obj/item/gun/ballistic/revolver/russian = 5, /obj/item/storage/box/syndie_kit/throwing_weapons, /obj/item/toy/cards/deck/syndicate = 2); + loot = list(/obj/item/gun/ballistic/revolver/russian=5,/obj/item/storage/box/syndie_kit/throwing_weapons,/obj/item/toy/cards/deck/syndicate=2); name = "gambling valuables spawner" }, /turf/open/floor/plasteel, @@ -57148,6 +57175,13 @@ }, /turf/open/floor/plasteel/dark, /area/ai_monitored/security/armory) +"xqY" = ( +/obj/structure/cable{ + icon_state = "4-8" + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/aft/secondary) "xrL" = ( /obj/machinery/light{ dir = 1 @@ -59058,6 +59092,13 @@ }, /turf/open/floor/circuit/telecomms/mainframe, /area/tcommsat/server) +"yle" = ( +/obj/structure/railing{ + dir = 4 + }, +/obj/effect/landmark/start/stowaway, +/turf/open/floor/plating, +/area/maintenance/port/central) "ylx" = ( /obj/effect/turf_decal/tile/red{ dir = 8 @@ -82324,7 +82365,7 @@ nLS nLS nLS xJp -xJp +yle nLS nLS jOq @@ -83351,7 +83392,7 @@ wje nLS cpX dGu -gdQ +rGN qel rRU nLS @@ -91384,7 +91425,7 @@ bfa rRa cey wlV -wlV +brv ucZ eTv iIS @@ -97042,7 +97083,7 @@ sAC iBd jpS wTK -wGq +wvA wTK wGq kSv @@ -98584,7 +98625,7 @@ tJJ tJJ tnV wTK -jxp +xqY fJr wTK avT @@ -108519,7 +108560,7 @@ eDt mKy qDt qDt -xJU +adG uoz xLQ vcm @@ -110826,7 +110867,7 @@ oUQ qRF lnH pwC -fBS +kKU wFO mZp wwi @@ -113913,7 +113954,7 @@ avT qDt lKk rUk -rUk +uFI qDt qDt qDt diff --git a/code/__DEFINES/_flags/_flags.dm b/code/__DEFINES/_flags/_flags.dm index c86659d49094..ca026edbf273 100644 --- a/code/__DEFINES/_flags/_flags.dm +++ b/code/__DEFINES/_flags/_flags.dm @@ -68,6 +68,8 @@ GLOBAL_LIST_INIT(bitflags, list( #define NO_RUINS_1 (1<<10) /// Should this tile be cleaned up and reinserted into an excited group? #define EXCITED_CLEANUP_1 (1 << 13) +/// Whether or not this atom has contextual screentips when hovered OVER +#define HAS_CONTEXTUAL_SCREENTIPS_1 (1 << 14) ////////////////Area flags\\\\\\\\\\\\\\ /// If it's a valid territory for cult summoning or the CRAB-17 phone to spawn diff --git a/code/__DEFINES/_flags/obj_flags.dm b/code/__DEFINES/_flags/obj_flags.dm index 5f5ea12aaa3b..c3c48c7d7431 100644 --- a/code/__DEFINES/_flags/obj_flags.dm +++ b/code/__DEFINES/_flags/obj_flags.dm @@ -17,6 +17,8 @@ #define EXAMINE_SKIP (1<<14) /// Makes the Examine proc not read out this item. #define IN_STORAGE (1<<15) //is this item in the storage item, such as backpack? used for tooltips #define HAND_ITEM (1<<16) // If an item is just your hand (circled hand, slapper) and shouldn't block things like riding +/// Has contextual screentips when HOVERING OVER OTHER objects +#define ITEM_HAS_CONTEXTUAL_SCREENTIPS (1 << 17) /// Integrity defines for clothing (not flags but close enough) #define CLOTHING_PRISTINE 0 // We have no damage on the clothing diff --git a/code/__DEFINES/dcs/signals/signals_painting.dm b/code/__DEFINES/dcs/signals/signals_painting.dm new file mode 100644 index 000000000000..4f9201ec8f2e --- /dev/null +++ b/code/__DEFINES/dcs/signals/signals_painting.dm @@ -0,0 +1,7 @@ +// signals for painting canvases, tools and the /datum/component/palette component + +///from base of /item/proc/set_painting_tool_color(): (chosen_color) +#define COMSIG_PAINTING_TOOL_SET_COLOR "painting_tool_set_color" + +/// from base of /item/canvas/ui_data(): (data) +#define COMSIG_PAINTING_TOOL_GET_ADDITIONAL_DATA "painting_tool_get_data" diff --git a/code/__DEFINES/dcs/signals/signals_screentips.dm b/code/__DEFINES/dcs/signals/signals_screentips.dm new file mode 100644 index 000000000000..8f7326ee2ee7 --- /dev/null +++ b/code/__DEFINES/dcs/signals/signals_screentips.dm @@ -0,0 +1,23 @@ +/// A "Type-A" contextual screentip interaction. +/// These are used for items that are defined by their behavior. They define their contextual text within *themselves*, +/// not in their targets. +/// Examples include syringes (LMB to inject, RMB to draw) and health analyzers (LMB to scan health/wounds, RMB for chems) +/// Items can override `add_item_context()`, and call `register_item_context()` in order to easily connect to this. +/// Called on /obj/item with a mutable screentip context list, the hovered target, and the mob hovering. +/// A screentip context list is a list that has context keys (SCREENTIP_CONTEXT_*, from __DEFINES/screentips.dm) +/// that map to the action as text. +/// If you mutate the list in this signal, you must return CONTEXTUAL_SCREENTIP_SET. +#define COMSIG_ITEM_REQUESTING_CONTEXT_FOR_TARGET "item_requesting_context_for_target" + +/// A "Type-B" contextual screentip interaction. +/// These are atoms that are defined by what happens *to* them. These should define contextual text within themselves, and +/// not in their operating tools. +/// Examples include construction objects (LMB with glass to put in screen for computers). +/// Called on /atom with a mutable screentip context list, the item being used, and the mob hovering. +/// A screentip context list is a list that has context keys (SCREENTIP_CONTEXT_*, from __DEFINES/screentips.dm) +/// that map to the action as text. +/// If you mutate the list in this signal, you must return CONTEXTUAL_SCREENTIP_SET. +#define COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM "atom_requesting_context_from_item" + +/// Tells the contextual screentips system that the list context was mutated. +#define CONTEXTUAL_SCREENTIP_SET (1 << 0) diff --git a/code/__DEFINES/inventory.dm b/code/__DEFINES/inventory.dm index 681a4f9059ae..6d7df3e93f6e 100644 --- a/code/__DEFINES/inventory.dm +++ b/code/__DEFINES/inventory.dm @@ -58,9 +58,11 @@ #define ITEM_SLOT_HANDCUFFED (1<<23) /// Legcuff slot (bolas, beartraps) #define ITEM_SLOT_LEGCUFFED (1<<24) +/// To attach to a jumpsuit +#define ITEM_SLOT_ACCESSORY (1<<25) /// Total amount of slots -#define SLOTS_AMT 25 // Keep this up to date! +#define SLOTS_AMT 26 // Keep this up to date! //SLOT GROUP HELPERS #define ITEM_SLOT_POCKETS (ITEM_SLOT_LPOCKET|ITEM_SLOT_RPOCKET) diff --git a/code/__DEFINES/jobs.dm b/code/__DEFINES/jobs.dm index 49daf4147f45..032ae9ded04c 100644 --- a/code/__DEFINES/jobs.dm +++ b/code/__DEFINES/jobs.dm @@ -48,6 +48,7 @@ #define MIME (1<<12) #define ASSISTANT (1<<13) #define PRISONER (1<<14) +#define STOWAWAY (1<<15) #define JOB_AVAILABLE 0 #define JOB_UNAVAILABLE_GENERIC 1 @@ -101,3 +102,4 @@ #define JOB_DISPLAY_ORDER_BLUESHIELD 37 #define JOB_DISPLAY_ORDER_BO 38 #define JOB_DISPLAY_ORDER_PRISONER 39 +#define JOB_DISPLAY_ORDER_STOWAWAY 40 diff --git a/code/__DEFINES/loadout.dm b/code/__DEFINES/loadout.dm index 182e58c1f738..9f771df663de 100644 --- a/code/__DEFINES/loadout.dm +++ b/code/__DEFINES/loadout.dm @@ -4,10 +4,12 @@ #define LOADOUT_SUBCATEGORY_NONE "Miscellaneous" #define LOADOUT_SUBCATEGORIES_NONE list("Miscellaneous") +//accessory +#define LOADOUT_CATEGORY_ACCESSORY "Accessory" + //backpack #define LOADOUT_CATEGORY_BACKPACK "In backpack" #define LOADOUT_SUBCATEGORY_BACKPACK_GENERAL "General" //basically anything that there's not enough of to have its own subcategory -#define LOADOUT_SUBCATEGORY_BACKPACK_ACCESSORIES "Accessories" //maybe one day someone will make loadouts have accessory compatibility #define LOADOUT_SUBCATEGORY_BACKPACK_TOYS "Toys" //neck #define LOADOUT_CATEGORY_NECK "Neck" @@ -84,7 +86,7 @@ #define LOADOUT_CAN_DESCRIPTION (1<<1) //adding a custom description to items #define LOADOUT_CAN_COLOR_POLYCHROMIC (1<<2) -//the names of the customization tabs +/* the names of the customization tabs #define SETTINGS_TAB 0 #define GAME_PREFERENCES_TAB 1 #define APPEARANCE_TAB 2 @@ -92,6 +94,7 @@ #define LOADOUT_TAB 4 #define CONTENT_PREFERENCES_TAB 5 #define KEYBINDINGS_TAB 6 +*/ //quirks #define QUIRK_POSITIVE "Positive" diff --git a/code/__DEFINES/screentips.dm b/code/__DEFINES/screentips.dm new file mode 100644 index 000000000000..a3b101835251 --- /dev/null +++ b/code/__DEFINES/screentips.dm @@ -0,0 +1,35 @@ +/// Context applied to LMB actions +#define SCREENTIP_CONTEXT_LMB "LMB" + +/// Context applied to RMB actions +#define SCREENTIP_CONTEXT_RMB "RMB" + +/// Context applied to Shift-LMB actions +#define SCREENTIP_CONTEXT_SHIFT_LMB "Shift-LMB" + +/// Context applied to Ctrl-LMB actions +#define SCREENTIP_CONTEXT_CTRL_LMB "Ctrl-LMB" + +/// Context applied to Ctrl-RMB actions +#define SCREENTIP_CONTEXT_CTRL_RMB "Ctrl-RMB" + +/// Context applied to Alt-LMB actions +#define SCREENTIP_CONTEXT_ALT_LMB "Alt-LMB" + +/// Context applied to Alt-RMB actions +#define SCREENTIP_CONTEXT_ALT_RMB "Alt-RMB" + +/// Context applied to Ctrl-Shift-LMB actions +#define SCREENTIP_CONTEXT_CTRL_SHIFT_LMB "Ctrl-Shift-LMB" + +/// Screentips are always disabled +#define SCREENTIP_PREFERENCE_DISABLED "Disabled" + +/// Screentips are always enabled +#define SCREENTIP_PREFERENCE_ENABLED "Enabled" + +/// Screentips are only enabled when they have context +#define SCREENTIP_PREFERENCE_CONTEXT_ONLY "Only with tips" + +/// Regardless of intent +#define INTENT_ANY "intent_any" diff --git a/code/__HELPERS/custom_holoforms.dm b/code/__HELPERS/custom_holoforms.dm index 8aa8d279ec42..87f3bfbe8bbb 100644 --- a/code/__HELPERS/custom_holoforms.dm +++ b/code/__HELPERS/custom_holoforms.dm @@ -6,6 +6,7 @@ prefs.copy_to(mannequin) if(apply_loadout && prefs.parent) SSjob.equip_loadout(prefs.parent.mob, mannequin, bypass_prereqs = TRUE) + SSjob.post_equip_loadout(prefs.parent.mob, mannequin, bypass_prereqs = TRUE) if(copy_job) var/datum/job/highest = prefs.get_highest_job() if(highest && !istype(highest, /datum/job/ai) && !istype(highest, /datum/job/cyborg)) diff --git a/code/__HELPERS/game.dm b/code/__HELPERS/game.dm index fc220e60c63d..38b8bdfb2497 100644 --- a/code/__HELPERS/game.dm +++ b/code/__HELPERS/game.dm @@ -578,7 +578,7 @@ deadchat_broadcast(" has arrived at the station at [player_area.name].", "[character.real_name] ([rank])", follow_target = character, message_type=DEADCHAT_ARRIVALRATTLE) if((!GLOB.announcement_systems.len) || (!character.mind)) return - if((character.mind.assigned_role == "Cyborg") || (character.mind.assigned_role == character.mind.special_role)) + if((character.mind.assigned_role == "Cyborg") || (character.mind.assigned_role == character.mind.special_role) || (character.mind.assigned_role == "Stowaway")) return //Skyrat changes diff --git a/code/__HELPERS/screentips.dm b/code/__HELPERS/screentips.dm new file mode 100644 index 000000000000..967e1c3bb64f --- /dev/null +++ b/code/__HELPERS/screentips.dm @@ -0,0 +1,31 @@ +// Generate intent icons +/// Help intent icon for screentip context +GLOBAL_DATUM_INIT(icon_intent_help, /image, image('icons/emoji.dmi', icon_state = INTENT_HELP)) +/// Disarm intent icon for screentip context +GLOBAL_DATUM_INIT(icon_intent_disarm, /image, image('icons/emoji.dmi', icon_state = INTENT_DISARM)) +/// Grab intent icon for screentip context +GLOBAL_DATUM_INIT(icon_intent_grab, /image, image('icons/emoji.dmi', icon_state = INTENT_GRAB)) +/// Harm intent icon for screentip context +GLOBAL_DATUM_INIT(icon_intent_harm, /image, image('icons/emoji.dmi', icon_state = INTENT_HARM)) + +/* + * # Builds context with each intent for this key + * Args: + * - context = list (REQUIRED) + * - key = string (REQUIRED) +*/ +/proc/build_context(list/context, key) + var/list/to_add + for(var/intent in context[key]) + switch(intent) + if(INTENT_HELP) + LAZYADD(to_add, "\icon[GLOB.icon_intent_help] [key]: [context[key][INTENT_HELP]]") + if(INTENT_DISARM) + LAZYADD(to_add, "\icon[GLOB.icon_intent_disarm] [key]: [context[key][INTENT_DISARM]]") + if(INTENT_GRAB) + LAZYADD(to_add, "\icon[GLOB.icon_intent_grab] [key]: [context[key][INTENT_GRAB]]") + if(INTENT_HARM) + LAZYADD(to_add, "\icon[GLOB.icon_intent_harm] [key]: [context[key][INTENT_HARM]]") + else // If you're adding intent-less YOU BETTER ADD IT FIRST IN THE LIST + LAZYADD(to_add, "[key]: [context[key][intent]]") + return english_list(to_add, "", " ", " ") diff --git a/code/__SANDCODE/DEFINES/DNA.dm b/code/__SANDCODE/DEFINES/DNA.dm new file mode 100644 index 000000000000..547ab21071e6 --- /dev/null +++ b/code/__SANDCODE/DEFINES/DNA.dm @@ -0,0 +1,3 @@ +#define PREVIEW_PREF_JOB "Job" +#define PREVIEW_PREF_LOADOUT "Loadout" +#define PREVIEW_PREF_NAKED "Naked" diff --git a/code/__SANDCODE/DEFINES/dcs/signals/signals_mob_main.dm b/code/__SANDCODE/DEFINES/dcs/signals/signals_mob_main.dm new file mode 100644 index 000000000000..9eaa655bf202 --- /dev/null +++ b/code/__SANDCODE/DEFINES/dcs/signals/signals_mob_main.dm @@ -0,0 +1 @@ +#define COMSIG_MOB_CTRLSHIFTCLICKON "mob_ctrlshiftclickon" diff --git a/code/__SANDCODE/DEFINES/loadout.dm b/code/__SANDCODE/DEFINES/loadout.dm index 3e87fca92711..3d3a130334e2 100644 --- a/code/__SANDCODE/DEFINES/loadout.dm +++ b/code/__SANDCODE/DEFINES/loadout.dm @@ -13,3 +13,21 @@ #define LOADOUT_CATEGORY_WRISTS "Wrists" /// Subcategory for watches #define LOADOUT_SUBCATEGORY_WATCHES "Watches" + +//the names of the customization tabs +#define SETTINGS_TAB 0 +#define PREFERENCES_TAB 1 +#define KEYBINDINGS_TAB 2 + +//subtabs for the character settings tab +#define GENERAL_CHAR_TAB 0 +#define APPEARANCE_CHAR_TAB 1 +#define MARKINGS_CHAR_TAB 2 +#define SPEECH_CHAR_TAB 3 +#define BACKGROUND_CHAR_TAB 4 +#define LOADOUT_CHAR_TAB 5 + +//subtabs for preferences tab +#define GAME_PREFS_TAB 0 +#define OOC_PREFS_TAB 1 +#define CONTENT_PREFS_TAB 2 diff --git a/code/__SANDCODE/HELPERS/sizecode.dm b/code/__SANDCODE/HELPERS/sizecode.dm index b312b8fcc96b..41c17a0ef0d8 100644 --- a/code/__SANDCODE/HELPERS/sizecode.dm +++ b/code/__SANDCODE/HELPERS/sizecode.dm @@ -14,3 +14,15 @@ return has_dna.features["body_size"] else return target.size_multiplier + +/* + * # COMPARE_SIZES(mob/living/user, mob/living/target) + * Returns how bigger or smaller the target is in comparison to user + * Example: + * - user = 2, target = 1, result = 0.5 + * - user = 1, target = 2, result = 2 + * Args: + * - user = /mob/living + * - target = /mob/living +*/ +#define COMPARE_SIZES(user, target) abs((get_size(user) / get_size(target))) diff --git a/code/__SPLURTCODE/DEFINES/preferences.dm b/code/__SPLURTCODE/DEFINES/preferences.dm new file mode 100644 index 000000000000..ba74e8762e81 --- /dev/null +++ b/code/__SPLURTCODE/DEFINES/preferences.dm @@ -0,0 +1 @@ +#define DEFAULT_SAVE_SLOTS 24 diff --git a/code/__SPLURTCODE/DEFINES/quirks.dm b/code/__SPLURTCODE/DEFINES/quirks.dm index 9353f87dc789..041d47311755 100644 --- a/code/__SPLURTCODE/DEFINES/quirks.dm +++ b/code/__SPLURTCODE/DEFINES/quirks.dm @@ -1,3 +1,9 @@ //Dominant/Well-trained quirks #define DOMINANT_DETECT_RANGE 5 #define DOMINANT_SNAP_COOLDOWN 10 SECONDS + +// Quirk mood types +#define QMOOD_NUDIST "mood_nudist" +#define QMOOD_MASKED_MOOK "mood_masked_mook" +#define QMOOD_HIDE_BAG "mood_storage_concealment" +#define QMOOD_WELL_TRAINED "mood_dom_trained" diff --git a/code/__SPLURTCODE/DEFINES/species.dm b/code/__SPLURTCODE/DEFINES/species.dm index d9d5642ce874..3248d840c85a 100644 --- a/code/__SPLURTCODE/DEFINES/species.dm +++ b/code/__SPLURTCODE/DEFINES/species.dm @@ -1,2 +1,4 @@ -#define SPECIES_SPECBOT "spectre_bot" -#define SPECIES_SHADEKIN "shadekin" +#define SPECIES_SPECBOT "spectre_bot" +#define SPECIES_SHADEKIN "shadekin" +#define SPECIES_ASHWALKER_WEST "ashlizard_west" +#define SPECIES_ASHWALKER_EAST "ashlizard_east" diff --git a/code/__SPLURTCODE/DEFINES/traits.dm b/code/__SPLURTCODE/DEFINES/traits.dm index 121772f7e171..ad5c15198c59 100644 --- a/code/__SPLURTCODE/DEFINES/traits.dm +++ b/code/__SPLURTCODE/DEFINES/traits.dm @@ -1,28 +1,32 @@ -#define SLAVER_TRAIT "slaver" -#define PREGNANCY_TRAIT "pregnancy" - -#define TRAIT_HYPNOTIC_GAZE "Hypnotic Gaze" -#define TRAIT_PREGNANT "pregnant" - -#define TRAIT_FLOORED "floored" -#define IGNORE_FAKE_Z_AXIS "ignore_fake_z_axis" - -#define TRAIT_GFLUID_DETECT "genital_fluid_detect" - -#define TRAIT_ASHRESISTANCE "TRAIT_ASHRESISTANCE" - -#define TRAIT_TONGUELESS_SPEECH "tongueless-speech" //for dephelm stuff - -// Hyperstation traits -#define TRAIT_PHARMA "hepatic_pharmacokinesis" +// General traits +#define TRAIT_PREGNANT "pregnant" +#define TRAIT_FLOORED "floored" +#define IGNORE_FAKE_Z_AXIS "ignore_fake_z_axis" +#define TRAIT_TONGUELESS_SPEECH "tongueless_speech" + +// Trait types +#define SLAVER_TRAIT "slaver" +#define PREGNANCY_TRAIT "pregnancy" + +// Quirk traits +#define TRAIT_HYPNOTIC_GAZE "hypnotic_gaze" +#define TRAIT_GFLUID_DETECT "genital_fluid_detect" +#define TRAIT_ASHRESISTANCE "ash_resistance" +#define TRAIT_PHARMA "hepatic_pharmacokinesis" #define TRAIT_CHOKE_SLUT "choke_slut" - -#define TRAIT_BLOODFLEDGE "BloodFledge" - -#define TRAIT_INCUBUS "Incubus" -#define TRAIT_SUCCUBUS "Succubus" - -#define TRAIT_ARACHNID "Arachnid" +#define TRAIT_BLOODFLEDGE "bloodfledge" +#define TRAIT_INCUBUS "incubus" +#define TRAIT_SUCCUBUS "succubus" +#define TRAIT_ARACHNID "arachnid" #define TRAIT_FLUTTER "flutter" -#define TRAIT_NUDIST "Nudist" +#define TRAIT_NUDIST "nudist" #define TRAIT_CLOTH_EATER "cloth_eater" +#define TRAIT_WEREWOLF "werewolf" +#define TRAIT_PRIMITIVE "primitive" +#define TRAIT_STEEL_ASS "steel_ass" +#define TRAIT_CURSED_BLOOD "cursed_blood" +#define TRAIT_HEADPAT_SLUT "headpat_slut" +#define TRAIT_DISTANT "headpat_hater" +#define TRAIT_ILLITERATE "illiterate" +#define TRAIT_HIDE_BACKPACK "hide_backpack" +#define TRAIT_DUMB4CUM "dumb4cum" diff --git a/code/__SPLURTCODE/DEFINES/zeros/species.dm b/code/__SPLURTCODE/DEFINES/zeros/species.dm deleted file mode 100644 index e24d77ca0ff1..000000000000 --- a/code/__SPLURTCODE/DEFINES/zeros/species.dm +++ /dev/null @@ -1,2 +0,0 @@ -#define SPECIES_ASHWALKER_WEST "ashlizard_west" -#define SPECIES_ASHWALKER_EAST "ashlizard_east" diff --git a/code/__SPLURTCODE/DEFINES/zeros/traits.dm b/code/__SPLURTCODE/DEFINES/zeros/traits.dm deleted file mode 100644 index 199962dbfd07..000000000000 --- a/code/__SPLURTCODE/DEFINES/zeros/traits.dm +++ /dev/null @@ -1,9 +0,0 @@ -#define TRAIT_PRIMITIVE "primitive" -#define TRAIT_STEEL_ASS "steel_ass" -#define TRAIT_CURSED_BLOOD "cursed_blood" //Yo dawg I heard you like bloodborne references so I put a -#define TRAIT_HEADPAT_SLUT "headpat_slut" -#define TRAIT_DISTANT "headpat_hater" -#define TRAIT_ILLITERATE "illiterate" -#define TRAIT_HIDE_BACKPACK "hide_backpack" - -#define TRAIT_DUMB4CUM "dumb4cum" diff --git a/code/_globalvars/bitfields.dm b/code/_globalvars/bitfields.dm index f412f31e9ced..d16c24be44c8 100644 --- a/code/_globalvars/bitfields.dm +++ b/code/_globalvars/bitfields.dm @@ -155,6 +155,7 @@ DEFINE_BITFIELD(flags_1, list( "CAN_BE_DIRTY_1" = CAN_BE_DIRTY_1, "CONDUCT_1" = CONDUCT_1, "DEFAULT_RICOCHET_1" = DEFAULT_RICOCHET_1, + "HAS_CONTEXTUAL_SCREENTIPS_1" = HAS_CONTEXTUAL_SCREENTIPS_1, "HEAR_1" = HEAR_1, "HOLOGRAM_1" = HOLOGRAM_1, "INITIALIZED_1" = INITIALIZED_1, @@ -246,6 +247,7 @@ DEFINE_BITFIELD(item_flags, list( "IN_STORAGE" = IN_STORAGE, "ITEM_CAN_BLOCK" = ITEM_CAN_BLOCK, "ITEM_CAN_PARRY" = ITEM_CAN_PARRY, + "ITEM_HAS_CONTEXTUAL_SCREENTIPS" = ITEM_HAS_CONTEXTUAL_SCREENTIPS, "NEEDS_PERMIT" = NEEDS_PERMIT, "NOBLUDGEON" = NOBLUDGEON, "NO_MAT_REDEMPTION" = NO_MAT_REDEMPTION, @@ -412,6 +414,7 @@ DEFINE_BITFIELD(sight, list( )) DEFINE_BITFIELD(slot_flags, list( + "ITEM_SLOT_ACCESSORY" = ITEM_SLOT_ACCESSORY, "ITEM_SLOT_BACK" = ITEM_SLOT_BACK, "ITEM_SLOT_BACKPACK" = ITEM_SLOT_BACKPACK, "ITEM_SLOT_BELT" = ITEM_SLOT_BELT, diff --git a/code/_globalvars/lists/flavor_misc.dm b/code/_globalvars/lists/flavor_misc.dm index e2996ecd7ecd..44d507891c02 100644 --- a/code/_globalvars/lists/flavor_misc.dm +++ b/code/_globalvars/lists/flavor_misc.dm @@ -338,7 +338,7 @@ GLOBAL_LIST_INIT(colored_mutant_parts, list("insect_wings" = "wings_color", "dec GLOBAL_LIST_INIT(greyscale_limb_types, list("human","moth","lizard","pod","plant","jelly","slime","golem","slimelumi","stargazer","mush","ethereal","snail","c_golem","b_golem","mammal","xeno","ipc","insect","synthliz","avian","aquatic", "shadekin")) //body ids that have prosthetic sprites -GLOBAL_LIST_INIT(prosthetic_limb_types, list("xion","bishop","cybersolutions","grayson","hephaestus","nanotrasen","talon")) +GLOBAL_LIST_INIT(prosthetic_limb_types, list("xion","bishop","cybersolutions","grayson","hephaestus","nanotrasen","talon","veymed")) //I don't know if i can module this to splurt //body ids that have non-gendered bodyparts GLOBAL_LIST_INIT(nongendered_limb_types, list("fly", "zombie" ,"synth", "shadow", "cultgolem", "agent", "plasmaman", "clockgolem", "clothgolem")) diff --git a/code/_globalvars/lists/loadout_categories.dm b/code/_globalvars/lists/loadout_categories.dm index 371e09392bdc..428e5b0e3234 100644 --- a/code/_globalvars/lists/loadout_categories.dm +++ b/code/_globalvars/lists/loadout_categories.dm @@ -1,5 +1,6 @@ GLOBAL_LIST_INIT(loadout_categories, list( - LOADOUT_CATEGORY_BACKPACK = list(LOADOUT_SUBCATEGORY_BACKPACK_GENERAL, LOADOUT_SUBCATEGORY_BACKPACK_ACCESSORIES, LOADOUT_SUBCATEGORY_BACKPACK_TOYS), + LOADOUT_CATEGORY_ACCESSORY = LOADOUT_SUBCATEGORIES_NONE, + LOADOUT_CATEGORY_BACKPACK = list(LOADOUT_SUBCATEGORY_BACKPACK_GENERAL, LOADOUT_SUBCATEGORY_BACKPACK_TOYS), LOADOUT_CATEGORY_NECK = list(LOADOUT_SUBCATEGORY_NECK_GENERAL, LOADOUT_SUBCATEGORY_NECK_TIE, LOADOUT_SUBCATEGORY_NECK_SCARVES), LOADOUT_CATEGORY_MASK = LOADOUT_SUBCATEGORIES_NONE, LOADOUT_CATEGORY_HANDS = LOADOUT_SUBCATEGORIES_NONE, diff --git a/code/_globalvars/lists/maintenance_loot.dm b/code/_globalvars/lists/maintenance_loot.dm index b41b7356a8b7..cec25c0047cf 100644 --- a/code/_globalvars/lists/maintenance_loot.dm +++ b/code/_globalvars/lists/maintenance_loot.dm @@ -49,6 +49,8 @@ GLOBAL_LIST_INIT(maintenance_loot, list( /obj/item/radio/off = 2, /obj/item/t_scanner = 5, /obj/item/airlock_painter = 1, + /obj/item/airlock_painter/decal = 1, + /obj/item/airlock_painter/decal/tile = 1, /obj/item/stack/cable_coil/random = 4, /obj/item/stack/cable_coil/random/five = 6, /obj/item/stack/medical/suture = 1, diff --git a/code/_onclick/click.dm b/code/_onclick/click.dm index 6e8d1de95513..b3a75c024c77 100644 --- a/code/_onclick/click.dm +++ b/code/_onclick/click.dm @@ -397,8 +397,10 @@ Unused except for AI */ /mob/proc/CtrlShiftClickOn(atom/A) + . = SEND_SIGNAL(src, COMSIG_MOB_CTRLSHIFTCLICKON, A) + if(. & COMSIG_MOB_CANCEL_CLICKON) + return A.CtrlShiftClick(src) - return /mob/proc/ShiftMiddleClickOn(atom/A) src.pointed(A) diff --git a/code/_onclick/hud/hud.dm b/code/_onclick/hud/hud.dm index cd8fb4b30cf8..593fa1a41138 100644 --- a/code/_onclick/hud/hud.dm +++ b/code/_onclick/hud/hud.dm @@ -64,13 +64,15 @@ GLOBAL_LIST_INIT(available_ui_styles, list( /// This is updated by the preference for cheaper reads than would be /// had with a proc call, especially on one of the hottest procs in the /// game (MouseEntered). - var/screentips_enabled = TRUE + // var/screentips_enabled = SCREENTIP_PREFERENCE_ENABLED /// The color to use for the screentips. /// This is updated by the preference for cheaper reads than would be /// had with a proc call, especially on one of the hottest procs in the /// game (MouseEntered). - var/screentip_color + // var/screentip_color + + // We don't actually do proccalls really yet, so let's grab at prefs var/atom/movable/screen/movable/action_button/hide_toggle/hide_actions_toggle var/action_buttons_hidden = FALSE diff --git a/code/_onclick/hud/new_player.dm b/code/_onclick/hud/new_player.dm index b426db1aac45..2e9ed3211fbe 100644 --- a/code/_onclick/hud/new_player.dm +++ b/code/_onclick/hud/new_player.dm @@ -241,7 +241,7 @@ if(!.) return - hud.mymob.client.prefs.current_tab = GAME_PREFERENCES_TAB + hud.mymob.client.prefs.current_tab = PREFERENCES_TAB hud.mymob.client.prefs.ShowChoices(hud.mymob) /atom/movable/screen/lobby/button/changelog_button diff --git a/code/controllers/subsystem/job.dm b/code/controllers/subsystem/job.dm index 02c8afdfc79a..01393ed0d194 100644 --- a/code/controllers/subsystem/job.dm +++ b/code/controllers/subsystem/job.dm @@ -487,7 +487,7 @@ SUBSYSTEM_DEF(job) if(job.dresscodecompliant)// CIT CHANGE - dress code compliance equip_loadout(N, H) // CIT CHANGE - allows players to spawn with loadout items job.after_spawn(H, M.client, joined_late) // note: this happens before the mob has a key! M will always have a client, H might not. - equip_loadout(N, H, TRUE)//CIT CHANGE - makes players spawn with in-backpack loadout items properly. A little hacky but it works + post_equip_loadout(N, H)//CIT CHANGE - makes players spawn with in-backpack loadout items properly. A little hacky but it works handle_roundstart_items(H, M.ckey, H.mind.assigned_role, H.mind.special_role) @@ -691,7 +691,7 @@ SUBSYSTEM_DEF(job) message_admins(msg) CRASH(msg) -/datum/controller/subsystem/job/proc/equip_loadout(mob/dead/new_player/N, mob/living/M, equipbackpackstuff, bypass_prereqs = FALSE, can_drop = TRUE) +/datum/controller/subsystem/job/proc/equip_loadout(mob/dead/new_player/N, mob/living/M, bypass_prereqs = FALSE, can_drop = TRUE) var/mob/the_mob = N if(!the_mob) the_mob = M // cause this doesn't get assigned if player is a latejoiner @@ -709,9 +709,68 @@ SUBSYSTEM_DEF(job) permitted = FALSE if(G.donoritem && !G.donator_ckey_check(the_mob.client.ckey)) permitted = FALSE - if(!equipbackpackstuff && G.slot == ITEM_SLOT_BACKPACK)//snowflake check since plopping stuff in the backpack doesnt work for pre-job equip loadout stuffs + if(G.handle_post_equip) permitted = FALSE - if(equipbackpackstuff && G.slot != ITEM_SLOT_BACKPACK)//ditto + if(!permitted) + continue + var/obj/item/I = new G.path + if(I) + if(length(i[LOADOUT_COLOR])) //handle loadout colors + //handle polychromic items + if((G.loadout_flags & LOADOUT_CAN_COLOR_POLYCHROMIC) && length(G.loadout_initial_colors)) + var/datum/element/polychromic/polychromic = LAZYACCESS(I.comp_lookup, "item_worn_overlays") //stupid way to do it but GetElement does not work for this + if(polychromic && istype(polychromic)) + var/list/polychromic_entry = polychromic.colors_by_atom[I] + if(polychromic_entry) + if(polychromic.suits_with_helmet_typecache[I.type]) //is this one of those toggleable hood/helmet things? + polychromic.connect_helmet(I,i[LOADOUT_COLOR]) + polychromic.colors_by_atom[I] = i[LOADOUT_COLOR] + I.update_icon() + else + //handle non-polychromic items (they only have one color) + I.add_atom_colour(i[LOADOUT_COLOR][1], FIXED_COLOUR_PRIORITY) + I.update_icon() + //when inputting the data it's already sanitized + if(i[LOADOUT_CUSTOM_NAME]) + var/custom_name = i[LOADOUT_CUSTOM_NAME] + I.name = custom_name + if(i[LOADOUT_CUSTOM_DESCRIPTION]) + var/custom_description = i[LOADOUT_CUSTOM_DESCRIPTION] + I.desc = custom_description + if(!M.equip_to_slot_if_possible(I, G.slot, disable_warning = TRUE, bypass_equip_delay_self = TRUE)) // If the job's dresscode compliant, try to put it in its slot, first + if(iscarbon(M)) + var/mob/living/carbon/C = M + var/obj/item/storage/backpack/B = C.back + if(!B || !SEND_SIGNAL(B, COMSIG_TRY_STORAGE_INSERT, I, null, TRUE, TRUE)) // Otherwise, try to put it in the backpack, for carbons. + if(can_drop) + I.forceMove(get_turf(C)) + else + qdel(I) + else if(!M.equip_to_slot_if_possible(I, ITEM_SLOT_BACKPACK, disable_warning = TRUE, bypass_equip_delay_self = TRUE)) // Otherwise, try to put it in the backpack + if(can_drop) + I.forceMove(get_turf(M)) // If everything fails, just put it on the floor under the mob. + else + qdel(I) + +/datum/controller/subsystem/job/proc/post_equip_loadout(mob/dead/new_player/N, mob/living/M, bypass_prereqs = FALSE, can_drop = TRUE) + var/mob/the_mob = N + if(!the_mob) + the_mob = M // cause this doesn't get assigned if player is a latejoiner + var/list/chosen_gear = the_mob.client.prefs.loadout_data["SAVE_[the_mob.client.prefs.loadout_slot]"] + if(the_mob.client && the_mob.client.prefs && (chosen_gear && chosen_gear.len)) + if(!ishuman(M))//no silicons allowed + return + for(var/i in chosen_gear) + var/datum/gear/G = istext(i[LOADOUT_ITEM]) ? text2path(i[LOADOUT_ITEM]) : i[LOADOUT_ITEM] + G = GLOB.loadout_items[initial(G.category)][initial(G.subcategory)][initial(G.name)] + if(!G) + continue + var/permitted = TRUE + if(!bypass_prereqs && G.restricted_roles && G.restricted_roles.len && !(M.mind.assigned_role in G.restricted_roles)) + permitted = FALSE + if(G.donoritem && !G.donator_ckey_check(the_mob.client.ckey)) + permitted = FALSE + if(!G.handle_post_equip) permitted = FALSE if(!permitted) continue diff --git a/code/datums/components/dullahan.dm b/code/datums/components/dullahan.dm index 973f06a61e4a..94733636c753 100644 --- a/code/datums/components/dullahan.dm +++ b/code/datums/components/dullahan.dm @@ -114,17 +114,17 @@ cut_overlays() /obj/item/dullahan_head/proc/add_head_overlay(var/overlay) - overlays_standing += overlay + LAZYADD(overlays_standing, overlay) //SPLURT edit add_overlay(overlay) /obj/item/dullahan_head/update_appearance() if(owner && !HAS_TRAIT(owner, TRAIT_HUMAN_NO_RENDER)) - remove_head_overlays() + //remove_head_overlays() //SPLURT edit // to do this without duplicating large amounts of code // it's best to regenerate the head, then remove it once we have the overlays we want owner.regenerate_limb(BODY_ZONE_HEAD, TRUE) // don't heal them - owner.cut_overlays() - owner.regenerate_icons(TRUE) // yes i know it's expensive but do you want me to rewrite our entire overlay system, also block recursive calls here by passing in TRUE (it wont go back to call update_appearance this way) + //owner.cut_overlays() //SPLURT edit + //owner.regenerate_icons(TRUE) // yes i know it's expensive but do you want me to rewrite our entire overlay system, also block recursive calls here by passing in TRUE (it wont go back to call update_appearance this way) //SPLURT edit var/obj/item/bodypart/head/head = owner.get_bodypart(BODY_ZONE_HEAD) if(head) add_overlay(head.get_limb_icon(FALSE, TRUE, TRUE)) @@ -154,12 +154,8 @@ /datum/action/item_action/organ_action/dullahan/Trigger() . = ..() var/mob/living/carbon/human/H = owner - var/obj/item/organ/eyes/E = owner.getorganslot(ORGAN_SLOT_EYES) - if(E) - if(E.tint) - E.tint = 0 - else - E.tint = INFINITY + + toggle_monochromacy() //SPLURT edit var/datum/component/dullahan/D = H.GetComponent(/datum/component/dullahan) if(D) @@ -171,8 +167,7 @@ return . var/obj/item/organ/eyes/eyes = H.getorganslot(ORGAN_SLOT_EYES) if(eyes) - H.update_tint() - if(eyes.tint) + if(eyes.monochromacy_on) //SPLURT edit H.reset_perspective(H) else H.reset_perspective(dullahan_head) diff --git a/code/datums/datacore.dm b/code/datums/datacore.dm index 2351b7b4ba5d..0ca8f07c413a 100644 --- a/code/datums/datacore.dm +++ b/code/datums/datacore.dm @@ -240,7 +240,7 @@ /datum/datacore/proc/manifest_inject(mob/living/carbon/human/H, client/C, datum/preferences/prefs) set waitfor = FALSE var/static/list/show_directions = list(SOUTH, WEST) - if(H.mind && (H.mind.assigned_role != H.mind.special_role)) + if(H.mind && (H.mind.assigned_role != H.mind.special_role) && (H.mind.assigned_role != "Stowaway")) var/assignment if(H.mind.assigned_role) assignment = H.mind.assigned_role diff --git a/code/datums/elements/object_reskinning.dm b/code/datums/elements/object_reskinning.dm index 8b5d905e723c..a75a818fc3da 100644 --- a/code/datums/elements/object_reskinning.dm +++ b/code/datums/elements/object_reskinning.dm @@ -18,21 +18,20 @@ /datum/element/object_reskinning element_flags = ELEMENT_DETACH -/datum/element/object_reskinning/Attach(datum/target) +/datum/element/object_reskinning/Attach(obj/target) . = ..() - var/obj/the_obj = target - if(!istype(the_obj)) + if(!istype(target)) return ELEMENT_INCOMPATIBLE - if(!islist(the_obj.unique_reskin) || !length(the_obj.unique_reskin)) + if(!islist(target.unique_reskin) || !length(target.unique_reskin)) message_admins("[src] was given to an object without any unique reskins, if you really need to, give it a couple skins first.") return ELEMENT_INCOMPATIBLE - RegisterSignal(the_obj, COMSIG_PARENT_EXAMINE, .proc/on_examine) - RegisterSignal(the_obj, the_obj.reskin_binding, .proc/reskin) + RegisterSignal(target, COMSIG_PARENT_EXAMINE, .proc/on_examine) + RegisterSignal(target, target.reskin_binding, .proc/reskin) + RegisterSignal(target, COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM, .proc/on_requesting_context_from_item) -/datum/element/object_reskinning/Detach(datum/source, force) - var/obj/being_deleted = source - UnregisterSignal(source, list(COMSIG_PARENT_EXAMINE, being_deleted.reskin_binding)) +/datum/element/object_reskinning/Detach(obj/source, force) + UnregisterSignal(source, list(COMSIG_PARENT_EXAMINE, source.reskin_binding, COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM)) return ..() /datum/element/object_reskinning/proc/on_examine(obj/obj, mob/user, list/examine_list) @@ -102,3 +101,19 @@ if(user.incapacitated()) return FALSE return TRUE + +/datum/element/object_reskinning/proc/on_requesting_context_from_item( + obj/source, + list/context, + obj/item/held_item, + mob/living/user, +) + SIGNAL_HANDLER + + if(isnull(held_item)) + switch(source.reskin_binding) + if(COMSIG_CLICK_CTRL_SHIFT) + LAZYSET(context[SCREENTIP_CONTEXT_CTRL_SHIFT_LMB], INTENT_ANY, "Reskin PDA") + else + LAZYSET(context[SCREENTIP_CONTEXT_ALT_LMB], INTENT_ANY, "Reskin [source]") + return CONTEXTUAL_SCREENTIP_SET diff --git a/code/datums/elements/screentips/README.md b/code/datums/elements/screentips/README.md new file mode 100644 index 000000000000..5b4ee4fd1852 --- /dev/null +++ b/code/datums/elements/screentips/README.md @@ -0,0 +1,136 @@ +# Contextual screentips (and when to not use this folder) + +Contextual screentips provide information in the form of text at the top of your screen to inform you of the possibilities of an item. The "contextual" here refers to this being handled entirely through code, what it displays and when is completely up to you. + +## The elements (and this folder) + +This folder provides several useful shortcuts to be able to handle 95% of situations. + +### `/datum/element/contextual_screentip_bare_hands` + +This element is used to display screentips **when the user hovers over the object with nothing in their active hand.** + +It takes parameters in the form of both non-combat mode and, optionally, combat mode. + +Example: + +```dm +/obj/machinery/firealarm/Initialize(mapload) + . = ..() + + AddElement( \ + /datum/element/contextual_screentip_bare_hands, \ + lmb_text = list(INTENT_HELP = "Turn on"), \ + rmb_text = list(INTENT_HELP = "Turn off"), \ + ) +``` + +This will display "LMB: Turn on | RMB: Turn off" when the user hovers over a fire alarm with an empty active hand. + +### `/datum/element/contextual_screentip_tools` + +This element takes a map of tool behaviors to [context lists](#context-lists). These will be displayed **when the user hovers over the object with an item that has the tool behavior.** + +Example: + +```dm +/obj/structure/table/Initialize(mapload) + if (!(flags_1 & NODECONSTRUCT_1)) + var/static/list/tool_behaviors = list( + TOOL_SCREWDRIVER = list( + SCREENTIP_CONTEXT_LMB = list(INTENT_ANY = "Disassemble"), + ), + + TOOL_WRENCH = list( + SCREENTIP_CONTEXT_LMB = list(INTENT_ANY = "Deconstruct"), + ), + ) + + AddElement(/datum/element/contextual_screentip_tools, tool_behaviors) +``` + +This will display "LMB: Deconstruct" when the user hovers over a table with a wrench. + +### `/datum/element/contextual_screentip_item_typechecks` + +This element takes a map of item typepaths to [context lists](#context-lists). These will be displayed **when the user hovers over the object with the selected item.** + +Example: + +```dm +/obj/item/restraints/handcuffs/cable/Initialize(mapload) + . = ..() + + var/static/list/hovering_item_typechecks = list( + /obj/item/stack/rods = list( + SCREENTIP_CONTEXT_LMB = list(INTENT_ANY = "Craft wired rod"), + ), + + /obj/item/stack/sheet/iron = list( + SCREENTIP_CONTEXT_LMB = list(INTENT_ANY = "Craft bola"), + ), + ) + + AddElement(/datum/element/contextual_screentip_item_typechecks, hovering_item_typechecks) +``` + +This will display "LMB: Craft bola" when the user hovers over cable restraints with metal in their hand. + +## The basic system (and when to not use this folder) + +The basic system acknowledges the following two interactions: + +### Self-defining items (Type A) +These are items that are defined by their behavior. These should define their contextual text within themselves, and not in their targets. + +- Stun batons (LMB to stun, RMB to harm) +- Syringes (LMB to inject, RMB to draw) +- Health analyzers (LMB to scan for health/wounds [another piece of context], RMB to scans for chemicals) + +### Receiving action defining objects (Type B) +These are objects (not necessarily items) that are defined by what happens *to* them. These should define their contextual text within themselves, and not in their operating tools. + +- Tables (RMB with wrench to deconstruct) +- Construction objects (LMB with glass to put in screen for computers) +- Carbon copies (RMB to take a copy) + +--- + +Both of these are supported, and can be hooked to through several means. + +Note that you **must return `CONTEXTUAL_SCREENTIP_SET` if you change the contextual screentip at all**, otherwise you may not see it. + +### `COMSIG_ITEM_REQUESTING_CONTEXT_FOR_TARGET` + +This signal is registered on **items**, and receives **the hovering object**, provided in the form of `obj/item/source, list/context, atom/target, mob/living/user`. + +### `/atom/proc/register_item_context()`, and `/atom/proc/add_item_context()` +`/atom/proc/add_item_context()` is a proc intended to be overridden to easily create Type-B interactions (ones where atoms are hovered over by items). It receives the exact same arguments as `COMSIG_ITEM_REQUESTING_CONTEXT_FOR_TARGET`: `obj/item/source, list/context, atom/target, mob/living/user`. + +In order for your `add_item_context()` method to be run, you **must** call `register_item_context()`. + +### `COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM` + +This signal is registered on **atoms**, and receives **what the user is hovering with**, provided in the form of `atom/source, list/context, obj/item/held_item, mob/living/user`. + +### `/atom/proc/register_context()`, and `/atom/proc/add_context()` +`/atom/proc/add_context()` is a proc intended to be overridden to easily create Type-B interactions (ones where atoms are hovered over by items). It receives the exact same arguments as `COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM`: `atom/source, list/context, obj/item/held_item, mob/living/user`. + +In order for your `add_context()` method to be run, you **must** call `register_context()`. + +--- + +When using any of these methods, you will receive a mutable context list. + +### Context lists + +Context lists are lists with keys mapping from `SCREENTIP_CONTEXT_*` to a string. You can find these keys in `code/__DEFINES/screentips.dm`. + +The signals and `add_context()` variants mutate the list directly, while shortcut elements will just have you pass them in directly. + +For example: + +```dm +context[SCREENTIP_CONTEXT_LMB] = "Open" +context[SCREENTIP_CONTEXT_RMB] = "Destroy" +``` diff --git a/code/datums/elements/screentips/contextual_screentip_bare_hands.dm b/code/datums/elements/screentips/contextual_screentip_bare_hands.dm new file mode 100644 index 000000000000..98ef45af3ff3 --- /dev/null +++ b/code/datums/elements/screentips/contextual_screentip_bare_hands.dm @@ -0,0 +1,92 @@ +/// Apply basic contextual screentips when the user hovers over this item with an empty hand. +/// A "Type B" interaction. +/// This stacks with other contextual screentip elements, though you may want to register the signal/flag manually at that point for performance. +/datum/element/contextual_screentip_bare_hands + element_flags = ELEMENT_BESPOKE | ELEMENT_DETACH + id_arg_index = 3 + + /* How to use SandPoot's version of this: + * + * Combat mode will be checked first, then the intents for it, if the + * current intent has not been set it defaults to the first item of the list. + * + * Otherwise if not in combat mode or no messages for it + * will also try to get messages for the current intent + * if failing to, will try to get the first item of the list. + */ + + /// If set, the text to show for LMB + var/list/lmb_text + + /// If set, the text to show for RMB + var/list/rmb_text + + /// If set, the text to show for LMB when in combat mode. Otherwise, defaults to lmb_text. + var/list/lmb_text_combat_mode + + /// If set, the text to show for RMB when in combat mode. Otherwise, defaults to rmb_text. + var/list/rmb_text_combat_mode + +// If you're curious about `use_named_parameters`, it's because you should use named parameters! +// AddElement(/datum/element/contextual_screentip_bare_hands, lmb_text = list(INTENT_HELP = "Do the thing")) +/datum/element/contextual_screentip_bare_hands/Attach( + datum/target, + use_named_parameters, + lmb_text, + rmb_text, + lmb_text_combat_mode, + rmb_text_combat_mode, +) + . = ..() + if (!isatom(target)) + return ELEMENT_INCOMPATIBLE + + if (!isnull(use_named_parameters)) + CRASH("Use named parameters instead of positional ones.") + + src.lmb_text = lmb_text + src.rmb_text = rmb_text + src.lmb_text_combat_mode = lmb_text_combat_mode || lmb_text + src.rmb_text_combat_mode = rmb_text_combat_mode || rmb_text + + var/atom/atom_target = target + atom_target.flags_1 |= HAS_CONTEXTUAL_SCREENTIPS_1 + RegisterSignal(atom_target, COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM, .proc/on_requesting_context_from_item) + +/datum/element/contextual_screentip_bare_hands/Detach(datum/source, ...) + UnregisterSignal(source, COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM) + + // We don't remove HAS_CONTEXTUAL_SCREENTIPS_1, since there could be other stuff still hooked to it, + // and being set without signals is not dangerous, just less performant. + // A lot of things don't do this, perhaps make a proc that checks if any signals are still set, and if not, + // remove the flag. + + return ..() + +/datum/element/contextual_screentip_bare_hands/proc/on_requesting_context_from_item( + datum/source, + list/context, + obj/item/held_item, + mob/living/user, +) + SIGNAL_HANDLER + + if (!isnull(held_item)) + return NONE + + var/combat_mode = SEND_SIGNAL(user, COMSIG_COMBAT_MODE_CHECK, COMBAT_MODE_ACTIVE) + + // Combat lmb + if(combat_mode && length(lmb_text_combat_mode)) + context[SCREENTIP_CONTEXT_LMB] = lmb_text_combat_mode + // LMB + else if(length(lmb_text)) + context[SCREENTIP_CONTEXT_LMB] = lmb_text + // Combat rmb + if(combat_mode && length(rmb_text_combat_mode)) + context[SCREENTIP_CONTEXT_RMB] = rmb_text_combat_mode + // RMB + else if(length(rmb_text)) + context[SCREENTIP_CONTEXT_RMB] = rmb_text + + return CONTEXTUAL_SCREENTIP_SET diff --git a/code/datums/elements/screentips/contextual_screentip_item_typechecks.dm b/code/datums/elements/screentips/contextual_screentip_item_typechecks.dm new file mode 100644 index 000000000000..44ff1f3190f6 --- /dev/null +++ b/code/datums/elements/screentips/contextual_screentip_item_typechecks.dm @@ -0,0 +1,47 @@ +/// Apply basic contextual screentips when the user hovers over this item with a provided item. +/// A "Type B" interaction. +/// This stacks with other contextual screentip elements, though you may want to register the signal/flag manually at that point for performance. +/datum/element/contextual_screentip_item_typechecks + element_flags = ELEMENT_BESPOKE | ELEMENT_DETACH + id_arg_index = 2 + + /// Map of item paths to contexts to usages + var/list/item_paths_to_contexts + +/datum/element/contextual_screentip_item_typechecks/Attach(datum/target, item_paths_to_contexts) + . = ..() + if (!isatom(target)) + return ELEMENT_INCOMPATIBLE + + src.item_paths_to_contexts = item_paths_to_contexts + + var/atom/atom_target = target + atom_target.flags_1 |= HAS_CONTEXTUAL_SCREENTIPS_1 + RegisterSignal(atom_target, COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM, .proc/on_requesting_context_from_item) + +/datum/element/contextual_screentip_item_typechecks/Detach(datum/source, ...) + UnregisterSignal(source, COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM) + + // We don't remove HAS_CONTEXTUAL_SCREENTIPS_1, since there could be other stuff still hooked to it, + // and being set without signals is not dangerous, just less performant. + // A lot of things don't do this, perhaps make a proc that checks if any signals are still set, and if not, + // remove the flag. + + return ..() + +/datum/element/contextual_screentip_item_typechecks/proc/on_requesting_context_from_item( + datum/source, + list/context, + obj/item/held_item, +) + SIGNAL_HANDLER + + if (isnull(held_item)) + return NONE + + for (var/item_path in item_paths_to_contexts) + if (istype(held_item, item_path)) + context += item_paths_to_contexts[item_path] + return CONTEXTUAL_SCREENTIP_SET + + return NONE diff --git a/code/datums/elements/screentips/contextual_screentip_sharpness.dm b/code/datums/elements/screentips/contextual_screentip_sharpness.dm new file mode 100644 index 000000000000..0ee89f2fd77c --- /dev/null +++ b/code/datums/elements/screentips/contextual_screentip_sharpness.dm @@ -0,0 +1,57 @@ +/// Apply basic contextual screentips when the user hovers over this item with an item of the given tool behavior. +/// A "Type B" interaction. +/// This stacks with other contextual screentip elements, though you may want to register the signal/flag manually at that point for performance. +/datum/element/contextual_screentip_sharpness + element_flags = ELEMENT_BESPOKE | ELEMENT_DETACH + id_arg_index = 2 + + /// If set, the text to show for LMB + var/list/lmb_text + + /// If set, the text to show for RMB + var/list/rmb_text + +/datum/element/contextual_screentip_sharpness/Attach(datum/target, lmb_text, rmb_text) + . = ..() + if (!isatom(target)) + return ELEMENT_INCOMPATIBLE + + src.lmb_text = lmb_text + src.rmb_text = rmb_text + + var/atom/atom_target = target + atom_target.flags_1 |= HAS_CONTEXTUAL_SCREENTIPS_1 + RegisterSignal(atom_target, COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM, .proc/on_requesting_context_from_item) + +/datum/element/contextual_screentip_sharpness/Detach(datum/source, ...) + UnregisterSignal(source, COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM) + + // We don't remove HAS_CONTEXTUAL_SCREENTIPS_1, since there could be other stuff still hooked to it, + // and being set without signals is not dangerous, just less performant. + // A lot of things don't do this, perhaps make a proc that checks if any signals are still set, and if not, + // remove the flag. + + return ..() + +/datum/element/contextual_screentip_sharpness/proc/on_requesting_context_from_item( + datum/source, + list/context, + obj/item/held_item, +) + SIGNAL_HANDLER + + if (isnull(held_item)) + return NONE + + var/sharpness = held_item.get_sharpness() + if (!sharpness) + return NONE + + if (length(lmb_text)) + context[SCREENTIP_CONTEXT_LMB] = lmb_text + + if (length(rmb_text)) + context[SCREENTIP_CONTEXT_RMB] = rmb_text + + return CONTEXTUAL_SCREENTIP_SET + diff --git a/code/datums/elements/screentips/contextual_screentip_tools.dm b/code/datums/elements/screentips/contextual_screentip_tools.dm new file mode 100644 index 000000000000..a0850f8742b8 --- /dev/null +++ b/code/datums/elements/screentips/contextual_screentip_tools.dm @@ -0,0 +1,48 @@ +/// Apply basic contextual screentips when the user hovers over this item with an item of the given tool behavior. +/// A "Type B" interaction. +/// This stacks with other contextual screentip elements, though you may want to register the signal/flag manually at that point for performance. +/datum/element/contextual_screentip_tools + element_flags = ELEMENT_BESPOKE | ELEMENT_DETACH + id_arg_index = 2 + + /// Map of tool behaviors to contexts to usages + var/list/tool_behaviors + +/datum/element/contextual_screentip_tools/Attach(datum/target, tool_behaviors) + . = ..() + if (!isatom(target)) + return ELEMENT_INCOMPATIBLE + + src.tool_behaviors = tool_behaviors + + var/atom/atom_target = target + atom_target.flags_1 |= HAS_CONTEXTUAL_SCREENTIPS_1 + RegisterSignal(atom_target, COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM, .proc/on_requesting_context_from_item) + +/datum/element/contextual_screentip_tools/Detach(datum/source, ...) + UnregisterSignal(source, COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM) + + // We don't remove HAS_CONTEXTUAL_SCREENTIPS_1, since there could be other stuff still hooked to it, + // and being set without signals is not dangerous, just less performant. + // A lot of things don't do this, perhaps make a proc that checks if any signals are still set, and if not, + // remove the flag. + + return ..() + +/datum/element/contextual_screentip_tools/proc/on_requesting_context_from_item( + datum/source, + list/context, + obj/item/held_item, +) + SIGNAL_HANDLER + + if (isnull(held_item)) + return NONE + + var/tool_behavior = held_item.tool_behaviour + if (!(tool_behavior in tool_behaviors)) + return NONE + + context += tool_behaviors[tool_behavior] + + return CONTEXTUAL_SCREENTIP_SET diff --git a/code/datums/screentips/atom_context.dm b/code/datums/screentips/atom_context.dm new file mode 100644 index 000000000000..ebab6b155adc --- /dev/null +++ b/code/datums/screentips/atom_context.dm @@ -0,0 +1,25 @@ +/// Create a "Type-B" contextual screentip interaction, registering to `add_context()`. +/// This will run `add_context()` when the atom is hovered over by an item for context. +/// `add_context()` will *not* be called unless this is run. +/// This is not necessary for Type-B interactions, as you can just apply the flag and register to the signal yourself. +/atom/proc/register_context() + flags_1 |= HAS_CONTEXTUAL_SCREENTIPS_1 + RegisterSignal(src, COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM, .proc/add_context, override = TRUE) + +/// Creates a "Type-B" contextual screentip interaction. +/// When a user hovers over this, this proc will be called in order +/// to provide context for contextual screentips. +/// You must call `register_context()` in order for this to be registered. +/// A screentip context list is a list that has context keys (SCREENTIP_CONTEXT_*, from __DEFINES/screentips.dm) +/// that map to the action as text. +/// If you mutate the list in this signal, you must return CONTEXTUAL_SCREENTIP_SET. +/// `source` can, in all cases, be replaced with `src`, and only exists because this proc directly connects to a signal. +/atom/proc/add_context( + atom/source, + list/context, + obj/item/held_item, + mob/living/user, +) + SIGNAL_HANDLER + + return NONE diff --git a/code/datums/screentips/item_context.dm b/code/datums/screentips/item_context.dm new file mode 100644 index 000000000000..239cd1868364 --- /dev/null +++ b/code/datums/screentips/item_context.dm @@ -0,0 +1,29 @@ +/// Create a "Type-A" contextual screentip interaction, registering to `add_item_context()`. +/// This will run `add_item_context()` when the item hovers over another object for context. +/// `add_item_context()` will *not* be called unless this is run. +/// This is not necessary for Type-A interactions, as you can just apply the flag and register to the signal yourself. +/obj/item/proc/register_item_context() + item_flags |= ITEM_HAS_CONTEXTUAL_SCREENTIPS + RegisterSignal( + src, + COMSIG_ITEM_REQUESTING_CONTEXT_FOR_TARGET, + .proc/add_item_context, + ) + +/// Creates a "Type-A" contextual screentip interaction. +/// When a user hovers over something with this item in hand, this proc will be called in order +/// to provide context for contextual screentips. +/// You must call `register_item_context()` in order for this to be registered. +/// A screentip context list is a list that has context keys (SCREENTIP_CONTEXT_*, from __DEFINES/screentips.dm) +/// that map to the action as text. +/// If you mutate the list in this signal, you must return CONTEXTUAL_SCREENTIP_SET. +/// `source` can, in all cases, be replaced with `src`, and only exists because this proc directly connects to a signal. +/obj/item/proc/add_item_context( + obj/item/source, + list/context, + atom/target, + mob/living/user, +) + SIGNAL_HANDLER + + return NONE diff --git a/code/datums/traits/good.dm b/code/datums/traits/good.dm index 5b00d2e71e29..26bc6746add3 100644 --- a/code/datums/traits/good.dm +++ b/code/datums/traits/good.dm @@ -128,7 +128,7 @@ var/mob/living/carbon/human/H = quirk_holder var/obj/item/camera/camera = new(get_turf(H)) H.put_in_hands(camera) - H.equip_to_slot(camera, ITEM_SLOT_NECK) + H.equip_to_slot(camera, ITEM_SLOT_BACKPACK) //SPLURT Edit H.regenerate_icons() /datum/quirk/selfaware @@ -190,7 +190,7 @@ // Get targets var/obj/item/organ/eyes/old_eyes = quirk_holder.getorganslot(ORGAN_SLOT_EYES) var/obj/item/organ/eyes/robotic/glow/new_eyes = new - + // Replace eyes qdel(old_eyes) new_eyes.Insert(quirk_holder) diff --git a/code/game/atoms.dm b/code/game/atoms.dm index 5b26a67caeb5..08d879645505 100644 --- a/code/game/atoms.dm +++ b/code/game/atoms.dm @@ -1467,11 +1467,97 @@ /atom/MouseEntered(location, control, params) . = ..() // Screentips - var/client/client = usr?.client - var/datum/hud/active_hud = client?.mob?.hud_used + var/mob/user = usr + if(isnull(user) && !user.client) + return + + var/datum/hud/active_hud = user.hud_used if(active_hud) - if(!client.prefs.screentip_pref || (flags_1 & NO_SCREENTIPS_1)) + var/screentips_enabled = user.client.prefs.screentip_pref + if(screentips_enabled == SCREENTIP_PREFERENCE_DISABLED || (flags_1 & NO_SCREENTIPS_1)) active_hud.screentip_text.maptext = "" else - //We inline a MAPTEXT() here, because there's no good way to statically add to a string like this - active_hud.screentip_text.maptext = MAPTEXT("[name]") + active_hud.screentip_text.maptext_y = 0 + var/lmb_rmb_line = "" + var/ctrl_lmb_ctrl_rmb_line = "" + var/alt_lmb_alt_rmb_line = "" + var/shift_lmb_ctrl_shift_lmb_line = "" + var/extra_lines = 0 + var/extra_context = "" + + if (isliving(user) || isovermind(user) || isaicamera(user)) + var/obj/item/held_item = user.get_active_held_item() + + if (flags_1 & HAS_CONTEXTUAL_SCREENTIPS_1 || held_item?.item_flags & ITEM_HAS_CONTEXTUAL_SCREENTIPS) + var/list/context = list() + + var/contextual_screentip_returns = \ + SEND_SIGNAL(src, COMSIG_ATOM_REQUESTING_CONTEXT_FROM_ITEM, context, held_item, user) \ + | (held_item && SEND_SIGNAL(held_item, COMSIG_ITEM_REQUESTING_CONTEXT_FOR_TARGET, context, src, user)) + + if (contextual_screentip_returns & CONTEXTUAL_SCREENTIP_SET) + // LMB and RMB on one line... + var/lmb_text = "" + if((SCREENTIP_CONTEXT_LMB in context) && (length(context[SCREENTIP_CONTEXT_LMB]) > 0)) + lmb_text = build_context(context, SCREENTIP_CONTEXT_LMB) + var/rmb_text = "" + if((SCREENTIP_CONTEXT_RMB in context) && (length(context[SCREENTIP_CONTEXT_RMB]) > 0)) + rmb_text = build_context(context, SCREENTIP_CONTEXT_RMB) + + if (lmb_text) + lmb_rmb_line = lmb_text + if (rmb_text) + lmb_rmb_line += " | [rmb_text]" + else if (rmb_text) + lmb_rmb_line = rmb_text + + // Ctrl-LMB, Ctrl-RMB on one line... + if (lmb_rmb_line != "") + lmb_rmb_line += "
" + extra_lines++ + if((SCREENTIP_CONTEXT_CTRL_LMB in context) && (length(context[SCREENTIP_CONTEXT_CTRL_LMB]) > 0)) + ctrl_lmb_ctrl_rmb_line = build_context(context, SCREENTIP_CONTEXT_CTRL_LMB) + + if((SCREENTIP_CONTEXT_CTRL_RMB in context) && (length(context[SCREENTIP_CONTEXT_CTRL_RMB]) > 0)) + if (ctrl_lmb_ctrl_rmb_line != "") + ctrl_lmb_ctrl_rmb_line += " | " + ctrl_lmb_ctrl_rmb_line += "[SCREENTIP_CONTEXT_CTRL_RMB]: [context[SCREENTIP_CONTEXT_CTRL_RMB]]" + ctrl_lmb_ctrl_rmb_line = build_context(context, SCREENTIP_CONTEXT_CTRL_RMB) + + // Alt-LMB, Alt-RMB on one line... + if (ctrl_lmb_ctrl_rmb_line != "") + ctrl_lmb_ctrl_rmb_line += "
" + extra_lines++ + if((SCREENTIP_CONTEXT_ALT_LMB in context) && (length(context[SCREENTIP_CONTEXT_ALT_LMB]) > 0)) + alt_lmb_alt_rmb_line = build_context(context, SCREENTIP_CONTEXT_ALT_LMB) + if((SCREENTIP_CONTEXT_ALT_RMB in context) && (length(context[SCREENTIP_CONTEXT_ALT_RMB]) > 0)) + if (alt_lmb_alt_rmb_line != "") + alt_lmb_alt_rmb_line += " | " + alt_lmb_alt_rmb_line = build_context(context, SCREENTIP_CONTEXT_ALT_RMB) + + // Shift-LMB, Ctrl-Shift-LMB on one line... + if (alt_lmb_alt_rmb_line != "") + alt_lmb_alt_rmb_line += "
" + extra_lines++ + if((SCREENTIP_CONTEXT_SHIFT_LMB in context) && (length(context[SCREENTIP_CONTEXT_SHIFT_LMB]) > 0)) + shift_lmb_ctrl_shift_lmb_line = build_context(context, SCREENTIP_CONTEXT_SHIFT_LMB) + + if((SCREENTIP_CONTEXT_CTRL_SHIFT_LMB in context) && (length(context[SCREENTIP_CONTEXT_CTRL_SHIFT_LMB]) > 0)) + if (shift_lmb_ctrl_shift_lmb_line != "") + shift_lmb_ctrl_shift_lmb_line += " | " + shift_lmb_ctrl_shift_lmb_line += "[SCREENTIP_CONTEXT_CTRL_SHIFT_LMB]: [context[SCREENTIP_CONTEXT_CTRL_SHIFT_LMB]]" + shift_lmb_ctrl_shift_lmb_line = build_context(context, SCREENTIP_CONTEXT_CTRL_SHIFT_LMB) + + if (shift_lmb_ctrl_shift_lmb_line != "") + extra_lines++ + + if(extra_lines) + extra_context = "
[lmb_rmb_line][ctrl_lmb_ctrl_rmb_line][alt_lmb_alt_rmb_line][shift_lmb_ctrl_shift_lmb_line]" + //first extra line pushes atom name line up 10px, subsequent lines push it up 9px, this offsets that and keeps the first line in the same place + active_hud.screentip_text.maptext_y = -10 + (extra_lines - 1) * -9 + + if (screentips_enabled == SCREENTIP_PREFERENCE_CONTEXT_ONLY && extra_context == "") + active_hud.screentip_text.maptext = "" + else + //We inline a MAPTEXT() here, because there's no good way to statically add to a string like this + active_hud.screentip_text.maptext = "[name][extra_context]" diff --git a/code/game/atoms_movable.dm b/code/game/atoms_movable.dm index 30363e6c0109..6c6b31fbfd1c 100644 --- a/code/game/atoms_movable.dm +++ b/code/game/atoms_movable.dm @@ -606,6 +606,16 @@ animate(time = 1) animate(alpha = 0, time = 3, easing = CIRCULAR_EASING|EASE_OUT) +/// Common proc used by painting tools like spraycans and palettes that can access the entire 24 bits color space. +/obj/item/proc/pick_painting_tool_color(mob/user, default_color) + var/chosen_color = input(user,"Pick new color", "[src]", default_color) as color|null + if(!chosen_color || QDELETED(src) || IS_DEAD_OR_INCAP(user) || !user.is_holding(src)) + return + set_painting_tool_color(chosen_color) + +/obj/item/proc/set_painting_tool_color(chosen_color) + SEND_SIGNAL(src, COMSIG_PAINTING_TOOL_SET_COLOR, chosen_color) + /atom/movable/vv_get_dropdown() . = ..() . += "" diff --git a/code/game/machinery/aug_manipulator.dm b/code/game/machinery/aug_manipulator.dm index c34e0a2d4f3e..cbece7626e10 100644 --- a/code/game/machinery/aug_manipulator.dm +++ b/code/game/machinery/aug_manipulator.dm @@ -15,6 +15,7 @@ "Talon" = 'icons/mob/augmentation/cosmetic_prosthetic/talon.dmi', "Nanotrasen" = 'icons/mob/augmentation/cosmetic_prosthetic/nanotrasen.dmi', "Hephaesthus" = 'icons/mob/augmentation/cosmetic_prosthetic/hephaestus.dmi', + "Veymed" = 'icons/mob/augmentation/cosmetic_prosthetic/veymed.dmi', //i don't know if i can module this either "Bishop" = 'icons/mob/augmentation/cosmetic_prosthetic/bishop.dmi', "Xion" = 'icons/mob/augmentation/cosmetic_prosthetic/xion.dmi', "Grayson" = 'icons/mob/augmentation/cosmetic_prosthetic/grayson.dmi', diff --git a/code/game/machinery/computer/card.dm b/code/game/machinery/computer/card.dm index a16e70155f13..50ad14d0fc2c 100644 --- a/code/game/machinery/computer/card.dm +++ b/code/game/machinery/computer/card.dm @@ -28,6 +28,7 @@ GLOBAL_VAR_INIT(time_last_changed_position, 0) var/list/blacklisted = list( "AI", "Assistant", + "Stowaway", "Cyborg", "Captain", "Head of Personnel", diff --git a/code/game/machinery/computer/crew.dm b/code/game/machinery/computer/crew.dm index eca5fc4ce370..8921232c069c 100644 --- a/code/game/machinery/computer/crew.dm +++ b/code/game/machinery/computer/crew.dm @@ -158,7 +158,7 @@ GLOBAL_DATUM_INIT(crewmonitor, /datum/crewmonitor, new) if (I) name = I.registered_name assignment = I.assignment - ijob = jobs[I.assignment] + ijob = jobs[GetJobName(I.assignment)] else name = "Unknown" assignment = "" diff --git a/code/game/machinery/computer/security.dm b/code/game/machinery/computer/security.dm index 45bb9bd327b5..d5b47d45f69c 100644 --- a/code/game/machinery/computer/security.dm +++ b/code/game/machinery/computer/security.dm @@ -18,6 +18,8 @@ var/sortBy = "name" var/order = 1 // -1 = Descending - 1 = Ascending + var/list/logged_access + light_color = LIGHT_COLOR_RED /obj/machinery/computer/secure_data/syndie @@ -295,6 +297,9 @@ What a mess.*/ screen = null active1 = null active2 = null + + logged_access = null + playsound(src, 'sound/machines/terminal_off.ogg', 50, FALSE) if("Log In") @@ -307,18 +312,27 @@ What a mess.*/ authenticated = borg.name rank = "AI" screen = 1 + + logged_access = get_all_accesses() + else if(IsAdminGhost(M)) active1 = null active2 = null authenticated = M.client.holder.admin_signature rank = "Central Command" screen = 1 + + logged_access = get_centcom_access("CentCom Commander") + else if(I && check_access(I)) active1 = null active2 = null authenticated = I.registered_name rank = I.assignment screen = 1 + + logged_access = I.access + else to_chat(usr, "Unauthorized Access.") playsound(src, 'sound/machines/terminal_on.ogg', 50, FALSE) @@ -583,7 +597,7 @@ What a mess.*/ active1.fields["age"] = t1 if("species") if(istype(active1, /datum/data/record)) - var/t1 = input("Select a species", "Species Selection") as null|anything in GLOB.roundstart_races + var/t1 = stripped_input("Please input species name", "Sec. records", active1.fields["species"], null) if(!canUseSecurityRecordsConsole(usr, t1, a1)) return active1.fields["species"] = t1 @@ -678,9 +692,7 @@ What a mess.*/ temp += "
  • Discharged
  • " temp += "" if("rank") - var/list/L = list( "Head of Personnel", "Captain", "AI", "Central Command" ) - //This was so silly before the change. Now it actually works without beating your head against the keyboard. /N - if((istype(active1, /datum/data/record) && L.Find(rank))) + if(istype(active1, /datum/data/record) && ((ACCESS_CAPTAIN in logged_access) || (ACCESS_HOP in logged_access))) temp = "
    Rank:
    " temp += "