Files
vgstation13/code/ATMOSPHERICS/components/unary/heat_exchanger.dm

62 lines
1.8 KiB
Plaintext

/obj/machinery/atmospherics/unary/heat_exchanger
icon = 'icons/obj/atmospherics/heat_exchanger.dmi'
icon_state = "intact"
density = 1
name = "Heat Exchanger"
desc = "Exchanges heat between two input gases. Setup for fast heat transfer"
var/obj/machinery/atmospherics/unary/heat_exchanger/partner = null
var/update_cycle
/obj/machinery/atmospherics/unary/heat_exchanger/update_icon()
if(node)
icon_state = "intact"
else
icon_state = "exposed"
return
/obj/machinery/atmospherics/unary/heat_exchanger/initialize()
if(!partner)
var/partner_connect = turn(dir,180)
for(var/obj/machinery/atmospherics/unary/heat_exchanger/target in get_step(src,partner_connect))
if(target.dir & get_dir(src,target))
partner = target
partner.partner = src
break
..()
/obj/machinery/atmospherics/unary/heat_exchanger/process()
. = ..()
if(!partner || !air_master || air_master.current_cycle <= update_cycle)
return
var/old_temperature = partner.air_contents.temperature
var/other_old_temperature = air_contents.temperature
update_cycle = air_master.current_cycle
partner.update_cycle = air_master.current_cycle
var/combined_heat_capacity = partner.air_contents.heat_capacity + air_contents.heat_capacity
if(combined_heat_capacity > 0)
var/combined_energy = partner.air_contents.thermal_energy() + air_contents.thermal_energy()
var/new_temperature = combined_energy/combined_heat_capacity
air_contents.set_temperature(new_temperature)
partner.air_contents.set_temperature(new_temperature)
if(network)
if(abs(old_temperature-air_contents.temperature) > 1)
network.update = 1
if(partner.network)
if(abs(other_old_temperature-partner.air_contents.temperature) > 1)
partner.network.update = 1
return 1