From 8df222b2cef94dd5a73544d29144fc1e37a6a5e4 Mon Sep 17 00:00:00 2001
From: SkyratBot <59378654+SkyratBot@users.noreply.github.com>
Date: Sun, 19 Nov 2023 14:51:41 +0100
Subject: [PATCH] [MIRROR] Fixes delam counter incorrect reset on delam [MDB
IGNORE] (#25113)
* Fixes delam counter incorrect reset on delam (#79805)
## About The Pull Request
Fixes the delam counter being off by 1 when a delam happens, it should
reset to 0 next round, not 1.
## Changelog
:cl: LT3
fix: Delam counter will correctly show 0 the shift after a delam
/:cl:
* Fixes delam counter incorrect reset on delam
---------
Co-authored-by: lessthanthree <83487515+lessthnthree@users.noreply.github.com>
---
code/game/machinery/incident_display.dm | 37 ++++++++++---------
.../supermatter_delamination/_sm_delam.dm | 2 +-
2 files changed, 20 insertions(+), 19 deletions(-)
diff --git a/code/game/machinery/incident_display.dm b/code/game/machinery/incident_display.dm
index 97557c5611c..9e6a3fe8124 100644
--- a/code/game/machinery/incident_display.dm
+++ b/code/game/machinery/incident_display.dm
@@ -215,12 +215,12 @@ MAPPING_DIRECTIONAL_HELPERS(/obj/machinery/incident_display/tram, 32)
var/mutable_appearance/delam_base_emissive = emissive_appearance(icon, "delam_base_emissive", src, alpha = src.alpha)
var/delam_display_color
. += delam_base_emissive
- if(!last_delam)
+ if(last_delam <= 0)
delam_display_color = COLOR_DISPLAY_RED
else
delam_display_color = COLOR_DISPLAY_YELLOW
- var/delam_pos1 = last_delam % 10
+ var/delam_pos1 = clamp(last_delam, 0, 199) % 10
var/mutable_appearance/delam_pos1_overlay = mutable_appearance(icon, "num_[delam_pos1]")
var/mutable_appearance/delam_pos1_emissive = emissive_appearance(icon, "num_[delam_pos1]_e", src, alpha = src.alpha)
delam_pos1_overlay.color = delam_display_color
@@ -231,7 +231,7 @@ MAPPING_DIRECTIONAL_HELPERS(/obj/machinery/incident_display/tram, 32)
. += delam_pos1_overlay
. += delam_pos1_emissive
- var/delam_pos2 = (last_delam / 10) % 10
+ var/delam_pos2 = (clamp(last_delam, 0, 199) / 10) % 10
var/mutable_appearance/delam_pos2_overlay = mutable_appearance(icon, "num_[delam_pos2]")
var/mutable_appearance/delam_pos2_emissive = emissive_appearance(icon, "num_[delam_pos2]_e", src, alpha = src.alpha)
delam_pos2_overlay.color = delam_display_color
@@ -327,24 +327,25 @@ MAPPING_DIRECTIONAL_HELPERS(/obj/machinery/incident_display/tram, 32)
. = ..()
if(sign_features & DISPLAY_DELAM)
- . += span_info("It has been [last_delam] shift\s since the last delamination event at this Nanotrasen facility.")
- switch (last_delam)
- if(0)
- . += span_info("In case you didn't notice.
")
- if(1)
- . += span_info("Let's do better today.
")
- if(2 to 5)
- . += span_info("There's room for improvement.
")
- if(6 to 10)
- . += span_info("Good work!
")
- if(69)
- . += span_info("Nice.
")
- else
- . += span_info("Incredible!
")
+ if(last_delam >= 0)
+ . += span_info("It has been [last_delam] shift\s since the last delamination event at this Nanotrasen facility.")
+ switch(last_delam)
+ if(0)
+ . += span_info("Let's do better today.
")
+ if(1 to 5)
+ . += span_info("There's room for improvement.
")
+ if(6 to 10)
+ . += span_info("Good work!
")
+ if(69)
+ . += span_info("Nice.
")
+ else
+ . += span_info("Incredible!
")
+ else
+ . += span_info("The supermatter crystal has delaminated, in case you didn't notice.")
if(sign_features & DISPLAY_TRAM)
. += span_info("The station has had [hit_count] tram incident\s this shift.")
- switch (hit_count)
+ switch(hit_count)
if(0)
. += span_info("Fantastic! Champions of safety.
")
if(1)
diff --git a/code/modules/power/supermatter/supermatter_delamination/_sm_delam.dm b/code/modules/power/supermatter/supermatter_delamination/_sm_delam.dm
index 8edcc6710bf..eabb07d1137 100644
--- a/code/modules/power/supermatter/supermatter_delamination/_sm_delam.dm
+++ b/code/modules/power/supermatter/supermatter_delamination/_sm_delam.dm
@@ -15,7 +15,7 @@ GLOBAL_LIST_INIT(sm_delam_list, list(
/datum/sm_delam/proc/can_select(obj/machinery/power/supermatter_crystal/sm)
return FALSE
-#define ROUNDCOUNT_ENGINE_JUST_EXPLODED 0
+#define ROUNDCOUNT_ENGINE_JUST_EXPLODED -1
/// Called when the count down has been finished, do the nasty work.
/// [/obj/machinery/power/supermatter_crystal/proc/count_down]