wpe: Reintroduce persistent WebContext

A WebContext leak was introduced in MR
https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/-/merge_requests/2252.
If we wanted one WebContext per WebView we should also unref the
WebKitWebContext when destroying the WebView.

This patch reintroduces the persistent WebContext, initially part of
https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/-/merge_requests/1484.

Fixes #1084

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/1982>
This commit is contained in:
Philippe Normand 2022-03-11 17:02:55 +00:00 committed by GStreamer Marge Bot
parent 618bbf80dc
commit a31307d37d

View file

@ -346,11 +346,13 @@ WPEView* WPEContextThread::createWPEView(GstWpeVideoSrc* src, GstGLContext* cont
WPEView* view = nullptr; WPEView* view = nullptr;
dispatch([&]() mutable { dispatch([&]() mutable {
auto* manager = webkit_website_data_manager_new_ephemeral(); if (!glib.web_context) {
auto web_context = webkit_web_context_new_with_website_data_manager(manager); auto *manager = webkit_website_data_manager_new_ephemeral();
g_object_unref(manager); glib.web_context =
webkit_web_context_new_with_website_data_manager(manager);
view = new WPEView(web_context, src, context, display, width, height); g_object_unref(manager);
}
view = new WPEView(glib.web_context, src, context, display, width, height);
}); });
if (view && view->hasUri()) { if (view && view->hasUri()) {