X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fshared%2Futil.c;h=c71293106f228910d52323957b78e1baa9cbaf4b;hb=85ca9433abc00d8cc641fceafe9e87dfcd92af4a;hp=206fc803d0e8b3f04a50fd0baf5cea1ff1a00f5c;hpb=27373e442747010dfc195296c0705f67e905a611;p=elogind.git diff --git a/src/shared/util.c b/src/shared/util.c index 206fc803d..c71293106 100644 --- a/src/shared/util.c +++ b/src/shared/util.c @@ -5379,7 +5379,7 @@ bool is_locale_utf8(void) { goto out; } - if(streq(set, "UTF-8")) { + if (streq(set, "UTF-8")) { cached_answer = true; goto out; } @@ -5791,6 +5791,8 @@ void* greedy_realloc(void **p, size_t *allocated, size_t need) { size_t a; void *q; + assert(allocated); + if (*allocated >= need) return *p; @@ -5804,6 +5806,20 @@ void* greedy_realloc(void **p, size_t *allocated, size_t need) { return q; } +void* greedy_realloc0(void **p, size_t *allocated, size_t need) { + size_t prev = *allocated; + uint8_t *q; + + q = greedy_realloc(p, allocated, need); + if (!q) + return NULL; + + if (*allocated > prev) + memset(&q[prev], 0, *allocated - prev); + + return q; +} + bool id128_is_valid(const char *s) { size_t i, l; @@ -5903,7 +5919,7 @@ int shall_restore_state(void) { return 1; FOREACH_WORD_QUOTED(w, l, line, state) - if (l == 23 && memcmp(w, "systemd.restore_state=0", 23)) + if (l == 23 && strneq(w, "systemd.restore_state=0", 23)) return 0; return 1;