summaryrefslogtreecommitdiff
path: root/src/ical.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/ical.c')
-rw-r--r--src/ical.c18
1 files changed, 8 insertions, 10 deletions
diff --git a/src/ical.c b/src/ical.c
index b87f0e5..4626dde 100644
--- a/src/ical.c
+++ b/src/ical.c
@@ -529,14 +529,14 @@ static time_t ical_datetime2time_t(char *datestr, ical_vevent_e * type)
static long ical_durtime2long(char *timestr)
{
- char *p;
+ char *p = timestr;
int bytes_read;
unsigned hour = 0, min = 0, sec = 0;
- if ((p = strchr(timestr, 'T')) == NULL)
+ if (*p != 'T')
return 0;
-
p++;
+
if (strchr(p, 'H')) {
if (sscanf(p, "%uH%n", &hour, &bytes_read) != 1)
return 0;
@@ -548,14 +548,11 @@ static long ical_durtime2long(char *timestr)
p += bytes_read;
}
if (strchr(p, 'S')) {
- if (sscanf(p, "%uM%n", &sec, &bytes_read) != 1)
+ if (sscanf(p, "%uS%n", &sec, &bytes_read) != 1)
return 0;
p += bytes_read;
}
- if (hour == 0 && min == 0 && sec == 0)
- return 0;
-
return hour * HOURINSEC + min * MININSEC + sec;
}
@@ -587,6 +584,7 @@ static long ical_durtime2long(char *timestr)
static long ical_dur2long(char *durstr)
{
char *p;
+ int bytes_read;
struct {
unsigned week, day;
} date;
@@ -612,9 +610,9 @@ static long ical_dur2long(char *durstr)
return date.week * WEEKINDAYS * DAYINSEC;
} else if (strchr(p, 'D')) {
/* dur-date */
- if (sscanf(p, "%uD", &date.day) == 1) {
- return date.day * DAYINSEC +
- ical_durtime2long(p);
+ if (sscanf(p, "%uD%n", &date.day, &bytes_read) == 1) {
+ p += bytes_read;
+ return date.day * DAYINSEC + ical_durtime2long(p);
}
}