mirror of
				https://github.com/rad4day/Waybar.git
				synced 2025-10-25 23:22:28 +02:00 
			
		
		
		
	cleanup onEvent, dont use try/catch for flow control
This commit is contained in:
		| @@ -88,7 +88,7 @@ class Workspace { | |||||||
|   void initialize_window_map(const Json::Value& clients_data); |   void initialize_window_map(const Json::Value& clients_data); | ||||||
|  |  | ||||||
|   bool on_window_opened(WindowCreationPayload const& create_window_paylod); |   bool on_window_opened(WindowCreationPayload const& create_window_paylod); | ||||||
|   std::optional<std::string> on_window_closed(WindowAddress const& addr); |   std::optional<std::string> close_window(WindowAddress const& addr); | ||||||
|  |  | ||||||
|   void update(const std::string& format, const std::string& icon); |   void update(const std::string& format, const std::string& icon); | ||||||
|  |  | ||||||
| @@ -127,7 +127,7 @@ class Workspaces : public AModule, public EventHandler { | |||||||
|  |  | ||||||
|   std::string get_rewrite(std::string window_class, std::string window_title); |   std::string get_rewrite(std::string window_class, std::string window_title); | ||||||
|   std::string& get_window_separator() { return format_window_separator_; } |   std::string& get_window_separator() { return format_window_separator_; } | ||||||
|   bool is_workspace_ignored(std::string& workspace_name); |   bool is_workspace_ignored(std::string const& workspace_name); | ||||||
|  |  | ||||||
|   bool window_rewrite_config_uses_title() const { return any_window_rewrite_rule_uses_title_; } |   bool window_rewrite_config_uses_title() const { return any_window_rewrite_rule_uses_title_; } | ||||||
|  |  | ||||||
| @@ -142,10 +142,23 @@ class Workspaces : public AModule, public EventHandler { | |||||||
|   void parse_config(const Json::Value& config); |   void parse_config(const Json::Value& config); | ||||||
|   void register_ipc(); |   void register_ipc(); | ||||||
|  |  | ||||||
|  |   // workspace events | ||||||
|  |   void on_workspace_activated(std::string const& payload); | ||||||
|  |   void on_workspace_destroyed(std::string const& payload); | ||||||
|  |   void on_workspace_created(std::string const& payload); | ||||||
|  |   void on_workspace_moved(std::string const& payload); | ||||||
|  |   void on_workspace_renamed(std::string const& payload); | ||||||
|  |  | ||||||
|  |   // monitor events | ||||||
|  |   void on_monitor_focused(std::string const& payload); | ||||||
|  |  | ||||||
|  |   // window events | ||||||
|   void on_window_opened(std::string const& payload); |   void on_window_opened(std::string const& payload); | ||||||
|   void on_window_closed(std::string const& payload); |   void on_window_closed(std::string const& payload); | ||||||
|   void on_window_moved(std::string const& payload); |   void on_window_moved(std::string const& payload); | ||||||
|  |  | ||||||
|  |   void on_window_title_event(std::string const& payload); | ||||||
|  |  | ||||||
|   int window_rewrite_priority_function(std::string const& window_rule); |   int window_rewrite_priority_function(std::string const& window_rule); | ||||||
|  |  | ||||||
|   bool all_outputs_ = false; |   bool all_outputs_ = false; | ||||||
|   | |||||||
| @@ -225,7 +225,7 @@ auto Workspaces::update() -> void { | |||||||
|   AModule::update(); |   AModule::update(); | ||||||
| } | } | ||||||
|  |  | ||||||
| bool isDoubleSpecial(std::string &workspace_name) { | bool isDoubleSpecial(std::string const &workspace_name) { | ||||||
|   // Hyprland's IPC sometimes reports the creation of workspaces strangely named |   // Hyprland's IPC sometimes reports the creation of workspaces strangely named | ||||||
|   // `special:special:<some_name>`. This function checks for that and is used |   // `special:special:<some_name>`. This function checks for that and is used | ||||||
|   // to avoid creating (and then removing) such workspaces. |   // to avoid creating (and then removing) such workspaces. | ||||||
| @@ -233,7 +233,7 @@ bool isDoubleSpecial(std::string &workspace_name) { | |||||||
|   return workspace_name.find("special:special:") != std::string::npos; |   return workspace_name.find("special:special:") != std::string::npos; | ||||||
| } | } | ||||||
|  |  | ||||||
| bool Workspaces::is_workspace_ignored(std::string &name) { | bool Workspaces::is_workspace_ignored(std::string const &name) { | ||||||
|   for (auto &rule : ignore_workspaces_) { |   for (auto &rule : ignore_workspaces_) { | ||||||
|     if (std::regex_match(name, rule)) { |     if (std::regex_match(name, rule)) { | ||||||
|       return true; |       return true; | ||||||
| @@ -250,13 +250,43 @@ void Workspaces::onEvent(const std::string &ev) { | |||||||
|   std::string payload = ev.substr(eventName.size() + 2); |   std::string payload = ev.substr(eventName.size() + 2); | ||||||
|  |  | ||||||
|   if (eventName == "workspace") { |   if (eventName == "workspace") { | ||||||
|     active_workspace_name_ = payload; |     on_workspace_activated(payload); | ||||||
|  |  | ||||||
|   } else if (eventName == "destroyworkspace") { |   } else if (eventName == "destroyworkspace") { | ||||||
|  |     on_workspace_destroyed(payload); | ||||||
|  |   } else if (eventName == "createworkspace") { | ||||||
|  |     on_workspace_created(payload); | ||||||
|  |   } else if (eventName == "focusedmon") { | ||||||
|  |     on_monitor_focused(payload); | ||||||
|  |   } else if (eventName == "moveworkspace" && !all_outputs()) { | ||||||
|  |     on_workspace_moved(payload); | ||||||
|  |   } else if (eventName == "openwindow") { | ||||||
|  |     on_window_opened(payload); | ||||||
|  |   } else if (eventName == "closewindow") { | ||||||
|  |     on_window_closed(payload); | ||||||
|  |   } else if (eventName == "movewindow") { | ||||||
|  |     on_window_moved(payload); | ||||||
|  |   } else if (eventName == "urgent") { | ||||||
|  |     set_urgent_workspace(payload); | ||||||
|  |   } else if (eventName == "renameworkspace") { | ||||||
|  |     on_workspace_renamed(payload); | ||||||
|  |   } else if (eventName == "windowtitle") { | ||||||
|  |     on_window_title_event(payload); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   dp.emit(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void Workspaces::on_workspace_activated(std::string const &payload) { | ||||||
|  |   active_workspace_name_ = payload; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void Workspaces::on_workspace_destroyed(std::string const &payload) { | ||||||
|   if (!isDoubleSpecial(payload)) { |   if (!isDoubleSpecial(payload)) { | ||||||
|     workspaces_to_remove_.push_back(payload); |     workspaces_to_remove_.push_back(payload); | ||||||
|   } |   } | ||||||
|   } else if (eventName == "createworkspace") { | } | ||||||
|  |  | ||||||
|  | void Workspaces::on_workspace_created(std::string const &payload) { | ||||||
|   const Json::Value workspaces_json = gIPC->getSocket1JsonReply("workspaces"); |   const Json::Value workspaces_json = gIPC->getSocket1JsonReply("workspaces"); | ||||||
|  |  | ||||||
|   if (!is_workspace_ignored(payload)) { |   if (!is_workspace_ignored(payload)) { | ||||||
| @@ -270,10 +300,9 @@ void Workspaces::onEvent(const std::string &ev) { | |||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   } else if (eventName == "focusedmon") { | } | ||||||
|     active_workspace_name_ = payload.substr(payload.find(',') + 1); |  | ||||||
|  |  | ||||||
|   } else if (eventName == "moveworkspace" && !all_outputs()) { | void Workspaces::on_workspace_moved(std::string const &payload) { | ||||||
|   std::string workspace = payload.substr(0, payload.find(',')); |   std::string workspace = payload.substr(0, payload.find(',')); | ||||||
|   std::string new_output = payload.substr(payload.find(',') + 1); |   std::string new_output = payload.substr(payload.find(',') + 1); | ||||||
|   if (bar_.output->name == new_output) {  // TODO: implement this better |   if (bar_.output->name == new_output) {  // TODO: implement this better | ||||||
| @@ -288,15 +317,9 @@ void Workspaces::onEvent(const std::string &ev) { | |||||||
|   } else { |   } else { | ||||||
|     workspaces_to_remove_.push_back(workspace); |     workspaces_to_remove_.push_back(workspace); | ||||||
|   } |   } | ||||||
|   } else if (eventName == "openwindow") { | } | ||||||
|     on_window_opened(payload); |  | ||||||
|   } else if (eventName == "closewindow") { | void Workspaces::on_workspace_renamed(std::string const &payload) { | ||||||
|     on_window_closed(payload); |  | ||||||
|   } else if (eventName == "movewindow") { |  | ||||||
|     on_window_moved(payload); |  | ||||||
|   } else if (eventName == "urgent") { |  | ||||||
|     set_urgent_workspace(payload); |  | ||||||
|   } else if (eventName == "renameworkspace") { |  | ||||||
|   std::string workspace_id_str = payload.substr(0, payload.find(',')); |   std::string workspace_id_str = payload.substr(0, payload.find(',')); | ||||||
|   int workspace_id = workspace_id_str == "special" ? -99 : std::stoi(workspace_id_str); |   int workspace_id = workspace_id_str == "special" ? -99 : std::stoi(workspace_id_str); | ||||||
|   std::string new_name = payload.substr(payload.find(',') + 1); |   std::string new_name = payload.substr(payload.find(',') + 1); | ||||||
| @@ -309,27 +332,10 @@ void Workspaces::onEvent(const std::string &ev) { | |||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   } else if (eventName == "windowtitle") { |  | ||||||
|     auto window_workspace = |  | ||||||
|         std::find_if(workspaces_.begin(), workspaces_.end(), |  | ||||||
|                      [payload](auto &workspace) { return workspace->contains_window(payload); }); |  | ||||||
|  |  | ||||||
|     if (window_workspace != workspaces_.end()) { |  | ||||||
|       Json::Value clients_data = gIPC->getSocket1JsonReply("clients"); |  | ||||||
|       std::string json_window_address = fmt::format("0x{}", payload); |  | ||||||
|  |  | ||||||
|       auto client = std::find_if(clients_data.begin(), clients_data.end(), |  | ||||||
|                                  [json_window_address](auto &client) { |  | ||||||
|                                    return client["address"].asString() == json_window_address; |  | ||||||
|                                  }); |  | ||||||
|  |  | ||||||
|       if (!client->empty()) { |  | ||||||
|         (*window_workspace)->insert_window({*client}); |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|   dp.emit(); | void Workspaces::on_monitor_focused(std::string const &payload) { | ||||||
|  |   active_workspace_name_ = payload.substr(payload.find(',') + 1); | ||||||
| } | } | ||||||
|  |  | ||||||
| void Workspaces::on_window_opened(std::string const &payload) { | void Workspaces::on_window_opened(std::string const &payload) { | ||||||
| @@ -356,7 +362,7 @@ void Workspaces::on_window_opened(std::string const &payload) { | |||||||
| void Workspaces::on_window_closed(std::string const &addr) { | void Workspaces::on_window_closed(std::string const &addr) { | ||||||
|   update_window_count(); |   update_window_count(); | ||||||
|   for (auto &workspace : workspaces_) { |   for (auto &workspace : workspaces_) { | ||||||
|     if (workspace->on_window_closed(addr)) { |     if (workspace->close_window(addr)) { | ||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @@ -384,12 +390,9 @@ void Workspaces::on_window_moved(std::string const &payload) { | |||||||
|  |  | ||||||
|   // Take the window's representation from the old workspace... |   // Take the window's representation from the old workspace... | ||||||
|   for (auto &workspace : workspaces_) { |   for (auto &workspace : workspaces_) { | ||||||
|     try { |     if (auto window_addr = workspace->close_window(window_address); window_addr != std::nullopt) { | ||||||
|       window_repr = workspace->on_window_closed(window_address).value(); |       window_repr = window_addr.value(); | ||||||
|       break; |       break; | ||||||
|     } catch (const std::bad_optional_access &e) { |  | ||||||
|       // window was not found in this workspace |  | ||||||
|       continue; |  | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -399,6 +402,26 @@ void Workspaces::on_window_moved(std::string const &payload) { | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void Workspaces::on_window_title_event(std::string const &payload) { | ||||||
|  |   auto window_workspace = | ||||||
|  |       std::find_if(workspaces_.begin(), workspaces_.end(), | ||||||
|  |                    [payload](auto &workspace) { return workspace->contains_window(payload); }); | ||||||
|  |  | ||||||
|  |   if (window_workspace != workspaces_.end()) { | ||||||
|  |     Json::Value clients_data = gIPC->getSocket1JsonReply("clients"); | ||||||
|  |     std::string json_window_address = fmt::format("0x{}", payload); | ||||||
|  |  | ||||||
|  |     auto client = | ||||||
|  |         std::find_if(clients_data.begin(), clients_data.end(), [json_window_address](auto &client) { | ||||||
|  |           return client["address"].asString() == json_window_address; | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |     if (!client->empty()) { | ||||||
|  |       (*window_workspace)->insert_window({*client}); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
| void Workspaces::update_window_count() { | void Workspaces::update_window_count() { | ||||||
|   const Json::Value workspaces_json = gIPC->getSocket1JsonReply("workspaces"); |   const Json::Value workspaces_json = gIPC->getSocket1JsonReply("workspaces"); | ||||||
|   for (auto &workspace : workspaces_) { |   for (auto &workspace : workspaces_) { | ||||||
| @@ -446,11 +469,11 @@ bool Workspace::on_window_opened(WindowCreationPayload const &create_window_payl | |||||||
|   return false; |   return false; | ||||||
| } | } | ||||||
|  |  | ||||||
| std::optional<std::string> Workspace::on_window_closed(WindowAddress const &addr) { | std::optional<std::string> Workspace::close_window(WindowAddress const &addr) { | ||||||
|   if (window_map_.contains(addr)) { |   if (window_map_.contains(addr)) { | ||||||
|     return remove_window(addr); |     return remove_window(addr); | ||||||
|   } |   } | ||||||
|   return {}; |   return std::nullopt; | ||||||
| } | } | ||||||
|  |  | ||||||
| void Workspaces::create_workspace(Json::Value const &workspace_data, | void Workspaces::create_workspace(Json::Value const &workspace_data, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 zjeffer
					zjeffer