Merge MidoriAddonsPrivate with MidoriAddons and hide it
This commit is contained in:
parent
1ffbfaded9
commit
86129a03da
2 changed files with 31 additions and 50 deletions
|
@ -19,18 +19,16 @@
|
||||||
#include <JavaScriptCore/JavaScript.h>
|
#include <JavaScriptCore/JavaScript.h>
|
||||||
#include <glib/gi18n.h>
|
#include <glib/gi18n.h>
|
||||||
|
|
||||||
G_DEFINE_TYPE (MidoriAddons, midori_addons, GTK_TYPE_VBOX)
|
struct _MidoriAddons
|
||||||
|
|
||||||
struct _MidoriAddonsPrivate
|
|
||||||
{
|
{
|
||||||
|
GtkVBox parent_instance;
|
||||||
|
|
||||||
MidoriAddonKind kind;
|
MidoriAddonKind kind;
|
||||||
GtkWidget* toolbar;
|
GtkWidget* toolbar;
|
||||||
GtkWidget* treeview;
|
GtkWidget* treeview;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define MIDORI_ADDONS_GET_PRIVATE(obj) \
|
G_DEFINE_TYPE (MidoriAddons, midori_addons, GTK_TYPE_VBOX)
|
||||||
(G_TYPE_INSTANCE_GET_PRIVATE ((obj), \
|
|
||||||
MIDORI_TYPE_ADDONS, MidoriAddonsPrivate))
|
|
||||||
|
|
||||||
GType
|
GType
|
||||||
midori_addon_kind_get_type (void)
|
midori_addon_kind_get_type (void)
|
||||||
|
@ -52,7 +50,7 @@ midori_addon_kind_get_type (void)
|
||||||
static void
|
static void
|
||||||
midori_addons_class_init (MidoriAddonsClass* class)
|
midori_addons_class_init (MidoriAddonsClass* class)
|
||||||
{
|
{
|
||||||
g_type_class_add_private (class, sizeof (MidoriAddonsPrivate));
|
/* Nothing to do */
|
||||||
}
|
}
|
||||||
|
|
||||||
static const
|
static const
|
||||||
|
@ -75,14 +73,12 @@ static void
|
||||||
midori_addons_button_add_clicked_cb (GtkToolItem* toolitem,
|
midori_addons_button_add_clicked_cb (GtkToolItem* toolitem,
|
||||||
MidoriAddons* addons)
|
MidoriAddons* addons)
|
||||||
{
|
{
|
||||||
MidoriAddonsPrivate* priv = addons->priv;
|
|
||||||
|
|
||||||
GtkWidget* dialog = gtk_message_dialog_new (
|
GtkWidget* dialog = gtk_message_dialog_new (
|
||||||
GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (addons))),
|
GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (addons))),
|
||||||
GTK_DIALOG_DESTROY_WITH_PARENT,
|
GTK_DIALOG_DESTROY_WITH_PARENT,
|
||||||
GTK_MESSAGE_INFO, GTK_BUTTONS_CLOSE,
|
GTK_MESSAGE_INFO, GTK_BUTTONS_CLOSE,
|
||||||
"Put scripts in the folder ~/.local/share/midori/%s",
|
"Put scripts in the folder ~/.local/share/midori/%s",
|
||||||
_folder_for_kind (priv->kind));
|
_folder_for_kind (addons->kind));
|
||||||
gtk_dialog_run (GTK_DIALOG (dialog));
|
gtk_dialog_run (GTK_DIALOG (dialog));
|
||||||
gtk_widget_destroy (dialog);
|
gtk_widget_destroy (dialog);
|
||||||
}
|
}
|
||||||
|
@ -94,12 +90,12 @@ midori_addons_treeview_render_icon_cb (GtkTreeViewColumn* column,
|
||||||
GtkTreeIter* iter,
|
GtkTreeIter* iter,
|
||||||
GtkWidget* treeview)
|
GtkWidget* treeview)
|
||||||
{
|
{
|
||||||
// gchar* source_id;
|
/* gchar* source_id;
|
||||||
// gtk_tree_model_get (model, iter, 2, &source_id, -1);
|
gtk_tree_model_get (model, iter, 2, &source_id, -1); */
|
||||||
|
|
||||||
g_object_set (renderer, "stock-id", GTK_STOCK_FILE, NULL);
|
g_object_set (renderer, "stock-id", GTK_STOCK_FILE, NULL);
|
||||||
|
|
||||||
// g_free (source_id);
|
/* g_free (source_id); */
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -114,7 +110,7 @@ midori_addons_treeview_render_text_cb (GtkTreeViewColumn* column,
|
||||||
gchar* b;
|
gchar* b;
|
||||||
gtk_tree_model_get (model, iter, 0, &filename, 1, &a, 2, &b, -1);
|
gtk_tree_model_get (model, iter, 0, &filename, 1, &a, 2, &b, -1);
|
||||||
|
|
||||||
// FIXME: Convert filename to UTF8
|
/* FIXME: Convert filename to UTF8 */
|
||||||
gchar* text = g_strdup_printf ("%s", filename);
|
gchar* text = g_strdup_printf ("%s", filename);
|
||||||
g_object_set (renderer, "text", text, NULL);
|
g_object_set (renderer, "text", text, NULL);
|
||||||
g_free (text);
|
g_free (text);
|
||||||
|
@ -142,32 +138,29 @@ midori_addons_treeview_row_activated_cb (GtkTreeView* treeview,
|
||||||
static void
|
static void
|
||||||
midori_addons_init (MidoriAddons* addons)
|
midori_addons_init (MidoriAddons* addons)
|
||||||
{
|
{
|
||||||
addons->priv = MIDORI_ADDONS_GET_PRIVATE (addons);
|
|
||||||
|
|
||||||
MidoriAddonsPrivate* priv = addons->priv;
|
|
||||||
|
|
||||||
GtkTreeViewColumn* column;
|
GtkTreeViewColumn* column;
|
||||||
GtkCellRenderer* renderer_text;
|
GtkCellRenderer* renderer_text;
|
||||||
GtkCellRenderer* renderer_pixbuf;
|
GtkCellRenderer* renderer_pixbuf;
|
||||||
priv->treeview = gtk_tree_view_new ();
|
|
||||||
gtk_tree_view_set_headers_visible (GTK_TREE_VIEW (priv->treeview), FALSE);
|
addons->treeview = gtk_tree_view_new ();
|
||||||
|
gtk_tree_view_set_headers_visible (GTK_TREE_VIEW (addons->treeview), FALSE);
|
||||||
column = gtk_tree_view_column_new ();
|
column = gtk_tree_view_column_new ();
|
||||||
renderer_pixbuf = gtk_cell_renderer_pixbuf_new ();
|
renderer_pixbuf = gtk_cell_renderer_pixbuf_new ();
|
||||||
gtk_tree_view_column_pack_start (column, renderer_pixbuf, FALSE);
|
gtk_tree_view_column_pack_start (column, renderer_pixbuf, FALSE);
|
||||||
gtk_tree_view_column_set_cell_data_func (column, renderer_pixbuf,
|
gtk_tree_view_column_set_cell_data_func (column, renderer_pixbuf,
|
||||||
(GtkTreeCellDataFunc)midori_addons_treeview_render_icon_cb,
|
(GtkTreeCellDataFunc)midori_addons_treeview_render_icon_cb,
|
||||||
priv->treeview, NULL);
|
addons->treeview, NULL);
|
||||||
renderer_text = gtk_cell_renderer_text_new ();
|
renderer_text = gtk_cell_renderer_text_new ();
|
||||||
gtk_tree_view_column_pack_start (column, renderer_text, FALSE);
|
gtk_tree_view_column_pack_start (column, renderer_text, FALSE);
|
||||||
gtk_tree_view_column_set_cell_data_func (column, renderer_text,
|
gtk_tree_view_column_set_cell_data_func (column, renderer_text,
|
||||||
(GtkTreeCellDataFunc)midori_addons_treeview_render_text_cb,
|
(GtkTreeCellDataFunc)midori_addons_treeview_render_text_cb,
|
||||||
priv->treeview, NULL);
|
addons->treeview, NULL);
|
||||||
gtk_tree_view_append_column (GTK_TREE_VIEW (priv->treeview), column);
|
gtk_tree_view_append_column (GTK_TREE_VIEW (addons->treeview), column);
|
||||||
g_signal_connect (priv->treeview, "row-activated",
|
g_signal_connect (addons->treeview, "row-activated",
|
||||||
G_CALLBACK (midori_addons_treeview_row_activated_cb),
|
G_CALLBACK (midori_addons_treeview_row_activated_cb),
|
||||||
addons);
|
addons);
|
||||||
gtk_widget_show (priv->treeview);
|
gtk_widget_show (addons->treeview);
|
||||||
gtk_box_pack_start (GTK_BOX (addons), priv->treeview, TRUE, TRUE, 0);
|
gtk_box_pack_start (GTK_BOX (addons), addons->treeview, TRUE, TRUE, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
@ -178,9 +171,10 @@ _js_script_from_file (JSContextRef js_context,
|
||||||
gboolean result = FALSE;
|
gboolean result = FALSE;
|
||||||
gchar* script;
|
gchar* script;
|
||||||
GError* error = NULL;
|
GError* error = NULL;
|
||||||
|
|
||||||
if (g_file_get_contents (filename, &script, NULL, &error))
|
if (g_file_get_contents (filename, &script, NULL, &error))
|
||||||
{
|
{
|
||||||
// Wrap the script to prevent global variables
|
/* Wrap the script to prevent global variables */
|
||||||
gchar* wrapped_script = g_strdup_printf (
|
gchar* wrapped_script = g_strdup_printf (
|
||||||
"var wrapped = function () { %s }; wrapped ();", script);
|
"var wrapped = function () { %s }; wrapped ();", script);
|
||||||
if (gjs_script_eval (js_context, wrapped_script, exception))
|
if (gjs_script_eval (js_context, wrapped_script, exception))
|
||||||
|
@ -203,11 +197,9 @@ midori_web_widget_window_object_cleared_cb (GtkWidget* web_widget,
|
||||||
JSObjectRef js_window,
|
JSObjectRef js_window,
|
||||||
MidoriAddons* addons)
|
MidoriAddons* addons)
|
||||||
{
|
{
|
||||||
MidoriAddonsPrivate* priv = addons->priv;
|
/* FIXME: We want to honor system installed addons as well */
|
||||||
|
|
||||||
// FIXME: We want to honor system installed addons as well
|
|
||||||
gchar* addon_path = g_build_filename (g_get_user_data_dir (), PACKAGE_NAME,
|
gchar* addon_path = g_build_filename (g_get_user_data_dir (), PACKAGE_NAME,
|
||||||
_folder_for_kind (priv->kind), NULL);
|
_folder_for_kind (addons->kind), NULL);
|
||||||
GDir* addon_dir = g_dir_open (addon_path, 0, NULL);
|
GDir* addon_dir = g_dir_open (addon_path, 0, NULL);
|
||||||
if (addon_dir)
|
if (addon_dir)
|
||||||
{
|
{
|
||||||
|
@ -252,12 +244,10 @@ 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);
|
||||||
|
|
||||||
MidoriAddons* addons = g_object_new (MIDORI_TYPE_ADDONS,
|
MidoriAddons* addons = g_object_new (MIDORI_TYPE_ADDONS,
|
||||||
// "kind", kind,
|
/* "kind", kind, */
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
MidoriAddonsPrivate* priv = addons->priv;
|
addons->kind = kind;
|
||||||
priv->kind = kind;
|
|
||||||
|
|
||||||
if (kind == MIDORI_ADDON_USER_SCRIPTS)
|
if (kind == MIDORI_ADDON_USER_SCRIPTS)
|
||||||
g_signal_connect (web_widget, "window-object-cleared",
|
g_signal_connect (web_widget, "window-object-cleared",
|
||||||
G_CALLBACK (midori_web_widget_window_object_cleared_cb), addons);
|
G_CALLBACK (midori_web_widget_window_object_cleared_cb), addons);
|
||||||
|
@ -265,9 +255,9 @@ midori_addons_new (GtkWidget* web_widget,
|
||||||
GtkListStore* liststore = gtk_list_store_new (3, G_TYPE_STRING,
|
GtkListStore* liststore = gtk_list_store_new (3, G_TYPE_STRING,
|
||||||
G_TYPE_INT,
|
G_TYPE_INT,
|
||||||
G_TYPE_STRING);
|
G_TYPE_STRING);
|
||||||
// FIXME: We want to honor system installed addons as well
|
/* FIXME: We want to honor system installed addons as well */
|
||||||
gchar* addon_path = g_build_filename (g_get_user_data_dir (), PACKAGE_NAME,
|
gchar* addon_path = g_build_filename (g_get_user_data_dir (), PACKAGE_NAME,
|
||||||
_folder_for_kind (priv->kind), NULL);
|
_folder_for_kind (addons->kind), NULL);
|
||||||
GDir* addon_dir = g_dir_open (addon_path, 0, NULL);
|
GDir* addon_dir = g_dir_open (addon_path, 0, NULL);
|
||||||
if (addon_dir)
|
if (addon_dir)
|
||||||
{
|
{
|
||||||
|
@ -281,7 +271,7 @@ midori_addons_new (GtkWidget* web_widget,
|
||||||
}
|
}
|
||||||
g_dir_close (addon_dir);
|
g_dir_close (addon_dir);
|
||||||
}
|
}
|
||||||
gtk_tree_view_set_model (GTK_TREE_VIEW (priv->treeview),
|
gtk_tree_view_set_model (GTK_TREE_VIEW (addons->treeview),
|
||||||
GTK_TREE_MODEL (liststore));
|
GTK_TREE_MODEL (liststore));
|
||||||
|
|
||||||
return GTK_WIDGET (addons);
|
return GTK_WIDGET (addons);
|
||||||
|
@ -298,11 +288,9 @@ midori_addons_new (GtkWidget* web_widget,
|
||||||
GtkWidget*
|
GtkWidget*
|
||||||
midori_addons_get_toolbar (MidoriAddons* addons)
|
midori_addons_get_toolbar (MidoriAddons* addons)
|
||||||
{
|
{
|
||||||
MidoriAddonsPrivate* priv = addons->priv;
|
|
||||||
|
|
||||||
g_return_val_if_fail (MIDORI_IS_ADDONS (addons), NULL);
|
g_return_val_if_fail (MIDORI_IS_ADDONS (addons), NULL);
|
||||||
|
|
||||||
if (!priv->toolbar)
|
if (!addons->toolbar)
|
||||||
{
|
{
|
||||||
GtkWidget* toolbar = gtk_toolbar_new ();
|
GtkWidget* toolbar = gtk_toolbar_new ();
|
||||||
gtk_toolbar_set_style (GTK_TOOLBAR (toolbar), GTK_TOOLBAR_BOTH_HORIZ);
|
gtk_toolbar_set_style (GTK_TOOLBAR (toolbar), GTK_TOOLBAR_BOTH_HORIZ);
|
||||||
|
@ -322,8 +310,8 @@ midori_addons_get_toolbar (MidoriAddons* addons)
|
||||||
G_CALLBACK (midori_addons_button_add_clicked_cb), addons);
|
G_CALLBACK (midori_addons_button_add_clicked_cb), addons);
|
||||||
gtk_toolbar_insert (GTK_TOOLBAR (toolbar), toolitem, -1);
|
gtk_toolbar_insert (GTK_TOOLBAR (toolbar), toolitem, -1);
|
||||||
gtk_widget_show (GTK_WIDGET (toolitem));
|
gtk_widget_show (GTK_WIDGET (toolitem));
|
||||||
priv->toolbar = toolbar;
|
addons->toolbar = toolbar;
|
||||||
}
|
}
|
||||||
|
|
||||||
return priv->toolbar;
|
return addons->toolbar;
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,13 +35,6 @@ typedef struct _MidoriAddons MidoriAddons;
|
||||||
typedef struct _MidoriAddonsPrivate MidoriAddonsPrivate;
|
typedef struct _MidoriAddonsPrivate MidoriAddonsPrivate;
|
||||||
typedef struct _MidoriAddonsClass MidoriAddonsClass;
|
typedef struct _MidoriAddonsClass MidoriAddonsClass;
|
||||||
|
|
||||||
struct _MidoriAddons
|
|
||||||
{
|
|
||||||
GtkVBox parent_instance;
|
|
||||||
|
|
||||||
MidoriAddonsPrivate* priv;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct _MidoriAddonsClass
|
struct _MidoriAddonsClass
|
||||||
{
|
{
|
||||||
GtkVBoxClass parent_class;
|
GtkVBoxClass parent_class;
|
||||||
|
|
Loading…
Reference in a new issue