summaryrefslogtreecommitdiff
path: root/usr.bin/tmux/tty.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@cvs.openbsd.org>2019-11-28 09:05:35 +0000
committerNicholas Marriott <nicm@cvs.openbsd.org>2019-11-28 09:05:35 +0000
commitcd611b35a50075d97d586625dfd38e67ef935a63 (patch)
treebc4d2a048a782e44cd422f60d0ee436799757f04 /usr.bin/tmux/tty.c
parentce3b476e5570567573ce3ac4a03c418c1105021a (diff)
Store xpixel/ypixel from TIOCGWINSZ and add formats.
Diffstat (limited to 'usr.bin/tmux/tty.c')
-rw-r--r--usr.bin/tmux/tty.c25
1 files changed, 18 insertions, 7 deletions
diff --git a/usr.bin/tmux/tty.c b/usr.bin/tmux/tty.c
index 81d29e0036b..d81e7ea5e0b 100644
--- a/usr.bin/tmux/tty.c
+++ b/usr.bin/tmux/tty.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: tty.c,v 1.333 2019/11/14 07:56:32 nicm Exp $ */
+/* $OpenBSD: tty.c,v 1.334 2019/11/28 09:05:34 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com>
@@ -127,29 +127,40 @@ tty_resize(struct tty *tty)
{
struct client *c = tty->client;
struct winsize ws;
- u_int sx, sy;
+ u_int sx, sy, xpixel, ypixel;
if (ioctl(tty->fd, TIOCGWINSZ, &ws) != -1) {
sx = ws.ws_col;
- if (sx == 0)
+ if (sx == 0) {
sx = 80;
+ xpixel = 0;
+ } else
+ xpixel = ws.ws_xpixel / sx;
sy = ws.ws_row;
- if (sy == 0)
+ if (sy == 0) {
sy = 24;
+ ypixel = 0;
+ } else
+ ypixel = ws.ws_ypixel / sy;
} else {
sx = 80;
sy = 24;
+ xpixel = 0;
+ ypixel = 0;
}
- log_debug("%s: %s now %ux%u", __func__, c->name, sx, sy);
- tty_set_size(tty, sx, sy);
+ log_debug("%s: %s now %ux%u (%ux%u)", __func__, c->name, sx, sy,
+ xpixel, ypixel);
+ tty_set_size(tty, sx, sy, xpixel, ypixel);
tty_invalidate(tty);
}
void
-tty_set_size(struct tty *tty, u_int sx, u_int sy)
+tty_set_size(struct tty *tty, u_int sx, u_int sy, u_int xpixel, u_int ypixel)
{
tty->sx = sx;
tty->sy = sy;
+ tty->xpixel = xpixel;
+ tty->ypixel = ypixel;
}
static void