X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fcore%2Fload-fragment.c;h=8a42e739bedc11572fd7a261ff7bc7dfdf7b6f8c;hb=5acac4c814f973d1d47e5fbad1fa52cd3e92e7cf;hp=d9dd6faaeba02a2271b5d835e1cc3e6acaf36f12;hpb=d420282b28f50720e233ccb1c02547c562195653;p=elogind.git diff --git a/src/core/load-fragment.c b/src/core/load-fragment.c index d9dd6faae..8a42e739b 100644 --- a/src/core/load-fragment.c +++ b/src/core/load-fragment.c @@ -1350,15 +1350,17 @@ int config_parse_socket_service(const char *unit, assert(data); r = unit_name_printf(UNIT(s), rvalue, &p); - if (r < 0) + if (r < 0) { log_syntax(unit, LOG_ERR, filename, line, -r, "Failed to resolve specifiers, ignoring: %s", rvalue); + return 0; + } - if (!endswith(p ?: rvalue, ".service")) { + if (!endswith(p, ".service")) { log_syntax(unit, LOG_ERR, filename, line, EINVAL, "Unit must be of type service, ignoring: %s", rvalue); return 0; } - r = manager_load_unit(UNIT(s)->manager, p ?: rvalue, NULL, &error, &x); + r = manager_load_unit(UNIT(s)->manager, p, NULL, &error, &x); if (r < 0) { log_syntax(unit, LOG_ERR, filename, line, r, "Failed to load unit %s, ignoring: %s", rvalue, bus_error_message(&error, r)); return 0;