/obj/proc/analyze_gases(var/obj/A, var/mob/user) if(src != A) user.visible_message("\The [user] has used \an [src] on \the [A]") A.add_fingerprint(user) var/list/result = A.atmosanalyze(user) if(result && result.len) user << "Results of the analysis[src == A ? "" : " of \the [A]"]" for(var/line in result) user << "[line]" return 1 user << "Your [src] flashes a red light as it fails to analyze \the [A]." return 0 /proc/atmosanalyzer_scan(var/obj/target, var/datum/gas_mixture/mixture, var/mob/user) var/pressure = mixture.return_pressure() var/total_moles = mixture.total_moles var/list/results = list() if (total_moles>0) results += "Pressure: [round(pressure,0.1)] kPa" for(var/mix in mixture.gas) results += "[gas_data.name[mix]]: [round((mixture.gas[mix] / total_moles) * 100)]%" results += "Temperature: [round(mixture.temperature-T0C)]°C" else results += "\The [target] is empty!" return results /obj/proc/atmosanalyze(var/mob/user) return /obj/item/weapon/tank/atmosanalyze(var/mob/user) return atmosanalyzer_scan(src, src.air_contents, user) /obj/machinery/portable_atmospherics/atmosanalyze(var/mob/user) return atmosanalyzer_scan(src, src.air_contents, user) /obj/machinery/atmospherics/pipe/atmosanalyze(var/mob/user) return atmosanalyzer_scan(src, src.parent.air, user) /obj/machinery/power/rad_collector/atmosanalyze(var/mob/user) if(P) return atmosanalyzer_scan(src, src.P.air_contents, user) /obj/item/weapon/flamethrower/atmosanalyze(var/mob/user) if(ptank) return atmosanalyzer_scan(src, ptank.air_contents, user)