aboutsummaryrefslogtreecommitdiffstats
path: root/vncviewer
diff options
context:
space:
mode:
authorPierre Ossman <ossman@cendio.se>2011-07-13 17:56:26 +0000
committerPierre Ossman <ossman@cendio.se>2011-07-13 17:56:26 +0000
commitf0d92835619987eb7c1e1ac34be6f54c732c9e9e (patch)
treed921398daf4040f946d28e0cee199d60120a2655 /vncviewer
parent829cdeb5e1ec3339e337082ae549bb3ee8c1aa79 (diff)
downloadtigervnc-f0d92835619987eb7c1e1ac34be6f54c732c9e9e.tar.gz
tigervnc-f0d92835619987eb7c1e1ac34be6f54c732c9e9e.zip
Port over the AltGr hack that the old Windows viewer has. Seems we need this
to get sane behaviour when connecting to a Unix desktop. git-svn-id: svn://svn.code.sf.net/p/tigervnc/code/trunk@4584 3789f03b-4d11-0410-bbf8-ca57d06f2519
Diffstat (limited to 'vncviewer')
-rw-r--r--vncviewer/Viewport.cxx57
1 files changed, 57 insertions, 0 deletions
diff --git a/vncviewer/Viewport.cxx b/vncviewer/Viewport.cxx
index 865143a0..019d99e1 100644
--- a/vncviewer/Viewport.cxx
+++ b/vncviewer/Viewport.cxx
@@ -715,6 +715,43 @@ void Viewport::handleKeyEvent(int keyCode, int origKeyCode, const char *keyText,
if (keySym == XK_VoidSymbol)
return;
+#ifdef WIN32
+ // Ugly hack alert!
+ //
+ // Windows doesn't have a proper AltGr, but handles it using fake
+ // Ctrl+Alt. Unfortunately X11 doesn't generally like the combination
+ // Ctrl+Alt+AltGr, which we usually end up with when Xvnc tries to
+ // get everything in the correct state. Cheat and temporarily release
+ // Ctrl and Alt whenever we get a key with a symbol.
+ bool need_cheat = true;
+
+ if (keyText[0] == '\0')
+ need_cheat = false;
+ else if ((downKeySym.find(FL_Control_L) == downKeySym.end()) &&
+ (downKeySym.find(FL_Control_R) == downKeySym.end()))
+ need_cheat = false;
+ else if ((downKeySym.find(FL_Alt_L) == downKeySym.end()) &&
+ (downKeySym.find(FL_Alt_R) == downKeySym.end()))
+ need_cheat = false;
+
+ if (need_cheat) {
+ vlog.debug("Faking release of AltGr (Ctrl+Alt)");
+ try {
+ if (downKeySym.find(FL_Control_L) != downKeySym.end())
+ cc->writer()->keyEvent(XK_Control_L, false);
+ if (downKeySym.find(FL_Control_R) != downKeySym.end())
+ cc->writer()->keyEvent(XK_Control_R, false);
+ if (downKeySym.find(FL_Alt_L) != downKeySym.end())
+ cc->writer()->keyEvent(XK_Alt_L, false);
+ if (downKeySym.find(FL_Alt_R) != downKeySym.end())
+ cc->writer()->keyEvent(XK_Alt_R, false);
+ } catch (rdr::Exception& e) {
+ vlog.error(e.str());
+ exit_vncviewer(e.str());
+ }
+ }
+#endif
+
vlog.debug("Key pressed: 0x%04x (0x%04x) '%s' => 0x%04x",
origKeyCode, keyCode, keyText, keySym);
@@ -726,6 +763,26 @@ void Viewport::handleKeyEvent(int keyCode, int origKeyCode, const char *keyText,
vlog.error(e.str());
exit_vncviewer(e.str());
}
+
+#ifdef WIN32
+ // Ugly hack continued...
+ if (need_cheat) {
+ vlog.debug("Restoring AltGr state");
+ try {
+ if (downKeySym.find(FL_Control_L) != downKeySym.end())
+ cc->writer()->keyEvent(XK_Control_L, true);
+ if (downKeySym.find(FL_Control_R) != downKeySym.end())
+ cc->writer()->keyEvent(XK_Control_R, true);
+ if (downKeySym.find(FL_Alt_L) != downKeySym.end())
+ cc->writer()->keyEvent(XK_Alt_L, true);
+ if (downKeySym.find(FL_Alt_R) != downKeySym.end())
+ cc->writer()->keyEvent(XK_Alt_R, true);
+ } catch (rdr::Exception& e) {
+ vlog.error(e.str());
+ exit_vncviewer(e.str());
+ }
+ }
+#endif
}