mirror of
https://github.com/Bubberstation/Bubberstation.git
synced 2025-12-16 12:43:09 +00:00
* Improves proccall admin circuit component. Adds the option to not resolve weakrefs for set variables and proccall admin circuit components. (#64564) * Improves proccall admin circuit function * Improves proccall admin circuit component. Adds the option to not resolve weakrefs for set variables and proccall admin circuit components. Co-authored-by: Watermelon914 <37270891+Watermelon914@users.noreply.github.com>
44 lines
1.4 KiB
Plaintext
44 lines
1.4 KiB
Plaintext
/**
|
|
* # Set Variable Component
|
|
*
|
|
* A component that sets a variable on an object
|
|
*/
|
|
/obj/item/circuit_component/set_variable
|
|
display_name = "Set Variable"
|
|
desc = "A component that sets a variable on an object."
|
|
category = "Admin"
|
|
circuit_flags = CIRCUIT_FLAG_INPUT_SIGNAL|CIRCUIT_FLAG_OUTPUT_SIGNAL|CIRCUIT_FLAG_ADMIN
|
|
|
|
/// Whether to resolve weakrefs or not
|
|
var/datum/port/input/resolve_weakrefs
|
|
|
|
/// Entity to set variable of
|
|
var/datum/port/input/entity
|
|
|
|
/// Variable name
|
|
var/datum/port/input/variable_name
|
|
|
|
/// New value to set the variable name to.
|
|
var/datum/port/input/new_value
|
|
|
|
|
|
/obj/item/circuit_component/set_variable/populate_ports()
|
|
resolve_weakrefs = add_input_port("Resolve Weakrefs", PORT_TYPE_NUMBER, default = TRUE)
|
|
entity = add_input_port("Target", PORT_TYPE_DATUM)
|
|
variable_name = add_input_port("Variable Name", PORT_TYPE_STRING)
|
|
new_value = add_input_port("New Value", PORT_TYPE_ANY)
|
|
|
|
/obj/item/circuit_component/set_variable/input_received(datum/port/input/port)
|
|
var/atom/object = entity.value
|
|
var/var_name = variable_name.value
|
|
if(!var_name || !object)
|
|
return
|
|
|
|
var/resolved_new_value = new_value.value
|
|
if(islist(resolved_new_value) && resolve_weakrefs.value)
|
|
var/list/to_resolve = resolved_new_value
|
|
resolved_new_value = recursive_list_resolve(to_resolve)
|
|
|
|
log_admin_circuit("[parent.get_creator()] set the variable '[var_name]' on [object] to [resolved_new_value].")
|
|
object.vv_edit_var(var_name, resolved_new_value)
|