|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
From c88a943a7300a2c206d17aabc733ba3704eb83e5 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 00:53:49 +0200
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
Subject: [PATCH] install: make sure that --root= mode doesn't make us consider
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
all units outside of search path
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
(cherry picked from commit 8f294b45cbb627d31342f6a79444be59ce7e2274)
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
---
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
src/shared/install.c | 41 +++++++++++++++++++++++++++++++++++++----
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
src/shared/util.c | 16 ----------------
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
src/shared/util.h | 1 -
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
3 files changed, 37 insertions(+), 21 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 278350be..509ae933 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,6 +47,37 @@ 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 |
+ _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 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
+ r = path_get_parent(path, &parent);
|
|
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 |
+}
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
static int lookup_paths_init_from_scope(LookupPaths *paths,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
UnitFileScope scope,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
const char *root_dir) {
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
@@ -746,7 +777,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);
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
+ q = in_search_path(*i, paths.unit_path, root_dir);
|
|
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 |
@@ -1296,6 +1327,7 @@ static int install_info_symlink_link(
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
InstallInfo *i,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
LookupPaths *paths,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
const char *config_path,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
+ const char *root_dir,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
bool force,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
UnitFileChange **changes,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
unsigned *n_changes) {
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
@@ -1308,7 +1340,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);
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
+ r = in_search_path(i->path, paths->unit_path, 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 |
@@ -1323,6 +1355,7 @@ static int install_info_apply(
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
InstallInfo *i,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
LookupPaths *paths,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
const char *config_path,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
+ const char *root_dir,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
bool force,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
UnitFileChange **changes,
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
unsigned *n_changes) {
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
@@ -1343,7 +1376,7 @@ static int install_info_apply(
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
if (r == 0)
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
r = q;
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
- q = install_info_symlink_link(i, paths, config_path, force, changes, n_changes);
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
+ q = install_info_symlink_link(i, paths, config_path, root_dir, force, changes, n_changes);
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
if (r == 0)
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
r = q;
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
@@ -1383,7 +1416,7 @@ static int install_context_apply(
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
} else if (r >= 0)
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
r += q;
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
- q = install_info_apply(i, paths, config_path, force, changes, n_changes);
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
+ q = install_info_apply(i, paths, config_path, root_dir, force, changes, n_changes);
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
if (r >= 0 && q < 0)
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
r = q;
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
diff --git a/src/shared/util.c b/src/shared/util.c
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
index 91cbf204..9be80887 100644
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
--- a/src/shared/util.c
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
+++ b/src/shared/util.c
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
@@ -4452,22 +4452,6 @@ int dirent_ensure_type(DIR *d, struct dirent *de) {
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
return 0;
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
-int in_search_path(const char *path, char **search) {
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
- char **i;
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
- _cleanup_free_ char *parent = NULL;
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
- int r;
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
-
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
- r = path_get_parent(path, &parent);
|
|
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 |
- if (path_equal(parent, *i))
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
- return 1;
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
-
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
- return 0;
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
-}
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
-
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
int get_files_in_directory(const char *path, char ***list) {
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
_cleanup_closedir_ DIR *d = NULL;
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
size_t bufsize = 0, n = 0;
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
diff --git a/src/shared/util.h b/src/shared/util.h
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
index 0f8c3933..9c38499a 100644
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
--- a/src/shared/util.h
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
+++ b/src/shared/util.h
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
@@ -543,7 +543,6 @@ int glob_extend(char ***strv, const char *path);
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
int dirent_ensure_type(DIR *d, struct dirent *de);
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
-int in_search_path(const char *path, char **search);
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
int get_files_in_directory(const char *path, char ***list);
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
|
|
Zbigniew Jędrzejewski-Szmek |
5509c0 |
char *strjoin(const char *x, ...) _sentinel_;
|