diff options
author | Christoph Lohmann <20h@r-36.net> | 2013-06-01 13:06:53 +0200 |
---|---|---|
committer | Christoph Lohmann <20h@r-36.net> | 2013-06-01 13:06:53 +0200 |
commit | 405fd89ac1d333be79325417c973a07ccad67453 (patch) | |
tree | 5e887eb5906c5088b602ab494948508faf8a866e /st.c | |
parent | 8315dc417982936186837edfac24420d0d0e516e (diff) |
Implementing mouse focus and all events.
Diffstat (limited to 'st.c')
-rw-r--r-- | st.c | 15 |
1 files changed, 15 insertions, 0 deletions
@@ -118,6 +118,7 @@ enum term_mode { MODE_8BIT = 8192, MODE_BLINK = 16384, MODE_FBLINK = 32768, + MODE_FOCUS = 65536, }; enum escape_state { @@ -1782,6 +1783,13 @@ tsetmode(bool priv, bool set, int *args, int narg) { MODBIT(term.mode, set, MODE_MOUSEMOTION); MODBIT(term.mode, 0, MODE_MOUSEBTN); break; + case 1003: /* 1003: enable all mouse reports */ + MODBIT(term.mode, set, MODE_MOUSEMOTION); + MODBIT(term.mode, set, MODE_MOUSEBTN); + break; + case 1004: + MODBIT(term.mode, set, MODE_FOCUS); + break; case 1006: MODBIT(term.mode, set, MODE_MOUSESGR); break; @@ -1807,6 +1815,9 @@ tsetmode(bool priv, bool set, int *args, int narg) { case 1048: tcursor((set) ? CURSOR_SAVE : CURSOR_LOAD); break; + case 9: /* X10 compatibility mode */ + case 1001: /* mouse highlight mode; can hang the + terminal when implemented. */ default: fprintf(stderr, "erresc: unknown private set/reset mode %d\n", @@ -3309,9 +3320,13 @@ focus(XEvent *ev) { XSetICFocus(xw.xic); xw.state |= WIN_FOCUSED; xseturgency(0); + if(IS_SET(MODE_FOCUS)) + ttywrite("\033[I", 3); } else { XUnsetICFocus(xw.xic); xw.state &= ~WIN_FOCUSED; + if(IS_SET(MODE_FOCUS)) + ttywrite("\033[O", 3); } } |