[Xfce4-commits] <midori:master> Abstract availability of Netscape plugin support

Christian Dywan noreply at xfce.org
Sat Feb 25 02:08:01 CET 2012


Updating branch refs/heads/master
         to 18b6b48ef5feea17e51e4a64149013b6fcac34e0 (commit)
       from 9275a6cd24fa7480e4f1bd0abbe5217e2b9538a2 (commit)

commit 18b6b48ef5feea17e51e4a64149013b6fcac34e0
Author: Christian Dywan <christian at twotoasts.de>
Date:   Sat Feb 25 02:06:46 2012 +0100

    Abstract availability of Netscape plugin support
    
    Disable if MOZ_PLUGIN_PATH is / or MIDORI_UNARMED.

 INSTALL                         |    2 ++
 extensions/statusbar-features.c |    7 +++++--
 midori/main.c                   |    3 +++
 midori/midori-view.c            |   10 ++++++++--
 midori/midori-websettings.c     |   29 ++++++++++++++++++++++-------
 midori/midori-websettings.h     |    3 +++
 6 files changed, 43 insertions(+), 11 deletions(-)

diff --git a/INSTALL b/INSTALL
index aed4768..50ae600 100644
--- a/INSTALL
+++ b/INSTALL
@@ -67,6 +67,8 @@ If you want to "dry run" without WebKitGTK+ rendering, try this:
 
 'MIDORI_UNARMED=1 _build_/default/midori/midori'
 
+To disable Netscape plugins, use MOZ_PLUGIN_PATH=/.
+
 To debug extensions you can specify the path:
 
 'export MIDORI_EXTENSION_PATH=_build_/default/extensions'
diff --git a/extensions/statusbar-features.c b/extensions/statusbar-features.c
index 9480fec..24e55f2 100644
--- a/extensions/statusbar-features.c
+++ b/extensions/statusbar-features.c
@@ -142,8 +142,11 @@ statusbar_features_app_add_browser_cb (MidoriApp*       app,
     g_signal_connect (toolbar, "notify::toolbar-style",
         G_CALLBACK (statusbar_features_toolbar_notify_toolbar_style_cb), button);
     gtk_box_pack_start (GTK_BOX (bbox), button, FALSE, FALSE, 2);
-    button = katze_property_proxy (settings, "enable-plugins", "toggle");
-    g_object_set_data (G_OBJECT (button), "feature-label", _("Netscape plugins"));
+    if (midori_web_settings_has_plugin_support ())
+    {
+        button = katze_property_proxy (settings, "enable-plugins", "toggle");
+        g_object_set_data (G_OBJECT (button), "feature-label", _("Netscape plugins"));
+    }
     image = gtk_image_new_from_stock (STOCK_PLUGINS, GTK_ICON_SIZE_MENU);
     gtk_button_set_image (GTK_BUTTON (button), image);
     gtk_widget_set_tooltip_text (button, _("Enable Netscape plugins"));
diff --git a/midori/main.c b/midori/main.c
index 08b163a..f0efec4 100644
--- a/midori/main.c
+++ b/midori/main.c
@@ -1743,6 +1743,8 @@ midori_clear_web_cookies_cb (void)
     }
 
     /* Local shared objects/ Flash cookies */
+    if (midori_web_settings_has_plugin_support ())
+    {
     #ifdef GDK_WINDOWING_X11
     cache = g_build_filename (g_get_home_dir (), ".macromedia", "Flash_Player", NULL);
     sokoke_remove_path (cache, TRUE);
@@ -1757,6 +1759,7 @@ midori_clear_web_cookies_cb (void)
     sokoke_remove_path (cache, TRUE);
     g_free (cache);
     #endif
+    }
 
     /* HTML5 databases */
     webkit_remove_all_web_databases ();
