mirror of https://github.com/adamdruppe/arsd.git
more mouse bugs
This commit is contained in:
parent
5400e91cbf
commit
0bc256f9d0
65
terminal.d
65
terminal.d
|
@ -575,6 +575,10 @@ struct Terminal {
|
||||||
doTermcap("ti");
|
doTermcap("ti");
|
||||||
moveTo(0, 0, ForceOption.alwaysSend); // we need to know where the cursor is for some features to work, and moving it is easier than querying it
|
moveTo(0, 0, ForceOption.alwaysSend); // we need to know where the cursor is for some features to work, and moving it is easier than querying it
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(terminalInFamily("xterm", "rxvt", "screen")) {
|
||||||
|
writeStringRaw("\033[22;0t"); // save window title on a stack (support seems spotty, but it doesn't hurt to have it)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
version(Windows)
|
version(Windows)
|
||||||
|
@ -617,6 +621,9 @@ http://msdn.microsoft.com/en-us/library/windows/desktop/ms683193%28v=vs.85%29.as
|
||||||
if(type == ConsoleOutputType.cellular) {
|
if(type == ConsoleOutputType.cellular) {
|
||||||
doTermcap("te");
|
doTermcap("te");
|
||||||
}
|
}
|
||||||
|
if(terminalInFamily("xterm", "rxvt", "screen")) {
|
||||||
|
writeStringRaw("\033[23;0t"); // restore window title from the stack
|
||||||
|
}
|
||||||
showCursor();
|
showCursor();
|
||||||
reset();
|
reset();
|
||||||
flush();
|
flush();
|
||||||
|
@ -1110,9 +1117,20 @@ struct RealTimeConsoleInput {
|
||||||
|
|
||||||
|
|
||||||
if(flags & ConsoleInputFlags.mouse) {
|
if(flags & ConsoleInputFlags.mouse) {
|
||||||
if(terminal.terminalInFamily("xterm", "rxvt", "screen", "linux")) {
|
// basic button press+release notification
|
||||||
terminal.writeStringRaw("\033[?1000h"); // this is vt200 mouse, supported by xterm and linux + gpm
|
|
||||||
destructor ~= { terminal.writeStringRaw("\033[?1000l"); };
|
// FIXME: try to get maximum capabilities from all terminals
|
||||||
|
// right now this works well on xterm but rxvt isn't sending movements...
|
||||||
|
|
||||||
|
terminal.writeStringRaw("\033[?1000h");
|
||||||
|
destructor ~= { terminal.writeStringRaw("\033[?1000l"); };
|
||||||
|
if(terminal.terminalInFamily("xterm")) {
|
||||||
|
// this is vt200 mouse with full motion tracking, supported by xterm
|
||||||
|
terminal.writeStringRaw("\033[?1003h");
|
||||||
|
destructor ~= { terminal.writeStringRaw("\033[?1003l"); };
|
||||||
|
} else if(terminal.terminalInFamily("rxvt", "screen")) {
|
||||||
|
terminal.writeStringRaw("\033[?1002h"); // this is vt200 mouse with press/release and motion notification iff buttons are pressed
|
||||||
|
destructor ~= { terminal.writeStringRaw("\033[?1002l"); };
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(flags & ConsoleInputFlags.paste) {
|
if(flags & ConsoleInputFlags.paste) {
|
||||||
|
@ -1395,15 +1413,21 @@ struct RealTimeConsoleInput {
|
||||||
|
|
||||||
switch(ev.dwEventFlags) {
|
switch(ev.dwEventFlags) {
|
||||||
case 0:
|
case 0:
|
||||||
//press
|
//press or release
|
||||||
e.eventType = MouseEvent.Type.Pressed;
|
e.eventType = MouseEvent.Type.Pressed;
|
||||||
|
static DWORD lastButtonState;
|
||||||
e.buttons = ev.dwButtonState;
|
e.buttons = ev.dwButtonState;
|
||||||
|
|
||||||
// this is sent on state change. if nothing is pressed, it must mean released
|
// this is sent on state change. if fewer buttons are pressed, it must mean released
|
||||||
// FIXME: ideally we should compare the current state to the previous state to generate
|
if(e.buttons < lastButtonState) {
|
||||||
// the appropriate event
|
|
||||||
if(e.buttons == 0)
|
|
||||||
e.eventType = MouseEvent.Type.Released;
|
e.eventType = MouseEvent.Type.Released;
|
||||||
|
// if last was 101 and now it is 100, then button far right was released
|
||||||
|
// so we flip the bits, ~100 == 011, then and them: 101 & 011 == 001, the
|
||||||
|
// button that was released
|
||||||
|
e.buttons = lastButtonState & ~e.buttons;
|
||||||
|
}
|
||||||
|
|
||||||
|
lastButtonState = e.buttons;
|
||||||
break;
|
break;
|
||||||
case MOUSE_MOVED:
|
case MOUSE_MOVED:
|
||||||
e.eventType = MouseEvent.Type.Moved;
|
e.eventType = MouseEvent.Type.Moved;
|
||||||
|
@ -1577,7 +1601,7 @@ struct RealTimeConsoleInput {
|
||||||
break;
|
break;
|
||||||
case "\033[M":
|
case "\033[M":
|
||||||
// mouse event
|
// mouse event
|
||||||
auto buttonCode = nextRaw();
|
auto buttonCode = nextRaw() - 32;
|
||||||
// nextChar is commented because i'm not using UTF-8 mouse mode
|
// nextChar is commented because i'm not using UTF-8 mouse mode
|
||||||
// cuz i don't think it is as widely supported
|
// cuz i don't think it is as widely supported
|
||||||
auto x = cast(int) (/*nextChar*/(nextRaw())) - 33; /* they encode value + 32, but make upper left 1,1. I want it to be 0,0 */
|
auto x = cast(int) (/*nextChar*/(nextRaw())) - 33; /* they encode value + 32, but make upper left 1,1. I want it to be 0,0 */
|
||||||
|
@ -1609,9 +1633,28 @@ struct RealTimeConsoleInput {
|
||||||
// 16 == control
|
// 16 == control
|
||||||
|
|
||||||
MouseEvent m;
|
MouseEvent m;
|
||||||
m.eventType = isRelease ? MouseEvent.Type.Released : MouseEvent.Type.Pressed;
|
|
||||||
|
if(buttonCode & 32)
|
||||||
|
m.eventType = MouseEvent.Type.Moved;
|
||||||
|
else
|
||||||
|
m.eventType = isRelease ? MouseEvent.Type.Released : MouseEvent.Type.Pressed;
|
||||||
|
|
||||||
|
// ugh, if no buttons are pressed, released and moved are indistinguishable...
|
||||||
|
// so we'll count the buttons down, and if we get a release
|
||||||
|
static int buttonsDown = 0;
|
||||||
|
if(!isRelease && buttonNumber <= 3) // exclude wheel "presses"...
|
||||||
|
buttonsDown++;
|
||||||
|
|
||||||
|
if(isRelease && m.eventType != MouseEvent.Type.Moved) {
|
||||||
|
if(buttonsDown)
|
||||||
|
buttonsDown--;
|
||||||
|
else // no buttons down, so this should be a motion instead..
|
||||||
|
m.eventType = MouseEvent.Type.Moved;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if(buttonNumber == 0)
|
if(buttonNumber == 0)
|
||||||
m.buttons = 0; // we don't actually know
|
m.buttons = 0; // we don't actually know :(
|
||||||
else
|
else
|
||||||
m.buttons = 1 << (buttonNumber - 1); // I prefer flags so that's how we do it
|
m.buttons = 1 << (buttonNumber - 1); // I prefer flags so that's how we do it
|
||||||
m.x = x;
|
m.x = x;
|
||||||
|
|
Loading…
Reference in New Issue