From 3030ccd79f71854551d06cda904fd56b85b1aeb7 Mon Sep 17 00:00:00 2001 From: Lennart Poettering Date: Sun, 13 Feb 2011 19:01:47 +0100 Subject: util: when determining the right TERM for /dev/console consult /sys/class/tty/console/active --- src/util.c | 20 +++++++++++++++----- 1 file changed, 15 insertions(+), 5 deletions(-) diff --git a/src/util.c b/src/util.c index 09c13143c6..e78063c5aa 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) { -- cgit v1.2.3-54-g00ecf