X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fcore%2Fload-fragment.c;h=ea66ce01497f2aee15eef5c328083215f12b915d;hb=39881ed299a39ad331262c75d9e627e6ffb848eb;hp=98794bfafbbf497e8df21946efbd04cbc0eaf564;hpb=cc98b3025eeb89addb76a27390cb2baca4eab8b9;p=elogind.git diff --git a/src/core/load-fragment.c b/src/core/load-fragment.c index 98794bfaf..ea66ce014 100644 --- a/src/core/load-fragment.c +++ b/src/core/load-fragment.c @@ -21,26 +21,18 @@ ***/ #include -#include #include #include -#include #include #include -#include -#include #include #include -#include #include -#include -#include #ifdef HAVE_SECCOMP #include #endif -#include "sd-messages.h" #include "unit.h" #include "strv.h" #include "conf-parser.h" @@ -3150,6 +3142,7 @@ int config_parse_set_status( FOREACH_WORD(word, l, rvalue, state) { _cleanup_free_ char *temp; int val; + Set **set; temp = strndup(word, l); if (!temp) @@ -3162,21 +3155,23 @@ int config_parse_set_status( if (val <= 0) { log_syntax(unit, LOG_ERR, filename, line, -val, "Failed to parse value, ignoring: %s", word); - return 0; + continue; } + set = &status_set->signal; } else { if (val < 0 || val > 255) { log_syntax(unit, LOG_ERR, filename, line, ERANGE, "Value %d is outside range 0-255, ignoring", val); continue; } + set = &status_set->status; } - r = set_ensure_allocated(&status_set->status, NULL); + r = set_ensure_allocated(set, NULL); if (r < 0) return log_oom(); - r = set_put(status_set->status, INT_TO_PTR(val)); + r = set_put(*set, INT_TO_PTR(val)); if (r < 0) { log_syntax(unit, LOG_ERR, filename, line, -r, "Unable to store: %s", word); @@ -3437,9 +3432,8 @@ static int open_follow(char **filename, FILE **_f, Set *names, char **_final) { f = fdopen(fd, "re"); if (!f) { - r = -errno; safe_close(fd); - return r; + return -errno; } *_f = f;