diff options
-rw-r--r-- | embed/Makefile.am | 10 | ||||
-rw-r--r-- | embed/ephy-history-store.h | 66 | ||||
-rw-r--r-- | embed/ephy-hosts-view.c | 165 | ||||
-rw-r--r-- | lib/widgets/Makefile.am | 11 | ||||
-rw-r--r-- | lib/widgets/ephy-history-view.c (renamed from embed/ephy-history-view.c) | 75 | ||||
-rw-r--r-- | lib/widgets/ephy-history-view.h (renamed from embed/ephy-history-view.h) | 0 | ||||
-rw-r--r-- | lib/widgets/ephy-hosts-store.c (renamed from embed/ephy-hosts-store.c) | 3 | ||||
-rw-r--r-- | lib/widgets/ephy-hosts-store.h (renamed from embed/ephy-hosts-store.h) | 0 | ||||
-rw-r--r-- | lib/widgets/ephy-hosts-view.c | 55 | ||||
-rw-r--r-- | lib/widgets/ephy-hosts-view.h (renamed from embed/ephy-hosts-view.h) | 8 | ||||
-rw-r--r-- | lib/widgets/ephy-urls-store.c (renamed from embed/ephy-history-store.c) | 48 | ||||
-rw-r--r-- | lib/widgets/ephy-urls-store.h | 66 | ||||
-rw-r--r-- | lib/widgets/ephy-urls-view.c | 96 | ||||
-rw-r--r-- | lib/widgets/ephy-urls-view.h | 56 |
14 files changed, 323 insertions, 336 deletions
diff --git a/embed/Makefile.am b/embed/Makefile.am index 30f44c379..fee25a9c1 100644 --- a/embed/Makefile.am +++ b/embed/Makefile.am @@ -26,11 +26,7 @@ INST_H_FILES = \ ephy-embed-shell.h \ ephy-embed-utils.h \ ephy-history.h \ - ephy-history-store.h \ - ephy-history-view.h \ - ephy-permission-manager.h \ - ephy-hosts-store.h \ - ephy-hosts-view.h \ + ephy-permission-manager.h \ ephy-web-view.h @@ -52,13 +48,9 @@ libephyembed_la_SOURCES = \ ephy-encodings.c \ ephy-favicon-cache.c \ ephy-history.c \ - ephy-history-store.c \ - ephy-history-view.c \ ephy-permission-manager.c \ ephy-request-about.c \ ephy-embed-prefs.c \ - ephy-hosts-store.c \ - ephy-hosts-view.c \ ephy-web-app-utils.c \ ephy-web-view.c \ $(INST_H_FILES) \ diff --git a/embed/ephy-history-store.h b/embed/ephy-history-store.h deleted file mode 100644 index f5b5e702d..000000000 --- a/embed/ephy-history-store.h +++ /dev/null @@ -1,66 +0,0 @@ -/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2; -*- */ -/* vim: set sw=2 ts=2 sts=2 et: */ -/* - * Copyright © 2011, 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_HISTORY_STORE_H -#define _EPHY_HISTORY_STORE_H - -#include "ephy-history-types.h" - -#include <gtk/gtk.h> - -G_BEGIN_DECLS - -#define EPHY_TYPE_HISTORY_STORE (ephy_history_store_get_type()) -#define EPHY_HISTORY_STORE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), EPHY_TYPE_HISTORY_STORE, EphyHistoryStore)) -#define EPHY_HISTORY_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), EPHY_TYPE_HISTORY_STORE, EphyHistoryStoreClass)) -#define EPHY_IS_HISTORY_STORE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), EPHY_TYPE_HISTORY_STORE)) -#define EPHY_IS_HISTORY_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), EPHY_TYPE_HISTORY_STORE)) -#define EPHY_HISTORY_STORE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), EPHY_TYPE_HISTORY_STORE, EphyHistoryStoreClass)) - -typedef struct _EphyHistoryStore EphyHistoryStore; -typedef struct _EphyHistoryStoreClass EphyHistoryStoreClass; -typedef struct _EphyHistoryStorePrivate EphyHistoryStorePrivate; - -typedef enum { - EPHY_HISTORY_STORE_COLUMN_TITLE = 0, - EPHY_HISTORY_STORE_COLUMN_ADDRESS, - EPHY_HISTORY_STORE_COLUMN_DATE, - EPHY_HISTORY_STORE_N_COLUMNS -} EphyHistoryStoreColumn; - -struct _EphyHistoryStore { - GtkListStore parent; -}; - -struct _EphyHistoryStoreClass { - GtkListStoreClass parent_class; -}; - -GType ephy_history_store_get_type (void) G_GNUC_CONST; -EphyHistoryStore* ephy_history_store_new (void); -void ephy_history_store_add_urls (EphyHistoryStore *store, GList *urls); -void ephy_history_store_add_url (EphyHistoryStore *store, EphyHistoryURL *url); -void ephy_history_store_add_visits (EphyHistoryStore *store, GList *visits); -EphyHistoryURL* ephy_history_store_get_url_from_path (EphyHistoryStore *store, GtkTreePath *path); - -G_END_DECLS - -#endif /* _EPHY_HISTORY_STORE_H */ diff --git a/embed/ephy-hosts-view.c b/embed/ephy-hosts-view.c deleted file mode 100644 index f508c8350..000000000 --- a/embed/ephy-hosts-view.c +++ /dev/null @@ -1,165 +0,0 @@ -/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2; -*- */ -/* vim: set sw=2 ts=2 sts=2 et: */ -/* - * Copyright © 2011, 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-hosts-view.h" - -#include "ephy-gui.h" -#include "ephy-hosts-store.h" - -#include <gtk/gtk.h> -#include <glib/gi18n.h> - -G_DEFINE_TYPE (EphyHostsView, ephy_hosts_view, GTK_TYPE_TREE_VIEW) -static void -ephy_hosts_view_class_init (EphyHostsViewClass *klass) -{ -} - -static gboolean -button_event_modifies_selection (GdkEventButton *event) -{ - return (event->state & (GDK_CONTROL_MASK | GDK_SHIFT_MASK)) != 0; -} - -static gboolean -ephy_hosts_view_button_press_cb (GtkWidget *treeview, - GdkEventButton *event, - EphyHostsView *view) -{ - GtkTreeSelection *selection; - GtkTreePath *path = NULL; - gboolean path_is_selected, call_parent = TRUE; - - if (event->window != gtk_tree_view_get_bin_window (GTK_TREE_VIEW (treeview))) - return GTK_WIDGET_CLASS (ephy_hosts_view_parent_class)->button_press_event (treeview, event); - - selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (treeview)); - if (gtk_tree_view_get_path_at_pos (GTK_TREE_VIEW (treeview), - event->x, - event->y, - &path, - NULL, NULL, NULL)) { - path_is_selected = gtk_tree_selection_path_is_selected (selection, path); - - if (!gtk_widget_is_focus (GTK_WIDGET (treeview))) - gtk_widget_grab_focus (GTK_WIDGET (treeview)); - - if (event->button == 3 && path_is_selected) - call_parent = FALSE; - - if (!button_event_modifies_selection (event) && - event->button == 1 && path_is_selected && - gtk_tree_selection_count_selected_rows (selection) > 1) - call_parent = FALSE; - - if (call_parent) - GTK_WIDGET_CLASS (ephy_hosts_view_parent_class)->button_press_event (treeview, event); - - if (event->button == 3) { - gboolean retval; - - g_signal_emit_by_name (view, "popup_menu", &retval); - } - gtk_tree_path_free (path); - } else - gtk_tree_selection_unselect_all (selection); - - return TRUE; -} - -static void -ephy_hosts_view_init (EphyHostsView *self) -{ - GtkTreeViewColumn *column; - GtkTreeSelection *selection; - - column = gtk_tree_view_column_new_with_attributes (_("Sites"), - gtk_cell_renderer_text_new (), - "text", EPHY_HOSTS_STORE_COLUMN_TITLE, - NULL); - gtk_tree_view_append_column (GTK_TREE_VIEW (self), column); - - selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (self)); - gtk_tree_selection_set_mode (selection, GTK_SELECTION_MULTIPLE); - - g_signal_connect_object (self, "button_press_event", - G_CALLBACK (ephy_hosts_view_button_press_cb), - self, 0); -} - -GtkWidget * -ephy_hosts_view_new (void) -{ - return g_object_new (EPHY_TYPE_HOSTS_VIEW, NULL); -} - -void -ephy_hosts_view_popup (EphyHostsView *view, GtkWidget *menu) -{ - GdkEvent *event; - - event = gtk_get_current_event (); - if (event) - { - if (event->type == GDK_KEY_PRESS) { - GdkEventKey *key = (GdkEventKey *) event; - - gtk_menu_popup (GTK_MENU (menu), NULL, NULL, - ephy_gui_menu_position_tree_selection, - view, 0, key->time); - gtk_menu_shell_select_first (GTK_MENU_SHELL (menu), FALSE); - } else if (event->type == GDK_BUTTON_PRESS) { - GdkEventButton *button = (GdkEventButton *) event; - - gtk_menu_popup (GTK_MENU (menu), NULL, NULL, NULL, - NULL, button->button, button->time); - } - gdk_event_free (event); - } -} - -static void -get_selection (GtkTreeModel *model, - GtkTreePath *path, - GtkTreeIter *iter, - gpointer *data) -{ - EphyHistoryHost *host; - - host = ephy_hosts_store_get_host_from_path (EPHY_HOSTS_STORE (model), path); - *data = g_list_prepend (*data, host); -} - -GList * -ephy_hosts_view_get_selection (EphyHostsView *view) -{ - GtkTreeSelection *selection; - GList *list = NULL; - - selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (view)); - gtk_tree_selection_selected_foreach (selection, - (GtkTreeSelectionForeachFunc) get_selection, - &list); - - return g_list_reverse (list); -} diff --git a/lib/widgets/Makefile.am b/lib/widgets/Makefile.am index f581674f8..9f751e0d8 100644 --- a/lib/widgets/Makefile.am +++ b/lib/widgets/Makefile.am @@ -3,6 +3,12 @@ noinst_LTLIBRARIES = libephywidgets.la libephywidgets_la_SOURCES = \ ephy-download-widget.c \ ephy-download-widget.h \ + ephy-history-view.c \ + ephy-history-view.h \ + ephy-hosts-store.c \ + ephy-hosts-store.h \ + ephy-hosts-view.c \ + ephy-hosts-view.h \ ephy-location-entry.c \ ephy-location-entry.h \ ephy-middle-clickable-button.c \ @@ -15,6 +21,10 @@ libephywidgets_la_SOURCES = \ ephy-tree-model-node.h \ ephy-tree-model-sort.c \ ephy-tree-model-sort.h \ + ephy-urls-store.c \ + ephy-urls-store.h \ + ephy-urls-view.c \ + ephy-urls-view.h \ ephy-zoom-action.h \ ephy-zoom-action.c \ nautilus-floating-bar.c \ @@ -28,6 +38,7 @@ libephywidgets_la_CPPFLAGS = \ -I$(top_srcdir)/lib \ -I$(top_srcdir)/embed \ -I$(top_srcdir)/lib/egg \ + -I$(top_srcdir)/lib/history \ -DSHARE_DIR=\"$(pkgdatadir)\" \ $(AM_CPPFLAGS) diff --git a/embed/ephy-history-view.c b/lib/widgets/ephy-history-view.c index e23a371f7..145f3cafa 100644 --- a/embed/ephy-history-view.c +++ b/lib/widgets/ephy-history-view.c @@ -1,7 +1,7 @@ /* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2; -*- */ /* vim: set sw=2 ts=2 sts=2 et: */ /* - * Copyright © 2011, 2012 Igalia S.L. + * 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 @@ -20,21 +20,15 @@ */ #include "config.h" - #include "ephy-history-view.h" #include "ephy-gui.h" -#include "ephy-history-store.h" #include <glib/gi18n.h> #include <gtk/gtk.h> G_DEFINE_TYPE (EphyHistoryView, ephy_history_view, GTK_TYPE_TREE_VIEW) -static void -ephy_history_view_class_init (EphyHistoryViewClass *klass) -{ -} static gboolean button_event_modifies_selection (GdkEventButton *event) @@ -51,9 +45,8 @@ ephy_history_view_button_press_cb (GtkWidget *treeview, GtkTreePath *path = NULL; gboolean path_is_selected, call_parent = TRUE; - if (event->window != gtk_tree_view_get_bin_window (GTK_TREE_VIEW (treeview))) { + if (event->window != gtk_tree_view_get_bin_window (GTK_TREE_VIEW (treeview))) return GTK_WIDGET_CLASS (ephy_history_view_parent_class)->button_press_event (treeview, event); - } selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (treeview)); if (gtk_tree_view_get_path_at_pos (GTK_TREE_VIEW (treeview), @@ -86,37 +79,19 @@ ephy_history_view_button_press_cb (GtkWidget *treeview, } else gtk_tree_selection_unselect_all (selection); - return TRUE; + return FALSE; +} + +static void +ephy_history_view_class_init (EphyHistoryViewClass *klass) +{ } static void ephy_history_view_init (EphyHistoryView *self) { - GtkTreeViewColumn *column; GtkTreeSelection *selection; - column = gtk_tree_view_column_new_with_attributes (_("Title"), - g_object_new (GTK_TYPE_CELL_RENDERER_TEXT, - "ellipsize-set", TRUE, - "ellipsize", PANGO_ELLIPSIZE_END, NULL), - "text", EPHY_HISTORY_STORE_COLUMN_TITLE, - NULL); - gtk_tree_view_append_column (GTK_TREE_VIEW (self), column); - - column = gtk_tree_view_column_new_with_attributes (_("Address"), - g_object_new (GTK_TYPE_CELL_RENDERER_TEXT, - "ellipsize-set", TRUE, - "ellipsize", PANGO_ELLIPSIZE_END, NULL), - "text", EPHY_HISTORY_STORE_COLUMN_ADDRESS, - NULL); - gtk_tree_view_append_column (GTK_TREE_VIEW (self), column); - - column = gtk_tree_view_column_new_with_attributes (_("Date"), - gtk_cell_renderer_text_new (), - "text", EPHY_HISTORY_STORE_COLUMN_DATE, - NULL); - gtk_tree_view_append_column (GTK_TREE_VIEW (self), column); - selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (self)); gtk_tree_selection_set_mode (selection, GTK_SELECTION_MULTIPLE); @@ -125,18 +100,15 @@ ephy_history_view_init (EphyHistoryView *self) self, 0); } -GtkWidget * -ephy_history_view_new (void) -{ - return g_object_new (EPHY_TYPE_HISTORY_VIEW, NULL); -} - void ephy_history_view_popup (EphyHistoryView *view, GtkWidget *menu) { GdkEvent *event; + g_return_if_fail (EPHY_IS_HISTORY_VIEW (view)); + event = gtk_get_current_event (); + if (event) { if (event->type == GDK_KEY_PRESS) { GdkEventKey *key = (GdkEventKey *) event; @@ -151,32 +123,9 @@ ephy_history_view_popup (EphyHistoryView *view, GtkWidget *menu) gtk_menu_popup (GTK_MENU (menu), NULL, NULL, NULL, NULL, button->button, button->time); } + gdk_event_free (event); } } -static void -get_selection (GtkTreeModel *model, - GtkTreePath *path, - GtkTreeIter *iter, - gpointer *data) -{ - EphyHistoryURL *url; - url = ephy_history_store_get_url_from_path (EPHY_HISTORY_STORE (model), path); - *data = g_list_prepend (*data, url); -} - -GList * -ephy_history_view_get_selection (EphyHistoryView *view) -{ - GtkTreeSelection *selection; - GList *list = NULL; - - selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (view)); - gtk_tree_selection_selected_foreach (selection, - (GtkTreeSelectionForeachFunc) get_selection, - &list); - - return g_list_reverse (list); -} diff --git a/embed/ephy-history-view.h b/lib/widgets/ephy-history-view.h index d6c2d0656..d6c2d0656 100644 --- a/embed/ephy-history-view.h +++ b/lib/widgets/ephy-history-view.h diff --git a/embed/ephy-hosts-store.c b/lib/widgets/ephy-hosts-store.c index ca84f4b72..77d6a9343 100644 --- a/embed/ephy-hosts-store.c +++ b/lib/widgets/ephy-hosts-store.c @@ -20,11 +20,8 @@ */ #include "config.h" - #include "ephy-hosts-store.h" -#include <gtk/gtk.h> - G_DEFINE_TYPE (EphyHostsStore, ephy_hosts_store, GTK_TYPE_LIST_STORE) static void diff --git a/embed/ephy-hosts-store.h b/lib/widgets/ephy-hosts-store.h index 5b61902f3..5b61902f3 100644 --- a/embed/ephy-hosts-store.h +++ b/lib/widgets/ephy-hosts-store.h diff --git a/lib/widgets/ephy-hosts-view.c b/lib/widgets/ephy-hosts-view.c new file mode 100644 index 000000000..7ed6b44da --- /dev/null +++ b/lib/widgets/ephy-hosts-view.c @@ -0,0 +1,55 @@ +/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2; -*- */ +/* vim: set sw=2 ts=2 sts=2 et: */ +/* + * Copyright © 2011, 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-hosts-view.h" + +#include "ephy-gui.h" +#include "ephy-hosts-store.h" + +#include <gtk/gtk.h> +#include <glib/gi18n.h> + +G_DEFINE_TYPE (EphyHostsView, ephy_hosts_view, EPHY_TYPE_HISTORY_VIEW) + +static void +ephy_hosts_view_class_init (EphyHostsViewClass *klass) +{ +} + +static void +ephy_hosts_view_init (EphyHostsView *self) +{ + GtkTreeViewColumn *column; + + column = gtk_tree_view_column_new_with_attributes (_("Sites"), + gtk_cell_renderer_text_new (), + "text", EPHY_HOSTS_STORE_COLUMN_TITLE, + NULL); + gtk_tree_view_append_column (GTK_TREE_VIEW (self), column); +} + +GtkWidget * +ephy_hosts_view_new (void) +{ + return g_object_new (EPHY_TYPE_HOSTS_VIEW, NULL); +} + diff --git a/embed/ephy-hosts-view.h b/lib/widgets/ephy-hosts-view.h index 534903cf5..393ad4e8b 100644 --- a/embed/ephy-hosts-view.h +++ b/lib/widgets/ephy-hosts-view.h @@ -22,6 +22,8 @@ #ifndef _EPHY_HOSTS_VIEW_H #define _EPHY_HOSTS_VIEW_H +#include "ephy-history-view.h" + #include <gtk/gtk.h> G_BEGIN_DECLS @@ -39,18 +41,16 @@ typedef struct _EphyHostsViewPrivate EphyHostsViewPrivate; struct _EphyHostsView { - GtkTreeView parent; + EphyHistoryView parent; }; struct _EphyHostsViewClass { - GtkTreeViewClass parent_class; + EphyHistoryViewClass parent_class; }; GType ephy_hosts_view_get_type (void) G_GNUC_CONST; GtkWidget *ephy_hosts_view_new (void); -void ephy_hosts_view_popup (EphyHostsView *view, GtkWidget *menu); -GList * ephy_hosts_view_get_selection (EphyHostsView *view); G_END_DECLS diff --git a/embed/ephy-history-store.c b/lib/widgets/ephy-urls-store.c index 37ccaaf9c..f859e72cc 100644 --- a/embed/ephy-history-store.c +++ b/lib/widgets/ephy-urls-store.c @@ -20,43 +20,39 @@ */ #include "config.h" - -#include "ephy-history-store.h" - -#include "ephy-history-types.h" +#include "ephy-urls-store.h" #include <gtk/gtk.h> -G_DEFINE_TYPE (EphyHistoryStore, ephy_history_store, GTK_TYPE_LIST_STORE) +G_DEFINE_TYPE (EphyURLsStore, ephy_urls_store, GTK_TYPE_LIST_STORE) static void -ephy_history_store_class_init (EphyHistoryStoreClass *klass) +ephy_urls_store_class_init (EphyURLsStoreClass *klass) { } static void -ephy_history_store_init (EphyHistoryStore *self) +ephy_urls_store_init (EphyURLsStore *self) { - GType types[EPHY_HISTORY_STORE_N_COLUMNS]; + GType types[EPHY_URLS_STORE_N_COLUMNS]; - types[EPHY_HISTORY_STORE_COLUMN_TITLE] = G_TYPE_STRING; - types[EPHY_HISTORY_STORE_COLUMN_ADDRESS] = G_TYPE_STRING; - types[EPHY_HISTORY_STORE_COLUMN_DATE] = G_TYPE_INT; + types[EPHY_URLS_STORE_COLUMN_TITLE] = G_TYPE_STRING; + types[EPHY_URLS_STORE_COLUMN_ADDRESS] = G_TYPE_STRING; + types[EPHY_URLS_STORE_COLUMN_DATE] = G_TYPE_INT; gtk_list_store_set_column_types (GTK_LIST_STORE (self), - EPHY_HISTORY_STORE_N_COLUMNS, + EPHY_URLS_STORE_N_COLUMNS, types); } -EphyHistoryStore * -ephy_history_store_new (void) +EphyURLsStore * +ephy_urls_store_new (void) { - return g_object_new (EPHY_TYPE_HISTORY_STORE, - NULL); + return g_object_new (EPHY_TYPE_URLS_STORE, NULL); } void -ephy_history_store_add_urls (EphyHistoryStore *store, +ephy_urls_store_add_urls (EphyURLsStore *store, GList *urls) { EphyHistoryURL *url; @@ -66,25 +62,25 @@ ephy_history_store_add_urls (EphyHistoryStore *store, url = (EphyHistoryURL *)iter->data; gtk_list_store_insert_with_values (GTK_LIST_STORE (store), NULL, G_MAXINT, - EPHY_HISTORY_STORE_COLUMN_TITLE, url->title, - EPHY_HISTORY_STORE_COLUMN_ADDRESS, url->url, - EPHY_HISTORY_STORE_COLUMN_DATE, url->last_visit_time, + EPHY_URLS_STORE_COLUMN_TITLE, url->title, + EPHY_URLS_STORE_COLUMN_ADDRESS, url->url, + EPHY_URLS_STORE_COLUMN_DATE, url->last_visit_time, -1); } } void -ephy_history_store_add_url (EphyHistoryStore *store, EphyHistoryURL *url) +ephy_urls_store_add_url (EphyURLsStore *store, EphyHistoryURL *url) { GList *urls = NULL; urls = g_list_append (urls, url); - ephy_history_store_add_urls (store, urls); + ephy_urls_store_add_urls (store, urls); g_list_free (urls); } EphyHistoryURL * -ephy_history_store_get_url_from_path (EphyHistoryStore *store, - GtkTreePath *path) +ephy_urls_store_get_url_from_path (EphyURLsStore *store, + GtkTreePath *path) { GtkTreeIter iter; @@ -92,8 +88,8 @@ ephy_history_store_get_url_from_path (EphyHistoryStore *store, gtk_tree_model_get_iter (GTK_TREE_MODEL (store), &iter, path); gtk_tree_model_get (GTK_TREE_MODEL (store), &iter, - EPHY_HISTORY_STORE_COLUMN_TITLE, &url->title, - EPHY_HISTORY_STORE_COLUMN_ADDRESS, &url->url, + EPHY_URLS_STORE_COLUMN_TITLE, &url->title, + EPHY_URLS_STORE_COLUMN_ADDRESS, &url->url, -1); return url; } diff --git a/lib/widgets/ephy-urls-store.h b/lib/widgets/ephy-urls-store.h new file mode 100644 index 000000000..1a0453d8e --- /dev/null +++ b/lib/widgets/ephy-urls-store.h @@ -0,0 +1,66 @@ +/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2; -*- */ +/* vim: set sw=2 ts=2 sts=2 et: */ +/* + * Copyright © 2011, 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_URLS_STORE_H +#define _EPHY_URLS_STORE_H + +#include "ephy-history-types.h" + +#include <gtk/gtk.h> + +G_BEGIN_DECLS + +#define EPHY_TYPE_URLS_STORE (ephy_urls_store_get_type()) +#define EPHY_URLS_STORE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), EPHY_TYPE_URLS_STORE, EphyURLsStore)) +#define EPHY_URLS_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), EPHY_TYPE_URLS_STORE, EphyURLsStoreClass)) +#define EPHY_IS_URLS_STORE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), EPHY_TYPE_URLS_STORE)) +#define EPHY_IS_URLS_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), EPHY_TYPE_URLS_STORE)) +#define EPHY_URLS_STORE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), EPHY_TYPE_URLS_STORE, EphyURLsStoreClass)) + +typedef struct _EphyURLsStore EphyURLsStore; +typedef struct _EphyURLsStoreClass EphyURLsStoreClass; +typedef struct _EphyURLsStorePrivate EphyURLsStorePrivate; + +typedef enum { + EPHY_URLS_STORE_COLUMN_TITLE = 0, + EPHY_URLS_STORE_COLUMN_ADDRESS, + EPHY_URLS_STORE_COLUMN_DATE, + EPHY_URLS_STORE_N_COLUMNS +} EphyURLsStoreColumn; + +struct _EphyURLsStore { + GtkListStore parent; +}; + +struct _EphyURLsStoreClass { + GtkListStoreClass parent_class; +}; + +GType ephy_urls_store_get_type (void) G_GNUC_CONST; +EphyURLsStore* ephy_urls_store_new (void); +void ephy_urls_store_add_urls (EphyURLsStore *store, GList *urls); +void ephy_urls_store_add_url (EphyURLsStore *store, EphyHistoryURL *url); +void ephy_urls_store_add_visits (EphyURLsStore *store, GList *visits); +EphyHistoryURL* ephy_urls_store_get_url_from_path (EphyURLsStore *store, GtkTreePath *path); + +G_END_DECLS + +#endif /* _EPHY_URLS_STORE_H */ diff --git a/lib/widgets/ephy-urls-view.c b/lib/widgets/ephy-urls-view.c new file mode 100644 index 000000000..10a8100ff --- /dev/null +++ b/lib/widgets/ephy-urls-view.c @@ -0,0 +1,96 @@ +/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2; -*- */ +/* vim: set sw=2 ts=2 sts=2 et: */ +/* + * Copyright © 2011, 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-urls-view.h" + +#include "ephy-gui.h" +#include "ephy-urls-store.h" + +#include <glib/gi18n.h> +#include <gtk/gtk.h> + +G_DEFINE_TYPE (EphyURLsView, ephy_urls_view, EPHY_TYPE_HISTORY_VIEW) + +static void +ephy_urls_view_class_init (EphyURLsViewClass *klass) +{ +} + +static void +ephy_urls_view_init (EphyURLsView *self) +{ + GtkTreeViewColumn *column; + + column = gtk_tree_view_column_new_with_attributes (_("Title"), + g_object_new (GTK_TYPE_CELL_RENDERER_TEXT, + "ellipsize-set", TRUE, + "ellipsize", PANGO_ELLIPSIZE_END, NULL), + "text", EPHY_URLS_STORE_COLUMN_TITLE, + NULL); + gtk_tree_view_append_column (GTK_TREE_VIEW (self), column); + + column = gtk_tree_view_column_new_with_attributes (_("Address"), + g_object_new (GTK_TYPE_CELL_RENDERER_TEXT, + "ellipsize-set", TRUE, + "ellipsize", PANGO_ELLIPSIZE_END, NULL), + "text", EPHY_URLS_STORE_COLUMN_ADDRESS, + NULL); + gtk_tree_view_append_column (GTK_TREE_VIEW (self), column); + + column = gtk_tree_view_column_new_with_attributes (_("Date"), + gtk_cell_renderer_text_new (), + "text", EPHY_URLS_STORE_COLUMN_DATE, + NULL); + gtk_tree_view_append_column (GTK_TREE_VIEW (self), column); +} + +GtkWidget * +ephy_urls_view_new (void) +{ + return g_object_new (EPHY_TYPE_URLS_VIEW, NULL); +} + +static void +get_selection (GtkTreeModel *model, + GtkTreePath *path, + GtkTreeIter *iter, + gpointer *data) +{ + EphyHistoryURL *url; + + url = ephy_urls_store_get_url_from_path (EPHY_URLS_STORE (model), path); + *data = g_list_prepend (*data, url); +} + +GList * +ephy_urls_view_get_selection (EphyURLsView *view) +{ + GtkTreeSelection *selection; + GList *list = NULL; + + selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (view)); + gtk_tree_selection_selected_foreach (selection, + (GtkTreeSelectionForeachFunc) get_selection, + &list); + + return g_list_reverse (list); +} diff --git a/lib/widgets/ephy-urls-view.h b/lib/widgets/ephy-urls-view.h new file mode 100644 index 000000000..9bcee2481 --- /dev/null +++ b/lib/widgets/ephy-urls-view.h @@ -0,0 +1,56 @@ +/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2; -*- */ +/* vim: set sw=2 ts=2 sts=2 et: */ +/* + * Copyright © 2011, 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_URLS_VIEW_H +#define _EPHY_URLS_VIEW_H + +#include "ephy-history-view.h" + +#include <gtk/gtk.h> + +G_BEGIN_DECLS + +#define EPHY_TYPE_URLS_VIEW (ephy_urls_view_get_type()) +#define EPHY_URLS_VIEW(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), EPHY_TYPE_URLS_VIEW, EphyURLsView)) +#define EPHY_URLS_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), EPHY_TYPE_URLS_VIEW, EphyURLsViewClass)) +#define EPHY_IS_URLS_VIEW(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), EPHY_TYPE_URLS_VIEW)) +#define EPHY_IS_URLS_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), EPHY_TYPE_URLS_VIEW)) +#define EPHY_URLS_VIEW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), EPHY_TYPE_URLS_VIEW, EphyURLsViewClass)) + +typedef struct _EphyURLsView EphyURLsView; +typedef struct _EphyURLsViewClass EphyURLsViewClass; +typedef struct _EphyURLsViewPrivate EphyURLsViewPrivate; + +struct _EphyURLsView { + EphyHistoryView parent; +}; + +struct _EphyURLsViewClass { + EphyHistoryViewClass parent_class; +}; + +GType ephy_urls_view_get_type (void) G_GNUC_CONST; +GtkWidget * ephy_urls_view_new (void); +GList * ephy_urls_view_get_selection (EphyURLsView *view); + +G_END_DECLS + +#endif /* _EPHY_URLS_VIEW_H */ |