|
Michal Schmidt |
e43452 |
From 423d96b0e5e351ae6489370ebc4af1bd18008b5d Mon Sep 17 00:00:00 2001
|
|
Michal Schmidt |
e43452 |
From: Lennart Poettering <lennart@poettering.net>
|
|
Michal Schmidt |
e43452 |
Date: Fri, 6 Jan 2012 19:23:03 +0100
|
|
Michal Schmidt |
f1996e |
Subject: [PATCH] service: add dependencies on configured sockets (cherry
|
|
Michal Schmidt |
f1996e |
picked from commit
|
|
Michal Schmidt |
e43452 |
73aa0c00df8b101bad4c3a038148a633df88610c)
|
|
Michal Schmidt |
e43452 |
|
|
Michal Schmidt |
e43452 |
---
|
|
Michal Schmidt |
e43452 |
src/service.c | 22 ++++++++++++++++++++++
|
|
Michal Schmidt |
e43452 |
1 files changed, 22 insertions(+), 0 deletions(-)
|
|
Michal Schmidt |
e43452 |
|
|
Michal Schmidt |
e43452 |
diff --git a/src/service.c b/src/service.c
|
|
Michal Schmidt |
e43452 |
index d229301..65a45e1 100644
|
|
Michal Schmidt |
e43452 |
--- a/src/service.c
|
|
Michal Schmidt |
e43452 |
+++ b/src/service.c
|
|
Michal Schmidt |
e43452 |
@@ -1100,6 +1100,22 @@ static int service_add_default_dependencies(Service *s) {
|
|
Michal Schmidt |
e43452 |
return unit_add_two_dependencies_by_name(UNIT(s), UNIT_BEFORE, UNIT_CONFLICTS, SPECIAL_SHUTDOWN_TARGET, NULL, true);
|
|
Michal Schmidt |
e43452 |
}
|
|
Michal Schmidt |
e43452 |
|
|
Michal Schmidt |
e43452 |
+static int service_add_socket_dependencies(Service *s) {
|
|
Michal Schmidt |
e43452 |
+ Iterator i;
|
|
Michal Schmidt |
e43452 |
+ Unit *u;
|
|
Michal Schmidt |
e43452 |
+ int r;
|
|
Michal Schmidt |
e43452 |
+
|
|
Michal Schmidt |
e43452 |
+ /* Make sure we pull in all explicitly configured sockets */
|
|
Michal Schmidt |
e43452 |
+
|
|
Michal Schmidt |
e43452 |
+ SET_FOREACH(u, s->configured_sockets, i) {
|
|
Michal Schmidt |
e43452 |
+ r = unit_add_two_dependencies(UNIT(s), UNIT_AFTER, UNIT_REQUIRES, u, true);
|
|
Michal Schmidt |
e43452 |
+ if (r < 0)
|
|
Michal Schmidt |
e43452 |
+ return r;
|
|
Michal Schmidt |
e43452 |
+ }
|
|
Michal Schmidt |
e43452 |
+
|
|
Michal Schmidt |
e43452 |
+ return 0;
|
|
Michal Schmidt |
e43452 |
+}
|
|
Michal Schmidt |
e43452 |
+
|
|
Michal Schmidt |
e43452 |
static void service_fix_output(Service *s) {
|
|
Michal Schmidt |
e43452 |
assert(s);
|
|
Michal Schmidt |
e43452 |
|
|
Michal Schmidt |
e43452 |
@@ -1173,6 +1189,12 @@ static int service_load(Unit *u) {
|
|
Michal Schmidt |
e43452 |
if ((r = unit_add_two_dependencies_by_name(u, UNIT_AFTER, UNIT_REQUIRES, SPECIAL_DBUS_SOCKET, NULL, true)) < 0)
|
|
Michal Schmidt |
e43452 |
return r;
|
|
Michal Schmidt |
e43452 |
|
|
Michal Schmidt |
e43452 |
+ if (!set_isempty(s->configured_sockets)) {
|
|
Michal Schmidt |
e43452 |
+ r = service_add_socket_dependencies(s);
|
|
Michal Schmidt |
e43452 |
+ if (r < 0)
|
|
Michal Schmidt |
e43452 |
+ return r;
|
|
Michal Schmidt |
e43452 |
+ }
|
|
Michal Schmidt |
e43452 |
+
|
|
Michal Schmidt |
e43452 |
if (s->meta.default_dependencies)
|
|
Michal Schmidt |
e43452 |
if ((r = service_add_default_dependencies(s)) < 0)
|
|
Michal Schmidt |
e43452 |
return r;
|