mirror of
https://github.com/Bubberstation/Bubberstation.git
synced 2026-01-16 20:16:09 +00:00
Fixes #39976 A good number of things were missing various parts of the logging (going to GLOB.bombers, not going to client logs, not logging to game, ect), or doing incorrect things like passing admin verbs to saved logs. Unified all the necessary actions under a single proc log_bomber() which handles everything in most use cases. This way the log isn't all jumbled up with inconsistent messages, everything's one format so you can quickly find what you need to bwoink the right person.
173 lines
6.8 KiB
Plaintext
173 lines
6.8 KiB
Plaintext
//CREATOR'S NOTE: DO NOT FUCKING GIVE THIS TO BOTANY!
|
|
/obj/item/hot_potato
|
|
name = "hot potato"
|
|
desc = "A label on the side of this potato reads \"Product of DonkCo Service Wing. Activate far away from populated areas. Device will only attach to sapient creatures.\" <span class='boldnotice'>You can attack anyone with it to force it on them instead of yourself!</span>"
|
|
icon = 'icons/obj/hydroponics/harvest.dmi'
|
|
icon_state = "potato"
|
|
item_flags = NOBLUDGEON
|
|
force = 0
|
|
var/icon_off = "potato"
|
|
var/icon_on = "potato_active"
|
|
var/detonation_timerid
|
|
var/activation_time = 0
|
|
var/timer = 600 //deciseconds
|
|
var/show_timer = FALSE
|
|
var/reusable = FALSE //absolute madman
|
|
var/sticky = TRUE
|
|
var/forceful_attachment = TRUE
|
|
var/stimulant = TRUE
|
|
var/detonate_explosion = TRUE
|
|
var/detonate_dev_range = 0
|
|
var/detonate_heavy_range = 0
|
|
var/detonate_light_range = 2
|
|
var/detonate_flash_range = 5
|
|
var/detonate_fire_range = 5
|
|
|
|
var/active = FALSE
|
|
|
|
var/color_val = FALSE
|
|
|
|
var/datum/weakref/current
|
|
|
|
/obj/item/hot_potato/Destroy()
|
|
if(active)
|
|
deactivate()
|
|
return ..()
|
|
|
|
/obj/item/hot_potato/proc/colorize(mob/target)
|
|
//Clear color from old target
|
|
if(current)
|
|
var/mob/M = current.resolve()
|
|
if(istype(M))
|
|
M.remove_atom_colour(FIXED_COLOUR_PRIORITY)
|
|
//Give to new target
|
|
current = null
|
|
//Swap colors
|
|
color_val = !color_val
|
|
if(istype(target))
|
|
current = WEAKREF(target)
|
|
target.add_atom_colour(color_val? "#ffff00" : "#00ffff", FIXED_COLOUR_PRIORITY)
|
|
|
|
/obj/item/hot_potato/proc/detonate()
|
|
var/atom/location = loc
|
|
location.visible_message("<span class='userdanger'>[src] [detonate_explosion? "explodes" : "activates"]!</span>", "<span class='userdanger'>[src] activates! You've ran out of time!</span>")
|
|
if(detonate_explosion)
|
|
explosion(src, detonate_dev_range, detonate_heavy_range, detonate_light_range, detonate_flash_range, flame_range = detonate_fire_range)
|
|
deactivate()
|
|
if(!reusable)
|
|
var/mob/M = loc
|
|
if(istype(M))
|
|
M.dropItemToGround(src, TRUE)
|
|
qdel(src)
|
|
|
|
/obj/item/hot_potato/attack_self(mob/user)
|
|
if(activate(timer, user))
|
|
user.visible_message("<span class='boldwarning'>[user] squeezes [src], which promptly starts to flash red-hot colors!</span>", "<span class='boldwarning'>You squeeze [src], activating its countdown and attachment mechanism!</span>",
|
|
"<span class='boldwarning'>You hear a mechanical click and a loud beeping!</span>")
|
|
return
|
|
return ..()
|
|
|
|
/obj/item/hot_potato/process()
|
|
if(stimulant)
|
|
if(isliving(loc))
|
|
var/mob/living/L = loc
|
|
L.SetStun(0)
|
|
L.SetKnockdown(0)
|
|
L.SetSleeping(0)
|
|
L.SetUnconscious(0)
|
|
L.reagents.add_reagent("muscle_stimulant", CLAMP(5 - L.reagents.get_reagent_amount("muscle_stimulant"), 0, 5)) //If you don't have legs or get bola'd, tough luck!
|
|
colorize(L)
|
|
|
|
/obj/item/hot_potato/examine(mob/user)
|
|
. = ..()
|
|
if(active)
|
|
to_chat(user, "<span class='warning'>[src] is flashing red-hot! You should probably get rid of it!</span>")
|
|
if(show_timer)
|
|
to_chat(user, "<span class='warning'>[src]'s timer looks to be at [DisplayTimeText(activation_time - world.time)]!</span>")
|
|
|
|
/obj/item/hot_potato/equipped(mob/user)
|
|
. = ..()
|
|
if(active)
|
|
to_chat(user, "<span class='userdanger'>You have a really bad feeling about [src]!</span>")
|
|
|
|
/obj/item/hot_potato/afterattack(atom/target, mob/user, adjacent, params)
|
|
. = ..()
|
|
if(!adjacent || !ismob(target))
|
|
return
|
|
force_onto(target, user)
|
|
|
|
/obj/item/hot_potato/proc/force_onto(mob/living/victim, mob/user)
|
|
if(!istype(victim) || user != loc || victim == user)
|
|
return FALSE
|
|
if(!victim.client)
|
|
to_chat(user, "<span class='boldwarning'>[src] refuses to attach to a non-sapient creature!</span>")
|
|
if(victim.stat != CONSCIOUS || !victim.get_num_legs())
|
|
to_chat(user, "<span class='boldwarning'>[src] refuses to attach to someone incapable of using it!</span>")
|
|
user.temporarilyRemoveItemFromInventory(src, TRUE)
|
|
. = FALSE
|
|
if(!victim.put_in_hands(src))
|
|
if(forceful_attachment)
|
|
victim.dropItemToGround(victim.get_inactive_held_item())
|
|
if(!victim.put_in_hands(src))
|
|
victim.dropItemToGround(victim.get_active_held_item())
|
|
if(victim.put_in_hands(src))
|
|
. = TRUE
|
|
else
|
|
. = TRUE
|
|
else
|
|
. = TRUE
|
|
if(.)
|
|
log_combat(user, victim, "forced a hot potato with explosive variables ([detonate_explosion]-[detonate_dev_range]/[detonate_heavy_range]/[detonate_light_range]/[detonate_flash_range]/[detonate_fire_range]) onto")
|
|
user.visible_message("<span class='userdanger'>[user] forces [src] onto [victim]!</span>", "<span class='userdanger'>You force [src] onto [victim]!</span>", "<span class='boldwarning'>You hear a mechanical click and a beep.</span>")
|
|
colorize(null)
|
|
else
|
|
log_combat(user, victim, "tried to force a hot potato with explosive variables ([detonate_explosion]-[detonate_dev_range]/[detonate_heavy_range]/[detonate_light_range]/[detonate_flash_range]/[detonate_fire_range]) onto")
|
|
user.visible_message("<span class='boldwarning'>[user] tried to force [src] onto [victim], but it could not attach!</span>", "<span class='boldwarning'>You try to force [src] onto [victim], but it is unable to attach!</span>", "<span class='boldwarning'>You hear a mechanical click and two buzzes.</span>")
|
|
user.put_in_hands(src)
|
|
|
|
/obj/item/hot_potato/dropped(mob/user)
|
|
. = ..()
|
|
colorize(null)
|
|
|
|
/obj/item/hot_potato/proc/activate(delay, mob/user)
|
|
if(active)
|
|
return
|
|
update_icon()
|
|
if(sticky)
|
|
item_flags |= NODROP
|
|
name = "primed [name]"
|
|
activation_time = timer + world.time
|
|
detonation_timerid = addtimer(CALLBACK(src, .proc/detonate), delay, TIMER_STOPPABLE)
|
|
START_PROCESSING(SSfastprocess, src)
|
|
if(user)
|
|
log_bomber(user, "has primed a", src, "for detonation (Timer:[delay],Explosive:[detonate_explosion],Range:[detonate_dev_range]/[detonate_heavy_range]/[detonate_light_range]/[detonate_fire_range])")
|
|
else
|
|
log_bomber(null, null, src, "was primed for detonation (Timer:[delay],Explosive:[detonate_explosion],Range:[detonate_dev_range]/[detonate_heavy_range]/[detonate_light_range]/[detonate_fire_range])")
|
|
active = TRUE
|
|
|
|
/obj/item/hot_potato/proc/deactivate()
|
|
update_icon()
|
|
name = initial(name)
|
|
item_flags &= ~NODROP
|
|
deltimer(detonation_timerid)
|
|
STOP_PROCESSING(SSfastprocess, src)
|
|
detonation_timerid = null
|
|
colorize(null)
|
|
active = FALSE
|
|
|
|
/obj/item/hot_potato/update_icon()
|
|
icon_state = active? icon_on : icon_off
|
|
|
|
/obj/item/hot_potato/syndicate
|
|
detonate_light_range = 4
|
|
detonate_fire_range = 5
|
|
|
|
/obj/item/hot_potato/harmless
|
|
detonate_explosion = FALSE
|
|
|
|
/obj/item/hot_potato/harmless/toy
|
|
desc = "A label on the side of this potato reads \"Product of DonkCo Toys and Recreation department.\" <span class='boldnotice'>You can attack anyone with it to put it on them instead, if they have a free hand to take it!</span>"
|
|
sticky = FALSE
|
|
reusable = TRUE
|
|
forceful_attachment = FALSE
|