diff options
| author | rcaridade145 <[email protected]> | 2020-02-29 13:01:36 +0000 | 
|---|---|---|
| committer | Victor Kareh <[email protected]> | 2020-05-27 11:25:49 -0400 | 
| commit | c0549f97732dd57080c15bdd2b64c4162b1a856a (patch) | |
| tree | f7a0b6f8d20166093e607efddc38748f54ca1d96 /src/compositor/compositor-xrender.c | |
| parent | 7e767379251734c6efeef9cc22b326c950470c30 (diff) | |
| download | marco-c0549f97732dd57080c15bdd2b64c4162b1a856a.tar.bz2 marco-c0549f97732dd57080c15bdd2b64c4162b1a856a.tar.xz | |
compositor: fix possible crash closing/destroying window . Fixes to previous commit.
Partially restore call to destroy_win in compositor when calling
meta_window_free. This is needed to ensure that we never call
meta_window_get_frame_bounds while windows is destroying.
https://bugzilla.gnome.org/show_bug.cgi?id=751833
Based on commit https://gitlab.gnome.org/GNOME/metacity/-/commit/a9f28dbc26f5211ef08889109db3dc8c7ba76aca
Diffstat (limited to 'src/compositor/compositor-xrender.c')
| -rw-r--r-- | src/compositor/compositor-xrender.c | 36 | 
1 files changed, 27 insertions, 9 deletions
| diff --git a/src/compositor/compositor-xrender.c b/src/compositor/compositor-xrender.c index 59fbd93f..5b40b82e 100644 --- a/src/compositor/compositor-xrender.c +++ b/src/compositor/compositor-xrender.c @@ -3041,22 +3041,39 @@ xrender_end_move (MetaCompositor *compositor,  #endif  } +#endif /* 0 */ +  static void  xrender_free_window (MetaCompositor *compositor,                       MetaWindow     *window)  {  #ifdef HAVE_COMPOSITE_EXTENSIONS -  /* FIXME: When an undecorated window is hidden this is called, -     but the window does not get readded if it is subsequentally shown again -     See http://bugzilla.gnome.org/show_bug.cgi?id=504876 - -     I don't *think* theres any need for this call anyway, leaving it out -     does not seem to cause any side effects so far, but I should check with -     someone who understands more. */ -  /* destroy_win (compositor->display, window->xwindow, FALSE); */ +  MetaCompositorXRender *xrc; +  MetaFrame *frame; +  Window xwindow; + +  xrc = (MetaCompositorXRender *) compositor; +  frame = meta_window_get_frame (window); +  xwindow = None; + +  if (frame) +    { +      xwindow = meta_frame_get_xwindow (frame); +    } +  else +    { +      /* FIXME: When an undecorated window is hidden this is called, but the +       * window does not get readded if it is subsequentally shown again. See: +       * http://bugzilla.gnome.org/show_bug.cgi?id=504876 +       */ +      /* xwindow = meta_window_get_xwindow (window); */ +    } + +  if (xwindow != None) +    destroy_win (xrc->display, xwindow, FALSE);  #endif  } -#endif /* 0 */ +  static void  xrender_process_event (MetaCompositor *compositor, @@ -3360,6 +3377,7 @@ static MetaCompositor comp_info = {    xrender_process_event,    xrender_get_window_surface,    xrender_set_active_window, +  xrender_free_window,    xrender_maximize_window,    xrender_unmaximize_window,  }; | 
