aboutsummaryrefslogtreecommitdiffstats
path: root/src/ephy-toolbars-model.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/ephy-toolbars-model.c')
-rwxr-xr-xsrc/ephy-toolbars-model.c551
1 files changed, 106 insertions, 445 deletions
diff --git a/src/ephy-toolbars-model.c b/src/ephy-toolbars-model.c
index 0df59cb0a..b730b93e2 100755
--- a/src/ephy-toolbars-model.c
+++ b/src/ephy-toolbars-model.c
@@ -1,5 +1,6 @@
/*
- * Copyright (C) 2002 Marco Pesenti Gritti
+ * Copyright (C) 2002-2004 Marco Pesenti Gritti
+ * Copyright (C) 2003, 2004 Christian Persch
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@@ -23,54 +24,27 @@
#endif
#include "ephy-toolbars-model.h"
-#include "ephy-dnd.h"
-#include "ephy-bookmarks.h"
-#include "ephy-node-common.h"
#include "ephy-file-helpers.h"
-#include "ephy-history.h"
-#include "ephy-embed-shell.h"
-#include "ephy-shell.h"
#include "ephy-debug.h"
-#include "ephy-string.h"
#include <string.h>
-#include <glib/gi18n.h>
-static void ephy_toolbars_model_class_init (EphyToolbarsModelClass *klass);
-static void ephy_toolbars_model_init (EphyToolbarsModel *t);
-static void ephy_toolbars_model_finalize (GObject *object);
-
-#define EPHY_TOOLBARS_XML_VERSION "1.0"
-
-enum
-{
- ACTION_ADDED,
- LAST_SIGNAL
-};
-
-enum
-{
- PROP_0,
- PROP_BOOKMARKS
-};
-
-enum
-{
- URL,
- NAME
-};
-
-static GObjectClass *parent_class = NULL;
+#define EPHY_TOOLBARS_XML_FILE "epiphany-toolbars-2.xml"
+#define EPHY_TOOLBARS_XML_VERSION "1.0"
#define EPHY_TOOLBARS_MODEL_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_TOOLBARS_MODEL, EphyToolbarsModelPrivate))
struct EphyToolbarsModelPrivate
{
- EphyBookmarks *bookmarks;
char *xml_file;
- gboolean loading;
+ guint timeout;
};
+static void ephy_toolbars_model_class_init (EphyToolbarsModelClass *klass);
+static void ephy_toolbars_model_init (EphyToolbarsModel *model);
+
+static GObjectClass *parent_class = NULL;
+
GType
ephy_toolbars_model_get_type (void)
{
@@ -98,207 +72,75 @@ ephy_toolbars_model_get_type (void)
return type;
}
-char *
-ephy_toolbars_model_get_action_name (EphyToolbarsModel *model,
- long id)
+static gboolean
+save_changes_idle (EphyToolbarsModel *model)
{
- return g_strdup_printf ("GoBookmark-%ld", id);
-}
+ LOG ("Saving toolbars model")
-EphyNode *
-ephy_toolbars_model_get_node (EphyToolbarsModel *model,
- const char *action_name)
-{
- EphyBookmarks *bookmarks = EPHY_TOOLBARS_MODEL (model)->priv->bookmarks;
- long node_id;
+ egg_toolbars_model_save
+ (EGG_TOOLBARS_MODEL (model),
+ model->priv->xml_file,
+ EPHY_TOOLBARS_XML_VERSION);
- if (!ephy_string_to_int (action_name + strlen ("GoBookmark-"), &node_id))
- {
- return NULL;
- }
+ model->priv->timeout = 0;
- return ephy_bookmarks_get_from_id (bookmarks, node_id);
+ /* don't run again */
+ return FALSE;
}
static void
-bookmark_destroy_cb (EphyNode *node,
- EphyToolbarsModel *model)
-{
- long id;
-
- id = ephy_node_get_id (node);
- ephy_toolbars_model_remove_bookmark (model, id);
-}
-
-static char *
-impl_get_item_data (EggToolbarsModel *t,
- const char *type,
- const char *id)
+save_changes (EphyToolbarsModel *model)
{
- EphyToolbarsModel *model = EPHY_TOOLBARS_MODEL (t);
- EphyNode *node;
-
- if (strcmp (type, EPHY_DND_TOPIC_TYPE) == 0)
- {
- char *uri;
-
- node = ephy_toolbars_model_get_node (model, id);
- g_return_val_if_fail (node != NULL, NULL);
-
- uri = ephy_bookmarks_get_topic_uri
- (model->priv->bookmarks, node);
-
- return uri;
- }
- else if (strcmp (type, EPHY_DND_URL_TYPE) == 0)
+ if (model->priv->timeout == 0)
{
- const char *name;
-
- node = ephy_toolbars_model_get_node (model, id);
- g_return_val_if_fail (node != NULL, NULL);
-
- name = ephy_node_get_property_string
- (node, EPHY_NODE_BMK_PROP_LOCATION);
-
- return g_strdup (name);
+ model->priv->timeout =
+ g_idle_add ((GSourceFunc) save_changes_idle, model);
}
-
- return EGG_TOOLBARS_MODEL_CLASS (parent_class)->get_item_data (t, type, id);
}
-static char *
-impl_get_item_id (EggToolbarsModel *t,
- const char *type,
- const char *name)
+static void
+update_flags_and_save_changes (EphyToolbarsModel *model)
{
- EphyToolbarsModel *model = EPHY_TOOLBARS_MODEL (t);
- EphyBookmarks *bookmarks = model->priv->bookmarks;
-
- if (strcmp (type, EPHY_DND_TOPIC_TYPE) == 0)
- {
- EphyNode *topic;
-
- topic = ephy_bookmarks_find_keyword (bookmarks, name, FALSE);
- if (topic == NULL) return NULL;
-
- return ephy_toolbars_model_get_action_name
- (model, ephy_node_get_id (topic));
- }
- else if (strcmp (type, EPHY_DND_URL_TYPE) == 0)
- {
- EphyNode *node = NULL;
- gchar **netscape_url;
-
- netscape_url = g_strsplit (name, "\n", 2);
- node = ephy_bookmarks_find_bookmark (bookmarks, netscape_url[URL]);
-
- if (!node)
- {
- /* Create the bookmark, it does not exist */
- EphyHistory *gh;
- const char *icon;
- const char *title;
-
- title = netscape_url[NAME];
- if (title == NULL || *title == '\0')
- {
- title = _("Untitled");
- }
-
- node = ephy_bookmarks_add (bookmarks, title, netscape_url[URL]);
-
- if (node != NULL)
- {
- gh = EPHY_HISTORY (ephy_embed_shell_get_global_history (embed_shell));
- icon = ephy_history_get_icon (gh, netscape_url[URL]);
-
- if (icon)
- {
- ephy_bookmarks_set_icon (bookmarks, netscape_url[URL], icon);
- }
- }
- }
-
- g_strfreev (netscape_url);
-
- if (node == NULL) return NULL;
-
- return ephy_toolbars_model_get_action_name
- (model, ephy_node_get_id (node));
- }
+ EggToolbarsModel *eggmodel = EGG_TOOLBARS_MODEL (model);
+ int i, n_toolbars;
+ int flag = EGG_TB_MODEL_ACCEPT_ITEMS_ONLY;
- return EGG_TOOLBARS_MODEL_CLASS (parent_class)->get_item_data (t, type, name);
-}
+ n_toolbars = egg_toolbars_model_n_toolbars (eggmodel);
-static char *
-impl_get_item_type (EggToolbarsModel *t,
- GdkAtom type)
-{
- if (gdk_atom_intern (EPHY_DND_TOPIC_TYPE, FALSE) == type)
- {
- return g_strdup (EPHY_DND_TOPIC_TYPE);
- }
- else if (gdk_atom_intern (EPHY_DND_URL_TYPE, FALSE) == type)
+ if (n_toolbars <= 1)
{
- return g_strdup (EPHY_DND_URL_TYPE);
+ flag |= EGG_TB_MODEL_NOT_REMOVABLE;
}
- return EGG_TOOLBARS_MODEL_CLASS (parent_class)->get_item_type (t, type);
-}
-
-static gboolean
-get_toolbar_and_item_pos (EphyToolbarsModel *model,
- const char *action_name,
- int *toolbar,
- int *position)
-{
- int n_toolbars, n_items;
- int t,i;
-
- n_toolbars = egg_toolbars_model_n_toolbars (EGG_TOOLBARS_MODEL (model));
-
- for (t = 0; t < n_toolbars; t++)
+ for (i = 0; i < n_toolbars; i++)
{
- n_items = egg_toolbars_model_n_items
- (EGG_TOOLBARS_MODEL (model), t);
-
- for (i = 0; i < n_items; i++)
- {
- const char *i_name;
- gboolean is_separator;
-
- egg_toolbars_model_item_nth (EGG_TOOLBARS_MODEL (model),
- t, i, &is_separator, &i_name, NULL);
- g_return_val_if_fail (i_name != NULL, FALSE);
+ const char *t_name;
+ EggTbModelFlags flags;
- if (strcmp (i_name, action_name) == 0)
- {
- if (toolbar) *toolbar = t;
- if (position) *position = i;
+ t_name = egg_toolbars_model_toolbar_nth (eggmodel, i);
+ g_return_if_fail (t_name != NULL);
- return TRUE;
- }
- }
+ flags = egg_toolbars_model_get_flags (eggmodel, i);
+ egg_toolbars_model_set_flags (eggmodel, flags | flag, i);
}
- return FALSE;
+ save_changes (model);
}
static int
-get_toolbar_pos (EphyToolbarsModel *model,
+get_toolbar_pos (EggToolbarsModel *model,
const char *name)
{
int i, n_toolbars;
- n_toolbars = egg_toolbars_model_n_toolbars
- (EGG_TOOLBARS_MODEL (model));
+ n_toolbars = egg_toolbars_model_n_toolbars (model);
for (i = 0; i < n_toolbars; i++)
{
const char *t_name;
- t_name = egg_toolbars_model_toolbar_nth
- (EGG_TOOLBARS_MODEL (model), i);
+ t_name = egg_toolbars_model_toolbar_nth (model, i);
+ g_return_val_if_fail (t_name != NULL, -1);
if (strcmp (name, t_name) == 0)
{
return i;
@@ -308,289 +150,108 @@ get_toolbar_pos (EphyToolbarsModel *model,
return -1;
}
-static void
-connect_item (EphyToolbarsModel *model,
- const char *name)
-{
- EphyNode *node;
-
- if (g_str_has_prefix (name, "GoBookmark-"))
- {
- node = ephy_toolbars_model_get_node (model, name);
- g_return_if_fail (node != NULL);
-
- ephy_node_signal_connect_object (node,
- EPHY_NODE_DESTROY,
- (EphyNodeCallback) bookmark_destroy_cb,
- G_OBJECT (model));
- }
-}
-
-static void
-update_toolbar_removeable_flag (EggToolbarsModel *model)
+void
+ephy_toolbars_model_load (EphyToolbarsModel *model)
{
- int i, n_toolbars;
- int flag = 0;
+ EggToolbarsModel *eggmodel = EGG_TOOLBARS_MODEL (model);
+ gboolean success;
- n_toolbars = egg_toolbars_model_n_toolbars (model);
-
- /* If there is only one toolbar and the bookmarks bar */
- if (n_toolbars <= 2)
- {
- flag = EGG_TB_MODEL_NOT_REMOVABLE;
- }
+ success = egg_toolbars_model_load (eggmodel, model->priv->xml_file);
+ LOG ("Loading the toolbars was %ssuccessful", success ? "" : "un")
- for (i = 0; i < n_toolbars; i++)
+ /* maybe an old format, try to migrate: load the old layout, and
+ * remove the BookmarksBar toolbar
+ */
+ if (success == FALSE)
{
- const char *t_name;
+ char *old_xml;
+ int toolbar;
- t_name = egg_toolbars_model_toolbar_nth (model, i);
- g_return_if_fail (t_name != NULL);
+ old_xml = g_build_filename (ephy_dot_dir (),
+ "epiphany-toolbars.xml",
+ NULL);
+ success = egg_toolbars_model_load (eggmodel, old_xml);
+ g_free (old_xml);
- if (!(strcmp (t_name, "BookmarksBar") == 0))
+ if (success)
{
- egg_toolbars_model_set_flags (model, flag, i);
+ toolbar = get_toolbar_pos (eggmodel, "BookmarksBar");
+ if (toolbar != -1)
+ {
+ egg_toolbars_model_remove_toolbar (eggmodel, toolbar);
+ }
}
- }
-}
-
-static void
-ephy_toolbars_model_set_bookmarks (EphyToolbarsModel *model, EphyBookmarks *bookmarks)
-{
- EggToolbarsModel *egg_model = EGG_TOOLBARS_MODEL (model);
- gboolean success = FALSE;
-
- model->priv->bookmarks = g_object_ref (bookmarks);
-
- model->priv->loading = TRUE;
- if (g_file_test (model->priv->xml_file, G_FILE_TEST_EXISTS))
- {
- success = egg_toolbars_model_load (egg_model,
- model->priv->xml_file);
+ LOG ("Migration was %ssuccessful", success ? "" : "un")
}
+ /* Still no success, load the default toolbars */
if (success == FALSE)
{
- const char *default_xml;
-
- default_xml = ephy_file ("epiphany-toolbar.xml");
- egg_toolbars_model_load (egg_model, default_xml);
+ success = egg_toolbars_model_load
+ (eggmodel, ephy_file ("epiphany-toolbar.xml"));
+ LOG ("Loading the default toolbars was %ssuccessful", success ? "" : "un")
}
- /* ensure that we have a BookmarksBar */
- if (get_toolbar_pos (model, "BookmarksBar") == -1)
+ /* Ensure we have at least 1 toolbar */
+ if (egg_toolbars_model_n_toolbars (eggmodel) < 1)
{
- egg_toolbars_model_add_toolbar
- (EGG_TOOLBARS_MODEL (model), -1, "BookmarksBar");
+ egg_toolbars_model_add_toolbar (eggmodel, 0, "DefaultToolbar");
}
-
- model->priv->loading = FALSE;
}
static void
-ephy_toolbars_model_set_property (GObject *object,
- guint prop_id,
- const GValue *value,
- GParamSpec *pspec)
+ephy_toolbars_model_init (EphyToolbarsModel *model)
{
- EphyToolbarsModel *model;
-
- model = EPHY_TOOLBARS_MODEL (object);
-
- switch (prop_id)
- {
- case PROP_BOOKMARKS:
- ephy_toolbars_model_set_bookmarks (model, g_value_get_object (value));
- break;
- }
+ model->priv = EPHY_TOOLBARS_MODEL_GET_PRIVATE (model);
+
+ model->priv->xml_file = g_build_filename (ephy_dot_dir (),
+ EPHY_TOOLBARS_XML_FILE,
+ NULL);
+
+ g_signal_connect_after (model, "item_added",
+ G_CALLBACK (save_changes), NULL);
+ g_signal_connect_after (model, "item_removed",
+ G_CALLBACK (save_changes), NULL);
+ g_signal_connect_after (model, "toolbar_added",
+ G_CALLBACK (update_flags_and_save_changes), NULL);
+ g_signal_connect_after (model, "toolbar_removed",
+ G_CALLBACK (update_flags_and_save_changes), NULL);
}
static void
-ephy_toolbars_model_get_property (GObject *object,
- guint prop_id,
- GValue *value,
- GParamSpec *pspec)
+ephy_toolbars_model_finalize (GObject *object)
{
- EphyToolbarsModel *model;
-
- model = EPHY_TOOLBARS_MODEL (object);
+ EphyToolbarsModel *model = EPHY_TOOLBARS_MODEL (object);
- switch (prop_id)
+ if (model->priv->timeout != 0)
{
- case PROP_BOOKMARKS:
- g_value_set_object (value, model->priv->bookmarks);
- break;
+ g_source_remove (model->priv->timeout);
+ model->priv->timeout = 0;
}
+
+ /* FIXME: we should detect when item data changes, and save then instead */
+ save_changes_idle (model);
+
+ g_free (model->priv->xml_file);
+
+ G_OBJECT_CLASS (parent_class)->finalize (object);
}
static void
ephy_toolbars_model_class_init (EphyToolbarsModelClass *klass)
{
GObjectClass *object_class = G_OBJECT_CLASS (klass);
- EggToolbarsModelClass *etm_class;
-
- etm_class = EGG_TOOLBARS_MODEL_CLASS (klass);
parent_class = g_type_class_peek_parent (klass);
object_class->finalize = ephy_toolbars_model_finalize;
- object_class->set_property = ephy_toolbars_model_set_property;
- object_class->get_property = ephy_toolbars_model_get_property;
-
- etm_class->get_item_id = impl_get_item_id;
- etm_class->get_item_data = impl_get_item_data;
- etm_class->get_item_type = impl_get_item_type;
-
- g_object_class_install_property (object_class,
- PROP_BOOKMARKS,
- g_param_spec_object ("bookmarks",
- "Bookmarks",
- "Bookmarks",
- EPHY_TYPE_BOOKMARKS,
- G_PARAM_READWRITE));
-
- g_type_class_add_private (object_class, sizeof(EphyToolbarsModelPrivate));
-}
-
-static void
-save_changes (EphyToolbarsModel *model)
-{
- if (!model->priv->loading)
- {
- egg_toolbars_model_save (EGG_TOOLBARS_MODEL (model),
- model->priv->xml_file,
- EPHY_TOOLBARS_XML_VERSION);
- }
-}
-
-static void
-item_added (EphyToolbarsModel *model, int toolbar_position, int position)
-{
- const char *i_name;
- gboolean is_separator;
-
- egg_toolbars_model_item_nth (EGG_TOOLBARS_MODEL (model), toolbar_position,
- position, &is_separator, &i_name, NULL);
- if (!is_separator)
- {
- connect_item (model, i_name);
- }
-
- save_changes (model);
-}
-
-static void
-item_removed (EphyToolbarsModel *model, int toolbar_position, int position)
-{
- save_changes (model);
-}
-
-static void
-toolbar_added (EphyToolbarsModel *model, int position)
-{
- save_changes (model);
- update_toolbar_removeable_flag (EGG_TOOLBARS_MODEL (model));
-}
-
-static void
-toolbar_removed (EphyToolbarsModel *model, int position)
-{
- save_changes (model);
- update_toolbar_removeable_flag (EGG_TOOLBARS_MODEL (model));
-}
-
-static void
-ephy_toolbars_model_init (EphyToolbarsModel *t)
-{
- t->priv = EPHY_TOOLBARS_MODEL_GET_PRIVATE (t);
-
- t->priv->bookmarks = NULL;
- t->priv->loading = FALSE;
- t->priv->xml_file = g_build_filename (ephy_dot_dir (),
- "epiphany-toolbars.xml",
- NULL);
-
- g_signal_connect (t, "item_added", G_CALLBACK (item_added), NULL);
- g_signal_connect (t, "item_removed", G_CALLBACK (item_removed), NULL);
- g_signal_connect (t, "toolbar_added", G_CALLBACK (toolbar_added), NULL);
- g_signal_connect (t, "toolbar_removed", G_CALLBACK (toolbar_removed), NULL);
-}
-
-static void
-ephy_toolbars_model_finalize (GObject *object)
-{
- EphyToolbarsModel *t = EPHY_TOOLBARS_MODEL (object);
- save_changes (t);
-
- g_object_unref (t->priv->bookmarks);
-
- g_free (t->priv->xml_file);
-
- G_OBJECT_CLASS (parent_class)->finalize (object);
-}
-
-EphyToolbarsModel *
-ephy_toolbars_model_new (EphyBookmarks *bookmarks)
-{
- return EPHY_TOOLBARS_MODEL (g_object_new (EPHY_TYPE_TOOLBARS_MODEL,
- "bookmarks", bookmarks,
- NULL));
-}
-
-void
-ephy_toolbars_model_remove_bookmark (EphyToolbarsModel *model,
- long id)
-{
- char *action_name;
- int toolbar, position;
-
- action_name = ephy_toolbars_model_get_action_name (model, id);
- g_return_if_fail (action_name != NULL);
-
- if (get_toolbar_and_item_pos (model, action_name, &toolbar, &position))
- {
- egg_toolbars_model_remove_item (EGG_TOOLBARS_MODEL (model),
- toolbar, position);
- }
-
- g_free (action_name);
-}
-
-void
-ephy_toolbars_model_add_bookmark (EphyToolbarsModel *model,
- gboolean topic,
- long id)
-{
- char *name;
- int toolbar_position;
-
- toolbar_position = get_toolbar_pos (model, "BookmarksBar");
- g_return_if_fail (toolbar_position != -1);
-
- name = ephy_toolbars_model_get_action_name (model, id);
- egg_toolbars_model_add_item (EGG_TOOLBARS_MODEL (model),
- toolbar_position, -1, name,
- topic ? EPHY_DND_TOPIC_TYPE :
- EPHY_DND_URL_TYPE);
- g_free (name);
+ g_type_class_add_private (object_class, sizeof (EphyToolbarsModelPrivate));
}
-gboolean
-ephy_toolbars_model_has_bookmark (EphyToolbarsModel *model,
- long id)
+EggToolbarsModel *
+ephy_toolbars_model_new (void)
{
- char *action_name;
- gboolean found;
- int toolbar, pos;
-
- action_name = ephy_toolbars_model_get_action_name (model, id);
- g_return_val_if_fail (action_name != NULL, FALSE);
-
- found = get_toolbar_and_item_pos (model, action_name, &toolbar, &pos);
-
- g_free (action_name);
-
- return found;
+ return EGG_TOOLBARS_MODEL (g_object_new (EPHY_TYPE_TOOLBARS_MODEL, NULL));
}