mirror of
				https://github.com/rad4day/Waybar.git
				synced 2025-10-24 22:52:32 +02:00 
			
		
		
		
	fix(Custom): loop script block main loop
This commit is contained in:
		| @@ -17,6 +17,7 @@ class Custom : public ALabel { | ||||
|  | ||||
|     const std::string name_; | ||||
|     waybar::util::SleeperThread thread_; | ||||
|     waybar::util::command::res output_; | ||||
| }; | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -4,12 +4,12 @@ | ||||
|  | ||||
| namespace waybar::util::command { | ||||
|  | ||||
| struct cmd_res { | ||||
| struct res { | ||||
|   int exit_code; | ||||
|   std::string out; | ||||
| }; | ||||
|  | ||||
| inline struct cmd_res exec(const std::string cmd) | ||||
| inline struct res exec(const std::string cmd) | ||||
| { | ||||
|   FILE* fp(popen(cmd.c_str(), "r")); | ||||
|   if (!fp) { | ||||
|   | ||||
| @@ -24,6 +24,7 @@ void waybar::modules::Custom::worker() | ||||
|       } | ||||
|     } | ||||
|     if (can_update) { | ||||
|       output_ = waybar::util::command::exec(config_["exec"].asString()); | ||||
|       dp.emit(); | ||||
|     } | ||||
|     thread_.sleep_for(chrono::seconds(interval)); | ||||
| @@ -32,15 +33,13 @@ void waybar::modules::Custom::worker() | ||||
|  | ||||
| auto waybar::modules::Custom::update() -> void | ||||
| { | ||||
|   auto res = waybar::util::command::exec(config_["exec"].asString()); | ||||
|  | ||||
|   // Hide label if output is empty | ||||
|   if (res.out.empty() || res.exit_code != 0) { | ||||
|   if (output_.out.empty() || output_.exit_code != 0) { | ||||
|     label_.hide(); | ||||
|     label_.set_name(""); | ||||
|   } else { | ||||
|     label_.set_name("custom-" + name_); | ||||
|     auto str = fmt::format(format_, res.out); | ||||
|     auto str = fmt::format(format_, output_.out); | ||||
|     label_.set_text(str); | ||||
|     label_.set_tooltip_text(str); | ||||
|     label_.show(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Alexis
					Alexis