|
@@ -1190,9 +1190,12 @@ void OS_X11::set_window_position(const Point2 &p_position) {
|
|
|
unsigned long remaining;
|
|
|
unsigned char *data = NULL;
|
|
|
if (XGetWindowProperty(x11_display, x11_window, prop, 0, 4, False, AnyPropertyType, &type, &format, &len, &remaining, &data) == Success) {
|
|
|
- long *extents = (long *)data;
|
|
|
- x = extents[0];
|
|
|
- y = extents[2];
|
|
|
+ if (format == 32 && len == 4) {
|
|
|
+ long *extents = (long *)data;
|
|
|
+ x = extents[0];
|
|
|
+ y = extents[2];
|
|
|
+ }
|
|
|
+ XFree(data);
|
|
|
}
|
|
|
}
|
|
|
XMoveWindow(x11_display, x11_window, p_position.x - x, p_position.y - y);
|
|
@@ -1218,9 +1221,12 @@ Size2 OS_X11::get_real_window_size() const {
|
|
|
unsigned long remaining;
|
|
|
unsigned char *data = NULL;
|
|
|
if (XGetWindowProperty(x11_display, x11_window, prop, 0, 4, False, AnyPropertyType, &type, &format, &len, &remaining, &data) == Success) {
|
|
|
- long *extents = (long *)data;
|
|
|
- w += extents[0] + extents[1]; // left, right
|
|
|
- h += extents[2] + extents[3]; // top, bottom
|
|
|
+ if (format == 32 && len == 4) {
|
|
|
+ long *extents = (long *)data;
|
|
|
+ w += extents[0] + extents[1]; // left, right
|
|
|
+ h += extents[2] + extents[3]; // top, bottom
|
|
|
+ }
|
|
|
+ XFree(data);
|
|
|
}
|
|
|
return Size2(w, h);
|
|
|
}
|