From 0f67f1efae74e6d129338f1b63ede902b3d7e5ae Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= Date: Thu, 15 Nov 2012 15:25:05 +0100 Subject: [PATCH] core: lift restriction on order of - and @ in ExecStart --- man/systemd.service.xml | 5 ++--- src/core/load-fragment.c | 20 ++++++++++++-------- src/test/test-unit-file.c | 23 +++++++++++++++++++++++ 3 files changed, 37 insertions(+), 11 deletions(-) diff --git a/man/systemd.service.xml b/man/systemd.service.xml index 00a6398a1e..8c1dfe18b7 100644 --- a/man/systemd.service.xml +++ b/man/systemd.service.xml @@ -326,9 +326,8 @@ abnormal exit due to signal) is ignored and considered success. If both - and - @ are used for the - same command the former must precede - the latter. Unless + @ are used they + can appear in either order. Unless Type=forking is set, the process started via this command line will be considered the diff --git a/src/core/load-fragment.c b/src/core/load-fragment.c index 4dc5c529a2..b99e70e05a 100644 --- a/src/core/load-fragment.c +++ b/src/core/load-fragment.c @@ -438,6 +438,7 @@ int config_parse_exec( e += ltype; for (;;) { + int i; char *w; size_t l; char *state; @@ -452,18 +453,21 @@ int config_parse_exec( if (rvalue[0] == 0) break; - if (rvalue[0] == '-') { - ignore = true; - rvalue ++; - } + for (i = 0; i < 2; i++) { + if (rvalue[0] == '-' && !ignore) { + ignore = true; + rvalue ++; + } - if (rvalue[0] == '@') { - honour_argv0 = true; - rvalue ++; + if (rvalue[0] == '@' && !honour_argv0) { + honour_argv0 = true; + rvalue ++; + } } if (*rvalue != '/') { - log_error("[%s:%u] Invalid executable path in command line, ignoring: %s", filename, line, rvalue); + log_error("[%s:%u] Executable path is not absolute, ignoring: %s", + filename, line, rvalue); return 0; } diff --git a/src/test/test-unit-file.c b/src/test/test-unit-file.c index bca8a69b78..6636b949ea 100644 --- a/src/test/test-unit-file.c +++ b/src/test/test-unit-file.c @@ -111,6 +111,29 @@ static void test_config_parse_exec(void) { check_execcommand(c1, "/RValue/slashes3", "argv0a", "r1", true); + /* ignore && honour_argv0 */ + r = config_parse_exec("fake", 4, "section", + "LValue", 0, "@-/RValue///slashes4/// argv0b r1", + &c, NULL); + assert_se(r >= 0); + c1 = c1->command_next; + check_execcommand(c1, + "/RValue/slashes4", "argv0b", "r1", true); + + /* ignore && ignore */ + r = config_parse_exec("fake", 4, "section", + "LValue", 0, "--/RValue argv0 r1", + &c, NULL); + assert_se(r == 0); + assert_se(c1->command_next == NULL); + + /* ignore && ignore */ + r = config_parse_exec("fake", 4, "section", + "LValue", 0, "-@-/RValue argv0 r1", + &c, NULL); + assert_se(r == 0); + assert_se(c1->command_next == NULL); + /* semicolon */ r = config_parse_exec("fake", 5, "section", "LValue", 0,