Skip to content

Commit

Permalink
Revert "more"
Browse files Browse the repository at this point in the history
This reverts commit 8707bfe.
  • Loading branch information
bobbah committed Jul 20, 2020
1 parent 8707bfe commit c2af9e7
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 20 deletions.
1 change: 0 additions & 1 deletion code/__DEFINES/subsystems.dm
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 +169,6 @@
#define FIRE_PRIORITY_CHAT 400
#define FIRE_PRIORITY_OVERLAYS 500
#define FIRE_PRIORITY_EXPLOSIONS 666
#define FIRE_PRIORITY_TIMER 700
#define FIRE_PRIORITY_INPUT 1000 // This must always always be the max highest priority. Player input must never be lost.

// SS runlevels
Expand Down
48 changes: 29 additions & 19 deletions code/controllers/subsystem/timer.dm
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@ SUBSYSTEM_DEF(timer)
name = "Timer"
wait = 1 //SS_TICKER subsystem, so wait is in ticks
init_order = INIT_ORDER_TIMER
priority = FIRE_PRIORITY_TIMER

flags = SS_TICKER|SS_NO_INIT

Expand Down Expand Up @@ -40,7 +39,7 @@ SUBSYSTEM_DEF(timer)
bucket_resolution = world.tick_lag

/datum/controller/subsystem/timer/stat_entry(msg)
..("B:[bucket_count] P:[second_queue.len] H:[hashes.len] C:[clienttime_timers.len] S:[timer_id_dict.len]")
..("B:[bucket_count] P:[length(second_queue)] H:[length(hashes)] C:[length(clienttime_timers)] S:[length(timer_id_dict)]")

/datum/controller/subsystem/timer/fire(resumed = FALSE)
var/lit = last_invoke_tick
Expand All @@ -59,7 +58,7 @@ SUBSYSTEM_DEF(timer)
bucket_resolution = 0

log_world("Timer bucket reset. world.time: [world.time], head_offset: [head_offset], practical_offset: [practical_offset]")
for (var/i in 1 to bucket_list.len)
for (var/i in 1 to length(bucket_list))
var/datum/timedevent/bucket_head = bucket_list[i]
if (!bucket_head)
continue
Expand All @@ -78,7 +77,9 @@ SUBSYSTEM_DEF(timer)
log_world(get_timer_debug_string(I))

var/next_clienttime_timer_index = 0
for (next_clienttime_timer_index in 1 to clienttime_timers.len)
var/len = length(clienttime_timers)

for (next_clienttime_timer_index in 1 to len)
if (MC_TICK_CHECK)
next_clienttime_timer_index--
break
Expand All @@ -89,7 +90,7 @@ SUBSYSTEM_DEF(timer)

var/datum/callback/callBack = ctime_timer.callBack
if (!callBack)
clienttime_timers.Cut(next_clienttime_timer_index, next_clienttime_timer_index + 1)
clienttime_timers.Cut(next_clienttime_timer_index,next_clienttime_timer_index+1)
CRASH("Invalid timer: [get_timer_debug_string(ctime_timer)] world.time: [world.time], head_offset: [head_offset], practical_offset: [practical_offset], REALTIMEOFDAY: [REALTIMEOFDAY]")

ctime_timer.spent = REALTIMEOFDAY
Expand All @@ -104,7 +105,7 @@ SUBSYSTEM_DEF(timer)


if (next_clienttime_timer_index)
clienttime_timers.Cut(1, next_clienttime_timer_index + 1)
clienttime_timers.Cut(1, next_clienttime_timer_index+1)

if (MC_TICK_CHECK)
return
Expand All @@ -116,7 +117,7 @@ SUBSYSTEM_DEF(timer)
practical_offset = 1
resumed = FALSE

