diff options
author | Lennart Poettering <lennart@poettering.net> | 2011-03-08 03:24:42 +0100 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2011-03-08 03:24:42 +0100 |
commit | 21256a2b3be4f5fb12b68c47e570b865c5a631f8 (patch) | |
tree | 82f2c50cc8ff6f60861d6be5989a14df52a47f89 /src/target.c | |
parent | d4a7e06dea271fb38bfbca0090654f54cfb37992 (diff) |
unit: don't accidently create ordering links to targets when default deps are off for either target and unit
Diffstat (limited to 'src/target.c')
-rw-r--r-- | src/target.c | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/src/target.c b/src/target.c index 27b54e3808..e61255c123 100644 --- a/src/target.c +++ b/src/target.c @@ -53,9 +53,19 @@ static void target_set_state(Target *t, TargetState state) { } static int target_add_default_dependencies(Target *t) { + static const UnitDependency deps[] = { + UNIT_REQUIRES, + UNIT_REQUIRES_OVERRIDABLE, + UNIT_REQUISITE, + UNIT_REQUISITE_OVERRIDABLE, + UNIT_WANTS, + UNIT_BIND_TO + }; + Iterator i; Unit *other; int r; + unsigned k; assert(t); @@ -64,17 +74,10 @@ static int target_add_default_dependencies(Target *t) { * ordering manually we won't add anything in here to make * sure we don't create a loop. */ - SET_FOREACH(other, t->meta.dependencies[UNIT_REQUIRES], i) - if ((r = unit_add_default_target_dependency(other, UNIT(t))) < 0) - return r; - - SET_FOREACH(other, t->meta.dependencies[UNIT_REQUIRES_OVERRIDABLE], i) - if ((r = unit_add_default_target_dependency(other, UNIT(t))) < 0) - return r; - - SET_FOREACH(other, t->meta.dependencies[UNIT_WANTS], i) - if ((r = unit_add_default_target_dependency(other, UNIT(t))) < 0) - return r; + for (k = 0; k < ELEMENTSOF(deps); k++) + SET_FOREACH(other, t->meta.dependencies[deps[k]], i) + if ((r = unit_add_default_target_dependency(other, UNIT(t))) < 0) + return r; /* Make sure targets are unloaded on shutdown */ return unit_add_dependency_by_name(UNIT(t), UNIT_CONFLICTS, SPECIAL_SHUTDOWN_TARGET, NULL, true); |