Matthew Barnes 3b4059
--- evolution-data-server-1.10.0/libedataserverui/e-name-selector-dialog.glade.code-cleanup	2007-01-03 05:09:27.000000000 -0500
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/libedataserverui/e-name-selector-dialog.glade	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -118,7 +118,10 @@
Matthew Barnes 3b4059
 		  <property name="yalign">0.5</property>
Matthew Barnes 3b4059
 		  <property name="xpad">0</property>
Matthew Barnes 3b4059
 		  <property name="ypad">0</property>
Matthew Barnes 3b4059
-		  <property name="mnemonic_widget">optionmenu-category</property> 
Matthew Barnes 3b4059
+		  <property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
Matthew Barnes 3b4059
+		  <property name="width_chars">-1</property>
Matthew Barnes 3b4059
+		  <property name="single_line_mode">False</property>
Matthew Barnes 3b4059
+		  <property name="angle">0</property>
Matthew Barnes 3b4059
 		</widget>
Matthew Barnes 3b4059
 		<packing>
Matthew Barnes 3b4059
 		  <property name="left_attach">0</property>
Matthew Barnes 3b4059
@@ -127,23 +130,7 @@
Matthew Barnes 3b4059
 		  <property name="bottom_attach">2</property>
Matthew Barnes 3b4059
 		  <property name="x_options">fill</property>
Matthew Barnes 3b4059
 		  <property name="y_options"></property>
Matthew Barnes 3b4059
-	        </packing>
Matthew Barnes 3b4059
-	      </child>
Matthew Barnes 3b4059
-	
Matthew Barnes 3b4059
-	      <child>
Matthew Barnes 3b4059
-		<widget class="GtkOptionMenu" id="optionmenu-category">
Matthew Barnes 3b4059
-		  <property name="visible">True</property>
Matthew Barnes 3b4059
-		  <property name="can_focus">True</property>
Matthew Barnes 3b4059
-		  <property name="history">0</property>
Matthew Barnes 3b4059
-	        </widget>
Matthew Barnes 3b4059
-	        <packing>
Matthew Barnes 3b4059
-  	          <property name="left_attach">1</property>
Matthew Barnes 3b4059
-	     	  <property name="right_attach">2</property>
Matthew Barnes 3b4059
-	          <property name="top_attach">1</property>
Matthew Barnes 3b4059
-	          <property name="bottom_attach">2</property>
Matthew Barnes 3b4059
-	          <property name="x_options">fill</property>
Matthew Barnes 3b4059
-	          <property name="y_options">fill</property>
Matthew Barnes 3b4059
-	        </packing>
Matthew Barnes 3b4059
+		</packing>
Matthew Barnes 3b4059
 	      </child>
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	      <child>
Matthew Barnes 3b4059
@@ -229,6 +216,23 @@
Matthew Barnes 3b4059
 		  <property name="y_options">fill</property>
Matthew Barnes 3b4059
 		</packing>
Matthew Barnes 3b4059
 	      </child>
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	      <child>
Matthew Barnes 3b4059
+		<widget class="GtkComboBox" id="combobox-category">
Matthew Barnes 3b4059
+		  <property name="visible">True</property>
Matthew Barnes 3b4059
+		  <property name="items" translatable="yes">Any Category</property>
Matthew Barnes 3b4059
+		  <property name="add_tearoffs">False</property>
Matthew Barnes 3b4059
+		  <property name="focus_on_click">True</property>
Matthew Barnes 3b4059
+		</widget>
Matthew Barnes 3b4059
+		<packing>
Matthew Barnes 3b4059
+		  <property name="left_attach">1</property>
Matthew Barnes 3b4059
+		  <property name="right_attach">2</property>
Matthew Barnes 3b4059
+		  <property name="top_attach">1</property>
Matthew Barnes 3b4059
+		  <property name="bottom_attach">2</property>
Matthew Barnes 3b4059
+		  <property name="x_options">fill</property>
Matthew Barnes 3b4059
+		  <property name="y_options">fill</property>
Matthew Barnes 3b4059
+		</packing>
Matthew Barnes 3b4059
+	      </child>
Matthew Barnes 3b4059
 	    </widget>
Matthew Barnes 3b4059
 	    <packing>
Matthew Barnes 3b4059
 	      <property name="padding">0</property>
Matthew Barnes 3b4059
--- evolution-data-server-1.10.0/libedataserverui/e-name-selector-list.c.code-cleanup	2007-01-03 05:09:27.000000000 -0500
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/libedataserverui/e-name-selector-list.c	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -447,7 +447,7 @@
Matthew Barnes 3b4059
 		
