Blame SOURCES/evince-3.21.4-NPNVToolKit.patch

eb855a
--- evince-3.21.92/browser-plugin/EvBrowserPluginMain.cpp
eb855a
+++ evince-3.21.92/browser-plugin/EvBrowserPluginMain.cpp
eb855a
@@ -38,11 +38,40 @@ static EvBrowserPlugin *pluginForInstanc
eb855a
         return static_cast<EvBrowserPlugin *>(instance->pdata);
eb855a
 }
eb855a
 
eb855a
+static gboolean gtkToolkitIsCompatible(NPP instance)
eb855a
+{
eb855a
+        NPNToolkitType toolkit_type = NPNVGtk12;
eb855a
+        NPError error;
eb855a
+
eb855a
+        error = browser->getvalue(instance, NPNVToolkit, &toolkit_type);
eb855a
+
eb855a
+        if (error == NPERR_NO_ERROR &&
eb855a
+            (toolkit_type == NPNVGtk12 ||
eb855a
+             toolkit_type == NPNVGtk2))
eb855a
+                return FALSE;
eb855a
+        else
eb855a
+                return TRUE;
eb855a
+}
eb855a
+
eb855a
 NPError NPP_New(NPMIMEType pluginType, NPP instance, uint16_t mode, int16_t argc, char *argn[], char *argv[], NPSavedData *savedData)
eb855a
 {
eb855a
         if (!instance)
eb855a
                 return NPERR_INVALID_INSTANCE_ERROR;
eb855a
 
eb855a
+        if (!gtkToolkitIsCompatible(instance))
eb855a
+                return NPERR_GENERIC_ERROR;
eb855a
+
eb855a
+        GBytes *resourceData = g_resources_lookup_data("/org/gnome/evince/browser/ui/evince-browser.css", G_RESOURCE_LOOKUP_FLAGS_NONE, nullptr);
eb855a
+        if (resourceData) {
eb855a
+            GtkCssProvider *cssProvider = gtk_css_provider_new();
eb855a
+
eb855a
+            gtk_css_provider_load_from_data(cssProvider, static_cast<const gchar *>(g_bytes_get_data(resourceData, nullptr)), g_bytes_get_size(resourceData), nullptr);
eb855a
+            g_bytes_unref(resourceData);
eb855a
+
eb855a
+            gtk_style_context_add_provider_for_screen(gdk_screen_get_default(), GTK_STYLE_PROVIDER(cssProvider), GTK_STYLE_PROVIDER_PRIORITY_APPLICATION);
eb855a
+            g_object_unref(cssProvider);
eb855a
+        }
eb855a
+
eb855a
         return EvBrowserPlugin::create(instance)->initialize(pluginType, mode, argc, argn, argv, savedData);
eb855a
 }
eb855a
 
eb855a
@@ -197,6 +226,11 @@ NPError NP_Initialize(NPNetscapeFuncs *b
eb855a
         if ((browserFuncs->version >> 8) > NP_VERSION_MAJOR)
eb855a
                 return NPERR_INCOMPATIBLE_VERSION_ERROR;
eb855a
 
eb855a
+        browser = browserFuncs;
eb855a
+
eb855a
+        if (!gtkToolkitIsCompatible(NULL))
eb855a
+                return NPERR_GENERIC_ERROR;
eb855a
+
eb855a
         if (!ev_init())
eb855a
                 return NPERR_GENERIC_ERROR;
eb855a
 
eb855a
@@ -207,20 +241,8 @@ NPError NP_Initialize(NPNetscapeFuncs *b
eb855a
                 return NPERR_GENERIC_ERROR;
eb855a
 #endif
eb855a
 
eb855a
-        browser = browserFuncs;
eb855a
         initializePluginFuncs(pluginFuncs);
eb855a
 
eb855a
-        GBytes *resourceData = g_resources_lookup_data("/org/gnome/evince/browser/ui/evince-browser.css", G_RESOURCE_LOOKUP_FLAGS_NONE, nullptr);
eb855a
-        if (resourceData) {
eb855a
-            GtkCssProvider *cssProvider = gtk_css_provider_new();
eb855a
-
eb855a
-            gtk_css_provider_load_from_data(cssProvider, static_cast<const gchar *>(g_bytes_get_data(resourceData, nullptr)), g_bytes_get_size(resourceData), nullptr);
eb855a
-            g_bytes_unref(resourceData);
eb855a
-
eb855a
-            gtk_style_context_add_provider_for_screen(gdk_screen_get_default(), GTK_STYLE_PROVIDER(cssProvider), GTK_STYLE_PROVIDER_PRIORITY_APPLICATION);
eb855a
-            g_object_unref(cssProvider);
eb855a
-        }
eb855a
-
eb855a
         return NPERR_NO_ERROR;
eb855a
 }
eb855a