2004-01-21  Nat Friedman <nat@novell.com>

	* gui/contact-editor/contact-editor.glade: Added missing
	entry-blog widget.

2004-01-21  Hans Petter Jansson  <hpj@ximian.com>

	* gui/component/addressbook-config.c (create_source_dir): Remove.
	(dialog_to_source): Don't create source dir, backend takes care of
	that now.

2004-01-21  Chris Toshok  <toshok@ximian.com>

	* gui/component/addressbook-component.c
	(addressbook_component_peek_gconf_client): new function.

	* gui/component/addressbook-component.h: add prototype for
	addressbook_component_peek_gconf_client.

	* gui/component/addressbook-migrate.c
	(migrate_completion_folders): more gross hacking.  migrate the
	completion settings.
	(get_source_by_uri): function to search for an ESource given the
	entire uri.  used for migrate_completion_folders.
	(migrate_ldap_servers): get_string_value -> get_string_child.
	same with get_integer_child.
	(get_string_child): rename to make it apparent it's a child, not a
	property.
	(get_integer_child): same.
	(addressbook_migrate): call migrate_completion_folders.

2004-01-21  Chris Toshok  <toshok@ximian.com>

	* gui/contact-editor/e-contact-editor.c (new_target_cb): call
	widget_changed here too, since we're changing the destination.

