Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Small Optimizations #3905

Merged
merged 8 commits into from
Dec 29, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion code/__HELPERS/AStar.dm
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ Actual Adjacent procs :
if(!start || !end)
stack_trace("Invalid A* start or destination")
return FALSE
if(start.virtual_z() != end.virtual_z() || start == end) //no pathfinding between z levels
if(start.virtual_z != end.virtual_z || start == end) //no pathfinding between z levels
return FALSE
if(maxnodes)
//if start turf is farther than maxnodes from end turf, no need to do anything
Expand Down
2 changes: 1 addition & 1 deletion code/_onclick/hud/radial.dm
Original file line number Diff line number Diff line change
Expand Up @@ -357,6 +357,6 @@ GLOBAL_LIST_EMPTY(radial_menus)
/// If provided, will display an info button that will put this text in your chat
var/info

/datum/radial_menu_choice/Destroy(force, ...)
/datum/radial_menu_choice/Destroy(force)
. = ..()
QDEL_NULL(image)
58 changes: 25 additions & 33 deletions code/controllers/subsystem/jukeboxes.dm
Original file line number Diff line number Diff line change
Expand Up @@ -35,9 +35,7 @@ SUBSYSTEM_DEF(jukeboxes)
var/sound/song_to_init = sound(T.song_path)
song_to_init.status = SOUND_MUTE
for(var/mob/M in GLOB.player_list)
if(!M.client)
continue
if(!(M.client.prefs.toggles & SOUND_INSTRUMENTS))
if(!(M?.client.prefs.toggles & SOUND_INSTRUMENTS))
continue

M.playsound_local(M, null, 100, channel = youvegotafreejukebox[2], S = song_to_init)
Expand Down Expand Up @@ -88,9 +86,7 @@ SUBSYSTEM_DEF(jukeboxes)
return ..()

/datum/controller/subsystem/jukeboxes/fire()
if(!activejukeboxes.len)
return
for(var/list/jukeinfo in activejukeboxes)
for(var/list/jukeinfo as anything in activejukeboxes)
if(!jukeinfo.len)
stack_trace("Active jukebox without any associated metadata.")
continue
Expand All @@ -103,42 +99,38 @@ SUBSYSTEM_DEF(jukeboxes)
stack_trace("Nonexistant or invalid object associated with jukebox.")
continue
var/sound/song_played = sound(juketrack.song_path)
var/area/currentarea = get_area(jukebox)
var/turf/currentturf = get_turf(jukebox)
var/list/hearerscache = hearers(7, jukebox)
var/turf/above_turf = currentturf.above()
var/turf/below_turf = currentturf.below()
var/list/hearerscache = get_hearers_in_view(7, jukebox)

var/datum/virtual_level/zone = currentturf.get_virtual_level()
var/turf/above_turf = zone.get_above_turf(currentturf)
var/turf/below_turf = zone.get_below_turf(currentturf)

var/list/virtual_ids = list(zone.id)
var/list/areas = list(get_area(jukebox))
if(above_turf && istransparentturf(above_turf))
virtual_ids += above_turf.virtual_z
areas += get_area(above_turf)
if(below_turf && istransparentturf(below_turf))
virtual_ids += below_turf.virtual_z
areas += get_area(below_turf)

song_played.falloff = jukeinfo[4]

for(var/mob/M in GLOB.player_list)
if(!M.client)
continue
if(!(M.client.prefs.toggles & SOUND_INSTRUMENTS) || !M.can_hear())
for(var/mob/M as anything in GLOB.player_list)
if(!(M.client?.prefs.toggles & SOUND_INSTRUMENTS) || !M.can_hear())
M.stop_sound_channel(jukeinfo[2])
continue

