Zbigniew Jędrzejewski-Szmek 77e6ed
From 68f8c0b9eeeead72fbdf90b32e5cf01862d9c351 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 77e6ed
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
Zbigniew Jędrzejewski-Szmek 77e6ed
Date: Sat, 14 Mar 2015 21:46:59 -0400
Zbigniew Jędrzejewski-Szmek 77e6ed
Subject: [PATCH] sysv-generator: initialize LookupPaths just once
Zbigniew Jędrzejewski-Szmek 77e6ed
Zbigniew Jędrzejewski-Szmek 77e6ed
With debugging on, sysv-generator would print the full set of
Zbigniew Jędrzejewski-Szmek 77e6ed
lookup paths for *every* sysv script.
Zbigniew Jędrzejewski-Szmek 77e6ed
Zbigniew Jędrzejewski-Szmek 77e6ed
While at it, pass LookupPaths as a pointer in sysv-generator,
Zbigniew Jędrzejewski-Szmek 77e6ed
and constify it everywhere.
Zbigniew Jędrzejewski-Szmek 77e6ed
Zbigniew Jędrzejewski-Szmek 77e6ed
(cherry picked from commit a8ffe6fbcbfdba39aef8dce8b298b3e0cb377c0e)
Zbigniew Jędrzejewski-Szmek 77e6ed
---
Zbigniew Jędrzejewski-Szmek 77e6ed
 src/shared/install.c                | 55 ++++++++++++++++++++++---------------
Zbigniew Jędrzejewski-Szmek 77e6ed
 src/shared/install.h                | 11 +++++++-
Zbigniew Jędrzejewski-Szmek 77e6ed
 src/shared/path-lookup.c            |  1 +
Zbigniew Jędrzejewski-Szmek 77e6ed
 src/shared/path-lookup.h            |  3 +-
Zbigniew Jędrzejewski-Szmek 77e6ed
 src/sysv-generator/sysv-generator.c | 14 +++++-----
Zbigniew Jędrzejewski-Szmek 77e6ed
 5 files changed, 53 insertions(+), 31 deletions(-)
