X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Ftarget.c;h=3522bf12168f9a702a8cb2c6add51ed4d1d1ed21;hp=f1f656e6dd0f2fc0d5c72e36e169a17cac9c1520;hb=9841e8e3d305e6f4173c9aedbe8d57adfe10d145;hpb=98bc20006d89aa8e7d9d3eeb75f475a66943fe55 diff --git a/src/target.c b/src/target.c index f1f656e6d..3522bf121 100644 --- a/src/target.c +++ b/src/target.c @@ -53,8 +53,29 @@ static void target_set_state(Target *t, TargetState state) { } static int target_add_default_dependencies(Target *t) { + Iterator i; + Unit *other; + int r; + assert(t); + /* Imply ordering for requirement dependencies on target + * units. Note that when the user created a contradicting + * 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; + /* Make sure targets are unloaded on shutdown */ return unit_add_dependency_by_name(UNIT(t), UNIT_CONFLICTED_BY, SPECIAL_SHUTDOWN_TARGET, NULL, true); }