var/inrange = FALSE
if(jukebox.z == M.z) //todo - expand this to work with mining planet z-levels when robust jukebox audio gets merged to master
song_played.status = SOUND_UPDATE
if(get_area(M) == currentarea)
inrange = TRUE
else if(M in hearerscache)
inrange = TRUE
else if(above_turf?.z == M.z)
song_played.status = SOUND_UPDATE
if(istransparentturf(above_turf) && (get_area(M) == get_area(above_turf)))
inrange = TRUE
else if(below_turf?.z == M.z)
if(jukebox.volume <= 0 || !(M.virtual_z() in virtual_ids))
song_played.status = SOUND_MUTE | SOUND_UPDATE
else
song_played.status = SOUND_UPDATE
if(istransparentturf(below_turf) && (get_area(M) == get_area(below_turf)))
if((get_area(M) in areas) || (M in hearerscache))
inrange = TRUE
else
song_played.status = SOUND_MUTE | SOUND_UPDATE //Setting volume = 0 doesn't let the sound properties update at all, which is lame.

if(jukebox.volume <= 0)
song_played.status = SOUND_MUTE

M.playsound_local(currentturf, null, jukebox.volume, channel = jukeinfo[2], S = song_played, envwet = (inrange ? -250 : 0), envdry = (inrange ? 0 : -10000))
CHECK_TICK
return

if(MC_TICK_CHECK)
return
2 changes: 1 addition & 1 deletion code/controllers/subsystem/overmap.dm
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ SUBSYSTEM_DEF(overmap)
name = "Overmap"
wait = 10
init_order = INIT_ORDER_OVERMAP
flags = SS_KEEP_TIMING|SS_NO_TICK_CHECK
flags = SS_KEEP_TIMING
runlevels = RUNLEVEL_SETUP | RUNLEVEL_GAME

///Defines which generator to use for the overmap
Expand Down
2 changes: 1 addition & 1 deletion code/controllers/subsystem/statpanel.dm
Original file line number Diff line number Diff line change
Expand Up @@ -298,7 +298,7 @@ SUBSYSTEM_DEF(statpanels)
. = ..()
src.parent = parent

/datum/object_window_info/Destroy(force, ...)
/datum/object_window_info/Destroy(force)
atoms_to_show = null
atoms_to_images = null
atoms_to_imagify = null
Expand Down
2 changes: 1 addition & 1 deletion code/datums/ai_laws.dm
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
var/mob/living/silicon/owner
var/id = DEFAULT_AI_LAWID

/datum/ai_laws/Destroy(force, ...)
/datum/ai_laws/Destroy(force)
if(!QDELETED(owner))
CRASH("AI lawset destroyed even though owner AI is not being destroyed.")
owner = null
Expand Down
8 changes: 3 additions & 5 deletions code/datums/components/_component.dm
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@
var/list/arguments = raw_args.Copy(2)
if(Initialize(arglist(arguments)) == COMPONENT_INCOMPATIBLE)
stack_trace("Incompatible [type] assigned to a [parent.type]! args: [json_encode(arguments)]")
qdel(src, TRUE, TRUE)
qdel(src, TRUE)
return

_JoinParent(parent)
Expand All @@ -69,15 +69,13 @@
*
* Arguments:
* * force - makes it not check for and remove the component from the parent
* * silent - deletes the component without sending a [COMSIG_COMPONENT_REMOVING] signal
*/
/datum/component/Destroy(force=FALSE, silent=FALSE)
/datum/component/Destroy(force=FALSE)
if(!parent)
return ..()
if(!force)
_RemoveFromParent()
if(!silent)
SEND_SIGNAL(parent, COMSIG_COMPONENT_REMOVING, src)
SEND_SIGNAL(parent, COMSIG_COMPONENT_REMOVING, src)
parent = null
return ..()

Expand Down
10 changes: 7 additions & 3 deletions code/datums/components/remote_materials.dm
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ handles linking back and forth.
src.category = category
src.allow_standalone = allow_standalone

