Cleanup MidoriAddons a bit and remove Extensions from it
This commit is contained in:
parent
d2cdb95928
commit
e1c5e81cc9
3 changed files with 46 additions and 134 deletions
|
@ -1009,10 +1009,12 @@ midori_app_add_browser_cb (MidoriApp* app,
|
||||||
panel = katze_object_get_object (browser, "panel");
|
panel = katze_object_get_object (browser, "panel");
|
||||||
|
|
||||||
/* Transfers */
|
/* Transfers */
|
||||||
/* addon = midori_view_new (net);
|
#if 0
|
||||||
|
addon = midori_view_new (net);
|
||||||
gtk_widget_show (addon);
|
gtk_widget_show (addon);
|
||||||
midori_panel_append_page (MIDORI_PANEL (panel), addon, NULL,
|
midori_panel_append_page (MIDORI_PANEL (panel), addon, NULL,
|
||||||
STOCK_TRANSFERS, _("Transfers")); */
|
STOCK_TRANSFERS, _("Transfers"));
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Console */
|
/* Console */
|
||||||
addon = midori_console_new ();
|
addon = midori_console_new ();
|
||||||
|
@ -1025,14 +1027,14 @@ midori_app_add_browser_cb (MidoriApp* app,
|
||||||
G_CALLBACK (midori_browser_add_tab_cb), addon);
|
G_CALLBACK (midori_browser_add_tab_cb), addon);
|
||||||
|
|
||||||
/* Userscripts */
|
/* Userscripts */
|
||||||
addon = midori_addons_new (GTK_WIDGET (browser), MIDORI_ADDON_USER_SCRIPTS);
|
addon = midori_addons_new (MIDORI_ADDON_USER_SCRIPTS, GTK_WIDGET (browser));
|
||||||
gtk_widget_show (addon);
|
gtk_widget_show (addon);
|
||||||
toolbar = midori_addons_get_toolbar (MIDORI_ADDONS (addon));
|
toolbar = midori_addons_get_toolbar (MIDORI_ADDONS (addon));
|
||||||
gtk_widget_show (toolbar);
|
gtk_widget_show (toolbar);
|
||||||
midori_panel_append_page (MIDORI_PANEL (panel), addon, toolbar,
|
midori_panel_append_page (MIDORI_PANEL (panel), addon, toolbar,
|
||||||
STOCK_SCRIPTS, _("Userscripts"));
|
STOCK_SCRIPTS, _("Userscripts"));
|
||||||
/* Userstyles */
|
/* Userstyles */
|
||||||
addon = midori_addons_new (GTK_WIDGET (browser), MIDORI_ADDON_USER_STYLES);
|
addon = midori_addons_new (MIDORI_ADDON_USER_STYLES, GTK_WIDGET (browser));
|
||||||
gtk_widget_show (addon);
|
gtk_widget_show (addon);
|
||||||
toolbar = midori_addons_get_toolbar (MIDORI_ADDONS (addon));
|
toolbar = midori_addons_get_toolbar (MIDORI_ADDONS (addon));
|
||||||
gtk_widget_show (toolbar);
|
gtk_widget_show (toolbar);
|
||||||
|
@ -1040,12 +1042,15 @@ midori_app_add_browser_cb (MidoriApp* app,
|
||||||
STOCK_STYLES, _("Userstyles"));
|
STOCK_STYLES, _("Userstyles"));
|
||||||
|
|
||||||
/* Extensions */
|
/* Extensions */
|
||||||
addon = midori_addons_new (GTK_WIDGET (browser), MIDORI_ADDON_EXTENSIONS);
|
#if 0
|
||||||
|
addon = midori_addons_new (MIDORI_ADDON_EXTENSIONS,
|
||||||
|
katze_object_get_object (app, "extensions"), NULL);
|
||||||
gtk_widget_show (addon);
|
gtk_widget_show (addon);
|
||||||
toolbar = midori_addons_get_toolbar (MIDORI_ADDONS (addon));
|
toolbar = midori_addons_get_toolbar (MIDORI_ADDONS (addon));
|
||||||
gtk_widget_show (toolbar);
|
gtk_widget_show (toolbar);
|
||||||
midori_panel_append_page (MIDORI_PANEL (panel), addon, toolbar,
|
midori_panel_append_page (MIDORI_PANEL (panel), addon, toolbar,
|
||||||
STOCK_EXTENSIONS, _("Extensions"));
|
STOCK_EXTENSIONS, _("Extensions"));
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
|
@ -32,8 +32,8 @@ struct _MidoriAddons
|
||||||
{
|
{
|
||||||
GtkVBox parent_instance;
|
GtkVBox parent_instance;
|
||||||
|
|
||||||
GtkWidget* web_widget;
|
|
||||||
MidoriAddonKind kind;
|
MidoriAddonKind kind;
|
||||||
|
GtkWidget* web_widget;
|
||||||
GtkWidget* toolbar;
|
GtkWidget* toolbar;
|
||||||
GtkWidget* treeview;
|
GtkWidget* treeview;
|
||||||
|
|
||||||
|
@ -58,8 +58,8 @@ enum
|
||||||
{
|
{
|
||||||
PROP_0,
|
PROP_0,
|
||||||
|
|
||||||
PROP_WEB_WIDGET,
|
PROP_KIND,
|
||||||
PROP_KIND
|
PROP_WEB_WIDGET
|
||||||
};
|
};
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -85,7 +85,6 @@ midori_addon_kind_get_type (void)
|
||||||
{
|
{
|
||||||
static const GEnumValue values[] = {
|
static const GEnumValue values[] = {
|
||||||
{ MIDORI_ADDON_NONE, "MIDORI_ADDON_NONE", N_("None") },
|
{ MIDORI_ADDON_NONE, "MIDORI_ADDON_NONE", N_("None") },
|
||||||
{ MIDORI_ADDON_EXTENSIONS, "MIDORI_ADDON_EXTENSIONS", N_("Extensions") },
|
|
||||||
{ MIDORI_ADDON_USER_SCRIPTS, "MIDORI_USER_SCRIPTS", N_("Userscripts") },
|
{ MIDORI_ADDON_USER_SCRIPTS, "MIDORI_USER_SCRIPTS", N_("Userscripts") },
|
||||||
{ MIDORI_ADDON_USER_STYLES, "MIDORI_USER_STYLES", N_("Userstyles") },
|
{ MIDORI_ADDON_USER_STYLES, "MIDORI_USER_STYLES", N_("Userstyles") },
|
||||||
{ 0, NULL, NULL }
|
{ 0, NULL, NULL }
|
||||||
|
@ -108,15 +107,6 @@ midori_addons_class_init (MidoriAddonsClass* class)
|
||||||
|
|
||||||
flags = G_PARAM_READWRITE | G_PARAM_CONSTRUCT;
|
flags = G_PARAM_READWRITE | G_PARAM_CONSTRUCT;
|
||||||
|
|
||||||
g_object_class_install_property (gobject_class,
|
|
||||||
PROP_WEB_WIDGET,
|
|
||||||
g_param_spec_object (
|
|
||||||
"web-widget",
|
|
||||||
"Web Widget",
|
|
||||||
"The assigned web widget",
|
|
||||||
GTK_TYPE_WIDGET,
|
|
||||||
G_PARAM_READWRITE));
|
|
||||||
|
|
||||||
g_object_class_install_property (gobject_class,
|
g_object_class_install_property (gobject_class,
|
||||||
PROP_KIND,
|
PROP_KIND,
|
||||||
g_param_spec_enum (
|
g_param_spec_enum (
|
||||||
|
@ -126,6 +116,15 @@ midori_addons_class_init (MidoriAddonsClass* class)
|
||||||
MIDORI_TYPE_ADDON_KIND,
|
MIDORI_TYPE_ADDON_KIND,
|
||||||
MIDORI_ADDON_NONE,
|
MIDORI_ADDON_NONE,
|
||||||
flags));
|
flags));
|
||||||
|
|
||||||
|
g_object_class_install_property (gobject_class,
|
||||||
|
PROP_WEB_WIDGET,
|
||||||
|
g_param_spec_object (
|
||||||
|
"web-widget",
|
||||||
|
"Web Widget",
|
||||||
|
"The assigned web widget",
|
||||||
|
GTK_TYPE_WIDGET,
|
||||||
|
G_PARAM_READWRITE));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -138,11 +137,11 @@ midori_addons_set_property (GObject* object,
|
||||||
|
|
||||||
switch (prop_id)
|
switch (prop_id)
|
||||||
{
|
{
|
||||||
case PROP_WEB_WIDGET:
|
|
||||||
midori_addons_set_web_widget (addons, g_value_get_object (value));
|
|
||||||
break;
|
|
||||||
case PROP_KIND:
|
case PROP_KIND:
|
||||||
midori_addons_set_kind (addons, g_value_get_enum (value));
|
addons->kind = g_value_get_enum (value);
|
||||||
|
break;
|
||||||
|
case PROP_WEB_WIDGET:
|
||||||
|
katze_object_assign (addons->web_widget, g_value_dup_object (value));
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
|
@ -160,11 +159,11 @@ midori_addons_get_property (GObject* object,
|
||||||
|
|
||||||
switch (prop_id)
|
switch (prop_id)
|
||||||
{
|
{
|
||||||
case PROP_WEB_WIDGET:
|
|
||||||
g_value_set_object (value, midori_addons_get_web_widget (addons));
|
|
||||||
break;
|
|
||||||
case PROP_KIND:
|
case PROP_KIND:
|
||||||
g_value_set_enum (value, midori_addons_get_kind (addons));
|
g_value_set_enum (value, addons->kind);
|
||||||
|
break;
|
||||||
|
case PROP_WEB_WIDGET:
|
||||||
|
g_value_set_object (value, addons->web_widget);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
|
@ -177,8 +176,6 @@ _addons_get_folder (MidoriAddons* addons)
|
||||||
{
|
{
|
||||||
switch (addons->kind)
|
switch (addons->kind)
|
||||||
{
|
{
|
||||||
case MIDORI_ADDON_EXTENSIONS:
|
|
||||||
return "extensions";
|
|
||||||
case MIDORI_ADDON_USER_SCRIPTS:
|
case MIDORI_ADDON_USER_SCRIPTS:
|
||||||
return "scripts";
|
return "scripts";
|
||||||
case MIDORI_ADDON_USER_STYLES:
|
case MIDORI_ADDON_USER_STYLES:
|
||||||
|
@ -193,8 +190,6 @@ _addons_get_extension (MidoriAddons* addons)
|
||||||
{
|
{
|
||||||
switch (addons->kind)
|
switch (addons->kind)
|
||||||
{
|
{
|
||||||
case MIDORI_ADDON_EXTENSIONS:
|
|
||||||
return ".midori.js";
|
|
||||||
case MIDORI_ADDON_USER_SCRIPTS:
|
case MIDORI_ADDON_USER_SCRIPTS:
|
||||||
return ".user.js";
|
return ".user.js";
|
||||||
case MIDORI_ADDON_USER_STYLES:
|
case MIDORI_ADDON_USER_STYLES:
|
||||||
|
@ -491,6 +486,9 @@ static void
|
||||||
midori_addons_finalize (GObject* object)
|
midori_addons_finalize (GObject* object)
|
||||||
{
|
{
|
||||||
MidoriAddons* addons = MIDORI_ADDONS (object);
|
MidoriAddons* addons = MIDORI_ADDONS (object);
|
||||||
|
|
||||||
|
katze_object_assign (addons->web_widget, NULL);
|
||||||
|
|
||||||
g_slist_free (addons->elements);
|
g_slist_free (addons->elements);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -875,8 +873,8 @@ midori_web_widget_window_object_cleared_cb (GtkWidget* web_widget,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* midori_addons_new:
|
* midori_addons_new:
|
||||||
* @web_widget: a web widget
|
|
||||||
* @kind: the kind of addon
|
* @kind: the kind of addon
|
||||||
|
* @web_widget: a web widget
|
||||||
*
|
*
|
||||||
* Creates a new addons widget.
|
* Creates a new addons widget.
|
||||||
*
|
*
|
||||||
|
@ -886,8 +884,8 @@ midori_web_widget_window_object_cleared_cb (GtkWidget* web_widget,
|
||||||
* Return value: a new #MidoriAddons
|
* Return value: a new #MidoriAddons
|
||||||
**/
|
**/
|
||||||
GtkWidget*
|
GtkWidget*
|
||||||
midori_addons_new (GtkWidget* web_widget,
|
midori_addons_new (MidoriAddonKind kind,
|
||||||
MidoriAddonKind kind)
|
GtkWidget* web_widget)
|
||||||
{
|
{
|
||||||
MidoriAddons* addons;
|
MidoriAddons* addons;
|
||||||
#if GLIB_CHECK_VERSION (2, 16, 0)
|
#if GLIB_CHECK_VERSION (2, 16, 0)
|
||||||
|
@ -901,10 +899,14 @@ midori_addons_new (GtkWidget* web_widget,
|
||||||
g_return_val_if_fail (GTK_IS_WIDGET (web_widget), NULL);
|
g_return_val_if_fail (GTK_IS_WIDGET (web_widget), NULL);
|
||||||
|
|
||||||
addons = g_object_new (MIDORI_TYPE_ADDONS,
|
addons = g_object_new (MIDORI_TYPE_ADDONS,
|
||||||
/* "web-widget", web_widget,
|
"kind", kind,
|
||||||
"kind", kind, */ NULL);
|
"web-widget", web_widget,
|
||||||
addons->web_widget = web_widget;
|
NULL);
|
||||||
midori_addons_set_kind (addons, kind);
|
|
||||||
|
if (kind == MIDORI_ADDON_USER_SCRIPTS || kind == MIDORI_ADDON_USER_STYLES)
|
||||||
|
g_signal_connect (addons->web_widget, "window-object-cleared",
|
||||||
|
G_CALLBACK (midori_web_widget_window_object_cleared_cb), addons);
|
||||||
|
|
||||||
midori_addons_update_elements (addons);
|
midori_addons_update_elements (addons);
|
||||||
|
|
||||||
#if GLIB_CHECK_VERSION (2, 16, 0)
|
#if GLIB_CHECK_VERSION (2, 16, 0)
|
||||||
|
@ -933,87 +935,6 @@ midori_addons_new (GtkWidget* web_widget,
|
||||||
return GTK_WIDGET (addons);
|
return GTK_WIDGET (addons);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* midori_addons_set_web_widget:
|
|
||||||
* @addons: a #MidoriAddons
|
|
||||||
* @web_widget: a web widget
|
|
||||||
*
|
|
||||||
* Sets the assigned web widget. Basically any widget
|
|
||||||
* with a window-object-cleared qualifies as such.
|
|
||||||
*
|
|
||||||
* Note: This may only be set once.
|
|
||||||
**/
|
|
||||||
void
|
|
||||||
midori_addons_set_web_widget (MidoriAddons* addons,
|
|
||||||
GtkWidget* web_widget)
|
|
||||||
{
|
|
||||||
g_return_if_fail (MIDORI_IS_ADDONS (addons));
|
|
||||||
g_return_if_fail (GTK_IS_WIDGET (addons));
|
|
||||||
g_return_if_fail (g_signal_lookup ("window-object-cleared", G_TYPE_FROM_INSTANCE (web_widget)));
|
|
||||||
|
|
||||||
/* FIXME: Implement this */
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* midori_addons_get_web_widget:
|
|
||||||
* @addons: a #MidoriAddons
|
|
||||||
*
|
|
||||||
* Determines the assigned web widget.
|
|
||||||
*
|
|
||||||
* Return value: a web widget
|
|
||||||
**/
|
|
||||||
GtkWidget*
|
|
||||||
midori_addons_get_web_widget (MidoriAddons* addons)
|
|
||||||
{
|
|
||||||
g_return_val_if_fail (MIDORI_IS_ADDONS (addons), NULL);
|
|
||||||
|
|
||||||
return addons->web_widget;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* midori_addons_set_kind:
|
|
||||||
* @addons: a #MidoriAddons
|
|
||||||
* @kind: a #MidoriAddonKind
|
|
||||||
*
|
|
||||||
* Sets the kind of addons.
|
|
||||||
*
|
|
||||||
* Note: This may only be set once.
|
|
||||||
**/
|
|
||||||
void
|
|
||||||
midori_addons_set_kind (MidoriAddons* addons,
|
|
||||||
MidoriAddonKind kind)
|
|
||||||
{
|
|
||||||
g_return_if_fail (MIDORI_IS_ADDONS (addons));
|
|
||||||
g_return_if_fail (addons->kind == MIDORI_ADDON_NONE);
|
|
||||||
|
|
||||||
if (kind == MIDORI_ADDON_NONE)
|
|
||||||
return;
|
|
||||||
|
|
||||||
g_return_if_fail (addons->web_widget);
|
|
||||||
|
|
||||||
addons->kind = kind;
|
|
||||||
|
|
||||||
if (kind == MIDORI_ADDON_USER_SCRIPTS || kind == MIDORI_ADDON_USER_STYLES)
|
|
||||||
g_signal_connect (addons->web_widget, "window-object-cleared",
|
|
||||||
G_CALLBACK (midori_web_widget_window_object_cleared_cb), addons);
|
|
||||||
|
|
||||||
g_object_notify (G_OBJECT (addons), "kind");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* midori_addons_get_kind:
|
|
||||||
* @addons: a #MidoriAddons
|
|
||||||
*
|
|
||||||
* Determines the kind of addons.
|
|
||||||
*
|
|
||||||
* Return value: a #MidoriAddonKind
|
|
||||||
**/
|
|
||||||
MidoriAddonKind
|
|
||||||
midori_addons_get_kind (MidoriAddons* addons)
|
|
||||||
{
|
|
||||||
return addons->kind;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* midori_addons_get_toolbar:
|
* midori_addons_get_toolbar:
|
||||||
* @addons: a #MidoriAddons
|
* @addons: a #MidoriAddons
|
||||||
|
@ -1112,6 +1033,7 @@ midori_addons_update_elements (MidoriAddons* addons)
|
||||||
GSList* list;
|
GSList* list;
|
||||||
struct AddonElement* element;
|
struct AddonElement* element;
|
||||||
|
|
||||||
|
g_return_if_fail (MIDORI_IS_ADDONS (addons));
|
||||||
g_return_if_fail (addons->kind != MIDORI_ADDON_NONE);
|
g_return_if_fail (addons->kind != MIDORI_ADDON_NONE);
|
||||||
|
|
||||||
/* FIXME: would GHashTable be better? */
|
/* FIXME: would GHashTable be better? */
|
||||||
|
|
|
@ -42,7 +42,6 @@ struct _MidoriAddonsClass
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
MIDORI_ADDON_NONE,
|
MIDORI_ADDON_NONE,
|
||||||
MIDORI_ADDON_EXTENSIONS,
|
|
||||||
MIDORI_ADDON_USER_SCRIPTS,
|
MIDORI_ADDON_USER_SCRIPTS,
|
||||||
MIDORI_ADDON_USER_STYLES
|
MIDORI_ADDON_USER_STYLES
|
||||||
} MidoriAddonKind;
|
} MidoriAddonKind;
|
||||||
|
@ -57,23 +56,9 @@ GType
|
||||||
midori_addons_get_type (void);
|
midori_addons_get_type (void);
|
||||||
|
|
||||||
GtkWidget*
|
GtkWidget*
|
||||||
midori_addons_new (GtkWidget* web_widget,
|
midori_addons_new (MidoriAddonKind kind,
|
||||||
MidoriAddonKind kind);
|
|
||||||
|
|
||||||
void
|
|
||||||
midori_addons_set_web_widget (MidoriAddons* addons,
|
|
||||||
GtkWidget* web_widget);
|
GtkWidget* web_widget);
|
||||||
|
|
||||||
GtkWidget*
|
|
||||||
midori_addons_get_web_widget (MidoriAddons* addons);
|
|
||||||
|
|
||||||
void
|
|
||||||
midori_addons_set_kind (MidoriAddons* addons,
|
|
||||||
MidoriAddonKind kind);
|
|
||||||
|
|
||||||
MidoriAddonKind
|
|
||||||
midori_addons_get_kind (MidoriAddons* addons);
|
|
||||||
|
|
||||||
GtkWidget*
|
GtkWidget*
|
||||||
midori_addons_get_toolbar (MidoriAddons* addons);
|
midori_addons_get_toolbar (MidoriAddons* addons);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue