From 11c98f13e3dd3fecade215c431626de4d9ab77df Mon Sep 17 00:00:00 2001 From: Robinhuett <5955614+Robinhuett@users.noreply.github.com> Date: Wed, 26 Dec 2018 03:52:05 +0100 Subject: [PATCH] feat(custom): Add format-icons to custom module This commit allows custom modules (json only) to set a percentage. This can be displayed either by using {percentage} or by using {icon} with format-icons set. --- include/modules/custom.hpp | 2 ++ src/modules/custom.cpp | 22 +++++++++++++++++++++- 2 files changed, 23 insertions(+), 1 deletion(-) diff --git a/include/modules/custom.hpp b/include/modules/custom.hpp index 937ab76f..b429a840 100644 --- a/include/modules/custom.hpp +++ b/include/modules/custom.hpp @@ -19,12 +19,14 @@ class Custom : public ALabel { void continuousWorker(); void parseOutputRaw(); void parseOutputJson(); + bool isInteger(const std::string&); const std::string name_; std::string text_; std::string tooltip_; std::string class_; std::string prevclass_; + int percentage_; waybar::util::SleeperThread thread_; waybar::util::command::res output_; waybar::util::JsonParser parser_; diff --git a/src/modules/custom.cpp b/src/modules/custom.cpp index 68d98462..2bcb35b3 100644 --- a/src/modules/custom.cpp +++ b/src/modules/custom.cpp @@ -87,7 +87,9 @@ auto waybar::modules::Custom::update() -> void parseOutputRaw(); } - auto str = fmt::format(format_, text_); + auto str = fmt::format(format_, text_, + fmt::arg("icon", getIcon(percentage_)), + fmt::arg("percentage", percentage_)); label_.set_markup(str); if (text_ == tooltip_) { label_.set_tooltip_text(str); @@ -130,6 +132,19 @@ void waybar::modules::Custom::parseOutputRaw() } } +bool waybar::modules::Custom::isInteger(const std::string& n) +{ + if (std::isdigit(n[0]) || (n.size() > 1 && (n[0] == '-' || n[0] == '+'))) { + for (std::string::size_type i{ 1 }; i < n.size(); ++i) { + if (!std::isdigit(n[i])) { + return false; + } + } + return true; + } + return false; +} + void waybar::modules::Custom::parseOutputJson() { std::istringstream output(output_.out); @@ -139,6 +154,11 @@ void waybar::modules::Custom::parseOutputJson() text_ = parsed["text"].asString(); tooltip_ = parsed["tooltip"].asString(); class_ = parsed["class"].asString(); + if (!parsed["percentage"].asString().empty() && isInteger(parsed["percentage"].asString())) { + percentage_ = std::stoi(parsed["percentage"].asString(), nullptr); + } else { + percentage_ = 0; + } break; } }