if ((bucket_list.len != BUCKET_LEN) || (world.tick_lag != bucket_resolution))
if ((length(bucket_list) != BUCKET_LEN) || (world.tick_lag != bucket_resolution))
reset_buckets()
bucket_list = src.bucket_list
resumed = FALSE
Expand Down Expand Up @@ -154,7 +155,8 @@ SUBSYSTEM_DEF(timer)

//we freed up a bucket, lets see if anything in second_queue needs to be shifted to that bucket.
var/i = 0
for (i in 1 to second_queue.len)
var/L = length(second_queue)
for (i in 1 to L)
timer = second_queue[i]
if (timer.timeToRun >= TIMER_MAX)
i--
Expand Down Expand Up @@ -200,13 +202,14 @@ SUBSYSTEM_DEF(timer)
timer.next.prev = timer
timer.prev.next = timer
if (i)
second_queue.Cut(1, i + 1)
second_queue.Cut(1, i+1)

timer = null

bucket_count -= spent.len
bucket_count -= length(spent)

for (var/datum/timedevent/qtimer in spent)
for (var/i in spent)
var/datum/timedevent/qtimer = i
if(QDELETED(qtimer))
bucket_count++
continue
Expand All @@ -216,7 +219,10 @@ SUBSYSTEM_DEF(timer)
bucket_count++
qtimer.spent = 0
qtimer.bucketEject()
qtimer.timeToRun = qtimer.flags & TIMER_CLIENT_TIME ? REALTIMEOFDAY + qtimer.wait : world.time + qtimer.wait
if(qtimer.flags & TIMER_CLIENT_TIME)
qtimer.timeToRun = REALTIMEOFDAY + qtimer.wait
else
qtimer.timeToRun = world.time + qtimer.wait
qtimer.bucketJoin()

spent.len = 0
Expand Down Expand Up @@ -254,7 +260,7 @@ SUBSYSTEM_DEF(timer)
bucket_resolution = world.tick_lag

alltimers += second_queue
if (!alltimers.len)
if (!length(alltimers))
return

sortTim(alltimers, .proc/cmp_timer)
Expand All @@ -266,7 +272,7 @@ SUBSYSTEM_DEF(timer)

var/new_bucket_count
var/i = 1
for (i in 1 to alltimers.len)
for (i in 1 to length(alltimers))
var/datum/timedevent/timer = alltimers[i]
if (!timer)
continue
Expand Down Expand Up @@ -401,9 +407,9 @@ SUBSYSTEM_DEF(timer)
else if(timeToRun < TIMER_MAX || next || prev)
SStimer.bucket_count--
else
var/l = second_queue.len
var/l = length(second_queue)
second_queue -= src
if(l == second_queue.len)
if(l == length(second_queue))
SStimer.bucket_count--
if(prev != next)
prev.next = next
Expand All @@ -415,6 +421,7 @@ SUBSYSTEM_DEF(timer)

/datum/timedevent/proc/bucketJoin()
var/list/L

if (flags & TIMER_CLIENT_TIME)
L = SStimer.clienttime_timers
else if (timeToRun >= TIMER_MAX)
Expand Down Expand Up @@ -477,10 +484,13 @@ SUBSYSTEM_DEF(timer)
CRASH("Attempted to create timer with INFINITY delay")

var/hash

if (flags & TIMER_UNIQUE)
var/list/hashlist = list(callback.object, "([REF(callback.object)])", callback.delegate, flags & TIMER_CLIENT_TIME)
if (!(flags & TIMER_NO_HASH_WAIT))
hashlist += wait
var/list/hashlist
if(flags & TIMER_NO_HASH_WAIT)
hashlist = list(callback.object, "([REF(callback.object)])", callback.delegate, flags & TIMER_CLIENT_TIME)
else
hashlist = list(callback.object, "([REF(callback.object)])", callback.delegate, wait, flags & TIMER_CLIENT_TIME)
hashlist += callback.arguments
hash = hashlist.Join("|||||||")

Expand Down

0 comments on commit c2af9e7

Please sign in to comment.