aboutsummaryrefslogtreecommitdiff
path: root/tty-keys.c
diff options
context:
space:
mode:
authorTiago Cunha <tcunha@gmx.com>2009-10-12 00:18:19 +0000
committerTiago Cunha <tcunha@gmx.com>2009-10-12 00:18:19 +0000
commitb26ea8462ec0bb7d3d5cbeed115f6f4bbd4e1072 (patch)
tree698ba80e7b13c711d195e1b4c75adad2bfcc7d5f /tty-keys.c
parent323469723b29fdd05a88e55ce9d3346f10506458 (diff)
downloadrtmux-b26ea8462ec0bb7d3d5cbeed115f6f4bbd4e1072.tar.gz
rtmux-b26ea8462ec0bb7d3d5cbeed115f6f4bbd4e1072.tar.bz2
rtmux-b26ea8462ec0bb7d3d5cbeed115f6f4bbd4e1072.zip
Sync OpenBSD patchset 381:
Clean up by introducing a wrapper struct for mouse clicks rather than passing three u_chars around. As a side-effect this fixes incorrectly rejecting high cursor positions (because it was comparing them as signed char), reported by Tom Doherty.
Diffstat (limited to 'tty-keys.c')
-rw-r--r--tty-keys.c23
1 files changed, 12 insertions, 11 deletions
diff --git a/tty-keys.c b/tty-keys.c
index d6bd5f2e..99ba6b9b 100644
--- a/tty-keys.c
+++ b/tty-keys.c
@@ -1,4 +1,4 @@
-/* $Id: tty-keys.c,v 1.30 2009-09-20 22:11:27 tcunha Exp $ */
+/* $Id: tty-keys.c,v 1.31 2009-10-12 00:18:19 tcunha Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -27,7 +27,7 @@
void tty_keys_add(struct tty *, const char *, int, int);
int tty_keys_parse_xterm(struct tty *, char *, size_t, size_t *);
-int tty_keys_parse_mouse(struct tty *, char *, size_t, size_t *, u_char *);
+int tty_keys_parse_mouse(char *, size_t, size_t *, struct mouse_event *);
struct tty_key_ent {
enum tty_code_code code;
@@ -231,7 +231,7 @@ tty_keys_find(struct tty *tty, char *buf, size_t len, size_t *size)
}
int
-tty_keys_next(struct tty *tty, int *key, u_char *mouse)
+tty_keys_next(struct tty *tty, int *key, struct mouse_event *mouse)
{
struct tty_key *tk;
struct timeval tv;
@@ -269,7 +269,7 @@ tty_keys_next(struct tty *tty, int *key, u_char *mouse)
}
/* Not found. Is this a mouse key press? */
- *key = tty_keys_parse_mouse(tty, buf, len, &size, mouse);
+ *key = tty_keys_parse_mouse(buf, len, &size, mouse);
if (*key != KEYC_NONE) {
buffer_remove(tty->in, size);
goto found;
@@ -331,8 +331,7 @@ found:
}
int
-tty_keys_parse_mouse(
- unused struct tty *tty, char *buf, size_t len, size_t *size, u_char *mouse)
+tty_keys_parse_mouse(char *buf, size_t len, size_t *size, struct mouse_event *m)
{
/*
* Mouse sequences are \033[M followed by three characters indicating
@@ -344,12 +343,14 @@ tty_keys_parse_mouse(
return (KEYC_NONE);
*size = 6;
- if (buf[3] < 32 || buf[4] < 33 || buf[5] < 33)
+ m->b = buf[3];
+ m->x = buf[4];
+ m->y = buf[5];
+ if (m->b < 32 || m->x < 33 || m->y < 33)
return (KEYC_NONE);
-
- mouse[0] = buf[3] - 32;
- mouse[1] = buf[4] - 33;
- mouse[2] = buf[5] - 33;
+ m->b -= 32;
+ m->x -= 33;
+ m->y -= 33;
return (KEYC_MOUSE);
}