Zbigniew Jędrzejewski-Szmek 77e6ed
Zbigniew Jędrzejewski-Szmek 77e6ed
diff --git a/src/shared/install.c b/src/shared/install.c
Zbigniew Jędrzejewski-Szmek 77e6ed
index 65f1c245c6..92b8d6e8ef 100644
Zbigniew Jędrzejewski-Szmek 77e6ed
--- a/src/shared/install.c
Zbigniew Jędrzejewski-Szmek 77e6ed
+++ b/src/shared/install.c
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -1084,7 +1084,7 @@ static int unit_file_load(
Zbigniew Jędrzejewski-Szmek 77e6ed
 static int unit_file_search(
Zbigniew Jędrzejewski-Szmek 77e6ed
                 InstallContext *c,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 InstallInfo *info,
Zbigniew Jędrzejewski-Szmek 77e6ed
-                LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *root_dir,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 bool allow_symlink,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 bool load,
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -1153,7 +1153,7 @@ static int unit_file_search(
Zbigniew Jędrzejewski-Szmek 77e6ed
 }
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
 static int unit_file_can_install(
Zbigniew Jędrzejewski-Szmek 77e6ed
-                LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *root_dir,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *name,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 bool allow_symlink,
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -1317,7 +1317,7 @@ static int install_info_symlink_wants(
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
 static int install_info_symlink_link(
Zbigniew Jędrzejewski-Szmek 77e6ed
                 InstallInfo *i,
Zbigniew Jędrzejewski-Szmek 77e6ed
-                LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *config_path,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *root_dir,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 bool force,
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -1345,7 +1345,7 @@ static int install_info_symlink_link(
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
 static int install_info_apply(
Zbigniew Jędrzejewski-Szmek 77e6ed
                 InstallInfo *i,
Zbigniew Jędrzejewski-Szmek 77e6ed
-                LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *config_path,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *root_dir,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 bool force,
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -1377,7 +1377,7 @@ static int install_info_apply(
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
 static int install_context_apply(
Zbigniew Jędrzejewski-Szmek 77e6ed
                 InstallContext *c,
Zbigniew Jędrzejewski-Szmek 77e6ed
-                LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *config_path,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *root_dir,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 bool force,
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -1424,7 +1424,7 @@ static int install_context_apply(
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
 static int install_context_mark_for_removal(
Zbigniew Jędrzejewski-Szmek 77e6ed
                 InstallContext *c,
Zbigniew Jędrzejewski-Szmek 77e6ed
-                LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 Set **remove_symlinks_to,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *config_path,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *root_dir) {
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -1785,39 +1785,28 @@ int unit_file_get_default(
Zbigniew Jędrzejewski-Szmek 77e6ed
         return -ENOENT;
Zbigniew Jędrzejewski-Szmek 77e6ed
 }
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-UnitFileState unit_file_get_state(
Zbigniew Jędrzejewski-Szmek 77e6ed
+UnitFileState unit_file_lookup_state(
Zbigniew Jędrzejewski-Szmek 77e6ed
                 UnitFileScope scope,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *root_dir,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
                 const char *name) {
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-        _cleanup_lookup_paths_free_ LookupPaths paths = {};
Zbigniew Jędrzejewski-Szmek 77e6ed
         UnitFileState state = _UNIT_FILE_STATE_INVALID;
Zbigniew Jędrzejewski-Szmek 77e6ed
         char **i;
Zbigniew Jędrzejewski-Szmek 77e6ed
         _cleanup_free_ char *path = NULL;
Zbigniew Jędrzejewski-Szmek 77e6ed
         int r;
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-        assert(scope >= 0);
Zbigniew Jędrzejewski-Szmek 77e6ed
-        assert(scope < _UNIT_FILE_SCOPE_MAX);
Zbigniew Jędrzejewski-Szmek 77e6ed
-        assert(name);
Zbigniew Jędrzejewski-Szmek 77e6ed
-
Zbigniew Jędrzejewski-Szmek 77e6ed
-        if (root_dir && scope != UNIT_FILE_SYSTEM)
Zbigniew Jędrzejewski-Szmek 77e6ed
-                return -EINVAL;
Zbigniew Jędrzejewski-Szmek 77e6ed
+        assert(paths);
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
         if (!unit_name_is_valid(name, TEMPLATE_VALID))
Zbigniew Jędrzejewski-Szmek 77e6ed
                 return -EINVAL;
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-        r = lookup_paths_init_from_scope(&paths, scope, root_dir);
Zbigniew Jędrzejewski-Szmek 77e6ed
-        if (r < 0)
Zbigniew Jędrzejewski-Szmek 77e6ed
-                return r;
Zbigniew Jędrzejewski-Szmek 77e6ed
-
Zbigniew Jędrzejewski-Szmek 77e6ed
-        STRV_FOREACH(i, paths.unit_path) {
Zbigniew Jędrzejewski-Szmek 77e6ed
+        STRV_FOREACH(i, paths->unit_path) {
Zbigniew Jędrzejewski-Szmek 77e6ed
                 struct stat st;
Zbigniew Jędrzejewski-Szmek 77e6ed
                 char *partial;
Zbigniew Jędrzejewski-Szmek 77e6ed
                 bool also = false;
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
                 free(path);
Zbigniew Jędrzejewski-Szmek 77e6ed
-                path = NULL;
Zbigniew Jędrzejewski-Szmek 77e6ed
-
Zbigniew Jędrzejewski-Szmek 77e6ed
                 path = path_join(root_dir, *i, name);
Zbigniew Jędrzejewski-Szmek 77e6ed
                 if (!path)
Zbigniew Jędrzejewski-Szmek 77e6ed
                         return -ENOMEM;
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -1858,7 +1847,7 @@ UnitFileState unit_file_get_state(
Zbigniew Jędrzejewski-Szmek 77e6ed
                 else if (r > 0)
Zbigniew Jędrzejewski-Szmek 77e6ed
                         return state;
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-                r = unit_file_can_install(&paths, root_dir, partial, true, &also);
Zbigniew Jędrzejewski-Szmek 77e6ed
+                r = unit_file_can_install(paths, root_dir, partial, true, &also);
Zbigniew Jędrzejewski-Szmek 77e6ed
                 if (r < 0 && errno != ENOENT)
Zbigniew Jędrzejewski-Szmek 77e6ed
                         return r;
Zbigniew Jędrzejewski-Szmek 77e6ed
                 else if (r > 0)
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -1873,6 +1862,28 @@ UnitFileState unit_file_get_state(
Zbigniew Jędrzejewski-Szmek 77e6ed
         return r < 0 ? r : state;
Zbigniew Jędrzejewski-Szmek 77e6ed
 }
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
+UnitFileState unit_file_get_state(
Zbigniew Jędrzejewski-Szmek 77e6ed
+                UnitFileScope scope,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const char *root_dir,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const char *name) {
Zbigniew Jędrzejewski-Szmek 77e6ed
+
Zbigniew Jędrzejewski-Szmek 77e6ed
+        _cleanup_lookup_paths_free_ LookupPaths paths = {};
Zbigniew Jędrzejewski-Szmek 77e6ed
+        int r;
Zbigniew Jędrzejewski-Szmek 77e6ed
+
Zbigniew Jędrzejewski-Szmek 77e6ed
+        assert(scope >= 0);
Zbigniew Jędrzejewski-Szmek 77e6ed
+        assert(scope < _UNIT_FILE_SCOPE_MAX);
Zbigniew Jędrzejewski-Szmek 77e6ed
+        assert(name);
Zbigniew Jędrzejewski-Szmek 77e6ed
+
Zbigniew Jędrzejewski-Szmek 77e6ed
+        if (root_dir && scope != UNIT_FILE_SYSTEM)
Zbigniew Jędrzejewski-Szmek 77e6ed
+                return -EINVAL;
Zbigniew Jędrzejewski-Szmek 77e6ed
+
Zbigniew Jędrzejewski-Szmek 77e6ed
+        r = lookup_paths_init_from_scope(&paths, scope, root_dir);
Zbigniew Jędrzejewski-Szmek 77e6ed
+        if (r < 0)
Zbigniew Jędrzejewski-Szmek 77e6ed
+                return r;
Zbigniew Jędrzejewski-Szmek 77e6ed
+
Zbigniew Jędrzejewski-Szmek 77e6ed
+        return unit_file_lookup_state(scope, root_dir, &paths, name);
Zbigniew Jędrzejewski-Szmek 77e6ed
+}
Zbigniew Jędrzejewski-Szmek 77e6ed
+
Zbigniew Jędrzejewski-Szmek 77e6ed
 int unit_file_query_preset(UnitFileScope scope, const char *root_dir, const char *name) {
Zbigniew Jędrzejewski-Szmek 77e6ed
         _cleanup_strv_free_ char **files = NULL;
Zbigniew Jędrzejewski-Szmek 77e6ed
         char **p;
Zbigniew Jędrzejewski-Szmek 77e6ed
diff --git a/src/shared/install.h b/src/shared/install.h
Zbigniew Jędrzejewski-Szmek 77e6ed
index 357be0f92d..3ca39397e6 100644
Zbigniew Jędrzejewski-Szmek 77e6ed
--- a/src/shared/install.h
Zbigniew Jędrzejewski-Szmek 77e6ed
+++ b/src/shared/install.h
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -23,6 +23,7 @@
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
 #include "hashmap.h"
Zbigniew Jędrzejewski-Szmek 77e6ed
 #include "unit-name.h"
Zbigniew Jędrzejewski-Szmek 77e6ed
+#include "path-lookup.h"
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
 typedef enum UnitFileScope {
Zbigniew Jędrzejewski-Szmek 77e6ed
         UNIT_FILE_SYSTEM,
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -98,7 +99,15 @@ int unit_file_set_default(UnitFileScope scope, const char *root_dir, const char
Zbigniew Jędrzejewski-Szmek 77e6ed
 int unit_file_get_default(UnitFileScope scope, const char *root_dir, char **name);
Zbigniew Jędrzejewski-Szmek 77e6ed
 int unit_file_add_dependency(UnitFileScope scope, bool runtime, const char *root_dir, char **files, char *target, UnitDependency dep, bool force, UnitFileChange **changes, unsigned *n_changes);
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-UnitFileState unit_file_get_state(UnitFileScope scope, const char *root_dir, const char *filename);
Zbigniew Jędrzejewski-Szmek 77e6ed
+UnitFileState unit_file_lookup_state(
Zbigniew Jędrzejewski-Szmek 77e6ed
+                UnitFileScope scope,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const char *root_dir,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const char *name);
Zbigniew Jędrzejewski-Szmek 77e6ed
+UnitFileState unit_file_get_state(
Zbigniew Jędrzejewski-Szmek 77e6ed
+                UnitFileScope scope,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const char *root_dir,
Zbigniew Jędrzejewski-Szmek 77e6ed
+                const char *filename);
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
 int unit_file_get_list(UnitFileScope scope, const char *root_dir, Hashmap *h);
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
diff --git a/src/shared/path-lookup.c b/src/shared/path-lookup.c
Zbigniew Jędrzejewski-Szmek 77e6ed
index 291a2f4054..812730be1c 100644
Zbigniew Jędrzejewski-Szmek 77e6ed
--- a/src/shared/path-lookup.c
Zbigniew Jędrzejewski-Szmek 77e6ed
+++ b/src/shared/path-lookup.c
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -31,6 +31,7 @@
Zbigniew Jędrzejewski-Szmek 77e6ed
 #include "strv.h"
Zbigniew Jędrzejewski-Szmek 77e6ed
 #include "path-util.h"
Zbigniew Jędrzejewski-Szmek 77e6ed
 #include "path-lookup.h"
Zbigniew Jędrzejewski-Szmek 77e6ed
+#include "install.h"
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
 int user_config_home(char **config_home) {
Zbigniew Jędrzejewski-Szmek 77e6ed
         const char *e;
Zbigniew Jędrzejewski-Szmek 77e6ed
diff --git a/src/shared/path-lookup.h b/src/shared/path-lookup.h
Zbigniew Jędrzejewski-Szmek 77e6ed
index 2ec888da81..f1925eef69 100644
Zbigniew Jędrzejewski-Szmek 77e6ed
--- a/src/shared/path-lookup.h
Zbigniew Jędrzejewski-Szmek 77e6ed
+++ b/src/shared/path-lookup.h
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -22,7 +22,8 @@
Zbigniew Jędrzejewski-Szmek 77e6ed
 ***/
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
 #include "macro.h"
Zbigniew Jędrzejewski-Szmek 77e6ed
-#include "install.h"
Zbigniew Jędrzejewski-Szmek 77e6ed
+
Zbigniew Jędrzejewski-Szmek 77e6ed
+typedef enum UnitFileScope UnitFileScope;
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
 typedef struct LookupPaths {
Zbigniew Jędrzejewski-Szmek 77e6ed
         char **unit_path;
Zbigniew Jędrzejewski-Szmek 77e6ed
diff --git a/src/sysv-generator/sysv-generator.c b/src/sysv-generator/sysv-generator.c
Zbigniew Jędrzejewski-Szmek 77e6ed
index 6e39b449eb..0125ca27d9 100644
Zbigniew Jędrzejewski-Szmek 77e6ed
--- a/src/sysv-generator/sysv-generator.c
Zbigniew Jędrzejewski-Szmek 77e6ed
+++ b/src/sysv-generator/sysv-generator.c
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -723,10 +723,10 @@ static int fix_order(SysvStub *s, Hashmap *all_services) {
Zbigniew Jędrzejewski-Szmek 77e6ed
         return 0;
Zbigniew Jędrzejewski-Szmek 77e6ed
 }
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-static int enumerate_sysv(LookupPaths lp, Hashmap *all_services) {
Zbigniew Jędrzejewski-Szmek 77e6ed
+static int enumerate_sysv(const LookupPaths *lp, Hashmap *all_services) {
Zbigniew Jędrzejewski-Szmek 77e6ed
         char **path;
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-        STRV_FOREACH(path, lp.sysvinit_path) {
Zbigniew Jędrzejewski-Szmek 77e6ed
+        STRV_FOREACH(path, lp->sysvinit_path) {
Zbigniew Jędrzejewski-Szmek 77e6ed
                 _cleanup_closedir_ DIR *d = NULL;
Zbigniew Jędrzejewski-Szmek 77e6ed
                 struct dirent *de;
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -768,7 +768,7 @@ static int enumerate_sysv(LookupPaths lp, Hashmap *all_services) {
Zbigniew Jędrzejewski-Szmek 77e6ed
                         if (!fpath)
Zbigniew Jędrzejewski-Szmek 77e6ed
                                 return log_oom();
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-                        if (unit_file_get_state(UNIT_FILE_SYSTEM, NULL, name) >= 0) {
Zbigniew Jędrzejewski-Szmek 77e6ed
+                        if (unit_file_lookup_state(UNIT_FILE_SYSTEM, NULL, lp, name) >= 0) {
Zbigniew Jędrzejewski-Szmek 77e6ed
                                 log_debug("Native unit for %s already exists, skipping", name);
Zbigniew Jędrzejewski-Szmek 77e6ed
                                 continue;
Zbigniew Jędrzejewski-Szmek 77e6ed
                         }
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -793,7 +793,7 @@ static int enumerate_sysv(LookupPaths lp, Hashmap *all_services) {
Zbigniew Jędrzejewski-Szmek 77e6ed
         return 0;
Zbigniew Jędrzejewski-Szmek 77e6ed
 }
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-static int set_dependencies_from_rcnd(LookupPaths lp, Hashmap *all_services) {
Zbigniew Jędrzejewski-Szmek 77e6ed
+static int set_dependencies_from_rcnd(const LookupPaths *lp, Hashmap *all_services) {
Zbigniew Jędrzejewski-Szmek 77e6ed
         char **p;
Zbigniew Jędrzejewski-Szmek 77e6ed
         unsigned i;
Zbigniew Jędrzejewski-Szmek 77e6ed
         _cleanup_closedir_ DIR *d = NULL;
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -804,7 +804,7 @@ static int set_dependencies_from_rcnd(LookupPaths lp, Hashmap *all_services) {
Zbigniew Jędrzejewski-Szmek 77e6ed
         _cleanup_set_free_ Set *shutdown_services = NULL;
Zbigniew Jędrzejewski-Szmek 77e6ed
         int r = 0;
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-        STRV_FOREACH(p, lp.sysvrcnd_path)
Zbigniew Jędrzejewski-Szmek 77e6ed
+        STRV_FOREACH(p, lp->sysvrcnd_path)
Zbigniew Jędrzejewski-Szmek 77e6ed
                 for (i = 0; i < ELEMENTSOF(rcnd_table); i ++) {
Zbigniew Jędrzejewski-Szmek 77e6ed
                         struct dirent *de;
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
@@ -954,13 +954,13 @@ int main(int argc, char *argv[]) {
Zbigniew Jędrzejewski-Szmek 77e6ed
                 return EXIT_FAILURE;
Zbigniew Jędrzejewski-Szmek 77e6ed
         }
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-        r = enumerate_sysv(lp, all_services);
Zbigniew Jędrzejewski-Szmek 77e6ed
+        r = enumerate_sysv(&lp, all_services);
Zbigniew Jędrzejewski-Szmek 77e6ed
         if (r < 0) {
Zbigniew Jędrzejewski-Szmek 77e6ed
                 log_error("Failed to generate units for all init scripts.");
Zbigniew Jędrzejewski-Szmek 77e6ed
                 return EXIT_FAILURE;
Zbigniew Jędrzejewski-Szmek 77e6ed
         }
Zbigniew Jędrzejewski-Szmek 77e6ed
 
Zbigniew Jędrzejewski-Szmek 77e6ed
-        r = set_dependencies_from_rcnd(lp, all_services);
Zbigniew Jędrzejewski-Szmek 77e6ed
+        r = set_dependencies_from_rcnd(&lp, all_services);
Zbigniew Jędrzejewski-Szmek 77e6ed
         if (r < 0) {
Zbigniew Jędrzejewski-Szmek 77e6ed
                 log_error("Failed to read runlevels from rcnd links.");
Zbigniew Jędrzejewski-Szmek 77e6ed
                 return EXIT_FAILURE;