summaryrefslogtreecommitdiff
path: root/usr.bin/tmux
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@cvs.openbsd.org>2013-05-31 19:46:43 +0000
committerNicholas Marriott <nicm@cvs.openbsd.org>2013-05-31 19:46:43 +0000
commit19d7b14e58409cab47706b37687f3d67ad783b7d (patch)
treeafa189f9454bf9f5ea0ec309d20b60caf84bd974 /usr.bin/tmux
parent992a59f18ab0b55b4b125b7e8abdae7993d6cbe8 (diff)
Add host_short format, from Tiago Cunha.
Diffstat (limited to 'usr.bin/tmux')
-rw-r--r--usr.bin/tmux/format.c76
-rw-r--r--usr.bin/tmux/tmux.15
2 files changed, 59 insertions, 22 deletions
diff --git a/usr.bin/tmux/format.c b/usr.bin/tmux/format.c
index ac9274c7730..f979224a133 100644
--- a/usr.bin/tmux/format.c
+++ b/usr.bin/tmux/format.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: format.c,v 1.24 2013/04/17 14:52:31 deraadt Exp $ */
+/* $OpenBSD: format.c,v 1.25 2013/05/31 19:46:42 nicm Exp $ */
/*
* Copyright (c) 2011 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -46,8 +46,8 @@ format_cmp(struct format_entry *fe1, struct format_entry *fe2)
return (strcmp(fe1->key, fe2->key));
}
-/* Single-character aliases. */
-const char *format_aliases[26] = {
+/* Single-character uppercase aliases. */
+const char *format_upper[] = {
NULL, /* A */
NULL, /* B */
NULL, /* C */
@@ -76,18 +76,52 @@ const char *format_aliases[26] = {
NULL /* Z */
};
+/* Single-character lowercase aliases. */
+const char *format_lower[] = {
+ NULL, /* a */
+ NULL, /* b */
+ NULL, /* c */
+ NULL, /* d */
+ NULL, /* e */
+ NULL, /* f */
+ NULL, /* g */
+ "host_short", /* h */
+ NULL, /* i */
+ NULL, /* j */
+ NULL, /* k */
+ NULL, /* l */
+ NULL, /* m */
+ NULL, /* n */
+ NULL, /* o */
+ NULL, /* p */
+ NULL, /* q */
+ NULL, /* r */
+ NULL, /* s */
+ NULL, /* t */
+ NULL, /* u */
+ NULL, /* v */
+ NULL, /* w */
+ NULL, /* x */
+ NULL, /* y */
+ NULL /* z */
+};
+
/* Create a new tree. */
struct format_tree *
format_create(void)
{
struct format_tree *ft;
- char host[MAXHOSTNAMELEN];
+ char host[MAXHOSTNAMELEN], *ptr;
ft = xmalloc(sizeof *ft);
RB_INIT(ft);
- if (gethostname(host, sizeof host) == 0)
+ if (gethostname(host, sizeof host) == 0) {
format_add(ft, "host", "%s", host);
+ if ((ptr = strrchr(host, '.')) != NULL)
+ *ptr = '\0';
+ format_add(ft, "host_short", "%s", host);
+ }
return (ft);
}
@@ -109,7 +143,7 @@ format_free(struct format_tree *ft)
free(fe);
}
- free (ft);
+ free(ft);
}
/* Add a key-value pair. */
@@ -230,6 +264,7 @@ format_expand(struct format_tree *ft, const char *fmt)
fmt++;
ch = (u_char) *fmt++;
+
switch (ch) {
case '{':
ptr = strchr(fmt, '}');
@@ -242,22 +277,23 @@ format_expand(struct format_tree *ft, const char *fmt)
fmt += n + 1;
continue;
default:
- if (ch >= 'A' && ch <= 'Z') {
- s = format_aliases[ch - 'A'];
- if (s != NULL) {
- n = strlen(s);
- if (format_replace (
- ft, s, n, &buf, &len, &off) != 0)
- break;
- continue;
+ s = NULL;
+ if (ch >= 'A' && ch <= 'Z')
+ s = format_upper[ch - 'A'];
+ else if (ch >= 'a' && ch <= 'z')
+ s = format_lower[ch - 'a'];
+ if (s == NULL) {
+ while (len - off < 3) {
+ buf = xrealloc(buf, 2, len);
+ len *= 2;
}
+ buf[off++] = '#';
+ buf[off++] = ch;
+ continue;
}
- while (len - off < 3) {
- buf = xrealloc(buf, 2, len);
- len *= 2;
- }
- buf[off++] = '#';
- buf[off++] = ch;
+ n = strlen(s);
+ if (format_replace(ft, s, n, &buf, &len, &off) != 0)
+ break;
continue;
}
diff --git a/usr.bin/tmux/tmux.1 b/usr.bin/tmux/tmux.1
index cfa5b06b486..a5e7ecdb3d8 100644
--- a/usr.bin/tmux/tmux.1
+++ b/usr.bin/tmux/tmux.1
@@ -1,4 +1,4 @@
-.\" $OpenBSD: tmux.1,v 1.357 2013/04/24 10:15:47 nicm Exp $
+.\" $OpenBSD: tmux.1,v 1.358 2013/05/31 19:46:42 nicm Exp $
.\"
.\" Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
.\"
@@ -14,7 +14,7 @@
.\" IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
.\" OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
.\"
-.Dd $Mdocdate: April 24 2013 $
+.Dd $Mdocdate: May 31 2013 $
.Dt TMUX 1
.Os
.Sh NAME
@@ -3056,6 +3056,7 @@ The following variables are available, where appropriate:
.It Li "history_limit" Ta "Maximum window history lines"
.It Li "history_size" Ta "Size of history in bytes"
.It Li "host" Ta "Hostname of local host"
+.It Li "host_short" Ta "Hostname of local host (no domain name)"
.It Li "insert_flag" Ta "Pane insert flag"
.It Li "keypad_cursor_flag" Ta "Pane keypad cursor flag"
.It Li "keypad_flag" Ta "Pane keypad flag"