chiark
/
gitweb
/
~ianmdlvl
/
elogind.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
importd: take a lock while we set up /var/lib/machines/
[elogind.git]
/
src
/
shared
/
time-util.c
diff --git
a/src/shared/time-util.c
b/src/shared/time-util.c
index 33d0822f335ace06ff2583a4869f535c7254297a..1c36c577c4af36c9255554831161c8e65cb26171 100644
(file)
--- a/
src/shared/time-util.c
+++ b/
src/shared/time-util.c
@@
-296,8
+296,14
@@
char *format_timespan(char *buf, size_t l, usec_t t, usec_t accuracy) {
assert(buf);
assert(l > 0);
assert(buf);
assert(l > 0);
- if (t == USEC_INFINITY || t <= 0) {
- strncpy(p, t == USEC_INFINITY ? "infinity" : "0", l);
+ if (t == USEC_INFINITY) {
+ strncpy(p, "infinity", l-1);
+ p[l-1] = 0;
+ return p;
+ }
+
+ if (t <= 0) {
+ strncpy(p, "0", l-1);
p[l-1] = 0;
return p;
}
p[l-1] = 0;
return p;
}
@@
-780,7
+786,7
@@
int parse_nsec(const char *t, nsec_t *nsec) {
s = startswith(p, "infinity");
if (s) {
s += strspn(s, WHITESPACE);
s = startswith(p, "infinity");
if (s) {
s += strspn(s, WHITESPACE);
- if (
!
*s != 0)
+ if (*s != 0)
return -EINVAL;
*nsec = NSEC_INFINITY;
return -EINVAL;
*nsec = NSEC_INFINITY;
@@
-959,7
+965,7
@@
bool timezone_is_valid(const char *name) {
if (slash)
return false;
if (slash)
return false;
- t = str
append
a("/usr/share/zoneinfo/", name);
+ t = str
join
a("/usr/share/zoneinfo/", name);
if (stat(t, &st) < 0)
return false;
if (stat(t, &st) < 0)
return false;