diff options
author | Lennart Poettering <lennart@poettering.net> | 2016-04-20 20:26:34 +0200 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2016-04-20 20:26:34 +0200 |
commit | f15ab461ec10cb0164b9e6110957012d052415ea (patch) | |
tree | 51bac2b0baf064fc0ec93133e88656e46a3ca71a /src/basic/terminal-util.c | |
parent | 129baf1bbfe3174a667c1ae73de131c503c025ea (diff) | |
parent | df8dee85da5fa41e95dd7f536e67fcc6940a6488 (diff) |
Merge pull request #3074 from keszybz/tmpfiles
systemd-tmpfiles improvements, nspawn -E, honouring $TERM in pid1
Diffstat (limited to 'src/basic/terminal-util.c')
-rw-r--r-- | src/basic/terminal-util.c | 19 |
1 files changed, 12 insertions, 7 deletions
diff --git a/src/basic/terminal-util.c b/src/basic/terminal-util.c index 0a9d2bbdef..9521b79daa 100644 --- a/src/basic/terminal-util.c +++ b/src/basic/terminal-util.c @@ -1135,14 +1135,19 @@ int open_terminal_in_namespace(pid_t pid, const char *name, int mode) { } bool colors_enabled(void) { - const char *colors; + static int enabled = -1; - colors = getenv("SYSTEMD_COLORS"); - if (!colors) { - if (streq_ptr(getenv("TERM"), "dumb")) - return false; - return on_tty(); + if (_unlikely_(enabled < 0)) { + const char *colors; + + colors = getenv("SYSTEMD_COLORS"); + if (colors) + enabled = parse_boolean(colors) != 0; + else if (streq_ptr(getenv("TERM"), "dumb")) + enabled = false; + else + enabled = on_tty(); } - return parse_boolean(colors) != 0; + return enabled; } |