Also simplify the code a bit by moving mkdir to the common path.
- if (m->running_as == SYSTEMD_SYSTEM) {
+ if (m->running_as == SYSTEMD_SYSTEM)
m->notify_socket = strdup("/run/systemd/notify");
m->notify_socket = strdup("/run/systemd/notify");
- if (!m->notify_socket)
- return log_oom();
- } else {
const char *e;
e = getenv("XDG_RUNTIME_DIR");
const char *e;
e = getenv("XDG_RUNTIME_DIR");
}
m->notify_socket = strappend(e, "/systemd/notify");
}
m->notify_socket = strappend(e, "/systemd/notify");
- if (!m->notify_socket)
- return log_oom();
-
- mkdir_parents_label(m->notify_socket, 0755);
+ if (!m->notify_socket)
+ return log_oom();
+
+ (void) mkdir_parents_label(m->notify_socket, 0755);
strncpy(sa.un.sun_path, m->notify_socket, sizeof(sa.un.sun_path)-1);
r = bind(fd, &sa.sa, offsetof(struct sockaddr_un, sun_path) + strlen(sa.un.sun_path));
strncpy(sa.un.sun_path, m->notify_socket, sizeof(sa.un.sun_path)-1);
r = bind(fd, &sa.sa, offsetof(struct sockaddr_un, sun_path) + strlen(sa.un.sun_path));