From 06a98fd971912763b8bb575864c26314890b5059 Mon Sep 17 00:00:00 2001 From: Aram Drevekenin Date: Wed, 9 Oct 2024 08:08:29 +0200 Subject: [PATCH] fix(plugins): handle race when setting plugin selectable (#3651) --- zellij-server/src/screen.rs | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/zellij-server/src/screen.rs b/zellij-server/src/screen.rs index 832dfcdbfc..1d266859f6 100644 --- a/zellij-server/src/screen.rs +++ b/zellij-server/src/screen.rs @@ -2710,6 +2710,7 @@ pub(crate) fn screen_thread_main( let mut pending_tab_ids: HashSet = HashSet::new(); let mut pending_tab_switches: HashSet<(usize, ClientId)> = HashSet::new(); // usize is the // tab_index + let mut pending_events_waiting_for_tab: Vec = vec![]; let mut pending_events_waiting_for_client: Vec = vec![]; let mut plugin_loading_message_cache = HashMap::new(); loop { @@ -3299,12 +3300,18 @@ pub(crate) fn screen_thread_main( }, ScreenInstruction::SetSelectable(pid, selectable) => { let all_tabs = screen.get_tabs_mut(); + let mut found_plugin = false; for tab in all_tabs.values_mut() { if tab.has_pane_with_pid(&pid) { tab.set_pane_selectable(pid, selectable); + found_plugin = true; break; } } + if !found_plugin { + pending_events_waiting_for_tab + .push(ScreenInstruction::SetSelectable(pid, selectable)); + } screen.render(None)?; screen.log_and_report_session_state()?; }, @@ -3505,6 +3512,10 @@ pub(crate) fn screen_thread_main( screen.bus.senders.send_to_screen(event).non_fatal(); } + for event in pending_events_waiting_for_tab.drain(..) { + screen.bus.senders.send_to_screen(event).non_fatal(); + } + screen.unblock_input()?; screen.render(None)?; // we do this here in order to recover from a race condition on app start