mirror of
				https://github.com/rad4day/Waybar.git
				synced 2025-10-24 22:52:32 +02:00 
			
		
		
		
	fix(Workspaces): fix concurrence and move json parser to ipc client
This commit is contained in:
		| @@ -6,8 +6,10 @@ | ||||
| #include <unistd.h> | ||||
| #include <cstring> | ||||
| #include <iostream> | ||||
| #include <memory> | ||||
| #include <mutex> | ||||
| #include "ipc.hpp" | ||||
| #include "util/json.hpp" | ||||
|  | ||||
| namespace waybar::modules::sway { | ||||
|  | ||||
| @@ -19,7 +21,7 @@ class Ipc { | ||||
|   struct ipc_response { | ||||
|     uint32_t    size; | ||||
|     uint32_t    type; | ||||
|     std::string payload; | ||||
|     Json::Value payload; | ||||
|   }; | ||||
|  | ||||
|   sigc::signal<void, const struct ipc_response> signal_event; | ||||
| @@ -38,10 +40,11 @@ class Ipc { | ||||
|   struct ipc_response send(int fd, uint32_t type, const std::string &payload = ""); | ||||
|   struct ipc_response recv(int fd); | ||||
|  | ||||
|   int        fd_; | ||||
|   int        fd_event_; | ||||
|   std::mutex mutex_; | ||||
|   std::mutex mutex_event_; | ||||
|   int              fd_; | ||||
|   int              fd_event_; | ||||
|   std::mutex       mutex_; | ||||
|   std::mutex       mutex_event_; | ||||
|   util::JsonParser parser_; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::modules::sway | ||||
|   | ||||
| @@ -5,7 +5,6 @@ | ||||
| #include "bar.hpp" | ||||
| #include "client.hpp" | ||||
| #include "modules/sway/ipc/client.hpp" | ||||
| #include "util/json.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
|  | ||||
| namespace waybar::modules::sway { | ||||
| @@ -22,7 +21,6 @@ class Mode : public ALabel { | ||||
|  | ||||
|   const Bar&                  bar_; | ||||
|   waybar::util::SleeperThread thread_; | ||||
|   util::JsonParser            parser_; | ||||
|   Ipc                         ipc_; | ||||
|   std::string                 mode_; | ||||
| }; | ||||
|   | ||||
| @@ -6,7 +6,6 @@ | ||||
| #include "bar.hpp" | ||||
| #include "client.hpp" | ||||
| #include "modules/sway/ipc/client.hpp" | ||||
| #include "util/json.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
|  | ||||
| namespace waybar::modules::sway { | ||||
| @@ -26,7 +25,6 @@ class Window : public ALabel { | ||||
|  | ||||
|   const Bar&                  bar_; | ||||
|   waybar::util::SleeperThread thread_; | ||||
|   util::JsonParser            parser_; | ||||
|   Ipc                         ipc_; | ||||
|   std::string                 window_; | ||||
|   int                         windowId_; | ||||
|   | ||||
| @@ -7,7 +7,6 @@ | ||||
| #include "bar.hpp" | ||||
| #include "client.hpp" | ||||
| #include "modules/sway/ipc/client.hpp" | ||||
| #include "util/json.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
|  | ||||
| namespace waybar::modules::sway { | ||||
| @@ -36,8 +35,8 @@ class Workspaces : public IModule { | ||||
|   const Json::Value&                           config_; | ||||
|   std::vector<Json::Value>                     workspaces_; | ||||
|   waybar::util::SleeperThread                  thread_; | ||||
|   std::mutex                                   mutex_; | ||||
|   Gtk::Box                                     box_; | ||||
|   util::JsonParser                             parser_; | ||||
|   Ipc                                          ipc_; | ||||
|   bool                                         scrolling_; | ||||
|   std::unordered_map<std::string, Gtk::Button> buttons_; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Alex
					Alex