|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
From a13ee4c792cb5738c3dd13b2a4bb1a828e7994fd Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Date: Fri, 29 Aug 2014 07:48:33 -0500
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Subject: [PATCH] cgroup-util: shorten cg_path_get_session
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
---
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/shared/cgroup-util.c | 12 ++++--------
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/test/test-cgroup-util.c | 3 ++-
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
2 files changed, 6 insertions(+), 9 deletions(-)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/shared/cgroup-util.c b/src/shared/cgroup-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index e8cb9c73ac..00eac64236 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/shared/cgroup-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/shared/cgroup-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -1306,9 +1306,8 @@ int cg_pid_get_machine_name(pid_t pid, char **machine) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
int cg_path_get_session(const char *path, char **session) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- const char *e, *n, *x;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ const char *e, *n, *x, *y;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
char *s;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- size_t l;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
assert(path);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -1325,17 +1324,14 @@ int cg_path_get_session(const char *path, char **session) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
x = startswith(s, "session-");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
if (!x)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
return -ENOENT;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- if (!endswith(x, ".scope"))
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- return -ENOENT;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
-
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- l = strlen(x);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- if (l <= 6)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ y = endswith(x, ".scope");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ if (!y || x == y)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
return -ENOENT;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
if (session) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
char *r;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- r = strndup(x, l - 6);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ r = strndup(x, y - x);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
if (!r)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
return -ENOMEM;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/test/test-cgroup-util.c b/src/test/test-cgroup-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index fda8bcc5c5..68c526ae82 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/test/test-cgroup-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/test/test-cgroup-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -106,7 +106,8 @@ static void check_p_g_s(const char *path, int code, const char *result) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
static void test_path_get_session(void) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
check_p_g_s("/user.slice/user-1000.slice/session-2.scope/foobar.service", 0, "2");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
check_p_g_s("/session-3.scope", 0, "3");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- check_p_g_s("", -ENOENT, 0);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ check_p_g_s("/session-.scope", -ENOENT, NULL);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ check_p_g_s("", -ENOENT, NULL);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
static void check_p_g_o_u(const char *path, int code, uid_t result) {
|