diff --git a/midori/midori-view.c b/midori/midori-view.c
index 77b3273..a94881f 100644
--- a/midori/midori-view.c
+++ b/midori/midori-view.c
@@ -3660,6 +3660,8 @@ midori_view_construct_web_view (MidoriView* view)
 
 static gchar* list_netscape_plugins ()
 {
+    if (midori_web_settings_has_plugin_support ())
+    {
     GtkWidget* web_view = webkit_web_view_new ();
     WebKitWebFrame* web_frame = webkit_web_view_get_main_frame (WEBKIT_WEB_VIEW (web_view));
     JSContextRef js_context = webkit_web_frame_get_global_context (web_frame);
@@ -3671,7 +3673,7 @@ static gchar* list_netscape_plugins ()
         "plugins (navigator.plugins)", NULL);
     gchar** items = g_strsplit (value, ",", 0);
     guint i = 0;
-    GString* ns_plugins = g_string_new (NULL);
+    GString* ns_plugins = g_string_new ("<h2>Netscape Plugins:</h2><table>");
     if (items != NULL)
         while (items[i] != NULL)
         {
@@ -3689,10 +3691,14 @@ static gchar* list_netscape_plugins ()
         }
         if (g_str_has_prefix (value, "undefined"))
             g_string_append (ns_plugins, "<tr><td>No plugins found</td></tr>");
+        g_string_append (ns_plugins, "</table>");
         g_strfreev (items);
         g_free (value);
     gtk_widget_destroy (web_view);
     return g_string_free (ns_plugins, FALSE);
+    }
+    else
+        return g_strdup ("");
 }
 
 static gchar*
@@ -4022,7 +4028,7 @@ midori_view_set_uri (MidoriView*  view,
                     "<tr><td>Identification</td><td>%s</td></tr>"
                     "<tr><td>Video Formats</td><td>%s</td></tr>"
                     "</table>"
-                    "<h2>Netscape Plugins:</h2><table>%s</table>"
+                    "%s"
                     "</body></html>",
                     _("Version numbers in brackets show the version used at runtime."),
                     command_line,
diff --git a/midori/midori-websettings.c b/midori/midori-websettings.c
index 121d314..d586261 100644
--- a/midori/midori-websettings.c
+++ b/midori/midori-websettings.c
@@ -728,13 +728,8 @@ midori_web_settings_class_init (MidoriWebSettingsClass* class)
                                      "enable-plugins",
                                      _("Enable Netscape plugins"),
                                      _("Enable embedded Netscape plugin objects"),
-    #ifdef G_OS_WIN32
-                                     FALSE,
-                                     G_PARAM_READABLE));
-    #else
-                                     TRUE,
-                                     flags));
-    #endif
+                                     midori_web_settings_has_plugin_support (),
+        midori_web_settings_has_plugin_support () ? flags : G_PARAM_READABLE));
     /* Override properties to override defaults */
     g_object_class_install_property (gobject_class,
                                      PROP_ENABLE_DEVELOPER_EXTRAS,
@@ -1191,6 +1186,26 @@ midori_web_settings_finalize (GObject* object)
     G_OBJECT_CLASS (midori_web_settings_parent_class)->finalize (object);
 }
 
+/**
+ * midori_web_settings_has_plugin_support:
+ *
+ * Determines if Netscape plugins are supported.
+ *
+ * Returns: %TRUE if Netscape plugins can be used
+ *
+ * Since: 0.4.4
+ **/
+gboolean
+midori_web_settings_has_plugin_support (void)
+{
+    #ifdef G_OS_WIN32
+    return FALSE;
+    #else
+    return g_getenv ("MIDORI_UNARMED") == NULL
+        && g_strcmp0 (g_getenv ("MOZ_PLUGIN_PATH"), "/");
+    #endif
+}
+
 #if (!HAVE_OSX && defined (G_OS_UNIX)) || defined (G_OS_WIN32)
 static gchar*
 get_sys_name (gchar** architecture)
diff --git a/midori/midori-websettings.h b/midori/midori-websettings.h
index e11ffef..3b96fc7 100644
--- a/midori/midori-websettings.h
+++ b/midori/midori-websettings.h
@@ -173,6 +173,9 @@ const gchar*
 midori_web_settings_get_system_name        (gchar**            architecture,
                                             gchar**            platform);
 
+gboolean
+midori_web_settings_has_plugin_support     (void);
+
 G_END_DECLS
 
 #endif /* __MIDORI_WEB_SETTINGS_H__ */


More information about the Xfce4-commits mailing list