aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorClaudio Saavedra <csaavedra@igalia.com>2012-01-26 00:23:00 +0800
committerClaudio Saavedra <csaavedra@igalia.com>2012-09-01 02:34:00 +0800
commit54810099280f6086b79f92db0a2722b434c01657 (patch)
treed51896d9682f555204fd668621a4d041a125c9c7
parent8ddda2707becfbf0fa90159c99f5c7a89a961b79 (diff)
downloadgsoc2013-epiphany-54810099280f6086b79f92db0a2722b434c01657.tar
gsoc2013-epiphany-54810099280f6086b79f92db0a2722b434c01657.tar.gz
gsoc2013-epiphany-54810099280f6086b79f92db0a2722b434c01657.tar.bz2
gsoc2013-epiphany-54810099280f6086b79f92db0a2722b434c01657.tar.lz
gsoc2013-epiphany-54810099280f6086b79f92db0a2722b434c01657.tar.xz
gsoc2013-epiphany-54810099280f6086b79f92db0a2722b434c01657.tar.zst
gsoc2013-epiphany-54810099280f6086b79f92db0a2722b434c01657.zip
Add the base EphyOverviewStore model
This should be subclassed by the models for the history and/or currently open views. https://bugzilla.gnome.org/show_bug.cgi?id=455173
-rw-r--r--lib/widgets/Makefile.am2
-rw-r--r--lib/widgets/ephy-overview-store.c557
-rw-r--r--lib/widgets/ephy-overview-store.h94
3 files changed, 653 insertions, 0 deletions
diff --git a/lib/widgets/Makefile.am b/lib/widgets/Makefile.am
index d1b36d6f2..0232edfc5 100644
--- a/lib/widgets/Makefile.am
+++ b/lib/widgets/Makefile.am
@@ -79,6 +79,8 @@ libephywidgets_la_SOURCES = \
ephy-middle-clickable-button.h \
ephy-node-view.c \
ephy-node-view.h \
+ ephy-overview-store.c \
+ ephy-overview-store.h \
ephy-removable-pixbuf-renderer.c \
ephy-removable-pixbuf-renderer.h \
ephy-search-entry.c \
diff --git a/lib/widgets/ephy-overview-store.c b/lib/widgets/ephy-overview-store.c
new file mode 100644
index 000000000..60c4cd856
--- /dev/null
+++ b/lib/widgets/ephy-overview-store.c
@@ -0,0 +1,557 @@
+/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
+/*
+ * Copyright © 2012 Igalia S.L.
+ *
+ * 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
+ * the Free Software Foundation; either version 2, or (at your option)
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ *
+ */
+
+#include "config.h"
+#include "ephy-history-service.h"
+#include "ephy-overview-store.h"
+#include "ephy-snapshot-service.h"
+
+#define EPHY_OVERVIEW_STORE_GET_PRIVATE(object) (G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_OVERVIEW_STORE, EphyOverviewStorePrivate))
+
+struct _EphyOverviewStorePrivate
+{
+ EphyHistoryService *history_service;
+ GdkPixbuf *default_icon;
+};
+
+enum
+{
+ PROP_0,
+ PROP_HISTORY_SERVICE,
+ PROP_DEFAULT_ICON,
+};
+
+G_DEFINE_TYPE (EphyOverviewStore, ephy_overview_store, GTK_TYPE_LIST_STORE)
+
+static void
+ephy_overview_store_set_property (GObject *object,
+ guint prop_id,
+ const GValue *value,
+ GParamSpec *pspec)
+{
+ EphyOverviewStore *store = EPHY_OVERVIEW_STORE (object);
+
+ switch (prop_id)
+ {
+ case PROP_HISTORY_SERVICE:
+ store->priv->history_service = g_value_get_object (value);
+ g_object_notify (object, "history-service");
+ break;
+ case PROP_DEFAULT_ICON:
+ ephy_overview_store_set_default_icon (store,
+ g_value_get_object (value));
+ break;
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+ break;
+ }
+}
+
+static void
+ephy_overview_store_get_property (GObject *object,
+ guint prop_id,
+ GValue *value,
+ GParamSpec *pspec)
+{
+ EphyOverviewStore *store = EPHY_OVERVIEW_STORE (object);
+
+ switch (prop_id)
+ {
+ case PROP_HISTORY_SERVICE:
+ g_value_set_object (value, store->priv->history_service);
+ break;
+ case PROP_DEFAULT_ICON:
+ g_value_set_object (value, store->priv->default_icon);
+ break;
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+ break;
+ }
+}
+
+static void
+ephy_overview_store_class_init (EphyOverviewStoreClass *klass)
+{
+ GObjectClass *object_class = G_OBJECT_CLASS (klass);
+
+ object_class->set_property = ephy_overview_store_set_property;
+ object_class->get_property = ephy_overview_store_get_property;
+
+ g_object_class_install_property (object_class,
+ PROP_HISTORY_SERVICE,
+ g_param_spec_object ("history-service",
+ "History service",
+ "History Service",
+ EPHY_TYPE_HISTORY_SERVICE,
+ G_PARAM_READWRITE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB));
+
+ g_object_class_install_property (object_class,
+ PROP_DEFAULT_ICON,
+ g_param_spec_object ("default-icon",
+ "Default icon",
+ "Default Icon",
+ GDK_TYPE_PIXBUF,
+ G_PARAM_READWRITE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB));
+
+ g_type_class_add_private (object_class, sizeof(EphyOverviewStorePrivate));
+}
+
+static void
+ephy_overview_store_init (EphyOverviewStore *self)
+{
+ GType types[EPHY_OVERVIEW_STORE_NCOLS];
+
+ types[EPHY_OVERVIEW_STORE_ID] = G_TYPE_STRING;
+ types[EPHY_OVERVIEW_STORE_URI] = G_TYPE_STRING;
+ types[EPHY_OVERVIEW_STORE_TITLE] = G_TYPE_STRING;
+ types[EPHY_OVERVIEW_STORE_AUTHOR] = G_TYPE_STRING;
+ types[EPHY_OVERVIEW_STORE_SNAPSHOT] = GDK_TYPE_PIXBUF;
+ types[EPHY_OVERVIEW_STORE_LAST_VISIT] = G_TYPE_LONG;
+ types[EPHY_OVERVIEW_STORE_SELECTED] = G_TYPE_BOOLEAN;
+ types[EPHY_OVERVIEW_STORE_SNAPSHOT_CANCELLABLE] = G_TYPE_CANCELLABLE;
+
+ gtk_list_store_set_column_types (GTK_LIST_STORE (self),
+ EPHY_OVERVIEW_STORE_NCOLS, types);
+
+ self->priv = EPHY_OVERVIEW_STORE_GET_PRIVATE (self);
+}
+
+typedef struct {
+ GtkTreeRowReference *ref;
+ char *url;
+ WebKitWebView *webview;
+ GCancellable *cancellable;
+} PeekContext;
+
+static void
+peek_context_free (PeekContext *ctx)
+{
+ g_free (ctx->url);
+ gtk_tree_row_reference_free (ctx->ref);
+ if (ctx->webview)
+ g_object_unref (ctx->webview);
+ if (ctx->cancellable)
+ g_object_unref (ctx->cancellable);
+
+ g_slice_free (PeekContext, ctx);
+}
+
+static GdkPixbuf *
+overview_add_frame (GdkPixbuf *pixbuf) {
+ cairo_t *cr;
+ cairo_surface_t *surface;
+ cairo_pattern_t *pattern;
+ int width, height;
+ int border = 10;
+ GdkPixbuf *framed;
+
+ width = gdk_pixbuf_get_width (pixbuf) + 2*border;
+ height = gdk_pixbuf_get_height (pixbuf) + 2*border;
+
+ surface = cairo_image_surface_create (CAIRO_FORMAT_ARGB32, width, height);
+ cr = cairo_create (surface);
+
+ /* FIXME: This could be done as two masks that are later rotated
+ and moved, instead of repeating the same code 4 times. */
+
+ /* Draw the left-shadow. */
+ cairo_save(cr);
+ pattern = cairo_pattern_create_linear (border, border, 0, border);
+ cairo_pattern_add_color_stop_rgba (pattern, 0, 0, 0, 0, 0.5);
+ cairo_pattern_add_color_stop_rgba (pattern, 1, 0, 0, 0, 0.0);
+ cairo_rectangle (cr, 0, border, border, height - 2*border);
+ cairo_clip (cr);
+ cairo_set_source (cr, pattern);
+ cairo_mask (cr, pattern);
+ cairo_pattern_destroy (pattern);
+ cairo_restore (cr);
+
+ /* Draw the up-left quarter-circle. */
+ cairo_save(cr);
+ pattern = cairo_pattern_create_radial (border, border, 0, border, border, border);
+ cairo_pattern_add_color_stop_rgba (pattern, 0, 0, 0, 0, 0.5);
+ cairo_pattern_add_color_stop_rgba (pattern, 1, 0, 0, 0, 0.0);
+ cairo_rectangle (cr, 0, 0, border, border);
+ cairo_clip (cr);
+ cairo_set_source (cr, pattern);
+ cairo_mask (cr, pattern);
+ cairo_pattern_destroy (pattern);
+ cairo_restore(cr);
+
+ cairo_save(cr);
+ pattern = cairo_pattern_create_linear (border, border, border, 0);
+ cairo_pattern_add_color_stop_rgba (pattern, 0, 0, 0, 0, 0.5);
+ cairo_pattern_add_color_stop_rgba (pattern, 1, 0, 0, 0, 0.0);
+ cairo_rectangle (cr, border, 0, width - 2*border, border);
+ cairo_clip (cr);
+ cairo_set_source (cr, pattern);
+ cairo_mask (cr, pattern);
+ cairo_pattern_destroy (pattern);
+ cairo_restore (cr);
+
+ cairo_save(cr);
+ pattern = cairo_pattern_create_radial (width - border, border, 0, width - border, border, border);
+ cairo_pattern_add_color_stop_rgba (pattern, 0, 0, 0, 0, 0.5);
+ cairo_pattern_add_color_stop_rgba (pattern, 1, 0, 0, 0, 0.0);
+ cairo_rectangle (cr, width - border, 0, border, border);
+ cairo_clip (cr);
+ cairo_set_source (cr, pattern);
+ cairo_mask (cr, pattern);
+ cairo_pattern_destroy (pattern);
+ cairo_restore(cr);
+
+ cairo_save(cr);
+ pattern = cairo_pattern_create_linear (width - border, border, width, border);
+ cairo_pattern_add_color_stop_rgba (pattern, 0, 0, 0, 0, 0.5);
+ cairo_pattern_add_color_stop_rgba (pattern, 1, 0, 0, 0, 0.0);
+ cairo_rectangle (cr, width - border, border, width, height - 2*border);
+ cairo_clip (cr);
+ cairo_set_source (cr, pattern);
+ cairo_mask (cr, pattern);
+ cairo_pattern_destroy (pattern);
+ cairo_restore (cr);
+
+ cairo_save(cr);
+ pattern = cairo_pattern_create_radial (border, height - border, 0, border, height - border, border);
+ cairo_pattern_add_color_stop_rgba (pattern, 0, 0, 0, 0, 0.5);
+ cairo_pattern_add_color_stop_rgba (pattern, 1, 0, 0, 0, 0.0);
+ cairo_rectangle (cr, 0, height - border, border, border);
+ cairo_clip (cr);
+ cairo_set_source (cr, pattern);
+ cairo_mask (cr, pattern);
+ cairo_pattern_destroy (pattern);
+ cairo_restore(cr);
+
+ cairo_save(cr);
+ pattern = cairo_pattern_create_linear (border, height - border, border, height);
+ cairo_pattern_add_color_stop_rgba (pattern, 0, 0, 0, 0, 0.5);
+ cairo_pattern_add_color_stop_rgba (pattern, 1, 0, 0, 0, 0.0);
+ cairo_rectangle (cr, border, height - border, width - 2*border, border);
+ cairo_clip (cr);
+ cairo_set_source (cr, pattern);
+ cairo_mask (cr, pattern);
+ cairo_pattern_destroy (pattern);
+ cairo_restore (cr);
+
+ cairo_save(cr);
+ pattern = cairo_pattern_create_radial (width - border, height - border, 0, width - border, height - border, border);
+ cairo_pattern_add_color_stop_rgba (pattern, 0, 0, 0, 0, 0.5);
+ cairo_pattern_add_color_stop_rgba (pattern, 1, 0, 0, 0, 0.0);
+ cairo_rectangle (cr, width - border, height - border, border, border);
+ cairo_clip (cr);
+ cairo_set_source (cr, pattern);
+ cairo_mask (cr, pattern);
+ cairo_pattern_destroy (pattern);
+ cairo_restore(cr);
+
+ gdk_cairo_set_source_pixbuf (cr, pixbuf, border, border);
+ cairo_rectangle (cr, border, border, width - 2*border, height - 2*border);
+ cairo_clip(cr);
+ cairo_paint (cr);
+
+ framed = gdk_pixbuf_get_from_surface (surface, 0, 0, width, height);
+
+ cairo_destroy (cr);
+ cairo_surface_destroy (surface);
+
+ return framed;
+}
+
+static void
+ephy_overview_store_set_snapshot_internal (EphyOverviewStore *store,
+ GtkTreeIter *iter,
+ GdkPixbuf *snapshot)
+{
+ GdkPixbuf *framed;
+
+ framed = overview_add_frame (snapshot);
+ gtk_list_store_set (GTK_LIST_STORE (store), iter,
+ EPHY_OVERVIEW_STORE_SNAPSHOT, framed,
+ -1);
+ g_object_unref (framed);
+}
+
+static void
+history_service_get_url_for_saving (EphyHistoryService *service,
+ gboolean success,
+ EphyHistoryURL *url,
+ GdkPixbuf *pixbuf)
+{
+ EphySnapshotService *snapshot_service;
+ int timestamp;
+
+ snapshot_service = ephy_snapshot_service_get_default ();
+ timestamp = success ? (url->visit_count / 5) : 0;
+
+ ephy_snapshot_service_save_snapshot_async (snapshot_service,
+ pixbuf, url->url, timestamp,
+ NULL, NULL, NULL);
+ g_object_unref (pixbuf);
+}
+
+void
+ephy_overview_store_set_snapshot (EphyOverviewStore *store,
+ GtkTreeIter *iter,
+ cairo_surface_t *snapshot)
+{
+ GdkPixbuf *pixbuf;
+ char *url;
+
+ pixbuf = ephy_snapshot_service_crop_snapshot (snapshot);
+ ephy_overview_store_set_snapshot_internal (store, iter, pixbuf);
+ gtk_tree_model_get (GTK_TREE_MODEL (store), iter,
+ EPHY_OVERVIEW_STORE_URI, &url,
+ -1);
+ ephy_history_service_get_url (store->priv->history_service, url,
+ NULL, (EphyHistoryJobCallback) history_service_get_url_for_saving,
+ pixbuf);
+}
+
+static void
+on_snapshot_retrieved_cb (GObject *object,
+ GAsyncResult *res,
+ PeekContext *ctx)
+{
+ GtkTreeModel *model;
+ GtkTreePath *path;
+ GtkTreeIter iter;
+ GdkPixbuf *snapshot;
+ GError *error = NULL;
+
+ snapshot = ephy_snapshot_service_get_snapshot_finish (EPHY_SNAPSHOT_SERVICE (object),
+ res, &error);
+
+ if (error) {
+ g_warning ("Error retrieving snapshot: %s\n", error->message);
+ g_error_free (error);
+ error = NULL;
+ } else {
+ model = gtk_tree_row_reference_get_model (ctx->ref);
+ path = gtk_tree_row_reference_get_path (ctx->ref);
+ gtk_tree_model_get_iter (model, &iter, path);
+ gtk_tree_path_free (path);
+ if (snapshot) {
+ ephy_overview_store_set_snapshot_internal (EPHY_OVERVIEW_STORE (model),
+ &iter, snapshot);
+ g_object_unref (snapshot);
+
+ }
+ gtk_list_store_set (GTK_LIST_STORE (model), &iter,
+ EPHY_OVERVIEW_STORE_SNAPSHOT_CANCELLABLE, NULL,
+ -1);
+ }
+
+ peek_context_free (ctx);
+}
+
+static void
+history_service_url_cb (gpointer service,
+ gboolean success,
+ EphyHistoryURL *url,
+ PeekContext *ctx)
+{
+ EphySnapshotService *snapshot_service;
+ int timestamp;
+
+ snapshot_service = ephy_snapshot_service_get_default ();
+
+ /* This is a bit of an abuse of the semantics of the mtime
+ paramenter. Since the thumbnailing backend only takes the exact
+ mtime of the thumbnailed file, we will use the visit count to
+ generate a fake timestamp that will be increased every fifth
+ visit. This way, we'll update the thumbnail every other fifth
+ visit. */
+ timestamp = success ? (url->visit_count / 5) : 0;
+
+ ephy_snapshot_service_get_snapshot_async (snapshot_service,
+ ctx->webview, ctx->url, timestamp, ctx->cancellable,
+ (GAsyncReadyCallback) on_snapshot_retrieved_cb,
+ ctx);
+ ephy_history_url_free (url);
+}
+
+void
+ephy_overview_store_peek_snapshot (EphyOverviewStore *self,
+ WebKitWebView *webview,
+ GtkTreeIter *iter)
+{
+ char *url;
+ GtkTreePath *path;
+ PeekContext *ctx;
+ GCancellable *cancellable;
+
+ gtk_tree_model_get (GTK_TREE_MODEL (self), iter,
+ EPHY_OVERVIEW_STORE_URI, &url,
+ EPHY_OVERVIEW_STORE_SNAPSHOT_CANCELLABLE, &cancellable,
+ -1);
+
+ if (cancellable) {
+ g_cancellable_cancel (cancellable);
+ g_object_unref (cancellable);
+ }
+
+ gtk_list_store_set (GTK_LIST_STORE (self), iter,
+ EPHY_OVERVIEW_STORE_SNAPSHOT,
+ self->priv->default_icon,
+ -1);
+
+ if (url == NULL || g_strcmp0 (url, "about:blank") == 0) {
+ gtk_list_store_set (GTK_LIST_STORE (self), iter,
+ EPHY_OVERVIEW_STORE_SNAPSHOT_CANCELLABLE,
+ NULL, -1);
+ return;
+ }
+
+ cancellable = g_cancellable_new ();
+ gtk_list_store_set (GTK_LIST_STORE (self), iter,
+ EPHY_OVERVIEW_STORE_SNAPSHOT_CANCELLABLE,
+ cancellable, -1);
+
+ ctx = g_slice_new (PeekContext);
+ path = gtk_tree_model_get_path (GTK_TREE_MODEL (self), iter);
+ ctx->ref = gtk_tree_row_reference_new (GTK_TREE_MODEL (self), path);
+ ctx->url = url;
+ ctx->webview = webview ? g_object_ref (webview) : NULL;
+ ctx->cancellable = cancellable;
+ ephy_history_service_get_url (self->priv->history_service,
+ url, NULL, (EphyHistoryJobCallback)history_service_url_cb,
+ ctx);
+ gtk_tree_path_free (path);
+}
+
+static gboolean
+set_default_icon_helper (GtkTreeModel *model,
+ GtkTreePath *path,
+ GtkTreeIter *iter,
+ GdkPixbuf *new_default_icon)
+{
+ EphyOverviewStorePrivate *priv;
+ GdkPixbuf *current_pixbuf;
+
+ priv = EPHY_OVERVIEW_STORE (model)->priv;
+
+ gtk_tree_model_get (model, iter,
+ EPHY_OVERVIEW_STORE_SNAPSHOT, &current_pixbuf,
+ -1);
+ if (current_pixbuf == priv->default_icon ||
+ current_pixbuf == NULL)
+ gtk_list_store_set (GTK_LIST_STORE (model), iter,
+ EPHY_OVERVIEW_STORE_SNAPSHOT, new_default_icon,
+ -1);
+ g_object_unref (current_pixbuf);
+
+ return FALSE;
+}
+
+void
+ephy_overview_store_set_default_icon (EphyOverviewStore *store,
+ GdkPixbuf *default_icon)
+{
+ if (store->priv->default_icon == default_icon)
+ return;
+
+ if (store->priv->default_icon)
+ g_object_unref (store->priv->default_icon);
+
+ store->priv->default_icon = g_object_ref (default_icon);
+
+ gtk_tree_model_foreach (GTK_TREE_MODEL (store),
+ (GtkTreeModelForeachFunc) set_default_icon_helper,
+ NULL);
+
+ g_object_notify (G_OBJECT (store), "default-icon");
+}
+
+gboolean
+ephy_overview_store_needs_snapshot (EphyOverviewStore *store,
+ GtkTreeIter *iter)
+{
+ GdkPixbuf *icon;
+ GCancellable *cancellable;
+ gboolean needs_snapshot;
+
+ g_return_val_if_fail (EPHY_IS_OVERVIEW_STORE (store), FALSE);
+ g_return_val_if_fail (iter != NULL, FALSE);
+
+ gtk_tree_model_get (GTK_TREE_MODEL (store), iter,
+ EPHY_OVERVIEW_STORE_SNAPSHOT, &icon,
+ EPHY_OVERVIEW_STORE_SNAPSHOT_CANCELLABLE, &cancellable,
+ -1);
+
+ /* If the thumbnail is the default icon and there is no cancellable
+ in the row, then this row needs a snapshot. */
+ needs_snapshot = (icon == store->priv->default_icon && cancellable == NULL);
+
+ if (icon)
+ g_object_unref (icon);
+ if (cancellable)
+ g_object_unref (cancellable);
+
+ return needs_snapshot;
+}
+
+gboolean
+ephy_overview_store_remove (EphyOverviewStore *store,
+ GtkTreeIter *iter)
+{
+ GCancellable *cancellable;
+
+ g_return_val_if_fail (EPHY_IS_OVERVIEW_STORE (store), FALSE);
+
+ gtk_tree_model_get (GTK_TREE_MODEL (store), iter,
+ EPHY_OVERVIEW_STORE_SNAPSHOT_CANCELLABLE,
+ &cancellable,
+ -1);
+ if (cancellable) {
+ g_cancellable_cancel (cancellable);
+ g_object_unref (cancellable);
+ }
+
+ return gtk_list_store_remove (GTK_LIST_STORE (store), iter);
+}
+
+gboolean
+ephy_overview_store_find_url (EphyOverviewStore *store,
+ const char *url,
+ GtkTreeIter *iter)
+{
+ gboolean valid, found = FALSE;
+ char *row_url;
+
+ g_return_val_if_fail (EPHY_IS_OVERVIEW_STORE (store), FALSE);
+ g_return_val_if_fail (url != NULL, FALSE);
+
+ valid = gtk_tree_model_get_iter_first (GTK_TREE_MODEL (store), iter);
+
+ while (valid) {
+ gtk_tree_model_get (GTK_TREE_MODEL (store), iter,
+ EPHY_OVERVIEW_STORE_URI, &row_url,
+ -1);
+
+ found = g_strcmp0 (row_url, url) == 0;
+ g_free (row_url);
+ if (found)
+ break;
+
+ valid = gtk_tree_model_iter_next (GTK_TREE_MODEL (store), iter);
+ }
+
+ return found;
+}
diff --git a/lib/widgets/ephy-overview-store.h b/lib/widgets/ephy-overview-store.h
new file mode 100644
index 000000000..b618bb914
--- /dev/null
+++ b/lib/widgets/ephy-overview-store.h
@@ -0,0 +1,94 @@
+/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
+/*
+ * Copyright © 2012 Igalia S.L.
+ *
+ * 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
+ * the Free Software Foundation; either version 2, or (at your option)
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ *
+ */
+
+#ifndef _EPHY_OVERVIEW_STORE_H
+#define _EPHY_OVERVIEW_STORE_H
+
+#include <gtk/gtk.h>
+#ifdef HAVE_WEBKIT2
+#include <webkit2/webkit2.h>
+#else
+#include <webkit/webkit.h>
+#endif
+#include "gd-main-view.h"
+
+G_BEGIN_DECLS
+
+#define EPHY_TYPE_OVERVIEW_STORE (ephy_overview_store_get_type())
+#define EPHY_OVERVIEW_STORE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), EPHY_TYPE_OVERVIEW_STORE, EphyOverviewStore))
+#define EPHY_OVERVIEW_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), EPHY_TYPE_OVERVIEW_STORE, EphyOverviewStoreClass))
+#define EPHY_IS_OVERVIEW_STORE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), EPHY_TYPE_OVERVIEW_STORE))
+#define EPHY_IS_OVERVIEW_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), EPHY_TYPE_OVERVIEW_STORE))
+#define EPHY_OVERVIEW_STORE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), EPHY_TYPE_OVERVIEW_STORE, EphyOverviewStoreClass))
+
+typedef struct _EphyOverviewStore EphyOverviewStore;
+typedef struct _EphyOverviewStoreClass EphyOverviewStoreClass;
+typedef struct _EphyOverviewStorePrivate EphyOverviewStorePrivate;
+
+struct _EphyOverviewStore
+{
+ GtkListStore parent;
+
+ EphyOverviewStorePrivate *priv;
+};
+
+struct _EphyOverviewStoreClass
+{
+ GtkListStoreClass parent_class;
+};
+
+enum {
+ EPHY_OVERVIEW_STORE_ID = GD_MAIN_COLUMN_ID,
+ EPHY_OVERVIEW_STORE_URI = GD_MAIN_COLUMN_URI,
+ EPHY_OVERVIEW_STORE_TITLE = GD_MAIN_COLUMN_TITLE,
+ EPHY_OVERVIEW_STORE_AUTHOR = GD_MAIN_COLUMN_AUTHOR,
+ EPHY_OVERVIEW_STORE_SNAPSHOT = GD_MAIN_COLUMN_ICON,
+ EPHY_OVERVIEW_STORE_LAST_VISIT = GD_MAIN_COLUMN_MTIME,
+ EPHY_OVERVIEW_STORE_SELECTED = GD_MAIN_COLUMN_SELECTED,
+ EPHY_OVERVIEW_STORE_SNAPSHOT_CANCELLABLE,
+ EPHY_OVERVIEW_STORE_NCOLS
+};
+
+GType ephy_overview_store_get_type (void) G_GNUC_CONST;
+
+void ephy_overview_store_peek_snapshot (EphyOverviewStore *self,
+ WebKitWebView *webview,
+ GtkTreeIter *iter);
+
+void ephy_overview_store_set_default_icon (EphyOverviewStore *store,
+ GdkPixbuf *default_icon);
+
+gboolean ephy_overview_store_needs_snapshot (EphyOverviewStore *store,
+ GtkTreeIter *iter);
+
+gboolean ephy_overview_store_remove (EphyOverviewStore *store,
+ GtkTreeIter *iter);
+
+gboolean ephy_overview_store_find_url (EphyOverviewStore *store,
+ const char *url,
+ GtkTreeIter *iter);
+
+void ephy_overview_store_set_snapshot (EphyOverviewStore *store,
+ GtkTreeIter *iter,
+ cairo_surface_t *snapshot);
+
+G_END_DECLS
+
+#endif /* _EPHY_OVERVIEW_STORE_H */