]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
pid1: initialize status color mode after setting up TERM 3526/head
authorFranck Bui <fbui@suse.com>
Mon, 20 Jun 2016 19:45:28 +0000 (21:45 +0200)
committerFranck Bui <fbui@suse.com>
Wed, 22 Jun 2016 06:29:02 +0000 (08:29 +0200)
Also we had to connect PID's stdio to null later since colors_enabled()
assume that stdout is connected to the console.

src/core/main.c

index 0a09ff514af9c90aabe0a364c9cb4ac6931eedff..6124a984c3dc06184bd94b5f100e114563fadd02 100644 (file)
@@ -1382,7 +1382,6 @@ int main(int argc, char *argv[]) {
         saved_argv = argv;
         saved_argc = argc;
 
-        log_show_color(colors_enabled());
         log_set_upgrade_syslog_to_journal(true);
 
         /* Disable the umask logic */
@@ -1393,7 +1392,6 @@ int main(int argc, char *argv[]) {
 
                 /* Running outside of a container as PID 1 */
                 arg_system = true;
-                make_null_stdio();
                 log_set_target(LOG_TARGET_KMSG);
                 log_open();
 
@@ -1511,12 +1509,19 @@ int main(int argc, char *argv[]) {
 
         /* We expect the environment to be set correctly if run inside a
          * container. */
-        if (arg_system && detect_container() <= 0)
+        if (arg_system && detect_container() <= 0) {
                 if (fixup_environment() < 0) {
                         error_message = "Failed to fix up PID1 environment";
                         goto finish;
                 }
 
+                /* Try to figure out if we can use colors with the console. No
+                 * need to do that for user instances since they never log
+                 * into the console. */
+                log_show_color(colors_enabled());
+                make_null_stdio();
+        }
+
         /* Initialize default unit */
         r = free_and_strdup(&arg_default_unit, SPECIAL_DEFAULT_TARGET);
         if (r < 0) {