mirror of
				https://github.com/rad4day/Waybar.git
				synced 2025-10-25 07:02:30 +02:00 
			
		
		
		
	refactor: lint
This commit is contained in:
		| @@ -13,11 +13,11 @@ class AIconLabel : public ALabel { | ||||
|              const std::string &format, uint16_t interval = 0, bool ellipsize = false, | ||||
|              bool enable_click = false, bool enable_scroll = false); | ||||
|   virtual ~AIconLabel() = default; | ||||
|   virtual auto        update() -> void; | ||||
|   virtual auto update() -> void; | ||||
|  | ||||
|  protected: | ||||
|   Gtk::Image image_; | ||||
|   Gtk::Box   box_; | ||||
|   Gtk::Box box_; | ||||
|  | ||||
|   bool iconEnabled() const; | ||||
| }; | ||||
|   | ||||
| @@ -3,6 +3,7 @@ | ||||
| #include <glibmm/markup.h> | ||||
| #include <gtkmm/label.h> | ||||
| #include <json/json.h> | ||||
|  | ||||
| #include "AModule.hpp" | ||||
|  | ||||
| namespace waybar { | ||||
| @@ -10,20 +11,21 @@ namespace waybar { | ||||
| class ALabel : public AModule { | ||||
|  public: | ||||
|   ALabel(const Json::Value &, const std::string &, const std::string &, const std::string &format, | ||||
|          uint16_t interval = 0, bool ellipsize = false, bool enable_click = false, bool enable_scroll = false); | ||||
|          uint16_t interval = 0, bool ellipsize = false, bool enable_click = false, | ||||
|          bool enable_scroll = false); | ||||
|   virtual ~ALabel() = default; | ||||
|   virtual auto        update() -> void; | ||||
|   virtual auto update() -> void; | ||||
|   virtual std::string getIcon(uint16_t, const std::string &alt = "", uint16_t max = 0); | ||||
|   virtual std::string getIcon(uint16_t, const std::vector<std::string> &alts, uint16_t max = 0); | ||||
|  | ||||
|  protected: | ||||
|   Gtk::Label                 label_; | ||||
|   std::string                format_; | ||||
|   Gtk::Label label_; | ||||
|   std::string format_; | ||||
|   const std::chrono::seconds interval_; | ||||
|   bool                       alt_ = false; | ||||
|   std::string                default_format_; | ||||
|   bool alt_ = false; | ||||
|   std::string default_format_; | ||||
|  | ||||
|   virtual bool        handleToggle(GdkEventButton *const &e); | ||||
|   virtual bool handleToggle(GdkEventButton *const &e); | ||||
|   virtual std::string getState(uint8_t value, bool lesser = false); | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -15,7 +15,7 @@ class AModule : public IModule { | ||||
|           bool enable_scroll = false); | ||||
|   virtual ~AModule(); | ||||
|   virtual auto update() -> void; | ||||
|   virtual      operator Gtk::Widget &(); | ||||
|   virtual operator Gtk::Widget &(); | ||||
|  | ||||
|   Glib::Dispatcher dp; | ||||
|  | ||||
| @@ -23,36 +23,35 @@ class AModule : public IModule { | ||||
|   enum SCROLL_DIR { NONE, UP, DOWN, LEFT, RIGHT }; | ||||
|  | ||||
|   SCROLL_DIR getScrollDir(GdkEventScroll *e); | ||||
|   bool       tooltipEnabled(); | ||||
|   bool tooltipEnabled(); | ||||
|  | ||||
|   const std::string  name_; | ||||
|   const std::string name_; | ||||
|   const Json::Value &config_; | ||||
|   Gtk::EventBox      event_box_; | ||||
|   Gtk::EventBox event_box_; | ||||
|  | ||||
|   virtual bool handleToggle(GdkEventButton *const &ev); | ||||
|   virtual bool handleScroll(GdkEventScroll *); | ||||
|  | ||||
|  private: | ||||
|   std::vector<int> pid_; | ||||
|   gdouble          distance_scrolled_y_; | ||||
|   gdouble          distance_scrolled_x_; | ||||
|   gdouble distance_scrolled_y_; | ||||
|   gdouble distance_scrolled_x_; | ||||
|   static const inline std::map<std::pair<uint, GdkEventType>, std::string> eventMap_{ | ||||
|     {std::make_pair(1, GdkEventType::GDK_BUTTON_PRESS),  "on-click"}, | ||||
|     {std::make_pair(1, GdkEventType::GDK_2BUTTON_PRESS), "on-double-click"}, | ||||
|     {std::make_pair(1, GdkEventType::GDK_3BUTTON_PRESS), "on-triple-click"}, | ||||
|     {std::make_pair(2, GdkEventType::GDK_BUTTON_PRESS),  "on-click-middle"}, | ||||
|     {std::make_pair(2, GdkEventType::GDK_2BUTTON_PRESS), "on-double-click-middle"}, | ||||
|     {std::make_pair(2, GdkEventType::GDK_3BUTTON_PRESS), "on-triple-click-middle"}, | ||||
|     {std::make_pair(3, GdkEventType::GDK_BUTTON_PRESS),  "on-click-right"}, | ||||
|     {std::make_pair(3, GdkEventType::GDK_2BUTTON_PRESS), "on-double-click-right"}, | ||||
|     {std::make_pair(3, GdkEventType::GDK_3BUTTON_PRESS), "on-triple-click-right"}, | ||||
|     {std::make_pair(8, GdkEventType::GDK_BUTTON_PRESS),  "on-click-backward"}, | ||||
|     {std::make_pair(8, GdkEventType::GDK_2BUTTON_PRESS), "on-double-click-backward"}, | ||||
|     {std::make_pair(8, GdkEventType::GDK_2BUTTON_PRESS), "on-triple-click-backward"}, | ||||
|     {std::make_pair(9, GdkEventType::GDK_BUTTON_PRESS),  "on-click-forward"}, | ||||
|     {std::make_pair(9, GdkEventType::GDK_2BUTTON_PRESS), "on-double-click-forward"}, | ||||
|     {std::make_pair(9, GdkEventType::GDK_2BUTTON_PRESS), "on-triple-click-forward"} | ||||
|   }; | ||||
|       {std::make_pair(1, GdkEventType::GDK_BUTTON_PRESS), "on-click"}, | ||||
|       {std::make_pair(1, GdkEventType::GDK_2BUTTON_PRESS), "on-double-click"}, | ||||
|       {std::make_pair(1, GdkEventType::GDK_3BUTTON_PRESS), "on-triple-click"}, | ||||
|       {std::make_pair(2, GdkEventType::GDK_BUTTON_PRESS), "on-click-middle"}, | ||||
|       {std::make_pair(2, GdkEventType::GDK_2BUTTON_PRESS), "on-double-click-middle"}, | ||||
|       {std::make_pair(2, GdkEventType::GDK_3BUTTON_PRESS), "on-triple-click-middle"}, | ||||
|       {std::make_pair(3, GdkEventType::GDK_BUTTON_PRESS), "on-click-right"}, | ||||
|       {std::make_pair(3, GdkEventType::GDK_2BUTTON_PRESS), "on-double-click-right"}, | ||||
|       {std::make_pair(3, GdkEventType::GDK_3BUTTON_PRESS), "on-triple-click-right"}, | ||||
|       {std::make_pair(8, GdkEventType::GDK_BUTTON_PRESS), "on-click-backward"}, | ||||
|       {std::make_pair(8, GdkEventType::GDK_2BUTTON_PRESS), "on-double-click-backward"}, | ||||
|       {std::make_pair(8, GdkEventType::GDK_2BUTTON_PRESS), "on-triple-click-backward"}, | ||||
|       {std::make_pair(9, GdkEventType::GDK_BUTTON_PRESS), "on-click-forward"}, | ||||
|       {std::make_pair(9, GdkEventType::GDK_2BUTTON_PRESS), "on-double-click-forward"}, | ||||
|       {std::make_pair(9, GdkEventType::GDK_2BUTTON_PRESS), "on-triple-click-forward"}}; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar | ||||
|   | ||||
| @@ -7,8 +7,8 @@ namespace waybar { | ||||
| class IModule { | ||||
|  public: | ||||
|   virtual ~IModule() = default; | ||||
|   virtual auto     update() -> void = 0; | ||||
|   virtual          operator Gtk::Widget &() = 0; | ||||
|   virtual auto update() -> void = 0; | ||||
|   virtual operator Gtk::Widget&() = 0; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar | ||||
|   | ||||
| @@ -19,8 +19,8 @@ namespace waybar { | ||||
| class Factory; | ||||
| struct waybar_output { | ||||
|   Glib::RefPtr<Gdk::Monitor> monitor; | ||||
|   std::string                name; | ||||
|   std::string                identifier; | ||||
|   std::string name; | ||||
|   std::string identifier; | ||||
|  | ||||
|   std::unique_ptr<struct zxdg_output_v1, decltype(&zxdg_output_v1_destroy)> xdg_output = { | ||||
|       nullptr, &zxdg_output_v1_destroy}; | ||||
| @@ -41,9 +41,9 @@ struct bar_margins { | ||||
|  | ||||
| struct bar_mode { | ||||
|   bar_layer layer; | ||||
|   bool      exclusive; | ||||
|   bool      passthrough; | ||||
|   bool      visible; | ||||
|   bool exclusive; | ||||
|   bool passthrough; | ||||
|   bool visible; | ||||
| }; | ||||
|  | ||||
| #ifdef HAVE_SWAY | ||||
| @@ -71,7 +71,7 @@ class BarSurface { | ||||
| class Bar { | ||||
|  public: | ||||
|   using bar_mode_map = std::map<std::string_view, struct bar_mode>; | ||||
|   static const bar_mode_map     PRESET_MODES; | ||||
|   static const bar_mode_map PRESET_MODES; | ||||
|   static const std::string_view MODE_DEFAULT; | ||||
|   static const std::string_view MODE_INVISIBLE; | ||||
|  | ||||
| @@ -85,11 +85,11 @@ class Bar { | ||||
|   void handleSignal(int); | ||||
|  | ||||
|   struct waybar_output *output; | ||||
|   Json::Value           config; | ||||
|   struct wl_surface    *surface; | ||||
|   bool                  visible = true; | ||||
|   bool                  vertical = false; | ||||
|   Gtk::Window           window; | ||||
|   Json::Value config; | ||||
|   struct wl_surface *surface; | ||||
|   bool visible = true; | ||||
|   bool vertical = false; | ||||
|   Gtk::Window window; | ||||
|  | ||||
| #ifdef HAVE_SWAY | ||||
|   std::string bar_id; | ||||
| @@ -98,20 +98,20 @@ class Bar { | ||||
|  private: | ||||
|   void onMap(GdkEventAny *); | ||||
|   auto setupWidgets() -> void; | ||||
|   void getModules(const Factory &, const std::string &, Gtk::Box*); | ||||
|   void getModules(const Factory &, const std::string &, Gtk::Box *); | ||||
|   void setupAltFormatKeyForModule(const std::string &module_name); | ||||
|   void setupAltFormatKeyForModuleList(const char *module_list_name); | ||||
|   void setMode(const bar_mode &); | ||||
|  | ||||
|   /* Copy initial set of modes to allow customization */ | ||||
|   bar_mode_map configured_modes = PRESET_MODES; | ||||
|   std::string  last_mode_{MODE_DEFAULT}; | ||||
|   std::string last_mode_{MODE_DEFAULT}; | ||||
|  | ||||
|   std::unique_ptr<BarSurface>                   surface_impl_; | ||||
|   Gtk::Box                                      left_; | ||||
|   Gtk::Box                                      center_; | ||||
|   Gtk::Box                                      right_; | ||||
|   Gtk::Box                                      box_; | ||||
|   std::unique_ptr<BarSurface> surface_impl_; | ||||
|   Gtk::Box left_; | ||||
|   Gtk::Box center_; | ||||
|   Gtk::Box right_; | ||||
|   Gtk::Box box_; | ||||
|   std::vector<std::shared_ptr<waybar::AModule>> modules_left_; | ||||
|   std::vector<std::shared_ptr<waybar::AModule>> modules_center_; | ||||
|   std::vector<std::shared_ptr<waybar::AModule>> modules_right_; | ||||
|   | ||||
| @@ -17,27 +17,27 @@ namespace waybar { | ||||
| class Client { | ||||
|  public: | ||||
|   static Client *inst(); | ||||
|   int            main(int argc, char *argv[]); | ||||
|   void           reset(); | ||||
|   int main(int argc, char *argv[]); | ||||
|   void reset(); | ||||
|  | ||||
|   Glib::RefPtr<Gtk::Application>      gtk_app; | ||||
|   Glib::RefPtr<Gdk::Display>          gdk_display; | ||||
|   struct wl_display *                 wl_display = nullptr; | ||||
|   struct wl_registry *                registry = nullptr; | ||||
|   struct zwlr_layer_shell_v1 *        layer_shell = nullptr; | ||||
|   struct zxdg_output_manager_v1 *     xdg_output_manager = nullptr; | ||||
|   Glib::RefPtr<Gtk::Application> gtk_app; | ||||
|   Glib::RefPtr<Gdk::Display> gdk_display; | ||||
|   struct wl_display *wl_display = nullptr; | ||||
|   struct wl_registry *registry = nullptr; | ||||
|   struct zwlr_layer_shell_v1 *layer_shell = nullptr; | ||||
|   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; | ||||
|   std::string                         bar_id; | ||||
|   std::vector<std::unique_ptr<Bar>> bars; | ||||
|   Config config; | ||||
|   std::string bar_id; | ||||
|  | ||||
|  private: | ||||
|   Client() = default; | ||||
|   const std::string        getStyle(const std::string &style); | ||||
|   void                     bindInterfaces(); | ||||
|   void                     handleOutput(struct waybar_output &output); | ||||
|   auto                     setupCss(const std::string &css_file) -> void; | ||||
|   struct waybar_output &   getOutput(void *); | ||||
|   const std::string getStyle(const std::string &style); | ||||
|   void bindInterfaces(); | ||||
|   void handleOutput(struct waybar_output &output); | ||||
|   auto setupCss(const std::string &css_file) -> void; | ||||
|   struct waybar_output &getOutput(void *); | ||||
|   std::vector<Json::Value> getOutputConfigs(struct waybar_output &output); | ||||
|  | ||||
|   static void handleGlobal(void *data, struct wl_registry *registry, uint32_t name, | ||||
| @@ -46,12 +46,12 @@ class Client { | ||||
|   static void handleOutputDone(void *, struct zxdg_output_v1 *); | ||||
|   static void handleOutputName(void *, struct zxdg_output_v1 *, const char *); | ||||
|   static void handleOutputDescription(void *, struct zxdg_output_v1 *, const char *); | ||||
|   void        handleMonitorAdded(Glib::RefPtr<Gdk::Monitor> monitor); | ||||
|   void        handleMonitorRemoved(Glib::RefPtr<Gdk::Monitor> monitor); | ||||
|   void        handleDeferredMonitorRemoval(Glib::RefPtr<Gdk::Monitor> monitor); | ||||
|   void handleMonitorAdded(Glib::RefPtr<Gdk::Monitor> monitor); | ||||
|   void handleMonitorRemoved(Glib::RefPtr<Gdk::Monitor> monitor); | ||||
|   void handleDeferredMonitorRemoval(Glib::RefPtr<Gdk::Monitor> monitor); | ||||
|  | ||||
|   Glib::RefPtr<Gtk::StyleContext> style_context_; | ||||
|   Glib::RefPtr<Gtk::CssProvider>  css_provider_; | ||||
|   Glib::RefPtr<Gtk::CssProvider> css_provider_; | ||||
|   std::list<struct waybar_output> outputs_; | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -7,10 +7,10 @@ | ||||
| #include "modules/simpleclock.hpp" | ||||
| #endif | ||||
| #ifdef HAVE_SWAY | ||||
| #include "modules/sway/language.hpp" | ||||
| #include "modules/sway/mode.hpp" | ||||
| #include "modules/sway/window.hpp" | ||||
| #include "modules/sway/workspaces.hpp" | ||||
| #include "modules/sway/language.hpp" | ||||
| #endif | ||||
| #ifdef HAVE_WLR | ||||
| #include "modules/wlr/taskbar.hpp" | ||||
| @@ -61,9 +61,9 @@ | ||||
| #include "modules/custom.hpp" | ||||
| #include "modules/temperature.hpp" | ||||
| #if defined(__linux__) | ||||
| #  ifdef WANT_RFKILL | ||||
| #    include "modules/bluetooth.hpp" | ||||
| #  endif | ||||
| #ifdef WANT_RFKILL | ||||
| #include "modules/bluetooth.hpp" | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| namespace waybar { | ||||
| @@ -74,7 +74,7 @@ class Factory { | ||||
|   AModule* makeModule(const std::string& name) const; | ||||
|  | ||||
|  private: | ||||
|   const Bar&         bar_; | ||||
|   const Bar& bar_; | ||||
|   const Json::Value& config_; | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -1,8 +1,9 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <gtkmm/widget.h> | ||||
| #include <gtkmm/box.h> | ||||
| #include <gtkmm/widget.h> | ||||
| #include <json/json.h> | ||||
|  | ||||
| #include "AModule.hpp" | ||||
| #include "bar.hpp" | ||||
| #include "factory.hpp" | ||||
| @@ -14,7 +15,7 @@ class Group : public AModule { | ||||
|   Group(const std::string&, const Bar&, const Json::Value&); | ||||
|   ~Group() = default; | ||||
|   auto update() -> void; | ||||
|   operator Gtk::Widget &(); | ||||
|   operator Gtk::Widget&(); | ||||
|   Gtk::Box box; | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -19,19 +19,19 @@ class Backlight : public ALabel { | ||||
|    public: | ||||
|     BacklightDev() = default; | ||||
|     BacklightDev(std::string name, int actual, int max); | ||||
|     std::string_view   name() const; | ||||
|     int                get_actual() const; | ||||
|     void               set_actual(int actual); | ||||
|     int                get_max() const; | ||||
|     void               set_max(int max); | ||||
|     std::string_view name() const; | ||||
|     int get_actual() const; | ||||
|     void set_actual(int actual); | ||||
|     int get_max() const; | ||||
|     void set_max(int max); | ||||
|     friend inline bool operator==(const BacklightDev &lhs, const BacklightDev &rhs) { | ||||
|       return lhs.name_ == rhs.name_ && lhs.actual_ == rhs.actual_ && lhs.max_ == rhs.max_; | ||||
|     } | ||||
|  | ||||
|    private: | ||||
|     std::string name_; | ||||
|     int         actual_ = 1; | ||||
|     int         max_ = 1; | ||||
|     int actual_ = 1; | ||||
|     int max_ = 1; | ||||
|   }; | ||||
|  | ||||
|  public: | ||||
| @@ -47,13 +47,13 @@ class Backlight : public ALabel { | ||||
|   template <class ForwardIt, class Inserter> | ||||
|   static void enumerate_devices(ForwardIt first, ForwardIt last, Inserter inserter, udev *udev); | ||||
|  | ||||
|   const std::string    preferred_device_; | ||||
|   const std::string preferred_device_; | ||||
|   static constexpr int EPOLL_MAX_EVENTS = 16; | ||||
|  | ||||
|   std::optional<BacklightDev> previous_best_; | ||||
|   std::string                 previous_format_; | ||||
|   std::string previous_format_; | ||||
|  | ||||
|   std::mutex                udev_thread_mutex_; | ||||
|   std::mutex udev_thread_mutex_; | ||||
|   std::vector<BacklightDev> devices_; | ||||
|   // thread must destruct before shared data | ||||
|   util::SleeperThread udev_thread_; | ||||
|   | ||||
| @@ -7,10 +7,12 @@ | ||||
| #endif | ||||
| #include <fmt/format.h> | ||||
| #include <sys/inotify.h> | ||||
|  | ||||
| #include <algorithm> | ||||
| #include <fstream> | ||||
| #include <string> | ||||
| #include <vector> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
|  | ||||
| @@ -31,23 +33,23 @@ class Battery : public ALabel { | ||||
|  private: | ||||
|   static inline const fs::path data_dir_ = "/sys/class/power_supply/"; | ||||
|  | ||||
|   void                                                 refreshBatteries(); | ||||
|   void                                                 worker(); | ||||
|   const std::string                                    getAdapterStatus(uint8_t capacity) const; | ||||
|   void refreshBatteries(); | ||||
|   void worker(); | ||||
|   const std::string getAdapterStatus(uint8_t capacity) const; | ||||
|   const std::tuple<uint8_t, float, std::string, float> getInfos(); | ||||
|   const std::string                                    formatTimeRemaining(float hoursRemaining); | ||||
|   const std::string formatTimeRemaining(float hoursRemaining); | ||||
|  | ||||
|   int                   global_watch; | ||||
|   std::map<fs::path,int> batteries_; | ||||
|   fs::path              adapter_; | ||||
|   int                   battery_watch_fd_; | ||||
|   int                   global_watch_fd_; | ||||
|   std::mutex            battery_list_mutex_; | ||||
|   std::string           old_status_; | ||||
|   int global_watch; | ||||
|   std::map<fs::path, int> batteries_; | ||||
|   fs::path adapter_; | ||||
|   int battery_watch_fd_; | ||||
|   int global_watch_fd_; | ||||
|   std::mutex battery_list_mutex_; | ||||
|   std::string old_status_; | ||||
|  | ||||
|   util::SleeperThread   thread_; | ||||
|   util::SleeperThread   thread_battery_update_; | ||||
|   util::SleeperThread   thread_timer_; | ||||
|   util::SleeperThread thread_; | ||||
|   util::SleeperThread thread_battery_update_; | ||||
|   util::SleeperThread thread_timer_; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::modules | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <date/tz.h> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
|  | ||||
| @@ -24,7 +25,7 @@ class Clock : public ALabel { | ||||
|   std::locale locale_; | ||||
|   std::vector<const date::time_zone*> time_zones_; | ||||
|   int current_time_zone_idx_; | ||||
|   date::year_month_day cached_calendar_ymd_ = date::January/1/0; | ||||
|   date::year_month_day cached_calendar_ymd_ = date::January / 1 / 0; | ||||
|   std::string cached_calendar_text_; | ||||
|   bool is_calendar_in_tooltip_; | ||||
|   bool is_timezoned_list_in_tooltip_; | ||||
| @@ -36,7 +37,7 @@ class Clock : public ALabel { | ||||
|   auto first_day_of_week() -> date::weekday; | ||||
|   const date::time_zone* current_timezone(); | ||||
|   bool is_timezone_fixed(); | ||||
|   auto timezones_text(std::chrono::system_clock::time_point *now) -> std::string; | ||||
|   auto timezones_text(std::chrono::system_clock::time_point* now) -> std::string; | ||||
| }; | ||||
|  | ||||
| }  // namespace modules | ||||
|   | ||||
| @@ -1,12 +1,14 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <fmt/format.h> | ||||
|  | ||||
| #include <cstdint> | ||||
| #include <fstream> | ||||
| #include <numeric> | ||||
| #include <string> | ||||
| #include <utility> | ||||
| #include <vector> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
|  | ||||
| @@ -19,11 +21,11 @@ class Cpu : public ALabel { | ||||
|   auto update() -> void; | ||||
|  | ||||
|  private: | ||||
|   double                                         getCpuLoad(); | ||||
|   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::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_; | ||||
|  | ||||
|   | ||||
| @@ -1,8 +1,10 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <fmt/format.h> | ||||
|  | ||||
| #include <csignal> | ||||
| #include <string> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
| #include "util/command.hpp" | ||||
| #include "util/json.hpp" | ||||
| @@ -26,16 +28,16 @@ class Custom : public ALabel { | ||||
|   bool handleScroll(GdkEventScroll* e); | ||||
|   bool handleToggle(GdkEventButton* const& e); | ||||
|  | ||||
|   const std::string        name_; | ||||
|   std::string              text_; | ||||
|   std::string              alt_; | ||||
|   std::string              tooltip_; | ||||
|   const std::string name_; | ||||
|   std::string text_; | ||||
|   std::string alt_; | ||||
|   std::string tooltip_; | ||||
|   std::vector<std::string> class_; | ||||
|   int                      percentage_; | ||||
|   FILE*                    fp_; | ||||
|   int                      pid_; | ||||
|   util::command::res       output_; | ||||
|   util::JsonParser         parser_; | ||||
|   int percentage_; | ||||
|   FILE* fp_; | ||||
|   int pid_; | ||||
|   util::command::res output_; | ||||
|   util::JsonParser parser_; | ||||
|  | ||||
|   util::SleeperThread thread_; | ||||
| }; | ||||
|   | ||||
| @@ -1,11 +1,13 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <fmt/format.h> | ||||
| #include <fstream> | ||||
| #include <sys/statvfs.h> | ||||
|  | ||||
| #include <fstream> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
| #include "util/format.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
|  | ||||
| namespace waybar::modules { | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <fmt/format.h> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
| #include "bar.hpp" | ||||
| #include "client.hpp" | ||||
| @@ -13,14 +14,14 @@ class IdleInhibitor : public ALabel { | ||||
|   ~IdleInhibitor(); | ||||
|   auto update() -> void; | ||||
|   static std::list<waybar::AModule*> modules; | ||||
|   static bool                        status; | ||||
|   static bool status; | ||||
|  | ||||
|  private: | ||||
|   bool handleToggle(GdkEventButton* const& e); | ||||
|  | ||||
|   const Bar&                    bar_; | ||||
|   const Bar& bar_; | ||||
|   struct zwp_idle_inhibitor_v1* idle_inhibitor_; | ||||
|   int                           pid_; | ||||
|   int pid_; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::modules | ||||
|   | ||||
| @@ -1,9 +1,9 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <memory> | ||||
|  | ||||
| #include <gio/gio.h> | ||||
|  | ||||
| #include <memory> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
| #include "bar.hpp" | ||||
|  | ||||
| @@ -19,9 +19,9 @@ class Inhibitor : public ALabel { | ||||
|  private: | ||||
|   auto handleToggle(::GdkEventButton* const& e) -> bool; | ||||
|  | ||||
|   const std::unique_ptr<::GDBusConnection, void(*)(::GDBusConnection*)> dbus_; | ||||
|   const std::unique_ptr<::GDBusConnection, void (*)(::GDBusConnection*)> dbus_; | ||||
|   const std::string inhibitors_; | ||||
|   int handle_ = -1; | ||||
| }; | ||||
|  | ||||
| } // namespace waybar::modules | ||||
| }  // namespace waybar::modules | ||||
|   | ||||
| @@ -6,10 +6,11 @@ | ||||
| #else | ||||
| #include <fmt/chrono.h> | ||||
| #endif | ||||
| #include <gtkmm/label.h> | ||||
|  | ||||
| #include "AModule.hpp" | ||||
| #include "bar.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
| #include <gtkmm/label.h> | ||||
|  | ||||
| extern "C" { | ||||
| #include <libevdev/libevdev.h> | ||||
| @@ -24,10 +25,10 @@ class KeyboardState : public AModule { | ||||
|   auto update() -> void; | ||||
|  | ||||
|  private: | ||||
|   Gtk::Box    box_; | ||||
|   Gtk::Label  numlock_label_; | ||||
|   Gtk::Label  capslock_label_; | ||||
|   Gtk::Label  scrolllock_label_; | ||||
|   Gtk::Box box_; | ||||
|   Gtk::Label numlock_label_; | ||||
|   Gtk::Label capslock_label_; | ||||
|   Gtk::Label scrolllock_label_; | ||||
|  | ||||
|   std::string numlock_format_; | ||||
|   std::string capslock_format_; | ||||
| @@ -36,8 +37,8 @@ class KeyboardState : public AModule { | ||||
|   std::string icon_locked_; | ||||
|   std::string icon_unlocked_; | ||||
|  | ||||
|   int         fd_; | ||||
|   libevdev*   dev_; | ||||
|   int fd_; | ||||
|   libevdev* dev_; | ||||
|  | ||||
|   util::SleeperThread thread_; | ||||
| }; | ||||
|   | ||||
| @@ -1,8 +1,10 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <fmt/format.h> | ||||
|  | ||||
| #include <fstream> | ||||
| #include <unordered_map> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
|  | ||||
| @@ -15,7 +17,7 @@ class Memory : public ALabel { | ||||
|   auto update() -> void; | ||||
|  | ||||
|  private: | ||||
|   void                            parseMeminfo(); | ||||
|   void parseMeminfo(); | ||||
|  | ||||
|   std::unordered_map<std::string, unsigned long> meminfo_; | ||||
|  | ||||
|   | ||||
| @@ -22,8 +22,8 @@ class MPD : public ALabel { | ||||
|  | ||||
|   // Not using unique_ptr since we don't manage the pointer | ||||
|   // (It's either nullptr, or from the config) | ||||
|   const char*       server_; | ||||
|   const unsigned    port_; | ||||
|   const char* server_; | ||||
|   const unsigned port_; | ||||
|   const std::string password_; | ||||
|  | ||||
|   unsigned timeout_; | ||||
| @@ -31,8 +31,8 @@ class MPD : public ALabel { | ||||
|   detail::unique_connection connection_; | ||||
|  | ||||
|   detail::unique_status status_; | ||||
|   mpd_state             state_; | ||||
|   detail::unique_song   song_; | ||||
|   mpd_state state_; | ||||
|   detail::unique_song song_; | ||||
|  | ||||
|  public: | ||||
|   MPD(const std::string&, const Json::Value&); | ||||
| @@ -41,7 +41,7 @@ class MPD : public ALabel { | ||||
|  | ||||
|  private: | ||||
|   std::string getTag(mpd_tag_type type, unsigned idx = 0) const; | ||||
|   void        setLabel(); | ||||
|   void setLabel(); | ||||
|   std::string getStateIcon() const; | ||||
|   std::string getOptionIcon(std::string optionName, bool activated) const; | ||||
|  | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <mpd/client.h> | ||||
| #include <fmt/format.h> | ||||
| #include <mpd/client.h> | ||||
| #include <spdlog/spdlog.h> | ||||
|  | ||||
| #include <condition_variable> | ||||
| @@ -57,7 +57,7 @@ class State { | ||||
| }; | ||||
|  | ||||
| class Idle : public State { | ||||
|   Context* const   ctx_; | ||||
|   Context* const ctx_; | ||||
|   sigc::connection idle_connection_; | ||||
|  | ||||
|  public: | ||||
| @@ -80,7 +80,7 @@ class Idle : public State { | ||||
| }; | ||||
|  | ||||
| class Playing : public State { | ||||
|   Context* const   ctx_; | ||||
|   Context* const ctx_; | ||||
|   sigc::connection timer_connection_; | ||||
|  | ||||
|  public: | ||||
| @@ -102,7 +102,7 @@ class Playing : public State { | ||||
| }; | ||||
|  | ||||
| class Paused : public State { | ||||
|   Context* const   ctx_; | ||||
|   Context* const ctx_; | ||||
|   sigc::connection timer_connection_; | ||||
|  | ||||
|  public: | ||||
| @@ -124,7 +124,7 @@ class Paused : public State { | ||||
| }; | ||||
|  | ||||
| class Stopped : public State { | ||||
|   Context* const   ctx_; | ||||
|   Context* const ctx_; | ||||
|   sigc::connection timer_connection_; | ||||
|  | ||||
|  public: | ||||
| @@ -146,7 +146,7 @@ class Stopped : public State { | ||||
| }; | ||||
|  | ||||
| class Disconnected : public State { | ||||
|   Context* const   ctx_; | ||||
|   Context* const ctx_; | ||||
|   sigc::connection timer_connection_; | ||||
|  | ||||
|  public: | ||||
| @@ -170,7 +170,7 @@ class Disconnected : public State { | ||||
|  | ||||
| class Context { | ||||
|   std::unique_ptr<State> state_; | ||||
|   waybar::modules::MPD*  mpd_module_; | ||||
|   waybar::modules::MPD* mpd_module_; | ||||
|  | ||||
|   friend class State; | ||||
|   friend class Playing; | ||||
| @@ -188,18 +188,18 @@ class Context { | ||||
|     state_->entry(); | ||||
|   } | ||||
|  | ||||
|   bool                             is_connected() const; | ||||
|   bool                             is_playing() const; | ||||
|   bool                             is_paused() const; | ||||
|   bool                             is_stopped() const; | ||||
|   constexpr std::size_t            interval() const; | ||||
|   void                             tryConnect() const; | ||||
|   void                             checkErrors(mpd_connection*) const; | ||||
|   void                             do_update(); | ||||
|   void                             queryMPD() const; | ||||
|   void                             fetchState() const; | ||||
|   constexpr mpd_state              state() const; | ||||
|   void                             emit() const; | ||||
|   bool is_connected() const; | ||||
|   bool is_playing() const; | ||||
|   bool is_paused() const; | ||||
|   bool is_stopped() const; | ||||
|   constexpr std::size_t interval() const; | ||||
|   void tryConnect() const; | ||||
|   void checkErrors(mpd_connection*) const; | ||||
|   void do_update(); | ||||
|   void queryMPD() const; | ||||
|   void fetchState() const; | ||||
|   constexpr mpd_state state() const; | ||||
|   void emit() const; | ||||
|   [[nodiscard]] unique_connection& connection(); | ||||
|  | ||||
|  public: | ||||
|   | ||||
| @@ -8,13 +8,11 @@ inline bool Context::is_paused() const { return mpd_module_->paused(); } | ||||
| inline bool Context::is_stopped() const { return mpd_module_->stopped(); } | ||||
|  | ||||
| constexpr inline std::size_t Context::interval() const { return mpd_module_->interval_.count(); } | ||||
| inline void                  Context::tryConnect() const { mpd_module_->tryConnect(); } | ||||
| inline unique_connection&    Context::connection() { return mpd_module_->connection_; } | ||||
| constexpr inline mpd_state   Context::state() const { return mpd_module_->state_; } | ||||
| inline void Context::tryConnect() const { mpd_module_->tryConnect(); } | ||||
| inline unique_connection& Context::connection() { return mpd_module_->connection_; } | ||||
| constexpr inline mpd_state Context::state() const { return mpd_module_->state_; } | ||||
|  | ||||
| inline void Context::do_update() { | ||||
|   mpd_module_->setLabel(); | ||||
| } | ||||
| inline void Context::do_update() { mpd_module_->setLabel(); } | ||||
|  | ||||
| inline void Context::checkErrors(mpd_connection* conn) const { mpd_module_->checkErrors(conn); } | ||||
| inline void Context::queryMPD() const { mpd_module_->queryMPD(); } | ||||
|   | ||||
| @@ -7,6 +7,7 @@ | ||||
| #include <netlink/genl/genl.h> | ||||
| #include <netlink/netlink.h> | ||||
| #include <sys/epoll.h> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
| #ifdef WANT_RFKILL | ||||
| @@ -31,51 +32,51 @@ class Network : public ALabel { | ||||
|  | ||||
|   void askForStateDump(void); | ||||
|  | ||||
|   void              worker(); | ||||
|   void              createInfoSocket(); | ||||
|   void              createEventSocket(); | ||||
|   void              parseEssid(struct nlattr**); | ||||
|   void              parseSignal(struct nlattr**); | ||||
|   void              parseFreq(struct nlattr**); | ||||
|   bool              associatedOrJoined(struct nlattr**); | ||||
|   bool              checkInterface(std::string name); | ||||
|   auto              getInfo() -> void; | ||||
|   void worker(); | ||||
|   void createInfoSocket(); | ||||
|   void createEventSocket(); | ||||
|   void parseEssid(struct nlattr**); | ||||
|   void parseSignal(struct nlattr**); | ||||
|   void parseFreq(struct nlattr**); | ||||
|   bool associatedOrJoined(struct nlattr**); | ||||
|   bool checkInterface(std::string name); | ||||
|   auto getInfo() -> void; | ||||
|   const std::string getNetworkState() const; | ||||
|   void              clearIface(); | ||||
|   bool              wildcardMatch(const std::string& pattern, const std::string& text) 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_; | ||||
|   int ifid_; | ||||
|   sa_family_t family_; | ||||
|   struct sockaddr_nl nladdr_ = {0}; | ||||
|   struct nl_sock*    sock_ = nullptr; | ||||
|   struct nl_sock*    ev_sock_ = nullptr; | ||||
|   int                efd_; | ||||
|   int                ev_fd_; | ||||
|   int                nl80211_id_; | ||||
|   std::mutex         mutex_; | ||||
|   struct nl_sock* sock_ = nullptr; | ||||
|   struct nl_sock* ev_sock_ = nullptr; | ||||
|   int efd_; | ||||
|   int ev_fd_; | ||||
|   int nl80211_id_; | ||||
|   std::mutex mutex_; | ||||
|  | ||||
|   bool               want_route_dump_; | ||||
|   bool               want_link_dump_; | ||||
|   bool               want_addr_dump_; | ||||
|   bool               dump_in_progress_; | ||||
|   bool want_route_dump_; | ||||
|   bool want_link_dump_; | ||||
|   bool want_addr_dump_; | ||||
|   bool dump_in_progress_; | ||||
|  | ||||
|   unsigned long long bandwidth_down_total_; | ||||
|   unsigned long long bandwidth_up_total_; | ||||
|  | ||||
|   std::string state_; | ||||
|   std::string essid_; | ||||
|   bool        carrier_; | ||||
|   bool carrier_; | ||||
|   std::string ifname_; | ||||
|   std::string ipaddr_; | ||||
|   std::string gwaddr_; | ||||
|   std::string netmask_; | ||||
|   int         cidr_; | ||||
|   int32_t     signal_strength_dbm_; | ||||
|   uint8_t     signal_strength_; | ||||
|   int cidr_; | ||||
|   int32_t signal_strength_dbm_; | ||||
|   uint8_t signal_strength_; | ||||
|   std::string signal_strength_app_; | ||||
|   float       frequency_; | ||||
|   uint32_t    route_priority; | ||||
|   float frequency_; | ||||
|   uint32_t route_priority; | ||||
|  | ||||
|   util::SleeperThread thread_; | ||||
|   util::SleeperThread thread_timer_; | ||||
|   | ||||
| @@ -3,8 +3,10 @@ | ||||
| #include <fmt/format.h> | ||||
| #include <pulse/pulseaudio.h> | ||||
| #include <pulse/volume.h> | ||||
|  | ||||
| #include <algorithm> | ||||
| #include <array> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
|  | ||||
| namespace waybar::modules { | ||||
| @@ -23,27 +25,27 @@ class Pulseaudio : public ALabel { | ||||
|   static void serverInfoCb(pa_context*, const pa_server_info*, void*); | ||||
|   static void volumeModifyCb(pa_context*, int, void*); | ||||
|  | ||||
|   bool              handleScroll(GdkEventScroll* e); | ||||
|   bool handleScroll(GdkEventScroll* e); | ||||
|   const std::vector<std::string> getPulseIcon() const; | ||||
|  | ||||
|   pa_threaded_mainloop* mainloop_; | ||||
|   pa_mainloop_api*      mainloop_api_; | ||||
|   pa_context*           context_; | ||||
|   pa_mainloop_api* mainloop_api_; | ||||
|   pa_context* context_; | ||||
|   // SINK | ||||
|   uint32_t    sink_idx_{0}; | ||||
|   uint16_t    volume_; | ||||
|   pa_cvolume  pa_volume_; | ||||
|   bool        muted_; | ||||
|   uint32_t sink_idx_{0}; | ||||
|   uint16_t volume_; | ||||
|   pa_cvolume pa_volume_; | ||||
|   bool muted_; | ||||
|   std::string port_name_; | ||||
|   std::string form_factor_; | ||||
|   std::string desc_; | ||||
|   std::string monitor_; | ||||
|   std::string current_sink_name_; | ||||
|   bool        current_sink_running_; | ||||
|   bool current_sink_running_; | ||||
|   // SOURCE | ||||
|   uint32_t    source_idx_{0}; | ||||
|   uint16_t    source_volume_; | ||||
|   bool        source_muted_; | ||||
|   uint32_t source_idx_{0}; | ||||
|   uint16_t source_volume_; | ||||
|   bool source_muted_; | ||||
|   std::string source_port_name_; | ||||
|   std::string source_desc_; | ||||
|   std::string default_source_name_; | ||||
|   | ||||
| @@ -5,8 +5,8 @@ | ||||
|  | ||||
| #include "AModule.hpp" | ||||
| #include "bar.hpp" | ||||
| #include "river-status-unstable-v1-client-protocol.h" | ||||
| #include "river-control-unstable-v1-client-protocol.h" | ||||
| #include "river-status-unstable-v1-client-protocol.h" | ||||
| #include "xdg-output-unstable-v1-client-protocol.h" | ||||
|  | ||||
| namespace waybar::modules::river { | ||||
| @@ -29,8 +29,8 @@ class Tags : public waybar::AModule { | ||||
|   struct wl_seat *seat_; | ||||
|  | ||||
|  private: | ||||
|   const waybar::Bar &      bar_; | ||||
|   Gtk::Box                 box_; | ||||
|   const waybar::Bar &bar_; | ||||
|   Gtk::Box box_; | ||||
|   std::vector<Gtk::Button> buttons_; | ||||
|   struct zriver_output_status_v1 *output_status_; | ||||
| }; | ||||
|   | ||||
| @@ -1,7 +1,9 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <sndio.h> | ||||
|  | ||||
| #include <vector> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
|  | ||||
| @@ -9,13 +11,13 @@ namespace waybar::modules { | ||||
|  | ||||
| class Sndio : public ALabel { | ||||
|  public: | ||||
|   Sndio(const std::string&, const Json::Value&); | ||||
|   Sndio(const std::string &, const Json::Value &); | ||||
|   ~Sndio(); | ||||
|   auto update() -> void; | ||||
|   auto set_desc(struct sioctl_desc *, unsigned int) -> void; | ||||
|   auto put_val(unsigned int, unsigned int) -> void; | ||||
|   bool handleScroll(GdkEventScroll *); | ||||
|   bool handleToggle(GdkEventButton* const&); | ||||
|   bool handleToggle(GdkEventButton *const &); | ||||
|  | ||||
|  private: | ||||
|   auto connect_to_sndio() -> void; | ||||
|   | ||||
| @@ -4,7 +4,9 @@ | ||||
| #include <giomm.h> | ||||
| #include <glibmm/refptr.h> | ||||
| #include <json/json.h> | ||||
|  | ||||
| #include <tuple> | ||||
|  | ||||
| #include "bar.hpp" | ||||
| #include "modules/sni/item.hpp" | ||||
|  | ||||
| @@ -18,27 +20,27 @@ class Host { | ||||
|   ~Host(); | ||||
|  | ||||
|  private: | ||||
|   void        busAcquired(const Glib::RefPtr<Gio::DBus::Connection>&, Glib::ustring); | ||||
|   void        nameAppeared(const Glib::RefPtr<Gio::DBus::Connection>&, Glib::ustring, | ||||
|                            const Glib::ustring&); | ||||
|   void        nameVanished(const Glib::RefPtr<Gio::DBus::Connection>&, Glib::ustring); | ||||
|   void busAcquired(const Glib::RefPtr<Gio::DBus::Connection>&, Glib::ustring); | ||||
|   void nameAppeared(const Glib::RefPtr<Gio::DBus::Connection>&, Glib::ustring, | ||||
|                     const Glib::ustring&); | ||||
|   void nameVanished(const Glib::RefPtr<Gio::DBus::Connection>&, Glib::ustring); | ||||
|   static void proxyReady(GObject*, GAsyncResult*, gpointer); | ||||
|   static void registerHost(GObject*, GAsyncResult*, gpointer); | ||||
|   static void itemRegistered(SnWatcher*, const gchar*, gpointer); | ||||
|   static void itemUnregistered(SnWatcher*, const gchar*, gpointer); | ||||
|  | ||||
|   std::tuple<std::string, std::string> getBusNameAndObjectPath(const std::string); | ||||
|   void                                 addRegisteredItem(std::string service); | ||||
|   void addRegisteredItem(std::string service); | ||||
|  | ||||
|   std::vector<std::unique_ptr<Item>>                items_; | ||||
|   const std::string                                 bus_name_; | ||||
|   const std::string                                 object_path_; | ||||
|   std::size_t                                       bus_name_id_; | ||||
|   std::size_t                                       watcher_id_; | ||||
|   GCancellable*                                     cancellable_ = nullptr; | ||||
|   SnWatcher*                                        watcher_ = nullptr; | ||||
|   const Json::Value&                                config_; | ||||
|   const Bar&                                        bar_; | ||||
|   std::vector<std::unique_ptr<Item>> items_; | ||||
|   const std::string bus_name_; | ||||
|   const std::string object_path_; | ||||
|   std::size_t bus_name_id_; | ||||
|   std::size_t watcher_id_; | ||||
|   GCancellable* cancellable_ = nullptr; | ||||
|   SnWatcher* watcher_ = nullptr; | ||||
|   const Json::Value& config_; | ||||
|   const Bar& bar_; | ||||
|   const std::function<void(std::unique_ptr<Item>&)> on_add_; | ||||
|   const std::function<void(std::unique_ptr<Item>&)> on_remove_; | ||||
| }; | ||||
|   | ||||
| @@ -31,25 +31,25 @@ class Item : public sigc::trackable { | ||||
|   std::string bus_name; | ||||
|   std::string object_path; | ||||
|  | ||||
|   int           icon_size; | ||||
|   int           effective_icon_size; | ||||
|   Gtk::Image    image; | ||||
|   int icon_size; | ||||
|   int effective_icon_size; | ||||
|   Gtk::Image image; | ||||
|   Gtk::EventBox event_box; | ||||
|   std::string   category; | ||||
|   std::string   id; | ||||
|   std::string category; | ||||
|   std::string id; | ||||
|  | ||||
|   std::string                  title; | ||||
|   std::string                  icon_name; | ||||
|   Glib::RefPtr<Gdk::Pixbuf>    icon_pixmap; | ||||
|   std::string title; | ||||
|   std::string icon_name; | ||||
|   Glib::RefPtr<Gdk::Pixbuf> icon_pixmap; | ||||
|   Glib::RefPtr<Gtk::IconTheme> icon_theme; | ||||
|   std::string                  overlay_icon_name; | ||||
|   std::string                  attention_icon_name; | ||||
|   std::string                  attention_movie_name; | ||||
|   std::string                  icon_theme_path; | ||||
|   std::string                  menu; | ||||
|   ToolTip                      tooltip; | ||||
|   DbusmenuGtkMenu*             dbus_menu = nullptr; | ||||
|   Gtk::Menu*                   gtk_menu = nullptr; | ||||
|   std::string overlay_icon_name; | ||||
|   std::string attention_icon_name; | ||||
|   std::string attention_movie_name; | ||||
|   std::string icon_theme_path; | ||||
|   std::string menu; | ||||
|   ToolTip tooltip; | ||||
|   DbusmenuGtkMenu* dbus_menu = nullptr; | ||||
|   Gtk::Menu* gtk_menu = nullptr; | ||||
|   /** | ||||
|    * ItemIsMenu flag means that the item only supports the context menu. | ||||
|    * Default value is true because libappindicator supports neither ItemIsMenu nor Activate method | ||||
| @@ -67,15 +67,15 @@ class Item : public sigc::trackable { | ||||
|   void onSignal(const Glib::ustring& sender_name, const Glib::ustring& signal_name, | ||||
|                 const Glib::VariantContainerBase& arguments); | ||||
|  | ||||
|   void                      updateImage(); | ||||
|   void updateImage(); | ||||
|   Glib::RefPtr<Gdk::Pixbuf> extractPixBuf(GVariant* variant); | ||||
|   Glib::RefPtr<Gdk::Pixbuf> getIconPixbuf(); | ||||
|   Glib::RefPtr<Gdk::Pixbuf> getIconByName(const std::string& name, int size); | ||||
|   double                    getScaledIconSize(); | ||||
|   static void               onMenuDestroyed(Item* self, GObject* old_menu_pointer); | ||||
|   void                      makeMenu(); | ||||
|   bool                      handleClick(GdkEventButton* const& /*ev*/); | ||||
|   bool                      handleScroll(GdkEventScroll* const&); | ||||
|   double getScaledIconSize(); | ||||
|   static void onMenuDestroyed(Item* self, GObject* old_menu_pointer); | ||||
|   void makeMenu(); | ||||
|   bool handleClick(GdkEventButton* const& /*ev*/); | ||||
|   bool handleScroll(GdkEventScroll* const&); | ||||
|  | ||||
|   // smooth scrolling threshold | ||||
|   gdouble scroll_threshold_ = 0; | ||||
| @@ -86,7 +86,7 @@ class Item : public sigc::trackable { | ||||
|  | ||||
|   Glib::RefPtr<Gio::DBus::Proxy> proxy_; | ||||
|   Glib::RefPtr<Gio::Cancellable> cancellable_; | ||||
|   std::set<std::string_view>     update_pending_; | ||||
|   std::set<std::string_view> update_pending_; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::modules::SNI | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <fmt/format.h> | ||||
|  | ||||
| #include "AModule.hpp" | ||||
| #include "bar.hpp" | ||||
| #include "modules/sni/host.hpp" | ||||
| @@ -20,9 +21,9 @@ class Tray : public AModule { | ||||
|   void onRemove(std::unique_ptr<Item>& item); | ||||
|  | ||||
|   static inline std::size_t nb_hosts_ = 0; | ||||
|   Gtk::Box                  box_; | ||||
|   SNI::Watcher::singleton   watcher_; | ||||
|   SNI::Host                 host_; | ||||
|   Gtk::Box box_; | ||||
|   SNI::Watcher::singleton watcher_; | ||||
|   SNI::Host host_; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::modules::SNI | ||||
|   | ||||
| @@ -30,26 +30,26 @@ class Watcher { | ||||
|  | ||||
|   typedef struct { | ||||
|     GfWatchType type; | ||||
|     Watcher *   watcher; | ||||
|     gchar *     service; | ||||
|     gchar *     bus_name; | ||||
|     gchar *     object_path; | ||||
|     guint       watch_id; | ||||
|     Watcher *watcher; | ||||
|     gchar *service; | ||||
|     gchar *bus_name; | ||||
|     gchar *object_path; | ||||
|     guint watch_id; | ||||
|   } GfWatch; | ||||
|  | ||||
|   void            busAcquired(const Glib::RefPtr<Gio::DBus::Connection> &, Glib::ustring); | ||||
|   void busAcquired(const Glib::RefPtr<Gio::DBus::Connection> &, Glib::ustring); | ||||
|   static gboolean handleRegisterHost(Watcher *, GDBusMethodInvocation *, const gchar *); | ||||
|   static gboolean handleRegisterItem(Watcher *, GDBusMethodInvocation *, const gchar *); | ||||
|   static GfWatch *gfWatchFind(GSList *list, const gchar *bus_name, const gchar *object_path); | ||||
|   static GfWatch *gfWatchNew(GfWatchType, const gchar *, const gchar *, const gchar *, Watcher *); | ||||
|   static void     nameVanished(GDBusConnection *connection, const char *name, gpointer data); | ||||
|   static void     gfWatchFree(gpointer data); | ||||
|   static void nameVanished(GDBusConnection *connection, const char *name, gpointer data); | ||||
|   static void gfWatchFree(gpointer data); | ||||
|  | ||||
|   void updateRegisteredItems(SnWatcher *obj); | ||||
|  | ||||
|   uint32_t   bus_name_id_; | ||||
|   GSList *   hosts_ = nullptr; | ||||
|   GSList *   items_ = nullptr; | ||||
|   uint32_t bus_name_id_; | ||||
|   GSList *hosts_ = nullptr; | ||||
|   GSList *items_ = nullptr; | ||||
|   SnWatcher *watcher_ = nullptr; | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -34,14 +34,14 @@ class BarIpcClient { | ||||
|   void onVisibilityUpdate(bool visible_by_modifier); | ||||
|   void update(); | ||||
|  | ||||
|   Bar&             bar_; | ||||
|   Bar& bar_; | ||||
|   util::JsonParser parser_; | ||||
|   Ipc              ipc_; | ||||
|   Ipc ipc_; | ||||
|  | ||||
|   swaybar_config bar_config_; | ||||
|   bool           visible_by_modifier_ = false; | ||||
|   bool visible_by_modifier_ = false; | ||||
|  | ||||
|   SafeSignal<bool>           signal_visible_; | ||||
|   SafeSignal<bool> signal_visible_; | ||||
|   SafeSignal<swaybar_config> signal_config_; | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -4,9 +4,11 @@ | ||||
| #include <sys/socket.h> | ||||
| #include <sys/un.h> | ||||
| #include <unistd.h> | ||||
|  | ||||
| #include <cstring> | ||||
| #include <memory> | ||||
| #include <mutex> | ||||
|  | ||||
| #include "ipc.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
|  | ||||
| @@ -18,8 +20,8 @@ class Ipc { | ||||
|   ~Ipc(); | ||||
|  | ||||
|   struct ipc_response { | ||||
|     uint32_t    size; | ||||
|     uint32_t    type; | ||||
|     uint32_t size; | ||||
|     uint32_t type; | ||||
|     std::string payload; | ||||
|   }; | ||||
|  | ||||
| @@ -33,16 +35,16 @@ class Ipc { | ||||
|  | ||||
|  protected: | ||||
|   static inline const std::string ipc_magic_ = "i3-ipc"; | ||||
|   static inline const size_t      ipc_header_size_ = ipc_magic_.size() + 8; | ||||
|   static inline const size_t ipc_header_size_ = ipc_magic_.size() + 8; | ||||
|  | ||||
|   const std::string   getSocketPath() const; | ||||
|   int                 open(const std::string &) const; | ||||
|   const std::string getSocketPath() const; | ||||
|   int open(const std::string &) const; | ||||
|   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_; | ||||
|   int fd_; | ||||
|   int fd_event_; | ||||
|   std::mutex mutex_; | ||||
|   util::SleeperThread thread_; | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -30,7 +30,7 @@ enum ipc_command_type { | ||||
|   IPC_EVENT_SHUTDOWN = ((1 << 31) | 6), | ||||
|   IPC_EVENT_TICK = ((1 << 31) | 7), | ||||
|  | ||||
| 	// sway-specific event types | ||||
| 	IPC_EVENT_BAR_STATE_UPDATE = ((1<<31) | 20), | ||||
| 	IPC_EVENT_INPUT = ((1<<31) | 21), | ||||
|   // sway-specific event types | ||||
|   IPC_EVENT_BAR_STATE_UPDATE = ((1 << 31) | 20), | ||||
|   IPC_EVENT_INPUT = ((1 << 31) | 21), | ||||
| }; | ||||
|   | ||||
| @@ -21,11 +21,7 @@ class Language : public ALabel, public sigc::trackable { | ||||
|   auto update() -> void; | ||||
|  | ||||
|  private: | ||||
|   enum class DispayedShortFlag { | ||||
| 	  None = 0, | ||||
| 	  ShortName = 1, | ||||
| 	  ShortDescription = 1 << 1 | ||||
|   }; | ||||
|   enum class DispayedShortFlag { None = 0, ShortName = 1, ShortDescription = 1 << 1 }; | ||||
|  | ||||
|   struct Layout { | ||||
|     std::string full_name; | ||||
| @@ -37,14 +33,15 @@ class Language : public ALabel, public sigc::trackable { | ||||
|  | ||||
|   class XKBContext { | ||||
|    public: | ||||
| 	   XKBContext(); | ||||
| 	   ~XKBContext(); | ||||
| 	   auto next_layout() -> Layout*; | ||||
|     XKBContext(); | ||||
|     ~XKBContext(); | ||||
|     auto next_layout() -> Layout*; | ||||
|  | ||||
|    private: | ||||
| 	rxkb_context* context_ = nullptr; | ||||
| 	rxkb_layout* xkb_layout_ = nullptr; | ||||
| 	Layout* layout_ = nullptr; | ||||
| 	std::map<std::string, rxkb_layout*> base_layouts_by_name_; | ||||
|     rxkb_context* context_ = nullptr; | ||||
|     rxkb_layout* xkb_layout_ = nullptr; | ||||
|     Layout* layout_ = nullptr; | ||||
|     std::map<std::string, rxkb_layout*> base_layouts_by_name_; | ||||
|   }; | ||||
|  | ||||
|   void onEvent(const struct Ipc::ipc_response&); | ||||
| @@ -56,15 +53,15 @@ class Language : public ALabel, public sigc::trackable { | ||||
|   const static std::string XKB_LAYOUT_NAMES_KEY; | ||||
|   const static std::string XKB_ACTIVE_LAYOUT_NAME_KEY; | ||||
|  | ||||
|   Layout                        layout_; | ||||
|   Layout layout_; | ||||
|   std::string tooltip_format_ = ""; | ||||
|   std::map<std::string, Layout> layouts_map_; | ||||
|   bool is_variant_displayed; | ||||
|   std::byte displayed_short_flag = static_cast<std::byte>(DispayedShortFlag::None); | ||||
|  | ||||
|   util::JsonParser         parser_; | ||||
|   std::mutex               mutex_; | ||||
|   Ipc                      ipc_; | ||||
|   util::JsonParser parser_; | ||||
|   std::mutex mutex_; | ||||
|   Ipc ipc_; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::modules::sway | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <fmt/format.h> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
| #include "bar.hpp" | ||||
| #include "client.hpp" | ||||
| @@ -18,10 +19,10 @@ class Mode : public ALabel, public sigc::trackable { | ||||
|  private: | ||||
|   void onEvent(const struct Ipc::ipc_response&); | ||||
|  | ||||
|   std::string      mode_; | ||||
|   std::string mode_; | ||||
|   util::JsonParser parser_; | ||||
|   std::mutex       mutex_; | ||||
|   Ipc              ipc_; | ||||
|   std::mutex mutex_; | ||||
|   Ipc ipc_; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::modules::sway | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <fmt/format.h> | ||||
|  | ||||
| #include <tuple> | ||||
|  | ||||
| #include "AIconLabel.hpp" | ||||
| @@ -18,23 +19,23 @@ class Window : public AIconLabel, public sigc::trackable { | ||||
|   auto update() -> void; | ||||
|  | ||||
|  private: | ||||
|   void                                                   onEvent(const struct Ipc::ipc_response&); | ||||
|   void                                                   onCmd(const struct Ipc::ipc_response&); | ||||
|   void onEvent(const struct Ipc::ipc_response&); | ||||
|   void onCmd(const struct Ipc::ipc_response&); | ||||
|   std::tuple<std::size_t, int, std::string, std::string> getFocusedNode(const Json::Value& nodes, | ||||
|                                                                         std::string&       output); | ||||
|   void                                                   getTree(); | ||||
|   std::string                                            rewriteTitle(const std::string& title); | ||||
|   void                                                   updateAppIcon(); | ||||
|                                                                         std::string& output); | ||||
|   void getTree(); | ||||
|   std::string rewriteTitle(const std::string& title); | ||||
|   void updateAppIcon(); | ||||
|  | ||||
|   const Bar&       bar_; | ||||
|   std::string      window_; | ||||
|   int              windowId_; | ||||
|   std::string      app_id_; | ||||
|   std::string      old_app_id_; | ||||
|   std::size_t      app_nb_; | ||||
|   const Bar& bar_; | ||||
|   std::string window_; | ||||
|   int windowId_; | ||||
|   std::string app_id_; | ||||
|   std::string old_app_id_; | ||||
|   std::size_t app_nb_; | ||||
|   util::JsonParser parser_; | ||||
|   std::mutex       mutex_; | ||||
|   Ipc              ipc_; | ||||
|   std::mutex mutex_; | ||||
|   Ipc ipc_; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::modules::sway | ||||
|   | ||||
| @@ -1,10 +1,11 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <unordered_map> | ||||
| #include <fmt/format.h> | ||||
| #include <gtkmm/button.h> | ||||
| #include <gtkmm/label.h> | ||||
|  | ||||
| #include <unordered_map> | ||||
|  | ||||
| #include "AModule.hpp" | ||||
| #include "bar.hpp" | ||||
| #include "client.hpp" | ||||
| @@ -24,25 +25,25 @@ class Workspaces : public AModule, public sigc::trackable { | ||||
|  | ||||
|   static int convertWorkspaceNameToNum(std::string name); | ||||
|  | ||||
|   void              onCmd(const struct Ipc::ipc_response&); | ||||
|   void              onEvent(const struct Ipc::ipc_response&); | ||||
|   bool              filterButtons(); | ||||
|   Gtk::Button&      addButton(const Json::Value&); | ||||
|   void              onButtonReady(const Json::Value&, Gtk::Button&); | ||||
|   std::string       getIcon(const std::string&, const Json::Value&); | ||||
|   void onCmd(const struct Ipc::ipc_response&); | ||||
|   void onEvent(const struct Ipc::ipc_response&); | ||||
|   bool filterButtons(); | ||||
|   Gtk::Button& addButton(const Json::Value&); | ||||
|   void onButtonReady(const Json::Value&, Gtk::Button&); | ||||
|   std::string getIcon(const std::string&, const Json::Value&); | ||||
|   const std::string getCycleWorkspace(std::vector<Json::Value>::iterator, bool prev) const; | ||||
|   uint16_t          getWorkspaceIndex(const std::string& name) const; | ||||
|   std::string       trimWorkspaceName(std::string); | ||||
|   bool              handleScroll(GdkEventScroll*); | ||||
|   uint16_t getWorkspaceIndex(const std::string& name) const; | ||||
|   std::string trimWorkspaceName(std::string); | ||||
|   bool handleScroll(GdkEventScroll*); | ||||
|  | ||||
|   const Bar&                                   bar_; | ||||
|   std::vector<Json::Value>                     workspaces_; | ||||
|   std::vector<std::string>                     workspaces_order_; | ||||
|   Gtk::Box                                     box_; | ||||
|   util::JsonParser                             parser_; | ||||
|   const Bar& bar_; | ||||
|   std::vector<Json::Value> workspaces_; | ||||
|   std::vector<std::string> workspaces_order_; | ||||
|   Gtk::Box box_; | ||||
|   util::JsonParser parser_; | ||||
|   std::unordered_map<std::string, Gtk::Button> buttons_; | ||||
|   std::mutex                                   mutex_; | ||||
|   Ipc                                          ipc_; | ||||
|   std::mutex mutex_; | ||||
|   Ipc ipc_; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::modules::sway | ||||
|   | ||||
| @@ -1,7 +1,9 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <fmt/format.h> | ||||
|  | ||||
| #include <fstream> | ||||
|  | ||||
| #include "ALabel.hpp" | ||||
| #include "util/sleeper_thread.hpp" | ||||
|  | ||||
| @@ -14,10 +16,10 @@ class Temperature : public ALabel { | ||||
|   auto update() -> void; | ||||
|  | ||||
|  private: | ||||
|   float               getTemperature(); | ||||
|   bool                isCritical(uint16_t); | ||||
|   float getTemperature(); | ||||
|   bool isCritical(uint16_t); | ||||
|  | ||||
|   std::string         file_path_; | ||||
|   std::string file_path_; | ||||
|   util::SleeperThread thread_; | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -38,41 +38,41 @@ class UPower : public AModule { | ||||
|                            gpointer data); | ||||
|   static void upowerDisappear(GDBusConnection *connection, const gchar *name, gpointer user_data); | ||||
|  | ||||
|   void        removeDevice(const gchar *objectPath); | ||||
|   void        addDevice(UpDevice *device); | ||||
|   void        setDisplayDevice(); | ||||
|   void        resetDevices(); | ||||
|   void        removeDevices(); | ||||
|   bool        show_tooltip_callback(int, int, bool, const Glib::RefPtr<Gtk::Tooltip> &tooltip); | ||||
|   bool        handleToggle(GdkEventButton *const &); | ||||
|   void removeDevice(const gchar *objectPath); | ||||
|   void addDevice(UpDevice *device); | ||||
|   void setDisplayDevice(); | ||||
|   void resetDevices(); | ||||
|   void removeDevices(); | ||||
|   bool show_tooltip_callback(int, int, bool, const Glib::RefPtr<Gtk::Tooltip> &tooltip); | ||||
|   bool handleToggle(GdkEventButton *const &); | ||||
|   std::string timeToString(gint64 time); | ||||
|  | ||||
|   const std::string getDeviceStatus(UpDeviceState &state); | ||||
|  | ||||
|   Gtk::Box   box_; | ||||
|   Gtk::Box box_; | ||||
|   Gtk::Image icon_; | ||||
|   Gtk::Label label_; | ||||
|  | ||||
|   // Config | ||||
|   bool        hideIfEmpty = true; | ||||
|   bool        tooltip_enabled = true; | ||||
|   uint        tooltip_spacing = 4; | ||||
|   uint        tooltip_padding = 4; | ||||
|   uint        iconSize = 20; | ||||
|   bool hideIfEmpty = true; | ||||
|   bool tooltip_enabled = true; | ||||
|   uint tooltip_spacing = 4; | ||||
|   uint tooltip_padding = 4; | ||||
|   uint iconSize = 20; | ||||
|   std::string format = DEFAULT_FORMAT; | ||||
|   std::string format_alt = DEFAULT_FORMAT_ALT; | ||||
|  | ||||
|   Devices          devices; | ||||
|   std::mutex       m_Mutex; | ||||
|   UpClient        *client; | ||||
|   UpDevice        *displayDevice; | ||||
|   guint            login1_id; | ||||
|   Devices devices; | ||||
|   std::mutex m_Mutex; | ||||
|   UpClient *client; | ||||
|   UpDevice *displayDevice; | ||||
|   guint login1_id; | ||||
|   GDBusConnection *login1_connection; | ||||
|   UPowerTooltip   *upower_tooltip; | ||||
|   std::string      lastStatus; | ||||
|   bool             showAltText; | ||||
|   bool             upowerRunning; | ||||
|   guint            upowerWatcher_id; | ||||
|   UPowerTooltip *upower_tooltip; | ||||
|   std::string lastStatus; | ||||
|   bool showAltText; | ||||
|   bool upowerRunning; | ||||
|   guint upowerWatcher_id; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::modules::upower | ||||
|   | ||||
| @@ -1,174 +1,168 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <gdk/gdk.h> | ||||
| #include <glibmm/refptr.h> | ||||
| #include <gtkmm/box.h> | ||||
| #include <gtkmm/button.h> | ||||
| #include <gtkmm/icontheme.h> | ||||
| #include <gtkmm/image.h> | ||||
| #include <gtkmm/label.h> | ||||
| #include <wayland-client.h> | ||||
|  | ||||
| #include <map> | ||||
| #include <memory> | ||||
| #include <string> | ||||
| #include <unordered_set> | ||||
| #include <vector> | ||||
|  | ||||
| #include "AModule.hpp" | ||||
| #include "bar.hpp" | ||||
| #include "client.hpp" | ||||
| #include "giomm/desktopappinfo.h" | ||||
| #include "util/json.hpp" | ||||
|  | ||||
| #include <memory> | ||||
| #include <string> | ||||
| #include <vector> | ||||
| #include <map> | ||||
| #include <unordered_set> | ||||
|  | ||||
| #include <gdk/gdk.h> | ||||
|  | ||||
| #include <glibmm/refptr.h> | ||||
|  | ||||
| #include <gtkmm/box.h> | ||||
| #include <gtkmm/button.h> | ||||
| #include <gtkmm/image.h> | ||||
| #include <gtkmm/label.h> | ||||
| #include <gtkmm/icontheme.h> | ||||
|  | ||||
| #include <wayland-client.h> | ||||
| #include "wlr-foreign-toplevel-management-unstable-v1-client-protocol.h" | ||||
|  | ||||
|  | ||||
| namespace waybar::modules::wlr { | ||||
|  | ||||
| class Taskbar; | ||||
|  | ||||
| class Task | ||||
| { | ||||
|    public: | ||||
|     Task(const waybar::Bar&, const Json::Value&, Taskbar*, | ||||
|          struct zwlr_foreign_toplevel_handle_v1 *, struct wl_seat*); | ||||
|     ~Task(); | ||||
| class Task { | ||||
|  public: | ||||
|   Task(const waybar::Bar &, const Json::Value &, Taskbar *, | ||||
|        struct zwlr_foreign_toplevel_handle_v1 *, struct wl_seat *); | ||||
|   ~Task(); | ||||
|  | ||||
|    public: | ||||
|     enum State { | ||||
|         MAXIMIZED = (1 << 0), | ||||
|         MINIMIZED = (1 << 1), | ||||
|         ACTIVE = (1 << 2), | ||||
|         FULLSCREEN = (1 << 3), | ||||
|         INVALID = (1 << 4) | ||||
|     }; | ||||
|  public: | ||||
|   enum State { | ||||
|     MAXIMIZED = (1 << 0), | ||||
|     MINIMIZED = (1 << 1), | ||||
|     ACTIVE = (1 << 2), | ||||
|     FULLSCREEN = (1 << 3), | ||||
|     INVALID = (1 << 4) | ||||
|   }; | ||||
|  | ||||
|    private: | ||||
|     static uint32_t global_id; | ||||
|  private: | ||||
|   static uint32_t global_id; | ||||
|  | ||||
|    private: | ||||
|     const waybar::Bar &bar_; | ||||
|     const Json::Value &config_; | ||||
|     Taskbar *tbar_; | ||||
|     struct zwlr_foreign_toplevel_handle_v1 *handle_; | ||||
|     struct wl_seat *seat_; | ||||
|  private: | ||||
|   const waybar::Bar &bar_; | ||||
|   const Json::Value &config_; | ||||
|   Taskbar *tbar_; | ||||
|   struct zwlr_foreign_toplevel_handle_v1 *handle_; | ||||
|   struct wl_seat *seat_; | ||||
|  | ||||
|     uint32_t id_; | ||||
|   uint32_t id_; | ||||
|  | ||||
|     Gtk::Button button_; | ||||
|     Gtk::Box content_; | ||||
|     Gtk::Image icon_; | ||||
|     Gtk::Label text_before_; | ||||
|     Gtk::Label text_after_; | ||||
|     Glib::RefPtr<Gio::DesktopAppInfo> app_info_; | ||||
|     bool button_visible_ = false; | ||||
|     bool ignored_ = false; | ||||
|   Gtk::Button button_; | ||||
|   Gtk::Box content_; | ||||
|   Gtk::Image icon_; | ||||
|   Gtk::Label text_before_; | ||||
|   Gtk::Label text_after_; | ||||
|   Glib::RefPtr<Gio::DesktopAppInfo> app_info_; | ||||
|   bool button_visible_ = false; | ||||
|   bool ignored_ = false; | ||||
|  | ||||
|     bool with_icon_ = false; | ||||
|     bool with_name_ = false; | ||||
|     std::string format_before_; | ||||
|     std::string format_after_; | ||||
|   bool with_icon_ = false; | ||||
|   bool with_name_ = false; | ||||
|   std::string format_before_; | ||||
|   std::string format_after_; | ||||
|  | ||||
|     std::string format_tooltip_; | ||||
|   std::string format_tooltip_; | ||||
|  | ||||
|     std::string name_; | ||||
|     std::string title_; | ||||
|     std::string app_id_; | ||||
|     uint32_t state_ = 0; | ||||
|   std::string name_; | ||||
|   std::string title_; | ||||
|   std::string app_id_; | ||||
|   uint32_t state_ = 0; | ||||
|  | ||||
|    private: | ||||
|     std::string repr() const; | ||||
|     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(); | ||||
|  private: | ||||
|   std::string repr() const; | ||||
|   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 */ | ||||
|     uint32_t id() const { return id_; } | ||||
|     std::string title() const { return title_; } | ||||
|     std::string app_id() const { return app_id_; } | ||||
|     uint32_t state() const { return state_; } | ||||
|     bool maximized() const { return state_ & MAXIMIZED; } | ||||
|     bool minimized() const { return state_ & MINIMIZED; } | ||||
|     bool active() const { return state_ & ACTIVE; } | ||||
|     bool fullscreen() const { return state_ & FULLSCREEN; } | ||||
|  public: | ||||
|   /* Getter functions */ | ||||
|   uint32_t id() const { return id_; } | ||||
|   std::string title() const { return title_; } | ||||
|   std::string app_id() const { return app_id_; } | ||||
|   uint32_t state() const { return state_; } | ||||
|   bool maximized() const { return state_ & MAXIMIZED; } | ||||
|   bool minimized() const { return state_ & MINIMIZED; } | ||||
|   bool active() const { return state_ & ACTIVE; } | ||||
|   bool fullscreen() const { return state_ & FULLSCREEN; } | ||||
|  | ||||
|    public: | ||||
|     /* Callbacks for the wlr protocol */ | ||||
|     void handle_title(const char *); | ||||
|     void handle_app_id(const char *); | ||||
|     void handle_output_enter(struct wl_output *); | ||||
|     void handle_output_leave(struct wl_output *); | ||||
|     void handle_state(struct wl_array *); | ||||
|     void handle_done(); | ||||
|     void handle_closed(); | ||||
|  public: | ||||
|   /* Callbacks for the wlr protocol */ | ||||
|   void handle_title(const char *); | ||||
|   void handle_app_id(const char *); | ||||
|   void handle_output_enter(struct wl_output *); | ||||
|   void handle_output_leave(struct wl_output *); | ||||
|   void handle_state(struct wl_array *); | ||||
|   void handle_done(); | ||||
|   void handle_closed(); | ||||
|  | ||||
|     /* Callbacks for Gtk events */ | ||||
|     bool handle_clicked(GdkEventButton *); | ||||
|   /* Callbacks for Gtk events */ | ||||
|   bool handle_clicked(GdkEventButton *); | ||||
|  | ||||
|   public: | ||||
|     bool operator==(const Task&) const; | ||||
|     bool operator!=(const Task&) const; | ||||
|  public: | ||||
|   bool operator==(const Task &) const; | ||||
|   bool operator!=(const Task &) const; | ||||
|  | ||||
|   public: | ||||
|     void update(); | ||||
|  public: | ||||
|   void update(); | ||||
|  | ||||
|   public: | ||||
|     /* Interaction with the tasks */ | ||||
|     void maximize(bool); | ||||
|     void minimize(bool); | ||||
|     void activate(); | ||||
|     void fullscreen(bool); | ||||
|     void close(); | ||||
|  public: | ||||
|   /* Interaction with the tasks */ | ||||
|   void maximize(bool); | ||||
|   void minimize(bool); | ||||
|   void activate(); | ||||
|   void fullscreen(bool); | ||||
|   void close(); | ||||
| }; | ||||
|  | ||||
| using TaskPtr = std::unique_ptr<Task>; | ||||
|  | ||||
| class Taskbar : public waybar::AModule { | ||||
|  public: | ||||
|   Taskbar(const std::string &, const waybar::Bar &, const Json::Value &); | ||||
|   ~Taskbar(); | ||||
|   void update(); | ||||
|  | ||||
| class Taskbar : public waybar::AModule | ||||
| { | ||||
|    public: | ||||
|     Taskbar(const std::string&, const waybar::Bar&, const Json::Value&); | ||||
|     ~Taskbar(); | ||||
|     void update(); | ||||
|  private: | ||||
|   const waybar::Bar &bar_; | ||||
|   Gtk::Box box_; | ||||
|   std::vector<TaskPtr> tasks_; | ||||
|  | ||||
|    private: | ||||
|     const waybar::Bar &bar_; | ||||
|     Gtk::Box box_; | ||||
|     std::vector<TaskPtr> tasks_; | ||||
|   std::vector<Glib::RefPtr<Gtk::IconTheme>> icon_themes_; | ||||
|   std::unordered_set<std::string> ignore_list_; | ||||
|   std::map<std::string, std::string> app_ids_replace_map_; | ||||
|  | ||||
|     std::vector<Glib::RefPtr<Gtk::IconTheme>> icon_themes_; | ||||
|     std::unordered_set<std::string> ignore_list_; | ||||
|     std::map<std::string, std::string> app_ids_replace_map_; | ||||
|   struct zwlr_foreign_toplevel_manager_v1 *manager_; | ||||
|   struct wl_seat *seat_; | ||||
|  | ||||
|     struct zwlr_foreign_toplevel_manager_v1 *manager_; | ||||
|     struct wl_seat *seat_; | ||||
|  public: | ||||
|   /* Callbacks for global registration */ | ||||
|   void register_manager(struct wl_registry *, uint32_t name, uint32_t version); | ||||
|   void register_seat(struct wl_registry *, uint32_t name, uint32_t version); | ||||
|  | ||||
|    public: | ||||
|     /* Callbacks for global registration */ | ||||
|     void register_manager(struct wl_registry*, uint32_t name, uint32_t version); | ||||
|     void register_seat(struct wl_registry*, uint32_t name, uint32_t version); | ||||
|   /* Callbacks for the wlr protocol */ | ||||
|   void handle_toplevel_create(struct zwlr_foreign_toplevel_handle_v1 *); | ||||
|   void handle_finished(); | ||||
|  | ||||
|     /* Callbacks for the wlr protocol */ | ||||
|     void handle_toplevel_create(struct zwlr_foreign_toplevel_handle_v1 *); | ||||
|     void handle_finished(); | ||||
|  public: | ||||
|   void add_button(Gtk::Button &); | ||||
|   void move_button(Gtk::Button &, int); | ||||
|   void remove_button(Gtk::Button &); | ||||
|   void remove_task(uint32_t); | ||||
|  | ||||
|    public: | ||||
|     void add_button(Gtk::Button &); | ||||
|     void move_button(Gtk::Button &, int); | ||||
|     void remove_button(Gtk::Button &); | ||||
|     void remove_task(uint32_t); | ||||
|   bool show_output(struct wl_output *) const; | ||||
|   bool all_outputs() const; | ||||
|  | ||||
|     bool show_output(struct wl_output *) const; | ||||
|     bool all_outputs() const; | ||||
|  | ||||
|     const std::vector<Glib::RefPtr<Gtk::IconTheme>>& icon_themes() const; | ||||
|     const std::unordered_set<std::string>& ignore_list() const; | ||||
|     const std::map<std::string, std::string>& app_ids_replace_map() const; | ||||
|   const std::vector<Glib::RefPtr<Gtk::IconTheme>> &icon_themes() const; | ||||
|   const std::unordered_set<std::string> &ignore_list() const; | ||||
|   const std::map<std::string, std::string> &app_ids_replace_map() const; | ||||
| }; | ||||
|  | ||||
| } /* namespace waybar::modules::wlr */ | ||||
|   | ||||
| @@ -53,24 +53,24 @@ class Workspace { | ||||
|  private: | ||||
|   auto get_icon() -> std::string; | ||||
|  | ||||
|   const Bar         &bar_; | ||||
|   const Bar &bar_; | ||||
|   const Json::Value &config_; | ||||
|   WorkspaceGroup    &workspace_group_; | ||||
|   WorkspaceGroup &workspace_group_; | ||||
|  | ||||
|   // wlr stuff | ||||
|   zext_workspace_handle_v1 *workspace_handle_; | ||||
|   uint32_t                  state_ = 0; | ||||
|   uint32_t state_ = 0; | ||||
|  | ||||
|   uint32_t                                  id_; | ||||
|   std::string                               name_; | ||||
|   std::vector<uint32_t>                     coordinates_; | ||||
|   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; | ||||
|   std::string format_; | ||||
|   bool with_icon_ = false; | ||||
|  | ||||
|   Gtk::Button button_; | ||||
|   Gtk::Box    content_; | ||||
|   Gtk::Label  label_; | ||||
|   Gtk::Box content_; | ||||
|   Gtk::Label label_; | ||||
| }; | ||||
|  | ||||
| class WorkspaceGroup { | ||||
| @@ -102,19 +102,19 @@ class WorkspaceGroup { | ||||
|   auto commit() -> void; | ||||
|  | ||||
|  private: | ||||
|   static uint32_t    workspace_global_id; | ||||
|   static uint32_t workspace_global_id; | ||||
|   const waybar::Bar &bar_; | ||||
|   Gtk::Box          &box_; | ||||
|   Gtk::Box &box_; | ||||
|   const Json::Value &config_; | ||||
|   WorkspaceManager  &workspace_manager_; | ||||
|   WorkspaceManager &workspace_manager_; | ||||
|  | ||||
|   // wlr stuff | ||||
|   zext_workspace_group_handle_v1 *workspace_group_handle_; | ||||
|   wl_output                      *output_ = nullptr; | ||||
|   wl_output *output_ = nullptr; | ||||
|  | ||||
|   uint32_t                                id_; | ||||
|   uint32_t id_; | ||||
|   std::vector<std::unique_ptr<Workspace>> workspaces_; | ||||
|   bool                                    need_to_sort = false; | ||||
|   bool need_to_sort = false; | ||||
| }; | ||||
|  | ||||
| class WorkspaceManager : public AModule { | ||||
| @@ -141,8 +141,8 @@ class WorkspaceManager : public AModule { | ||||
|   auto commit() -> void; | ||||
|  | ||||
|  private: | ||||
|   const waybar::Bar                           &bar_; | ||||
|   Gtk::Box                                     box_; | ||||
|   const waybar::Bar &bar_; | ||||
|   Gtk::Box box_; | ||||
|   std::vector<std::unique_ptr<WorkspaceGroup>> groups_; | ||||
|  | ||||
|   // wlr stuff | ||||
|   | ||||
| @@ -1,8 +1,10 @@ | ||||
| #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); | ||||
| } | ||||
| 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); | ||||
| }  // namespace waybar::modules::wlr | ||||
|   | ||||
| @@ -64,10 +64,10 @@ struct SafeSignal : sigc::signal<void(std::decay_t<Args>...)> { | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   Glib::Dispatcher        dp_; | ||||
|   std::mutex              mutex_; | ||||
|   Glib::Dispatcher dp_; | ||||
|   std::mutex mutex_; | ||||
|   std::queue<arg_tuple_t> queue_; | ||||
|   const std::thread::id   main_tid_ = std::this_thread::get_id(); | ||||
|   const std::thread::id main_tid_ = std::this_thread::get_id(); | ||||
|   // cache functor for signal emission to avoid recreating it on each event | ||||
|   const slot_t cached_fn_ = make_slot(); | ||||
| }; | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -20,13 +20,13 @@ extern std::list<pid_t> reap; | ||||
| namespace waybar::util::command { | ||||
|  | ||||
| struct res { | ||||
|   int         exit_code; | ||||
|   int exit_code; | ||||
|   std::string out; | ||||
| }; | ||||
|  | ||||
| inline std::string read(FILE* fp) { | ||||
|   std::array<char, 128> buffer = {0}; | ||||
|   std::string           output; | ||||
|   std::string output; | ||||
|   while (feof(fp) == 0) { | ||||
|     if (fgets(buffer.data(), 128, fp) != nullptr) { | ||||
|       output += buffer.data(); | ||||
| @@ -68,7 +68,7 @@ inline int close(FILE* fp, pid_t pid) { | ||||
| inline FILE* open(const std::string& cmd, int& pid) { | ||||
|   if (cmd == "") return nullptr; | ||||
|   int fd[2]; | ||||
|   if (pipe(fd) != 0){ | ||||
|   if (pipe(fd) != 0) { | ||||
|     spdlog::error("Unable to pipe fd"); | ||||
|     return nullptr; | ||||
|   } | ||||
| @@ -112,7 +112,7 @@ inline FILE* open(const std::string& cmd, int& pid) { | ||||
| } | ||||
|  | ||||
| inline struct res exec(const std::string& cmd) { | ||||
|   int  pid; | ||||
|   int pid; | ||||
|   auto fp = command::open(cmd, pid); | ||||
|   if (!fp) return {-1, ""}; | ||||
|   auto output = command::read(fp); | ||||
| @@ -121,7 +121,7 @@ inline struct res exec(const std::string& cmd) { | ||||
| } | ||||
|  | ||||
| inline struct res execNoRead(const std::string& cmd) { | ||||
|   int  pid; | ||||
|   int pid; | ||||
|   auto fp = command::open(cmd, pid); | ||||
|   if (!fp) return {-1, ""}; | ||||
|   auto stat = command::close(fp, pid); | ||||
|   | ||||
| @@ -4,96 +4,94 @@ | ||||
| #include <glibmm/ustring.h> | ||||
|  | ||||
| class pow_format { | ||||
|   public: | ||||
|     pow_format(long long val, std::string&& unit, bool binary = false): | ||||
|       val_(val), unit_(unit), binary_(binary) { }; | ||||
|  public: | ||||
|   pow_format(long long val, std::string&& unit, bool binary = false) | ||||
|       : val_(val), unit_(unit), binary_(binary){}; | ||||
|  | ||||
|     long long val_; | ||||
|     std::string unit_; | ||||
|     bool binary_; | ||||
|   long long val_; | ||||
|   std::string unit_; | ||||
|   bool binary_; | ||||
| }; | ||||
|  | ||||
|  | ||||
| namespace fmt { | ||||
|   template <> | ||||
|     struct formatter<pow_format> { | ||||
|       char spec = 0; | ||||
|       int width = 0; | ||||
| template <> | ||||
| struct formatter<pow_format> { | ||||
|   char spec = 0; | ||||
|   int width = 0; | ||||
|  | ||||
|       template <typename ParseContext> | ||||
|         constexpr auto parse(ParseContext& ctx) -> decltype (ctx.begin()) { | ||||
|           auto it = ctx.begin(), end = ctx.end(); | ||||
|           if (it != end && *it == ':') ++it; | ||||
|           if (it && (*it == '>' || *it == '<' || *it == '=')) { | ||||
|             spec = *it; | ||||
|             ++it; | ||||
|           } | ||||
|           if (it == end || *it == '}') return it; | ||||
|           if ('0' <= *it && *it <= '9') { | ||||
|             // We ignore it for now, but keep it for compatibility with | ||||
|             // existing configs where the format for pow_format'ed numbers was | ||||
|             // 'string' and specifications such as {:>9} were valid. | ||||
|             // The rationale for ignoring it is that the only reason to specify | ||||
|             // an alignment and a with is to get a fixed width bar, and ">" is | ||||
|             // sufficient in this implementation. | ||||
|   template <typename ParseContext> | ||||
|   constexpr auto parse(ParseContext& ctx) -> decltype(ctx.begin()) { | ||||
|     auto it = ctx.begin(), end = ctx.end(); | ||||
|     if (it != end && *it == ':') ++it; | ||||
|     if (it && (*it == '>' || *it == '<' || *it == '=')) { | ||||
|       spec = *it; | ||||
|       ++it; | ||||
|     } | ||||
|     if (it == end || *it == '}') return it; | ||||
|     if ('0' <= *it && *it <= '9') { | ||||
|       // We ignore it for now, but keep it for compatibility with | ||||
|       // existing configs where the format for pow_format'ed numbers was | ||||
|       // 'string' and specifications such as {:>9} were valid. | ||||
|       // The rationale for ignoring it is that the only reason to specify | ||||
|       // an alignment and a with is to get a fixed width bar, and ">" is | ||||
|       // sufficient in this implementation. | ||||
| #if FMT_VERSION < 80000 | ||||
|             width = parse_nonnegative_int(it, end, ctx); | ||||
|       width = parse_nonnegative_int(it, end, ctx); | ||||
| #else | ||||
|             width = detail::parse_nonnegative_int(it, end, -1); | ||||
|       width = detail::parse_nonnegative_int(it, end, -1); | ||||
| #endif | ||||
|           } | ||||
|           return it; | ||||
|         } | ||||
|     } | ||||
|     return it; | ||||
|   } | ||||
|  | ||||
|       template<class FormatContext> | ||||
|         auto format(const pow_format& s, FormatContext &ctx) -> decltype (ctx.out()) { | ||||
|           const char* units[] = { "", "k",  "M",  "G",  "T",  "P",  nullptr}; | ||||
|   template <class FormatContext> | ||||
|   auto format(const pow_format& s, FormatContext& ctx) -> decltype(ctx.out()) { | ||||
|     const char* units[] = {"", "k", "M", "G", "T", "P", nullptr}; | ||||
|  | ||||
|           auto base = s.binary_ ? 1024ull : 1000ll; | ||||
|           auto fraction = (double) s.val_; | ||||
|     auto base = s.binary_ ? 1024ull : 1000ll; | ||||
|     auto fraction = (double)s.val_; | ||||
|  | ||||
|           int pow; | ||||
|           for (pow = 0; units[pow+1] != nullptr && fraction / base >= 1; ++pow) { | ||||
|             fraction /= base; | ||||
|           } | ||||
|     int pow; | ||||
|     for (pow = 0; units[pow + 1] != nullptr && fraction / base >= 1; ++pow) { | ||||
|       fraction /= base; | ||||
|     } | ||||
|  | ||||
|           auto max_width = 4                  // coeff in {:.3g} format | ||||
|                          + 1                  // prefix from units array | ||||
|                          + s.binary_          // for the 'i' in GiB. | ||||
|                          + s.unit_.length(); | ||||
|     auto max_width = 4            // coeff in {:.3g} format | ||||
|                      + 1          // prefix from units array | ||||
|                      + s.binary_  // for the 'i' in GiB. | ||||
|                      + s.unit_.length(); | ||||
|  | ||||
|           const char * format; | ||||
|           std::string string; | ||||
|           switch (spec) { | ||||
|             case '>': | ||||
|               return format_to(ctx.out(), "{:>{}}", fmt::format("{}", s), max_width); | ||||
|             case '<': | ||||
|               return format_to(ctx.out(), "{:<{}}", fmt::format("{}", s), max_width); | ||||
|             case '=': | ||||
|               format = "{coefficient:<4.3g}{padding}{prefix}{unit}"; | ||||
|               break; | ||||
|             case 0: | ||||
|             default: | ||||
|               format = "{coefficient:.3g}{prefix}{unit}"; | ||||
|               break; | ||||
|           } | ||||
|           return format_to(ctx.out(), format | ||||
|               , fmt::arg("coefficient", fraction) | ||||
|               , fmt::arg("prefix", std::string() + units[pow] + ((s.binary_ && pow) ? "i" : "")) | ||||
|               , fmt::arg("unit", s.unit_) | ||||
|               , fmt::arg("padding", pow ? "" : s.binary_ ? "  " : " ") | ||||
|             ); | ||||
|         } | ||||
|     }; | ||||
|  | ||||
|  | ||||
|     // Glib ustirng support | ||||
|     template <> | ||||
|     struct formatter<Glib::ustring> : formatter<std::string> { | ||||
|       template <typename FormatContext> | ||||
|       auto format(const Glib::ustring& value, FormatContext& ctx) { | ||||
|         return formatter<std::string>::format(value, ctx); | ||||
|       } | ||||
|     }; | ||||
| } | ||||
|     const char* format; | ||||
|     std::string string; | ||||
|     switch (spec) { | ||||
|       case '>': | ||||
|         return format_to(ctx.out(), "{:>{}}", fmt::format("{}", s), max_width); | ||||
|       case '<': | ||||
|         return format_to(ctx.out(), "{:<{}}", fmt::format("{}", s), max_width); | ||||
|       case '=': | ||||
|         format = "{coefficient:<4.3g}{padding}{prefix}{unit}"; | ||||
|         break; | ||||
|       case 0: | ||||
|       default: | ||||
|         format = "{coefficient:.3g}{prefix}{unit}"; | ||||
|         break; | ||||
|     } | ||||
|     return format_to( | ||||
|         ctx.out(), format, fmt::arg("coefficient", fraction), | ||||
|         fmt::arg("prefix", std::string() + units[pow] + ((s.binary_ && pow) ? "i" : "")), | ||||
|         fmt::arg("unit", s.unit_), | ||||
|         fmt::arg("padding", pow         ? "" | ||||
|                             : s.binary_ ? "  " | ||||
|                                         : " ")); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| // Glib ustirng support | ||||
| template <> | ||||
| struct formatter<Glib::ustring> : formatter<std::string> { | ||||
|   template <typename FormatContext> | ||||
|   auto format(const Glib::ustring& value, FormatContext& ctx) { | ||||
|     return formatter<std::string>::format(value, ctx); | ||||
|   } | ||||
| }; | ||||
| }  // namespace fmt | ||||
|   | ||||
| @@ -13,7 +13,7 @@ struct JsonParser { | ||||
|       return root; | ||||
|     } | ||||
|     std::unique_ptr<Json::CharReader> const reader(builder_.newCharReader()); | ||||
|     std::string                             err; | ||||
|     std::string err; | ||||
|     bool res = reader->parse(data.c_str(), data.c_str() + data.size(), &root, &err); | ||||
|     if (!res) throw std::runtime_error(err); | ||||
|     return root; | ||||
|   | ||||
| @@ -17,8 +17,8 @@ class Rfkill : public sigc::trackable { | ||||
|  | ||||
|  private: | ||||
|   enum rfkill_type rfkill_type_; | ||||
|   bool             state_ = false; | ||||
|   int              fd_ = -1; | ||||
|   bool state_ = false; | ||||
|   int fd_ = -1; | ||||
|  | ||||
|   bool on_event(Glib::IOCondition cond); | ||||
| }; | ||||
|   | ||||
| @@ -17,7 +17,8 @@ namespace waybar::util { | ||||
|  */ | ||||
| class CancellationGuard { | ||||
|   int oldstate; | ||||
| public: | ||||
|  | ||||
|  public: | ||||
|   CancellationGuard() { pthread_setcancelstate(PTHREAD_CANCEL_DISABLE, &oldstate); } | ||||
|   ~CancellationGuard() { pthread_setcancelstate(oldstate, &oldstate); } | ||||
| }; | ||||
| @@ -47,7 +48,7 @@ class SleeperThread { | ||||
|   bool isRunning() const { return do_run_; } | ||||
|  | ||||
|   auto sleep_for(std::chrono::system_clock::duration dur) { | ||||
|     std::unique_lock  lk(mutex_); | ||||
|     std::unique_lock lk(mutex_); | ||||
|     CancellationGuard cancel_lock; | ||||
|     return condvar_.wait_for(lk, dur, [this] { return signal_ || !do_run_; }); | ||||
|   } | ||||
| @@ -55,7 +56,7 @@ class SleeperThread { | ||||
|   auto sleep_until( | ||||
|       std::chrono::time_point<std::chrono::system_clock, std::chrono::system_clock::duration> | ||||
|           time_point) { | ||||
|     std::unique_lock  lk(mutex_); | ||||
|     std::unique_lock lk(mutex_); | ||||
|     CancellationGuard cancel_lock; | ||||
|     return condvar_.wait_until(lk, time_point, [this] { return signal_ || !do_run_; }); | ||||
|   } | ||||
| @@ -90,11 +91,11 @@ class SleeperThread { | ||||
|   } | ||||
|  | ||||
|  private: | ||||
|   std::thread             thread_; | ||||
|   std::thread thread_; | ||||
|   std::condition_variable condvar_; | ||||
|   std::mutex              mutex_; | ||||
|   bool                    do_run_ = true; | ||||
|   bool                    signal_ = false; | ||||
|   std::mutex mutex_; | ||||
|   bool do_run_ = true; | ||||
|   bool signal_ = false; | ||||
| }; | ||||
|  | ||||
| }  // namespace waybar::util | ||||
|   | ||||
| @@ -6,7 +6,7 @@ | ||||
| namespace waybar { | ||||
|  | ||||
| struct waybar_time { | ||||
|   std::locale         locale; | ||||
|   std::locale locale; | ||||
|   date::zoned_seconds ztime; | ||||
| }; | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Alex
					Alex