diff --git a/src/modules/cpu.cpp b/src/modules/cpu.cpp index 656436d1..880a05a5 100644 --- a/src/modules/cpu.cpp +++ b/src/modules/cpu.cpp @@ -13,20 +13,13 @@ waybar::modules::Cpu::Cpu(const std::string& id, const Json::Value& config) } auto waybar::modules::Cpu::update() -> void { - std::vector> args; - if (format_.find("{load}") != std::string::npos) { - auto cpu_load = getCpuLoad(); - args.emplace_back(fmt::internal::make_arg(fmt::arg("load", cpu_load))); + // TODO: as creating dynamic fmt::arg arrays is buggy we have to calc both + auto cpu_load = getCpuLoad(); + auto [cpu_usage, tooltip] = getCpuUsage(); + if (tooltipEnabled()) { + label_.set_tooltip_text(tooltip); } - if (format_.find("{usage}") != std::string::npos) { - auto [cpu_usage, tooltip] = getCpuUsage(); - args.emplace_back(fmt::internal::make_arg(fmt::arg("usage", cpu_usage))); - if (tooltipEnabled()) { - label_.set_tooltip_text(tooltip); - } - } - label_.set_markup( - fmt::vformat(format_, fmt::basic_format_args(args.data(), args.size()))); + label_.set_markup(fmt::format(format_, fmt::arg("load", cpu_load), fmt::arg("usage", cpu_usage))); } uint16_t waybar::modules::Cpu::getCpuLoad() {