diff --git a/code/datums/wires/explosive.dm b/code/datums/wires/explosive.dm
index 800b5b88444..c8d576cf4f3 100644
--- a/code/datums/wires/explosive.dm
+++ b/code/datums/wires/explosive.dm
@@ -144,11 +144,3 @@
/datum/wires/explosive/pizza/explode()
var/obj/item/pizzabox/P = holder
P.bomb.detonate()
-
-
-/datum/wires/explosive/gibtonite
- holder_type = /obj/item/gibtonite
-
-/datum/wires/explosive/gibtonite/explode()
- var/obj/item/gibtonite/P = holder
- P.GibtoniteReaction(null, "A wire signal has primed a")
diff --git a/code/modules/mining/ores_coins.dm b/code/modules/mining/ores_coins.dm
index b01b537ec80..bea2570fc4e 100644
--- a/code/modules/mining/ores_coins.dm
+++ b/code/modules/mining/ores_coins.dm
@@ -236,35 +236,77 @@ GLOBAL_LIST_INIT(sand_recipes, list(\
inhand_icon_state = "Gibtonite ore"
w_class = WEIGHT_CLASS_BULKY
throw_range = 0
+ /// if the gibtonite is currently primed for explosion
var/primed = FALSE
- var/det_time = 100
- var/quality = GIBTONITE_QUALITY_LOW //How pure this gibtonite is, determines the explosion produced by it and is derived from the det_time of the rock wall it was taken from, higher value = better
- var/attacher = "UNKNOWN"
+ /// how long does it take for this to detonate
+ var/det_time = 10 SECONDS
+ /// the timer
var/det_timer
+ /// How pure this gibtonite is, determines the explosion produced by it and is derived from the det_time of the rock wall it was taken from, higher value = better
+ var/quality = GIBTONITE_QUALITY_LOW
+ /// who attached the rig to us
+ var/attacher
+ /// the assembly rig
+ var/obj/item/assembly_holder/rig
+ /// the rig overlay
+ var/mutable_appearance/rig_overlay
/obj/item/gibtonite/Initialize(mapload)
. = ..()
AddComponent(/datum/component/two_handed, require_twohands=TRUE)
AddComponent(/datum/component/golem_food, consume_on_eat = FALSE, golem_food_key = /obj/item/gibtonite)
+/obj/item/gibtonite/examine(mob/user)
+ . = ..()
+ if(rig)
+ . += span_warning("There is some kind of device rigged to it!")
+ else
+ . += span_notice("You could rig something to it.")
+
/obj/item/gibtonite/Destroy()
- qdel(wires)
- set_wires(null)
+ QDEL_NULL(rig)
+ rig_overlay = null
return ..()
+/obj/item/gibtonite/Exited(atom/movable/gone, direction)
+ . = ..()
+ if(gone == rig)
+ rig = null
+ attacher = null
+ cut_overlays(rig_overlay)
+ UnregisterSignal(src, COMSIG_IGNITER_ACTIVATE)
+
+/obj/item/gibtonite/IsSpecialAssembly()
+ return TRUE
+
/obj/item/gibtonite/attackby(obj/item/I, mob/user, params)
- if(!wires && isigniter(I))
- user.visible_message(span_notice("[user] attaches [I] to [src]."), span_notice("You attach [I] to [src]."))
- set_wires(new /datum/wires/explosive/gibtonite(src))
+ if(istype(I, /obj/item/assembly_holder) && !rig)
+ var/obj/item/assembly_holder/holder = I
+ if(!(locate(/obj/item/assembly/igniter) in holder.assemblies))
+ return ..()
+ if(!user.transferItemToLoc(holder, src))
+ return
+ add_fingerprint(user)
+ rig = holder
+ holder.master = src
+ holder.on_attach()
+ rig_overlay = holder
+ rig_overlay.pixel_y -= 5
+ add_overlay(rig_overlay)
+ RegisterSignal(src, COMSIG_IGNITER_ACTIVATE, PROC_REF(igniter_prime))
+ log_bomber(user, "attached [holder] to ", src)
attacher = key_name(user)
- qdel(I)
- add_overlay("Gibtonite_igniter")
+ user.balloon_alert_to_viewers("attached rig")
return
-
- if(wires && !primed)
- if(is_wire_tool(I))
- wires.interact(user)
+
+ if(I.tool_behaviour == TOOL_WRENCH && rig)
+ rig.on_found()
+ if(QDELETED(src))
return
+ user.balloon_alert_to_viewers("detached rig")
+ user.log_message("detached [rig] from [src].", LOG_GAME)
+ user.put_in_hands(rig)
+ return
if(I.tool_behaviour == TOOL_MINING || istype(I, /obj/item/resonator) || I.force >= 10)
GibtoniteReaction(user, "A resonator has primed for detonation a")
@@ -342,6 +384,10 @@ GLOBAL_LIST_INIT(sand_recipes, list(\
hit_mob.Paralyze(1.5 SECONDS)
hit_mob.Knockdown(8 SECONDS)
+/obj/item/gibtonite/proc/igniter_prime()
+ SIGNAL_HANDLER
+ GibtoniteReaction(null, "An attached rig has primed a")
+
/obj/item/stack/ore/Initialize(mapload, new_amount, merge = TRUE, list/mat_override=null, mat_amt=1)
. = ..()
pixel_x = base_pixel_x + rand(0, 16) - 8