mirror of
https://github.com/vgstation-coders/vgstation13.git
synced 2025-12-10 02:16:05 +00:00
Conflicts: baystation12.dme code/__HELPERS/global_lists.dm code/__HELPERS/type2type.dm code/__HELPERS/unsorted.dm code/datums/datumvars.dm code/datums/disease.dm code/datums/organs/organ_external.dm code/datums/supplypacks.dm code/defines/obj.dm code/game/area/areas.dm code/game/atoms.dm code/game/gamemodes/cult/cult_structures.dm code/game/gamemodes/cult/runes.dm code/game/gamemodes/events.dm code/game/gamemodes/events/ninja_equipment.dm code/game/gamemodes/events/space_ninja.dm code/game/gamemodes/game_mode.dm code/game/gamemodes/gameticker.dm code/game/hud.dm code/game/jobs/access.dm code/game/jobs/job/civilian.dm code/game/machinery/alarm.dm code/game/machinery/cloning.dm code/game/machinery/computer/cloning.dm code/game/machinery/computer/medical.dm code/game/machinery/computer/syndicate_shuttle.dm code/game/machinery/telecomms/broadcaster.dm code/game/machinery/telecomms/machine_interactions.dm code/game/objects/effects/decals/contraband.dm code/game/objects/effects/signs.dm code/game/objects/items/devices/PDA/PDA.dm code/game/objects/items/devices/PDA/cart.dm code/game/objects/items/weapons/photography.dm code/game/objects/structures/door_assembly.dm code/game/objects/structures/window.dm code/game/sound.dm code/game/verbs/ooc.dm code/global.dm code/modules/DetectiveWork/detective_work.dm code/modules/DetectiveWork/evidence.dm code/modules/DetectiveWork/footprints_and_rag.dm code/modules/DetectiveWork/scanner.dm code/modules/admin/player_panel.dm code/modules/admin/verbs/adminhelp.dm code/modules/admin/verbs/adminpm.dm code/modules/awaymissions/gateway.dm code/modules/client/client defines.dm code/modules/client/client procs.dm code/modules/client/preferences.dm code/modules/clothing/spacesuits/rig.dm code/modules/mining/machine_processing.dm code/modules/mining/machine_stacking.dm code/modules/mining/mint.dm code/modules/mining/ores_coins.dm code/modules/mining/satchel_ore_boxdm.dm code/modules/mob/living/carbon/alien/alien.dm code/modules/mob/living/carbon/carbon.dm code/modules/mob/living/carbon/carbon_defines.dm code/modules/mob/living/carbon/human/human_damage.dm code/modules/mob/living/carbon/human/life.dm code/modules/mob/living/carbon/human/update_icons.dm code/modules/mob/living/living.dm code/modules/mob/living/say.dm code/modules/mob/mob.dm code/modules/mob/mob_cleanup.dm code/modules/mob/mob_defines.dm code/modules/mob/mob_transformation_simple.dm code/modules/mob/new_player/login.dm code/modules/mob/new_player/new_player.dm code/modules/mob/new_player/preferences_setup.dm code/modules/mob/new_player/savefile.dm code/modules/mob/new_player/sprite_accessories.dm code/modules/paperwork/folders.dm code/modules/paperwork/paper.dm code/modules/paperwork/photocopier.dm code/modules/projectiles/guns/energy/special.dm code/modules/projectiles/guns/projectile/automatic.dm code/setup.dm code/unused/mining/datum_processing_recipe.dm code/unused/powerarmor/powerarmor.dm code/world.dm html/changelog.html icons/effects/96x96.dmi icons/mob/head.dmi icons/mob/items_lefthand.dmi icons/mob/items_righthand.dmi icons/mob/suit.dmi icons/obj/clothing/hats.dmi icons/obj/clothing/suits.dmi icons/obj/hydroponics.dmi icons/obj/items.dmi icons/turf/areas.dmi icons/turf/walls.dmi maps/RandomZLevels/fileList.txt maps/RandomZLevels/spacebattle.dmm Signed-off-by: Cael_Aislinn <cael_aislinn@yahoo.com.au>
167 lines
6.0 KiB
Plaintext
167 lines
6.0 KiB
Plaintext
//CONTAINS: Detective's Scanner
|
|
|
|
|
|
/obj/item/device/detective_scanner
|
|
name = "Scanner"
|
|
desc = "Used to scan objects for DNA and fingerprints. Can print a report of the findings."
|
|
icon_state = "forensic1"
|
|
w_class = 3.0
|
|
item_state = "electronic"
|
|
flags = FPRINT | TABLEPASS | CONDUCT | USEDELAY
|
|
slot_flags = SLOT_BELT
|
|
var/scanning = 0
|
|
var/list/log = list()
|
|
|
|
/obj/item/device/detective_scanner/attack_self(var/mob/user)
|
|
if(log.len && !scanning)
|
|
scanning = 1
|
|
user << "<span class='notice'>Printing report, please wait...</span>"
|
|
spawn(100)
|
|
var/obj/item/weapon/paper/P = new(get_turf(src))
|
|
P.info = "<center><font size='4'>Scanner Report</font></center><HR><BR>"
|
|
P.info += dd_list2text(log, "<BR>")
|
|
P.info_links = P.info
|
|
|
|
user.put_in_hands(P)
|
|
|
|
log = list()
|
|
scanning = 0
|
|
if(user)
|
|
user << "<span class='notice'>Report printed. Log cleared.<span>"
|
|
else
|
|
user << "<span class='notice'>The scanner has no logs or is in use.</span>"
|
|
|
|
/obj/item/device/detective_scanner/attack(mob/living/carbon/human/M as mob, mob/user as mob)
|
|
if(!scanning)
|
|
scanning = 1
|
|
spawn(0)
|
|
add_log(user, "<font color='blue'>Scanning [M]...</font>")
|
|
if (!ishuman(M))
|
|
add_log(user, "<span class='warning'>[M] is not human and cannot have the fingerprints.</span>")
|
|
else
|
|
if (( !( istype(M.dna, /datum/dna) ) || M.gloves) )
|
|
add_log(user, "<span class='info'>No fingerprints found on [M]</span>")
|
|
else
|
|
add_log(user, "<span class='info'>Fingerprints found on [M]. Analysing...</span>")
|
|
sleep(30)
|
|
add_log(user, "<span class='info'>[M]'s Fingerprints: [md5(M.dna.uni_identity)]</span>")
|
|
|
|
if ( !M.blood_DNA || !M.blood_DNA.len )
|
|
add_log(user, "<span class='info'>No blood found on [M]</span>")
|
|
if(M.blood_DNA)
|
|
del(M.blood_DNA)
|
|
else
|
|
add_log(user, "<span class='info'>Blood found on [M]. Analysing...</span>")
|
|
sleep(30)
|
|
for(var/blood in M.blood_DNA)
|
|
add_log(user, "<span class='info'>Blood type: [M.blood_DNA[blood]]\nDNA: [blood]</span>")
|
|
add_log(null, "<font color='blue'>Ending scan report.</font>")
|
|
scanning = 0
|
|
return
|
|
|
|
/obj/item/device/detective_scanner/afterattack(atom/A as obj|turf|area, mob/user as mob)
|
|
if(!in_range(A,user))
|
|
return
|
|
if(!isturf(A) && !isobj(A))
|
|
return
|
|
if(loc != user)
|
|
return
|
|
|
|
if(!scanning)
|
|
scanning = 1
|
|
add_fingerprint(user)
|
|
|
|
spawn(0)
|
|
|
|
add_log(user, "<font color='blue'>Scanning [A]...</font>")
|
|
//PRINTS
|
|
if(!A.fingerprints || !A.fingerprints.len)
|
|
if(A.fingerprints)
|
|
del(A.fingerprints)
|
|
else
|
|
var/list/completed_prints = list()
|
|
// Bah this looks awful but basically it loop throught the last 15 entries.
|
|
for(var/i in A.fingerprints)
|
|
var/print = A.fingerprints[i]
|
|
completed_prints += print
|
|
if(completed_prints.len < 1)
|
|
add_log(user, "<span class='info'>No intact prints found</span>")
|
|
else
|
|
add_log(user, "<span class='info'>Found [completed_prints.len] intact print[completed_prints.len == 1 ? "" : "s"]. Analysing...</span>")
|
|
sleep(30)
|
|
for(var/i in completed_prints)
|
|
add_log(user, " [i]")
|
|
|
|
//FIBERS
|
|
if(A.suit_fibers && A.suit_fibers.len)
|
|
add_log(user, "<span class='info'>Fibers found. Analysing...</span>")
|
|
sleep(30)
|
|
for(var/fiber in A.suit_fibers)
|
|
add_log(user, " [fiber]")
|
|
|
|
//Blood
|
|
if (A.blood_DNA && A.blood_DNA.len)
|
|
add_log(user, "<span class='info'>Blood found. Analysing...</span>")
|
|
sleep(30)
|
|
for(var/blood in A.blood_DNA)
|
|
add_log(user, " Blood type: <font color='red'>[A.blood_DNA[blood]]</font> DNA: <font color='red'>[blood]</font>")
|
|
|
|
//General
|
|
if ((!A.fingerprints || !A.fingerprints.len) && (!A.suit_fibers || !A.suit_fibers.len) && (!A.blood_DNA || !A.blood_DNA.len))
|
|
add_log(null, "Unable to locate any fingerprints, materials, fibers, or blood.")
|
|
user.visible_message("\The [user] scans \the [A] with \a [src], the air around [user.gender == MALE ? "him" : "her"] humming[prob(70) ? " gently." : "."]" ,\
|
|
"<span class='notice'>Unable to locate any fingerprints, materials, fibers, or blood on [A]!</span>",\
|
|
"You hear a faint hum of electrical equipment.")
|
|
else
|
|
user.visible_message("\The [user] scans \the [A] with \a [src], the air around [user.gender == MALE ? "him" : "her"] humming[prob(70) ? " gently." : "."]" ,\
|
|
"You finish scanning \the [A].",\
|
|
"You hear a faint hum of electrical equipment.")
|
|
|
|
add_log(null, "<font color='blue'>Ending scan report.</font>")
|
|
scanning = 0
|
|
return 0
|
|
|
|
|
|
proc/add_data(atom/A as mob|obj|turf|area)
|
|
//I love associative lists.
|
|
var/list/data_entry = stored["\ref [A]"]
|
|
if(islist(data_entry)) //Yay, it was already stored!
|
|
//Merge the fingerprints.
|
|
var/list/data_prints = data_entry[1]
|
|
for(var/print in A.fingerprints)
|
|
var/merged_print = data_prints[print]
|
|
if(!merged_print)
|
|
data_prints[print] = A.fingerprints[print]
|
|
else
|
|
data_prints[print] = stringmerge(data_prints[print],A.fingerprints[print])
|
|
|
|
//Now the fibers
|
|
var/list/fibers = data_entry[2]
|
|
if(!fibers)
|
|
fibers = list()
|
|
if(A.suit_fibers && A.suit_fibers.len)
|
|
for(var/j = 1, j <= A.suit_fibers.len, j++) //Fibers~~~
|
|
if(!fibers.Find(A.suit_fibers[j])) //It isn't! Add!
|
|
fibers += A.suit_fibers[j]
|
|
var/list/blood = data_entry[3]
|
|
if(!blood)
|
|
blood = list()
|
|
if(A.blood_DNA && A.blood_DNA.len)
|
|
for(var/main_blood in A.blood_DNA)
|
|
if(!blood[main_blood])
|
|
blood[main_blood] = A.blood_DNA[blood]
|
|
return 1
|
|
var/list/sum_list[4] //Pack it back up!
|
|
sum_list[1] = A.fingerprints ? A.fingerprints.Copy() : null
|
|
sum_list[2] = A.suit_fibers ? A.suit_fibers.Copy() : null
|
|
sum_list[3] = A.blood_DNA ? A.blood_DNA.Copy() : null
|
|
sum_list[4] = "\The [A] in \the [get_area(A)]"
|
|
stored["\ref [A]"] = sum_list
|
|
return 0
|
|
/obj/item/device/detective_scanner/proc/add_log(var/mob/user, var/msg)
|
|
if(scanning)
|
|
if(user)
|
|
user << msg
|
|
log += "<span class='prefix'>[time2text(world.time + 432000, "hh:mm:ss")]</span>: [msg]"
|
|
else
|
|
CRASH("[src] \ref[src] is adding a log when it was never put in scanning mode!") |