Matthew Barnes 3b4059
 			if (len > 1) {
Matthew Barnes 3b4059
 				menu_item = gtk_radio_menu_item_new_with_label (group, email);
Matthew Barnes 3b4059
-				group = gtk_radio_menu_item_group (GTK_RADIO_MENU_ITEM (menu_item));
Matthew Barnes 3b4059
+				group = gtk_radio_menu_item_get_group (GTK_RADIO_MENU_ITEM (menu_item));
Matthew Barnes 3b4059
 				g_signal_connect (menu_item, "toggled", G_CALLBACK (destination_set_email), destination);
Matthew Barnes 3b4059
 			} else {
Matthew Barnes 3b4059
 				menu_item = gtk_menu_item_new_with_label (email);			
Matthew Barnes 3b4059
--- evolution-data-server-1.10.0/libedataserverui/e-name-selector-entry.c.code-cleanup	2007-01-03 05:09:27.000000000 -0500
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/libedataserverui/e-name-selector-entry.c	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -2136,7 +2136,7 @@
Matthew Barnes 3b4059
 		
Matthew Barnes 3b4059
 			if (len > 1) {
Matthew Barnes 3b4059
 				menu_item = gtk_radio_menu_item_new_with_label (group, email);
Matthew Barnes 3b4059
-				group = gtk_radio_menu_item_group (GTK_RADIO_MENU_ITEM (menu_item));
Matthew Barnes 3b4059
+				group = gtk_radio_menu_item_get_group (GTK_RADIO_MENU_ITEM (menu_item));
Matthew Barnes 3b4059
 				g_signal_connect (menu_item, "toggled", G_CALLBACK (destination_set_email), destination);
Matthew Barnes 3b4059
 			} else {
Matthew Barnes 3b4059
 				menu_item = gtk_menu_item_new_with_label (email);			
Matthew Barnes 3b4059
--- evolution-data-server-1.10.0/libedataserverui/test-source-option-menu.c.code-cleanup	2007-01-03 05:09:27.000000000 -0500
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/libedataserverui/test-source-option-menu.c	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -1,5 +1,5 @@
Matthew Barnes 3b4059
 /* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
Matthew Barnes 3b4059
-/* test-source-option-menu.c - Test for ESourceOptionMenu.
Matthew Barnes 3b4059
+/* test-source-combo-box.c - Test for ESourceComboBox.
Matthew Barnes 3b4059
  *
Matthew Barnes 3b4059
  * Copyright (C) 2003 Novell, Inc.
Matthew Barnes 3b4059
  *
Matthew Barnes 3b4059
@@ -24,17 +24,17 @@
Matthew Barnes 3b4059
 #include <config.h>
Matthew Barnes 3b4059
 #endif
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
-
Matthew Barnes 3b4059
-#include "e-source-option-menu.h"
Matthew Barnes 3b4059
+#include "e-source-combo-box.h"
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 #include <gtk/gtkwindow.h>
Matthew Barnes 3b4059
 #include <gtk/gtkmain.h>
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 static void
Matthew Barnes 3b4059
-source_selected_callback (ESourceOptionMenu *menu,
Matthew Barnes 3b4059
-			  ESource *source,
Matthew Barnes 3b4059
-			  void *unused_data)
Matthew Barnes 3b4059
+source_changed_cb (ESourceComboBox *combo_box)
Matthew Barnes 3b4059
 {
Matthew Barnes 3b4059
+	ESource *source;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	source = e_source_combo_box_get_active (combo_box);
Matthew Barnes 3b4059
 	g_print ("source selected: \"%s\"\n", e_source_peek_name (source));
Matthew Barnes 3b4059
 }
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
@@ -43,7 +43,7 @@
Matthew Barnes 3b4059
 on_idle_create_widget (const char *gconf_path)
Matthew Barnes 3b4059
 {
Matthew Barnes 3b4059
 	GtkWidget *window;
Matthew Barnes 3b4059
-	GtkWidget *option_menu;
Matthew Barnes 3b4059
+	GtkWidget *combo_box;
Matthew Barnes 3b4059
 	ESourceList *source_list;
Matthew Barnes 3b4059
 	GConfClient *gconf_client;
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
@@ -51,10 +51,12 @@
Matthew Barnes 3b4059
 	source_list = e_source_list_new_for_gconf (gconf_client, gconf_path);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
Matthew Barnes 3b4059
-	option_menu = e_source_option_menu_new (source_list);
Matthew Barnes 3b4059
-	g_signal_connect (option_menu, "source_selected", G_CALLBACK (source_selected_callback), NULL);
Matthew Barnes 3b4059
+	combo_box = e_source_combo_box_new (source_list);
Matthew Barnes 3b4059
+	g_signal_connect (
Matthew Barnes 3b4059
+		combo_box, "changed",
Matthew Barnes 3b4059
+		G_CALLBACK (source_changed_cb), NULL);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
-	gtk_container_add (GTK_CONTAINER (window), option_menu);
Matthew Barnes 3b4059
+	gtk_container_add (GTK_CONTAINER (window), combo_box);
Matthew Barnes 3b4059
 	gtk_widget_show_all (window);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	g_object_unref (gconf_client);
Matthew Barnes 3b4059
--- evolution-data-server-1.10.0/libedataserverui/e-source-option-menu.h.code-cleanup	2007-01-03 05:09:27.000000000 -0500
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/libedataserverui/e-source-option-menu.h	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -23,6 +23,8 @@
Matthew Barnes 3b4059
 #ifndef _E_SOURCE_OPTION_MENU_H_
Matthew Barnes 3b4059
 #define _E_SOURCE_OPTION_MENU_H_
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
+#ifndef EDS_DISABLE_DEPRECATED
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
 #include <libedataserver/e-source-list.h>
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 #include <gtk/gtkoptionmenu.h>
Matthew Barnes 3b4059
@@ -60,5 +62,6 @@
Matthew Barnes 3b4059
 void     e_source_option_menu_select         (ESourceOptionMenu *menu,
Matthew Barnes 3b4059
 					      ESource           *source);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
+#endif /* EDS_DISABLE_DEPRECATED */
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 #endif /* _E_SOURCE_OPTION_MENU_H_ */
Matthew Barnes 89d907
--- /dev/null	2007-03-30 19:30:56.246366825 -0400
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/libedataserverui/e-source-combo-box.h	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -0,0 +1,79 @@
Matthew Barnes 3b4059
+/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
Matthew Barnes 3b4059
+/* e-source-combo-box.h
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Copyright (C) 2007 Novell, Inc.
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * This program is free software; you can redistribute it and/or
Matthew Barnes 3b4059
+ * modify it under the terms of version 2 of the GNU Lesser General Public
Matthew Barnes 3b4059
+ * License as published by the Free Software Foundation.
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * This program is distributed in the hope that it will be useful,
Matthew Barnes 3b4059
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
Matthew Barnes 3b4059
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Matthew Barnes 3b4059
+ * General Public License for more details.
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * You should have received a copy of the GNU Lesser General Public
Matthew Barnes 3b4059
+ * License along with this program; if not, write to the
Matthew Barnes 3b4059
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Matthew Barnes 3b4059
+ * Boston, MA 02111-1307, USA.
Matthew Barnes 3b4059
+ */
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+#ifndef _E_SOURCE_COMBO_BOX_H_
Matthew Barnes 3b4059
+#define _E_SOURCE_COMBO_BOX_H_
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+#include <gtk/gtk.h>
Matthew Barnes 3b4059
+#include <libedataserver/e-source-list.h>
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+#define E_TYPE_SOURCE_COMBO_BOX \
Matthew Barnes 3b4059
+	(e_source_combo_box_get_type ())
Matthew Barnes 3b4059
+#define E_SOURCE_COMBO_BOX(obj) \
Matthew Barnes 3b4059
+	(G_TYPE_CHECK_INSTANCE_CAST \
Matthew Barnes 3b4059
+	((obj), E_TYPE_SOURCE_COMBO_BOX, ESourceComboBox))
Matthew Barnes 3b4059
+#define E_SOURCE_COMBO_BOX_CLASS(cls) \
Matthew Barnes 3b4059
+	(G_TYPE_CHECK_CLASS_CAST \
Matthew Barnes 3b4059
+	((cls), E_TYPE_SOURCE_COMBO_BOX, ESourceComboBoxClass))
Matthew Barnes 3b4059
+#define E_IS_SOURCE_COMBO_BOX(obj) \
Matthew Barnes 3b4059
+	(G_TYPE_CHECK_INSTANCE_TYPE ((obj), E_TYPE_SOURCE_COMBO_BOX))
Matthew Barnes 3b4059
+#define E_IS_SOURCE_COMBO_BOX_CLASS(cls) \
Matthew Barnes 3b4059
+	(G_TYPE_CHECK_CLASS_TYPE ((cls), E_TYPE_SOURCE_COMBO_BOX))
Matthew Barnes 3b4059
+#define E_SOURCE_COMBO_BOX_GET_CLASS(obj) \
Matthew Barnes 3b4059
+	(G_TYPE_INSTANCE_GET_CLASS \
Matthew Barnes 3b4059
+	((obj), E_TYPE_SOURCE_COMBO_BOX, ESourceComboBox))
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+G_BEGIN_DECLS
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+typedef struct _ESourceComboBox ESourceComboBox;
Matthew Barnes 3b4059
+typedef struct _ESourceComboBoxClass ESourceComboBoxClass;
Matthew Barnes 3b4059
+typedef struct _ESourceComboBoxPrivate ESourceComboBoxPrivate;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+struct _ESourceComboBox {
Matthew Barnes 3b4059
+	GtkComboBox parent;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	ESourceComboBoxPrivate *priv;
Matthew Barnes 3b4059
+};
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+struct _ESourceComboBoxClass {
Matthew Barnes 3b4059
+	GtkComboBoxClass parent_class;
Matthew Barnes 3b4059
+};
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+GType		e_source_combo_box_get_type	(void);
Matthew Barnes 3b4059
+GtkWidget *	e_source_combo_box_new		(ESourceList *source_list);
Matthew Barnes 3b4059
+ESourceList *	e_source_combo_box_get_source_list
Matthew Barnes 3b4059
+						(ESourceComboBox *source_combo_box);
Matthew Barnes 3b4059
+void		e_source_combo_box_set_source_list
Matthew Barnes 3b4059
+						(ESourceComboBox *source_combo_box,
Matthew Barnes 3b4059
+					 	 ESourceList *source_list);
Matthew Barnes 3b4059
+ESource *	e_source_combo_box_get_active
Matthew Barnes 3b4059
+						(ESourceComboBox *source_combo_box);
Matthew Barnes 3b4059
+void		e_source_combo_box_set_active
Matthew Barnes 3b4059
+						(ESourceComboBox *source_combo_box,
Matthew Barnes 3b4059
+						 ESource *source);
Matthew Barnes 3b4059
+const gchar *	e_source_combo_box_get_active_uid
Matthew Barnes 3b4059
+						(ESourceComboBox *source_combo_box);
Matthew Barnes 3b4059
+void		e_source_combo_box_set_active_uid
Matthew Barnes 3b4059
+						(ESourceComboBox *source_combo_box,
Matthew Barnes 3b4059
+						 const gchar *uid);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+G_END_DECLS
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+#endif /* _E_SOURCE_COMBO_BOX_H_ */
Matthew Barnes 89d907
--- evolution-data-server-1.10.0/libedataserverui/Makefile.in.code-cleanup	2007-03-12 12:04:04.000000000 -0400
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/libedataserverui/Makefile.in	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -78,8 +78,8 @@
Matthew Barnes 3b4059
 	e-name-selector-dialog.lo e-name-selector-entry.lo \
Matthew Barnes 3b4059
 	e-name-selector-model.lo e-name-selector-list.lo \
Matthew Barnes 3b4059
 	e-passwords.lo e-source-selector.lo \
Matthew Barnes 3b4059
-	e-source-selector-dialog.lo e-source-option-menu.lo \
Matthew Barnes 3b4059
-	e-tree-model-generator.lo
Matthew Barnes 3b4059
+	e-source-selector-dialog.lo e-source-combo-box.lo \
Matthew Barnes 3b4059
+	e-source-option-menu.lo e-tree-model-generator.lo
Matthew Barnes 3b4059
 libedataserverui_1_2_la_OBJECTS =  \
Matthew Barnes 3b4059
 	$(am_libedataserverui_1_2_la_OBJECTS)
Matthew Barnes 3b4059
 PROGRAMS = $(noinst_PROGRAMS)
Matthew Barnes 3b4059
@@ -452,6 +452,7 @@
Matthew Barnes 3b4059
 	e-passwords.c			\
Matthew Barnes 3b4059
 	e-source-selector.c		\
Matthew Barnes 3b4059
 	e-source-selector-dialog.c	\
Matthew Barnes 3b4059
+	e-source-combo-box.c		\
Matthew Barnes 3b4059
 	e-source-option-menu.c		\
Matthew Barnes 3b4059
 	e-tree-model-generator.c
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
@@ -481,6 +482,7 @@
Matthew Barnes 3b4059
 	e-passwords.h			\
Matthew Barnes 3b4059
 	e-source-selector.h		\
Matthew Barnes 3b4059
 	e-source-selector-dialog.h	\
Matthew Barnes 3b4059
+	e-source-combo-box.h		\
Matthew Barnes 3b4059
 	e-source-option-menu.h		\
Matthew Barnes 3b4059
 	e-tree-model-generator.h
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
@@ -619,6 +621,7 @@
Matthew Barnes 3b4059
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/e-name-selector-model.Plo@am__quote@
Matthew Barnes 3b4059
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/e-name-selector.Plo@am__quote@
Matthew Barnes 3b4059
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/e-passwords.Plo@am__quote@
Matthew Barnes 3b4059
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/e-source-combo-box.Plo@am__quote@
Matthew Barnes 3b4059
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/e-source-option-menu.Plo@am__quote@
Matthew Barnes 3b4059
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/e-source-selector-dialog.Plo@am__quote@
Matthew Barnes 3b4059
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/e-source-selector.Plo@am__quote@
Matthew Barnes 3b4059
--- evolution-data-server-1.10.0/libedataserverui/e-name-selector-dialog.h.code-cleanup	2007-01-03 05:09:27.000000000 -0500
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/libedataserverui/e-name-selector-dialog.h	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -58,7 +58,6 @@
Matthew Barnes 3b4059
 	/* Private */
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	EBook              *pending_book;
Matthew Barnes 3b4059
-	ESourceList        *source_list;
Matthew Barnes 3b4059
 	ENameSelectorModel *name_selector_model;
Matthew Barnes 3b4059
 	GtkTreeModelSort   *contact_sort;
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
--- evolution-data-server-1.10.0/libedataserverui/Makefile.am.code-cleanup	2007-01-03 05:09:27.000000000 -0500
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/libedataserverui/Makefile.am	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -31,6 +31,7 @@
Matthew Barnes 3b4059
 	e-passwords.c			\
Matthew Barnes 3b4059
 	e-source-selector.c		\
Matthew Barnes 3b4059
 	e-source-selector-dialog.c	\
Matthew Barnes 3b4059
+	e-source-combo-box.c		\
Matthew Barnes 3b4059
 	e-source-option-menu.c		\
Matthew Barnes 3b4059
 	e-tree-model-generator.c
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
@@ -63,6 +64,7 @@
Matthew Barnes 3b4059
 	e-passwords.h			\
Matthew Barnes 3b4059
 	e-source-selector.h		\
Matthew Barnes 3b4059
 	e-source-selector-dialog.h	\
Matthew Barnes 3b4059
+	e-source-combo-box.h		\
Matthew Barnes 3b4059
 	e-source-option-menu.h		\
Matthew Barnes 3b4059
 	e-tree-model-generator.h
Matthew Barnes 3b4059
 
Matthew Barnes 89d907
--- evolution-data-server-1.10.0/libedataserverui/e-name-selector-dialog.c.code-cleanup	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/libedataserverui/e-name-selector-dialog.c	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -32,7 +32,7 @@
Matthew Barnes 3b4059
 #include <gtk/gtkscrolledwindow.h>
Matthew Barnes 3b4059
 #include <gtk/gtkstock.h>
Matthew Barnes 3b4059
 #include <glib/gi18n-lib.h>
Matthew Barnes 3b4059
-#include <libedataserverui/e-source-option-menu.h>
Matthew Barnes 3b4059
+#include <libedataserverui/e-source-combo-box.h>
Matthew Barnes 3b4059
 #include <libedataserverui/e-destination-store.h>
Matthew Barnes 3b4059
 #include <libedataserverui/e-contact-store.h>
Matthew Barnes 3b4059
 #include <libedataserverui/e-book-auth-util.h>
Matthew Barnes 3b4059
@@ -64,9 +64,8 @@
Matthew Barnes 3b4059
 	guint destination_index;
Matthew Barnes 3b4059
 };
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
-static ESource *find_first_source             (ESourceList *source_list);
Matthew Barnes 3b4059
 static void     search_changed                (ENameSelectorDialog *name_selector_dialog);
Matthew Barnes 3b4059
-static void     source_selected               (ENameSelectorDialog *name_selector_dialog, ESource *source);
Matthew Barnes 3b4059
+static void     source_changed                (ENameSelectorDialog *name_selector_dialog, ESourceComboBox *source_combo_box);
Matthew Barnes 3b4059
 static void     transfer_button_clicked       (ENameSelectorDialog *name_selector_dialog, GtkButton *transfer_button);
Matthew Barnes 3b4059
 static void     contact_selection_changed     (ENameSelectorDialog *name_selector_dialog);
Matthew Barnes 3b4059
 static void     setup_name_selector_model     (ENameSelectorDialog *name_selector_dialog);
Matthew Barnes 3b4059
@@ -106,33 +105,28 @@
Matthew Barnes 3b4059
 {
Matthew Barnes 3b4059
 }
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
-/* FIXME: category_list should become part of ENameSelectorDialog structure */
Matthew Barnes 3b4059
-GList *category_list;
Matthew Barnes 3b4059
-
Matthew Barnes 3b4059
 static void
Matthew Barnes 3b4059
 e_name_selector_dialog_populate_categories (ENameSelectorDialog *name_selector_dialog)
Matthew Barnes 3b4059
 {
Matthew Barnes 3b4059
-	GtkWidget *category_option_menu;
Matthew Barnes 3b4059
-	GtkWidget *category_menu;
Matthew Barnes 3b4059
-	GList *l;
Matthew Barnes 3b4059
-	category_option_menu = glade_xml_get_widget (name_selector_dialog->gui, "optionmenu-category");
Matthew Barnes 3b4059
+	GtkWidget *combo_box;
Matthew Barnes 3b4059
+	GList *category_list, *iter;
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
-	/* Categories are already sorted */
Matthew Barnes 3b4059
-	category_list = e_categories_get_list () ;
Matthew Barnes 3b4059
-	category_list = g_list_prepend (category_list, _("Any Category"));
Matthew Barnes 3b4059
-
Matthew Barnes 3b4059
-	category_menu = gtk_menu_new ();
Matthew Barnes 3b4059
-	l = category_list;
Matthew Barnes 3b4059
-	while (l) {	
Matthew Barnes 3b4059
-		GtkWidget *item;
Matthew Barnes 3b4059
-		item = gtk_menu_item_new_with_label (l->data);
Matthew Barnes 3b4059
-		gtk_menu_shell_append (GTK_MENU_SHELL (category_menu), item);
Matthew Barnes 3b4059
-		l = l->next;
Matthew Barnes 3b4059
-	}
Matthew Barnes 3b4059
-	gtk_widget_show_all (category_menu);
Matthew Barnes 3b4059
-	gtk_option_menu_set_menu (GTK_OPTION_MENU (category_option_menu), category_menu);
Matthew Barnes 3b4059
-	
Matthew Barnes 3b4059
-	g_signal_connect_swapped (category_option_menu, "changed", G_CALLBACK (search_changed), name_selector_dialog);
Matthew Barnes 3b4059
+	/* "Any Category" is preloaded. */
Matthew Barnes 3b4059
+	combo_box = glade_xml_get_widget (
Matthew Barnes 3b4059
+		name_selector_dialog->gui, "combobox-category");
Matthew Barnes 3b4059
+	if (gtk_combo_box_get_active (GTK_COMBO_BOX (combo_box)) == -1)
Matthew Barnes 3b4059
+		gtk_combo_box_set_active (GTK_COMBO_BOX (combo_box), 0);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	/* Categories are already sorted. */
Matthew Barnes 3b4059
+	category_list = e_categories_get_list ();
Matthew Barnes 3b4059
+	for (iter = category_list; iter != NULL; iter = iter->next)
Matthew Barnes 3b4059
+		gtk_combo_box_append_text (
Matthew Barnes 3b4059
+			GTK_COMBO_BOX (combo_box), iter->data);
Matthew Barnes 3b4059
+	g_list_free (category_list);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	g_signal_connect_swapped (
Matthew Barnes 3b4059
+		combo_box, "changed",
Matthew Barnes 3b4059
+		G_CALLBACK (search_changed), name_selector_dialog);
Matthew Barnes 3b4059
 }
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 static void
Matthew Barnes 3b4059
@@ -223,34 +217,26 @@
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	name_selector_dialog->name_selector_model = e_name_selector_model_new ();
Matthew Barnes 3b4059
 	name_selector_dialog->sections            = g_array_new (FALSE, FALSE, sizeof (Section));
Matthew Barnes 3b4059
-	name_selector_dialog->source_list         = source_list;
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	setup_name_selector_model (name_selector_dialog);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	/* Create source menu */
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
-	widget = e_source_option_menu_new (name_selector_dialog->source_list);
Matthew Barnes 3b4059
-        
Matthew Barnes 3b4059
+	widget = e_source_combo_box_new (source_list);
Matthew Barnes 3b4059
+	g_signal_connect_swapped (
Matthew Barnes 3b4059
+		widget, "changed",
Matthew Barnes 3b4059
+		G_CALLBACK (source_changed), name_selector_dialog);
Matthew Barnes 3b4059
+	g_object_unref (source_list);
Matthew Barnes 3b4059
+ 
Matthew Barnes 3b4059
 	gconf_client = gconf_client_get_default();
Matthew Barnes 3b4059
 	uid = gconf_client_get_string (gconf_client, "/apps/evolution/addressbook/display/primary_addressbook",
Matthew Barnes 3b4059
 			NULL);
Matthew Barnes 3b4059
 	g_object_unref (gconf_client);
Matthew Barnes 3b4059
 	if (uid) {
Matthew Barnes 3b4059
-		ESource *source = e_source_list_peek_source_by_uid(name_selector_dialog->source_list, uid);
Matthew Barnes 3b4059
-		if (source) {
Matthew Barnes 3b4059
-			e_source_option_menu_select ((ESourceOptionMenu *)widget, source);
Matthew Barnes 3b4059
-			source_selected (name_selector_dialog, source);
Matthew Barnes 3b4059
-		}
Matthew Barnes 3b4059
-		else {
Matthew Barnes 3b4059
-			source_selected (name_selector_dialog, find_first_source (name_selector_dialog->source_list));
Matthew Barnes 3b4059
-		}
Matthew Barnes 3b4059
+		e_source_combo_box_set_active_uid (
Matthew Barnes 3b4059
+			E_SOURCE_COMBO_BOX (widget), uid);
Matthew Barnes 3b4059
 		g_free (uid);
Matthew Barnes 3b4059
 	}
Matthew Barnes 3b4059
-	else {
Matthew Barnes 3b4059
-		source_selected (name_selector_dialog, find_first_source (name_selector_dialog->source_list));
Matthew Barnes 3b4059
-	}
Matthew Barnes 3b4059
-
Matthew Barnes 3b4059
-	g_signal_connect_swapped (widget, "source_selected", G_CALLBACK (source_selected), name_selector_dialog);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	label = glade_xml_get_widget (name_selector_dialog->gui, "AddressBookLabel");
Matthew Barnes 3b4059
 	gtk_label_set_mnemonic_widget (GTK_LABEL (label), widget);
Matthew Barnes 3b4059
@@ -308,9 +294,7 @@
Matthew Barnes 3b4059
 	ENameSelectorDialog *name_selector_dialog = E_NAME_SELECTOR_DIALOG (object);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	g_array_free (name_selector_dialog->sections, TRUE);
Matthew Barnes 3b4059
-	g_object_unref (name_selector_dialog->source_list);
Matthew Barnes 3b4059
 	g_object_unref (name_selector_dialog->button_size_group);
Matthew Barnes 3b4059
-	g_list_free (category_list);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	if (G_OBJECT_CLASS (e_name_selector_dialog_parent_class)->finalize)
Matthew Barnes 3b4059
 		G_OBJECT_CLASS (e_name_selector_dialog_parent_class)->finalize (object);
Matthew Barnes 3b4059
@@ -384,26 +368,6 @@
Matthew Barnes 3b4059
 		*email_n = email_n_local;
Matthew Barnes 3b4059
 }
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
-static ESource *
Matthew Barnes 3b4059
-find_first_source (ESourceList *source_list)
Matthew Barnes 3b4059
-{
Matthew Barnes 3b4059
-	GSList *groups, *sources, *l, *m;
Matthew Barnes 3b4059
-			
Matthew Barnes 3b4059
-	groups = e_source_list_peek_groups (source_list);
Matthew Barnes 3b4059
-	for (l = groups; l; l = l->next) {
Matthew Barnes 3b4059
-		ESourceGroup *group = l->data;
Matthew Barnes 3b4059
-				
Matthew Barnes 3b4059
-		sources = e_source_group_peek_sources (group);
Matthew Barnes 3b4059
-		for (m = sources; m; m = m->next) {
Matthew Barnes 3b4059
-			ESource *source = m->data;
Matthew Barnes 3b4059
-
Matthew Barnes 3b4059
-			return source;
Matthew Barnes 3b4059
-		}				
Matthew Barnes 3b4059
-	}
Matthew Barnes 3b4059
-
Matthew Barnes 3b4059
-	return NULL;
Matthew Barnes 3b4059
-}
Matthew Barnes 3b4059
-
Matthew Barnes 3b4059
 static void
