[systemd-devel] [PATCH v5 2/4] util: introduce new sec_to_stringa()
WaLyong Cho
walyong.cho at samsung.com
Mon Dec 8 04:18:32 PST 2014
---
src/shared/time-util.c | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++
src/shared/time-util.h | 1 +
src/test/test-time.c | 20 +++++++++++++++++++
3 files changed, 73 insertions(+)
diff --git a/src/shared/time-util.c b/src/shared/time-util.c
index d3404af..d94be7e 100644
--- a/src/shared/time-util.c
+++ b/src/shared/time-util.c
@@ -861,6 +861,58 @@ int parse_nsec(const char *t, nsec_t *nsec) {
return 0;
}
+int sec_to_stringa(const char *t, usec_t usec, const char **time) {
+ static const struct {
+ const char *suffix;
+ usec_t usec;
+ } table[] = {
+ { "seconds", USEC_PER_SEC },
+ { "second", USEC_PER_SEC },
+ { "sec", USEC_PER_SEC },
+ { "s", USEC_PER_SEC },
+ { "minutes", USEC_PER_MINUTE },
+ { "minute", USEC_PER_MINUTE },
+ { "min", USEC_PER_MINUTE },
+ { "months", USEC_PER_MONTH },
+ { "month", USEC_PER_MONTH },
+ { "msec", USEC_PER_MSEC },
+ { "ms", USEC_PER_MSEC },
+ { "m", USEC_PER_MINUTE },
+ { "hours", USEC_PER_HOUR },
+ { "hour", USEC_PER_HOUR },
+ { "hr", USEC_PER_HOUR },
+ { "h", USEC_PER_HOUR },
+ { "days", USEC_PER_DAY },
+ { "day", USEC_PER_DAY },
+ { "d", USEC_PER_DAY },
+ { "weeks", USEC_PER_WEEK },
+ { "week", USEC_PER_WEEK },
+ { "w", USEC_PER_WEEK },
+ { "years", USEC_PER_YEAR },
+ { "year", USEC_PER_YEAR },
+ { "y", USEC_PER_YEAR },
+ { "usec", 1ULL },
+ { "us", 1ULL },
+ { "", USEC_PER_SEC }, /* default is sec */
+ };
+
+ char *s = NULL;
+ unsigned i;
+
+ for (i = 0; i < ELEMENTSOF(table); i++) {
+ if (streq(t, table[i].suffix)) {
+ if (asprintf(&s, "%g%s", ((double) usec)/table[i].usec, t) < 0)
+ return -ENOMEM;
+
+ *time = s;
+
+ return 0;
+ }
+ }
+
+ return -EINVAL;
+}
+
bool ntp_synced(void) {
struct timex txc = {};
diff --git a/src/shared/time-util.h b/src/shared/time-util.h
index b55a660..7d0eff9 100644
--- a/src/shared/time-util.h
+++ b/src/shared/time-util.h
@@ -100,6 +100,7 @@ int parse_timestamp(const char *t, usec_t *usec);
int parse_sec(const char *t, usec_t *usec);
int parse_nsec(const char *t, nsec_t *nsec);
+int sec_to_stringa(const char *t, usec_t usec, const char **time);
bool ntp_synced(void);
diff --git a/src/test/test-time.c b/src/test/test-time.c
index 8cfc4cc..b57639a 100644
--- a/src/test/test-time.c
+++ b/src/test/test-time.c
@@ -86,6 +86,25 @@ static void test_parse_nsec(void) {
assert_se(parse_nsec(".s ", &u) < 0);
}
+static void test_sec_to_stringa(void) {
+ _cleanup_free_ const char *time1 = NULL, *time2 = NULL, *time3 = NULL, *time4 = NULL, *time5 = NULL;
+
+ assert_se(sec_to_stringa("", 27314123, &time1) >= 0);
+ puts(time1);
+
+ assert_se(sec_to_stringa("sec", 27314123, &time2) >= 0);
+ puts(time2);
+
+ assert_se(sec_to_stringa("ms", 27314123, &time3) >= 0);
+ puts(time3);
+
+ assert_se(sec_to_stringa("days", 27314123, &time4) >= 0);
+ puts(time4);
+
+ assert_se(sec_to_stringa("years", 27314123, &time5) >= 0);
+ puts(time5);
+}
+
static void test_format_timespan_one(usec_t x, usec_t accuracy) {
char *r;
char l[FORMAT_TIMESPAN_MAX];
@@ -156,6 +175,7 @@ static void test_get_timezones(void) {
int main(int argc, char *argv[]) {
test_parse_sec();
test_parse_nsec();
+ test_sec_to_stringa();
test_format_timespan(1);
test_format_timespan(USEC_PER_MSEC);
test_format_timespan(USEC_PER_SEC);
--
1.9.3
More information about the systemd-devel
mailing list