mirror of
https://github.com/Aurorastation/Aurora.3.git
synced 2025-12-25 01:22:13 +00:00
* cbt * AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA * fsadffsda sad * sadfasd * jhn * dsfa * saf * safsad * sda
252 lines
8.0 KiB
Plaintext
252 lines
8.0 KiB
Plaintext
/*
|
|
HOW IT WORKS
|
|
|
|
SSradio is a subsystem responsible for maintaining all radio transmissions, think about it as about "ether".
|
|
Note that walkie-talkie, intercoms and headsets handle transmission using nonstandard way.
|
|
procs:
|
|
|
|
add_object(obj/device as obj, var/new_frequency as num, var/filter as text|null = null)
|
|
Adds listening object.
|
|
parameters:
|
|
device - device receiving signals, must have proc receive_signal (see description below).
|
|
one device may listen several frequencies, but not same frequency twice.
|
|
new_frequency - see possibly frequencies below;
|
|
filter - thing for optimization. Optional, but recommended.
|
|
All filters should be consolidated in this file, see defines later.
|
|
Device without listening filter will receive all signals (on specified frequency).
|
|
Device with filter will receive any signals sent without filter.
|
|
Device with filter will not receive any signals sent with different filter.
|
|
returns:
|
|
Reference to frequency object.
|
|
|
|
remove_object (obj/device, old_frequency)
|
|
Obliviously, after calling this proc, device will not receive any signals on old_frequency.
|
|
Other frequencies will left unaffected.
|
|
|
|
return_frequency(var/frequency as num)
|
|
returns:
|
|
Reference to frequency object. Use it if you need to send and do not need to listen.
|
|
|
|
radio_frequency is a global object maintaining list of devices that listening specific frequency.
|
|
|
|
procs:
|
|
|
|
post_signal(obj/source as obj|null, datum/signal/signal, var/filter as text|null = null, var/range as num|null = null)
|
|
Sends signal to all devices that wants such signal.
|
|
parameters:
|
|
source - object, emitted signal. Usually, devices will not receive their own signals.
|
|
signal - see description below.
|
|
filter - described above.
|
|
range - radius of regular byond's square circle on that z-level. null means everywhere, on all z-levels.
|
|
|
|
obj/proc/receive_signal(datum/signal/signal, var/receive_method as num, var/receive_param)
|
|
Handler from received signals. By default does nothing. Define your own for your object.
|
|
Avoid of sending signals directly from this proc, use spawn(-1). DO NOT use sleep() here or call procs that sleep please. If you must, use spawn()
|
|
parameters:
|
|
signal - see description below. Extract all needed data from the signal before doing sleep(), spawn() or return!
|
|
receive_method - may be TRANSMISSION_WIRE or TRANSMISSION_RADIO.
|
|
TRANSMISSION_WIRE is currently unused.
|
|
receive_param - for TRANSMISSION_RADIO here comes frequency.
|
|
|
|
datum/signal
|
|
vars:
|
|
source
|
|
an object that emitted signal. Used for debug and bearing.
|
|
data
|
|
list with transmitting data. Usual use pattern:
|
|
data["msg"] = "hello world"
|
|
encryption
|
|
Some number symbolizing "encryption key".
|
|
Note that game actually do not use any cryptography here.
|
|
If receiving object don't know right key, it must ignore encrypted signal in its receive_signal.
|
|
|
|
*/
|
|
|
|
/*
|
|
Frequency range: 1200 to 1600
|
|
Radiochat range: 1441 to 1489 (most devices refuse to be tune to other frequency, even during mapmaking)
|
|
|
|
Radio:
|
|
1459 - standard radio chat
|
|
1351 - Science
|
|
1353 - Command
|
|
1355 - Medical
|
|
1357 - Engineering
|
|
1359 - Security
|
|
1341 - deathsquad
|
|
1443 - Confession Intercom
|
|
1347 - Cargo techs
|
|
1349 - Service people
|
|
|
|
Devices:
|
|
1451 - tracking implant
|
|
1457 - RSD default
|
|
|
|
On the map:
|
|
1311 for prison shuttle console (in fact, it is not used)
|
|
1435 for status displays
|
|
1437 for atmospherics/fire alerts
|
|
1438 for engine components
|
|
1439 for air pumps, air scrubbers, atmo control
|
|
1441 for atmospherics - supply tanks
|
|
1443 for atmospherics - distribution loop/mixed air tank
|
|
1445 for bot nav beacons
|
|
1449 for airlock controls, electropack, magnets
|
|
1451 for toxin lab access
|
|
1453 for engineering access
|
|
1455 for AI access
|
|
*/
|
|
|
|
SUBSYSTEM_DEF(radio)
|
|
name = "Radio"
|
|
flags = SS_NO_FIRE | SS_NO_INIT
|
|
|
|
var/list/datum/radio_frequency/frequencies = list()
|
|
|
|
/datum/controller/subsystem/radio/stat_entry(msg)
|
|
msg = "F:[frequencies.len]"
|
|
return ..()
|
|
|
|
/datum/controller/subsystem/radio/proc/add_object(obj/device, new_frequency, filter = null)
|
|
var/f_text = num2text(new_frequency)
|
|
var/datum/radio_frequency/frequency = frequencies[f_text]
|
|
|
|
if(!frequency)
|
|
frequency = new
|
|
frequency.frequency = new_frequency
|
|
frequencies[f_text] = frequency
|
|
|
|
frequency.add_listener(device, filter)
|
|
return frequency
|
|
|
|
/datum/controller/subsystem/radio/proc/remove_object(obj/device, old_frequency)
|
|
var/f_text = num2text(old_frequency)
|
|
var/datum/radio_frequency/frequency = frequencies[f_text]
|
|
|
|
if(frequency)
|
|
frequency.remove_listener(device)
|
|
|
|
/datum/controller/subsystem/radio/proc/remove_object_all(obj/device)
|
|
for(var/freq in frequencies)
|
|
SSradio.remove_object(device, text2num(freq))
|
|
|
|
/datum/controller/subsystem/radio/proc/get_devices(freq, filter = RADIO_DEFAULT)
|
|
var/datum/radio_frequency/frequency = frequencies[num2text(freq)]
|
|
if(!frequency)
|
|
return
|
|
|
|
return frequency.devices["[filter]"]
|
|
|
|
/datum/controller/subsystem/radio/proc/return_frequency(new_frequency)
|
|
var/f_text = num2text(new_frequency)
|
|
var/datum/radio_frequency/frequency = frequencies[f_text]
|
|
|
|
if(!frequency)
|
|
frequency = new
|
|
frequency.frequency = new_frequency
|
|
frequencies[f_text] = frequency
|
|
|
|
return frequency
|
|
|
|
// Used to test connectivity to the telecomms network.
|
|
/datum/controller/subsystem/radio/proc/telecomms_ping(obj/O, test_freq = PUB_FREQ)
|
|
var/datum/signal/subspace/testsig = new(O, test_freq)
|
|
for (var/obj/machinery/telecomms/R in SSmachinery.all_receivers)
|
|
if(R.receive_range(testsig) >= 0)
|
|
return TRUE
|
|
|
|
// Some misc procs not technically part of the subsystem, but are related.
|
|
|
|
//callback used by objects to react to incoming radio signals
|
|
/obj/proc/receive_signal(datum/signal/signal, receive_method, receive_param)
|
|
return null
|
|
|
|
/proc/frequency_span_class(var/frequency)
|
|
var/fstr = "[frequency]"
|
|
// Antags!
|
|
if (ANTAG_FREQS_ASSOC[fstr])
|
|
return "syndradio"
|
|
|
|
// centcomm channels (deathsquid and ert)
|
|
if(CENT_FREQS_ASSOC[fstr])
|
|
return "centradio"
|
|
|
|
// department radio formatting
|
|
switch (frequency)
|
|
if (COMM_FREQ) // command
|
|
return "comradio"
|
|
if (AI_FREQ) // AI Private
|
|
return "airadio"
|
|
if (SEC_FREQ,SEC_I_FREQ)
|
|
return "secradio"
|
|
if (PEN_FREQ)
|
|
return "penradio"
|
|
if (ENG_FREQ)
|
|
return "engradio"
|
|
if (SCI_FREQ)
|
|
return "sciradio"
|
|
if (MED_FREQ,MED_I_FREQ)
|
|
return"medradio"
|
|
if (SUP_FREQ) // cargo
|
|
return "supradio"
|
|
if (SRV_FREQ) // service
|
|
return "srvradio"
|
|
if (ENT_FREQ) //entertainment
|
|
return "entradio"
|
|
if (BLSP_FREQ)
|
|
return "bluespaceradio"
|
|
if (HAIL_FREQ)
|
|
return "hailradio"
|
|
|
|
if(DEPT_FREQS_ASSOC[fstr])
|
|
return "deptradio"
|
|
|
|
for(var/channel in AWAY_FREQS_ASSIGNED)
|
|
if(AWAY_FREQS_ASSIGNED[channel] == frequency)
|
|
return "shipradio"
|
|
|
|
return "radio"
|
|
|
|
/proc/update_away_freq(old_channel, new_channel)
|
|
if(!old_channel || !new_channel || !(old_channel in AWAY_FREQS_ASSIGNED))
|
|
return FALSE
|
|
|
|
var/freq = AWAY_FREQS_ASSIGNED[old_channel]
|
|
var/datum/radio_frequency/RF = SSradio.return_frequency(freq)
|
|
|
|
if(old_channel == new_channel)
|
|
return istype(RF) ? RF : assign_away_freq(new_channel)
|
|
|
|
LAZYREPLACEKEY(AWAY_FREQS_ASSIGNED, old_channel, new_channel)
|
|
LAZYREPLACEKEY(radiochannels, old_channel, new_channel)
|
|
LAZYREPLACEKEY(ALL_RADIO_CHANNELS, old_channel, new_channel)
|
|
reverseradiochannels["[freq]"] = new_channel
|
|
|
|
for(var/obj/item/device/radio/R in RF.devices[RADIO_CHAT])
|
|
var/obj/item/device/radio/headset/H = R
|
|
if(istype(H))
|
|
for(var/obj/item/device/encryptionkey/EK in list(H.keyslot1, H.keyslot2))
|
|
if(old_channel in EK.channels)
|
|
LAZYREPLACEKEY(EK.channels, old_channel, new_channel)
|
|
|
|
H.recalculateChannels(TRUE)
|
|
|
|
else if(old_channel in R.channels)
|
|
LAZYREPLACEKEY(R.channels, old_channel, new_channel)
|
|
LAZYREPLACEKEY(R.secure_radio_connections, old_channel, new_channel)
|
|
|
|
/proc/assign_away_freq(channel)
|
|
if (!AWAY_FREQS_UNASSIGNED.len)
|
|
return FALSE
|
|
|
|
if (channel in AWAY_FREQS_ASSIGNED)
|
|
return AWAY_FREQS_ASSIGNED[channel]
|
|
|
|
var/freq = pick_n_take(AWAY_FREQS_UNASSIGNED)
|
|
AWAY_FREQS_ASSIGNED[channel] = freq
|
|
radiochannels[channel] = freq
|
|
reverseradiochannels["[freq]"] = channel
|
|
ALL_RADIO_CHANNELS[channel] = TRUE
|
|
|
|
return freq
|