evolution-data-server r9475 - in trunk: docs/reference/libedataserverui/tmpl libedataserverui
- From: mbarnes svn gnome org
- To: svn-commits-list gnome org
- Subject: evolution-data-server r9475 - in trunk: docs/reference/libedataserverui/tmpl libedataserverui
- Date: Wed, 3 Sep 2008 14:19:35 +0000 (UTC)
Author: mbarnes
Date: Wed Sep 3 14:19:35 2008
New Revision: 9475
URL: http://svn.gnome.org/viewvc/evolution-data-server?rev=9475&view=rev
Log:
2008-09-03 Matthew Barnes <mbarnes redhat com>
* libedataserverui/e-source-selector.c:
Make ESourceSelector subclassable by adding a "source-list"
constructor property.
Modified:
trunk/docs/reference/libedataserverui/tmpl/e-source-selector.sgml
trunk/libedataserverui/ChangeLog
trunk/libedataserverui/e-source-selector.c
Modified: trunk/docs/reference/libedataserverui/tmpl/e-source-selector.sgml
==============================================================================
--- trunk/docs/reference/libedataserverui/tmpl/e-source-selector.sgml (original)
+++ trunk/docs/reference/libedataserverui/tmpl/e-source-selector.sgml Wed Sep 3 14:19:35 2008
@@ -47,6 +47,11 @@
@esourceselector: the object which received the signal.
+<!-- ##### ARG ESourceSelector:source-list ##### -->
+<para>
+
+</para>
+
<!-- ##### FUNCTION e_source_selector_new ##### -->
<para>
Modified: trunk/libedataserverui/e-source-selector.c
==============================================================================
--- trunk/libedataserverui/e-source-selector.c (original)
+++ trunk/libedataserverui/e-source-selector.c Wed Sep 3 14:19:35 2008
@@ -30,6 +30,10 @@
#include "e-data-server-ui-marshal.h"
#include "e-source-selector.h"
+#define E_SOURCE_SELECTOR_GET_PRIVATE(obj) \
+ (G_TYPE_INSTANCE_GET_PRIVATE \
+ ((obj), E_TYPE_SOURCE_SELECTOR, ESourceSelectorPrivate))
+
struct _ESourceSelectorPrivate {
ESourceList *list;
@@ -56,6 +60,11 @@
} ESourceSelectorRebuildData;
enum {
+ PROP_0,
+ PROP_SOURCE_LIST
+};
+
+enum {
SELECTION_CHANGED,
PRIMARY_SELECTION_CHANGED,
POPUP_EVENT,
@@ -388,15 +397,6 @@
selector);
}
-static void
-setup_model (ESourceSelector *selector)
-{
- rebuild_model (selector);
-
- g_signal_connect_object (selector->priv->list, "changed", G_CALLBACK (list_changed_callback), G_OBJECT (selector), 0);
-}
-
-
/* Data functions for rendering the model. */
static void
@@ -711,15 +711,65 @@
/* GObject methods. */
static void
-e_source_selector_dispose (GObject *object)
+source_selector_set_source_list (ESourceSelector *selector,
+ ESourceList *source_list)
{
- ESourceSelectorPrivate *priv = E_SOURCE_SELECTOR (object)->priv;
+ g_return_if_fail (E_IS_SOURCE_LIST (source_list));
+ g_return_if_fail (selector->priv->list == NULL);
+
+ selector->priv->list = g_object_ref (source_list);
+
+ rebuild_model (selector);
+
+ g_signal_connect_object (
+ source_list, "changed",
+ G_CALLBACK (list_changed_callback),
+ G_OBJECT (selector), 0);
- if (priv->selected_sources != NULL) {
- g_hash_table_destroy (priv->selected_sources);
- priv->selected_sources = NULL;
+ gtk_tree_view_expand_all (GTK_TREE_VIEW (selector));
+}
+
+static void
+source_selector_set_property (GObject *object,
+ guint property_id,
+ const GValue *value,
+ GParamSpec *pspec)
+{
+ switch (property_id) {
+ case PROP_SOURCE_LIST:
+ source_selector_set_source_list (
+ E_SOURCE_SELECTOR (object),
+ g_value_get_object (value));
+ return;
}
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+}
+
+static void
+source_selector_get_property (GObject *object,
+ guint property_id,
+ GValue *value,
+ GParamSpec *pspec)
+{
+ switch (property_id) {
+ case PROP_SOURCE_LIST:
+ g_value_set_object (
+ value, e_source_selector_get_source_list (
+ E_SOURCE_SELECTOR (object)));
+ return;
+ }
+
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+}
+
+static void
+source_selector_dispose (GObject *object)
+{
+ ESourceSelectorPrivate *priv = E_SOURCE_SELECTOR (object)->priv;
+
+ g_hash_table_remove_all (priv->selected_sources);
+
if (priv->rebuild_model_idle_id != 0) {
g_source_remove (priv->rebuild_model_idle_id);
priv->rebuild_model_idle_id = 0;
@@ -737,17 +787,19 @@
clear_saved_primary_selection (E_SOURCE_SELECTOR (object));
- (* G_OBJECT_CLASS (e_source_selector_parent_class)->dispose) (object);
+ /* Chain up to parent's dispose() method. */
+ G_OBJECT_CLASS (e_source_selector_parent_class)->dispose (object);
}
static void
-e_source_selector_finalize (GObject *object)
+source_selector_finalize (GObject *object)
{
ESourceSelectorPrivate *priv = E_SOURCE_SELECTOR (object)->priv;
- g_free (priv);
+ g_hash_table_destroy (priv->selected_sources);
- (* G_OBJECT_CLASS (e_source_selector_parent_class)->finalize) (object);
+ /* Chain up to parent's finalize() method. */
+ G_OBJECT_CLASS (e_source_selector_parent_class)->finalize (object);
}
@@ -765,13 +817,30 @@
static void
e_source_selector_class_init (ESourceSelectorClass *class)
{
- GObjectClass *object_class = G_OBJECT_CLASS (class);
- GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (class);
+ GObjectClass *object_class;
+ GtkWidgetClass *widget_class;
+
+ g_type_class_add_private (class, sizeof (ESourceSelectorPrivate));
- object_class->dispose = e_source_selector_dispose;
- object_class->finalize = e_source_selector_finalize;
+ object_class = G_OBJECT_CLASS (class);
+ object_class->set_property = source_selector_set_property;
+ object_class->get_property = source_selector_get_property;
+ object_class->dispose = source_selector_dispose;
+ object_class->finalize = source_selector_finalize;
+
+ widget_class = GTK_WIDGET_CLASS (class);
widget_class->popup_menu = selector_popup_menu;
+ g_object_class_install_property (
+ object_class,
+ PROP_SOURCE_LIST,
+ g_param_spec_object (
+ "source-list",
+ NULL,
+ NULL,
+ E_TYPE_SOURCE_LIST,
+ G_PARAM_READWRITE |
+ G_PARAM_CONSTRUCT_ONLY));
signals[SELECTION_CHANGED] =
g_signal_new ("selection_changed",
@@ -838,13 +907,16 @@
GtkTreeViewColumn *column;
GtkCellRenderer *cell_renderer;
GtkTreeSelection *selection;
+ GtkTreeView *tree_view;
+
+ selector->priv = E_SOURCE_SELECTOR_GET_PRIVATE (selector);
+ priv = selector->priv;
- priv = g_new0 (ESourceSelectorPrivate, 1);
- selector->priv = priv;
+ tree_view = GTK_TREE_VIEW (selector);
- gtk_tree_view_set_search_column (GTK_TREE_VIEW (selector), 0);
- gtk_tree_view_set_search_equal_func (GTK_TREE_VIEW (selector), group_search_function, NULL, NULL);
- gtk_tree_view_set_enable_search (GTK_TREE_VIEW (selector), TRUE);
+ gtk_tree_view_set_search_column (tree_view, 0);
+ gtk_tree_view_set_search_equal_func (tree_view, group_search_function, NULL, NULL);
+ gtk_tree_view_set_enable_search (tree_view, TRUE);
g_signal_connect (G_OBJECT (selector), "button_press_event",
G_CALLBACK (selector_button_press_event), selector);
@@ -856,10 +928,10 @@
priv->selected_sources = create_selected_sources_hash ();
priv->tree_store = gtk_tree_store_new (1, G_TYPE_OBJECT);
- gtk_tree_view_set_model (GTK_TREE_VIEW (selector), GTK_TREE_MODEL (priv->tree_store));
+ gtk_tree_view_set_model (tree_view, GTK_TREE_MODEL (priv->tree_store));
column = gtk_tree_view_column_new ();
- gtk_tree_view_append_column (GTK_TREE_VIEW (selector), column);
+ gtk_tree_view_append_column (tree_view, column);
cell_renderer = gtk_cell_renderer_pixbuf_new ();
g_object_set (G_OBJECT (cell_renderer), "mode", GTK_CELL_RENDERER_MODE_ACTIVATABLE, NULL);
@@ -876,11 +948,11 @@
gtk_tree_view_column_pack_start (column, cell_renderer, TRUE);
gtk_tree_view_column_set_cell_data_func (column, cell_renderer, (GtkTreeCellDataFunc) text_cell_data_func, selector, NULL);
- selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (selector));
+ selection = gtk_tree_view_get_selection (tree_view);
gtk_tree_selection_set_select_function (selection, (GtkTreeSelectionFunc) selection_func, selector, NULL);
g_signal_connect_object (selection, "changed", G_CALLBACK (selection_changed_callback), G_OBJECT (selector), 0);
- gtk_tree_view_set_headers_visible (GTK_TREE_VIEW (selector), FALSE);
+ gtk_tree_view_set_headers_visible (tree_view, FALSE);
g_signal_connect (G_OBJECT (selector), "test-collapse-row", G_CALLBACK (test_collapse_row_callback), selector);
g_signal_connect (G_OBJECT (selector), "row-expanded", G_CALLBACK (row_expanded_callback), selector);
@@ -901,20 +973,10 @@
GtkWidget *
e_source_selector_new (ESourceList *list)
{
- ESourceSelector *selector;
-
g_return_val_if_fail (E_IS_SOURCE_LIST (list), NULL);
- selector = g_object_new (e_source_selector_get_type (), NULL);
-
- selector->priv->list = list;
- g_object_ref (list);
-
- setup_model (selector);
-
- gtk_tree_view_expand_all (GTK_TREE_VIEW (selector));
-
- return GTK_WIDGET (selector);
+ return g_object_new (
+ E_TYPE_SOURCE_SELECTOR, "source-list", list, NULL);
}
/**
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]