mirror of
https://github.com/systemd/systemd.git
synced 2024-11-13 23:21:08 +03:00
install: make unit_file_get_list aware of UNIT_FILE_INDIRECT
Commit aedd401 introduced new unit file state, UNIT_FILE_INDIRECT. Unit file is said to have indirect state if it contains [Install] section which has only Also= directive. Thus, if enable of such unit file is requested then some other unit file gets enabled. Whether or not unit file is in indirect state can be determined by calling unit_file_can_install. Function unit_file_get_list populates list of unit files present in given lookup location. So far it did call unit_file_can_install in a way that would prevent finding out about unit files in indirect state. Such unit file would be incorrectly marked as static. Fixes following assertion in test-install, Assertion 'p->state == s' failed at src/test/test-install.c:59, function main(). Aborting. [1] 26868 abort (core dumped) ./test-install
This commit is contained in:
parent
906fa49076
commit
8508ea9d05
@ -2190,6 +2190,7 @@ int unit_file_get_list(
|
||||
_cleanup_(unit_file_list_free_onep) UnitFileList *f = NULL;
|
||||
struct dirent *de;
|
||||
_cleanup_free_ char *path = NULL;
|
||||
bool also = false;
|
||||
|
||||
errno = 0;
|
||||
de = readdir(d);
|
||||
@ -2243,7 +2244,7 @@ int unit_file_get_list(
|
||||
if (!path)
|
||||
return -ENOMEM;
|
||||
|
||||
r = unit_file_can_install(&paths, root_dir, path, true, NULL);
|
||||
r = unit_file_can_install(&paths, root_dir, path, true, &also);
|
||||
if (r == -EINVAL || /* Invalid setting? */
|
||||
r == -EBADMSG || /* Invalid format? */
|
||||
r == -ENOENT /* Included file not found? */)
|
||||
@ -2253,7 +2254,7 @@ int unit_file_get_list(
|
||||
else if (r > 0)
|
||||
f->state = UNIT_FILE_DISABLED;
|
||||
else
|
||||
f->state = UNIT_FILE_STATIC;
|
||||
f->state = also ? UNIT_FILE_INDIRECT : UNIT_FILE_STATIC;
|
||||
|
||||
found:
|
||||
r = hashmap_put(h, basename(f->path), f);
|
||||
|
Loading…
Reference in New Issue
Block a user