$Log$
+Revision 619.23 2005/07/14 04:02:18 ajc
+* Fix bug #147 (date sometimes saved incorrectly for all day events due
+ to timezone differences)
+
Revision 619.22 2005/07/13 16:55:59 ajc
* Use the new icons in more places.
1998-12-03 Nathan Bryant <bryant@cs.usm.maine.edu>
* webserver.c: warning fix
+
int created_new_vtodo = 0;
int i;
int sequence = 0;
+ struct icaltimetype t;
if (supplied_vtodo != NULL) {
vtodo = supplied_vtodo;
icalcomponent_remove_property(vtodo, prop);
icalproperty_free(prop);
}
+ icaltime_from_webform(&t, "dtstart");
icalcomponent_add_property(vtodo,
- icalproperty_new_dtstart(
- icaltime_from_webform("dtstart")
- )
+ icalproperty_new_dtstart(t)
);
while (prop = icalcomponent_get_first_property(vtodo,
icalcomponent_remove_property(vtodo, prop);
icalproperty_free(prop);
}
+ icaltime_from_webform(&t, "due");
icalcomponent_add_property(vtodo,
- icalproperty_new_due(
- icaltime_from_webform("due")
- )
+ icalproperty_new_due(t)
);
/* Give this task a UID if it doesn't have one. */
}
-struct icaltimetype icaltime_from_webform(char *prefix) {
- struct icaltimetype t;
- time_t tt;
- struct tm tm;
- char vname[SIZ];
+void icaltime_from_webform(struct icaltimetype *t, char *prefix) {
+ char vname[32];
+ time_t tt;
+ struct tm tm;
+ struct icaltimetype t2;
+
+ tt = time(NULL);
+ localtime_r(&tt, &tm);
+
+ sprintf(vname, "%s_month", prefix); tm.tm_mon = atoi(bstr(vname)) - 1;
+ sprintf(vname, "%s_day", prefix); tm.tm_mday = atoi(bstr(vname));
+ sprintf(vname, "%s_year", prefix); tm.tm_year = atoi(bstr(vname)) - 1900;
+ sprintf(vname, "%s_hour", prefix); tm.tm_hour = atoi(bstr(vname));
+ sprintf(vname, "%s_minute", prefix); tm.tm_min = atoi(bstr(vname));
+
+ tt = mktime(&tm);
+ t2 = icaltime_from_timet(tt, 0);
+ memcpy(t, &t2, sizeof(struct icaltimetype));
+}
+
- tt = time(NULL);
- localtime_r(&tt, &tm);
+void icaltime_from_webform_dateonly(struct icaltimetype *t, char *prefix) {
+ char vname[32];
- sprintf(vname, "%s_month", prefix); tm.tm_mon = atoi(bstr(vname)) - 1;
- sprintf(vname, "%s_day", prefix); tm.tm_mday = atoi(bstr(vname));
- sprintf(vname, "%s_year", prefix); tm.tm_year = atoi(bstr(vname)) - 1900;
- sprintf(vname, "%s_hour", prefix); tm.tm_hour = atoi(bstr(vname));
- sprintf(vname, "%s_minute", prefix); tm.tm_min = atoi(bstr(vname));
+ memset(t, 0, sizeof(struct icaltimetype));
- tt = mktime(&tm);
- t = icaltime_from_timet(tt, 0);
- t = icaltime_normalize(t);
- return(t);
+ sprintf(vname, "%s_month", prefix); t->month = atoi(bstr(vname));
+ sprintf(vname, "%s_day", prefix); t->day = atoi(bstr(vname));
+ sprintf(vname, "%s_year", prefix); t->year = atoi(bstr(vname));
+ t->is_utc = 1;
+ t->is_date = 1;
}
icalcomponent *vevent, *encaps;
int created_new_vevent = 0;
int all_day_event = 0;
- struct icaltimetype event_start;
+ struct icaltimetype event_start, t;
icalproperty *attendee = NULL;
char attendee_string[SIZ];
int i;
all_day_event = 0;
}
- event_start = icaltime_from_webform("dtstart");
if (all_day_event) {
- event_start.is_date = 1;
- event_start.hour = 0;
- event_start.minute = 0;
- event_start.second = 0;
+ icaltime_from_webform_dateonly(&event_start, "dtstart");
+ }
+ else {
+ icaltime_from_webform(&event_start, "dtstart");
}
-
/* The following odd-looking snippet of code looks like it
* takes some unnecessary steps. It is done this way because
}
if (all_day_event == 0) {
+ icaltime_from_webform(&t, "dtend");
icalcomponent_add_property(vevent,
- icalproperty_new_dtend(icaltime_normalize(
- icaltime_from_webform("dtend"))
+ icalproperty_new_dtend(icaltime_normalize(t)
)
);
}
void display_edit_event(void);
void save_event(void);
void display_icaltimetype_as_webform(struct icaltimetype *, char *);
-struct icaltimetype icaltime_from_webform(char *prefix);
+void icaltime_from_webform(struct icaltimetype *result, char *prefix);
+void icaltime_from_webform_dateonly(struct icaltimetype *result, char *prefix);
void display_edit_individual_event(icalcomponent *supplied_vtodo, long msgnum);
void save_individual_event(icalcomponent *supplied_vtodo, long msgnum);
void respond_to_request(void);