summaryrefslogtreecommitdiff
path: root/mozilla-1624745.patch
blob: 2a1dc0609f05c50bb6941c2300dfe85e0415deac (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
diff --git a/widget/gtk/mozcontainer.cpp b/widget/gtk/mozcontainer.cpp
--- a/widget/gtk/mozcontainer.cpp
+++ b/widget/gtk/mozcontainer.cpp
@@ -624,17 +624,25 @@
     GdkDisplay* display = gtk_widget_get_display(GTK_WIDGET(container));
     nsWaylandDisplay* waylandDisplay = WaylandDisplayGet(display);
 
+    wl_surface* parent_surface =
+        moz_gtk_widget_get_wl_surface(GTK_WIDGET(container));
+    if (!parent_surface) {
+      return nullptr;
+    }
+
     // Available as of GTK 3.8+
     struct wl_compositor* compositor = waylandDisplay->GetCompositor();
     container->surface = wl_compositor_create_surface(compositor);
-    wl_surface* parent_surface =
-        moz_gtk_widget_get_wl_surface(GTK_WIDGET(container));
-    if (!container->surface || !parent_surface) {
+    if (!container->surface) {
       return nullptr;
     }
 
     container->subsurface = wl_subcompositor_get_subsurface(
         waylandDisplay->GetSubcompositor(), container->surface, parent_surface);
+    if (!container->subsurface) {
+      g_clear_pointer(&container->surface, wl_surface_destroy);
+      return nullptr;
+    }
 
     GdkWindow* window = gtk_widget_get_window(GTK_WIDGET(container));
     gint x, y;

bgstack15