From: Lennart Poettering Date: Sun, 13 Feb 2011 18:01:47 +0000 (+0100) Subject: util: when determining the right TERM for /dev/console consult /sys/class/tty/console... X-Git-Tag: v18~27 X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=3030ccd79f71854551d06cda904fd56b85b1aeb7;p=systemd util: when determining the right TERM for /dev/console consult /sys/class/tty/console/active --- diff --git a/src/util.c b/src/util.c index 09c13143..e78063c5 100644 --- a/src/util.c +++ b/src/util.c @@ -3550,18 +3550,28 @@ void filter_environ(const char *prefix) { } const char *default_term_for_tty(const char *tty) { + char *active = NULL; + const char *term; + assert(tty); if (startswith(tty, "/dev/")) tty += 5; - if (startswith(tty, "tty") && - tty[3] >= '0' && tty[3] <= '9') - return "TERM=linux"; + /* Resolve where /dev/console is pointing when determining + * TERM */ + if (streq(tty, "console")) + if (read_one_line_file("/sys/class/tty/console/active", &active) >= 0) { + truncate_nl(active); + tty = active; + } + + term = (startswith(tty, "tty") && + tty[3] >= '0' && tty[3] <= '9') ? "TERM=linux" : "TERM=vt100"; - /* FIXME: Proper handling of /dev/console would be cool */ + free(active); - return "TERM=vt100"; + return term; } bool running_in_vm(void) {