summaryrefslogtreecommitdiff
path: root/src/common/util.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-10-30 15:17:07 +0000
committerNick Mathewson <nickm@torproject.org>2007-10-30 15:17:07 +0000
commitc0c2001a5b8fd3907c7ba93eccbd536786f57594 (patch)
treec7aa35ecb0eab620cbd592451600347410da4dee /src/common/util.c
parent7709fb7143cc272c04f9de3970e4ac0fe3a000d6 (diff)
downloadtor-c0c2001a5b8fd3907c7ba93eccbd536786f57594.tar.gz
tor-c0c2001a5b8fd3907c7ba93eccbd536786f57594.zip
r16279@catbus: nickm | 2007-10-30 11:14:29 -0400
Improved skew reporting: "You are 365 days in the duture" is more useful than "You are 525600 minutes in the future". Also, when we get something that proves we are at least an hour in the past, tell the controller "CLOCK_SKEW MIN_SKEW=-3600" rather than just "CLOCK_SKEW" svn:r12283
Diffstat (limited to 'src/common/util.c')
-rw-r--r--src/common/util.c35
1 files changed, 35 insertions, 0 deletions
diff --git a/src/common/util.c b/src/common/util.c
index 27ff0c2ceb..8ee64f4522 100644
--- a/src/common/util.c
+++ b/src/common/util.c
@@ -1250,6 +1250,41 @@ parse_http_time(const char *date, struct tm *tm)
return 0;
}
+/** DOCDOC */
+int
+format_time_interval(char *out, size_t out_len, long interval)
+{
+ /* We only report seconds if there's no hours. */
+ long sec = 0, min = 0, hour = 0, day = 0;
+ if (interval < 0)
+ interval = -interval;
+
+ if (interval >= 86400) {
+ day = interval / 86400;
+ interval %= 86400;
+ }
+ if (interval >= 3600) {
+ hour = interval / 3600;
+ interval %= 3600;
+ }
+ if (interval >= 60) {
+ min = interval / 60;
+ interval %= 60;
+ }
+ sec = interval;
+
+ if (day) {
+ return tor_snprintf(out, out_len, "%ld days, %ld hours, %ld minutes",
+ day, hour, min);
+ } else if (hour) {
+ return tor_snprintf(out, out_len, "%ld hours, %ld minutes", hour, min);
+ } else if (min) {
+ return tor_snprintf(out, out_len, "%ld minutes, %ld seconds", min, sec);
+ } else {
+ return tor_snprintf(out, out_len, "%ld seconds", sec);
+ }
+}
+
/* =====
* Fuzzy time
* ===== */