Compare commits
7 Commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
f0e2e238f3 | ||
![]() |
0c48a2633f | ||
![]() |
26a18e8312 | ||
![]() |
2ea121a186 | ||
![]() |
958cdd5117 | ||
![]() |
58d2bd0581 | ||
![]() |
e5067368f5 |
11
NEWS
11
NEWS
@@ -1,3 +1,14 @@
|
|||||||
|
3.18.3
|
||||||
|
======
|
||||||
|
* Fix initialization of bypass compositor hint [Rui; #758544]
|
||||||
|
* Fix crash when initial cursor position is not on a monitor [Marek; #756698]
|
||||||
|
* Fix crash when more CRTs are enabled than outputs connected [Rui; #751638]
|
||||||
|
* Fix crash during XWayland initialization [Marek; #751845]
|
||||||
|
* Ensure to send a ConfigureNotify to just mapped windows [Rui; #759492]
|
||||||
|
|
||||||
|
Contributors:
|
||||||
|
Marek Chalupa, Rui Matos, Jasper St. Pierre
|
||||||
|
|
||||||
3.18.2
|
3.18.2
|
||||||
======
|
======
|
||||||
* Misc. crash fixes [Jonas, Rui; #756675, #756660, #757148, #756796]
|
* Misc. crash fixes [Jonas, Rui; #756675, #756660, #757148, #756796]
|
||||||
|
@@ -2,7 +2,7 @@ AC_PREREQ(2.62)
|
|||||||
|
|
||||||
m4_define([mutter_major_version], [3])
|
m4_define([mutter_major_version], [3])
|
||||||
m4_define([mutter_minor_version], [18])
|
m4_define([mutter_minor_version], [18])
|
||||||
m4_define([mutter_micro_version], [2])
|
m4_define([mutter_micro_version], [3])
|
||||||
|
|
||||||
m4_define([mutter_version],
|
m4_define([mutter_version],
|
||||||
[mutter_major_version.mutter_minor_version.mutter_micro_version])
|
[mutter_major_version.mutter_minor_version.mutter_micro_version])
|
||||||
|
@@ -27,6 +27,8 @@
|
|||||||
#include "meta-cursor-renderer.h"
|
#include "meta-cursor-renderer.h"
|
||||||
|
|
||||||
#include <meta/meta-backend.h>
|
#include <meta/meta-backend.h>
|
||||||
|
#include <backends/meta-backend-private.h>
|
||||||
|
#include <backends/meta-monitor-manager-private.h>
|
||||||
#include <meta/util.h>
|
#include <meta/util.h>
|
||||||
|
|
||||||
#include <cogl/cogl.h>
|
#include <cogl/cogl.h>
|
||||||
@@ -116,6 +118,14 @@ meta_cursor_renderer_calculate_rect (MetaCursorRenderer *renderer,
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
is_cursor_in_monitors_area (int x, int y)
|
||||||
|
{
|
||||||
|
MetaMonitorManager *monitor_manager = meta_backend_get_monitor_manager (meta_get_backend ());
|
||||||
|
return meta_monitor_manager_get_monitor_at_point (monitor_manager,
|
||||||
|
(gfloat) x, (gfloat) y) >= 0;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
update_cursor (MetaCursorRenderer *renderer,
|
update_cursor (MetaCursorRenderer *renderer,
|
||||||
MetaCursorSprite *cursor_sprite)
|
MetaCursorSprite *cursor_sprite)
|
||||||
@@ -124,6 +134,11 @@ update_cursor (MetaCursorRenderer *renderer,
|
|||||||
gboolean handled_by_backend;
|
gboolean handled_by_backend;
|
||||||
gboolean should_redraw = FALSE;
|
gboolean should_redraw = FALSE;
|
||||||
|
|
||||||
|
/* do not render cursor if it is not on any monitor. Such situation
|
||||||
|
* can occur e. g. after monitor hot-plug */
|
||||||
|
if (!is_cursor_in_monitors_area (priv->current_x, priv->current_y))
|
||||||
|
return;
|
||||||
|
|
||||||
if (cursor_sprite)
|
if (cursor_sprite)
|
||||||
meta_cursor_sprite_prepare_at (cursor_sprite,
|
meta_cursor_sprite_prepare_at (cursor_sprite,
|
||||||
priv->current_x,
|
priv->current_x,
|
||||||
|
@@ -178,7 +178,7 @@ make_logical_config (MetaMonitorManager *manager)
|
|||||||
unsigned int i, j;
|
unsigned int i, j;
|
||||||
|
|
||||||
monitor_infos = g_array_sized_new (FALSE, TRUE, sizeof (MetaMonitorInfo),
|
monitor_infos = g_array_sized_new (FALSE, TRUE, sizeof (MetaMonitorInfo),
|
||||||
manager->n_outputs);
|
manager->n_crtcs);
|
||||||
|
|
||||||
/* Walk the list of MetaCRTCs, and build a MetaMonitorInfo
|
/* Walk the list of MetaCRTCs, and build a MetaMonitorInfo
|
||||||
for each of them, unless they reference a rectangle that
|
for each of them, unless they reference a rectangle that
|
||||||
|
@@ -337,13 +337,13 @@ meta_wayland_init (void)
|
|||||||
meta_wayland_pointer_gestures_init (compositor);
|
meta_wayland_pointer_gestures_init (compositor);
|
||||||
meta_wayland_seat_init (compositor);
|
meta_wayland_seat_init (compositor);
|
||||||
|
|
||||||
|
if (!meta_xwayland_start (&compositor->xwayland_manager, compositor->wayland_display))
|
||||||
|
g_error ("Failed to start X Wayland");
|
||||||
|
|
||||||
compositor->display_name = wl_display_add_socket_auto (compositor->wayland_display);
|
compositor->display_name = wl_display_add_socket_auto (compositor->wayland_display);
|
||||||
if (compositor->display_name == NULL)
|
if (compositor->display_name == NULL)
|
||||||
g_error ("Failed to create socket");
|
g_error ("Failed to create socket");
|
||||||
|
|
||||||
if (!meta_xwayland_start (&compositor->xwayland_manager, compositor->wayland_display))
|
|
||||||
g_error ("Failed to start X Wayland");
|
|
||||||
|
|
||||||
set_gnome_env ("DISPLAY", meta_wayland_get_xwayland_display_name (compositor));
|
set_gnome_env ("DISPLAY", meta_wayland_get_xwayland_display_name (compositor));
|
||||||
set_gnome_env ("WAYLAND_DISPLAY", meta_wayland_get_wayland_display_name (compositor));
|
set_gnome_env ("WAYLAND_DISPLAY", meta_wayland_get_wayland_display_name (compositor));
|
||||||
}
|
}
|
||||||
|
@@ -1843,7 +1843,7 @@ meta_display_init_window_prop_hooks (MetaDisplay *display)
|
|||||||
{ display->atom__NET_WM_WINDOW_TYPE, META_PROP_VALUE_ATOM_LIST, reload_net_wm_window_type, LOAD_INIT | INCLUDE_OR | FORCE_INIT },
|
{ display->atom__NET_WM_WINDOW_TYPE, META_PROP_VALUE_ATOM_LIST, reload_net_wm_window_type, LOAD_INIT | INCLUDE_OR | FORCE_INIT },
|
||||||
{ display->atom__NET_WM_STRUT, META_PROP_VALUE_INVALID, reload_struts, NONE },
|
{ display->atom__NET_WM_STRUT, META_PROP_VALUE_INVALID, reload_struts, NONE },
|
||||||
{ display->atom__NET_WM_STRUT_PARTIAL, META_PROP_VALUE_INVALID, reload_struts, NONE },
|
{ display->atom__NET_WM_STRUT_PARTIAL, META_PROP_VALUE_INVALID, reload_struts, NONE },
|
||||||
{ display->atom__NET_WM_BYPASS_COMPOSITOR, META_PROP_VALUE_CARDINAL, reload_bypass_compositor, NONE },
|
{ display->atom__NET_WM_BYPASS_COMPOSITOR, META_PROP_VALUE_CARDINAL, reload_bypass_compositor, LOAD_INIT | INCLUDE_OR },
|
||||||
{ display->atom__NET_WM_WINDOW_OPACITY, META_PROP_VALUE_CARDINAL, reload_window_opacity, LOAD_INIT | INCLUDE_OR },
|
{ display->atom__NET_WM_WINDOW_OPACITY, META_PROP_VALUE_CARDINAL, reload_window_opacity, LOAD_INIT | INCLUDE_OR },
|
||||||
{ 0 },
|
{ 0 },
|
||||||
};
|
};
|
||||||
|
@@ -542,13 +542,10 @@ meta_window_x11_manage (MetaWindow *window)
|
|||||||
* For normal windows, do a full ConfigureRequest based on the
|
* For normal windows, do a full ConfigureRequest based on the
|
||||||
* window hints, as that's what the ICCCM says to do.
|
* window hints, as that's what the ICCCM says to do.
|
||||||
*/
|
*/
|
||||||
|
priv->client_rect = window->rect;
|
||||||
|
window->buffer_rect = window->rect;
|
||||||
|
|
||||||
if (window->override_redirect)
|
if (!window->override_redirect)
|
||||||
{
|
|
||||||
priv->client_rect = window->rect;
|
|
||||||
window->buffer_rect = window->rect;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
MetaRectangle rect;
|
MetaRectangle rect;
|
||||||
MetaMoveResizeFlags flags;
|
MetaMoveResizeFlags flags;
|
||||||
@@ -1735,9 +1732,9 @@ meta_window_x11_update_input_region (MetaWindow *window)
|
|||||||
region = cairo_region_create ();
|
region = cairo_region_create ();
|
||||||
}
|
}
|
||||||
else if (n_rects == 1 &&
|
else if (n_rects == 1 &&
|
||||||
(rects[0].x == 0 ||
|
(rects[0].x == 0 &&
|
||||||
rects[0].y == 0 ||
|
rects[0].y == 0 &&
|
||||||
rects[0].width == priv->client_rect.width ||
|
rects[0].width == priv->client_rect.width &&
|
||||||
rects[0].height == priv->client_rect.height))
|
rects[0].height == priv->client_rect.height))
|
||||||
{
|
{
|
||||||
/* This is the bounding region case. Keep the
|
/* This is the bounding region case. Keep the
|
||||||
|
Reference in New Issue
Block a user