From fb5a9d5d9e1d62b93847e3f0863480619461e2ea Mon Sep 17 00:00:00 2001 From: Mikayla Fischler Date: Tue, 5 Mar 2024 17:16:35 -0500 Subject: [PATCH] #432 fixes and enhancements to coordinator waiting on chunk loads --- coordinator/startup.lua | 27 ++++++++++++++++++--------- 1 file changed, 18 insertions(+), 9 deletions(-) diff --git a/coordinator/startup.lua b/coordinator/startup.lua index 268bec3..70dc511 100644 --- a/coordinator/startup.lua +++ b/coordinator/startup.lua @@ -22,9 +22,9 @@ local sounder = require("coordinator.sounder") local apisessions = require("coordinator.session.apisessions") -local COORDINATOR_VERSION = "v1.2.7" +local COORDINATOR_VERSION = "v1.2.8" -local CHUNK_LOAD_DELAY_S = 20.0 +local CHUNK_LOAD_DELAY_S = 30.0 local println = util.println local println_ts = util.println_ts @@ -42,24 +42,33 @@ local log_crypto = coordinator.log_crypto -- mount connected devices (required for monitor setup) ppm.mount_all() +local wait_on_load = true local loaded, monitors = coordinator.load_config() -- if the computer just started, its chunk may have just loaded (...or the user rebooted) -- if monitor config failed, maybe an adjacent chunk containing all or part of a monitor has not loaded yet, so keep trying -while loaded == 2 and os.clock() < CHUNK_LOAD_DELAY_S do +while wait_on_load and loaded == 2 and os.clock() < CHUNK_LOAD_DELAY_S do term.clear() term.setCursorPos(1, 1) println("There was a monitor configuration problem at boot.\n") println("Startup will keep trying every 2s in case of chunk load delays.\n") println(util.sprintf("The configurator will be started in %ds if all attempts fail.\n", math.max(0, CHUNK_LOAD_DELAY_S - os.clock()))) - println("(exit early with ctrl-t)") + println("(click to skip to the configurator)") ----@diagnostic disable-next-line: undefined-field - os.sleep(2) + local timer_id = util.start_timer(2) - -- remount and re-attempt - ppm.mount_all() - loaded, monitors = coordinator.load_config() + while true do + local event, param1 = util.pull_event() + if event == "timer" and param1 == timer_id then + -- remount and re-attempt + ppm.mount_all() + loaded, monitors = coordinator.load_config() + break + elseif event == "mouse_click" or event == "terminate" then + wait_on_load = false + break + end + end end if loaded ~= 0 then