X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Frrd_restore.c;h=4cbc37adc45ebc08de59ab2fb80822055d2c7cfd;hb=c3d19fcc2618e9ab67067b4145eef9ba00bd6e72;hp=6a28e34a5d13ae665532a6844cc3c9b3823faaca;hpb=9e0553265a0b0d700d1b75891b97dc5cf1031680;p=rrdtool.git diff --git a/src/rrd_restore.c b/src/rrd_restore.c index 6a28e34..4cbc37a 100644 --- a/src/rrd_restore.c +++ b/src/rrd_restore.c @@ -219,11 +219,11 @@ static int get_xml_long( static int get_xml_ulong( xmlTextReaderPtr reader, - ulong *value) + unsigned long *value) { xmlChar *text; - ulong temp; + unsigned long temp; if ((text = get_xml_text(reader)) != NULL){ errno = 0; temp = strtoul((char *)text,NULL, 0); @@ -241,6 +241,33 @@ static int get_xml_ulong( return -1; } /* get_xml_ulong */ +#ifndef TIME_T_IS_LONG +static int get_xml_llong( + xmlTextReaderPtr reader, + long long *value) +{ + + xmlChar *text; + long long temp; + if ((text = get_xml_text(reader)) != NULL){ + errno = 0; + temp = strtoll((char *)text,NULL, 0); + if (errno>0){ + rrd_set_error("ling %d: get_xml_llong from '%s' %s", + xmlTextReaderGetParserLineNumber(reader), + text,rrd_strerror(errno)); + xmlFree(text); + return -1; + } + xmlFree(text); + *value = temp; + return 0; + } + return -1; +} /* get_xml_llong */ + +#endif + static int get_xml_double( xmlTextReaderPtr reader, double *value) @@ -986,9 +1013,24 @@ static int parse_tag_rrd( else if (xmlStrcasecmp(element, (const xmlChar *) "step") == 0) status = get_xml_ulong(reader, &rrd->stat_head->pdp_step); - else if (xmlStrcasecmp(element, (const xmlChar *) "lastupdate") == 0) - status = get_xml_long(reader, - &rrd->live_head->last_up); + else if (xmlStrcasecmp(element, (const xmlChar *) "lastupdate") == 0) { +#ifdef TIME_T_IS_LONG + status = get_xml_long(reader, &rrd->live_head->last_up); +#else +#ifdef TIME_T_IS_LONG_LONG + status = get_xml_llong(reader, &rrd->live_head->last_up); +#else + if (sizeof(time_t) == sizeof(long)) { + status = get_xml_long(reader, + (long *)&rrd->live_head->last_up); + } + else if (sizeof(time_t) == sizeof(long long)) { + status = get_xml_llong(reader, + (long long *)&rrd->live_head->last_up); + } +#endif +#endif + } else if (xmlStrcasecmp(element, (const xmlChar *) "ds") == 0){ xmlFree(element); status = parse_tag_ds(reader, rrd);