mirror of
https://github.com/SPLURT-Station/S.P.L.U.R.T-Station-13.git
synced 2025-12-10 09:54:52 +00:00
Fixing an issue with DNA scanners maintenance hatches. Also porting some sleepers code updates.
This commit is contained in:
@@ -88,17 +88,50 @@
|
|||||||
return
|
return
|
||||||
close_machine(target)
|
close_machine(target)
|
||||||
|
|
||||||
/obj/machinery/sleeper/attackby(obj/item/I, mob/user, params)
|
/obj/machinery/sleeper/screwdriver_act(mob/living/user, obj/item/I)
|
||||||
if(!state_open && !occupant)
|
. = TRUE
|
||||||
if(default_deconstruction_screwdriver(user, "[initial(icon_state)]-o", initial(icon_state), I))
|
if(..())
|
||||||
return
|
return
|
||||||
|
if(occupant)
|
||||||
|
to_chat(user, "<span class='warning'>[src] is currently occupied!</span>")
|
||||||
|
return
|
||||||
|
if(state_open)
|
||||||
|
to_chat(user, "<span class='warning'>[src] must be closed to [panel_open ? "close" : "open"] its maintenance hatch!</span>")
|
||||||
|
return
|
||||||
|
if(default_deconstruction_screwdriver(user, "[initial(icon_state)]-o", initial(icon_state), I))
|
||||||
|
return
|
||||||
|
return FALSE
|
||||||
|
|
||||||
|
/obj/machinery/sleeper/wrench_act(mob/living/user, obj/item/I)
|
||||||
|
. = ..()
|
||||||
if(default_change_direction_wrench(user, I))
|
if(default_change_direction_wrench(user, I))
|
||||||
return
|
return TRUE
|
||||||
|
|
||||||
|
/obj/machinery/sleeper/crowbar_act(mob/living/user, obj/item/I)
|
||||||
|
. = ..()
|
||||||
if(default_pry_open(I))
|
if(default_pry_open(I))
|
||||||
return
|
return TRUE
|
||||||
if(default_deconstruction_crowbar(I))
|
if(default_deconstruction_crowbar(I))
|
||||||
|
return TRUE
|
||||||
|
|
||||||
|
/obj/machinery/sleeper/default_pry_open(obj/item/I) //wew
|
||||||
|
. = !(state_open || panel_open || (flags_1 & NODECONSTRUCT_1)) && I.tool_behaviour == TOOL_CROWBAR
|
||||||
|
if(.)
|
||||||
|
I.play_tool_sound(src, 50)
|
||||||
|
visible_message("<span class='notice'>[usr] pries open [src].</span>", "<span class='notice'>You pry open [src].</span>")
|
||||||
|
open_machine()
|
||||||
|
|
||||||
|
/obj/machinery/sleeper/AltClick(mob/user)
|
||||||
|
if(!user.canUseTopic(src, !issilicon(user)))
|
||||||
return
|
return
|
||||||
return ..()
|
if(state_open)
|
||||||
|
close_machine()
|
||||||
|
else
|
||||||
|
open_machine()
|
||||||
|
|
||||||
|
/obj/machinery/sleeper/examine(mob/user)
|
||||||
|
..()
|
||||||
|
to_chat(user, "<span class='notice'>Alt-click [src] to [state_open ? "close" : "open"] it.</span>")
|
||||||
|
|
||||||
/obj/machinery/sleeper/ui_interact(mob/user, ui_key = "main", datum/tgui/ui = null, force_open = FALSE, \
|
/obj/machinery/sleeper/ui_interact(mob/user, ui_key = "main", datum/tgui/ui = null, force_open = FALSE, \
|
||||||
datum/tgui/master_ui = null, datum/ui_state/state = GLOB.notcontained_state)
|
datum/tgui/master_ui = null, datum/ui_state/state = GLOB.notcontained_state)
|
||||||
@@ -190,7 +223,7 @@
|
|||||||
if(inject_chem(chem, usr))
|
if(inject_chem(chem, usr))
|
||||||
. = TRUE
|
. = TRUE
|
||||||
if(scrambled_chems && prob(5))
|
if(scrambled_chems && prob(5))
|
||||||
to_chat(usr, "<span class='warning'>Chem System Re-route detected, results may not be as expected!</span>")
|
to_chat(usr, "<span class='warning'>Chemical system re-route detected, results may not be as expected!</span>")
|
||||||
|
|
||||||
/obj/machinery/sleeper/emag_act(mob/user)
|
/obj/machinery/sleeper/emag_act(mob/user)
|
||||||
. = ..()
|
. = ..()
|
||||||
|
|||||||
@@ -89,11 +89,11 @@
|
|||||||
return C
|
return C
|
||||||
return null
|
return null
|
||||||
|
|
||||||
/obj/machinery/dna_scannernew/close_machine(mob/living/carbon/user)
|
/obj/machinery/dna_scannernew/close_machine(atom/movable/target)
|
||||||
if(!state_open)
|
if(!state_open)
|
||||||
return FALSE
|
return FALSE
|
||||||
|
|
||||||
..(user)
|
..(target)
|
||||||
|
|
||||||
// search for ghosts, if the corpse is empty and the scanner is connected to a cloner
|
// search for ghosts, if the corpse is empty and the scanner is connected to a cloner
|
||||||
var/mob/living/mob_occupant = get_mob_or_brainmob(occupant)
|
var/mob/living/mob_occupant = get_mob_or_brainmob(occupant)
|
||||||
@@ -111,7 +111,7 @@
|
|||||||
return TRUE
|
return TRUE
|
||||||
|
|
||||||
/obj/machinery/dna_scannernew/open_machine()
|
/obj/machinery/dna_scannernew/open_machine()
|
||||||
if(state_open)
|
if(state_open || panel_open)
|
||||||
return FALSE
|
return FALSE
|
||||||
|
|
||||||
..()
|
..()
|
||||||
@@ -126,23 +126,48 @@
|
|||||||
return
|
return
|
||||||
open_machine()
|
open_machine()
|
||||||
|
|
||||||
/obj/machinery/dna_scannernew/attackby(obj/item/I, mob/user, params)
|
/obj/machinery/dna_scannernew/screwdriver_act(mob/living/user, obj/item/I)
|
||||||
|
. = TRUE
|
||||||
if(!occupant && default_deconstruction_screwdriver(user, icon_state, icon_state, I))//sent icon_state is irrelevant...
|
if(..())
|
||||||
update_icon()//..since we're updating the icon here, since the scanner can be unpowered when opened/closed
|
|
||||||
return
|
return
|
||||||
|
if(occupant)
|
||||||
|
to_chat(user, "<span class='warning'>[src] is currently occupied!</span>")
|
||||||
|
return
|
||||||
|
if(state_open)
|
||||||
|
to_chat(user, "<span class='warning'>[src] must be closed to [panel_open ? "close" : "open"] its maintenance hatch!</span>")
|
||||||
|
return
|
||||||
|
if(default_deconstruction_screwdriver(user, icon_state, icon_state, I)) //sent icon_state is irrelevant...
|
||||||
|
update_icon() //..since we're updating the icon here, since the scanner can be unpowered when opened/closed
|
||||||
|
return
|
||||||
|
return FALSE
|
||||||
|
|
||||||
|
/obj/machinery/dna_scannernew/wrench_act(mob/living/user, obj/item/I)
|
||||||
|
. = ..()
|
||||||
|
if(default_change_direction_wrench(user, I))
|
||||||
|
return TRUE
|
||||||
|
|
||||||
|
/obj/machinery/dna_scannernew/crowbar_act(mob/living/user, obj/item/I)
|
||||||
|
. = ..()
|
||||||
if(default_pry_open(I))
|
if(default_pry_open(I))
|
||||||
return
|
return TRUE
|
||||||
|
|
||||||
if(default_deconstruction_crowbar(I))
|
if(default_deconstruction_crowbar(I))
|
||||||
return
|
return TRUE
|
||||||
|
|
||||||
return ..()
|
/obj/machinery/dna_scannernew/default_pry_open(obj/item/I) //wew
|
||||||
|
. = !(state_open || panel_open || (flags_1 & NODECONSTRUCT_1)) && I.tool_behaviour == TOOL_CROWBAR
|
||||||
|
if(.)
|
||||||
|
I.play_tool_sound(src, 50)
|
||||||
|
visible_message("<span class='notice'>[usr] pries open [src].</span>", "<span class='notice'>You pry open [src].</span>")
|
||||||
|
open_machine()
|
||||||
|
|
||||||
/obj/machinery/dna_scannernew/interact(mob/user)
|
/obj/machinery/dna_scannernew/interact(mob/user)
|
||||||
toggle_open(user)
|
toggle_open(user)
|
||||||
|
|
||||||
|
/obj/machinery/dna_scannernew/AltClick(mob/user)
|
||||||
|
if(!user.canUseTopic(src, !issilicon(user)))
|
||||||
|
return
|
||||||
|
interact(user)
|
||||||
|
|
||||||
/obj/machinery/dna_scannernew/MouseDrop_T(mob/target, mob/user)
|
/obj/machinery/dna_scannernew/MouseDrop_T(mob/target, mob/user)
|
||||||
if(user.stat || user.lying || !Adjacent(user) || !user.Adjacent(target) || !iscarbon(target) || !user.IsAdvancedToolUser())
|
if(user.stat || user.lying || !Adjacent(user) || !user.Adjacent(target) || !iscarbon(target) || !user.IsAdvancedToolUser())
|
||||||
return
|
return
|
||||||
|
|||||||
Reference in New Issue
Block a user