From: William Douglas Date: Tue, 7 Feb 2012 20:31:20 +0000 (-0800) Subject: systemd: Add systemd.setenv for /proc/cmdline parsing. X-Git-Tag: v41~17 X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=9e7c53579a1d16287134e64f78ec5e1451aa2506;p=systemd systemd: Add systemd.setenv for /proc/cmdline parsing. Check for systemd.setenv when parsing /proc/cmdline. ex: systemd.setenv=PATH=/opt/bin --- diff --git a/src/main.c b/src/main.c index a849824b..ed317b44 100644 --- a/src/main.c +++ b/src/main.c @@ -323,6 +323,26 @@ static int parse_proc_cmdline_word(const char *word) { log_warning("Failed to parse default standard error switch %s. Ignoring.", word + 31); else arg_default_std_error = r; + } else if (startswith(word, "systemd.setenv=")) { + char *cenv, *eq; + int r; + + cenv = strdup(word + 15); + if (!cenv) + return -ENOMEM; + + eq = strchr(cenv, '='); + if (!eq) { + r = unsetenv(cenv); + if (r < 0) + log_warning("unsetenv failed %s. Ignoring.", strerror(errno)); + } else { + *eq = 0; + r = setenv(cenv, eq + 1, 1); + if (r < 0) + log_warning("setenv failed %s. Ignoring.", strerror(errno)); + } + free(cenv); #ifdef HAVE_SYSV_COMPAT } else if (startswith(word, "systemd.sysv_console=")) { int r;