Matthew Barnes 3b4059
 add_destination (EDestinationStore *destination_store, EContact *contact, gint email_n)
Matthew Barnes 3b4059
 {
Matthew Barnes 3b4059
@@ -742,8 +706,13 @@
Matthew Barnes 3b4059
 }
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 static void
Matthew Barnes 3b4059
-source_selected (ENameSelectorDialog *name_selector_dialog, ESource *source)
Matthew Barnes 3b4059
+source_changed (ENameSelectorDialog *name_selector_dialog,
Matthew Barnes 3b4059
+                ESourceComboBox *source_combo_box)
Matthew Barnes 3b4059
 {
Matthew Barnes 3b4059
+	ESource *source;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	source = e_source_combo_box_get_active (source_combo_box);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
 	/* Remove any previous books being shown or loaded */
Matthew Barnes 3b4059
 	remove_books (name_selector_dialog);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
@@ -761,49 +730,54 @@
Matthew Barnes 3b4059
 {
Matthew Barnes 3b4059
 	EContactStore *contact_store;
Matthew Barnes 3b4059
 	EBookQuery    *book_query;
Matthew Barnes 3b4059
-	GtkWidget     *category_option_menu;
Matthew Barnes 3b4059
+	GtkWidget     *combo_box;
Matthew Barnes 3b4059
 	const gchar   *text;
Matthew Barnes 3b4059
-	gint 	      category_id;	
Matthew Barnes 3b4059
 	gchar         *text_escaped;
Matthew Barnes 3b4059
 	gchar         *query_string;
Matthew Barnes 3b4059
-	const gchar   *category;
Matthew Barnes 3b4059
+	gchar         *category;
Matthew Barnes 3b4059
 	gchar         *category_escaped;
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
-	category_option_menu = glade_xml_get_widget(name_selector_dialog->gui, "optionmenu-category");
Matthew Barnes 3b4059
-	category_id = gtk_option_menu_get_history (GTK_OPTION_MENU(category_option_menu));
Matthew Barnes 3b4059
-	category = g_list_nth_data (category_list, category_id);
Matthew Barnes 3b4059
-	if (!category)
Matthew Barnes 3b4059
-		return;
Matthew Barnes 3b4059
+	combo_box = glade_xml_get_widget (
Matthew Barnes 3b4059
+		name_selector_dialog->gui, "combobox-category");
Matthew Barnes 3b4059
+	if (gtk_combo_box_get_active (GTK_COMBO_BOX (combo_box)) == -1)
Matthew Barnes 3b4059
+		gtk_combo_box_set_active (GTK_COMBO_BOX (combo_box), 0);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	category = gtk_combo_box_get_active_text (GTK_COMBO_BOX (combo_box));
Matthew Barnes 3b4059
 	category_escaped = escape_sexp_string (category);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	text = gtk_entry_get_text (name_selector_dialog->search_entry);
Matthew Barnes 3b4059
 	text_escaped = escape_sexp_string (text);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
-	if ( !strcmp (category, _("Any Category"))) {
Matthew Barnes 3b4059
-		query_string = g_strdup_printf ("(or (beginswith \"file_as\" %s) "
Matthew Barnes 3b4059
-						"    (beginswith \"full_name\" %s) "
Matthew Barnes 3b4059
-						"    (beginswith \"email\" %s) "
Matthew Barnes 3b4059
-						"    (beginswith \"nickname\" %s)))",
Matthew Barnes 3b4059
-						text_escaped, text_escaped, text_escaped, text_escaped);
Matthew Barnes 3b4059
-	}
Matthew Barnes 3b4059
-	else {
Matthew Barnes 3b4059
-		query_string = g_strdup_printf ("(and (is \"category_list\" %s) "
Matthew Barnes 3b4059
-						"(or (beginswith \"file_as\" %s) "
Matthew Barnes 3b4059
-						"    (beginswith \"full_name\" %s) "
Matthew Barnes 3b4059
-						"    (beginswith \"email\" %s) "
Matthew Barnes 3b4059
-						"    (beginswith \"nickname\" %s)))",
Matthew Barnes 3b4059
-						category_escaped,text_escaped, text_escaped, text_escaped, text_escaped);
Matthew Barnes 3b4059
-	}
Matthew Barnes 3b4059
+	if (!strcmp (category, _("Any Category")))
Matthew Barnes 3b4059
+		query_string = g_strdup_printf (
Matthew Barnes 3b4059
+			"(or (beginswith \"file_as\" %s) "
Matthew Barnes 3b4059
+			"    (beginswith \"full_name\" %s) "
Matthew Barnes 3b4059
+			"    (beginswith \"email\" %s) "
Matthew Barnes 3b4059
+			"    (beginswith \"nickname\" %s)))",
Matthew Barnes 3b4059
+			text_escaped, text_escaped,
Matthew Barnes 3b4059
+			text_escaped, text_escaped);
Matthew Barnes 3b4059
+	else
Matthew Barnes 3b4059
+		query_string = g_strdup_printf (
Matthew Barnes 3b4059
+			"(and (is \"category_list\" %s) "
Matthew Barnes 3b4059
+			"(or (beginswith \"file_as\" %s) "
Matthew Barnes 3b4059
+			"    (beginswith \"full_name\" %s) "
Matthew Barnes 3b4059
+			"    (beginswith \"email\" %s) "
Matthew Barnes 3b4059
+			"    (beginswith \"nickname\" %s)))",
Matthew Barnes 3b4059
+			category_escaped, text_escaped, text_escaped,
Matthew Barnes 3b4059
+			text_escaped, text_escaped);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	book_query = e_book_query_from_string (query_string);
Matthew Barnes 3b4059
-	g_free (query_string);
Matthew Barnes 3b4059
-	g_free (text_escaped);
Matthew Barnes 3b4059
-	g_free (category_escaped);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
-	contact_store = e_name_selector_model_peek_contact_store (name_selector_dialog->name_selector_model);
Matthew Barnes 3b4059
+	contact_store = e_name_selector_model_peek_contact_store (
Matthew Barnes 3b4059
+		name_selector_dialog->name_selector_model);
Matthew Barnes 3b4059
 	e_contact_store_set_query (contact_store, book_query);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 	e_book_query_unref (book_query);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	g_free (query_string);
Matthew Barnes 3b4059
+	g_free (text_escaped);
Matthew Barnes 3b4059
+	g_free (category_escaped);
Matthew Barnes 3b4059
+	g_free (category);
Matthew Barnes 3b4059
 }
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 static void
Matthew Barnes 89d907
--- /dev/null	2007-03-30 19:30:56.246366825 -0400
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/libedataserverui/e-source-combo-box.c	2007-04-04 12:09:51.000000000 -0400
Matthew Barnes 89d907
@@ -0,0 +1,457 @@
Matthew Barnes 3b4059
+/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
Matthew Barnes 3b4059
+/* e-source-option-menu.c
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Copyright (C) 2007 Novell, Inc.
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * This program is free software; you can redistribute it and/or
Matthew Barnes 3b4059
+ * modify it under the terms of version 2 of the GNU Lesser General Public
Matthew Barnes 3b4059
+ * License as published by the Free Software Foundation.
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * This program is distributed in the hope that it will be useful,
Matthew Barnes 3b4059
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
Matthew Barnes 3b4059
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Matthew Barnes 3b4059
+ * General Public License for more details.
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * You should have received a copy of the GNU Lesser General Public
Matthew Barnes 3b4059
+ * License along with this program; if not, write to the
Matthew Barnes 3b4059
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Matthew Barnes 3b4059
+ * Boston, MA 02111-1307, USA.
Matthew Barnes 3b4059
+ */
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+#ifdef HAVE_CONFIG_H
Matthew Barnes 3b4059
+#include <config.h>
Matthew Barnes 3b4059
+#endif
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+#include "e-source-combo-box.h"
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+#define E_SOURCE_COMBO_BOX_GET_PRIVATE(obj) \
Matthew Barnes 3b4059
+	(G_TYPE_INSTANCE_GET_PRIVATE \
Matthew Barnes 3b4059
+	((obj), E_TYPE_SOURCE_COMBO_BOX, ESourceComboBoxPrivate))
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+struct _ESourceComboBoxPrivate {
Matthew Barnes 3b4059
+	ESourceList *source_list;
Matthew Barnes 3b4059
+	GHashTable *uid_to_row_reference;
Matthew Barnes 3b4059
+	gulong handler_id;
Matthew Barnes 3b4059
+};
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+enum {
Matthew Barnes 3b4059
+	PROP_0,
Matthew Barnes 3b4059
+	PROP_SOURCE_LIST
Matthew Barnes 3b4059
+};
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+enum {
Matthew Barnes 3b4059
+	COLUMN_NAME,		/* G_TYPE_STRING */
Matthew Barnes 3b4059
+	COLUMN_SENSITIVE,	/* G_TYPE_BOOLEAN */
Matthew Barnes 3b4059
+	COLUMN_SOURCE,		/* G_TYPE_OBJECT */
Matthew Barnes 3b4059
+	NUM_COLUMNS
Matthew Barnes 3b4059
+};
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+static gpointer parent_class = NULL;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+static void
Matthew Barnes 3b4059
+source_list_changed_cb (ESourceList *source_list,
Matthew Barnes 3b4059
+                        ESourceComboBox *source_combo_box)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	ESourceComboBoxPrivate *priv;
Matthew Barnes 3b4059
+	GtkComboBox *combo_box;
Matthew Barnes 3b4059
+	GtkTreeModel *model;
Matthew Barnes 3b4059
+	GtkListStore *store;
Matthew Barnes 3b4059
+	GtkTreeIter iter;
Matthew Barnes 3b4059
+	GtkTreePath *path;
Matthew Barnes 3b4059
+	GSList *groups;
Matthew Barnes 3b4059
+	GSList *sources;
Matthew Barnes 3b4059
+	const gchar *name;
Matthew Barnes 3b4059
+	const gchar *uid;
Matthew Barnes 3b4059
+	gchar *indented_name;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	priv = E_SOURCE_COMBO_BOX_GET_PRIVATE (source_combo_box);
Matthew Barnes 3b4059
+	g_hash_table_remove_all (priv->uid_to_row_reference);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	combo_box = GTK_COMBO_BOX (source_combo_box);
Matthew Barnes 3b4059
+	gtk_combo_box_set_active (combo_box, -1);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	model = gtk_combo_box_get_model (combo_box);
Matthew Barnes 3b4059
+	store = GTK_LIST_STORE (model);
Matthew Barnes 3b4059
+	gtk_list_store_clear (store);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	for (groups = e_source_list_peek_groups (source_list);
Matthew Barnes 3b4059
+		groups != NULL; groups = groups->next) {
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+		/* Only show source groups that have sources. */
Matthew Barnes 3b4059
+		if (e_source_group_peek_sources (groups->data) == NULL)
Matthew Barnes 3b4059
+			continue;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+		name = e_source_group_peek_name (groups->data);
Matthew Barnes 3b4059
+		gtk_list_store_append (store, &iter);
Matthew Barnes 3b4059
+		gtk_list_store_set (
Matthew Barnes 3b4059
+			store, &iter,
Matthew Barnes 3b4059
+			COLUMN_NAME, name,
Matthew Barnes 3b4059
+			COLUMN_SENSITIVE, FALSE,
Matthew Barnes 3b4059
+			COLUMN_SOURCE, groups->data,
Matthew Barnes 3b4059
+			-1);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+		for (sources = e_source_group_peek_sources (groups->data);
Matthew Barnes 3b4059
+			sources != NULL; sources = sources->next) {
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+			name = e_source_peek_name (sources->data);
Matthew Barnes 3b4059
+			indented_name = g_strconcat ("    ", name, NULL);
Matthew Barnes 3b4059
+			gtk_list_store_append (store, &iter);
Matthew Barnes 3b4059
+			gtk_list_store_set (
Matthew Barnes 3b4059
+				store, &iter,
Matthew Barnes 3b4059
+				COLUMN_NAME, indented_name,
Matthew Barnes 3b4059
+				COLUMN_SENSITIVE, TRUE,
Matthew Barnes 3b4059
+				COLUMN_SOURCE, sources->data,
Matthew Barnes 3b4059
+				-1);
Matthew Barnes 3b4059
+			g_free (indented_name);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+			uid = e_source_peek_uid (sources->data);
Matthew Barnes 3b4059
+			path = gtk_tree_model_get_path (model, &iter);
Matthew Barnes 3b4059
+			g_hash_table_insert (
Matthew Barnes 3b4059
+				priv->uid_to_row_reference, g_strdup (uid),
Matthew Barnes 3b4059
+				gtk_tree_row_reference_new (model, path));
Matthew Barnes 3b4059
+			gtk_tree_path_free (path);
Matthew Barnes 3b4059
+		}
Matthew Barnes 3b4059
+	}
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+static GObject *
Matthew Barnes 3b4059
+e_source_combo_box_constructor (GType type, guint n_construct_properties,
Matthew Barnes 3b4059
+                                GObjectConstructParam *construct_properties)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	GtkCellRenderer *renderer;
Matthew Barnes 3b4059
+	GtkListStore *store;
Matthew Barnes 3b4059
+	GObject *object;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	/* Chain up to parent's "constructor" method. */
Matthew Barnes 3b4059
+	object = G_OBJECT_CLASS (parent_class)->constructor (
Matthew Barnes 3b4059
+		type, n_construct_properties, construct_properties);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	store = gtk_list_store_new (
Matthew Barnes 3b4059
+		NUM_COLUMNS, G_TYPE_STRING, G_TYPE_BOOLEAN, G_TYPE_OBJECT);
Matthew Barnes 3b4059
+	gtk_combo_box_set_model (
Matthew Barnes 3b4059
+		GTK_COMBO_BOX (object), GTK_TREE_MODEL (store));
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	renderer = gtk_cell_renderer_text_new ();
Matthew Barnes 3b4059
+	gtk_cell_layout_pack_start (
Matthew Barnes 3b4059
+		GTK_CELL_LAYOUT (object), renderer, TRUE);
Matthew Barnes 3b4059
+	gtk_cell_layout_set_attributes (
Matthew Barnes 3b4059
+		GTK_CELL_LAYOUT (object), renderer,
Matthew Barnes 3b4059
+		"text", COLUMN_NAME,
Matthew Barnes 3b4059
+		"sensitive", COLUMN_SENSITIVE,
Matthew Barnes 3b4059
+		NULL);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	return object;
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+static void
Matthew Barnes 3b4059
+e_source_combo_box_set_property (GObject *object, guint property_id,
Matthew Barnes 3b4059
+                                 const GValue *value, GParamSpec *pspec)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	ESourceComboBoxPrivate *priv;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	priv = E_SOURCE_COMBO_BOX_GET_PRIVATE (object);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	switch (property_id) {
Matthew Barnes 3b4059
+		case PROP_SOURCE_LIST:
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+			if (priv->source_list != NULL) {
Matthew Barnes 3b4059
+				g_signal_handler_disconnect (
Matthew Barnes 3b4059
+					priv->source_list, priv->handler_id);
Matthew Barnes 3b4059
+				g_object_unref (priv->source_list);
Matthew Barnes 3b4059
+			}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+			priv->source_list = g_value_dup_object (value);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+			/* Reset the tree store. */
Matthew Barnes 3b4059
+			source_list_changed_cb (
Matthew Barnes 3b4059
+				priv->source_list,
Matthew Barnes 3b4059
+				E_SOURCE_COMBO_BOX (object));
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+			/* Watch for source list changes. */
Matthew Barnes 3b4059
+			priv->handler_id = g_signal_connect_object (
Matthew Barnes 3b4059
+				priv->source_list, "changed",
Matthew Barnes 3b4059
+				G_CALLBACK (source_list_changed_cb),
Matthew Barnes 3b4059
+				object, 0);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+			return;
Matthew Barnes 3b4059
+	}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+static void
Matthew Barnes 3b4059
+e_source_combo_box_get_property (GObject *object, guint property_id,
Matthew Barnes 3b4059
+                                 GValue *value, GParamSpec *pspec)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	ESourceComboBoxPrivate *priv;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	priv = E_SOURCE_COMBO_BOX_GET_PRIVATE (object);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	switch (property_id) {
Matthew Barnes 3b4059
+		case PROP_SOURCE_LIST:
Matthew Barnes 3b4059
+			g_value_set_object (value, priv->source_list);
Matthew Barnes 3b4059
+			return;
Matthew Barnes 3b4059
+	}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+static void
Matthew Barnes 3b4059
+e_source_combo_box_dispose (GObject *object)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	ESourceComboBoxPrivate *priv;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	priv = E_SOURCE_COMBO_BOX_GET_PRIVATE (object);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	if (priv->source_list != NULL) {
Matthew Barnes 3b4059
+		g_object_unref (priv->source_list);
Matthew Barnes 3b4059
+		priv->source_list = NULL;
Matthew Barnes 3b4059
+	}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	g_hash_table_remove_all (priv->uid_to_row_reference);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	/* Chain up to parent's "dispose" method. */
Matthew Barnes 3b4059
+	G_OBJECT_CLASS (parent_class)->dispose (object);
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+static void
Matthew Barnes 3b4059
+e_source_combo_box_finalize (GObject *object)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	ESourceComboBoxPrivate *priv;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	priv = E_SOURCE_COMBO_BOX_GET_PRIVATE (object);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	g_hash_table_destroy (priv->uid_to_row_reference);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	/* Chain up to parent's "finalize" method. */
Matthew Barnes 3b4059
+	G_OBJECT_CLASS (parent_class)->finalize (object);
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+static void
Matthew Barnes 3b4059
+e_source_combo_box_class_init (ESourceComboBoxClass *class)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	GObjectClass *object_class = G_OBJECT_CLASS (class);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	parent_class = g_type_class_peek_parent (class);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	g_type_class_add_private (class, sizeof (ESourceComboBox));
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	object_class->constructor = e_source_combo_box_constructor;
Matthew Barnes 3b4059
+	object_class->set_property = e_source_combo_box_set_property;
Matthew Barnes 3b4059
+	object_class->get_property = e_source_combo_box_get_property;
Matthew Barnes 3b4059
+	object_class->dispose = e_source_combo_box_dispose;
Matthew Barnes 3b4059
+	object_class->finalize = e_source_combo_box_finalize;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	g_object_class_install_property (
Matthew Barnes 3b4059
+		object_class,
Matthew Barnes 3b4059
+		PROP_SOURCE_LIST,
Matthew Barnes 3b4059
+		g_param_spec_object (
Matthew Barnes 3b4059
+			"source-list",
Matthew Barnes 3b4059
+			"source-list",
Matthew Barnes 3b4059
+			"List of sources to choose from",
Matthew Barnes 3b4059
+			E_TYPE_SOURCE_LIST,
Matthew Barnes 3b4059
+			G_PARAM_READWRITE));
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+static void
Matthew Barnes 3b4059
+e_source_combo_box_init (ESourceComboBox *source_combo_box)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	ESourceComboBoxPrivate *priv;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	priv = E_SOURCE_COMBO_BOX_GET_PRIVATE (source_combo_box);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	priv->uid_to_row_reference = g_hash_table_new_full (
Matthew Barnes 3b4059
+		g_str_hash, g_str_equal,
Matthew Barnes 3b4059
+		(GDestroyNotify) g_free,
Matthew Barnes 3b4059
+		(GDestroyNotify) gtk_tree_row_reference_free);
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+GType
Matthew Barnes 3b4059
+e_source_combo_box_get_type (void)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	static GType type = 0;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	if (G_UNLIKELY (type == 0)) {
Matthew Barnes 3b4059
+		static const GTypeInfo type_info = {
Matthew Barnes 3b4059
+			sizeof (ESourceComboBoxClass),
Matthew Barnes 3b4059
+			(GBaseInitFunc) NULL,
Matthew Barnes 3b4059
+			(GBaseFinalizeFunc) NULL,
Matthew Barnes 3b4059
+			(GClassInitFunc) e_source_combo_box_class_init,
Matthew Barnes 3b4059
+			(GClassFinalizeFunc) NULL,
Matthew Barnes 3b4059
+			NULL,  /* class_data */
Matthew Barnes 3b4059
+			sizeof (ESourceComboBox),
Matthew Barnes 3b4059
+			0,     /* n_preallocs */
Matthew Barnes 3b4059
+			(GInstanceInitFunc) e_source_combo_box_init,
Matthew Barnes 3b4059
+			NULL   /* value_table */
Matthew Barnes 3b4059
+		};
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+		type = g_type_register_static (
Matthew Barnes 3b4059
+			GTK_TYPE_COMBO_BOX, "ESourceComboBox", &type_info, 0);
Matthew Barnes 3b4059
+	}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	return type;
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+/**
Matthew Barnes 3b4059
+ * e_source_combo_box_new:
Matthew Barnes 3b4059
+ * @source_list: an #ESourceList
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Creates a new #ESourceComboBox widget that lets the user pick an #ESource
Matthew Barnes 3b4059
+ * from the provided #ESourceList.
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Returns: a new #ESourceComboBox
Matthew Barnes 3b4059
+ **/
Matthew Barnes 3b4059
+GtkWidget *
Matthew Barnes 3b4059
+e_source_combo_box_new (ESourceList *source_list)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	g_return_val_if_fail (source_list != NULL, NULL);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	return g_object_new (
Matthew Barnes 3b4059
+		E_TYPE_SOURCE_COMBO_BOX,
Matthew Barnes 3b4059
+		"source-list", source_list, NULL);
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+/**
Matthew Barnes 3b4059
+ * e_source_combo_box_get_source_list:
Matthew Barnes 3b4059
+ * @source_combo_box: an #ESourceComboBox
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Returns the #ESourceList which is acting as a data source for
Matthew Barnes 3b4059
+ * @source_combo_box.
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Returns: an #ESourceList
Matthew Barnes 3b4059
+ **/
Matthew Barnes 3b4059
+ESourceList *
Matthew Barnes 3b4059
+e_source_combo_box_get_source_list (ESourceComboBox *source_combo_box)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	ESourceList *source_list;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	g_return_val_if_fail (source_combo_box != NULL, NULL);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	g_object_get (source_combo_box, "source-list", &source_list, NULL);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	return source_list;
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+/**
Matthew Barnes 3b4059
+ * e_source_combo_box_set_source_list:
Matthew Barnes 3b4059
+ * @source_combo_box: an #ESourceComboBox
Matthew Barnes 3b4059
+ * @source_list: an #ESourceList
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Sets the source list used by @source_combo_box to be @source_list.  This
Matthew Barnes 3b4059
+ * causes the contents of @source_combo_box to be regenerated.
Matthew Barnes 3b4059
+ **/
Matthew Barnes 3b4059
+void
Matthew Barnes 3b4059
+e_source_combo_box_set_source_list (ESourceComboBox *source_combo_box,
Matthew Barnes 3b4059
+                                    ESourceList *source_list)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	g_return_if_fail (source_combo_box != NULL);
Matthew Barnes 3b4059
+	g_return_if_fail (source_list != NULL);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	g_object_set (source_combo_box, "source-list", source_list, NULL);
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+/**
Matthew Barnes 3b4059
+ * e_source_combo_box_get_active:
Matthew Barnes 3b4059
+ * @source_combo_box: an #ESourceComboBox
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Returns the #ESource corresponding to the currently active item, or %NULL
Matthew Barnes 3b4059
+ * if there is no active item.
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Returns: an #ESource or %NULL
Matthew Barnes 3b4059
+ **/
Matthew Barnes 3b4059
+ESource *
Matthew Barnes 3b4059
+e_source_combo_box_get_active (ESourceComboBox *source_combo_box)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	GtkComboBox *combo_box;
Matthew Barnes 3b4059
+	GtkTreeIter iter;
Matthew Barnes 3b4059
+	ESource *source;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	g_return_val_if_fail (source_combo_box != NULL, NULL);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	combo_box = GTK_COMBO_BOX (source_combo_box);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	if (!gtk_combo_box_get_active_iter (combo_box, &iter))
Matthew Barnes 3b4059
+		return NULL;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	gtk_tree_model_get (
Matthew Barnes 3b4059
+		gtk_combo_box_get_model (combo_box),
Matthew Barnes 3b4059
+		&iter, COLUMN_SOURCE, &source, -1);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	return source;
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+/**
Matthew Barnes 3b4059
+ * e_source_combo_box_set_active:
Matthew Barnes 3b4059
+ * @source_combo_box: an #ESourceComboBox
Matthew Barnes 3b4059
+ * @source: an #ESource
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Sets the active item to the one corresponding to @source.
Matthew Barnes 3b4059
+ **/
Matthew Barnes 3b4059
+void
Matthew Barnes 3b4059
+e_source_combo_box_set_active (ESourceComboBox *source_combo_box,
Matthew Barnes 3b4059
+                               ESource *source)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	g_return_if_fail (source_combo_box != NULL);
Matthew Barnes 3b4059
+	g_return_if_fail (source != NULL);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	e_source_combo_box_set_active_uid (
Matthew Barnes 3b4059
+		source_combo_box, e_source_peek_uid (source));
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+/**
Matthew Barnes 3b4059
+ * e_source_combo_box_get_active_uid:
Matthew Barnes 3b4059
+ * @source_combo_box: an #ESourceComboBox
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Returns the unique ID of the #ESource corresponding to the currently
Matthew Barnes 3b4059
+ * active item, or %NULL if there is no active item.
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Returns: a unique ID string or %NULL
Matthew Barnes 3b4059
+ **/
Matthew Barnes 3b4059
+const gchar *
Matthew Barnes 3b4059
+e_source_combo_box_get_active_uid (ESourceComboBox *source_combo_box)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	ESource *source;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	g_return_val_if_fail (source_combo_box != NULL, NULL);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	source = e_source_combo_box_get_active (source_combo_box);
Matthew Barnes 3b4059
+	if (source == NULL)
Matthew Barnes 3b4059
+		return NULL;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	return e_source_peek_uid (source);
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+/**
Matthew Barnes 3b4059
+ * e_source_combo_box_set_active_uid:
Matthew Barnes 3b4059
+ * @source_combo_box: an #ESourceComboBox
Matthew Barnes 3b4059
+ * @uid: a unique ID of an #ESource
Matthew Barnes 3b4059
+ *
Matthew Barnes 3b4059
+ * Sets the active item to the one corresponding to @uid.
Matthew Barnes 3b4059
+ **/
Matthew Barnes 3b4059
+void
Matthew Barnes 3b4059
+e_source_combo_box_set_active_uid (ESourceComboBox *source_combo_box,
Matthew Barnes 3b4059
+                                   const gchar *uid)
Matthew Barnes 3b4059
+{
Matthew Barnes 3b4059
+	ESourceComboBoxPrivate *priv;
Matthew Barnes 3b4059
+	GtkTreeRowReference *reference;
Matthew Barnes 3b4059
+	GtkComboBox *combo_box;
Matthew Barnes 3b4059
+	GtkTreeIter iter;
Matthew Barnes 3b4059
+	gboolean iter_was_set;
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	g_return_if_fail (source_combo_box != NULL);
Matthew Barnes 3b4059
+	g_return_if_fail (uid != NULL);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	priv = E_SOURCE_COMBO_BOX_GET_PRIVATE (source_combo_box);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	combo_box = GTK_COMBO_BOX (source_combo_box);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	reference = g_hash_table_lookup (priv->uid_to_row_reference, uid);
Matthew Barnes 2187af
+	g_return_if_fail (gtk_tree_row_reference_valid (reference));
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	iter_was_set = gtk_tree_model_get_iter (
Matthew Barnes 3b4059
+		gtk_combo_box_get_model (combo_box), &iter,
Matthew Barnes 3b4059
+		gtk_tree_row_reference_get_path (reference));
Matthew Barnes 2187af
+	g_return_if_fail (iter_was_set);
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+	gtk_combo_box_set_active_iter (combo_box, &iter);
Matthew Barnes 3b4059
+}
Matthew Barnes 3b4059
--- evolution-data-server-1.10.0/docs/reference/libedataserverui/libedataserverui-docs.sgml.code-cleanup	2007-03-12 01:23:42.000000000 -0400
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/docs/reference/libedataserverui/libedataserverui-docs.sgml	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -19,6 +19,7 @@
Matthew Barnes 3b4059
     <xi:include href="xml/e-name-selector-list.xml"/>
Matthew Barnes 3b4059
     <xi:include href="xml/e-name-selector-model.xml"/>
Matthew Barnes 3b4059
     <xi:include href="xml/e-passwords.xml"/>
Matthew Barnes 3b4059
+    <xi:include href="xml/e-source-combo-box.xml"/>
Matthew Barnes 3b4059
     <xi:include href="xml/e-source-option-menu.xml"/>
Matthew Barnes 3b4059
     <xi:include href="xml/e-source-selector.xml"/>
Matthew Barnes 3b4059
     <xi:include href="xml/e-source-selector-dialog.xml"/>
Matthew Barnes 3b4059
--- evolution-data-server-1.10.0/docs/reference/libedataserverui/libedataserverui.types.code-cleanup	2007-03-12 01:23:42.000000000 -0400
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/docs/reference/libedataserverui/libedataserverui.types	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -6,6 +6,7 @@
Matthew Barnes 3b4059
 #include <libedataserverui/e-name-selector-entry.h>
Matthew Barnes 3b4059
 #include <libedataserverui/e-name-selector-list.h>
Matthew Barnes 3b4059
 #include <libedataserverui/e-name-selector-model.h>
Matthew Barnes 3b4059
+#include <libedataserverui/e-source-combo-box.h>
Matthew Barnes 3b4059
 #include <libedataserverui/e-source-option-menu.h>
Matthew Barnes 3b4059
 #include <libedataserverui/e-source-selector.h>
Matthew Barnes 3b4059
 #include <libedataserverui/e-source-selector-dialog.h>
Matthew Barnes 3b4059
@@ -19,6 +20,7 @@
Matthew Barnes 3b4059
 e_name_selector_entry_get_type
Matthew Barnes 3b4059
 e_name_selector_list_get_type
Matthew Barnes 3b4059
 e_name_selector_model_get_type
Matthew Barnes 3b4059
+e_source_combo_box_get_type
Matthew Barnes 3b4059
 e_source_option_menu_get_type
Matthew Barnes 3b4059
 e_source_selector_get_type
Matthew Barnes 3b4059
 e_source_selector_dialog_get_type
Matthew Barnes 3b4059
--- evolution-data-server-1.10.0/docs/reference/libedataserverui/libedataserverui-sections.txt.code-cleanup	2007-03-12 01:23:42.000000000 -0400
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/docs/reference/libedataserverui/libedataserverui-sections.txt	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -25,6 +25,29 @@
Matthew Barnes 3b4059
 </SECTION>
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 <SECTION>
Matthew Barnes 3b4059
+<FILE>e-source-combo-box</FILE>
Matthew Barnes 3b4059
+<TITLE>ESourceComboBox</TITLE>
Matthew Barnes 3b4059
+ESourceComboBox
Matthew Barnes 3b4059
+e_source_combo_box_new
Matthew Barnes 3b4059
+e_source_combo_box_get_source_list
Matthew Barnes 3b4059
+e_source_combo_box_set_source_list
Matthew Barnes 3b4059
+e_source_combo_box_get_active
Matthew Barnes 3b4059
+e_source_combo_box_set_active
Matthew Barnes 3b4059
+e_source_combo_box_get_active_uid
Matthew Barnes 3b4059
+e_source_combo_box_set_active_uid
Matthew Barnes 3b4059
+<SUBSECTION Standard>
Matthew Barnes 3b4059
+E_SOURCE_COMBO_BOX
Matthew Barnes 3b4059
+E_IS_SOURCE_COMBO_BOX
Matthew Barnes 3b4059
+E_TYPE_SOURCE_COMBO_BOX
Matthew Barnes 3b4059
+E_SOURCE_COMBO_BOX_CLASS
Matthew Barnes 3b4059
+E_IS_SOURCE_COMBO_BOX_CLASS
Matthew Barnes 3b4059
+E_SOURCE_COMBO_BOX_GET_CLASS
Matthew Barnes 3b4059
+ESourceComboBoxClass
Matthew Barnes 3b4059
+<SUBSECTION Private>
Matthew Barnes 3b4059
+e_source_combo_box_get_type
Matthew Barnes 3b4059
+</SECTION>
Matthew Barnes 3b4059
+
Matthew Barnes 3b4059
+<SECTION>
Matthew Barnes 3b4059
 <FILE>e-source-option-menu</FILE>
Matthew Barnes 3b4059
 <TITLE>ESourceOptionMenu</TITLE>
Matthew Barnes 3b4059
 ESourceOptionMenu
Matthew Barnes 3b4059
--- evolution-data-server-1.10.0/calendar/libical/src/libicalss/icalssyacc.y.code-cleanup	2007-01-03 10:02:34.000000000 -0500
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/calendar/libical/src/libicalss/icalssyacc.y	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -47,6 +47,7 @@
Matthew Barnes 3b4059
 static void ssyacc_add_from(struct icalgauge_impl* impl, char* str1);
Matthew Barnes 3b4059
 static void set_logic(struct icalgauge_impl* impl,icalgaugelogic l);
Matthew Barnes 3b4059
 void sserror(char *s); /* Don't know why I need this.... */
Matthew Barnes 3b4059
+int sslex(void *YYPARSE_PARAM);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 %}
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
--- evolution-data-server-1.10.0/calendar/libical/src/libicalvcal/vcc.y.code-cleanup	2007-01-03 10:02:34.000000000 -0500
Matthew Barnes 89d907
+++ evolution-data-server-1.10.0/calendar/libical/src/libicalvcal/vcc.y	2007-04-04 12:08:04.000000000 -0400
Matthew Barnes 3b4059
@@ -170,6 +170,7 @@
Matthew Barnes 3b4059
 static void enterAttr(const char *s1, const char *s2);
Matthew Barnes 3b4059
 static void enterValues(const char *value);
Matthew Barnes 3b4059
 static void mime_error_(char *s);
Matthew Barnes 3b4059
+static int mime_lex(void);
Matthew Barnes 3b4059
 
Matthew Barnes 3b4059
 %}
Matthew Barnes 3b4059