RegisterSignal(parent, COMSIG_OBJ_DECONSTRUCT, PROC_REF(OnDeconstruct))
RegisterSignal(parent, COMSIG_PARENT_ATTACKBY, PROC_REF(OnAttackBy))
RegisterSignal(parent, COMSIG_ATOM_MULTITOOL_ACT, PROC_REF(OnMultitool))

Expand All @@ -35,12 +36,15 @@ handles linking back and forth.
silo.updateUsrDialog()
silo = null
mat_container = null
else if (mat_container)
mat_container = null
return ..()

/datum/component/remote_materials/proc/OnDeconstruct(disassembled)
SIGNAL_HANDLER
if(!silo && mat_container)
// specify explicitly in case the other component is deleted first
var/atom/P = parent
mat_container.retrieve_all(P.drop_location())
mat_container = null
return ..()

/datum/component/remote_materials/proc/_MakeLocal()
silo = null
Expand Down
3 changes: 2 additions & 1 deletion code/datums/components/weatherannouncer.dm
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,8 @@
light.set_light_color(LIGHT_COLOR_YELLOW)
if(WEATHER_ALERT_IMMINENT_OR_ACTIVE)
light.set_light_color(LIGHT_COLOR_INTENSE_RED)
light.update_light()
if(light.light_system == STATIC_LIGHT)
light.update_light()

/// Returns a string we should display to communicate what you should be doing
/datum/component/weather_announcer/proc/get_warning_message()
Expand Down
6 changes: 3 additions & 3 deletions code/datums/datum.dm
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@
*
* Returns [QDEL_HINT_QUEUE]
*/
/datum/proc/Destroy(force=FALSE, ...)
/datum/proc/Destroy(force)
SHOULD_CALL_PARENT(TRUE)
tag = null
datum_flags &= ~DF_USE_TAG //In case something tries to REF us
Expand All @@ -111,10 +111,10 @@
var/all_components = dc[/datum/component]
if(length(all_components))
for(var/datum/component/component as anything in all_components)
qdel(component, FALSE, TRUE)
qdel(component, FALSE)
else
var/datum/component/C = all_components
qdel(C, FALSE, TRUE)
qdel(C, FALSE)
dc.Cut()

clear_signal_refs()
Expand Down
19 changes: 19 additions & 0 deletions code/datums/map_zones.dm
Original file line number Diff line number Diff line change
Expand Up @@ -562,6 +562,25 @@
var/abs_y = Turf.y - low_y
return locate(up_linkage.low_x + abs_x, up_linkage.low_y + abs_y, up_linkage.z_value)

/datum/virtual_level/proc/get_zone_step(turf/source, direction)
// multiz dir is just the up/down dir flags
var/multiz_dir = direction & (UP|DOWN)
// while the passed dir is normalized to just the cardinals
direction &= ~(UP|DOWN)
var/turf/my_turf = get_step(source, direction)
if(isnull(my_turf))
return
switch(multiz_dir)
// the old version of this code prioritized UP over DOWN when
// both were passed. i don't want to fuck with that, so here it is preserved
if(UP|DOWN)
return get_above_turf(my_turf)
if(UP)
return get_above_turf(my_turf)
if(DOWN)
return get_below_turf(my_turf)
return my_turf

/datum/virtual_level/proc/get_client_mobs()
return get_alive_client_mobs() + get_dead_client_mobs()

Expand Down
5 changes: 1 addition & 4 deletions code/game/machinery/cloning.dm
Original file line number Diff line number Diff line change
Expand Up @@ -64,12 +64,9 @@
begin_processing()

/obj/machinery/clonepod/Destroy()
var/mob/living/mob_occupant = occupant
go_out()
if(mob_occupant)
log_cloning("[key_name(mob_occupant)] ejected from [src] at [AREACOORD(src)] due to Destroy().")
QDEL_NULL(radio)
QDEL_NULL(countdown)
QDEL_NULL(occupant)
if(connected)
connected.DetachCloner(src)
QDEL_LIST(unattached_flesh)
Expand Down
4 changes: 2 additions & 2 deletions code/game/machinery/doors/firedoor.dm
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@
/obj/machinery/door/firedoor/Destroy()
remove_from_areas()
density = FALSE
air_update_turf(1)
air_update_turf(TRUE)
affecting_areas.Cut()
return ..()

