summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--libps/tty.c71
1 files changed, 70 insertions, 1 deletions
diff --git a/libps/tty.c b/libps/tty.c
index 3e20e267..53dfcc8b 100644
--- a/libps/tty.c
+++ b/libps/tty.c
@@ -21,6 +21,7 @@
#include <hurd.h>
#include <stdio.h>
#include <stdlib.h>
+#include <string.h>
#include <assert.h>
#include <hurd/term.h>
@@ -40,6 +41,8 @@ ps_tty_create(file_t port, ps_tty_t *tty)
(*tty)->port = port;
(*tty)->name_state = PS_TTY_NAME_PENDING;
+ (*tty)->short_name = NULL;
+ (*tty)->short_name_alloced = FALSE;
return 0;
}
@@ -51,6 +54,8 @@ ps_tty_free(ps_tty_t tty)
mach_port_deallocate(mach_task_self(), tty->port);
if (tty->name_state == PS_TTY_NAME_OK && tty->name != NULL)
free(tty->name);
+ if (tty->short_name_alloced)
+ free(tty->short_name);
free(tty);
}
@@ -63,7 +68,7 @@ char *ps_tty_name(ps_tty_t tty)
{
string_t buf;
- if (term_get_nodename(tty->port, &buf) != 0)
+ if (term_get_nodename(tty->port, buf) != 0)
/* There is a terminal there, but we can't figure out its name. */
tty->name_state = PS_TTY_NAME_ERROR;
else
@@ -84,3 +89,67 @@ char *ps_tty_name(ps_tty_t tty)
else
return NULL;
}
+
+/* ---------------------------------------------------------------- */
+
+struct ps_tty_abbrev
+{
+ char *pfx;
+ char *subst;
+};
+
+struct ps_tty_abbrev ps_tty_abbrevs[] =
+{
+ { "/tmp/console", "oc" }, /* temp hack */
+ { "/dev/console", "co"},
+ { "/dev/tty", ""},
+ { "/dev/pty", ""},
+ { "/dev/", ""},
+ { 0 }
+};
+
+/* Returns the standard abbreviated name of the tty, the whole name if there
+ is no standard abbreviation, or NULL if it can't be figured out. */
+char *
+ps_tty_short_name(ps_tty_t tty)
+{
+ if (tty->short_name != NULL)
+ return tty->short_name;
+ else
+ {
+ struct ps_tty_abbrev *abbrev;
+ char *name = ps_tty_name(tty);
+
+ if (name)
+ for (abbrev = ps_tty_abbrevs; abbrev->pfx != NULL; abbrev++)
+ {
+ char *subst = abbrev->subst;
+ unsigned pfx_len = strlen(abbrev->pfx);
+
+ if (strncmp(name, abbrev->pfx, pfx_len) == 0)
+ {
+ if (name[pfx_len] == '\0')
+ tty->short_name = abbrev->subst;
+ else if (subst[0] = '\0')
+ tty->short_name = name + pfx_len;
+ else
+ {
+ tty->short_name =
+ malloc(strlen(subst) + strlen(name + pfx_len));
+ if (tty->short_name)
+ {
+ tty->short_name_alloced = TRUE;
+ strcpy(tty->short_name, subst);
+ strcat(tty->short_name, name + pfx_len);
+ }
+ }
+ break;
+ }
+ }
+
+ if (tty->short_name == NULL)
+ tty->short_name = name;
+
+ return tty->short_name;
+ }
+}