Zbigniew Jędrzejewski-Szmek 5509c0
From 7e1db29dde294155be972acf6d3e2db4d27266de Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 5509c0
From: Lennart Poettering <lennart@poettering.net>
Zbigniew Jędrzejewski-Szmek 5509c0
Date: Tue, 17 Jun 2014 01:37:54 +0200
Zbigniew Jędrzejewski-Szmek 5509c0
Subject: [PATCH] install: simplify symlink --root= logic
Zbigniew Jędrzejewski-Szmek 5509c0
Zbigniew Jędrzejewski-Szmek 5509c0
(cherry picked from commit 278fa5758c8e30f03c8c50f15873d55edfc4cbaf)
Zbigniew Jędrzejewski-Szmek 5509c0
---
Zbigniew Jędrzejewski-Szmek 5509c0
 src/shared/install.c | 59 +++++++++++++---------------------------------------
Zbigniew Jędrzejewski-Szmek 5509c0
 1 file changed, 15 insertions(+), 44 deletions(-)
Zbigniew Jędrzejewski-Szmek 5509c0
Zbigniew Jędrzejewski-Szmek 5509c0
diff --git a/src/shared/install.c b/src/shared/install.c
Zbigniew Jędrzejewski-Szmek 5509c0
index 509ae933..8322970a 100644
Zbigniew Jędrzejewski-Szmek 5509c0
--- a/src/shared/install.c
Zbigniew Jędrzejewski-Szmek 5509c0
+++ b/src/shared/install.c
Zbigniew Jędrzejewski-Szmek 5509c0
@@ -47,9 +47,8 @@ typedef struct {
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
 #define _cleanup_install_context_done_ _cleanup_(install_context_done)
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
-static int in_search_path(const char *path, char **search, const char *root_dir) {
Zbigniew Jędrzejewski-Szmek 5509c0
+static int in_search_path(const char *path, char **search) {
Zbigniew Jędrzejewski-Szmek 5509c0
         _cleanup_free_ char *parent = NULL;
Zbigniew Jędrzejewski-Szmek 5509c0
-        char **i;
Zbigniew Jędrzejewski-Szmek 5509c0
         int r;
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
         assert(path);
Zbigniew Jędrzejewski-Szmek 5509c0
@@ -58,24 +57,7 @@ static int in_search_path(const char *path, char **search, const char *root_dir)
Zbigniew Jędrzejewski-Szmek 5509c0
         if (r < 0)
Zbigniew Jędrzejewski-Szmek 5509c0
                 return r;
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
-        STRV_FOREACH(i, search) {
Zbigniew Jędrzejewski-Szmek 5509c0
-                _cleanup_free_ char *buf = NULL;
Zbigniew Jędrzejewski-Szmek 5509c0
-                const char *p;
Zbigniew Jędrzejewski-Szmek 5509c0
-
Zbigniew Jędrzejewski-Szmek 5509c0
-                if (root_dir) {
Zbigniew Jędrzejewski-Szmek 5509c0
-                        buf = strjoin(root_dir, "/", *i, NULL);
Zbigniew Jędrzejewski-Szmek 5509c0
-                        if (!buf)
Zbigniew Jędrzejewski-Szmek 5509c0
-                                return -ENOMEM;
Zbigniew Jędrzejewski-Szmek 5509c0
-
Zbigniew Jędrzejewski-Szmek 5509c0
-                        p = buf;
Zbigniew Jędrzejewski-Szmek 5509c0
-                } else
Zbigniew Jędrzejewski-Szmek 5509c0
-                        p = *i;
Zbigniew Jędrzejewski-Szmek 5509c0
-
Zbigniew Jędrzejewski-Szmek 5509c0
-                if (path_equal(parent, p))
Zbigniew Jędrzejewski-Szmek 5509c0
-                        return 1;
Zbigniew Jędrzejewski-Szmek 5509c0
-        }
Zbigniew Jędrzejewski-Szmek 5509c0
-
Zbigniew Jędrzejewski-Szmek 5509c0
-        return 0;
Zbigniew Jędrzejewski-Szmek 5509c0
+        return strv_contains(search, parent);
Zbigniew Jędrzejewski-Szmek 5509c0
 }
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
 static int lookup_paths_init_from_scope(LookupPaths *paths,
Zbigniew Jędrzejewski-Szmek 5509c0
@@ -777,7 +759,7 @@ int unit_file_link(
Zbigniew Jędrzejewski-Szmek 5509c0
                         continue;
Zbigniew Jędrzejewski-Szmek 5509c0
                 }
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
-                q = in_search_path(*i, paths.unit_path, root_dir);
Zbigniew Jędrzejewski-Szmek 5509c0
+                q = in_search_path(*i, paths.unit_path);
Zbigniew Jędrzejewski-Szmek 5509c0
                 if (q < 0)
Zbigniew Jędrzejewski-Szmek 5509c0
                         return q;
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
@@ -1021,6 +1003,7 @@ static int unit_file_load(
Zbigniew Jędrzejewski-Szmek 5509c0
                 InstallContext *c,
Zbigniew Jędrzejewski-Szmek 5509c0
                 InstallInfo *info,
Zbigniew Jędrzejewski-Szmek 5509c0
                 const char *path,
Zbigniew Jędrzejewski-Szmek 5509c0
+                const char *root_dir,
Zbigniew Jędrzejewski-Szmek 5509c0
                 bool allow_symlink) {
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
         const ConfigTableItem items[] = {
Zbigniew Jędrzejewski-Szmek 5509c0
@@ -1032,14 +1015,16 @@ static int unit_file_load(
Zbigniew Jędrzejewski-Szmek 5509c0
                 { NULL, NULL, NULL, 0, NULL }
Zbigniew Jędrzejewski-Szmek 5509c0
         };
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
-        int fd;
Zbigniew Jędrzejewski-Szmek 5509c0
         _cleanup_fclose_ FILE *f = NULL;
Zbigniew Jędrzejewski-Szmek 5509c0
-        int r;
Zbigniew Jędrzejewski-Szmek 5509c0
+        int fd, r;
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
         assert(c);
Zbigniew Jędrzejewski-Szmek 5509c0
         assert(info);
Zbigniew Jędrzejewski-Szmek 5509c0
         assert(path);
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
+        if (!isempty(root_dir))
Zbigniew Jędrzejewski-Szmek 5509c0
+                path = strappenda3(root_dir, "/", path);
Zbigniew Jędrzejewski-Szmek 5509c0
+
Zbigniew Jędrzejewski-Szmek 5509c0
         fd = open(path, O_RDONLY|O_CLOEXEC|O_NOCTTY|(allow_symlink ? 0 : O_NOFOLLOW));
Zbigniew Jędrzejewski-Szmek 5509c0
         if (fd < 0)
Zbigniew Jędrzejewski-Szmek 5509c0
                 return -errno;
Zbigniew Jędrzejewski-Szmek 5509c0
@@ -1075,30 +1060,19 @@ static int unit_file_search(
Zbigniew Jędrzejewski-Szmek 5509c0
         assert(info);
Zbigniew Jędrzejewski-Szmek 5509c0
         assert(paths);
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
-        if (info->path) {
Zbigniew Jędrzejewski-Szmek 5509c0
-                const char *path;
Zbigniew Jędrzejewski-Szmek 5509c0
-
Zbigniew Jędrzejewski-Szmek 5509c0
-                if (isempty(root_dir))
Zbigniew Jędrzejewski-Szmek 5509c0
-                        path = info->path;
Zbigniew Jędrzejewski-Szmek 5509c0
-                else
Zbigniew Jędrzejewski-Szmek 5509c0
-                        path = strappenda(root_dir, info->path);
Zbigniew Jędrzejewski-Szmek 5509c0
-
Zbigniew Jędrzejewski-Szmek 5509c0
-                return unit_file_load(c, info, path, allow_symlink);
Zbigniew Jędrzejewski-Szmek 5509c0
-        }
Zbigniew Jędrzejewski-Szmek 5509c0
+        if (info->path)
Zbigniew Jędrzejewski-Szmek 5509c0
+                return unit_file_load(c, info, info->path, root_dir, allow_symlink);
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
         assert(info->name);
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
         STRV_FOREACH(p, paths->unit_path) {
Zbigniew Jędrzejewski-Szmek 5509c0
                 _cleanup_free_ char *path = NULL;
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
-                if (isempty(root_dir))
Zbigniew Jędrzejewski-Szmek 5509c0
-                        path = strjoin(*p, "/", info->name, NULL);
Zbigniew Jędrzejewski-Szmek 5509c0
-                else
Zbigniew Jędrzejewski-Szmek 5509c0
-                        path = strjoin(root_dir, "/", *p, "/", info->name, NULL);
Zbigniew Jędrzejewski-Szmek 5509c0
+                path = strjoin(*p, "/", info->name, NULL);
Zbigniew Jędrzejewski-Szmek 5509c0
                 if (!path)
Zbigniew Jędrzejewski-Szmek 5509c0
                         return -ENOMEM;
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
-                r = unit_file_load(c, info, path, allow_symlink);
Zbigniew Jędrzejewski-Szmek 5509c0
+                r = unit_file_load(c, info, path, root_dir, allow_symlink);
Zbigniew Jędrzejewski-Szmek 5509c0
                 if (r >= 0) {
Zbigniew Jędrzejewski-Szmek 5509c0
                         info->path = path;
Zbigniew Jędrzejewski-Szmek 5509c0
                         path = NULL;
Zbigniew Jędrzejewski-Szmek 5509c0
@@ -1123,14 +1097,11 @@ static int unit_file_search(
Zbigniew Jędrzejewski-Szmek 5509c0
                 STRV_FOREACH(p, paths->unit_path) {
Zbigniew Jędrzejewski-Szmek 5509c0
                         _cleanup_free_ char *path = NULL;
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
-                        if (isempty(root_dir))
Zbigniew Jędrzejewski-Szmek 5509c0
-                                path = strjoin(*p, "/", template, NULL);
Zbigniew Jędrzejewski-Szmek 5509c0
-                        else
Zbigniew Jędrzejewski-Szmek 5509c0
-                                path = strjoin(root_dir, "/", *p, "/", template, NULL);
Zbigniew Jędrzejewski-Szmek 5509c0
+                        path = strjoin(*p, "/", template, NULL);
Zbigniew Jędrzejewski-Szmek 5509c0
                         if (!path)
Zbigniew Jędrzejewski-Szmek 5509c0
                                 return -ENOMEM;
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
-                        r = unit_file_load(c, info, path, allow_symlink);
Zbigniew Jędrzejewski-Szmek 5509c0
+                        r = unit_file_load(c, info, path, root_dir, allow_symlink);
Zbigniew Jędrzejewski-Szmek 5509c0
                         if (r >= 0) {
Zbigniew Jędrzejewski-Szmek 5509c0
                                 info->path = path;
Zbigniew Jędrzejewski-Szmek 5509c0
                                 path = NULL;
Zbigniew Jędrzejewski-Szmek 5509c0
@@ -1340,7 +1311,7 @@ static int install_info_symlink_link(
Zbigniew Jędrzejewski-Szmek 5509c0
         assert(config_path);
Zbigniew Jędrzejewski-Szmek 5509c0
         assert(i->path);
Zbigniew Jędrzejewski-Szmek 5509c0
 
Zbigniew Jędrzejewski-Szmek 5509c0
-        r = in_search_path(i->path, paths->unit_path, root_dir);
Zbigniew Jędrzejewski-Szmek 5509c0
+        r = in_search_path(i->path, paths->unit_path);
Zbigniew Jędrzejewski-Szmek 5509c0
         if (r != 0)
Zbigniew Jędrzejewski-Szmek 5509c0
                 return r;
Zbigniew Jędrzejewski-Szmek 5509c0