|
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 |
|