Expand Down Expand Up @@ -430,7 +430,7 @@
if(operating || welded)
return
density = TRUE
air_update_turf(1)
air_update_turf(TRUE)
do_animate("closing")
update_freelook_sight()
if(!(flags_1 & ON_BORDER_1))
Expand Down
5 changes: 4 additions & 1 deletion code/game/machinery/gulag_item_reclaimer.dm
Original file line number Diff line number Diff line change
Expand Up @@ -12,10 +12,13 @@
var/list/stored_items = list()
var/obj/machinery/gulag_teleporter/linked_teleporter = null

/obj/machinery/gulag_item_reclaimer/Destroy()
/obj/machinery/gulag_item_reclaimer/deconstruct(disassembled)
for(var/i in contents)
var/obj/item/I = i
I.forceMove(get_turf(src))
return ..()

/obj/machinery/gulag_item_reclaimer/Destroy()
if(linked_teleporter)
linked_teleporter.linked_reclaimer = null
return ..()
Expand Down
2 changes: 1 addition & 1 deletion code/game/machinery/slotmachine.dm
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@
var/obj/item/coin/C = cointype
coinvalues["[cointype]"] = initial(C.value)

/obj/machinery/computer/slot_machine/Destroy()
/obj/machinery/computer/slot_machine/deconstruct(disassembled, mob/user)
if(balance)
give_payout(balance)
return ..()
Expand Down
2 changes: 1 addition & 1 deletion code/game/objects/effects/effect_system/effects_smoke.dm
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@
if(!t_loc)
return
var/list/newsmokes = list()
for(var/turf/T in t_loc.GetAtmosAdjacentTurfs())
for(var/turf/T in t_loc.get_atmos_adjacent_turfs())
var/obj/effect/particle_effect/smoke/foundsmoke = locate() in T //Don't spread smoke where there's already smoke!
if(foundsmoke)
continue
Expand Down
33 changes: 17 additions & 16 deletions code/game/objects/effects/turf_fire.dm
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,18 @@
color = fire_color
base_icon_state = "greyscale"

switch(base_icon_state) //switches light color depdning on the flame color
if("greyscale")
light_color = hex_color
if("red")
light_color = LIGHT_COLOR_FIRE
if("blue")
light_color = LIGHT_COLOR_CYAN
if("green")
light_color = LIGHT_COLOR_GREEN
else
light_color = COLOR_VERY_LIGHT_GRAY

open_turf.turf_fire = src
START_PROCESSING(SSturf_fire, src)
if(power)
Expand Down Expand Up @@ -187,29 +199,18 @@
return
current_fire_state = new_state

switch(base_icon_state) //switches light color depdning on the flame color
if("greyscale")
light_color = hex_color
if("red")
light_color = LIGHT_COLOR_FIRE
if("blue")
light_color = LIGHT_COLOR_CYAN
if("green")
light_color = LIGHT_COLOR_GREEN
else
light_color = COLOR_VERY_LIGHT_GRAY
update_light()

switch(current_fire_state)
if(TURF_FIRE_STATE_SMALL)
icon_state = "[base_icon_state]_small"
set_light_range(1.5)
light_range = 1.5
if(TURF_FIRE_STATE_MEDIUM)
icon_state = "[base_icon_state]_medium"
set_light_range(2.5)
light_range = 2
if(TURF_FIRE_STATE_LARGE)
icon_state = "[base_icon_state]_big"
set_light_range(3)
light_range = 3

update_light()

#undef TURF_FIRE_REQUIRED_TEMP
#undef TURF_FIRE_TEMP_BASE
Expand Down
Loading
Loading