diff --git a/src/bar.cpp b/src/bar.cpp index 961a3215..1bbb40d1 100644 --- a/src/bar.cpp +++ b/src/bar.cpp @@ -184,7 +184,13 @@ void waybar::Bar::getModules(const Factory& factory, const std::string& pos) if (pos == "modules-right") { modules_right_.emplace_back(module); } - module->dp.connect([module] { module->update(); }); + module->dp.connect([module] { + try { + module->update(); + } catch (const std::exception& e) { + std::cerr << e.what() << std::endl; + } + }); } catch (const std::exception& e) { std::cerr << e.what() << std::endl; } diff --git a/src/modules/cpu.cpp b/src/modules/cpu.cpp index bd2b480c..91e177d2 100644 --- a/src/modules/cpu.cpp +++ b/src/modules/cpu.cpp @@ -12,16 +12,12 @@ waybar::modules::Cpu::Cpu(const Json::Value& config) auto waybar::modules::Cpu::update() -> void { - try { - // TODO: as creating dynamic fmt::arg arrays is buggy we have to calc both - auto cpu_load = getCpuLoad(); - auto [cpu_usage, tooltip] = getCpuUsage(); - label_.set_tooltip_text(tooltip); - label_.set_markup(fmt::format(format_, - fmt::arg("load", cpu_load), fmt::arg("usage", cpu_usage))); - } catch (const std::exception& e) { - std::cerr << e.what() << std::endl; - } + // TODO: as creating dynamic fmt::arg arrays is buggy we have to calc both + auto cpu_load = getCpuLoad(); + auto [cpu_usage, tooltip] = getCpuUsage(); + label_.set_tooltip_text(tooltip); + label_.set_markup(fmt::format(format_, + fmt::arg("load", cpu_load), fmt::arg("usage", cpu_usage))); } uint16_t waybar::modules::Cpu::getCpuLoad()