annotate src/lib/time-util.c @ 22664:fea53c2725c0

director: Fix director_max_parallel_moves/kicks type Should be uint, not time.
author Timo Sirainen <timo.sirainen@dovecot.fi>
date Thu, 09 Nov 2017 12:24:16 +0200
parents 3ffd4442b22c
children cb108f786fb4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
21390
2e2563132d5f Updated copyright notices to include the year 2017.
Stephan Bosch <stephan.bosch@dovecot.fi>
parents: 21278
diff changeset
1 /* Copyright (c) 2008-2017 Dovecot authors, see the included COPYING file */
9769
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
2
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
3 #include "lib.h"
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
4 #include "time-util.h"
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
5
13923
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
6 #include <time.h>
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
7
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
8 #define STRFTIME_MAX_BUFSIZE (1024*64)
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
9
9769
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
10 int timeval_cmp(const struct timeval *tv1, const struct timeval *tv2)
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
11 {
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
12 if (tv1->tv_sec < tv2->tv_sec)
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
13 return -1;
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
14 if (tv1->tv_sec > tv2->tv_sec)
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
15 return 1;
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
16 if (tv1->tv_usec < tv2->tv_usec)
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
17 return -1;
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
18 if (tv1->tv_usec > tv2->tv_usec)
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
19 return 1;
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
20 return 0;
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
21 }
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
22
17855
e45dda2d7cd6 lib: Created timeval_cmp_margin().
Stephan Bosch <stephan@rename-it.nl>
parents: 17130
diff changeset
23 int timeval_cmp_margin(const struct timeval *tv1, const struct timeval *tv2,
e45dda2d7cd6 lib: Created timeval_cmp_margin().
Stephan Bosch <stephan@rename-it.nl>
parents: 17130
diff changeset
24 unsigned int usec_margin)
e45dda2d7cd6 lib: Created timeval_cmp_margin().
Stephan Bosch <stephan@rename-it.nl>
parents: 17130
diff changeset
25 {
e45dda2d7cd6 lib: Created timeval_cmp_margin().
Stephan Bosch <stephan@rename-it.nl>
parents: 17130
diff changeset
26 if (tv1->tv_sec < tv2->tv_sec)
e45dda2d7cd6 lib: Created timeval_cmp_margin().
Stephan Bosch <stephan@rename-it.nl>
parents: 17130
diff changeset
27 return -1;
e45dda2d7cd6 lib: Created timeval_cmp_margin().
Stephan Bosch <stephan@rename-it.nl>
parents: 17130
diff changeset
28 if (tv1->tv_sec > tv2->tv_sec)
e45dda2d7cd6 lib: Created timeval_cmp_margin().
Stephan Bosch <stephan@rename-it.nl>
parents: 17130
diff changeset
29 return 1;
e45dda2d7cd6 lib: Created timeval_cmp_margin().
Stephan Bosch <stephan@rename-it.nl>
parents: 17130
diff changeset
30
20331
a7a1c3ca1b35 time-util: Fixed usec comparison in timeval_cmp_margin().
Stephan Bosch <stephan@dovecot.fi>
parents: 19552
diff changeset
31 if ((tv2->tv_usec - tv1->tv_usec) > (int)usec_margin)
17855
e45dda2d7cd6 lib: Created timeval_cmp_margin().
Stephan Bosch <stephan@rename-it.nl>
parents: 17130
diff changeset
32 return -1;
20331
a7a1c3ca1b35 time-util: Fixed usec comparison in timeval_cmp_margin().
Stephan Bosch <stephan@dovecot.fi>
parents: 19552
diff changeset
33 if ((tv1->tv_usec - tv2->tv_usec) > (int)usec_margin)
a7a1c3ca1b35 time-util: Fixed usec comparison in timeval_cmp_margin().
Stephan Bosch <stephan@dovecot.fi>
parents: 19552
diff changeset
34 return 1;
17855
e45dda2d7cd6 lib: Created timeval_cmp_margin().
Stephan Bosch <stephan@rename-it.nl>
parents: 17130
diff changeset
35 return 0;
e45dda2d7cd6 lib: Created timeval_cmp_margin().
Stephan Bosch <stephan@rename-it.nl>
parents: 17130
diff changeset
36 }
e45dda2d7cd6 lib: Created timeval_cmp_margin().
Stephan Bosch <stephan@rename-it.nl>
parents: 17130
diff changeset
37
9769
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
38 int timeval_diff_msecs(const struct timeval *tv1, const struct timeval *tv2)
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
39 {
9771
6ff08c7c9f03 timeval_diff_*() fixes.
Timo Sirainen <tss@iki.fi>
parents: 9769
diff changeset
40 return timeval_diff_usecs(tv1, tv2) / 1000;
9769
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
41 }
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
42
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
43 long long timeval_diff_usecs(const struct timeval *tv1,
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
44 const struct timeval *tv2)
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
45 {
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
46 time_t secs;
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
47 int usecs;
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
48
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
49 secs = tv1->tv_sec - tv2->tv_sec;
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
50 usecs = tv1->tv_usec - tv2->tv_usec;
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
51 if (usecs < 0) {
9771
6ff08c7c9f03 timeval_diff_*() fixes.
Timo Sirainen <tss@iki.fi>
parents: 9769
diff changeset
52 secs--;
9769
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
53 usecs += 1000000;
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
54 }
15909
f74bf0521d69 Avoid under/overflows in unsigned integer calculations.
Timo Sirainen <tss@iki.fi>
parents: 15715
diff changeset
55 return ((long long)secs * 1000000LL) + usecs;
9769
8716936443db Moved all struct timeval comparing/calculation code to lib/time-util.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
56 }
13923
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
57
21854
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
58 time_t time_to_local_day_start(time_t t)
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
59 {
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
60 const struct tm *day_tm;
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
61 struct tm tm;
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
62 time_t new_start_time;
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
63
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
64 day_tm = localtime(&t);
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
65 i_zero(&tm);
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
66 tm.tm_year = day_tm->tm_year;
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
67 tm.tm_mon = day_tm->tm_mon;
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
68 tm.tm_mday = day_tm->tm_mday;
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
69 tm.tm_isdst = -1;
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
70 new_start_time = mktime(&tm);
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
71 i_assert(new_start_time != (time_t)-1);
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
72 return new_start_time;
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
73 }
3ffd4442b22c lib: Add time_to_local_day_start()
Timo Sirainen <timo.sirainen@dovecot.fi>
parents: 21390
diff changeset
74
21278
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
75 static const char *strftime_real(const char *fmt, const struct tm *tm)
13923
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
76 {
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
77 size_t bufsize = strlen(fmt) + 32;
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
78 char *buf = t_buffer_get(bufsize);
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
79 size_t ret;
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
80
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
81 while ((ret = strftime(buf, bufsize, fmt, tm)) == 0) {
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
82 bufsize *= 2;
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
83 i_assert(bufsize <= STRFTIME_MAX_BUFSIZE);
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
84 buf = t_buffer_get(bufsize);
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
85 }
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
86 t_buffer_alloc(ret + 1);
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
87 return buf;
22cfba724675 Added t_strflocaltime().
Timo Sirainen <tss@iki.fi>
parents: 12782
diff changeset
88 }
21278
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
89
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
90 const char *t_strftime(const char *fmt, const struct tm *tm)
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
91 {
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
92 return strftime_real(fmt, tm);
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
93 }
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
94
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
95 const char *t_strflocaltime(const char *fmt, time_t t)
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
96 {
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
97 return strftime_real(fmt, localtime(&t));
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
98 }
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
99
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
100 const char *t_strfgmtime(const char *fmt, time_t t)
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
101 {
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
102 return strftime_real(fmt, gmtime(&t));
fcb25852e8b7 lib: add t_strfgmtime and t_strftime
Martti Rannanjärvi <martti.rannanjarvi@dovecot.fi>
parents: 20331
diff changeset
103 }