2004-01-20  Chris Toshok  <toshok@ximian.com>

	[ fixes bug #52955 ]
	* gui/merging/eab-contact-compare.c (use_common_book_cb): handle
	the case properly where there are no query parts (p == 0).
	Instead of passing "" to e_book_query_from_string, just set the
	query to NULL.

	* util/eab-book-util.c (eab_contact_list_to_string): we need to
	put a blank line here, so \r\n\r\n, not just \r\n.

2004-01-20  Chris Toshok  <toshok@ximian.com>

	* gui/component/addressbook-migrate.c (create_groups): deal with
	the groups/sources already being there.  Essentially make this
	function idempotent.
	(addressbook_migrate): unconditionally call create_groups now.
	move the version logic here from ipl_upgradeFromVersion, and
	include more versions in the set of those we upgrade from.

	* gui/component/addressbook-migrate.h: add major/minor/revision
	args to addressbook_migrate.

	* gui/component/addressbook-component.c (impl_upgradeFromVersion):
	remove the version logic from here.

2004-01-20 Sivaiah Nallagatla   <snallagatla@novell.com>

	* printing/e-contact-print.c (e_contact_print_response): do not 
	try to unref when query is NULL

2004 -01-20 Sivaiah Nallagatla  <snallagatla@novell.com>

	* gui/contact-editor/e-contact-editor.c (edit_im_clicked) : do not call
	gtk_tree_model_get when nothing in the list is selected 

2004-01-19  Hans Petter Jansson  <hpj@ximian.com>

	* gui/component/select-names/e-select-names.etspec: Get name from
	correct model column.

2004-01-19  Hans Petter Jansson  <hpj@ximian.com>

	* printing/e-contact-print.c (complete_sequence): Only unref if we
	have a query.

2004-01-19  Hans Petter Jansson  <hpj@ximian.com>

	* gui/component/addressbook-component.c
	(get_primary_source): Implement.
	(load_primary_selection): Use get_primary_source ().
	(impl_requestCreateItem): Use get_primary_source (), fixing a crash
	when we're asked to create a new item and we don't have the controls.

2004-01-16  Hans Petter Jansson  <hpj@ximian.com>

	* gui/component/addressbook.c (load_source_auth_cb): Don't run
	callback if the action was cancelled.
	(load_source_cb): Ditto.
	(addressbook_load_source): Return an ID for the load attempt.
	(addressbook_load_source_cancel): Implement, allows cancelling a
	load attempt.

	* gui/contact-editor/e-contact-editor.c (new_target_cb): Clear the
	values for in-progress load operation. Only unref new_book if it's
	non-NULL.
	(cancel_load): Implement. Cancels the load operation if one is in
	progress.
	(source_selected): Cancel any running load operation before starting
	a new one. Set up in-progress values.
	(e_contact_editor_init): Clear the in-progress values.
	(e_contact_editor_dispose): Cancel load operation.
	(e_contact_editor_set_property): If a new target book is set, cancel
	any conflicting load operation in progress.

	* gui/widgets/e-addressbook-view.c (set_paned_position): Remove
	debug output.
	(get_paned_position): Ditto.

2004-01-16  JP Rosevear <jpr@ximian.com>

	* gui/component/addressbook.c (set_prop): only set the menus and
	command state if we actually are already displayed, otherwise wait
	for activation

2004-01-15  Hans Petter Jansson  <hpj@ximian.com>

	* gui/widgets/e-addressbook-view.c (set_paned_position): Implement.
	(get_paned_position): Implement.
	(eab_view_new): Connect signal to get paned position changes.
	Remove old hack.
	(display_view): Set paned position properly.

2004-01-12  JP Rosevear <jpr@ximian.com>

	* gui/component/addressbook-component.c (impl_upgradeFromVersion):
	revert dumb upgrade change

2004-01-12  JP Rosevear <jpr@ximian.com>

	* gui/component/addressbook-component.c (impl_upgradeFromVersion):
	migrate from 1.5.0 and 1.5.1 properly

2004-01-12  JP Rosevear  <jpr@ximian.com>

	* gui/contact-editor/contact-editor.glade: de-bold ui elements

2004-01-09  Hans Petter Jansson  <hpj@ximian.com>

	* gui/component/addressbook-component.c (add_popup_menu_item): Take a
	sensitivity flag per menu item, and fall back to stock icons.
	(delete_addressbook_cb): Implement.
	(fill_popup_menu_callback): Reorder items, remove "remove" item, set
	sensitivity.

	* gui/component/ldap-config.glade: "Edit LDAP Server" ->
	"Addressbook Properties".

2004-01-11  Christian Hammond  <chipx86@gnupdate.org>

	* addressbook/gui/contact-editor/e-contact-editor-im.[ch],
	  addressbook/gui/contact-editor/im.glade: Added a dialog for
	  adding a new IM account.
	* addressbook/gui/contact-editor/Makefile.am: Added the previously
	  mentioned files, and depend on camel for necessary MIME parsing.

	* addressbook/gui/contact-editor/contact-editor.[ch],
	  addressbook/gui/contact-editor/contact-editor.glade: Add and implement

2004-01-09  Ross Burton  <ross@burtonini.com>

	* gui/component/select-names/e-select-names-completion.c:
	* gui/merging/eab-contact-compare.c:
	* gui/widgets/e-addressbook-model.c:
	* printing/e-contact-print.c:
	Update for API changes to e-book-async.

2004-01-08  Ross Burton  <ross@burtonini.com>

	* gui/contact-editor/contact-editor.glade:
	* gui/contact-editor/e-contact-editor.c:
	Add the video conferencing field.

2004-01-07  Rodney Dawes  <dobey@ximian.com>

	* gui/component/select-names/e-select-names.c:
	* gui/component/select-names/select-names.glade: Make the ESelectNames
	object be a HIG-compliant dialog, change "Folder" to be "Address Book",
	and fix a mnemonic conflict with "Category" and "Cancel"

	Fixes #51966

2004-01-07  Rodney Dawes  <dobey@ximian.com>

	* gui/component/addressbook-component.c: Move the smime_component_init
	call to the instance init callback, rather than the class init, and
	wrap it in #if HAVE_NSS, so the addressbook works without smime support

2004-01-07  JP Rosevear <jpr@ximian.com>

	* gui/component/Makefile.am: link in printer stuff

	Fixes #51172

2004-01-06  Chris Toshok  <toshok@ximian.com>

	* gui/component/addressbook-migrate.c (check_for_conflict): remove
	spew.
	(migrate_contacts): same.
	(migrate_contact_folder): same.
	(migrate_local_folders): same, and plug a leak.

2004-01-06  Chris Toshok  <toshok@ximian.com>

	* gui/component/Makefile.am (libevolution_addressbook_la_SOURCES):
	add addressbook-migrate.[ch].

	* gui/component/addressbook-component.c
	(addressbook_component_init): remove the source creation from
	here, it's in the migration code now.
	(impl_upgradeFromVersion): new function, call the
	addressbook-migration stuff.
	(addressbook_component_class_init): fill in
	epv->upgradeFromVersion, and call smime_component_init.
	(addressbook_component_peek_base_directory): new function.
	(addressbook_component_peek_source_list): same.

	* gui/component/addressbook-component.h: add prototypes for
	_peek_base_directory and _peek_source_list.

	* gui/component/addressbook-migrate.[ch]: add migration code to
	convert stuff from 1.x over to 1.5/2.0.

2004-01-06  Rodney Dawes  <dobey@ximian.com>

	* gui/contact-editor/e-contact-editor-address.c: Apply
	patch from Roozbeh Pournader to update countries list

	Fixes #48151

2004-01-06  JP Rosevear <jpr@ximian.com>

	* gui/component/select-names/e-select-names-popup.c
	(popup_info_cleanup): disconnect from selection-done signal

2004-01-05  JP Rosevear <jpr@ximian.com>

	* gui/component/addressbook.c
	(addressbook_show_load_error_dialog): these line breaks in the
	error messages should actually be spaces

	Fixes #51732
	
2003-12-19  Hans Petter Jansson  <hpj@ximian.com>

	* gui/component/addressbook-component.c (find_first_source): Impl.
	from calendar.
	(save_primary_selection): Implement, similar to calendar.
	(load_primary_selection): Implement, similar to calendar.
	(primary_source_selection_changed_callback): Save selection.
	(impl_createControls): Load selection.

2003-12-18  Hans Petter Jansson  <hpj@ximian.com>

	* gui/contact-editor/e-contact-editor.c (widget_changed):
	editable -> target_editable
	(e_contact_editor_get_property): Same.
	(_email_arrow_pressed): Same.
	(enable_writable_fields): Same.
	(set_editable): Same.
	(contact_added_cb): Make sure source book is editable before trying
	to remove contact from there.
	(e_contact_editor_init): Set up source/target editability.
	(command_state_changed): Allow save only if target editable. Allow
	delete only if source editable.
	(e_contact_editor_set_property): Set editability flags for
	source/target.

	* gui/contact-editor/e-contact-editor.h: Add source_editable,
	target_editable flags in place of old editable flag.

2003-12-17  Chris Toshok  <toshok@ximian.com>

	* gui/widgets/e-addressbook-view.c (eab_view_class_init): install
	the "source" property.
	(eab_view_init): init eav->source to NULL.
	(eab_view_dispose): disconnect the ecml_changed_id and unref
	source.
	(eab_view_new): create the search bar here.
	(view_preview): c&p the mailer's code mostly for this - this is
	the toggle listener for the Preview Pane menuitem.
	(setup_menus): add a listener for the ContactsViewPreview toggle.
	(eab_view_set_property): sensitize the search bar based on whether
	or not we have a book set.  This makes it so you can't search
	until the book is loaded.  Also add handling for the "source"
	attribute and print a warning when it's set multiple times
	(something that's not supported at the moment.)
	(eab_view_get_property): add "source" case.
	(search_activated, query_changed, compare_subitems, make_subitems,
	ecml_changed, get_master_list, connect_master_list_changed): move
	this here from addressbook.c
	(eab_view_show_contact_preview): implement - just show or hide the
	scrolled window.
	(eab_view_setup_menus): call e_search_bar_set_ui_component here,
	kind of a hack.

	* gui/widgets/e-addressbook-view.h: make this inherit from GtkVBox
	instead of GtkEventBox since we'll be packing children.  Add a
	prototype for eab_view_show_contact_preview.

	* gui/component/addressbook.c (get_current_view): return the
	EABView associated with the active notebook page.
	(save_contact_cb): use the current view.
	(view_contact_cb): same.
	(search_cb): same.
	(delete_contact_cb): same.
	(print_cb): same.
	(print_preview_cb): same.
	(stop_loading_cb): same.
	(cut_contacts_cb): same.
	(copy_contacts_cb): same.
	(paste_contacts_cb): same.
	(select_all_contacts_cb): same.
	(send_contact_cb): same.
	(send_contact_to_cb): same.
	(copy_contact_to_cb): same.
	(move_contact_to_cb): same.
	(update_command_state): same.
	(change_view_type): nuke, nothing uses this.
	(control_activate): use the current view.
	(control_activate_cb): same.
	(source_list_changed_cb): new function, remove the notebook pages
	(and destroy the EABView's) for sources that no longer exist.
	(addressbook_view_clear): dispose of the uid_to_view hash.
	(book_open_cb): store the ESource on the EABView too.  this
	function now takes a struct containing both EABView and ESource
	since we can't store either in the AddressbookView.
	(set_prop): if we have a view already for this uid, bring it up.
	otherwise create a new one and start the book loading.
	(addressbook_search_activated): nuked - this is being moved to
	e-addressbook-view.
	(addressbook_query_changed): same.
	(compare_subitems, make_subitems, ecml_changed,
	connect_master_list_changed): same.
	(addressbook_new_control): simplify things a bunch.  create a
	notebook to store the views in.  the search/vbox stuff is gone.
	use e_source_list_new_for_gconf_default, and handle the source
	list's "changed" signal.
	
2003-12-17  Rodney Dawes  <dobey@ximian.com>

	* gui/component/autocompletion-config.c:
	(autocompletion_config_control_new): Embed Tree in GtkScrolledWindow

2003-12-16  Hans Petter Jansson  <hpj@ximian.com>

	* gui/contact-editor/e-contact-editor.c (contact_added_cb): Update
	the contact's UID after normal add.

2003-12-16  Hans Petter Jansson  <hpj@ximian.com>

	* gui/component/addressbook.c (addressbook_show_load_error_dialog):
	Make a public function that shows an error dialog, which can be used
	when a source fails to load.
	(book_open_cb): Call addressbook_show_load_error_dialog () on error.
	(set_prop): Don't reuse the book when loading a new source. This was
	confusing the contact-editor, which gets the book passed in.

	* gui/contact-editor/e-contact-editor.c (e_contact_editor_class_init):
	Make "source_book" and "target_book" distinct properties.
	(new_target_cb): Implement.
	(source_selected): Implement.
	(contact_moved_cb): Implement.
	(contact_added_cb): Handle the case where source_book != target_book as
	a move - if the add was successful, remove contact from source book.
	(save_contact): Handle case where source_book != target_book.
	(delete_cb): "book" renamed to "source_book".
	(e_contact_editor_init): Set up source_selected signal.
	(e_contact_editor_dispose): Dispose of both source and target books.
	(e_contact_editor_new): "book" renamed to "source_book".
	(e_contact_editor_set_property): If a source book is set, and we don't
	have a target book, make target_book == source_book. Allow setting
	target book, and base editability on that. If we're editing an existing
	contact, treat book change as a change, and update command state.
	(e_contact_editor_get_property): Allow getting target book.
	(set_source_field): Indicate the selected book.

2003-12-16  Hans Petter Jansson  <hpj@ximian.com>

	* gui/contact-editor/e-contact-editor.c (set_source_field): Implement.
	Makes the source menu reflect the source for the current book.

2003-12-16  Hans Petter Jansson  <hpj@ximian.com>

	* gui/contact-editor/e-contact-editor.c
	(e_contact_editor_create_source_option_menu): Implement. Creates
	source selection option menu.

	* gui/contact-editor/contact-editor.glade: Add source selection custom
	widget.

2003-12-16  Hans Petter Jansson  <hpj@ximian.com>

	* gui/widgets/e-addressbook-table-adapter.c
	(addressbook_is_cell_editable): Disable cell editing.

2003-12-15  Hans Petter Jansson  <hpj@ximian.com>

	* gui/contact-editor/e-contact-editor.c (address_to_text): Implement.
	(text_to_address): Implement, using EAddressWestern.
	(address_text_changed): Adapt to EContactAddress.
	(full_addr_clicked): Ditto. Fix field IDs.
	(e_contact_editor_init): Init address_choice.
	(_email_arrow_pressed): Fix field IDs.
	(_address_arrow_pressed): Adapt to EContactAddress and fix field IDs.
	(find_address_mailing): Leave out for now. Addresses don't have flags
	anymore...
	(set_fields): Adapt to EContactAddress and fix field IDs. Make sure
	changes to other widgets don't make us go back to the first listed
	address.
	(set_address_field): Adapt to EContactAddress and fix field IDs.
	(enable_writable_fields): Ditto.
	(fill_in_info): Disable find_address_mailing () for now.

2003-12-10  Hans Petter Jansson  <hpj@ximian.com>

	* gui/contact-editor/e-contact-editor-address.c
	(e_contact_editor_address_class_init): Make "address" a boxed type.
	(e_contact_editor_address_init): Set address to NULL.
	(e_contact_editor_address_dispose): Free address.
	(e_contact_editor_address_new): Take an EContactAddress.
	(e_contact_editor_address_set_property): Re-implement setting the
	address property.
	(e_contact_editor_address_get_property): Ditto for getting.
	(fill_in_info): Enable, use EContactAddress fields.
	(extract_info): Ditto.

	* gui/contact-editor/e-contact-editor-address.h:
	Re-enable the address field, as EContactAddress.

2003-12-09  JP Rosevear <jpr@ximian.com>

	* gui/contact-list-editor/e-contact-list-editor.c (fill_in_info):
	free email list properly

2003-12-09  JP Rosevear <jpr@ximian.com>

	* gui/contact-list-editor/e-contact-list-editor.c (extract_info):
	free the list, not unref it, and free the elements

	Fixes #51976
	
2003-12-06  Chris Toshok  <toshok@ximian.com>

	* gui/component/select-names/e-select-names-manager.c
	(open_book_cb): change prototype to fix warning, and change the
	comment to read load_source instead of load_uri (which isn't what
	we use anymore.)
	(update_completion_books): just use our source list for this.
	check the "completion" source property.
	(source_list_changed): recreate the completion books.
	(e_select_names_manager_init): connect to the source_list's
	changed signal.
	(e_select_names_manager_dispose): don't need to free the
	completion_uids list anymore.

	* gui/component/select-names/e-select-names-config.c
	(e_select_names_config_get_completion_books,
	e_select_names_config_set_completion_books,
	e_select_names_config_add_notification_completion_books): remove.

	* gui/component/select-names/e-select-names-config.h: remove the
	completion books calls, since we can just use the source list.

	* gui/component/component-factory.c (factory): create the
	autocompletion control.

	* gui/component/autocompletion-config.[ch]: new config control for
	selecting completion folders.  Uses e-source-selector.  Could
	probably be beautified a bit.
	
	* gui/component/Makefile.am (libevolution_addressbook_la_SOURCES):
	add autocompletion-config.[ch]

	* gui/component/GNOME_Evolution_Addressbook.server.in.in: remove
	the ldap config control server, and add the autocompletion one.

2003-12-06  JP Rosevear <jpr@ximian.com>

	* */Makefile.am: Remove hard coded disable deprecated flags
	
2003-12-05  JP Rosevear <jpr@ximian.com>

	* gui/component/select-names/select-names.glade: no more custom
	widget for the selection of the search source

	* gui/component/select-names/e-select-names.h: add member

	* gui/component/select-names/e-select-names.etspec: update model
	column

	* gui/component/select-names/e-select-names.c (find_first_source):
	find the first source in the list
	(addressbook_model_set_source): we have the source to set directly
	now
	(source_selected): listen for the source item to change
	(e_select_names_init): create a source option menu and hook it up
	(e_select_names_dispose): destroy the source list
	(e_select_names_new): do away with the config setup here

	* gui/component/select-names/e-select-names-manager.h: update
	members

	* gui/component/select-names/e-select-names-manager.c
	(update_completion_books): add books based on source uid
	(config_completion_books_changed_cb): handle the completion list
	changing
	(config_min_query_length_changed_cb): handle minimum query length
	changing
	(e_select_names_manager_new): we don't do the settings stuff here
	any more
	(e_select_names_manager_init): do the initial set up here for the
	book loaded and listen for changes
	(e_select_names_manager_dispose): destroy the new stuff

	* gui/component/select-names/e-select-names-config.[hc]: config
	information

	* gui/component/select-names/e-select-names-config-keys.h: the
	config keys

	* gui/component/select-names/e-select-names-bonobo.c
	(impl_SelectNames_activate_dialog): do away with the shell client
	stuff

	* gui/component/select-names/Makefile.am: build new files

2003-12-05  Chris Toshok  <toshok@ximian.com>

	* gui/widgets/e-addressbook-model.c (book_view_loaded): call
	remove_book_view/free_data here as well, to guard against multiple
	book_view's being loaded.

2003-12-05  Hans Petter Jansson  <hpj@ximian.com>

	* gui/widgets/e-addressbook-view.etspec: Clean up and sync with
	current model columns.

2003-12-04  Christian Hammond  <chipx86@gnupdate.org>

	* addressbook/gui/contact-editor/e-contact-editor-im.[ch],
	  addressbook/gui/contact-editor/im.glade: Added a dialog for
	  adding a new IM account.
	* addressbook/gui/contact-editor/Makefile.am: Added the previously
	  mentioned files, and depend on camel for necessary MIME parsing.

	* addressbook/gui/contact-editor/contact-editor.[ch],
	  addressbook/gui/contact-editor/contact-editor.glade: Add and implement
	  the Instant Messaging tab.

2003-12-03  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/addressbook.c
	(retrieve_shell_view_interface_from_control): Remove.
	(set_folder_bar_label): Remove.
	(addressbook_new_control): Don't connect.

2003-12-03  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/addressbook-config.c: Do not depend on
	e-folder-list.

	* gui/component/select-names/e-select-names.c: Remove dependency
	on evolution-folder-selector-button.
	(e_addressbook_create_folder_selector): Just return a FIXME label
	for now.
	(folder_selected): #if 0 out.
	(e_select_names_init): Do not connect.

	* gui/component/select-names/e-select-names-manager.c
	(e_select_names_manager_activate_dialog): Don't get a shell_client
	arg anymore.
	(load_completion_books): Stub out.

	* gui/component/select-names/e-select-names.c
	(e_select_names_new): Don't get an EvolutionShellClient anymore.
	Don't create the folder selector button for now.

	* gui/component/select-names/e-select-names.h: Remove dependency
	on evolution-shell-client.

	* gui/component/select-names/e-select-names-bonobo.c: Remove
	dependency on evolution-shell-client.
	(impl_SelectNames_activate_dialog): Stub out.

	* gui/widgets/eab-gui-util.c: Remove dependency on
	evolution-shell-client.
	(eab_transfer_contacts): Stub out.

2003-12-02  Rodney Dawes  <dobey@ximian.com>

	* gui/component/Makefile.am: Version the schemas
	* gui/component/apps_evolution_addressbook.schemas: Removed
	* gui/component/apps_evolution_addressbook.schemas.in.in: Added

2003-12-02  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/addressbook.c (set_status_message): Call
	e_activity_handler_operation_finished() on the current activity ID
	when done.

2003-12-01  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/addressbook.c (struct AddressbookView): Replace
	activity_client with activity_id.
	(set_status_message): Use the EActivityHandler from the
	AddressbookComponent.

	* gui/component/addressbook-component.c (struct
	_AddressbookComponentPrivate): New member activity_handler.
	(addressbook_component_init): Init.
	(impl_dispose): Unref.
	(addressbook_component_peek_activity_handler): New.
	(impl_createControls): Return an ETaskBar as the statusbar control
	and attach it to the activity handler.

2003-12-01  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/addressbook-component.c (impl_createControls):
	Pass a label for the status bar control for now.

2003-12-01  Larry Ewing  <lewing@ximian.com>

	* gui/component/Makefile.am (INCLUDES): remove
	GTK_DISABLED_DEPRECATED so that we can build with gtk-2.3.

2003-12-01  Rodney Dawes  <dobey@ximian.com>

	* gui/component/GNOME_Evolution_Addressbook.server.in.in:
	* gui/component/addressbook-config.c:
	* gui/component/addressbook.c:
	* gui/component/component-factory.c:
	* gui/component/select-names/GNOME_Evolution_Addressbook_SelectNames.server.in.in:
	* gui/component/select-names/e-select-names-bonobo.c:
	* gui/component/select-names/e-select-names-factory.c:
	* gui/widgets/eab-gui-util.c:
	* gui/widgets/eab-vcard-control.c: Use BASE_VERSION for repo_ids and
	  OAFIIDs

2003-12-01  Hans Petter Jansson  <hpj@ximian.com>

	* gui/component/ldap-config.glade: Fix start page text.

2003-12-01  JP Rosevear <jpr@ximian.com>

	* conduit/Makefile.am: use privconduitdir

	* conduit/e-address.conduit.in: subst right thing

2003-12-01  JP Rosevear <jpr@ximian.com>

	* conduit/e-address.conduit.in: specify privlibdir as the location

	* conduit/Makefile.am: install the conduit to privlibdir

2003-12-01  JP Rosvear <jpr@ximian.com>

	* conduit/Makefile.am: version the .conduit file

2003-12-01  Hans Petter Jansson  <hpj@ximian.com>

	* gui/component/new-addressbook.glade: Remove this too.

	* gui/component/Makefile.am (glade_DATA): Remove new-addressbook.glade.

2003-12-01  Hans Petter Jansson  <hpj@ximian.com>

	* gui/component/Makefile.am (libevolution_addressbook_la_SOURCES):
	Remove addressbook-storage.[ch] and new-addressbook.[ch].

	* gui/component/addressbook-storage.[ch]: Removed from repository.

	* gui/component/new-addressbook.[ch]: Removed from repository.

	* gui/component/addressbook-component.c (load_uri_for_selection):
	Set source_uid property on view control, not folder_uri.
	(new_addressbook_cb): Call addressbook_config_create_new_source ().
	(edit_addressbook_cb): Implement.
	(fill_popup_menu_callback): Hook up edit_addressbook_cb ().
	(addressbook_component_init): Create the LDAP source group.

	* gui/component/addressbook-config.c (AddressbookSourceDialog):
	Take out the NEW_ADVANCED_UI stuff and add ESource related vars.
	(ldap_unparse_auth)
	(ldap_parse_auth)
	(ldap_unparse_scope)
	(ldap_unparse_ssl)
	(ldap_parse_ssl): Moved here from addressbook-storage.c.
	(addressbook_dialog_get_source)
	(addressbook_dialog_set_source)
	(objectclasses_create_server_table)
	(objectclasses_create_evolution_table)
	(objectclasses_add_foreach)
	(objectclasses_add)
	(objectclasses_sever_double_click)
	(objectclasses_remove_foreach)
	(objectclasses_remove)
	(objectclasses_evolution_double_click)
	(objectclasses_restore_default)
	(server_selection_model_changed)
	(evolution_selection_model_changed)
	(setup_objectclasses_tab): Nuke aging, unfinished NEW_ADVANCED_UI.
	(add_source_clicked)
	(edit_source_clicked)
	(delete_server)
	(delete_source_clicked)
	(ldap_config_control_destroy_callback)
	(ldap_config_control_apply_callback)
	(sources_selection_changed)
	(sources_table_row_activated)
	(ldap_dialog_new)
	(addressbook_dialog_create_sources_table)
	(ldap_config_control_new)
	(addressbook_config_control_new): Nuke config control.
	(create_source_dir)
	(dialog_to_source)
	(dialog_to_temp_source)
	(source_to_uri_parts)
	(source_to_dialog)
	(source_group_changed_cb)
	(source_group_menu_add_groups)
	(folder_page_forward)
	(finish_page_back): Implement.
	(addressbook_ldap_init): Take ESource instead of AddressbookSource.
	(addressbook_ldap_auth): Don't take a source, not needed.
	(addressbook_root_dse_query): Ditto.
	(addressbook_source_dialog_destroy): Clean up destroy function.
	(addressbook_add_server_druid_finish): Clean up, create ESource.
	(general_tab_check): If it's not LDAP, these options don't matter.
	(do_ldap_root_dse_query): Source no longer needed here.
	(query_for_supported_bases): Use a temp source generated from
	current dialog settings.
	(display_name_page_prepare): Renamed to folder_page_prepare ().
	(druid_display_name_page_modify_cb): Renamed to
	druid_folder_page_modify_cb ().
	(addressbook_add_server_druid): Set up source list, group selector.
	Make LDAP pages optional, dependent on selected group. Use ESource.
	(edit_dialog_store_change): Remove config control list stuff,
	export settings to ESource.
	(addressbook_edit_server_dialog): Renamed to
	addressbook_config_edit_source (), which takes an ESource. Remove
	config control list stuff, make LDAP pages show up only if we have
	an LDAP source. Remove NEW_ADVANCED_UI cruft.
	(addressbook_config_create_new_source): Just call
	addressbook_add_server_druid ().

	* gui/component/addressbook-config.h: Move LDAP enums here, from
	addressbook-storage.h.

	* gui/component/addressbook.c (control_activate_cb): uri -> source
	(addressbook_view_clear): Unref source list.
	(book_open_cb): Use ESource.
	(load_uri_auth_cb): Renamed to load_source_auth_cb (), manipulate
	ESource instead of URI.
	(get_remember_password): Implement.
	(set_remember_password): Implement.
	(addressbook_authenticate): Use ESource properties.
	(load_uri_cb): Renamed to load_source_cb (), ESource adaptation.
	(addressbook_load_uri): Renamed to addressbook_load_source (), takes
	ESource.
	(addressbook_load_default_book): ESource adaptation.
	(get_prop): folder_uri property -> source_uid property.
	(set_prop): folder_uri property -> source_uid property. Find ESource
	by UID.
	(addressbook_new_control): Set up source_uid property and ESourceList.

	* gui/component/component-factory.c (factory): Disable config control.

	* gui/component/ldap-config.glade: Druid and notebook dialogs
	generalized to deal with local sources as well as LDAP. This file
	should probably be renamed...

	* gui/component/select-names/e-select-names-manager.c
	(load_completion_books): Use addressbook_load_source (). However, this
	needs a bit more work to get source UIDs instead of URIs.

	* gui/component/select-names/e-select-names.c
	(addressbook_model_set_uri): Use addressbook_load_source (). However,
	this needs a bit more work to get source UIDs instead of URIs.

2003-11-26  JP Rosevear  <jpr@ximian.com>

	* gui/widgets/Makefile.am: turn on deprecated gtk and libgnomeui
	stuff

	* gui/component/select-names/Makefile.am: turn on deprecated gtk
	stuff

	* gui/contact-editor/Makefile.am: ditto
	
2003-11-17  Hans Petter Jansson  <hpj@ximian.com>

	* gui/component/addressbook-component.c (impl_createControls): Store
	a ref to the source selector.
	(impl_requestCreateItem): Implement.
	(impl_dispose): Unref the source selector.
	(addressbook_component_init): Set up default sources.

	* gui/widgets/e-addressbook-model.c (eab_model_set_property): If
	the 'book' property is set, and editability changes, emit a signal
	to that effect.

2003-11-14  JP Rosevear <jpr@ximian.com>

	* gui/component/new-addressbook.c: include e-source from e-d-s

2003-11-13  Hans Petter Jansson  <hpj@ximian.com>

	* gui/contact-list-editor/e-contact-list-model.c
	(contact_list_is_cell_editable): Return TRUE for all cells, for now.

	* gui/widgets/e-addressbook-table-adapter.c (card_modified_cb):
	Renamed to contact_modified_cb ().
	(addressbook_set_value_at): Port to use EContact instead of ECard.
	(addressbook_is_cell_editable): Ditto.
	(addressbook_append_row): Ditto.

	* gui/widgets/e-minicard-label.c (e_minicard_label_set_property):
	Make not editable, ever, and add a comment to this effect.
	(e_minicard_label_realize): Ditto.

	* gui/widgets/e-minicard.c (e_minicard_set_property): Ditto.
	(add_field): Ditto.

2003-11-13  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/addressbook-component.c
	(impl__get_userCreatableItems): New, implementation for the
	userCreatableItems property.
	(impl_requestCreateItem): New, implementation for the
	requestCreateItem method.
	(addressbook_component_class_init): Install.

2003-11-12  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/GNOME_Evolution_Addressbook.server.in.in: Add
	component_alias of "contacts".

2003-11-08  Hans Petter Jansson  <hpj@ximian.com>

	* gui/component/Makefile.am (libevolution_addressbook_la_SOURCES):
	Add new-addressbook.[ch].
	(glade_DATA): Add new-addressbook.glade.

	* gui/component/addressbook-component.c (add_popup_menu_item):
	Implement.
	(new_addressbook_cb): Implement.
	(delete_addressbook_cb): Implement (skeletal).
	(fill_popup_menu_callback): Implement.
	(impl_createControls): Hook up fill_popup_menu_callback().

	* gui/component/new-addressbook.[ch]: New files.

	* gui/component/new-addressbook.glade: New file.

2003-11-07  Dan Winship  <danw@ximian.com>

	* util/Makefile.am (INCLUDES): Remove some includes of directories
	that don't exist any more

2003-11-07  JP Rosevear <jpr@ximian.com>

	* gui/contact-editor/Makefile.am: don't include the c marshaller
	file twice

	* gui/widgets/Makefile.am: ditto
	
2003-11-07  JP Rosevear <jpr@ximian.com>

	* gui/widgets/Makefile.am: make sure the marshal header is in the
	source list

	* gui/component/select-names/Makefile.am: ditto

	* gui/contact-editor/Makefile.am: ditto

	* gui/contact-list-editor/Makefile.am: ditto
	
2003-11-07  JP Rosevear <jpr@ximian.com>

	* util/Makefile.am: dist the marshal list

2003-11-07  JP Rosevear <jpr@ximian.com>

	* gui/widgets/e-addressbook-view.c (change_view_type): don't
	destroy the widget here - its dead when removed from the paned
	container

2003-11-07  JP Rosevear <jpr@ximian.com>

	* In the gui this is a search and replace commit for moving the
	addressbook to evolution-data-server; it also deletes the old
	backend files

2003-11-05  Larry Ewing  <lewing@ximian.com>

	* gui/widgets/e-addressbook-view.c (create_minicard_view): fix cast.

2003-11-03  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/select-names/e-select-names-factory.c: Update
	factory ID.

	* gui/component/select-names/GNOME_Evolution_Addressbook_SelectNames.server.in.in:
	Version the SelectNames server IDs by appending a "_2".

2003-11-03  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/GNOME_Evolution_Addressbook.server.in.in: Change
	"evolution:config_item" into "evolution2:config_item".

2003-10-29  Chris Toshok  <toshok@ximian.com>

	* gui/component/GNOME_Evolution_Addressbook.server.in.in: add the
	S/MIME config control here.

2003-10-29  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-book-listener.c (e_book_listener_new): change
	the poa hint to PER_REQUEST.  fixes a couple of deadlocks.

2003-10-29  Chris Toshok  <toshok@ximian.com>

	* gui/component/component-factory.c (factory): ifdef the smime
	code with HAVE_NSS.

	* gui/component/Makefile.am (libevolution_addressbook_la_LIBADD):
	conditionally include libevolution-smime.la.

2003-10-24  Dan Winship  <danw@ximian.com>

	* backend/pas/Makefile.am (libpas_la_LIBADD): libpas should depend
	on libebook, but NOT on libpasfile, etc, since it needs to be
	linked into all backends, not just the wombat.
	(libpasfile_la_LIBADD): depend on libpas.la and libedb3util.la
	(libpasvcf_la_LIBADD): depend on libpas.la
	(libpasldap_la_LIBADD): depend on libpas.la and  $(LDAP_LIBS)

2003-10-23  Dan Winship  <danw@ximian.com>

	* backend/ebook/e-contact.c (e_contact_date_equal): new util func

	* backend/pas/pas-backend-ldap.c (anniversary_compare,
	birthday_compare): Use it

	* backend/pas/pas-backend-summary.c
	(pas_backend_summary_check_contact): Check if an ID exists in the
	summary.

2003-10-23  Chris Toshok  <toshok@ximian.com>

	* tools/Makefile.am: convert 8 spaces to a tab.

	* tools/.cvsignore: ignore evolution-addressbook-abuse and
	evolution-addressbook-clean.

	* gui/component/Makefile.am (libevolution_addressbook_la_LIBADD):
	add libevolution-smime.la.

	* gui/component/component-factory.c (factory): add the certificate
	manager config control stuff here, at least for now.

	* gui/component/GNOME_Evolution_Addressbook.server.in.in: same.

2003-10-23  Rodrigo Moya <rodrigo@ximian.com>

	* gui/component/addressbook-config.c
	(addressbook_dialog_create_source_table): fixed typo in variable name.

2003-10-22  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/GNOME_Evolution_Addressbook.server.in.in: Add an
	"evolution:button_icon" attribute.

2003-10-22  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/GNOME_Evolution_Addressbook.server.in.in: Add an
	"evolution:button_sort_order" property.

2003-10-22  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/addressbook-component.c (impl_createControls):
	Make the the scrolled window have an "in" shadow.
	* gui/component/addressbook-config.c
	(addressbook_dialog_create_sources_table): Likewise.
	* gui/widgets/e-addressbook-view.c (create_minicard_view): Likewise.
	(create_treeview_view): Likewise.

2003-10-22  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/addressbook-component.c (impl_createControls): Set
	the GtkScrolledWindow scrollbar policy to "automatic" for both the
	horizontal and the vertical scrollbar.

2003-10-22  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/GNOME_Evolution_Addressbook.server.in.in: Add an
	"evolution:button_label" property on the component for use in the
	shell.

2003-10-21  JP Rosevear <jpr@ximian.com>
 
 	* conduit/address-conduit.c: make it work with the new ebook api
 
 	* backend/pas/pas-book.c (pas_book_respond_get_changes): put the
 	vcard in for every change
 
 	* backend/pas/pas-backend.c (pas_backend_change_add_new): just use
 	the vcard field
 	(pas_backend_change_modify_new): ditto
 	(pas_backend_change_delete_new): ditto
 
 	* backend/pas/pas-backend-file.c
 	(pas_backend_file_changes_foreach_key): create a fake contact with
 	the uid
 	(pas_backend_file_get_changes): add the card to the changes
 
 	* backend/ebook/tests/ebook/test-changes.c (main): just print the
 	uid
 
 	* backend/ebook/e-book.c (e_book_free_change_list): unref the
 	contact
 
 	* backend/ebook/e-book-types.h: the change struct contains an
 	EContact now
 
 	* backend/ebook/e-book-listener.c
 	(impl_BookListener_respond_get_changes): create the contact from
 	the vcard string
 
 	* backend/idl/addressbook.idl: Book change item is no longer a
 	union, it always gives back a card
	
2003-10-21  Chris Toshok  <toshok@ximian.com>

	* tools/evolution-addressbook-abuse.c: use the synchronous api for
	this.  simplifies it a bunch.

2003-10-21  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-book.c
	(impl_GNOME_Evolution_Addressbook_Book_remove): we can ill afford
	bad debug spew.
	(view_listener_died_cb): implement.
	(impl_GNOME_Evolution_Addressbook_Book_getBookView): hook up an
	ORBit_small connection listener on the view's listener.
	(pas_book_respond_create): use e_contact_get_const instead of
	e_contact_get here.  fixes a leak.

	* backend/pas/pas-book-view.c
	(impl_GNOME_Evolution_Addressbook_BookView_stop): implement, call
	pas_backend_stop_book_view.
	(pas_book_view_get_listener): return the book view's listener.
	(pas_book_view_class_init): fill in epv->stop.
	(pas_book_view_init): use a #define for THRESHOLD_MAX instead of
	the constant.

	* backend/pas/pas-book-view.h: add prototype for
	pas_book_view_get_listener.

	* backend/pas/pas-backend.c (pas_backend_stop_book_view):
	implement.
	(pas_backend_remove_book_view): implement.

	* backend/pas/pas-backend.h: add prototype for stop_book_view and
	remove_book_view.

	* backend/pas/pas-backend-vcf.c (load_file): pass in the fd and
	use fdopen here.
	(foreach_build_list): don't creat EContacts here, because we'll
	just be converting them back to vcards anyway.
	(save_file): use char*'s instead of EContacts, and split entries
	with 2 blank lines.  Also, hold the lock over the entire function.
	(do_create): hold the lock around uid generation and touching the
	hash table.
	(pas_backend_vcf_process_remove_contacts): same.
	(pas_backend_vcf_process_modify_contact): same.
	(pas_backend_vcf_stop_book_view): new function, but leave
	unimplemented for now.
	(pas_backend_vcf_load_uri): the uri contains the directory name,
	not the filename.
	(pas_backend_vcf_dispose): grab the lock here just for sanity's
	sake.  Also reorder things a bit, and free the hashtable and
	mutex.
	(pas_backend_vcf_init): init the mutex.

	* backend/pas/pas-backend-summary.c
	(pas_backend_summary_add_contact): don't unref the contact here.

	* backend/pas/pas-backend-ldap.c
	(pas_backend_ldap_process_stop_book_view): new function, but leave
	unimplemented for now.

	* backend/pas/pas-backend-file.c (build_summary): use an EContact
	for this call.
	(do_summary_query): nuke, the contents of this has been moved to
	start_book_view.
	(pas_backend_file_search_timeout): same.
	(pas_backend_file_search): same.
	(pas_backend_file_start_book_view): glom everything into here
	involving searching.  This function could (and should) be renamed
	and reused from both this function and _get_contact_list.
	(pas_backend_file_stop_book_view): new function.
	(pas_backend_file_class_init): fill in backend->stop_book_view.

	* backend/pas/Makefile.am (LDAP_BACKEND): libpasldap.a ->
	libpasldap.la
	(noinst_LTLIBRARIES): *.a -> *.la.
	(libpas_la_SOURCES): same.
	(libpasfile_la_SOURCES): same.
	(libpasvcf_la_SOURCES): same.
	(libpasldap_la_SOURCES): same.

	* backend/idl/addressbook.idl: add BookView::stop.

	* backend/ebook/e-vcard.c (read_attribute_value): fix GString
	related leaks.
	(read_attribute_params): same.
	(parse): don't leak the EVCardAttributes corresponding to
	BEGIN/END:vCard.
	(free_gstring): new function
	(e_vcard_attribute_remove_values): free the decoded_values list,
	using free_gstring.

	* backend/ebook/e-book.c (e_book_response_get_book_view): ref the
	listener here.

	* backend/ebook/e-book-view.h: add prototype for e_book_view_stop.

	* backend/ebook/e-book-view.c (e_book_view_stop): new function.

	* backend/ebook/e-book-async.c (_get_book_view_response_dtor):
	unref the book view.

2003-10-20  Dan Winship  <danw@ximian.com>

	* backend/pas/pas-book-view.c: Queue up removes and modifies as
	well as adds, and remove the calls that took a list of changes
	rather than a single change, since no one was really using the
	list versions. Keep a list of IDs currently in the view so we can
	more easily figure out what changes count as adds, modifies, and
	removes.
	(send_pending_adds): Don't reset next_threshold if it's being
	called from notify_add.
	(send_pending_changes, send_pending_removes): New
	(pas_book_view_notify_update): Simplified add/change interface.
	Takes an EContact and figures out if it's new, modified, or
	removed relative to this view.
	(pas_book_view_notify_change, pas_book_view_notify_change_1,
	pas_book_view_notify_add, pas_book_view_notify_add_1): Gone.
	(pas_book_view_notify_remove): Now does what remove_1 used to do.
	(pas_book_view_vcard_matches): Remove this; no longer used.

	* backend/pas/pas-backend.c (pas_backend_notify_update): New.
	Calls pas_book_view_notify_update() on each of the backend's views.
	(pas_backend_notify_remove): Likewise for notify_remove().
	(pas_backend_notify_complete): And notify_complete().

	* backend/pas/pas-book.c (pas_book_respond_create): Take an
	EContact instead of an id and a vcard. Use
	pas_backend_notify_update.
	(pas_book_respond_remove_contacts): Use pas_backend_notify_remove.
	(pas_book_respond_modify): Take a single EContact instead of two
	vcards. Use pas_backend_notify_update.

	* backend/pas/pas-backend-sync.c
	(pas_backend_sync_create_contact): Return an EContact rather than
	an id.
	(pas_backend_sync_modify_contact): Return an EContact rather than
	the old_vcard.
	(_pas_backend_create_contact, _pas_backend_modify_contact): Update

	* backend/pas/pas-backend-file.c (do_summary_query): Use
	pas_book_view_notify_update.
	(pas_backend_file_search_timeout): Likewise
	(pas_backend_file_create_contact): Update for API changes
	(pas_backend_file_modify_contact): Likewise.

	* backend/pas/pas-backend-ldap.c (create_contact_handler,
	pas_backend_ldap_process_create_contact): Update for API changes
	(modify_contact_modify_handler, modify_contact_search_handler,
	pas_backend_ldap_process_modify_contact): Likewise
	(ldap_search_handler): Use pas_book_view_notify_update

	* backend/pas/pas-backend-vcf.c (foreach_search_compare): Use
	pas_book_view_notify_update.
	(pas_backend_vcf_process_create_contact): Update for API changes
	(pas_backend_vcf_process_modify_contact): Likewise

	* backend/pas/pas-backend-summary.c
	(pas_backend_summary_add_contact): Take an EContact instead of a
	const char *vcard.

	* backend/ebook/e-contact.c (photo_getter): s/malloc/g_malloc/

2003-10-20  JP Rosevear <jpr@ximian.com>

	* backend/pas/pas-backend-vcf.c (pas_backend_vcf_search): compiler
	with non-c99 compilers

2003-10-17  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-contact.c (fn_getter): new function, just return
	the full name value.
	(fn_setter): rather distasteful hack.  set the N attribute if it's
	not already present.
	(n_setter): set the X-EVOLUTION-FILE-AS attribute if it's not
	already set.

	* backend/pas/pas-backend-ldap.c (prop_info): add PROP_WRITE_ONLY
	flag for properties (right now just 'sn') that we don't want to
	use when building the EContact - we only use it when storing the
	contact out to the ldap server.
	(build_contact_from_entry): skip WRITE_ONLY properties.

2003-10-17  Chris Toshok  <toshok@ximian.com>

	* gui/widgets/e-addressbook-view.c (init_collection): add the
	minicard factory back in.
	(display_view): add the minicard case back in.
	(get_selection_model): same.
	(minicard_right_click): resurrect.
	(create_minicard_view): same.
	(change_view_type): add the minicard case back in.
	(eab_view_print): same.
	(eab_view_print_preview): same.

	* gui/widgets/e-addressbook-view.h (EABViewType): add MINICARD
	back in.

	* gui/widgets/e-addressbook-model.c (eab_model_new):
	E_TYPE_AB_MODEL -> EAB_TYPE_MODEL.

	* gui/widgets/e-addressbook-model.h: rename E_TYPE_AB_MODEL to
	EAB_TYPE_MODEL.

	* gui/widgets/Makefile.am (libeabwidgets_la_SOURCES): add the
	minicard stuff back into the build.

	* gui/widgets/e-addressbook-reflow-adapter.[ch],
	gui/widgets/e-minicard-label.[ch],
	gui/widgets/e-minicard-view-widget.[ch],
	gui/widgets/e-minicard-view.[ch], gui/widgets/e-minicard.[ch],
	gui/widgets/gal-view-factory-minicard.[ch], gal-view-minicard.h:
	resurrect the minicard stuff, in a new uneditable,
	EContact-friendly state.  no in-place editing anymore.

	
2003-10-10  Chris Toshok  <toshok@ximian.com>

	* gui/contact-editor/e-contact-editor.c (fill_in_info): un-ifdef
	the date handling code.
	(extract_info): same.

	* backend/pas/pas-backend-ldap.c (prop_info): add the address
	labels and dates to the build.
	(anniversary_populate): un-ifdef and get this working.
	(anniversary_ber): same.
	(anniversary_compare): same.
	(birthday_populate): same.
	(birthday_ber): same.
	(birthday_compare): same.

	* backend/ebook/tests/ebook/.cvsignore,
	backend/ebook/tests/ebook/Makefile.am
	backend/ebook/tests/ebook/test-date.c: add a test for EContactDate
	getting/setting.
	
	* backend/ebook/e-vcard.h: add EVC_BDAY.

	* backend/ebook/e-contact.h: add prototypes for the
	e_contact_date_* functions.

	* backend/ebook/e-contact.c (field_info): add
	BIRTH_DATE/ANNIVERSARY fields.
	(date_getter): new
	(date_setter): new
	(e_contact_date_new): new
	(e_contact_date_from_string): new
	(e_contact_date_to_string): new
	(e_contact_date_free): new

2003-10-10  Not Zed  <NotZed@Ximian.com>

	*
	gui/component/select-names/GNOME_Evolution_Addressbook_SelectNames.server.in.in:
	Use the main factory on the .so file, so it can be found.

2003-10-08  Chris Toshok  <toshok@ximian.com>

	* gui/component/select-names/e-select-names.c (contact_key): add a
	descriptive comment about this "#if notyet".

	* gui/component/select-names/e-select-names-model.h
	(e_select_names_model_thaw): add prorotype for
	e_select_names_model_cancel_all_contact_load.

	* gui/component/select-names/e-select-names-bonobo.c
	(_EntryPropertyID): remove the SIMPLE_CARD_LIST property.
	(entry_get_property_fn): same.
	(impl_SelectNames_get_entry_for_section): same.

	* backend/ebook/e-contact.h: add prototype for
	e_contact_name_to_string.

2003-10-07  Chris Toshok  <toshok@ximian.com>

	* util/eab-book-util.c: remove a bunch of ifdef'ed code (that's
	going to be living in e-book.c)

	* backend/pas/pas-backend-summary.c
	(pas_backend_summary_add_contact): un-ifdef some code.
	(pas_backend_summary_get_summary_vcard): same.

	* backend/pas/pas-backend-ldap.c (prop_info): remove the
	query_prop field since we can get it from e_contact_field_name.
	also remove it from all the macros and their uses.
	(homephone_populate): un-ifdef.
	(homephone_ber): same.
	(homephone_compare): same.
	(business_populate): same.
	(business_ber): same.
	(business_compare): same.
	(query_prop_to_ldap): use e_contact_field_name to get the query
	prop for a given attribute.
	(add_oc_attributes_to_supported_fields): same.

	* backend/pas/pas-backend-card-sexp.c (compare_phone): use the new
	EContactField constants to iterate over the phone list.

	* backend/ebook/e-contact.h (EContactField): add some useful
	constants for those pieces of code that iterate over
	email/phones/addresses.

2003-10-07  Chris Toshok  <toshok@ximian.com>

	* gui/widgets/eab-vcard-control.c (book_open_cb): un-ifdef this.
	(eab_vcard_control_new): put the buttons above the vcard so they
	don't move when it's expanded.

	* gui/widgets/eab-popup-control.h: remove prototypes for
	eab_popup_control_set_name and eab_popup_control_set_email.

	* gui/widgets/eab-popup-control.c (email_table_ok_cb): remove the
	stupid idle function and do the work here.
	(eab_popup_control_set_name): make this static - noone uses it.
	(eab_popup_control_set_email): same.

	* gui/widgets/eab-gui-util.c (eab_show_contact_editor):
	e_contact_editor_new is what we use for the time being.

	* gui/widgets/eab-contact-display.c (render_string): abstract this
	code out.
	(render_url): same.
	(eab_contact_display_render_normal): make use of render_string and
	render_url.

	* gui/widgets/e-addressbook-view.c (delete): un-ifdef this and get
	it working.
	(selection_received): same.

	* gui/widgets/e-addressbook-model.c (get_view): nuke some code
	that was moved to another function.
	(eab_model_set_property): get the writable state when we set the
	book - don't rely on the timing of signals.

	* gui/contact/editor/contact-editor.glade: add the blog field
	below the homepage url field.
	
	* gui/contact/editor/e-contact-editor-address.[ch]: get this
	building with the new stuff.
	
	* gui/contact/editor/e-contact-editor-fullname.[ch]: get this
	building with the new stuff.
	
	* gui/contact-editor/e-contact-editor.[ch]: get this most of the
	way there.
	
	* gui/contact-editor/e-contact-quick-add.[ch]: get this building
	with the new stuff.

	* gui/contact-editor/Makefile.am (libecontacteditor_la_SOURCES):
	remove e-contact-save-as.[ch].  They're in
	addressbook/widgets/eab-gui-util.[ch] now.

	* gui/merging/Makefile.am: track all the naming changes.
	
	* gui/merging/*.glade: gratuitous renaming.
	
	* gui/merging/eab-contact-compare.[ch]: gratuitous renaming, and
	move this from the old ebook/

	* gui/merging/eab-contact-merging.[ch]: gratuitous renaming.

	* backend/ebook/e-contact.[ch]: lots of overly complicated changes
	for an overly complicated piece of code.

	* backend/ebook/e-book-view.c (e_book_view_do_added_event): remove
	some ifdef'ed code.
	(e_book_view_do_modified_event): same.

	* backend/ebook/e-vcard.c (parse): plug a memory leak.
	(escape_string): deal with @s being NULL.
	(e_vcard_remove_attribute): new function.
	(e_vcard_attribute_remove_params): same.
	(e_vcard_attribute_param_free): same.
	(e_vcard_attribute_param_remove_values): same.

	* backend/ebook/e-vcard.h: add prototypes for
	e_vcard_remove_attribute, e_vcard_attribute_remove_params, and
	e_vcard_attribute_param_remove_values.

	* backend/ebook/e-book.c (e_book_handle_response): cache the
	writable state of the ebook before generating the signal.
	(e_book_unload_uri): initialize cap to NULL and writable to FALSE.

	* backend/ebook/e-book.h: add prototype for e_book_is_writable.

	* backend/ebook/e-book-async.c (_get_fields_response_handler):
	don't call the callback if it's NULL.
	(_get_methods_response_handler): same.
	(_auth_user_response_handler): same.
	(_get_contact_response_handler): same.
	(_remove_contacts_response_handler): same.
	(_add_contact_response_handler): same.
	(_commit_contact_response_handler): same.
	(_get_book_view_response_handler): same.
	(_get_contacts_response_handler): same.
	(_remove_contacts_dtor): free the list.
	(e_book_async_remove_contacts): duplicate the list.

	* backend/pas/pas-backend.c (pas_backend_open): if we successfully
	load the uri, report the writable status back.

	* backend/pas/pas-backend-sync.c (_pas_backend_remove_contacts):
	free the list of ids.

	* backend/pas/pas-backend-file.c (do_create): return the contact
	we create here.
	(pas_backend_file_create_contact): format the newly created
	contact as a string to add to the summary.
	(pas_backend_file_remove_contacts): don't free the list of removed
	cards here - it happens in pas-backend-sync.
	(pas_backend_file_load_uri): pass NULL for @contact to do_create.

2003-10-01  Chris Toshok  <toshok@ximian.com>

	* gui/widgets/eab-contact-display.c (render_address): move the :'s
	inside the <b>'s.  Thanks for pointing this out, guenther. :)
	(eab_contact_display_render_normal): same.
	(eab_contact_display_render_compact): same.

	* gui/widgets/eab-vcard-control.c (save_in_addressbook): track
	change to address_load_default_book.

2003-10-01  Chris Toshok  <toshok@ximian.com>

	* gui/component/Makefile.am: remove some commented out crap about
	e-address-popup.[ch].

	* gui/component/component-factory.c (factory): use
	eab_popup_control_new for the AddressPopup iid.

	* gui/widgets/Makefile.am (libeabwidgets_la_SOURCES): add
	eab-popup-control.[ch].

	* backend/ebook/e-book.c (e_book_get_default_addressbook): hack
	this so it at least sorta works - hardcode the
	~/evolution/local/Contacts uri for now.

	* gui/component/addressbook.[ch] (addressbook_load_default_book):
	remove the EBook argument, and call
	e_book_async_get_default_addressbook.

	* gui/component/e-address-popup.[ch]: nuke.
	
	* gui/widgets/eab-popup-control.c: rename
	gui/component/e-address-popup.c to this.

	* gui/widgets/eab-popup-control.h: rename
	gui/component/e-address-popup.h to this.

	* backend/ebook/e-book-async.h: add prototype for
	e_book_async_get_default_addressbook.
	
	* backend/ebook/e-book-async.c
	(e_book_async_get_default_addressbook): new function.

2003-10-01  Chris Toshok  <toshok@ximian.com>

	* gui/widgets/e-addressbook-view.c (eab_view_new): create the
	scrolled window to embed the EABContactDisplay widget inside of.

	* gui/widgets/e-addressbook-view.h (struct _EABView): add scrolled;

	* gui/widgets/eab-contact-display.h: add
	EABContactDisplayRenderMode enum, and add @render_mode arg to
	eab_contact_display_render.

	* gui/widgets/eab-contact-display.c
	(eab_contact_display_render_compact): new function, render a
	compact format suitable for inclusion in the mail display.
	(eab_contact_display_render_normal): move the previouw contents of
	eab_contact_display_render here.
	(eab_contact_display_render): render in either compact or normal
	mode depending on @mode.
	(eab_contact_display_new): remove the scrolled window stuff from
	here, as in the compact mode we don't want it present.  push it up
	into the e-addressbook-view.c code.
	
	* gui/widgets/eab-vcard-control.[ch]: bonobo control that wraps up
	the EABContactDisplay stuff and lets us display vcards in a pretty
	format in mail messages.
	
	* gui/component/component-factory.c (factory): replace the #if
	notyet'ed minicard control code with the new vcard control.

	* gui/component/Makefile.am (INCLUDES): remove gui/minicard.

	* gui/component/GNOME_Evolution_Addressbook.server.in.in: remove
	the MiniCard_Control iid, and replace it with VCard_Control.

2003-10-01  Chris Toshok  <toshok@ximian.com>

	* gui/component/addressbook-component.c
	(destination_folder_handle_drop): use
	eab_contact_list_from_string, and un-"#if notyet" this.

	* gui/component/addressbook.c: remove #include
	"e-contact-save-as.h"

	* gui/contact-list-editor/e-contact-list-editor.c
	(file_save_as_cb): use eab_contact_save.
	(file_send_as_cb): use eab_send_contact, un-"#if notyet" this.
	(file_send_to_cb): same.
	(table_drag_data_received_cb): use eab_contact_list_from_string.

	* gui/widgets/e-addressbook-reflow-adapter.[ch]: nuke.  last
	vestiges of the minicard view.
	
	* gui/widgets/e-addressbook-view.c (eab_view_init):
	s/clipboard_cards/cliboard_contacts.
	(eab_view_dispose): same.
	(get_contact_list_1): s/card/contact
	(get_contact_list): same.
	(save_as): same, and use eab_contact_list_save.
	(send_as): reenable this code, s/card/contact, and use
	eab_send_contact_list.
	(send_to): same.
	(print): s/card/contact.
	(delete): same.
	(new_card): same, and un-"#if notyet" some code.
	(selection_get): use eab_contact_list_to_string.
	(selection_clear_event): s/card/contact
	(selection_received): same.
	(get_selected_contacts): same.
	(eab_view_save_as): same, and use eab_contact_list_save.
	(eab_view_view): same, and use eab_show_multiple_contacts.
	(eab_view_send): reenable this code, s/card/contact, and use
	eab_send_contact_list.
	(eab_view_send_to): same.
	(eab_view_copy): s/card/contact.
	(view_transfer_contacts): same.
	(eab_view_copy_to_folder): same.
	(eab_view_move_to_folder): same.

	* gui/widgets/e-addressbook-view.h (struct _EABView): rename
	clipboard_cards to clipboard_contacts.

	* gui/widgets/eab-gui-util.c (view_contacts): un-"#if notyet"
	(file_exists): moved from e-contact-save-as.c
	(save_it): same.
	(close_it): same.
	(destroy_it): same.
	(make_safe_filename): same.
	(eab_contact_save): same, and renamed from e_contact_save_as.
	(eab_contact_list_save): same, and renamed from
	e_contact_list_save_as.
	(contact_deleted_cb): s/card/contact.
	(do_delete): same, and use e_book_async.
	(delete_contacts): s/card/contact.
	(process_unref): same.
	(contact_added_cb): same.
	(do_copy): same, and use e_book_async.
	(got_book_cb): same.
	(eab_transfer_contacts): same, and use e_book_async.
	(eab_send_contact_list): s/card/contact
	(eab_send_contact): same.

	* gui/widgets/eab-gui-util.h: some random s/card/contact work, and
	move the contents of e-contact-save-as.h here.

	* util/eab-book-util.c (eab_contact_list_from_string): rename
	eab_load_contacts_from_string to this.
	(eab_contact_list_to_string): new function.

	* util/eab-book-util.h: add prototype for
	eab_contact_list_to_string, and rename
	eab_load_contacts_from_string to eab_contact_list_from_string.

	* gui/contact-editor/e-contact-save-as.[ch]: nuke.  the contents
	of these files has been wrapped up in
	gui/widgets/eab-gui-util.[ch].
	
2003-09-30  Chris Toshok  <toshok@ximian.com>

	* gui/component/Makefile.am (libevolution_addressbook_la_LIBADD):
	add libecontactlisteditor.la back into the build.

	* gui/component/addressbook-component.c (new_item_cb): enable the
	contact list editor portion.

	* util/eab-book-util.c (eab_load_contacts_from_string): new
	function, return a GList of EContact*'s parsed from the string.

	* util/eab-book-util.h: add prototype for
	eab_load_contacts_from_string.

	* gui/contact-list-editor/contact-list-editor.glade: set the id of
	the list-image widget.

	* gui/contact-list-editor/e-contact-list-editor.c
	(e_contact_list_editor_class_init): PROP_CARD -> PROP_CONTACT.
	(e_contact_list_editor_init): initialize image_buf to null and
	card -> contact.  also, hook up the dnd signals on the list_image
	widget so we can drop images.
	(e_contact_list_editor_dispose): free the image_buf.
	(list_added_cb): card -> contact.
	(list_modified_cb): same.
	(save_contact): same, and use the ebook-async api.
	(prompt_to_save_changes): card -> contact.
	(file_save_cb): same.
	(file_save_as_cb): same.
	(file_send_as_cb): #if notyet for now.
	(file_send_to_cb): same.
	(tb_save_and_close_cb): card -> contact.
	(list_deleted_cb): same.
	(delete_cb): same.
	(delete_cb): same, and use ebook-async.
	(e_contact_list_editor_new): card -> contact.
	(e_contact_list_editor_set_property): same.
	(table_drag_motion_cb): use GDK_POINTER_TO_ATOM instead of
	casting.
	(table_drag_data_received_cb): use eab_load_contacts_from_string,
	and card -> contact.
	(set_image_from_data): new function. create a pixbuf from the
	image data and composite it in an image that's the same size as
	the initial list_image widget.
	(image_drag_motion_cb): new function.
	(image_drag_drop_cb): new function.
	(image_drag_data_received_cb): new function.
	(extract_info): port to EContact, and add support for the image.
	(fill_in_info): same.

	* gui/contact-list-editor/e-contact-list-editor.h (struct
	_EContactListEditor): add image stuff, and ECard -> EContact.

	* gui/contact-list-editor/e-contact-list-model.c
	(contact_list_value_at): e_destination -> eab_destination.
	(e_contact_list_model_init): same.
	(e_contact_list_model_add_destination): same.
	(e_contact_list_model_add_email): same.
	(e_contact_list_model_add_contact): same, and card -> contact.
	(e_contact_list_model_remove_row): e_destination ->
	eab_destination.
	(e_contact_list_model_get_destination): same.

	* gui/contact-list-editor/e-contact-list-model.h: card -> contact,
	and e-destination -> eab-destination.

	* gui/widgets/e-addressbook-view.etspec: fix a couple of
	fields.. this needs a completely once-over at some point soon.

	* gui/widgets/e-addressbook-view.c (table_double_click): reenable
	all of this.

	* gui/widgets/eab-contact-display.c (render_address): use
	e_text_to_html to convert the \n's to <br>'s.
	(on_url_requested): get PHOTO if there is one, otherwise LOGO.
	(eab_contact_display_render): escape all the text we're sending to
	gtkhtml with e_text_to_html.  also, if it's a contact list, output
	_("List Members") with the contents of _EMAIL.

	* gui/widgets/eab-gui-util.h: rename eab_send_card{_list} to
	eab_send_contact{_list}.

2003-09-30  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/tests/ebook/Makefile.am (noinst_PROGRAMS): add
	test-string.

	* backend/ebook/tests/ebook/test-string.c: test setting/getting a
	string attribute.

	* backend/ebook/e-contact.c (photo_setter): do gnome-vfs mime type
	sniffing before we set the attribute value.
	(e_contact_set_property): implement setting of MULTI list
	attributes (like MAIL).
	(e_contact_get_property): rework the ATTR_TYPE attribute handling
	so we aren't calling g_value_set_pointer on a value that holds a
	string (and vice versa).

	* backend/ebook/e-vcard.c (e_vcard_remove_attributes): implement.
	(e_vcard_attribute_add_param): use g_ascii_strcasecmp.

	* backend/ebook/e-vcard.h: rename e_vcard_remove_attribute to
	e_vcard_remove_attributes, since it removes all matching
	attributes.

	* backend/ebook/e-book.c (e_book_response_add_contact): we need to
	strdup the id here since the listener frees it.
	(e_book_handle_response): implement the WritableStatusEvent part
	of the switch.

	* backend/ebook/e-book-listener.c
	(impl_BookListener_report_writable): un-"#if notyet" this.

	* backend/ebook/e-book-async.c (_add_contact_handler): fill in
	response->id.

2003-09-29  Chris Toshok  <toshok@ximian.com>

	* printing/e-contact-print-envelope.c: card -> contact.

	* printing/e-contact-print-envelope.h: card -> contact.

	* printing/e-contact-print.c: card -> contact.

	* printing/e-contact-print.h: card -> contact.

	* printing/Makefile.am (contact_print_test_LDADD): add
	libeabutil.la and reorder things so it links.
	(contact_print_style_editor_test_LDADD): same.

2003-09-29  Chris Toshok  <toshok@ximian.com>

	* gui/component/select-names/e-select-names-text-model.c:
	e-addressbook-util.h -> eab-gui-util.h.

	* gui/component/select-names/e-select-names-popup.c:
	e-addressbook-util.h -> eab-gui-util.h.

	* gui/component/e-address-popup.c: e-addressbook-util.h ->
	eab-gui-util.h.

	* gui/component/component-factory.c: #if notyet the minicard
	control stuff, since it's been completely nuked from the tree.

	* gui/component/addressbook.c: e-addressbook-util.h ->
	eab-gui-util.h.

	* gui/component/addressbook-component.c: e-addressbook-util.h ->
	eab-gui-util.h.

	* gui/component/Makefile.am (libevolution_addressbook_la_LIBADD):
	rename libeminicard to libeabwidgets.

	* Makefile.am (SUBDIRS): add util/ to the build.

2003-09-29  Chris Toshok  <toshok@ximian.com>

	* gui/widgets/e-addressbook-treeview-adapter.c:
	e-addressbook-util.h -> eab-gui-util.h, and convert some
	EDestination code to EABDestination.

	* gui/widgets/e-addressbook-table-adapter.c: e-addressbook-util.h
	-> eab-gui-util.h, and include util/eab-destination.h.
	(addressbook_value_at): un-#if 0 some code.

	* gui/widgets/e-addressbook-model.c: e-addressbook-util.h ->
	eab-gui-util.h

	* gui/widgets/e-addressbook-view.c: e-addressbook-util.h ->
	eab-gui-util.h

	* gui/widgets/e-minicard-control.c,
	gui/widgets/e-minicard-control.h, gui/widgets/e-minicard-label.c,
	gui/widgets/e-minicard-label.h,
	gui/widgets/e-minicard-view-widget.c,
	gui/widgets/e-minicard-view-widget.h,
	gui/widgets/e-minicard-view.c, gui/widgets/e-minicard-view.h,
	gui/widgets/e-minicard-widget-test.c,
	gui/widgets/e-minicard-widget.c, gui/widgets/e-minicard-widget.h,
	gui/widgets/e-minicard.c, gui/widgets/e-minicard.h,
	test-minicard-label.c, test-minicard-view.c, test-minicard.c: nuke
	all of the old minicard stuff.
	
	* gui/widgets/eab-gui-util.[ch]: rename e-addressbook-util.[ch] to
	this and nuke e-addressbook-util.[ch].
	
	* gui/widgets/Makefile.am (INCLUDES): change G_LOG_DOMAIN to
	eab-widgets, and add -I$(top_srcdir)/addressbook.
	(noinst_LTLIBRARIES): rename to libeabwidgets.la
	(libeabwidgets_la_SOURCES): rename e-addressbook-util.[ch] to
	eab-gui-util.[ch].

2003-09-29  Chris Toshok  <toshok@ximian.com>

	* gui/widgets/eab-contact-display.c (eab_contact_display_new):
	track change from E_TYPE_AB_CONTACT_DISPLAY to
	EAB_TYPE_CONTACT_DISPLAY.

	* gui/widgets/eab-contact-display.h: change from E_* type foo to
	EAB_* type foo.

2003-09-29  Chris Toshok  <toshok@ximian.com>

	* gui/search/e-addressbook-search-dialog.[ch]: convert everything
	from e_addressbook_search_dialog to eab_search_dialog, and
	EAddressbookSearchDialog to EABSearchDialog.

	* gui/component/addressbook.c (search_cb):
	e_addressbook_search_dialog -> eab_search_dialog.
	(addressbook_search_activated): same.
	(addressbook_query_changed): same.

2003-09-29  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-book.c (pas_book_respond_get_supported_fields):
	don't free the fields here - the backends hold onto them.
	(pas_book_respond_get_supported_auth_methods): don't free the
	auth_methods here - the backends hold onto them.

	* backend/pas/pas-backend-file.c
	(pas_backend_file_get_supported_fields): fields go from 1 to
	E_CONTACT_FIELD_LAST, not 0.

2003-09-29  Chris Toshok  <toshok@ximian.com>

	* gui/component/addressbook.c: e-book-util.h -> eab-book-util.h

	* gui/component/addressbook-component.c: e-book-util.h ->
	eab-book-util.h.
	(new_item_cb): enable the contact editor portion of this.
	(user_create_new_item_cb): convert to async_load_uri api, and
	ifdef the _use_default_book crap.
	(ensure_completion_uris_exist): e_book_get_config_database ->
	eab_get_config_database.

	* gui/component/e-address-widget.h: e-book-util.h ->
	eab-book-util.h.

	* gui/component/Makefile.am (libevolution_addressbook_la_LIBADD):
	add selectnames back in, and add util/libeabutil.la.

2003-09-29  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-contact.c: my head explodes from so many
	changes.

	* backend/ebook/e-contact.h: reorder fields such that all the
	string fields are first in the enum (and add a
	E_CONTACT_LAST_SIMPLE_STRING value, ala the old e-card-simple
	stuff.)  Also, add E_CONTACT_LOGO, WANTS_HTML, IS_LIST, and
	LIST_SHOW_ADDRESSES.  remove E_CONTACT_PHOTO_URI.

	* backend/ebook/e-vcard.c (e_vcard_remove_attribute): rename from
	e_card_remove_attribute, and add a g_assert_not_reached.
	(_evc_base64_encode_simple): make this not static (we need it for
	a test.)
	(_evc_base64_decode_simple): same.

	* backend/ebook/e-vcard.h: add LOGO, X-MOZILLA-HTML,
	X-EVOLUTION-LIST, and X-EVOLUTION-LIST-SHOW_ADDRESSES #defines.
																
	* backend/ebook/e-book.c (EBookLoadState): change from
	UriNotLoaded to E_BOOK_URI_NOT_LOADED, etc.
	(e_book_add_contact): track _URI_ change.
	(e_book_get_supported_fields): same.
	(e_book_get_supported_auth_methods): same.
	(e_book_authenticate_user): same.
	(e_book_get_contact): same.
	(e_book_response_get_contact): remove the ifdefed call to
	e_contact_set_book.
	(e_book_remove_contacts): track _URI_ change.
	(e_book_get_book_view): same.
	(e_book_get_contacts): same.
	(e_book_get_changes): same.
	(e_book_remove): same.
	(e_book_unload_uri): same.
	(e_book_load_uri): same.
	(e_book_load_uri): same.
	(e_book_get_self): start the implementation of this.
	(e_book_get_default_addressbook): ifdef out a possible
	implementation of this (it's broken.)
	(e_book_init): track _URI_ change.
	(e_book_dispose): same.
																
	* backend/ebook/e-book.h: move get_default_addressbook out of the
	ifdef, and change get_default_addressbook/get_addressbooks to be
	more like the rest of the api.
																
	* backend/ebook/e-book-util.[ch]: nuke.
																
	* backend/ebook/e-card-compare.[ch]: nuke.
																
	* backend/ebook/e-destination.[ch]: nuke.
																
	* backend/ebook/e-book-query.c (func_and): fix valgrind error.
	(func_or): same.
																
	* backend/ebook/e-book-listener.h: drop #include of e-list.h
																
	* backend/ebook/e-book-async.c (_get_contacts_response_handler)
	(_get_contacts_response_dtor, _get_contacts_handler)
	(_get_contacts_dtor, e_book_async_get_contacts): new functions,
	implementing e_book_async_get_contacts.
																
	* backend/ebook/e-book-async.h: add e_book_async_get_contacts.

2003-09-29  Chris Toshok  <toshok@ximian.com>

	* util/eab-marshal.list: new file.

	* util/eab-destination.[ch]: rename
	backend/ebook/e-destination.[ch] to this, and change all the entry
	point names too.

	* util/eab-book-util.[ch]: rename backend/ebook/e-book-util.[ch]
	to this, and change all the entry point names too.

	* util/Makefile.am: new file, build libeabutil.la

2003-09-29  Chris Toshok  <toshok@ximian.com>

	* gui/component/select-names/e-select-names.c
	(addressbook_model_set_uri): e_addressbook_model -> eab_model.
	(contact_key): e-contactify this, and remove the call to
	e_contact_get_book since we don't have it.
	(sync_one_model): card -> contact.
	(real_add_address_cb): track various name changes.
	(esn_get_key_fn): same.
	(e_addressbook_create_ebook_table): same.
	(folder_selected): same.
	(select_entry_changed): same.
	(e_select_names_new): same.

	* gui/component/select-names/e-select-names-text-model.c
	(dump_model): s/card/contact.
	(e_select_names_text_model_insert_length): e-destination ->
	eab-destination.
	(e_select_names_text_model_delete): same.
	(e_select_names_text_model_obj_count): same.
	(nth_obj_index): same.
	(e_select_names_text_model_activate_obj): ifdef this out since we
	don't have e_contact_get_book in the new api.

	* gui/component/select-names/e-select-names-table-model.c
	(fill_in_info): convert to e_contact/eab_destination.

	* gui/component/select-names/e-select-names-popup.c
	(change_email_num_cb): e_destination -> eab_destination.
	(populate_popup_contact): same, and ECard -> EContact.  Also, the
	email attribute is a GList, not an EList.  lastly, rename from
	populate_popup_card.
	(populate_popup_nocontact): same, and rename from
	populate_popup_nocard.
	(e_select_names_populate_popup): same.

	* gui/component/select-names/e-select-names-model.h: track changes
	to e_destination, and rename the cardify methods to something mode
	descriptive.

	* gui/component/select-names/e-select-names-model.c
	(e_select_names_model_duplicate): e_destination ->
	eab_destination.
	(e_select_names_model_get_textification): same.
	(e_select_names_model_get_address_text): same.
	(e_select_names_model_get_destination): same.
	(e_select_names_model_export_destinationv): same.
	(send_changed): same.
	(e_select_names_model_import_destinationv): same.
	(e_select_names_model_get_contact): same, and rename from
	_get_card
	(e_select_names_model_get_string): same.
	(connect_destination): same.
	(disconnect_destination): same.
	(e_select_names_model_contains): same.
	(e_select_names_model_insert): same.
	(e_select_names_model_append): same.
	(e_select_names_model_replace): same.
	(e_select_names_model_delete): same.
	(e_select_names_model_clean): same.
	(delete_all_iter): same.
	(e_select_names_model_overwrite_copy): same.
	(e_select_names_model_merge): same.
	(e_select_names_model_name_pos): same.
	(e_select_names_model_text_pos): same.
	(e_select_names_model_cardify): nuke.
	(e_select_names_model_uncardify): nuke.
	(e_select_names_model_cancel_cardify): nuke.
	(e_select_names_model_load_all_contacts): rename _cardify_all to
	this.
	(e_select_names_model_cancel_all_contact_load): rename
	_cancel_cardify to this.

	* gui/component/select-names/e-select-names-manager.c
	(focus_in_cb): cancel_cardify_all -> cancel_all_contact_load
	(focus_out_cb): cardify_all -> load_all_contacts.
	(completion_popup_cb): same.
	(load_completion_books): no e_book_expand_uri anymore.
	(e_select_names_manager_new): e_book_get_config_database ->
	eab_get_config_database.
	(e_select_names_manager_dispose): same.

	* gui/component/select-names/e-select-names-completion.h: e-book.h
	-> e-book-async.h

	* gui/component/select-names/e-select-names-completion.c:
	EContactify this.

	* gui/component/select-names/e-select-names-bonobo.c
	(entry_get_property_fn): ifdef out the SIMPLE_CARD_LIST getter,
	and cardify_all -> load_all_contacts.

	* gui/component/select-names/Evolution-Addressbook-SelectNames.idl:
	nuke all the SimpleCard stuff.  It's a horribly inefficient way to
	deal with vcards, and since ebook is platform level now, we can
	(and should) promote just linking to ebook to do this.

2003-09-19  Gilbert Fang  <gilbert.fang@sun.com>

       * addressbook/gui/component/addressbook-component.c (xfer_folder):
         remove the "addressbook.db.summary" correctly. #48538

2003-09-11  Dan Winship  <danw@ximian.com>

	* backend/ebook/Makefile.am (privlib_LTLIBRARIES): Remove
	libebook-static.la

	* conduit/Makefile.am (libeaddress_conduit_la_LIBADD): Use
	non-static versions of libraries: the static ones were only needed
	for libtool 1.3.

2003-09-07  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-contact.c (e_contact_get_property): implement
	getters for the address labels.  they aren't really synthetic, but
	we can't handle them as normal strings because they switch off the
	TYPE parameter, not the attribute name (go go vcard.)  Also add
	getters for the structured address fields (ADR).  Also fix a spot
	where we were using strcmp instead of strcasecmp.
	(e_contact_address_free): new function.

	* backend/ebook/e-contact.h: Add EContactAddress structure, which
	will probably go away once i merge in my cool spiffy address
	editor.  Add LABEL fields for the address labels, and add
	prototype for e_contact_address_free.

	* backend/ebook/e-vcard.h: add EVC_LABEL and EVC_X_BLOG_URL.

	* backend/ebook/e-vcard.c (read_attribute_value): step to the next
	character after unescaping \-escaped characters.  keeps commas
	from multiplying.

	* gui/widgets/eab-contact-display.c (render_address): new function
	(eab_contact_display_render): display email, delivery addresses,
	and the blog url.

2003-09-06  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-contact.c (e_contact_set_property): implement
	E_CONTACT_EMAIL_*.

	* backend/pas/pas-backend-ldap.c (email_ber): EContact-ify and
	re-enable this code.
	(email_compare): same.
	(email_populate): same.

	* backend/pas/pas-backend-vcf.c (pas_backend_vcf_load_uri): use
	XIMIAN_VCARD.

	* backend/pas/pas-backend-file.c (pas_backend_file_load_uri): use
	XIMIAN_VCARD, and don't fail if the directory already exists.
	just try to create the db anyway.

	* backend/pas/Makefile.am (libpas_a_SOURCES): add ximian-vcard.h

	* backend/pas/ximian-vcard.h (XIMIAN_VCARD): put the initial vcard
	here, so we can share 1 #define between file/vcf backends.  Also,
	add a jpeg photo.

2003-09-06  Chris Toshok  <toshok@ximian.com>

	* gui/widgets/Makefile.am (libeminicard_la_SOURCES): add
	eab-contact-display.[ch]

	* gui/widgets/e-addressbook-view.c (eab_view_init): just init
	everything to NULL.
	(eab_view_new): move a bunch of stuff that was in eab_view_init
	here.  create a vpaned to hold the contact display, and create the
	contact display.
	(render_contact): render the selected contact to the
	contact_display.
	(selection_changed): add logic to display the currently selected
	contact in the preview pane.
	(create_table_view): add the table to the paned.
	(create_treeview_view): add the scrolled to the paned.
	(change_view_type): remove view->widget from the paned.

	* gui/widgets/e-addressbook-view.h: switch from using a GtkTable
	to a GtkEventBox - we don't need the table logic anymore.

	* gui/widgets/e-addressbook-model.c (create_contact): indent
	(eab_model_get_contact): same.

	* gui/widgets/eab-contact-display.[ch]: new files - this
	implements the preview pane.
	
2003-09-06  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-backend-ldap.c (BINARY_PROP): new type of
	property, for specifying data coming back from the ldap server
	with both data/length (like photos).
	(photo_populate): set the contact's photo.
	(build_contact_from_entry): add PROP_TYPE_BINARY handling.

	* backend/ebook/e-vcard.c (EVCardEncoding): new enum for use with
	the ENCODING attribute parameter.  Right now, just "raw",
	"base64", and "quoted-printable".
	(struct _EVCardAttribute): add a "decoded_values" list of
	GString*'s, as well as fields to hold encoding/encoding_set.
	(e_vcard_class_init): call _evc_base64_init.
	(e_vcard_attribute_add_value_decoded): based on what encoding the
	attribute uses, add the value properly.
	(e_vcard_attribute_add_param): if the parameter is ENCODING, work
	our magic.
	(e_vcard_attribute_get_values_decoded): spit out properly decoded
	values depending on the decoding type.
	(_evc_base64*): copy the camel base64 routines here.

	* backend/ebook/e-vcard.h: add prototypes for
	e_vcard_attribute_add_value_decoded and
	e_vcard_attribute_get_values_decoded.

	* backend/ebook/e-contact.c (e_contact_get_first_attr): move this
	to above _set_property so we can make use of it there.
	(e_contact_set_property): fix up the generic STRING field handler,
	and implement E_CONTACT_PHOTO setting.
	(e_contact_get_property): add handling for
	E_CONTACT_PHOTO/E_CONTACT_PHOTO_URI.
	(e_contact_photo_free): new function.

	* backend/ebook/e-contact.h: add EContactPhoto struct, a prototype
	for e_contact_photo_free, and two new EContactField elements (PHOTO and
	PHOTO_URI).

	* backend/ebook/tests/ebook/.cvsignore: ignore test-photo

	* backend/ebook/tests/ebook/Makefile.am (noinst_PROGRAMS): add test-photo

	* backend/ebook/tests/ebook/test-photo.c: test for the photo
	set/get routines (which do base64 encoding/decoding).

2003-09-02  Chris Toshok  <toshok@ximian.com>

	* gui/component/Makefile.am: comment out a buncha stuff just to
	get this building.

	* gui/component/select-names/e-select-names.c: #include
	e-book-async.h
	(search_result): EAddressbookModel -> EABModel.
	(addressbook_model_set_uri): same, and don't use
	e_book_expand_uri, as it's dead.
	(esn_get_key_fn): EAddressbookModel -> EABModel.
	(e_addressbook_create_ebook_table): same.
	(status_message): same.

	* gui/component/select-names/e-select-names.h (struct
	_ESelectNames): EAddressbookModel -> EABModel.

	* gui/component/addressbook-component.c (new_item_cb): ifdef out
	for now.
	(dnd_drop_book_open_cb): s/card/contact.
	(destination_folder_handle_drop): ifdef out.
	(request_quit): same.

	* gui/component/addressbook.c: track api changes - e_addressbook_
	-> eab_, and e_book_* becomes e_book_async_*.

	* gui/component/addressbook.h: #include e-book-async.h

	* gui/component/e-address-widget.c (query_results_cb):
	e/EBookSimpleQueryStatus/EBookStatus

	* gui/component/e-address-widget.h: s/ECard/EContact.

	* gui/component/e-cardlist-model.[ch]: nuke.
	
	* gui/component/e-address-popup.c: s/e-book.h/e-book-async.h

	* gui/component/e-address-popup.h: s/ECard/EContact

2003-09-02  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/Makefile.am (libebook_la_SOURCES): remove
	e-card.c,e-card.simple.c

	* backend/ebook/tests/ebook/test-ebook.c: remove #include of
	e-card-simple.h

	* backend/ebook/tests/ebook/test-changes.c: remove #include of
	e-card-simple.h

	* backend/ebook/e-card.[ch], backend/ebook/e-card-simple.[ch]:
	nuke.

	* backend/ebook/e-book-util.h: s/card/contact.

	* backend/ebook/e-book-util.c: ifdef out an #include.

	* backend/ebook/e-book-async.[ch]: stop doing the stupid #define
	renaming trick, and just rename all the prototypes from e_book_*
	to e_book_async_*. Also, get rid of the *_vcard variants.

2003-09-02  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-backend-card-sexp.[ch]
	(pas_backend_card_sexp_match_contact): rename
	pas_backend_card_sexp_match_card, and it takes an EContact now.
	Also, port this file to use EContact instead of ECard, and ifdef
	out lots of stuff.

	* backend/pas/pas-backend-ldap.c: convert this to use EContact
	instead of ECard, and ifdef great swaths of code to make it
	compile.

	* backend/pas/pas-book.c (pas_book_respond_modify): convert this
	from ECard to EContact.

2003-09-02  Chris Toshok  <toshok@ximian.com>

	* gui/widgets/Makefile.am (libeminicard_la_SOURCES): remove all
	the reflow/minicard stuff from the build.
	(e-addressbook-marshal.[ch]): change the prefix on the marshallers to
	eab_marshal.

	* gui/widgets/e-addressbook-view.etspec: bring this more in line
	with the field ids for EContact, and comment out a ton of them
	that aren't there yet.

	* gui/widgets/e-addressbook-view.[ch]: big renaming - rename
	e_addressbook_view to eab_view, and EAddressbookView to EABView.

	* gui/widgets/e-addressbook-util.c (eab_error_dialog): rename, and
	change a few of the error strings s/Card/Contact.
	(added_cb): E_BOOK_STATUS_SUCCESS => E_BOOK_ERROR_OK.
	(modified_cb): same.
	(e_addressbook_show_contact_editor): this takes an EContact now,
	and track the change to the contact editor signal names.
	(e_addressbook_show_contact_list_editor): this takes an EContact
	now.
	(view_contacts): rename view_cards to this, and ifdef the body.
	(e_addressbook_show_multiple_contacts): rename
	e_addressbook_show_multiple_cards to this, and s/card/contact.

	* gui/widgets/e-addressbook-util.h: ifdef some things out, and
	rename e_addressbook_error_dialog to eab_error_dialog.

	* gui/widgets/e-addressbook-table-adapter.[ch]: big renaming -
	rename e_addressbook_table_adapter to eab_table_adapter, and
	EAddressbookTableAdapter to EABTableAdapter.  Also, remove the
	simple mapping - we can do ECardSimple-like operations directly on
	the EContacts from the EABModel.

	* gui/widgets/e-addressbook-model.[ch]: big renaming - rename
	e_addressbook_model to eab_model, and EAddressbookModel to
	EABModel.  Also, convert everything from ECard to EContact.

2003-09-01  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-vcard.c (e_vcard_new_from_string): omg i'm dumb.
	don't call e_vcard_new here since it just turns around and calls
	e_vcard_new_from_string again.

2003-09-01  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-book-view.c (pas_book_view_notify_change): guard
	pending adds foo.
	(pas_book_view_notify_remove): same.
	(pas_book_view_notify_add): same.
	(pas_book_view_notify_complete): same.
	(pas_book_view_construct): init mutex
	(pas_book_view_dispose): free mutex

	* backend/pas/pas-backend-ldap.c (func_exists): new function.
	(send_pending_adds): remove
	(ldap_search_handler): let the BookView stuff handle the pending
	adds for us.
	(ldap_search_dtor): remove pending adds stuff.
	(pas_backend_ldap_search): same

	* backend/pas/pas-backend-card-sexp.c (func_exists): new function.
	
	* backend/ebook/tests/ebook/test-ebook.c (print_all_emails): use
	an exists query.

2003-08-31  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-book-query.c (func_and, func_or, func_not)
	(func_contains, func_is, func_beginswith, func_endswith)
	(e_book_query_from_string): adapt the pas ldap backend sexp
	parsing code to this, build up an EBookQuery that represents the
	sexp.

	* backend/ebook/e-contact.h (e_contact_field_id): add prototype.

	* backend/ebook/e-contact.c (e_contact_field_id): new function.

	* backend/ebook/Makefile.am (libebook_la_SOURCES): add
	e-book-util.c back into the build, if only for the config_database
	thingy.

2003-08-31  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-contact.c (e_contact_duplicate): new function.

	* backend/ebook/e-contact.h: add prototype for
	e_contact_duplicate.

	* backend/ebook/e-book-util.[ch]: massive ifdeffing.  most of this
	is either gone or will be unnecessary soon.

	* backend/ebook/e-book-query.c (e_book_query_from_string): hack
	this so it'll at least generate a query.

	* backend/ebook/e-book-listener.c
	(impl_BookListener_respond_get_view): add some debug spew and
	remove a c&p'ed comment.

	* backend/ebook/e-book-async.h: add prototype for
	e_book_async_unload_uri.

	* backend/ebook/e-book-async.c (e_book_async_unload_uri): new
	function.

	* backend/pas/pas-book-view.c (pas_book_view_construct): switch to
	CORBA_Object_duplicate, ala pas_book.

	* backend/pas/pas-backend-sync.c (pas_backend_sync_class_init):
	fix typo and the build.

2003-08-29  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-backend-ldap.c (ldap_error_to_response):
	s/card/contact.
	(pas_backend_ldap_process_create_contact): same.
	(remove_contact_handler): same.
	(remove_contact_dtor): same.
	(pas_backend_ldap_process_remove_contacts): same.
	(modify_contact_modify_handler): same.
	(modify_contact_dtor): same.
	(pas_backend_ldap_process_modify_contact): same.
	(get_contact_handler): same.
	(get_contact_dtor): same.
	(pas_backend_ldap_process_get_contact): same.
	(pas_backend_ldap_class_init): same.

	* backend/pas/pas-backend-summary.c
	(pas_backend_summary_add_contact): s/card/contact, and mostly
	switch from ECard{Simple} to EContact.
	(pas_backend_summary_get_summary_vcard): same.
	(pas_backend_summary_remove_contact): s/card/contact

	* backend/pas/pas-backend-summary.h: s/card/contact.

	* backend/pas/pas-backend-file.c (build_summary): fix g_warning,
	and return immediately if the db->cursor call fails.
	(pas_backend_file_create_contact): s/card/contact
	(pas_backend_file_remove_contacts): same.
	(pas_backend_file_modify_contact): same.
	(pas_backend_file_get_contact): same.
	(pas_backend_file_get_contact_list): same.
	(pas_backend_file_class_init): same.

	* backend/pas/pas-backend-vcf.c
	(pas_backend_vcf_process_create_contact): s/card/contact.
	(pas_backend_vcf_process_remove_contacts): same.
	(pas_backend_vcf_process_modify_contact): same.
	(pas_backend_vcf_process_get_contact): same.
	(pas_backend_vcf_process_get_contact_list): same.
	(pas_backend_vcf_class_init): same.

	* backend/pas/pas-backend-sync.c (pas_backend_sync_create_contact): s/card/contact.
	(pas_backend_sync_remove_contacts): same.
	(pas_backend_sync_modify_contact): same.
	(pas_backend_sync_get_contact): same.
	(pas_backend_sync_get_contact_list): same.
	(_pas_backend_create_contact): same.
	(_pas_backend_remove_contacts): same.
	(_pas_backend_modify_contact): same.
	(_pas_backend_get_contact): same.
	(_pas_backend_get_contact_list): same.
	(pas_backend_sync_class_init): same.

	* backend/pas/pas-backend-sync.h: s/card/contact.

	* backend/pas/pas-backend.c (pas_backend_create_contact): s/card/contact.
	(pas_backend_remove_contacts): same.
	(pas_backend_modify_contact): same.
	(pas_backend_get_contact): same.
	(pas_backend_get_contact_list): same.
	(pas_backend_change_add_new): same.
	(pas_backend_change_modify_new): same.
	(pas_backend_change_delete_new): same.

	* backend/pas/pas-backend.h: s/card/contact.

	* backend/pas/pas-book-view.c (send_pending_adds): s/card/contact
	(pas_book_view_notify_change): same.
	(pas_book_view_notify_remove): same.

	* backend/pas/pas-book.c
	(impl_GNOME_Evolution_Addressbook_Book_getContact): s/card/contact
	(impl_GNOME_Evolution_Addressbook_Book_getContactList): same.
	(impl_GNOME_Evolution_Addressbook_Book_addContact): same.
	(impl_GNOME_Evolution_Addressbook_Book_removeContacts): same.
	(impl_GNOME_Evolution_Addressbook_Book_modifyContact): same.
	(pas_book_respond_create): same.
	(pas_book_respond_remove_contacts): same.
	(pas_book_respond_modify): same.
	(pas_book_respond_get_contact): same.
	(pas_book_respond_get_contact_list): same.
	(pas_book_respond_get_changes): same.
	(pas_book_class_init): same.

	* backend/pas/pas-book.h: s/card/contact

	* backend/ebook/tests/vcard/dump-vcard.c: #include
	"ebook/e-vcard.h"

	* backend/ebook/tests/vcard/Makefile.am (TEST_LIBS): use
	top_builddir.
	(CFLAGS): same.

	* backend/ebook/tests/ebook/Makefile.am (TEST_LIBS): use
	top_builddir.
	(CFLAGS): use srcdir

	* backend/ebook/test-card.c, backend/ebook/test-client-list.c,
	backend/ebook/test-client.c, backend/ebook/test-ebook.c: remove.
	
	* backend/ebook/e-card-cursor.[ch]: remove.

	* backend/ebook/e-card-pairs.h: remove.
	
	* backend/ebook/e-book.c (e_book_add_contact): s/Card/Contact.
	(e_book_commit_contact): same
	(e_book_get_contact): same.
	(e_book_remove_contacts): same.
	(e_book_get_contacts): same.
	(e_book_handle_response): same.

	* backend/ebook/e-book-view.c (e_book_view_do_added_event):
	s/card/contact
	(e_book_view_do_modified_event): same.
	(e_book_view_do_removed_event): same.
	(e_book_view_handle_response): same.
	(e_book_view_class_init): same.

	* backend/ebook/e-book-view.h: s/card/contact and pad the class
	struct.

	* backend/ebook/e-book-view-listener.c
	(e_book_view_listener_queue_response): s/Card/Contact.
	(e_book_view_listener_queue_status_event): no need to assign
	things to NULL, we g_new0.
	(e_book_view_listener_queue_idlist_event): s/Card/Contact, and no
	need to assign things to NULL, we g_new0.
	(e_book_view_listener_queue_sequence_event): same.
	(e_book_view_listener_queue_message_event): same.
	(impl_BookViewListener_notify_contacts_added): s/Card/Contact.
	(impl_BookViewListener_notify_contacts_removed): same.
	(impl_BookViewListener_notify_contacts_changed): same.
	(e_book_view_listener_class_init): same.

	* backend/ebook/e-book-view-listener.h: s/Card/Contact

	* backend/ebook/e-book-types.h: s/CARD/CONTACT

	* backend/ebook/e-book-listener.c
	(e_book_listener_convert_status): s/Card/Contact
	(impl_BookListener_respond_create_contact): same.
	(impl_BookListener_respond_remove_contacts): same.
	(impl_BookListener_respond_modify_contact): same.
	(impl_BookListener_respond_get_contact): same.
	(impl_BookListener_respond_get_contact_list): same.
	(impl_BookListener_respond_get_changes): same.
	(e_book_listener_class_init): same.

	* backend/ebook/e-book-listener.h: pad the class struct, and
	s/Card/Contact.

	* backend/ebook/e-book-async.c (_load_uri_handler): GError
	changes.
	(_get_fields_handler): same.
	(_get_methods_handler): same.
	(_auth_user_handler): same.
	(_get_card_handler): same.
	(_remove_cards_handler): same.
	(_add_vcard_handler): same.
	(_commit_vcard_handler): same.
	(_get_book_view_handler): same.
	(e_book_async_get_book_view): use an EBookQuery instead of a char*.

	* backend/ebook/Makefile.am: remove the test handling.
	(SUBDIRS): set to ". tests"
	(libebook_la_SOURCES): add e-book-async.c

	* backend/idl/addressbook.idl: possibly gratuitous renaming, but i
	was sick of seeing "Card" being used everywhere.  "Contact" is the
	new "Card".

2003-08-28  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-book.c (e_book_op_free): rename from
	e_book_free_op.
	(e_book_op_remove): rename from e_book_remove_op.
	(e_book_clear_op): new function, remove the op, unlock its mutex,
	and free it.
	(e_book_add_contact): use e_book_clear_op.
	(e_book_commit_contact): same.
	(e_book_get_supported_fields): same.
	(e_book_get_supported_auth_methods): same.
	(e_book_authenticate_user): same.
	(e_book_get_contact): same.
	(e_book_remove_contacts): same.
	(e_book_get_book_view): same.
	(e_book_get_contacts): same.
	(e_book_get_changes): same.
	(e_book_load_uri): same.
	(e_book_remove): new function.
	(e_book_response_remove): new function.
	(e_book_handle_response): add handling for RemoveBookResponse.
	(e_book_load_local_addressbook): pass TRUE for e_book_load_uri
	@only_if_exists.

	* backend/ebook/e-book.h: add @only_if_exists arg to
	e_book_load_uri so we can support folder creation at load_uri
	time, and add prototype for e_book_remove.

	* backend/ebook/e-book-types.h: add an "id" slot in EBookChange.

	* backend/ebook/e-book-listener.c
	(impl_BookListener_respond_get_changes): handle union in idl.
	(impl_BookListener_respond_open_book): remove unnecessary
	exception check.
	(impl_BookListener_respond_remove_book): new function.
	(impl_BookListener_respond_get_supported_fields): rename this from
	_response_.
	(impl_BookListener_respond_get_supported_auth_methods): same.
	(e_book_listener_class_init): add _remove_book and track change to
	get_supported_fields/get_supported_auth_methods names.

	* backend/ebook/e-book-listener.h: add RemoveBookResponse to
	EBookListenerOperation enum.

	* backend/idl/addressbook.idl: make BookChangeItem a union that
	switches over BookChangeType.

	* backend/pas/pas-backend.c (pas_backend_change_add_new): new
	function, create a BookChangeItem representing the addition of a
	contact.
	(pas_backend_change_modify_new): same, but for modifications.
	(pas_backend_change_delete_new): same, but for deletions.

	* backend/pas/pas-backend.h: add prototypes for
	pas_backend_change_{add,modify,delete}_new

	* backend/pas/pas-backend-file.c (pas_backend_file_changes): nuke.
	(do_create): fix memory corruption.
	(pas_backend_file_get_changes): copy the body of
	pas_backend_file_changes here, and rework so that it's synchronous
	and return a list instead of the book view hack.
	(pas_backend_file_load_uri): mkdir the directory (we need a mkdir
	-p here).
	(select_changes): new function, scandir helper.
	(pas_backend_file_remove): NULL out bf->priv->summary to quiet
	valgrind, and call scandir to accumulate the .changes.db files
	then unlink them.

	* backend/pas/pas-book.c (pas_book_respond_remove): new function.
	(pas_book_respond_get_supported_fields): unifdef this, and make it
	use a glist.
	(pas_book_respond_get_supported_auth_methods): same.
	(pas_book_respond_get_changes): this code is kinda gross... lots
	of copying going on, there's got to be a better way.  but it
	works.

2003-08-26  Chris Toshok  <toshok@ximian.com>

	* backend/idl/addressbook.idl: add oneway void Book::remove() and
	oneway void notifyBookRemoved()

2003-08-26  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-backend.c (pas_backend_remove): new function.
	(pas_backend_add_book_view): new function.
	(pas_backend_add_client): move the "real_add_client" code here.
	(pas_backend_remove_client): move the "real_remove_client" code
	here.
	(pas_backend_class_init): remove assignments of add_client and
	remove_client vtable entries.
	(pas_backend_is_removed): new function.
	(pas_backend_set_is_removed): new function.
	(pas_backend_init): init clients_mutex and views_mutex.

	* backend/pas/pas-backend.h: remove the vtable entries for
	add/remove_client, since these are fully handled in PASBackend.
	Add prototypes for
	pas_backend_is_removed/pas_backend_add_book_view/pas_backend_set_is_removed.

	* backend/pas/pas-book.c
	(impl_GNOME_Evolution_Addressbook_Book_remove): new function.
	(impl_GNOME_Evolution_Addressbook_Book_getBookView): clean things
	up a bit, and don't use pas_backend_get_book_views as it can't
	lock the list of views.
	(pas_book_respond_get_supported_auth_methods): remove the extra
	unnecessary arg from the corba call.
	(pas_book_respond_get_changes): same.
	(pas_book_class_init): fill in epv "remove" slot.

	* backend/pas/pas-book.h: rename pas_book_respond_remove to
	pas_book_respond_remove_cards, and add a new
	pas_book_respond_remove for use with removing books.

	* backend/pas/pas-backend-sync.c (pas_backend_sync_remove): new
	function.
	(_pas_backend_remove): new function.
	(pas_backend_sync_class_init): fill in the "remove" vtable entry.
	(_pas_backend_remove_cards): track change to
	pas_book_respond_remove_cards (pas_book_respond_remove is used for
	removing the book, not the cards.)

	* backend/pas/pas-backend-sync.h: add pas_backend_sync_remove
	prototype and add remove_sync virtual function.

2003-08-26  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-backend-file.c (pas_backend_file_create_card,
	pas_backend_file_remove_cards, pas_backend_file_modify_card,
	pas_backend_file_get_vcard, pas_backend_file_get_card_list,
	pas_backend_file_start_book_view, pas_backend_file_get_changes,
	pas_backend_file_authenticate_user,
	pas_backend_file_get_supported_fields): rename from
	pas_backend_file_process_*
	(pas_backend_file_load_uri): save off the dirname/summary
	filename.
	(pas_backend_file_remove): new function, unlink all the files we
	know about.
	(pas_backend_file_class_init): track changes to functions, and add
	pas_backend_file_remove.

2003-08-26  JP Rosevear  <jpr@ximian.com>
 
	* conduit/address-conduit.c (ecard_from_remote_record): duplicate
 	the extra address lines
	
2003-08-22  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-book.[ch]: switch from using the PASRequest
	union and a central PASBackend dispatch function.  just call the
	pas_backend methods directly and expand the args out.

	* backend/pas/pas-backend.[ch]: same.
	
	* backend/pas/pas-backend-sync.[ch]: same.

	* backend/pas/pas-backend-vcf.c, backend/pas/pas-backend-file.c,
	backend/pas/pas-backend-ldap.c: same, and get these all compiling
	against the rest of the current pas/ebook code.	

2003-08-21  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/test-ebook.c: track GError case.

	* backend/ebook/e-book.[ch]: GError-ify the api, and clean up some
	cases where we weren't removing the current op.

	* backend/ebook/e-book-view-listener.c
	(e_book_view_listener_convert_status): track change from
	E_BOOK_VIEW_STATUS_* to E_BOOK_VIEW_ERROR_*.

	* backend/ebook/e-book-types.h: track change from E_BOOK_STATUS_*
	to E_BOOK_ERROR_*, and some E_BOOK_VIEW_STATUS_* to
	E_BOOK_VIEW_ERROR_*.

	* backend/ebook/e-book-listener.c
	(e_book_listener_convert_status): track change from
	E_BOOK_STATUS_* to E_BOOK_ERROR_*.

	* backend/ebook/e-book-query.c (e_book_query_any_field_contains):
	new function.
	(e_book_query_unref): handle the any_field_contains case.
	(e_book_query_to_string): same.

	* backend/ebook/e-book-query.h: add prototype for
	e_book_query_any_field_contains.

	* backend/ebook/e-card.c (e_card_load_uri): ifdef this out for
	now.

	* backend/ebook/e-contact.[ch] (e_contact_get_const): new
	function/prototype.

2003-08-20  Gilbert Fang  <gilbert.fang@sun.com>

	* gui/widgets/e-addressbook-util.c
        (e_addressbook_send_card_list): use memcpy to assign
        CORBA_char_sequence instead of strcpy. (#46706)

2003-08-18  Ettore Perazzoli  <ettore@ximian.com>

	* gui/component/component-factory.c: Update OAFIIDs.

	* gui/widgets/e-addressbook-util.c (e_addressbook_transfer_cards):
	Removed extern declaration for global_shell_client [yuck].
	(e_addressbook_transfer_cards): #if 0 the invocation for
	evolution_shell_client_user_select_folder(), we need to
	reimplement this component-side now.

	* gui/component/component-factory.c (factory): Call
	addressbook_component_peek() here instead of
	addressbook_component_init() [since the latter is no more].

	* gui/component/addressbook.c (set_status_message): Don't create
	the activity client for now.

	* gui/component/addressbook-config.c: Removed member shell from
	struct AddressbookDialog.
	(ldap_dialog_new): Do not take a shell arg anymore.
	(ldap_config_control_new): Likewise.
	(addressbook_config_control_new): No need to get the global shell
	pointer here anymore.

	* gui/component/addressbook-component.c: Rewritten to support the
	new ::Component interface.
	* gui/component/addressbook-component.h: Likewise.

	* gui/component/GNOME_Evolution_Addressbook.server.in.in: Version
	factory's OAFIID.  Remove ShellComponent server, add Component
	server.

2003-08-12  Rodrigo Moya <rodrigo@ximian.com>

	* backend/ebook/e-book.c (e_book_dispose): unref the
	EComponentListener before unloading the CORBA object.

2003-08-12  Hans Petter Jansson  <hpj@ximian.com>

	* backend/ebook/e-destination.c (e_destination_dispose): Chain.

	* gui/component/e-address-widget.c (e_address_widget_destroy): Chain.
	Prevent double frees. Prevent double GSource removal.

	* gui/component/e-cardlist-model.c (e_cardlist_model_class_init):
	Store parent class.
	(e_cardlist_model_dispose): Chain. Prevent double frees and unrefs.

	* gui/contact-editor/e-contact-editor-address.c
	(e_contact_editor_address_dispose): Chain.

	* gui/contact-editor/e-contact-editor-fullname.c
	(e_contact_editor_fullname_dispose): Chain.

	* gui/contact-list-editor/e-contact-list-editor.c
	(e_contact_list_editor_dispose): Chain.

	* gui/contact-list-editor/e-contact-list-model.c
	(contact_list_model_destroy): Chain. Prevent double frees and unrefs.

	* gui/widgets/e-addressbook-reflow-adapter.c (addressbook_dispose):
	Chain.
	(addressbook_finalize): Chain.

	* gui/widgets/e-addressbook-table-adapter.c (addressbook_dispose):
	Chain.

	* gui/widgets/e-addressbook-treeview-adapter.c (addressbook_destroy):
	Chain. Prevent double free.

	* gui/widgets/gal-view-minicard.c (gal_view_minicard_dispose):
	Chain. Prevent double free and detach.

	* gui/widgts/gal-view-treeview.c (gal_view_treeview_dispose):
	Chain. Prevent double free and detach.

	* printins/e-contact-print-style-editor.c
	(e_contact_print_stule_editor_destroy): Chain. Prevent double unref.

2003-08-07  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-vcard.c (e_vcard_to_string_vcard_21): new,
	unimplemented, function.
	(e_vcard_to_string_vcard_30): move the 3.0 vcard export code here.
	(e_vcard_to_string): call e_vcard_to_string_vcard_21 or
	e_vcard_to_string_vcard_30 based on @format.
	(e_vcard_attribute_remove_values): new function.

	* backend/ebook/e-vcard.h: add @format to e_vcard_to_string, and
	add prototype for e_vcard_attribute_remove_values.  also, add
	prototype for e_vcard_decode_b_encoding.

2003-08-07  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-book-listener.c
	(impl_BookListener_respond_open_book): remove the book arg.

	* backend/ebook/e-book-listener.h (struct _EBookListenerResponse):
	remove the corba book.

	* backend/ebook/e-book-async.c (_get_book_view_dtor): free the
	query string.
	(e_book_async_get_book_view): dup the query string.

	* backend/ebook/e-book.h: change e_book_get_book_view and
	e_book_get_contacts to take a const char * query string instead of
	an EBookQuery.

	* backend/ebook/e-book.c (e_book_add_contact): pass
	EVC_FORMAT_VCARD_30 to e_vcard_to_string.
	(e_book_commit_contact): same.
	(e_book_get_book_view): take a const char* query string instead of
	an EBookQuery.
	(e_book_get_contacts): same.
	(e_book_response_open): track change - the Book is no longer
	communicated back here.
	(listener_cb): nuke.
	(e_book_handle_response): track change to e_book_response_open.
	(e_book_load_uri): rework this from using BookFactory::openBook to
	BookFactory::getBook + Book::open.
	(e_book_get_uri): new function, reimplement from old api.
	(e_book_get_static_capabilities): same.
	(e_book_check_static_capability): same.
	(startup_mainloop): new function, run bonobo_main.
	(e_book_activate): start up a thread with startup_mainloop as the
	start func.
	(e_book_new): call e_book_activate.

	* backend/idl/addressbook.idl: Add Book::open, remove the Book
	from notifyBookOpened's args, and change BookFactory::openBook to
	BookFactory::getBook.

	* backend/pas/pas-backend-file.c (pas_backend_file_load_uri): add
	only_if_exists - stop using the "create-initial" special file.

	* backend/pas/pas-backend-vcf.c (pas_backend_vcf_load_uri): add
	only_if_exists - stop using the "create-initial" special file.

	* backend/pas/pas-backend.c (pas_backend_load_uri): add
	@only_if_exists, and pass it along to the virtual method.
	(pas_backend_open): new function, lock the mutex so only one
	PASBook can actually call load_uri.  call load_uri with
	pas_book_get_uri, and req->only_if_exists.
	(pas_backend_handle_request): rename process_client_request to
	this, and expose it publicly.  Also add a case statement for
	"Open".
	(real_add_client): gut this function, we don't need to create the
	book anymore, just add the client to the list and do the weak
	ref/ORBit small stuff.
	(pas_backend_add_client): track change to signature - BookListener
	-> PASBook.
	(pas_backend_init): init open_mutex.
	(pas_backend_dispose): free open_mutex.

	* backend/pas/pas-backend.h (PASBackendClass): add @only_if_exists
	to the load_uri virtual method, and change the add_client virtual
	method to take a PASBook instead of a BookListener.  add the same
	args to _load_uri and add_client.  Also, add prototypes for
	pas_backend_handle_request and pas_backend_open.

	* backend/pas/pas-book-factory.c
	(_pas_book_factory_send_open_book_response): nuke.
	(pas_book_factory_launch_backend): just return NULL, don't call
	_pas_book_factory_send_open_book_response, in the error case.
	(start_backend): nuke
	(impl_GNOME_Evolution_Addressbook_BookFactory_getBook): rename
	_openBook to this.  clean up the code a bit.  Create the PASBook
	here, and always track change to pas_backend_add_client's type (we
	pass the book now, not the listener).
	(pas_book_factory_class_init): openBook -> getBook.

	* backend/pas/pas-book.c
	(impl_GNOME_Evolution_Addressbook_Book_open): new function, call
	pas_backend_open.
	(impl_GNOME_Evolution_Addressbook_Book_getVCard): get rid of the
	signal crap, just call pas_backend_handle_request.
	(impl_GNOME_Evolution_Addressbook_Book_getCardList): same.
	(impl_GNOME_Evolution_Addressbook_Book_authenticateUser): same.
	(impl_GNOME_Evolution_Addressbook_Book_addCard): same.
	(impl_GNOME_Evolution_Addressbook_Book_removeCards): same.
	(impl_GNOME_Evolution_Addressbook_Book_modifyCard): same.
	(impl_GNOME_Evolution_Addressbook_Book_getChanges): same.
	(impl_GNOME_Evolution_Addressbook_Book_getSupportedFields): same.
	(impl_GNOME_Evolution_Addressbook_Book_getSupportedAuthMethods):
	same.
	(impl_GNOME_Evolution_Addressbook_Book_cancelOperation): same.
	(pas_book_get_backend): aggregate some g_return_if_fail's.
	(pas_book_get_listener): new function.
	(pas_book_get_uri): new function.
	(pas_book_respond_open): just call BookListener::notifyBookOpened.
	(pas_book_construct): add @uri, and g_strdup it.
	(pas_book_new): add @uri, and pass it to pas_book_construct.
	(pas_book_class_init): remove the "request" signal stuff, and fill
	in epv->open.

	* backend/pas/pas-book.h: add PASOpenRequest struct/enum entry.
	Also, add @uri to the pas_book_new args, and add a prototype for
	pas_book_get_uri.  Also, remove the "request" signal.

2003-08-07  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-book-factory.c
	(pas_book_factory_get_n_backends): lock map_mutex around hash
	table work.
	(pas_book_factory_dump_active_backends): same.
	(backend_last_client_gone_cb): same.
	(_pas_book_factory_send_open_book_response): track CallStatus idl
	change.
	(start_backend): simplify this greatly, since the factory is
	tagged with HINT_PER_THREAD.
	(impl_GNOME_Evolution_Addressbook_BookFactory_openBook): lock
	around hash table.
	(pas_book_factory_init): initialize map_mutex.
	(pas_book_factory_dispose): free map_mutex.

2003-08-06  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-backend-file.c
	(pas_backend_file_book_view_copy): nuke.
	(pas_backend_file_book_view_free): same.
	(view_destroy): same.
	(pas_backend_file_changes): #if notyet
	(do_create): e-card -> e-contact.
	(pas_backend_file_process_create_card): remove view handling from
	here.
	(pas_backend_file_process_remove_cards): same.
	(pas_backend_file_process_modify_card): convert to e-contact, and
	remove view handling.
	(pas_backend_file_get_book_view): nuke.
	(pas_backend_file_process_get_supported_fields): e-card-simple ->
	e-contact.
	(pas_backend_file_upgrade_db): e-card -> e-contact.
	(pas_backend_file_cancel_operation): implement, just return
	CouldNotCancel.
	(pas_backend_file_class_init): assign cancel_operation, and remove
	get_book_view assignment.
	(pas_backend_file_init): remove book_views assignment.

2003-08-06  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-backend-vcf.c (pas_backend_vcf_book_view_copy):
	nuke.
	(pas_backend_vcf_book_view_free): same.
	(view_destroy): same.
	(insert_contact): new function, insert the contact into our hash
	table.
	(load_file): reimplement without the e_card stuff.
	(foreach_build_list): e_card -> e_contact.
	(save_file): mostly reimplement in terms of e-contact.  more error
	case work needs doing.
	(do_create): e-card -> e-contact.
	(pas_backend_vcf_process_create_card): remove the view handling
	from here.
	(pas_backend_vcf_process_remove_cards): implement this, just
	remove it from the hash table and set ourselves to dirty.
	(pas_backend_vcf_process_modify_card): remove the view handling
	from here.
	(pas_backend_vcf_process_get_book_view): nuke.
	(pas_backend_vcf_process_get_supported_fields): reimplement in
	terms of e-contact.
	(INITIAL_VCARD): add in a FN attribute, and remove the quoted
	printable encoding.
	(pas_backend_vcf_cancel_operation): implement, just always return
	CouldNotCancel.
	(pas_backend_vcf_class_init): fill in cancel_operation, and remove
	get_book_view_sync.
	(pas_backend_vcf_init): remove book_views handling.

	* backend/pas/pas-backend-vcf.h: update copyright.

2003-08-06  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-backend-sync.c (pas_backend_sync_remove_cards):
	add out param @ids, so we can call pas_book_respond_remove
	properly.
	(_pas_backend_remove_cards): the other half of the change - pass
	the ids on to pas_book_response_remove.
	(pas_backend_sync_modify_card): add out param @old_vcard so we can
	call pas_book_respond_modify properly.
	(_pas_backend_modify_card): the other half of the change, pass the
	old_vcard on to pas_book_respond_modify.
	(pas_backend_sync_get_book_view): nuke.
	(pas_backend_sync_get_changes): track change (book view -> GList)
	(_pas_backend_is_threaded): nuke.
	(_pas_backend_create_card): indent.
	(_pas_backend_remove_cards): same.
	(_pas_backend_modify_card): same.
	(_pas_backend_get_card_list): same.
	(_pas_backend_get_changes): same.
	(_pas_backend_authenticate_user): same.
	(_pas_backend_get_supported_fields): same.
	(_pas_backend_get_supported_auth_methods): same.
	(_pas_backend_get_book_view): nuke.
	(pas_backend_sync_class_init): remove assignment to is_threaded
	and get_book_view.

	* backend/pas/pas-backend-sync.h: add out-params @ids to
	remove_cards_sync, @old_vcard to modify_card_sync.
	get_changes_sync's out-param is a GList instead of a book view,
	and remove get_book_view_sync.

	* backend/pas/pas-backend.c (pas_backend_get_book_view): nuke.
	(pas_backend_is_threaded): nuke.
	(pas_backend_start_threaded): nuke.
	(pas_backend_init): initialize priv->views.
	(pas_backend_dispose): free priv->views.
	(pas_backend_get_book_views): new function, return priv->views.

	* backend/pas/pas-backend.h: remove the get_book_view virtual
	method, and the pas_backend_get_book_view prototype.  Also, track
	the CallStatus change, and add a cancel_operation virtual method
	and prototype, and add pas_backend_get_book_views function, so the
	PASBook's can get ahold of the list.

	* backend/pas/pas-book-view.h: track collapsing of
	Addressbook::BookListenerCallStatus and
	Addressbook::BookView::CallStatus enums into
	Addressbook::CallStatus.

	* backend/pas/pas-book-view.c: same.
	
	* backend/pas/pas-card-cursor.[ch]: nuke
	
	* backend/pas/pas-book.c: track collapsing of
	Addressbook::BookListenerCallStatus and
	Addressbook::BookView::CallStatus enums into
	Addressbook::CallStatus.
	(impl_GNOME_Evolution_Addressbook_Book_getBookView): implement
	this all here, instead of farming it out to the backends.
	(impl_GNOME_Evolution_Addressbook_Book_getChanges): track change
	to signature.  this is no longer a book view, it'll return an
	actual list.
	(impl_GNOME_Evolution_Addressbook_Book_cancelOperation): new
	function, implement.
	(pas_book_respond_create): iterate over the views, notifying them
	if the new card matches their query.
	(pas_book_respond_remove): iterate over the views, telling them to
	delete the card matching the id.
	(pas_book_respond_modify): iterate over the views, notifying them
	if they need to change/add/remove that card.
	(view_destroy): move this here from the backends.
	(pas_book_respond_get_book_view): weak-ref the book view.
	(pas_book_new): remove the is_threaded switch on POA hints, and
	always use PER_REQUEST.
	(pas_book_class_init): fill in cancelOperation.

	* backend/pas/pas-book.h: track collapsing of
	Addressbook::BookListenerCallStatus and
	Addressbook::BookView::CallStatus enums into
	Addressbook::CallStatus.

2003-08-01  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-book-async.c: mostly finished.

2003-08-01  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-book-async.[ch]: new files, create async methods
	similar to the old ebook api that use GThread/GAsyncQueue to
	simulate the old async behavior.

2003-07-29  Chris Toshok  <toshok@ximian.com>

	* backend/idl/addressbook.idl: collapse
	Addressbook::BookListenerCallStatus and
	Addressbook::BookView::CallStatus enums into
	Addressbook::CallStatus.

2003-07-29  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-book-types.h: add EBookChangeType/EBookChange.

2003-07-29  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-book-view-listener.c: track collapsing of
	Addressbook::BookListenerCallStatus and
	Addressbook::BookView::CallStatus enums into
	Addressbook::CallStatus.

	* backend/ebook/e-book-listener.c track collapsing of
	Addressbook::BookListenerCallStatus and
	Addressbook::BookView::CallStatus enums into
	Addressbook::CallStatus.
	(response_free): nuked
	(e_book_listener_check_queue): nuked
	(e_book_listener_queue_response): nuked
	(e_book_listener_queue_progress): nuked
	(e_book_listener_queue_get_view_response): nuked
	(e_book_listener_queue_get_changes_response): nuked
	(e_book_listener_queue_writable_status): nuked
	(e_book_listener_queue_authentication_response): nuked
	(e_book_listener_queue_get_supported_fields_response): nuked
	(e_book_listener_queue_get_supported_auth_methods_response): nuked
	(e_book_listener_dispose): nuked
	
	* backend/ebook/e-book-listener.h: remove prototypes for
	check_pending and pop_response.

	* backend/ebook/e-book.c (e_book_get_changes): new function.
	implement this as more of a getCardList type function, instead of
	getBookView.
	(e_book_response_get_changes): new function.
	(e_book_free_change_list): new function.

	* backend/ebook/e-book.h: add prototype for
	e_book_free_change_list.

2003-07-23  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-book.c (e_book_get_book_view): new function,
	implement this.
	(e_book_response_get_book_view): same.
	(e_book_get_contacts): remove the op so we don't see BUSY after
	this request.
	(e_book_handle_response): unifdef a few things.
	(e_book_unload_uri): fix the assertion about URI_NOT_LOADED, and
	unifdef some code.
	(e_book_dispose): fix a typo.

	* backend/ebook/e-book-view.c (e_book_view_handle_response):
	rename _check_listener_queue to this.  we don't need to pop the
	response either, it's passed as an arg.
	(e_book_view_construct): "response_queued" -> "response"
	(e_book_view_start): new function, call BookView.start.
	(e_book_view_dispose): track the signal id change.

	* backend/ebook/e-book-view.h: add prototype for
	e_book_view_start.

	* backend/ebook/e-book-view-listener.c
	(e_book_view_listener_check_queue): remove.
	(e_book_view_listener_queue_response): just emit the signal.
	(impl_BookViewListener_notify_card_added): spew.
	(impl_BookViewListener_notify_card_changed): spew.
	(impl_BookViewListener_notify_sequence_complete): spew.
	(impl_BookViewListener_notify_progress): spew.
	(e_book_view_listener_check_pending): remove
	(e_book_view_listener_check_pop_response): remove
	(e_book_view_listener_new): use the ALL_AT_IDLE poa policy.
	(e_book_view_listener_init): remove the queue/timeout stuff.
	(e_book_view_listener_dispose): remove the queue/timeout stuff.

	* backend/ebook/e-book-view-listener.h: remove _check_pending and
	_pop_response.

2003-07-23  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-backend-file.c (do_summary_query): remove the
	completion_search argument, and remove the aggregating stuff.
	just call pas_book_view_notify_add_1.
	(pas_backend_file_book_view_copy): remove card_sexp crap.
	(pas_backend_file_book_view_free): same.
	(get_length): remove
	(get_nth): remove
	(cursor_destroy): remove
	(vcard_matches_search): remove
	(ecard_matches_search): remove
	(pas_backend_file_search_timeout): remove the aggregating stuff.
	just call pas_book_view_notify_add_1.
	(pas_backend_file_search): simplify this a bunch.
	(do_create): use pas_book_view_vcard_matches.
	(pas_backend_file_process_get_card_list): add some more error
	checks.
	(pas_backend_file_process_get_book_view): unifdef this, and
	implement it.
	(pas_backend_file_start_book_view): kick off the search.
	(pas_backend_file_get_uri): remove.
	(pas_backend_file_class_init): remove get_uri, add
	start_book_view.

	* backend/pas/pas-backend-ldap.c (view_destroy): don't need to
	unref the card_sexp, as the PASBookView owns it now.
	(create_card_handler): use pas_book_view_vcard_matches.
	(modify_card_modify_handler): same.
	(ldap_get_view): initialize the view properly.
	(pas_backend_ldap_get_uri): remove.
	(pas_backend_ldap_class_init): remove the get_uri assignment.

	* backend/pas/pas-backend-sync.c (_pas_backend_get_card_list):
	don't free this, it's freed in the pas_book code.

	* backend/pas/pas-backend-sync.h: make use of pas-types.h and
	remove some typedefs.

	* backend/pas/pas-backend-summary.h: same.

	* backend/pas/pas-backend-card-sexp.h: same.

2003-07-23  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-book.c
	(impl_GNOME_Evolution_Addressbook_Book_getBookView): spew.
	(pas_book_respond_create): unifdef this.
	(pas_book_respond_remove): same.
	(pas_book_respond_modify): same.
	(pas_book_respond_authenticate_user): same.
	(pas_book_respond_get_supported_fields): unref the iterator.
	(pas_book_respond_get_book_view): unifdef, and add spew.

	* backend/pas/pas-book.h: make use of pas-types.h and remove some
	typedefs.

2003-07-23  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-types.h: new file, all the typedefs shared
	between files here.

2003-07-23  Chris Toshok  <toshok@ximian.com>

	* backend/pas/pas-book-view.c (send_pending_adds): abstract all
	the aggregating code to the book view.  backends just call
	notify_card_added and the superclass does all the aggregating.
	(pas_book_view_notify_change): if there are pending adds, send
	them before we send the change.
	(pas_book_view_notify_remove): same.
	(pas_book_view_notify_add): the other part of the aggregating
	code.
	(pas_book_view_notify_complete): send pending adds if there are
	any.
	(impl_GNOME_Evolution_Addressbook_BookView_start): new function,
	call pas_backend_start_book_view.
	(pas_book_view_get_card_query): new function.
	(pas_book_view_get_card_sexp): new function.
	(pas_book_view_get_backend): new function.

	* backend/pas/pas-book-view.h: add a PASBackend arg to the
	constructor, as well as the char* query and PASBackendCardSExp
	form.  also add accessors for card_query, card_sexp, and backend.

	* backend/idl/addressbook.idl
	(GNOME::Evolution::Addressbook::BookView): add start() method.
	(GNOME::Evolution::Addressbook::BookListener): remove the oneway
	tag from notifyBookOpened, notifyViewRequested, and
	notifyChangesRequested so the call doesn't return until the remote
	object has gotten the method call.

	* backend/pas/pas-backend.c (pas_backend_load_uri): fill in the
	uri slot if the load was successful.
	(pas_backend_get_uri): return the uri, remove the virtual method
	call.
	(pas_backend_start_book_view): new function.
	(process_client_request): ifdef out the threaded foo, since i'm
	not certain it's at all necessary.
	(real_add_client): remove the bonobo_object_unref of the book,
	since it's immortal.
	(pas_backend_dispose): free the uri.

	* backend/pas/pas-backend.h: remove the get_uri virtual method,
	and add the start_book_view virtual method and
	pas_backend_start_book_view prototype.

2003-07-23  Chris Toshok  <toshok@ximian.com>

	* backend/pas/Makefile.am (libpasvcf_a_SOURCES): new.
	(noinst_LIBRARIES): add libpasvcf.a

	* backend/pas/pas-backend-vcf.[ch]: new files, implement a vcard
	file backend.  the backend api still needs a little work, but it's
	getting easier to write backends.

2003-07-23  Chris Toshok  <toshok@ximian.com>

	* printing/e-contact-print.c (e_contact_print_response): deal with
	"uses_list".  Fixes #30839.
	(e_contact_print_dialog_new): use GINT_TO_POINTER instead of
	casting to void*, and set "uses_list" to FALSE.
	(e_contact_print_card_dialog_new): same.
	(e_contact_print_card_list_dialog_new): same, but set "uses_list"
	to TRUE.

2003-07-23  Chris Toshok  <toshok@ximian.com>

	* backend/ebook/e-book.c (e_book_dispose): fix a typo.

2003-07-22  Akira TAGOH  <tagoh@redhat.com>

	* printing/e-contact-print-envelope.c (ecpe_print): Use 'Sans'
	instead of 'Helvetica' for the font name.
	* printing/e-contact-print.c (e_contact_build_style): Likewise.

2003-07-23  Dan Winship  <danw@ximian.com>

	* backend/ebook/Makefile.am: use EVO_MARSHAL_RULE
	* backend/pas/Makefile.am: Likewise
	* gui/component/select-names/Makefile.am: Likewise
	* gui/contact-editor/Makefile.am: Likewise
	* gui/contact-list-editor/Makefile.am: Likewise
	* gui/widgets/Makefile.am: Likewise

	* gui/contact-editor/e-contact-editor.c
	(e_contact_editor_class_init):
	s/ece_marshal/e_contact_editor_marshal/

	* gui/contact-list-editor/e-contact-list-editor.c
	(e_contact_list_editor_class_init): Likewise for ecle_marshal

	* gui/search/e-addressbook-search-dialog.c
	(e_addressbook_search_dialog_init): Remove gtk_window_set_policy
	call since that function is deprecated and it was just setting
	everything to the default values anyway.

	* gui/widgets/e-addressbook-util.c: #include gal/util/e-util.h for
	e_free_object_list.

2003-07-22  Dan Winship  <danw@ximian.com>

	* backend/ebook/e-card.c: (e_card_new,
	e_card_new_with_default_charset): Make the "vcard" arg const.
	...: add lots and lots of other consts as a side effect

2003-06-30  Dan Winship  <danw@ximian.com>

	* gui/widgets/e-addressbook-view.c (e_addressbook_view_dispose):
	disconnect from model signals to prevent a race condition at
	shutdown where the view gets destroyed and then the model notices
	the backend dying before being destroyed itself.

	* gui/widgets/e-addressbook-reflow-adapter.c
	(addressbook_finalize): add, to free priv.
	(e_addressbook_reflow_adapter_class_init): set it up

	* gui/component/e-address-popup.c (e_address_popup_set_free_form):
	Don't leak strings

	* gui/component/addressbook-storage.c (load_source_data): don't
	leak xml data.

	* gui/component/addressbook-component.c (new_item_cb): don't leak
	the new card.

2003-06-25  Gilbert Fang <gilbert.fang@sun.com>

	* gui/widgets/e-minicard-view-widget.c 
	(e_minicard_view_widget_real_focus_in_event): new function, 
	override the event handler for focus_in_event, set the first item
	be focused if no focused item at all.  Fixes bug 41826.

2003-06-18  Chris Toshok  <toshok@ximian.com>

	* gui/contact-editor/e-contact-editor.c (fill_in_field): in the
	EUrlEntry case just reassign widget.  it'll be handled by the
	GtkEditable code below.  Fixes #43841.

2003-06-14  Larry Ewing  <lewing@ximian.com>

        * gui/backend/ebook/e-card-simple.c:
	* gui/backend/ebook/e-card.c:
	* gui/backend/ebook/evolution-ldif-importer.c:
	* gui/backend/ebook/load-pine-addressbook.c:
	* gui/backend/ebook/test-card.c:
	* gui/backend/pas/pas-backend-card-sexp.c:
	* gui/backend/pas/pas-backend-ldap.c: Fix lots of leaks, update
	for correct use of g_object_get. Some cleanups.

2003-06-13  Larry Ewing  <lewing@ximian.com>
	
	* gui/component/addressbook.c:
        * gui/component/e-cardlist-model.c:
	* gui/component/select-names/e-select-names-text-model.c:
	* gui/contact-editor/e-contact-editor.c:
	* gui/contact-editor/e-contact-save-as.c:
	* gui/contact-list-editor/e-contact-list-editor.c:
	* gui/widgets/e-addressbook-table-adapter.c:
	* gui/widgets/e-addressbook-util.c:
	* gui/widgets/e-addressbook-view.c:
	* gui/widgets/e-minicard-view.c:
	* gui/widgets/e-minicard.c:  Fix lots of leaks, update for correct
	use of g_object_get.  Some misc cleanups.

	* printing/e-contact-print.c: update for correct use of
	g_object_get.

2003-06-05  Not Zed  <NotZed@Ximian.com>

	** For #42691.

	* gui/component/select-names/Makefile.am (%.server.in): implicit
	rule for .in file.
	(BUILT_SOURCES): added server_DATA.

	* gui/component/Makefile.am (%.server.in): use implicit rule for
	.in file.
	(BUILT_SOURCES): added, just server_DATA.
	(CLEANFILES): added

	* backend/ebook/Makefile.am (BUILT_SOURCES): add server_DATA.

2003-06-04  Rodrigo Moya <rodrigo@ximian.com>

 	* backend/ebook/ebook.c (e_book_do_response_open): adapted to
 	changes in EComponentListener API.

** See ChangeLog.pre-1-4 for older changes