summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPierre Ossman <ossman@cendio.se>2012-10-03 12:21:54 +0000
committerPierre Ossman <ossman@cendio.se>2012-10-03 12:21:54 +0000
commit9e0e7543072fc579f7a1a0cd075487e88712a500 (patch)
tree95452e13ac230e153b4057add8e02739402231cd
parent002cc5d12989da562baa14e075f1386574a8d341 (diff)
downloadtigervnc-9e0e7543072fc579f7a1a0cd075487e88712a500.tar.gz
tigervnc-9e0e7543072fc579f7a1a0cd075487e88712a500.zip
XFCE's window manager did not interact well with the code that avoided
accidental legacy full screen requests. Seems we need to sort that FIXME out sooner rather than later. git-svn-id: svn://svn.code.sf.net/p/tigervnc/code/trunk@5002 3789f03b-4d11-0410-bbf8-ca57d06f2519
-rw-r--r--vncviewer/DesktopWindow.cxx41
1 files changed, 25 insertions, 16 deletions
diff --git a/vncviewer/DesktopWindow.cxx b/vncviewer/DesktopWindow.cxx
index ed62de0f..fad5ad3e 100644
--- a/vncviewer/DesktopWindow.cxx
+++ b/vncviewer/DesktopWindow.cxx
@@ -281,26 +281,35 @@ void DesktopWindow::resize(int x, int y, int w, int h)
#if ! (defined(WIN32) || defined(__APPLE__))
// X11 window managers will treat a resize to cover the entire
// monitor as a request to go full screen. Make sure we avoid this.
- //
- // FIXME: If this is an external event then this code will get
- // FLTK into a confused state about the window's position/size.
- // Unfortunately FLTK doesn't offer an easy way to tell
- // what kind of resize it is. Let's hope this corner case
- // isn't too common...
#ifdef HAVE_FLTK_FULLSCREEN
if (!fullscreen_active())
#endif
{
- for (int i = 0;i < Fl::screen_count();i++) {
- int sx, sy, sw, sh;
-
- Fl::screen_xywh(sx, sy, sw, sh, i);
-
- if ((sx == x) && (sy == y) && (sw == w) && (sh == h)) {
- vlog.info("Adjusting window size to avoid accidental full screen request");
- // Assume a panel of some form and adjust the height
- y += 20;
- h -= 40;
+ // Get the real window coordinates, so we can determine if
+ // this is a request to resize, or a notification of a resize
+ // from the X server.
+ XWindowAttributes actual;
+ Window cr;
+ int wx, wy;
+
+ XGetWindowAttributes(fl_display, fl_xid(this), &actual);
+ XTranslateCoordinates(fl_display, fl_xid(this), actual.root,
+ 0, 0, &wx, &wy, &cr);
+
+ // Actual resize request?
+ if ((wx != x) || (wy != y) ||
+ (actual.width != w) || (actual.height != h)) {
+ for (int i = 0;i < Fl::screen_count();i++) {
+ int sx, sy, sw, sh;
+
+ Fl::screen_xywh(sx, sy, sw, sh, i);
+
+ if ((sx == x) && (sy == y) && (sw == w) && (sh == h)) {
+ vlog.info("Adjusting window size to avoid accidental full screen request");
+ // Assume a panel of some form and adjust the height
+ y += 20;
+ h -= 40;
+ }
}
}
}