X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;ds=sidebyside;f=webcit%2Fical_dezonify.c;h=f20be42795efb2b46b19cb90b9098f72ddd85b29;hb=16c0a868a43e20d7172692cda62d35f5100ac58e;hp=de444a9d5522a791e5a56083c0195b9de0323dcf;hpb=29d91a0edee2565fd59b5b5a20963e73d528a5cf;p=citadel.git diff --git a/webcit/ical_dezonify.c b/webcit/ical_dezonify.c index de444a9d5..f20be4279 100644 --- a/webcit/ical_dezonify.c +++ b/webcit/ical_dezonify.c @@ -1,20 +1,17 @@ -/* - * Function to go through an ical component set and convert all non-UTC - * date/time properties to UTC. It also strips out any VTIMEZONE - * subcomponents afterwards, because they're irrelevant. - * - * Everything here will work on both a fully encapsulated VCALENDAR component - * or any type of subcomponent. - */ +// Function to go through an ical component set and convert all non-UTC +// date/time properties to UTC. It also strips out any VTIMEZONE +// subcomponents afterwards, because they're irrelevant. +// +// Everything here will work on both components and subcomponents. If subcomponents are discovered it will recurse through them. +// +// Copyright (c) 2002-2024 by the citadel.org team (Art Cancro et al) +// This program is open source software. Use, duplication, or disclosure is subject to the GNU General Public License v3. #include "webcit.h" #include "webserver.h" -/* - * Figure out which time zone needs to be used for timestamps that are - * not UTC and do not have a time zone specified. - * - */ +// Figure out which time zone needs to be used for timestamps that are +// not UTC and do not have a time zone specified. icaltimezone *get_default_icaltimezone(void) { icaltimezone *zone = NULL; @@ -34,34 +31,30 @@ icaltimezone *get_default_icaltimezone(void) { } -/* - * Back end function for ical_dezonify() - * - * We supply this with the master component, the relevant component, - * and the property (which will be a DTSTART, DTEND, etc.) - * which we want to convert to UTC. - */ -void ical_dezonify_backend(icalcomponent *cal, - icalcomponent *rcal, - icalproperty *prop) { +// Back end function for ical_dezonify() +// +// We supply this with the master component, the relevant component, +// and the property (which will be a DTSTART, DTEND, etc.) +// which we want to convert to UTC. +void ical_dezonify_backend(icalcomponent *cal, icalcomponent *rcal, icalproperty *prop) { icaltimezone *t = NULL; icalparameter *param; const char *tzid = NULL; struct icaltimetype TheTime; - int utc_declared_as_tzid = 0; /* Component declared 'TZID=GMT' instead of using Z syntax */ + int utc_declared_as_tzid = 0; // Component declared 'TZID=GMT' instead of using Z syntax - /* Give me nothing and I will give you nothing in return. */ + // Give me nothing and I will give you nothing in return. if (cal == NULL) return; - /* Hunt for a TZID parameter in this property. */ + // Hunt for a TZID parameter in this property. param = icalproperty_get_first_parameter(prop, ICAL_TZID_PARAMETER); - /* Get the stringish name of this TZID. */ + // Get the stringish name of this TZID. if (param != NULL) { tzid = icalparameter_get_tzid(param); - /* Convert it to an icaltimezone type. */ + // Convert it to an icaltimezone type. if (tzid != NULL) { #ifdef DBG_ICAL syslog(LOG_DEBUG, " * Stringy supplied timezone is: '%s'\n", tzid); @@ -73,14 +66,14 @@ void ical_dezonify_backend(icalcomponent *cal, #endif } else { - /* try attached first */ + // try attached first t = icalcomponent_get_timezone(cal, tzid); #ifdef DBG_ICAL syslog(LOG_DEBUG, " * ...and I %s have tzdata for that zone.\n", (t ? "DO" : "DO NOT") ); #endif - /* then try built-in timezones */ + // then try built-in timezones if (!t) { t = icaltimezone_get_builtin_timezone(tzid); #ifdef DBG_ICAL @@ -94,7 +87,7 @@ void ical_dezonify_backend(icalcomponent *cal, } - /* Now we know the timezone. Convert to UTC. */ + // Now we know the timezone. Convert to UTC. if (icalproperty_isa(prop) == ICAL_DTSTART_PROPERTY) { TheTime = icalproperty_get_dtstart(prop); @@ -130,7 +123,7 @@ void ical_dezonify_backend(icalcomponent *cal, } else { - /* Do the conversion. */ + // Do the conversion. if (t != NULL) { #ifdef DBG_ICAL syslog(LOG_DEBUG, " * Timezone prop found. Converting to UTC.\n"); @@ -154,7 +147,7 @@ void ical_dezonify_backend(icalcomponent *cal, syslog(LOG_DEBUG, " * Now: %s\n", icaltime_as_ical_string(TheTime)); #endif - /* Now add the converted property back in. */ + // Now add the converted property back in. if (icalproperty_isa(prop) == ICAL_DTSTART_PROPERTY) { icalproperty_set_dtstart(prop, TheTime); } @@ -170,31 +163,23 @@ void ical_dezonify_backend(icalcomponent *cal, } -/* - * Recursive portion of ical_dezonify() - */ +// Recursive portion of ical_dezonify() void ical_dezonify_recurse(icalcomponent *cal, icalcomponent *rcal) { icalcomponent *c; icalproperty *p; - /* - * Recurse through all subcomponents *except* VTIMEZONE ones. - */ - for (c=icalcomponent_get_first_component( - rcal, ICAL_ANY_COMPONENT); + // Recurse through all subcomponents *except* VTIMEZONE ones. + for ( c=icalcomponent_get_first_component(rcal, ICAL_ANY_COMPONENT); c != NULL; - c = icalcomponent_get_next_component( - rcal, ICAL_ANY_COMPONENT) + c = icalcomponent_get_next_component(rcal, ICAL_ANY_COMPONENT) ) { if (icalcomponent_isa(c) != ICAL_VTIMEZONE_COMPONENT) { ical_dezonify_recurse(cal, c); } } - /* - * Now look for DTSTART and DTEND properties - */ - for (p=icalcomponent_get_first_property(rcal, ICAL_ANY_PROPERTY); + // Now look for DTSTART and DTEND properties + for ( p=icalcomponent_get_first_property(rcal, ICAL_ANY_PROPERTY); p != NULL; p = icalcomponent_get_next_property(rcal, ICAL_ANY_PROPERTY) ) { @@ -203,18 +188,16 @@ void ical_dezonify_recurse(icalcomponent *cal, icalcomponent *rcal) { || (icalproperty_isa(p) == ICAL_DTEND_PROPERTY) || (icalproperty_isa(p) == ICAL_DUE_PROPERTY) || (icalproperty_isa(p) == ICAL_EXDATE_PROPERTY) - ) { + ) { ical_dezonify_backend(cal, rcal, p); } } } -/* - * Convert all DTSTART and DTEND properties in all subcomponents to UTC. - * This function will search any VTIMEZONE subcomponents to learn the - * relevant timezone information. - */ +// Convert all DTSTART and DTEND properties in all subcomponents to UTC. +// This function will search any VTIMEZONE subcomponents to learn the +// relevant timezone information. void ical_dezonify(icalcomponent *cal) { icalcomponent *vt = NULL; @@ -222,12 +205,11 @@ void ical_dezonify(icalcomponent *cal) { syslog(LOG_DEBUG, "ical_dezonify() started\n"); #endif - /* Convert all times to UTC */ + // Convert all times to UTC ical_dezonify_recurse(cal, cal); - /* Strip out VTIMEZONE subcomponents -- we don't need them anymore */ - while (vt = icalcomponent_get_first_component( - cal, ICAL_VTIMEZONE_COMPONENT), vt != NULL) { + // Strip out VTIMEZONE subcomponents -- we don't need them anymore. + while (vt = icalcomponent_get_first_component(cal, ICAL_VTIMEZONE_COMPONENT), vt != NULL) { icalcomponent_remove_component(cal, vt); icalcomponent_free(vt); } @@ -236,4 +218,3 @@ void ical_dezonify(icalcomponent *cal) { syslog(LOG_DEBUG, "ical_dezonify() completed\n"); #endif } -