mirror of
				https://github.com/rad4day/Waybar.git
				synced 2025-10-25 15:12:29 +02:00 
			
		
		
		
	Add simpleclock as fallback when hhdate is not available
ref https://github.com/Alexays/Waybar/issues/668
This commit is contained in:
		| @@ -1,7 +1,11 @@ | |||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include <json/json.h> | #include <json/json.h> | ||||||
|  | #ifdef HAVE_LIBDATE | ||||||
| #include "modules/clock.hpp" | #include "modules/clock.hpp" | ||||||
|  | #else | ||||||
|  | #include "modules/simpleclock.hpp" | ||||||
|  | #endif | ||||||
| #ifdef HAVE_SWAY | #ifdef HAVE_SWAY | ||||||
| #include "modules/sway/mode.hpp" | #include "modules/sway/mode.hpp" | ||||||
| #include "modules/sway/window.hpp" | #include "modules/sway/window.hpp" | ||||||
|   | |||||||
							
								
								
									
										24
									
								
								include/modules/simpleclock.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								include/modules/simpleclock.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include <fmt/format.h> | ||||||
|  | #if FMT_VERSION < 60000 | ||||||
|  | #include <fmt/time.h> | ||||||
|  | #else | ||||||
|  | #include <fmt/chrono.h> | ||||||
|  | #endif | ||||||
|  | #include "ALabel.hpp" | ||||||
|  | #include "util/sleeper_thread.hpp" | ||||||
|  |  | ||||||
|  | namespace waybar::modules { | ||||||
|  |  | ||||||
|  | class Clock : public ALabel { | ||||||
|  |  public: | ||||||
|  |   Clock(const std::string&, const Json::Value&); | ||||||
|  |   ~Clock() = default; | ||||||
|  |   auto update() -> void; | ||||||
|  |  | ||||||
|  |  private: | ||||||
|  |   util::SleeperThread thread_; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | }  // namespace waybar::modules | ||||||
							
								
								
									
										14
									
								
								meson.build
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								meson.build
									
									
									
									
									
								
							| @@ -113,7 +113,11 @@ gtk_layer_shell = dependency('gtk-layer-shell-0', | |||||||
|         required: get_option('gtk-layer-shell'), |         required: get_option('gtk-layer-shell'), | ||||||
|         fallback : ['gtk-layer-shell', 'gtk_layer_shell_dep']) |         fallback : ['gtk-layer-shell', 'gtk_layer_shell_dep']) | ||||||
| systemd = dependency('systemd', required: get_option('systemd')) | systemd = dependency('systemd', required: get_option('systemd')) | ||||||
| tz_dep = dependency('date', default_options : [ 'use_system_tzdb=true' ], modules : [ 'date::date', 'date::date-tz' ], fallback: [ 'date', 'tz_dep' ]) | tz_dep = dependency('date', | ||||||
|  |     required: false, | ||||||
|  |     default_options : [ 'use_system_tzdb=true' ], | ||||||
|  |     modules : [ 'date::date', 'date::date-tz' ], | ||||||
|  |     fallback: [ 'date', 'tz_dep' ]) | ||||||
|  |  | ||||||
| prefix = get_option('prefix') | prefix = get_option('prefix') | ||||||
| sysconfdir = get_option('sysconfdir') | sysconfdir = get_option('sysconfdir') | ||||||
| @@ -137,7 +141,6 @@ src_files = files( | |||||||
|     'src/factory.cpp', |     'src/factory.cpp', | ||||||
|     'src/AModule.cpp', |     'src/AModule.cpp', | ||||||
|     'src/ALabel.cpp', |     'src/ALabel.cpp', | ||||||
|     'src/modules/clock.cpp', |  | ||||||
|     'src/modules/custom.cpp', |     'src/modules/custom.cpp', | ||||||
|     'src/modules/disk.cpp', |     'src/modules/disk.cpp', | ||||||
|     'src/modules/idle_inhibitor.cpp', |     'src/modules/idle_inhibitor.cpp', | ||||||
| @@ -237,6 +240,13 @@ if get_option('rfkill').enabled() | |||||||
|     endif |     endif | ||||||
| endif | endif | ||||||
|  |  | ||||||
|  | if tz_dep.found() | ||||||
|  |     add_project_arguments('-DHAVE_LIBDATE', language: 'cpp') | ||||||
|  |     src_files += 'src/modules/clock.cpp' | ||||||
|  | else | ||||||
|  |     src_files += 'src/modules/simpleclock.cpp' | ||||||
|  | endif | ||||||
|  |  | ||||||
| subdir('protocol') | subdir('protocol') | ||||||
|  |  | ||||||
| executable( | executable( | ||||||
|   | |||||||
							
								
								
									
										33
									
								
								src/modules/simpleclock.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								src/modules/simpleclock.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | #include "modules/simpleclock.hpp" | ||||||
|  | #include <time.h> | ||||||
|  |  | ||||||
|  | waybar::modules::Clock::Clock(const std::string& id, const Json::Value& config) | ||||||
|  |     : ALabel(config, "clock", id, "{:%H:%M}", 60) { | ||||||
|  |   thread_ = [this] { | ||||||
|  |     dp.emit(); | ||||||
|  |     auto now = std::chrono::system_clock::now(); | ||||||
|  |     auto timeout = std::chrono::floor<std::chrono::seconds>(now + interval_); | ||||||
|  |     auto diff = std::chrono::seconds(timeout.time_since_epoch().count() % interval_.count()); | ||||||
|  |     thread_.sleep_until(timeout - diff); | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | auto waybar::modules::Clock::update() -> void { | ||||||
|  |   tzset(); // Update timezone information | ||||||
|  |   auto now = std::chrono::system_clock::now(); | ||||||
|  |   auto localtime = fmt::localtime(std::chrono::system_clock::to_time_t(now)); | ||||||
|  |   auto text = fmt::format(format_, localtime); | ||||||
|  |   label_.set_markup(text); | ||||||
|  |  | ||||||
|  |   if (tooltipEnabled()) { | ||||||
|  |     if (config_["tooltip-format"].isString()) { | ||||||
|  |       auto tooltip_format = config_["tooltip-format"].asString(); | ||||||
|  |       auto tooltip_text = fmt::format(tooltip_format, localtime); | ||||||
|  |       label_.set_tooltip_text(tooltip_text); | ||||||
|  |     } else { | ||||||
|  |       label_.set_tooltip_text(text); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   // Call parent update | ||||||
|  |   ALabel::update(); | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user
	 Laurent Arnoud
					Laurent Arnoud