From 10d1b67452a902c682a5f774801c9c0315187ff3 Mon Sep 17 00:00:00 2001 From: Fred Date: Thu, 10 Oct 2024 20:00:59 +0100 Subject: [PATCH] fix timezone conversion (#5) --- datebook.cfg | 5 +++-- sync-calendar2.cpp | 14 ++++++++++---- 2 files changed, 13 insertions(+), 6 deletions(-) diff --git a/datebook.cfg b/datebook.cfg index 6602c14..a8d0af4 100644 --- a/datebook.cfg +++ b/datebook.cfg @@ -37,8 +37,9 @@ SECURE=true ## optional items -# local time zone (otherwise UTC is assumed) -#TIMEZONE="Europe/London" +# local time zone in TZ format, otherwise UTC is assumed (ETC/UTC) +# see https://en.wikipedia.org/wiki/List_of_tz_database_time_zones for a list of time zones +#TIMEZONE="America/New_York" # ignore calendar events from before this year (useful for very big calendars) #FROMYEAR=2023 diff --git a/sync-calendar2.cpp b/sync-calendar2.cpp index 35e9ece..4ffc9a1 100644 --- a/sync-calendar2.cpp +++ b/sync-calendar2.cpp @@ -924,6 +924,7 @@ int main(int argc, char **argv) { std::cout << " ==> Timezone Conversion <==" << std::endl << std::flush; // mktime apparently reads off the TZ environment variable + // per https://rl.se/convert-utc-to-local-time char *tz = getenv("TZ"); timezone = "TZ=" + timezone; putenv((char*)timezone.c_str()); @@ -935,15 +936,20 @@ int main(int argc, char **argv) { continue; } - // per https://rl.se/convert-utc-to-local-time convert to time_t then back to gm time_t stamp; - stamp = mktime(&Appointments[i].begin); + // timegm takes the tm struct and ignores TZ converting to time_t (assuming UTC, which it is) + // localtime take time_t and converts to a tm struct taking TZ into account + stamp = timegm(&Appointments[i].begin); Appointments[i].begin = *localtime(&stamp); - stamp = mktime(&Appointments[i].end); + stamp = timegm(&Appointments[i].end); Appointments[i].end = *localtime(&stamp); + // std::cout << " Summary: " << Appointments[i].description << std::endl; + // std::cout << " Start " << Appointments[i].begin.tm_zone << ": " << asctime(&Appointments[i].begin); + // std::cout << " End " << Appointments[i].end.tm_zone << ": " << asctime(&Appointments[i].end) << std::endl; + // repeat end? don't need to as it always is 23:59:59 on the day // loop exceptions? don't need to because also only a day } @@ -957,7 +963,7 @@ int main(int argc, char **argv) { putenv((char*)"TZ="); } - std::cout << " Converted to " << timezone.substr(3) << std::endl; + std::cout << " Converted to " << timezone.substr(3) << std::endl << std::endl; }