GLOBAL_LIST_EMPTY(doppler_arrays) /obj/machinery/doppler_array name = "tachyon-doppler array" desc = "A highly precise directional sensor array which measures the release of quants from decaying tachyons. The doppler shifting of the mirror-image formed by these quants can reveal the size, location and temporal affects of energetic disturbances within a large radius ahead of the array.\n" icon = 'icons/obj/machines/research.dmi' icon_state = "tdoppler" density = TRUE var/integrated = FALSE var/list_limit = 100 var/cooldown = 10 var/next_announce = 0 var/max_dist = 150 verb_say = "states coldly" var/list/message_log = list() /obj/machinery/doppler_array/Initialize() . = ..() GLOB.doppler_arrays += src /obj/machinery/doppler_array/ComponentInitialize() . = ..() AddComponent(/datum/component/simple_rotation,ROTATION_ALTCLICK | ROTATION_CLOCKWISE,null,null,CALLBACK(src,.proc/rot_message)) /obj/machinery/doppler_array/Destroy() GLOB.doppler_arrays -= src return ..() /obj/machinery/doppler_array/ui_interact(mob/user) . = ..() if(stat) return FALSE var/list/dat = list() for(var/i in 1 to LAZYLEN(message_log)) dat += "Log recording #[i]: [message_log[i]]

" dat += "Delete logs
" dat += "
" dat += "(Refresh)
" dat += "" var/datum/browser/popup = new(user, "computer", name, 400, 500) popup.set_content(dat.Join(" ")) popup.open() /obj/machinery/doppler_array/Topic(href, href_list) if(..()) return if(href_list["delete_log"]) LAZYCLEARLIST(message_log) if(href_list["refresh"]) updateUsrDialog() updateUsrDialog() return /obj/machinery/doppler_array/attackby(obj/item/I, mob/user, params) if(istype(I, /obj/item/wrench)) if(!anchored && !isinspace()) anchored = TRUE power_change() to_chat(user, "You fasten [src].") else if(anchored) anchored = FALSE power_change() to_chat(user, "You unfasten [src].") I.play_tool_sound(src) else return ..() /obj/machinery/doppler_array/proc/rot_message(mob/user) to_chat(user, "You adjust [src]'s dish to face to the [dir2text(dir)].") playsound(src, 'sound/items/screwdriver2.ogg', 50, 1) /obj/machinery/doppler_array/proc/sense_explosion(turf/epicenter, devastation_range, heavy_impact_range, light_impact_range, took, orig_dev_range, orig_heavy_range, orig_light_range) if(stat & NOPOWER) return FALSE var/turf/zone = get_turf(src) if(zone.z != epicenter.z) return FALSE if(next_announce > world.time) return FALSE next_announce = world.time + cooldown var/distance = get_dist(epicenter, zone) var/direct = get_dir(zone, epicenter) if(distance > max_dist) return FALSE if(!(direct & dir) && !integrated) return FALSE var/list/messages = list("Explosive disturbance detected.", \ "Epicenter at: grid ([epicenter.x],[epicenter.y]). Temporal displacement of tachyons: [took] seconds.", \ "Factual: Epicenter radius: [devastation_range]. Outer radius: [heavy_impact_range]. Shockwave radius: [light_impact_range].") // If the bomb was capped, say its theoretical size. if(devastation_range < orig_dev_range || heavy_impact_range < orig_heavy_range || light_impact_range < orig_light_range) messages += "Theoretical: Epicenter radius: [orig_dev_range]. Outer radius: [orig_heavy_range]. Shockwave radius: [orig_light_range]." if(integrated) var/obj/item/clothing/head/helmet/space/hardsuit/helm = loc if(!helm || !istype(helm, /obj/item/clothing/head/helmet/space/hardsuit)) return FALSE helm.display_visor_message("Explosion detected! Epicenter: [devastation_range], Outer: [heavy_impact_range], Shock: [light_impact_range]") else for(var/message in messages) say(message) if(LAZYLEN(message_log) > list_limit) say("Storage buffer is full! Clearing buffers...") LAZYCLEARLIST(message_log) LAZYADD(message_log, messages.Join(" ")) return TRUE /obj/machinery/doppler_array/examine(mob/user) . = ..() . += "Its dish is facing to the [dir2text(dir)]." /obj/machinery/doppler_array/process() return PROCESS_KILL /obj/machinery/doppler_array/power_change() if(stat & BROKEN) icon_state = "[initial(icon_state)]-broken" else if(powered() && anchored) icon_state = initial(icon_state) stat &= ~NOPOWER else icon_state = "[initial(icon_state)]-off" stat |= NOPOWER //Portable version, built into EOD equipment. It simply provides an explosion's three damage levels. /obj/machinery/doppler_array/integrated name = "integrated tachyon-doppler module" integrated = TRUE max_dist = 21 //Should detect most explosions in hearing range. use_power = NO_POWER_USE /obj/machinery/doppler_array/research name = "tachyon-doppler research array" desc = "A specialized tachyon-doppler bomb detection array that uses the results of the highest yield of explosions for research." var/datum/techweb/linked_techweb /obj/machinery/doppler_array/research/sense_explosion(turf/epicenter, dev, heavy, light, time, orig_dev, orig_heavy, orig_light) //probably needs a way to ignore admin explosives later on . = ..() if(!.) return FALSE if(!istype(linked_techweb)) say("Warning: No linked research system!") return var/point_gain = 0 /*****The Point Calculator*****/ if(orig_light < 10) say("Explosion not large enough for research calculations.") return else if(orig_light < 4500) point_gain = (83300 * orig_light) / (orig_light + 3000) else point_gain = TECHWEB_BOMB_POINTCAP /*****The Point Capper*****/ if(point_gain > linked_techweb.largest_bomb_value) if(point_gain <= TECHWEB_BOMB_POINTCAP || linked_techweb.largest_bomb_value < TECHWEB_BOMB_POINTCAP) var/old_tech_largest_bomb_value = linked_techweb.largest_bomb_value //held so we can pull old before we do math linked_techweb.largest_bomb_value = point_gain point_gain -= old_tech_largest_bomb_value point_gain = min(point_gain,TECHWEB_BOMB_POINTCAP) else linked_techweb.largest_bomb_value = TECHWEB_BOMB_POINTCAP point_gain = 1000 linked_techweb.add_point_type(TECHWEB_POINT_TYPE_DEFAULT, point_gain) say("Gained [point_gain] points from explosion dataset.") else //you've made smaller bombs say("Data already captured. Aborting.") return /obj/machinery/doppler_array/research/science/Initialize() . = ..() linked_techweb = SSresearch.science_tech