mirror of
				https://github.com/rad4day/Waybar.git
				synced 2025-10-24 22:52:32 +02:00 
			
		
		
		
	Merge branch 'master' of https://github.com/Alexays/Waybar into pr/anakael/add-name-to-taskbar
This commit is contained in:
		| @@ -3,11 +3,10 @@ | ||||
| #include <fmt/format.h> | ||||
| #include <gdk/gdk.h> | ||||
| #include <gdk/gdkwayland.h> | ||||
| #include <unistd.h> | ||||
| #include <wayland-client.h> | ||||
| #include <wordexp.h> | ||||
|  | ||||
| #include "bar.hpp" | ||||
| #include "config.hpp" | ||||
|  | ||||
| struct zwlr_layer_shell_v1; | ||||
| struct zwp_idle_inhibitor_v1; | ||||
| @@ -29,18 +28,13 @@ class Client { | ||||
|   struct zxdg_output_manager_v1 *     xdg_output_manager = nullptr; | ||||
|   struct zwp_idle_inhibit_manager_v1 *idle_inhibit_manager = nullptr; | ||||
|   std::vector<std::unique_ptr<Bar>>   bars; | ||||
|   Config                              config; | ||||
|  | ||||
|  private: | ||||
|   Client() = default; | ||||
|   std::tuple<const std::string, const std::string> getConfigs(const std::string &config, | ||||
|                                                               const std::string &style) const; | ||||
|   void                                             bindInterfaces(); | ||||
|   const std::string        getValidPath(const std::vector<std::string> &paths) const; | ||||
|   const std::string        getStyle(const std::string &style); | ||||
|   void                     bindInterfaces(); | ||||
|   void                     handleOutput(struct waybar_output &output); | ||||
|   bool                     isValidOutput(const Json::Value &config, struct waybar_output &output); | ||||
|   auto                     setupConfig(const std::string &config_file, int depth) -> void; | ||||
|   auto                     resolveConfigIncludes(Json::Value &config, int depth) -> void; | ||||
|   auto                     mergeConfig(Json::Value &a_config_, Json::Value &b_config_) -> void; | ||||
|   auto                     setupCss(const std::string &css_file) -> void; | ||||
|   struct waybar_output &   getOutput(void *); | ||||
|   std::vector<Json::Value> getOutputConfigs(struct waybar_output &output); | ||||
| @@ -55,7 +49,6 @@ class Client { | ||||
|   void        handleMonitorRemoved(Glib::RefPtr<Gdk::Monitor> monitor); | ||||
|   void        handleDeferredMonitorRemoval(Glib::RefPtr<Gdk::Monitor> monitor); | ||||
|  | ||||
|   Json::Value                     config_; | ||||
|   Glib::RefPtr<Gtk::StyleContext> style_context_; | ||||
|   Glib::RefPtr<Gtk::CssProvider>  css_provider_; | ||||
|   std::list<struct waybar_output> outputs_; | ||||
|   | ||||
							
								
								
									
										39
									
								
								include/config.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								include/config.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <json/json.h> | ||||
|  | ||||
| #include <optional> | ||||
| #include <string> | ||||
|  | ||||
| #ifndef SYSCONFDIR | ||||
| #define SYSCONFDIR "/etc" | ||||
| #endif | ||||
|  | ||||
| namespace waybar { | ||||
|  | ||||
| class Config { | ||||
|  public: | ||||
|   static const std::vector<std::string> CONFIG_DIRS; | ||||
|  | ||||
|   /* Try to find any of provided names in the supported set of config directories */ | ||||
|   static std::optional<std::string> findConfigPath( | ||||
|       const std::vector<std::string> &names, const std::vector<std::string> &dirs = CONFIG_DIRS); | ||||
|  | ||||
|   Config() = default; | ||||
|  | ||||
|   void load(const std::string &config); | ||||
|  | ||||
|   Json::Value &getConfig() { return config_; } | ||||
|  | ||||
|   std::vector<Json::Value> getOutputConfigs(const std::string &name, const std::string &identifier); | ||||
|  | ||||
|  private: | ||||
|   void setupConfig(Json::Value &dst, const std::string &config_file, int depth); | ||||
|   void resolveConfigIncludes(Json::Value &config, int depth); | ||||
|   void mergeConfig(Json::Value &a_config_, Json::Value &b_config_); | ||||
|  | ||||
|   std::string config_file_; | ||||
|  | ||||
|   Json::Value config_; | ||||
| }; | ||||
| }  // namespace waybar | ||||
| @@ -14,6 +14,7 @@ | ||||
| #endif | ||||
| #ifdef HAVE_WLR | ||||
| #include "modules/wlr/taskbar.hpp" | ||||
| #include "modules/wlr/workspace_manager.hpp" | ||||
| #endif | ||||
| #ifdef HAVE_RIVER | ||||
| #include "modules/river/tags.hpp" | ||||
|   | ||||
| @@ -37,6 +37,7 @@ class Clock : public ALabel { | ||||
|   auto calendar_text(const waybar_time& wtime) -> std::string; | ||||
|   auto weekdays_header(const date::weekday& first_dow, std::ostream& os) -> void; | ||||
|   auto first_day_of_week() -> date::weekday; | ||||
|   bool setTimeZone(Json::Value zone_name); | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::modules | ||||
|   | ||||
| @@ -19,11 +19,11 @@ class Cpu : public ALabel { | ||||
|   auto update() -> void; | ||||
|  | ||||
|  private: | ||||
|   double                                  getCpuLoad(); | ||||
|   std::tuple<uint16_t, std::string>       getCpuUsage(); | ||||
|   std::tuple<float, float, float>         getCpuFrequency(); | ||||
|   std::vector<std::tuple<size_t, size_t>> parseCpuinfo(); | ||||
|   std::vector<float>                      parseCpuFrequencies(); | ||||
|   double                                         getCpuLoad(); | ||||
|   std::tuple<std::vector<uint16_t>, std::string> getCpuUsage(); | ||||
|   std::tuple<float, float, float>                getCpuFrequency(); | ||||
|   std::vector<std::tuple<size_t, size_t>>        parseCpuinfo(); | ||||
|   std::vector<float>                             parseCpuFrequencies(); | ||||
|  | ||||
|   std::vector<std::tuple<size_t, size_t>> prev_times_; | ||||
|  | ||||
|   | ||||
| @@ -43,6 +43,7 @@ class Network : public ALabel { | ||||
|   const std::string getNetworkState() const; | ||||
|   void              clearIface(); | ||||
|   bool              wildcardMatch(const std::string& pattern, const std::string& text) const; | ||||
|   std::optional<std::pair<unsigned long long, unsigned long long>> readBandwidthUsage(); | ||||
|  | ||||
|   int                ifid_; | ||||
|   sa_family_t        family_; | ||||
| @@ -67,6 +68,7 @@ class Network : public ALabel { | ||||
|   bool        carrier_; | ||||
|   std::string ifname_; | ||||
|   std::string ipaddr_; | ||||
|   std::string gwaddr_; | ||||
|   std::string netmask_; | ||||
|   int         cidr_; | ||||
|   int32_t     signal_strength_dbm_; | ||||
|   | ||||
| @@ -6,6 +6,7 @@ | ||||
| #include "AModule.hpp" | ||||
| #include "bar.hpp" | ||||
| #include "river-status-unstable-v1-client-protocol.h" | ||||
| #include "river-control-unstable-v1-client-protocol.h" | ||||
| #include "xdg-output-unstable-v1-client-protocol.h" | ||||
|  | ||||
| namespace waybar::modules::river { | ||||
| @@ -20,7 +21,12 @@ class Tags : public waybar::AModule { | ||||
|   void handle_view_tags(struct wl_array *tags); | ||||
|   void handle_urgent_tags(uint32_t tags); | ||||
|  | ||||
|   void handle_primary_clicked(uint32_t tag); | ||||
|   bool handle_button_press(GdkEventButton *event_button, uint32_t tag); | ||||
|  | ||||
|   struct zriver_status_manager_v1 *status_manager_; | ||||
|   struct zriver_control_v1 *control_; | ||||
|   struct wl_seat *seat_; | ||||
|  | ||||
|  private: | ||||
|   const waybar::Bar &      bar_; | ||||
|   | ||||
| @@ -84,6 +84,7 @@ class Task | ||||
|     std::string state_string(bool = false) const; | ||||
|     void set_app_info_from_app_id_list(const std::string& app_id_list); | ||||
|     bool image_load_icon(Gtk::Image& image, const Glib::RefPtr<Gtk::IconTheme>& icon_theme, Glib::RefPtr<Gio::DesktopAppInfo> app_info, int size); | ||||
|     void hide_if_ignored(); | ||||
|  | ||||
|    public: | ||||
|     /* Getter functions */ | ||||
|   | ||||
							
								
								
									
										160
									
								
								include/modules/wlr/workspace_manager.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										160
									
								
								include/modules/wlr/workspace_manager.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,160 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <fmt/format.h> | ||||
| #include <gtkmm/button.h> | ||||
| #include <gtkmm/image.h> | ||||
| #include <gtkmm/label.h> | ||||
|  | ||||
| #include <functional> | ||||
| #include <map> | ||||
| #include <memory> | ||||
| #include <vector> | ||||
|  | ||||
| #include "AModule.hpp" | ||||
| #include "bar.hpp" | ||||
| #include "ext-workspace-unstable-v1-client-protocol.h" | ||||
|  | ||||
| namespace waybar::modules::wlr { | ||||
|  | ||||
| class WorkspaceManager; | ||||
| class WorkspaceGroup; | ||||
|  | ||||
| class Workspace { | ||||
|  public: | ||||
|   Workspace(const waybar::Bar &bar, const Json::Value &config, WorkspaceGroup &workspace_group, | ||||
|             zext_workspace_handle_v1 *workspace, uint32_t id); | ||||
|   ~Workspace(); | ||||
|   auto update() -> void; | ||||
|  | ||||
|   auto id() const -> uint32_t { return id_; } | ||||
|   auto is_active() const -> bool { return state_ & static_cast<uint32_t>(State::ACTIVE); } | ||||
|   auto is_urgent() const -> bool { return state_ & static_cast<uint32_t>(State::URGENT); } | ||||
|   auto is_hidden() const -> bool { return state_ & static_cast<uint32_t>(State::HIDDEN); } | ||||
|   // wlr stuff | ||||
|   auto handle_name(const std::string &name) -> void; | ||||
|   auto handle_coordinates(const std::vector<uint32_t> &coordinates) -> void; | ||||
|   auto handle_state(const std::vector<uint32_t> &state) -> void; | ||||
|   auto handle_remove() -> void; | ||||
|  | ||||
|   auto handle_done() -> void; | ||||
|   auto handle_clicked(GdkEventButton *bt) -> bool; | ||||
|   auto show() -> void; | ||||
|   auto hide() -> void; | ||||
|   auto get_button_ref() -> Gtk::Button & { return button_; } | ||||
|   auto get_name() -> std::string & { return name_; } | ||||
|   auto get_coords() -> std::vector<uint32_t> & { return coordinates_; } | ||||
|  | ||||
|   enum class State { | ||||
|     ACTIVE = (1 << 0), | ||||
|     URGENT = (1 << 1), | ||||
|     HIDDEN = (1 << 2), | ||||
|   }; | ||||
|  | ||||
|  private: | ||||
|   auto get_icon() -> std::string; | ||||
|  | ||||
|   const Bar         &bar_; | ||||
|   const Json::Value &config_; | ||||
|   WorkspaceGroup    &workspace_group_; | ||||
|  | ||||
|   // wlr stuff | ||||
|   zext_workspace_handle_v1 *workspace_handle_; | ||||
|   uint32_t                  state_ = 0; | ||||
|  | ||||
|   uint32_t                                  id_; | ||||
|   std::string                               name_; | ||||
|   std::vector<uint32_t>                     coordinates_; | ||||
|   static std::map<std::string, std::string> icons_map_; | ||||
|   std::string                               format_; | ||||
|   bool                                      with_icon_ = false; | ||||
|  | ||||
|   Gtk::Button button_; | ||||
|   Gtk::Box    content_; | ||||
|   Gtk::Label  label_; | ||||
| }; | ||||
|  | ||||
| class WorkspaceGroup { | ||||
|  public: | ||||
|   WorkspaceGroup(const waybar::Bar &bar, Gtk::Box &box, const Json::Value &config, | ||||
|                  WorkspaceManager &manager, zext_workspace_group_handle_v1 *workspace_group_handle, | ||||
|                  uint32_t id); | ||||
|   ~WorkspaceGroup(); | ||||
|   auto update() -> void; | ||||
|  | ||||
|   auto id() const -> uint32_t { return id_; } | ||||
|   auto is_visible() const -> bool; | ||||
|   auto remove_workspace(uint32_t id_) -> void; | ||||
|   auto active_only() const -> bool; | ||||
|   auto creation_delayed() const -> bool; | ||||
|   auto workspaces() -> std::vector<std::unique_ptr<Workspace>> & { return workspaces_; } | ||||
|  | ||||
|   auto sort_workspaces() -> void; | ||||
|   auto set_need_to_sort() -> void { need_to_sort = true; } | ||||
|   auto add_button(Gtk::Button &button) -> void; | ||||
|   auto remove_button(Gtk::Button &button) -> void; | ||||
|  | ||||
|   // wlr stuff | ||||
|   auto handle_workspace_create(zext_workspace_handle_v1 *workspace_handle) -> void; | ||||
|   auto handle_remove() -> void; | ||||
|   auto handle_output_enter(wl_output *output) -> void; | ||||
|   auto handle_output_leave() -> void; | ||||
|   auto handle_done() -> void; | ||||
|   auto commit() -> void; | ||||
|  | ||||
|  private: | ||||
|   static uint32_t    workspace_global_id; | ||||
|   const waybar::Bar &bar_; | ||||
|   Gtk::Box          &box_; | ||||
|   const Json::Value &config_; | ||||
|   WorkspaceManager  &workspace_manager_; | ||||
|  | ||||
|   // wlr stuff | ||||
|   zext_workspace_group_handle_v1 *workspace_group_handle_; | ||||
|   wl_output                      *output_ = nullptr; | ||||
|  | ||||
|   uint32_t                                id_; | ||||
|   std::vector<std::unique_ptr<Workspace>> workspaces_; | ||||
|   bool                                    need_to_sort = false; | ||||
| }; | ||||
|  | ||||
| class WorkspaceManager : public AModule { | ||||
|  public: | ||||
|   WorkspaceManager(const std::string &id, const waybar::Bar &bar, const Json::Value &config); | ||||
|   ~WorkspaceManager() override; | ||||
|   auto update() -> void override; | ||||
|  | ||||
|   auto all_outputs() const -> bool { return all_outputs_; } | ||||
|   auto active_only() const -> bool { return active_only_; } | ||||
|   auto workspace_comparator() const | ||||
|       -> std::function<bool(std::unique_ptr<Workspace> &, std::unique_ptr<Workspace> &)>; | ||||
|   auto creation_delayed() const -> bool { return creation_delayed_; } | ||||
|  | ||||
|   auto sort_workspaces() -> void; | ||||
|   auto remove_workspace_group(uint32_t id_) -> void; | ||||
|  | ||||
|   // wlr stuff | ||||
|   auto register_manager(wl_registry *registry, uint32_t name, uint32_t version) -> void; | ||||
|   auto handle_workspace_group_create(zext_workspace_group_handle_v1 *workspace_group_handle) | ||||
|       -> void; | ||||
|   auto handle_done() -> void; | ||||
|   auto handle_finished() -> void; | ||||
|   auto commit() -> void; | ||||
|  | ||||
|  private: | ||||
|   const waybar::Bar                           &bar_; | ||||
|   Gtk::Box                                     box_; | ||||
|   std::vector<std::unique_ptr<WorkspaceGroup>> groups_; | ||||
|  | ||||
|   // wlr stuff | ||||
|   zext_workspace_manager_v1 *workspace_manager_ = nullptr; | ||||
|  | ||||
|   static uint32_t group_global_id; | ||||
|  | ||||
|   bool sort_by_name_ = true; | ||||
|   bool sort_by_coordinates_ = true; | ||||
|   bool all_outputs_ = false; | ||||
|   bool active_only_ = false; | ||||
|   bool creation_delayed_ = false; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::modules::wlr | ||||
							
								
								
									
										8
									
								
								include/modules/wlr/workspace_manager_binding.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								include/modules/wlr/workspace_manager_binding.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| #include "ext-workspace-unstable-v1-client-protocol.h" | ||||
|  | ||||
| namespace waybar::modules::wlr { | ||||
|   void add_registry_listener(void *data); | ||||
|   void add_workspace_listener(zext_workspace_handle_v1 *workspace_handle, void *data); | ||||
|   void add_workspace_group_listener(zext_workspace_group_handle_v1 *workspace_group_handle, void *data); | ||||
|   zext_workspace_manager_v1* workspace_manager_bind(wl_registry *registry, uint32_t name, uint32_t version, void *data); | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 dmitry
					dmitry