mirror of
				https://github.com/rad4day/Waybar.git
				synced 2025-10-25 15:12:29 +02:00 
			
		
		
		
	fix(Window): avoid concurrency
This commit is contained in:
		| @@ -6,8 +6,8 @@ | ||||
| #include "bar.hpp" | ||||
| #include "client.hpp" | ||||
| #include "modules/sway/ipc/client.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
| #include "util/json.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
|  | ||||
| namespace waybar::modules::sway { | ||||
|  | ||||
| @@ -27,6 +27,7 @@ class Window : public ALabel { | ||||
|   const Bar&                  bar_; | ||||
|   waybar::util::SleeperThread thread_; | ||||
|   Ipc                         ipc_; | ||||
|   std::mutex                  mutex_; | ||||
|   std::string                 window_; | ||||
|   int                         windowId_; | ||||
|   std::string                 app_id_; | ||||
|   | ||||
| @@ -65,7 +65,7 @@ std::thread waybar::modules::MPD::event_listener() { | ||||
|       try { | ||||
|         if (connection_ == nullptr) { | ||||
|           // Retry periodically if no connection | ||||
|           update(); | ||||
|           dp.emit(); | ||||
|           std::this_thread::sleep_for(interval_); | ||||
|         } else { | ||||
|           waitForEvent(); | ||||
|   | ||||
| @@ -25,6 +25,7 @@ void Window::onEvent(const struct Ipc::ipc_response& res) { getTree(); } | ||||
|  | ||||
| void Window::onCmd(const struct Ipc::ipc_response& res) { | ||||
|   try { | ||||
|     std::lock_guard<std::mutex> lock(mutex_); | ||||
|     auto payload = parser_.parse(res.payload); | ||||
|     auto [nb, id, name, app_id] = getFocusedNode(payload); | ||||
|     if (!app_id_.empty()) { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Alex
					Alex