From 670f23f1698bb19ea2869e8f82198b2f9083ef88 Mon Sep 17 00:00:00 2001 From: Shreesh Adiga <16567adigashreesh@gmail.com> Date: Wed, 11 Nov 2020 15:30:08 +0530 Subject: osdep/terminal: Add function to get terminal pixel dimensions --- osdep/terminal-unix.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) (limited to 'osdep/terminal-unix.c') diff --git a/osdep/terminal-unix.c b/osdep/terminal-unix.c index 8e4d75f78b..78eb4c4618 100644 --- a/osdep/terminal-unix.c +++ b/osdep/terminal-unix.c @@ -493,6 +493,19 @@ void terminal_get_size(int *w, int *h) *h = ws.ws_row; } +void terminal_get_size2(int *rows, int *cols, int *px_width, int *px_height) +{ + struct winsize ws; + if (ioctl(tty_in, TIOCGWINSZ, &ws) < 0 || !ws.ws_row || !ws.ws_col + || !ws.ws_xpixel || !ws.ws_ypixel) + return; + + *rows = ws.ws_row; + *cols = ws.ws_col; + *px_width = ws.ws_xpixel; + *px_height = ws.ws_ypixel; +} + void terminal_init(void) { assert(!getch2_enabled); -- cgit v1.2.3