diff options
| author | Daniel Mack <github@zonque.org> | 2016-03-17 20:24:39 +0100 | 
|---|---|---|
| committer | Daniel Mack <github@zonque.org> | 2016-03-17 20:24:39 +0100 | 
| commit | 90e644608ebf94f5f3c8acb1317bf4723826e337 (patch) | |
| tree | 2de26c4cb4dc7b399e92510df482b87c213c6c01 | |
| parent | 2ddbdcc9c24b802564784f0812611b368a733e51 (diff) | |
| parent | 7aad67e7f2b3dfbc3b5a884471bd551e4bf997cc (diff) | |
Merge pull request #2856 from msekletar/merge-instance
core: look for instance when processing template name
| -rw-r--r-- | src/core/load-fragment.c | 14 | 
1 files changed, 13 insertions, 1 deletions
| diff --git a/src/core/load-fragment.c b/src/core/load-fragment.c index e1bfdccbca..d078924c5b 100644 --- a/src/core/load-fragment.c +++ b/src/core/load-fragment.c @@ -3507,7 +3507,19 @@ static int merge_by_names(Unit **u, Set *names, const char *id) {                           * ours? Then let's try it the other way                           * round */ -                        other = manager_get_unit((*u)->manager, k); +                        /* If the symlink name we are looking at is unit template, then +                           we must search for instance of this template */ +                        if (unit_name_is_valid(k, UNIT_NAME_TEMPLATE)) { +                                _cleanup_free_ char *instance = NULL; + +                                r = unit_name_replace_instance(k, (*u)->instance, &instance); +                                if (r < 0) +                                        return r; + +                                other = manager_get_unit((*u)->manager, instance); +                        } else +                                other = manager_get_unit((*u)->manager, k); +                          free(k);                          if (other) { | 
