Added importing of dates in CSV and XML files

SVN revision: 1916
This commit is contained in:
2007-09-18 13:14:10 +00:00
parent db334924ab
commit 343dd62147
+89
View File
@@ -436,6 +436,7 @@ int seteuser(char *str);
void strencode2(char *b, char *text, int size);
void load_config_section(char *section, char **buffer, char *error);
void remove_crlf(char *buffer);
time_t convert_date(char *date_string);
/*---- Funcions from the MIDAS library -----------------------------*/
@@ -13418,6 +13419,7 @@ void csv_import(LOGBOOK * lbs, char *csv, char *csvfile)
char *list, *line, *p, str[256], date[80], sep[80];
int i, j, n, n_attr, iline, n_imported, textcol;
BOOL first, in_quotes, filltext;
time_t ltime;
list = xmalloc(MAX_N_ATTR * NAME_LENGTH);
line = xmalloc(10000);
@@ -13515,6 +13517,18 @@ void csv_import(LOGBOOK * lbs, char *csv, char *csvfile)
continue;
}
/* interprete date entries correctly */
for (i = 0 ; i< n ; i++)
if (attr_flags[i] & AF_DATE) {
/* convert to seconds in Unix format */
ltime = convert_date(list+i*NAME_LENGTH);
if (ltime == 0) {
show_error(loc("Invalid date format"));
return;
}
sprintf(list+i*NAME_LENGTH, "%d", ltime);
}
/* check if text column is present */
if (first && isparam("filltext") && atoi(getparam("filltext"))) {
for (i = 0; i < n; i++)
@@ -13647,6 +13661,7 @@ void xml_import(LOGBOOK * lbs, char *xml, char *xmlfile)
attachment_all[64 * MAX_ATTACHMENTS];
int i, j, index, n_attr, iline, n_imported, textcol, i_line, line_len,
message_id, bedit;
time_t ltime;
PMXML_NODE root, entry;
iline = n_imported = 0;
@@ -13838,6 +13853,18 @@ void xml_import(LOGBOOK * lbs, char *xml, char *xmlfile)
strlcpy(list + i*NAME_LENGTH, mxml_get_value(mxml_find_node(entry, str)), NAME_LENGTH);
}
/* interprete date entries correctly */
for (i = 0 ; i < n_attr ; i++)
if (attr_flags[i] & AF_DATE) {
/* convert to seconds in Unix format */
ltime = convert_date(list+i*NAME_LENGTH);
if (ltime == 0) {
show_error(loc("Invalid date format"));
return;
}
sprintf(list+i*NAME_LENGTH, "%d", ltime);
}
encoding[0] = 0;
if (mxml_find_node(entry, "ENCODING"))
strlcpy(encoding, mxml_get_value(mxml_find_node(entry, "ENCODING")), sizeof(encoding));
@@ -17662,6 +17689,68 @@ time_t retrieve_date(char *index, BOOL bstart)
/*------------------------------------------------------------------*/
time_t convert_date(char *date_string)
{
/* convert date string in MM/DD/YY or DD.MM.YY format into Unix time */
int year, month, day;
char *p, str[256];
struct tm tms;
time_t ltime;
strlcpy(str, date_string, sizeof(str));
month = day = year = 0;
if (strchr(str, '/')) {
/* MM/DD/YY format */
p = strtok(str, "/");
if (p) {
month = atoi(p);
p = strtok(NULL, "/");
if (p) {
day = atoi(p);
p = strtok(NULL, "/");
if (p)
year = atoi(p);
}
}
} else if (strchr(str, '.')) {
/* DD.MM.YY format */
p = strtok(str, ".");
if (p) {
day = atoi(p);
p = strtok(NULL, ".");
if (p) {
month = atoi(p);
p = strtok(NULL, ".");
if (p)
year = atoi(p);
}
}
} else
return 0;
/* calculate years */
if (year > 1900) /* 1900-2100 */
year += 0;
else if (year < 70) /* 00-69 */
year += 2000;
else if (year < 100) /* 70-99 */
year += 1900;
/* use last day of month */
memset(&tms, 0, sizeof(struct tm));
tms.tm_year = year - 1900;
tms.tm_mon = month - 1;
tms.tm_mday = day;
tms.tm_hour = 12;
ltime = mktime(&tms);
return ltime;
}
/*------------------------------------------------------------------*/
void show_rss_feed(LOGBOOK * lbs)
{
int i, n, size, index, status, message_id, offset;