summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--TODO1
-rw-r--r--sysdep/unix/io.c27
-rw-r--r--sysdep/unix/timer.h4
3 files changed, 31 insertions, 1 deletions
diff --git a/TODO b/TODO
index 2a9120b..9271316 100644
--- a/TODO
+++ b/TODO
@@ -7,7 +7,6 @@ Core
- prefer loopback addresses as router IDs (dummy interface?)
- config: executable config files
-- config: better format for datetime then seconds
- do we really need preconfig?
diff --git a/sysdep/unix/io.c b/sysdep/unix/io.c
index 6d44f80..39cf200 100644
--- a/sysdep/unix/io.c
+++ b/sysdep/unix/io.c
@@ -217,6 +217,33 @@ tm_shot(void)
}
}
+bird_clock_t
+tm_parse_date(char *x)
+{
+ struct tm tm;
+ int n;
+ time_t t;
+
+ if (sscanf(x, "%d-%d-%d%n", &tm.tm_mday, &tm.tm_mon, &tm.tm_year, &n) != 3 || x[n])
+ return 0;
+ tm.tm_mon--;
+ tm.tm_year -= 1900;
+ tm.tm_hour = tm.tm_min = tm.tm_sec = 0;
+ t = mktime(&tm);
+ if (t == (time_t) -1)
+ return 0;
+ return t;
+}
+
+void
+tm_format_date(char *x, bird_clock_t t)
+{
+ struct tm *tm;
+
+ tm = localtime(&t);
+ sprintf(x, "%02d-%02d-%04d", tm->tm_mday, tm->tm_mon+1, tm->tm_year+1900);
+}
+
/*
* Sockets
*/
diff --git a/sysdep/unix/timer.h b/sysdep/unix/timer.h
index 10351a6..afb2668 100644
--- a/sysdep/unix/timer.h
+++ b/sysdep/unix/timer.h
@@ -32,4 +32,8 @@ void tm_dump_all(void);
extern bird_clock_t now; /* Time in seconds since unknown epoch */
+bird_clock_t tm_parse_date(char *); /* Convert date to bird_clock_t */
+void tm_format_date(char *, bird_clock_t); /* Convert bird_clock_t to date */
+#define TM_DATE_BUFFER_SIZE 12 /* Buffer size required by tm_format_date */
+
#endif