diff --git a/data/org.freedesktop.timedate1.xml b/data/org.freedesktop.timedate1.xml index c0ffaa1..ab148da 100644 --- a/data/org.freedesktop.timedate1.xml +++ b/data/org.freedesktop.timedate1.xml @@ -7,6 +7,7 @@ + diff --git a/src/timedate.cpp b/src/timedate.cpp index 59812ad..42bacf6 100644 --- a/src/timedate.cpp +++ b/src/timedate.cpp @@ -125,12 +125,16 @@ static void slack_get_property(Glib::VariantBase& result, const Glib::RefPtr::create(dlackware::timedate::ntp_synchronized()); } + else if (prop_name == "TimeUSecRTC") + { + result = Glib::Variant::create(dlackware::timedate::time_usec_rtc()); + } } namespace dlackware::timedate { - constexpr const std::int32_t usec_per_sec = 1000000ULL; - constexpr const std::int32_t nsec_per_usec = 1000ULL; + constexpr const std::uint64_t usec_per_sec = 1000000ULL; + constexpr const std::uint64_t nsec_per_usec = 1000ULL; timedate1::timedate1() : interface_vtable{ &slack_method_call, &slack_get_property } @@ -247,7 +251,7 @@ namespace dlackware::timedate } } - void set_time(gint64 seconds_since_epoch, bool relative, bool) + void set_time(std::int64_t seconds_since_epoch, bool relative, bool) { timespec ts; @@ -333,4 +337,10 @@ namespace dlackware::timedate } return ntp_result != TIME_ERROR && (buffer.status & STA_UNSYNC) == 0; } + + std::uint64_t time_usec_rtc() + { + return std::chrono::duration_cast( + std::chrono::system_clock::now().time_since_epoch()).count(); + } } diff --git a/src/timedate.h b/src/timedate.h index 2b2d1a2..952209c 100644 --- a/src/timedate.h +++ b/src/timedate.h @@ -43,6 +43,9 @@ namespace dlackware::timedate // Shows whether the kernel reports the time as synchronized. bool ntp_synchronized(); + // Shows the current time in the RTC. + std::uint64_t time_usec_rtc(); + // Returns the timezones available on the system. std::vector list_timezones(); @@ -57,7 +60,7 @@ namespace dlackware::timedate // Changes the date/time // Takes the amount of seconds since UNIX epoche and // Throws std::system_error. - void set_time(gint64 seconds_since_epoch, bool relative, bool user_interaction); + void set_time(std::int64_t seconds_since_epoch, bool relative, bool user_interaction); class timedate1 {