/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
/*
 *  Authors: Jeffrey Stedfast <fejj@ximian.com>
 *
 *  Copyright 2001 Ximian, Inc. (www.ximian.com)
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Street #330, Boston, MA 02111-1307, USA.
 *
 */

#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

#include <pwd.h>
#include <ctype.h>

#include <glib.h>
#include <libgnome/gnome-defs.h>
#include <libgnome/gnome-config.h>
#include <libgnomeui/gnome-dialog.h>
#include <libgnomeui/gnome-stock.h>
#include <gtkhtml/gtkhtml.h>
#include <glade/glade.h>

#include <bonobo/bonobo-object.h>
#include <bonobo/bonobo-generic-factory.h>
#include <bonobo/bonobo-context.h>
#include <bonobo/bonobo-moniker-util.h>
#include <bonobo/bonobo-exception.h>
#include <bonobo-conf/bonobo-config-database.h>

#include <shell/evolution-shell-client.h>

#include <gal/util/e-util.h>
#include <gal/unicode/gunicode.h>
#include <e-util/e-html-utils.h>
#include <e-util/e-url.h>
#include "mail.h"
#include "mail-config.h"
#include "mail-mt.h"

#include "Mail.h"

typedef struct {
	Bonobo_ConfigDatabase db;
	
	gboolean show_preview;
	gboolean thread_list;
	gboolean hide_deleted;
	gint paned_size;
	gboolean send_html;
	gboolean citation_highlight;
	guint32  citation_color;
	gboolean prompt_empty_subject;
	gboolean prompt_only_bcc;
	gboolean do_seen_timeout;
	gint seen_timeout;
	gboolean empty_trash_on_exit;
	
	GSList *accounts;
	gint default_account;
	
	GSList *news;
	
	char *pgp_path;
	CamelPgpType pgp_type;
	gboolean remember_pgp_passphrase;
	
	MailConfigHTTPMode http_mode;
	MailConfigForwardStyle default_forward_style;
	MailConfigDisplayStyle message_display_style;
	char *default_charset;
	
	GHashTable *threaded_hash;
	GHashTable *preview_hash;
	
	gboolean filter_log;
	char *filter_log_path;
} MailConfig;

static MailConfig *config = NULL;

#define MAIL_CONFIG_IID "OAFIID:GNOME_Evolution_MailConfig_Factory"

/* Prototypes */
static void config_read (void);
static void mail_config_set_default_account_num (gint new_default);


/* Identity */
MailConfigIdentity *
identity_copy (const MailConfigIdentity *id)
{
	MailConfigIdentity *new;
	
	g_return_val_if_fail (id != NULL, NULL);
	
	new = g_new0 (MailConfigIdentity, 1);
	new->name = g_strdup (id->name);
	new->address = g_strdup (id->address);
	new->organization = g_strdup (id->organization);
	new->signature = g_strdup (id->signature);
	new->html_signature = g_strdup (id->html_signature);
	new->has_html_signature = id->has_html_signature;
	
	return new;
}

void
identity_destroy (MailConfigIdentity *id)
{
	if (!id)
		return;
	
	g_free (id->name);
	g_free (id->address);
	g_free (id->organization);
	g_free (id->signature);
	g_free (id->html_signature);
	
	g_free (id);
}

/* Service */
MailConfigService *
service_copy (const MailConfigService *source) 
{
	MailConfigService *new;
	
	g_return_val_if_fail (source != NULL, NULL);
	
	new = g_new0 (MailConfigService, 1);
	new->url = g_strdup (source->url);
	new->keep_on_server = source->keep_on_server;
	new->auto_check = source->auto_check;
	new->auto_check_time = source->auto_check_time;
	new->enabled = source->enabled;
	new->save_passwd = source->save_passwd;
	
	return new;
}

void
service_destroy (MailConfigService *source)
{
	if (!source)
		return;
	
	g_free (source->url);
	
	g_free (source);
}

void
service_destroy_each (gpointer item, gpointer data)
{
	service_destroy ((MailConfigService *)item);
}

/* Account */
MailConfigAccount *
account_copy (const MailConfigAccount *account) 
{
	MailConfigAccount *new;
	
	g_return_val_if_fail (account != NULL, NULL);
	
	new = g_new0 (MailConfigAccount, 1);
	new->name = g_strdup (account->name);
	
	new->id = identity_copy (account->id);
	new->source = service_copy (account->source);
	new->transport = service_copy (account->transport);
	
	new->drafts_folder_name = g_strdup (account->drafts_folder_name);
	new->drafts_folder_uri = g_strdup (account->drafts_folder_uri);
	new->sent_folder_name = g_strdup (account->sent_folder_name);
	new->sent_folder_uri = g_strdup (account->sent_folder_uri);
	
	new->pgp_key = g_strdup (account->pgp_key);
	new->pgp_encrypt_to_self = account->pgp_encrypt_to_self;
	new->pgp_always_sign = account->pgp_always_sign;
	
	new->smime_key = g_strdup (account->smime_key);
	new->smime_encrypt_to_self = account->smime_encrypt_to_self;
	new->smime_always_sign = account->smime_always_sign;
	
	return new;
}

void
account_destroy (MailConfigAccount *account)
{
	if (!account)
		return;
	
	g_free (account->name);
	
	identity_destroy (account->id);
	service_destroy (account->source);
	service_destroy (account->transport);
	
	g_free (account->drafts_folder_name);
	g_free (account->drafts_folder_uri);
	g_free (account->sent_folder_name);
	g_free (account->sent_folder_uri);
	
	g_free (account->pgp_key);
	g_free (account->smime_key);
	
	g_free (account);
}

void
account_destroy_each (gpointer item, gpointer data)
{
	account_destroy ((MailConfigAccount *)item);
}

/* Config struct routines */
void
mail_config_init (void)
{
	Bonobo_ConfigDatabase db;
	CORBA_Environment ev;
	
	if (config)
		return;
	
	CORBA_exception_init (&ev);
	
	db = bonobo_get_object ("wombat:", "Bonobo/ConfigDatabase", &ev);
	
	if (BONOBO_EX (&ev) || db == CORBA_OBJECT_NIL) {
	       
		CORBA_exception_free (&ev);
		return;
 	}
	
	CORBA_exception_free (&ev);
	
	config = g_new0 (MailConfig, 1);
	
	config->db = db;
	
	config_read ();
}

void
mail_config_clear (void)
{
	if (!config)
		return;
	
	if (config->accounts) {
		g_slist_foreach (config->accounts, account_destroy_each, NULL);
		g_slist_free (config->accounts);
		config->accounts = NULL;
	}
	
	if (config->news) {
		g_slist_foreach (config->news, service_destroy_each, NULL);
		g_slist_free (config->news);
		config->news = NULL;
	}
}

static void
config_read (void)
{
	gint len, i, default_num;
	
	mail_config_clear ();
	
	len = bonobo_config_get_long_with_default (config->db, 
	        "/Mail/Accounts/num", 0, NULL);
	
	for (i = 0; i < len; i++) {
		MailConfigAccount *account;
		MailConfigIdentity *id;
		MailConfigService *source;
		MailConfigService *transport;
		gchar *path, *val;
		
		account = g_new0 (MailConfigAccount, 1);
		path = g_strdup_printf ("/Mail/Accounts/account_name_%d", i);
		account->name = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/account_drafts_folder_name_%d", i);
		val = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		if (val && *val)
			account->drafts_folder_name = val;
		else
			g_free (val);
		
		path = g_strdup_printf ("/Mail/Accounts/account_drafts_folder_uri_%d", i);
		val = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		if (val && *val)
			account->drafts_folder_uri = val;
		else
			g_free (val);
		
		path = g_strdup_printf ("/Mail/Accounts/account_sent_folder_name_%d", i);
		val = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		if (val && *val)
			account->sent_folder_name = val;
		else
			g_free (val);
		
		path = g_strdup_printf ("/Mail/Accounts/account_sent_folder_uri_%d", i);
		val = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		if (val && *val)
			account->sent_folder_uri = val;
		else
			g_free (val);
		
		/* get the pgp info */
		path = g_strdup_printf ("/Mail/Accounts/account_pgp_key_%d", i);
		val = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		if (val && *val)
			account->pgp_key = val;
		else
			g_free (val);
		
		path = g_strdup_printf ("/Mail/Accounts/account_pgp_encrypt_to_self_%d", i);
		account->pgp_encrypt_to_self = bonobo_config_get_boolean_with_default (
		        config->db, path, TRUE, NULL);
		g_free (path);
		
		/* get the s/mime info */
		path = g_strdup_printf ("/Mail/Accounts/account_smime_key_%d", i);
		val = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		if (val && *val)
			account->smime_key = val;
		else
			g_free (val);
		
		path = g_strdup_printf ("/Mail/Accounts/account_smime_encrypt_to_self_%d", i);
		account->smime_encrypt_to_self = bonobo_config_get_boolean_with_default (
		        config->db, path, TRUE, NULL);
		g_free (path);
		
		/* get the identity info */
		id = g_new0 (MailConfigIdentity, 1);		
		path = g_strdup_printf ("/Mail/Accounts/identity_name_%d", i);
		id->name = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/identity_address_%d", i);
		id->address = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/identity_organization_%d", i);
		id->organization = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/identity_signature_%d", i);
		id->signature = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		path = g_strdup_printf ("/Mail/Accounts/identity_html_signature_%d", i);
		id->html_signature = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		path = g_strdup_printf ("/Mail/Accounts/identity_has_html_signature_%d", i);
		id->has_html_signature = bonobo_config_get_boolean_with_default (
			config->db, path, FALSE, NULL);
		g_free (path);
		
		/* get the source */
		source = g_new0 (MailConfigService, 1);
		
		path = g_strdup_printf ("/Mail/Accounts/source_url_%d", i);
		val = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		if (val && *val)
			source->url = val;
		else
			g_free (val);
		
		path = g_strdup_printf ("/Mail/Accounts/source_keep_on_server_%d", i);
		source->keep_on_server = bonobo_config_get_boolean (config->db, path, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/source_auto_check_%d", i);
		source->auto_check = bonobo_config_get_boolean_with_default (
                        config->db, path, FALSE, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/source_auto_check_time_%d", i);
		source->auto_check_time = bonobo_config_get_long_with_default ( 
			config->db, path, -1, NULL);
		
		if (source->auto_check && source->auto_check_time <= 0) {
			source->auto_check_time = 5;
			source->auto_check = FALSE;
		}
		
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/source_enabled_%d", i);
		source->enabled = bonobo_config_get_boolean_with_default (
			config->db, path, TRUE, NULL);
		g_free (path);
		
		path = g_strdup_printf 
			("/Mail/Accounts/source_save_passwd_%d", i);
		source->save_passwd = bonobo_config_get_boolean_with_default ( 
			config->db, path, TRUE, NULL);
		g_free (path);
		
		/* get the transport */
		transport = g_new0 (MailConfigService, 1);
		path = g_strdup_printf ("/Mail/Accounts/transport_url_%d", i);
		val = bonobo_config_get_string (config->db, path, NULL);
		g_free (path);
		if (val && *val)
			transport->url = val;
		else
			g_free (val);
		
		path = g_strdup_printf ("/Mail/Accounts/transport_save_passwd_%d", i);
		transport->save_passwd = bonobo_config_get_boolean (config->db, path, NULL);
		g_free (path);
		
		account->id = id;
		account->source = source;
		account->transport = transport;
		
		config->accounts = g_slist_append (config->accounts, account);
	}
	
	default_num = bonobo_config_get_long_with_default (config->db,
		"/Mail/Accounts/default_account", 0, NULL);

	mail_config_set_default_account_num (default_num);
	
#ifdef ENABLE_NNTP
	/* News */
	
	len = bonobo_config_get_long_with_default (config->db, 
	        "/News/Sources/num", 0, NULL);
	for (i = 0; i < len; i++) {
		MailConfigService *n;
		gchar *path, *r;
		
		path = g_strdup_printf ("/News/Sources/url_%d", i);
		
		if ((r = bonobo_config_get_string (config->db, path, NULL))) {
			n = g_new0 (MailConfigService, 1);		
			n->url = r;
			config->news = g_slist_append (config->news, n);
		} 
		
		g_free (path);
		
	}
#endif
	
	/* Format */
	config->send_html = bonobo_config_get_boolean_with_default (config->db,
	        "/Mail/Format/send_html", FALSE, NULL);
	
	/* Citation */
	config->citation_highlight = bonobo_config_get_boolean_with_default (
		config->db, "/Mail/Display/citation_highlight", TRUE, NULL);
	
	config->citation_color = bonobo_config_get_long_with_default (
		config->db, "/Mail/Display/citation_color", 0x737373, NULL);
	
	/* Mark as seen toggle */
	config->do_seen_timeout = bonobo_config_get_boolean_with_default (
		config->db, "/Mail/Display/do_seen_timeout", TRUE, NULL);
	
	/* Mark as seen timeout */
	config->seen_timeout = bonobo_config_get_long_with_default (config->db,
                "/Mail/Display/seen_timeout", 1500, NULL);
	
	/* Show Messages Threaded */
	config->thread_list = bonobo_config_get_boolean_with_default (
                config->db, "/Mail/Display/thread_list", FALSE, NULL);
	
	config->show_preview = bonobo_config_get_boolean_with_default (
		config->db, "/Mail/Display/preview_pane", TRUE, NULL);
	
	/* Hide deleted automatically */
	config->hide_deleted = bonobo_config_get_boolean_with_default (
		config->db, "/Mail/Display/hide_deleted", FALSE, NULL);
	
	/* Size of vpaned in mail view */
	config->paned_size = bonobo_config_get_long_with_default (config->db, 
                "/Mail/Display/paned_size", 200, NULL);
	
	/* Empty Subject */
	config->prompt_empty_subject = bonobo_config_get_boolean_with_default (
		config->db, "/Mail/Prompts/empty_subject", TRUE, NULL);
	
	/* Only Bcc */
	config->prompt_only_bcc = bonobo_config_get_boolean_with_default (
		config->db, "/Mail/Prompts/only_bcc", TRUE, NULL);
	
	/* PGP/GPG */
	config->pgp_path = bonobo_config_get_string (config->db, 
						     "/Mail/PGP/path", NULL);
	
	config->pgp_type = bonobo_config_get_long_with_default (config->db, 
	        "/Mail/PGP/type", CAMEL_PGP_TYPE_NONE, NULL);
	
	config->remember_pgp_passphrase = bonobo_config_get_boolean_with_default (
		config->db, "/Mail/Prompts/remember_passphrase", TRUE, NULL);
	
	/* HTTP images */
	config->http_mode = bonobo_config_get_long_with_default (config->db, 
		"/Mail/Display/http_images", MAIL_CONFIG_HTTP_SOMETIMES, NULL);
	
	/* Forwarding */
	config->default_forward_style = bonobo_config_get_long_with_default (
		config->db, "/Mail/Format/default_forward_style", 
		MAIL_CONFIG_FORWARD_ATTACHED, NULL);
	
	/* Message Display */
	config->message_display_style = bonobo_config_get_long_with_default (
		config->db, "/Mail/Format/message_display_style", 
		MAIL_CONFIG_DISPLAY_NORMAL, NULL);
	
	/* Default charset */
	config->default_charset = bonobo_config_get_string (config->db, 
	        "/Mail/Format/default_charset", NULL);
	
	if (!config->default_charset) {
		g_get_charset (&config->default_charset);
		if (!config->default_charset ||
		    !g_strcasecmp (config->default_charset, "US-ASCII"))
			config->default_charset = g_strdup ("ISO-8859-1");
		else
			config->default_charset = g_strdup (config->default_charset);
	}
	
	/* Trash folders */
	config->empty_trash_on_exit = bonobo_config_get_boolean_with_default (
		config->db, "/Mail/Trash/empty_on_exit", FALSE, NULL);
	
	/* Filter logging */
	config->filter_log = bonobo_config_get_boolean_with_default (
		config->db, "/Mail/Filters/log", FALSE, NULL);
	
	config->filter_log_path = bonobo_config_get_string (
		config->db, "/Mail/Filters/log_path", NULL);
}

#define bonobo_config_set_string_wrapper(db, path, val, ev) bonobo_config_set_string (db, path, val ? val : "", ev)

void
mail_config_write (void)
{
	CORBA_Environment ev;
	gint len, i, default_num;
	
	/* Accounts */
	
	if (!config)
		return;
	
	CORBA_exception_init (&ev);
	Bonobo_ConfigDatabase_removeDir (config->db, "/Mail/Accounts", &ev);
	CORBA_exception_init (&ev);
	Bonobo_ConfigDatabase_removeDir (config->db, "/News/Sources", &ev);
	CORBA_exception_init (&ev);
	Bonobo_ConfigDatabase_sync (config->db, &ev);
	
	len = g_slist_length (config->accounts);
	bonobo_config_set_long (config->db,
				"/Mail/Accounts/num", len, NULL);
	
	default_num = mail_config_get_default_account_num ();
	bonobo_config_set_long (config->db,
				"/Mail/Accounts/default_account", default_num, NULL);
	
	for (i = 0; i < len; i++) {
		MailConfigAccount *account;
		gchar *path;
		
		account = g_slist_nth_data (config->accounts, i);
		
		/* account info */
		path = g_strdup_printf ("/Mail/Accounts/account_name_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, account->name, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/account_drafts_folder_name_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, 
						  account->drafts_folder_name, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/account_drafts_folder_uri_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, 
						  account->drafts_folder_uri, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/account_sent_folder_name_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, 
						  account->sent_folder_name, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/account_sent_folder_uri_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, 
						  account->sent_folder_uri, NULL);
		g_free (path);
		
		/* account pgp options */
		path = g_strdup_printf ("/Mail/Accounts/account_pgp_key_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, account->pgp_key, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/account_pgp_encrypt_to_self_%d", i);
		bonobo_config_set_boolean (config->db, path, 
					   account->pgp_encrypt_to_self, NULL);
		g_free (path);
		
		/* account s/mime options */
		path = g_strdup_printf ("/Mail/Accounts/account_smime_key_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, account->smime_key, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/account_smime_encrypt_to_self_%d", i);
		bonobo_config_set_boolean (config->db, path, account->smime_encrypt_to_self, NULL);
		g_free (path);
		
		/* identity info */
		path = g_strdup_printf ("/Mail/Accounts/identity_name_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, account->id->name, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/identity_address_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, account->id->address, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/identity_organization_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, account->id->organization, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/identity_signature_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, account->id->signature, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/identity_html_signature_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, account->id->html_signature, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/identity_has_html_signature_%d", i);
		bonobo_config_set_boolean (config->db, path, account->id->has_html_signature, NULL);
		g_free (path);
		
		/* source info */
		path = g_strdup_printf ("/Mail/Accounts/source_url_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, account->source->url, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/source_keep_on_server_%d", i);
		bonobo_config_set_boolean (config->db, path, account->source->keep_on_server, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/source_auto_check_%d", i);
		bonobo_config_set_boolean (config->db, path, account->source->auto_check, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/source_auto_check_time_%d", i);
		bonobo_config_set_long (config->db, path, account->source->auto_check_time, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/source_enabled_%d", i);
		bonobo_config_set_boolean (config->db, path, account->source->enabled, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/source_save_passwd_%d", i);
		bonobo_config_set_boolean (config->db, path, account->source->save_passwd, NULL);
		g_free (path);
		
		/* transport info */
		path = g_strdup_printf ("/Mail/Accounts/transport_url_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, account->transport->url, NULL);
		g_free (path);
		
		path = g_strdup_printf ("/Mail/Accounts/transport_save_passwd_%d", i);
		bonobo_config_set_boolean (config->db, path, account->transport->save_passwd, NULL);
		g_free (path);
	}
	
#ifdef ENABLE_NNTP
	/* News */
	
  	len = g_slist_length (config->news);
	bonobo_config_set_long (config->db, "/News/Sources/num", len, NULL);
	for (i = 0; i < len; i++) {
		MailConfigService *n;
		gchar *path;
		
		n = g_slist_nth_data (config->news, i);
		
		path = g_strdup_printf ("/News/Sources/url_%d", i);
		bonobo_config_set_string_wrapper (config->db, path, n->url, NULL);
		g_free (path);
	}
	
#endif
	
	CORBA_exception_init (&ev);
	Bonobo_ConfigDatabase_sync (config->db, &ev);
	CORBA_exception_free (&ev);
}

static gboolean
hash_save_state (gpointer key, gpointer value, gpointer user_data)
{
	char *path;
	gboolean bool = GPOINTER_TO_INT (value);
	
	path = g_strconcat ("/Mail/", (char *)user_data, "/", (char *)key, 
			    NULL);
	bonobo_config_set_boolean (config->db, path, bool, NULL);
	g_free (path);
	g_free (key);
	
	return TRUE;
}

void
mail_config_write_on_exit (void)
{
	CORBA_Environment ev;
	GSList *sources;
	MailConfigService *s;
	
	/* Show Messages Threaded */
	bonobo_config_set_boolean (config->db, "/Mail/Display/thread_list", 
				   config->thread_list, NULL);
	
	/* Show Message Preview */
	bonobo_config_set_boolean (config->db, "/Mail/Display/preview_pane",
				   config->show_preview, NULL);
	
	/* Hide deleted automatically */
	bonobo_config_set_boolean (config->db, "/Mail/Display/hide_deleted", 
				   config->hide_deleted, NULL);
	
	/* Size of vpaned in mail view */
	bonobo_config_set_long (config->db, "/Mail/Display/paned_size", 
				config->paned_size, NULL);
	
	/* Mark as seen toggle */
	bonobo_config_set_boolean (config->db, "/Mail/Display/do_seen_timeout",
				   config->do_seen_timeout, NULL);
	/* Mark as seen timeout */
	bonobo_config_set_long (config->db, "/Mail/Display/seen_timeout", 
				config->seen_timeout, NULL);
	
	/* Format */
	bonobo_config_set_boolean (config->db, "/Mail/Format/send_html", 
				   config->send_html, NULL);
	
	/* Citation */
	bonobo_config_set_boolean (config->db, 
				   "/Mail/Display/citation_highlight", 
				   config->citation_highlight, NULL);
	
	bonobo_config_set_long (config->db, "/Mail/Display/citation_color",
				config->citation_color, NULL);
	
	/* Empty Subject */
	bonobo_config_set_boolean (config->db, "/Mail/Prompts/empty_subject",
				   config->prompt_empty_subject, NULL);	
	
	/* Only Bcc */
	bonobo_config_set_boolean (config->db, "/Mail/Prompts/only_bcc",
				   config->prompt_only_bcc, NULL);	
	
	/* PGP/GPG */
	bonobo_config_set_string_wrapper (config->db, "/Mail/PGP/path", 
					  config->pgp_path, NULL);
	
	bonobo_config_set_long (config->db, "/Mail/PGP/type", 
				config->pgp_type, NULL);
	
	bonobo_config_set_boolean (config->db, "/Mail/Prompts/remember_passphrase",
				   config->remember_pgp_passphrase, NULL);	
	
	/* HTTP images */
	bonobo_config_set_long (config->db, "/Mail/Display/http_images", 
				config->http_mode, NULL);
	
	/* Forwarding */
	bonobo_config_set_long (config->db, 
				"/Mail/Format/default_forward_style", 
				config->default_forward_style, NULL);
	
	/* Message Display */
	bonobo_config_set_long (config->db, 
				"/Mail/Format/message_display_style", 
				config->message_display_style, NULL);
	
	/* Default charset */
	bonobo_config_set_string_wrapper (config->db, "/Mail/Format/default_charset", 
					  config->default_charset, NULL);
	
	/* Trash folders */
	bonobo_config_set_boolean (config->db, "/Mail/Trash/empty_on_exit", 
				   config->empty_trash_on_exit, NULL);
	
	/* Filter logging */
	bonobo_config_set_boolean (config->db, "/Mail/Filters/log",
				   config->filter_log, NULL);
	
	bonobo_config_set_string_wrapper (config->db, "/Mail/Filters/log_path",
					  config->filter_log_path, NULL);
	
	g_hash_table_foreach_remove (config->threaded_hash, 
				     hash_save_state, "Threads");
	
	g_hash_table_foreach_remove (config->preview_hash, 
				     hash_save_state, "Preview");
	
	CORBA_exception_init (&ev);
	Bonobo_ConfigDatabase_sync (config->db, &ev);
	CORBA_exception_free (&ev);
	
	/* Passwords */
	/* fixme: still depends on gnome-config */
	gnome_config_private_clean_section ("/Evolution/Passwords");
	sources = mail_config_get_sources ();
	for ( ; sources; sources = sources->next) {
		s = sources->data;
		if (s->save_passwd && s->url)
			mail_session_remember_password (s->url);
	}
	g_slist_free (sources);
	gnome_config_sync ();
	
	/* now do cleanup */
	mail_config_clear ();
}

/* Accessor functions */
gboolean
mail_config_is_configured (void)
{
	return config->accounts != NULL;
}

static char *
uri_to_key (const char *uri)
{
	char *rval;
	int i = 0;
	
	if (!uri)
		return NULL;
	
	rval = g_strdup (uri);
	
	while (rval [i]) {	
		if (rval [i] == '/' || rval [i] == ':')
			rval [i] = '_';
		
		i++;
	}
	
	return rval;
}

gboolean
mail_config_get_empty_trash_on_exit (void)
{
	return config->empty_trash_on_exit;
}

void
mail_config_set_empty_trash_on_exit (gboolean value)
{
	config->empty_trash_on_exit = value;
}

gboolean
mail_config_get_show_preview (const char *uri)
{
	if (uri) {
		gpointer key, val;
		char *dbkey;
		
		dbkey = uri_to_key (uri);
		
		if (!config->preview_hash)
			config->preview_hash = g_hash_table_new (g_str_hash, g_str_equal);
		
		if (!g_hash_table_lookup_extended (config->preview_hash, dbkey, &key, &val)) {
			gboolean value;
			char *str;
			
			str = g_strdup_printf ("/Mail/Preview/%s", dbkey);
			value = bonobo_config_get_boolean_with_default (config->db, str, TRUE, NULL);
			g_free (str);
			
			g_hash_table_insert (config->preview_hash, dbkey,
					     GINT_TO_POINTER (value));
			
			return value;
		} else {
			g_free (dbkey);
			return GPOINTER_TO_INT (val);
		}
	}
	
	/* return the default value */
	
	return config->show_preview;
}

void
mail_config_set_show_preview (const char *uri, gboolean value)
{
	if (uri) {
		char *dbkey = uri_to_key (uri);
		gpointer key, val;
		
		if (!config->preview_hash)
			config->preview_hash = g_hash_table_new (g_str_hash, g_str_equal);
		
		if (g_hash_table_lookup_extended (config->preview_hash, dbkey, &key, &val)) {
			g_hash_table_insert (config->preview_hash, dbkey,
					     GINT_TO_POINTER (value));
			g_free (dbkey);
		} else {
			g_hash_table_insert (config->preview_hash, dbkey, 
					     GINT_TO_POINTER (value));
		}
	} else
		config->show_preview = value;
}

gboolean
mail_config_get_thread_list (const char *uri)
{
	if (uri) {
		gpointer key, val;
		char *dbkey;
		
		dbkey = uri_to_key (uri);
		
		if (!config->threaded_hash)
			config->threaded_hash = g_hash_table_new (g_str_hash, g_str_equal);
		
		if (!g_hash_table_lookup_extended (config->threaded_hash, dbkey, &key, &val)) {
			gboolean value;
			char *str;
			
			str = g_strdup_printf ("/Mail/Threads/%s", dbkey);
			value = bonobo_config_get_boolean_with_default (config->db, str, FALSE, NULL);
			g_free (str);
			
			g_hash_table_insert (config->threaded_hash, dbkey,
					     GINT_TO_POINTER (value));
			
			return value;
		} else {
			g_free(dbkey);
			return GPOINTER_TO_INT (val);
		}
	}
	
	/* return the default value */
	
	return config->thread_list;
}

void
mail_config_set_thread_list (const char *uri, gboolean value)
{
	if (uri) {
		char *dbkey = uri_to_key (uri);
		gpointer key, val;
		
		if (!config->threaded_hash)
			config->threaded_hash = g_hash_table_new (g_str_hash, g_str_equal);
		
		if (g_hash_table_lookup_extended (config->threaded_hash, dbkey, &key, &val)) {
			g_hash_table_insert (config->threaded_hash, dbkey,
					     GINT_TO_POINTER (value));
			g_free (dbkey);
		} else {
			g_hash_table_insert (config->threaded_hash, dbkey, 
					     GINT_TO_POINTER (value));
		}
	} else
		config->thread_list = value;
}

gboolean
mail_config_get_filter_log (void)
{
	return config->filter_log;
}

void
mail_config_set_filter_log (gboolean value)
{
	config->filter_log = value;
}

const char *
mail_config_get_filter_log_path (void)
{
	return config->filter_log_path;
}

void
mail_config_set_filter_log_path (const char *path)
{
	g_free (config->filter_log_path);
	config->filter_log_path = g_strdup (path);
}

gboolean
mail_config_get_hide_deleted (void)
{
	return config->hide_deleted;
}

void
mail_config_set_hide_deleted (gboolean value)
{
	config->hide_deleted = value;
}

gint
mail_config_get_paned_size (void)
{
	return config->paned_size;
}

void
mail_config_set_paned_size (gint value)
{
	config->paned_size = value;
}

gboolean
mail_config_get_send_html (void)
{
	return config->send_html;
}

void
mail_config_set_send_html (gboolean send_html)
{
	config->send_html = send_html;
}

gboolean
mail_config_get_citation_highlight (void)
{
	return config->citation_highlight;
}

void
mail_config_set_citation_highlight (gboolean citation_highlight)
{
	config->citation_highlight = citation_highlight;
}

guint32
mail_config_get_citation_color (void)
{
	return config->citation_color;
}

void
mail_config_set_citation_color (guint32 citation_color)
{
	config->citation_color = citation_color;
}

gboolean
mail_config_get_do_seen_timeout (void)
{
	return config->do_seen_timeout;
}

void
mail_config_set_do_seen_timeout (gboolean do_seen_timeout)
{
	config->do_seen_timeout = do_seen_timeout;
}

gint
mail_config_get_mark_as_seen_timeout (void)
{
	return config->seen_timeout;
}

void
mail_config_set_mark_as_seen_timeout (gint timeout)
{
	config->seen_timeout = timeout;
}

gboolean
mail_config_get_prompt_empty_subject (void)
{
	return config->prompt_empty_subject;
}

void
mail_config_set_prompt_empty_subject (gboolean value)
{
	config->prompt_empty_subject = value;
}

gboolean
mail_config_get_prompt_only_bcc (void)
{
	return config->prompt_only_bcc;
}

void
mail_config_set_prompt_only_bcc (gboolean value)
{
	config->prompt_only_bcc = value;
}


struct {
	char *bin;
	CamelPgpType type;
} binaries[] = {
	{ "gpg", CAMEL_PGP_TYPE_GPG },
	{ "pgpv", CAMEL_PGP_TYPE_PGP5 },
	{ "pgp", CAMEL_PGP_TYPE_PGP2 },
	{ NULL, CAMEL_PGP_TYPE_NONE }
};

/* FIXME: what about PGP 6.x? And I assume we want to "prefer" GnuPG
   over the other, which is done now, but after that do we have a
   order-of-preference for the rest? */
static void
auto_detect_pgp_variables (void)
{
	CamelPgpType type = CAMEL_PGP_TYPE_NONE;
	const char *PATH, *path;
	char *pgp = NULL;
	
	PATH = getenv ("PATH");
	
	path = PATH;
	while (path && *path && !type) {
		const char *pend = strchr (path, ':');
		char *dirname;
		int i;
		
		if (pend) {
			/* don't even think of using "." */
			if (!strncmp (path, ".", pend - path)) {
				path = pend + 1;
				continue;
			}
			
			dirname = g_strndup (path, pend - path);
			path = pend + 1;
		} else {
			/* don't even think of using "." */
			if (!strcmp (path, "."))
				break;
			
			dirname = g_strdup (path);
			path = NULL;
		}
		
		for (i = 0; binaries[i].bin; i++) {
			struct stat st;
			
			pgp = g_strdup_printf ("%s/%s", dirname, binaries[i].bin);
			/* make sure the file exists *and* is executable? */
			if (stat (pgp, &st) != -1 && st.st_mode & (S_IXOTH | S_IXGRP | S_IXUSR)) {
				type = binaries[i].type;
				break;
			}
			
			g_free (pgp);
			pgp = NULL;
		}
		
		g_free (dirname);
	}
	
	if (pgp && type) {
		mail_config_set_pgp_path (pgp);
		mail_config_set_pgp_type (type);
	}
	
	g_free (pgp);
}

CamelPgpType
mail_config_get_pgp_type (void)
{
	if (!config->pgp_path || !config->pgp_type)
		auto_detect_pgp_variables ();
	
	return config->pgp_type;
}

void
mail_config_set_pgp_type (CamelPgpType pgp_type)
{
	config->pgp_type = pgp_type;
}

const char *
mail_config_get_pgp_path (void)
{
	if (!config->pgp_path || !config->pgp_type)
		auto_detect_pgp_variables ();
	
	return config->pgp_path;
}

void
mail_config_set_pgp_path (const char *pgp_path)
{
	g_free (config->pgp_path);
	
	config->pgp_path = g_strdup (pgp_path);
}

gboolean
mail_config_get_remember_pgp_passphrase (void)
{
	return config->remember_pgp_passphrase;
}

void
mail_config_set_remember_pgp_passphrase (gboolean value)
{
	config->remember_pgp_passphrase = value;
}

MailConfigHTTPMode
mail_config_get_http_mode (void)
{
	return config->http_mode;
}

void
mail_config_set_http_mode (MailConfigHTTPMode mode)
{
	config->http_mode = mode;
}

MailConfigForwardStyle
mail_config_get_default_forward_style (void)
{
	return config->default_forward_style;
}

void
mail_config_set_default_forward_style (MailConfigForwardStyle style)
{
	config->default_forward_style = style;
}

MailConfigDisplayStyle
mail_config_get_message_display_style (void)
{
	return config->message_display_style;
}

void
mail_config_set_message_display_style (MailConfigDisplayStyle style)
{
	config->message_display_style = style;
}

const char *
mail_config_get_default_charset (void)
{
	return config->default_charset;
}

void
mail_config_set_default_charset (const char *charset)
{
	g_free (config->default_charset);
	config->default_charset = g_strdup (charset);
}


const MailConfigAccount *
mail_config_get_default_account (void)
{
	MailConfigAccount *account;
	
	if (!config->accounts)
		return NULL;
	
	account = g_slist_nth_data (config->accounts,
				   config->default_account);
	
	/* Looks like we have no default, so make the first account
           the default */
	if (account == NULL) {
		mail_config_set_default_account_num (0);
		account = config->accounts->data;
	}
	
	return account;
}

const MailConfigAccount *
mail_config_get_account_by_name (const char *account_name)
{
	/* FIXME: this should really use a hash */
	const MailConfigAccount *account;
	GSList *l;
	
	l = config->accounts;
	while (l) {
		account = l->data;
		if (account && !strcmp (account->name, account_name))
			return account;
		
		l = l->next;
	}
	
	return NULL;
}

const MailConfigAccount *
mail_config_get_account_by_source_url (const char *source_url)
{
	const MailConfigAccount *account;
	GSList *l;

	g_return_val_if_fail (source_url != NULL, NULL);

	l = config->accounts;
	while (l) {
		account = l->data;
		if (account
		    && account->source 
		    && account->source->url
		    && e_url_equal (account->source->url, source_url))
			return account;
		
		l = l->next;
	}
	
	return NULL;
}

const MailConfigAccount *
mail_config_get_account_by_transport_url (const char *transport_url)
{
	const MailConfigAccount *account;
	GSList *l;

	g_return_val_if_fail (transport_url != NULL, NULL);

	l = config->accounts;
	while (l) {
		account = l->data;
		if (account
		    && account->transport 
		    && account->transport->url
		    && e_url_equal (account->transport->url, transport_url))
			return account;
		
		l = l->next;
	}
	
	return NULL;
}

const GSList *
mail_config_get_accounts (void)
{
	return config->accounts;
}

static void
add_shortcut_entry (const char *name, const char *uri, const char *type)
{
	extern EvolutionShellClient *global_shell_client;
	CORBA_Environment ev;
	GNOME_Evolution_Shortcuts shortcuts_interface;
	GNOME_Evolution_Shortcuts_GroupList *groups;
	GNOME_Evolution_Shortcuts_Group *the_group;
	GNOME_Evolution_Shortcuts_Shortcut *the_shortcut;
	int i, group_num;

	CORBA_exception_init (&ev);

	shortcuts_interface = evolution_shell_client_get_shortcuts_interface (global_shell_client);
	if (CORBA_Object_is_nil (shortcuts_interface, &ev)) {
		g_warning ("No ::Shortcut interface on the shell");
		CORBA_exception_free (&ev);
		return;
	}

	groups = GNOME_Evolution_Shortcuts__get_groups (shortcuts_interface, &ev);
	if (ev._major != CORBA_NO_EXCEPTION) {
		g_warning ("Exception getting the groups: %s", ev._repo_id);
		CORBA_exception_free (&ev);
		return;
	}

	the_group = NULL;
	group_num = 0;

	for (i = 0; i < groups->_length; i++) {
		GNOME_Evolution_Shortcuts_Group *iter;
		
		iter = groups->_buffer + i;
		if (!strcmp (iter->name, "Evolution Shortcuts")) {
			the_group = iter;
			group_num = i;
			break;
		}
	}

	if (the_group == NULL) {
		/* Bleah, just create it. Probably not the best
		 * course of action. */

		GNOME_Evolution_Shortcuts_addGroup (shortcuts_interface,
						    group_num,
						    "Evolution Shortcuts",
						    &ev);

		if (ev._major != CORBA_NO_EXCEPTION) {
			g_warning ("Exception recreating \"Evolution Shortcuts\" group: %s", ev._repo_id);
			goto cleanup;
		}

		the_group = GNOME_Evolution_Shortcuts_getGroup (shortcuts_interface,
								group_num,
								&ev);

		if (ev._major != CORBA_NO_EXCEPTION) {
			g_warning ("Exception getting newly created \"Evolution Shortcuts\" group: %s", ev._repo_id);
			goto cleanup;
		}
	}

	the_shortcut = NULL;

	for (i = 0; i < the_group->shortcuts._length; i++) {
		GNOME_Evolution_Shortcuts_Shortcut *iter;
		
		iter = the_group->shortcuts._buffer + i;
		if (!strcmp (iter->name, name)) {
			the_shortcut = iter;
			break;
		}
	}

	if (the_shortcut == NULL) {
		the_shortcut = 
			GNOME_Evolution_Shortcuts_Shortcut__alloc ();

		the_shortcut->name = CORBA_string_dup (name);
		the_shortcut->uri = CORBA_string_dup (uri);
		the_shortcut->type = CORBA_string_dup (type);

		GNOME_Evolution_Shortcuts_add (shortcuts_interface,
					       group_num,
					       the_group->shortcuts._length,
					       the_shortcut,
					       &ev);

		CORBA_free (the_shortcut);

		if (ev._major != CORBA_NO_EXCEPTION) {
			g_warning ("Exception creating shortcut \"%s\": %s", name, ev._repo_id);
			goto cleanup;
		}

	} 

 cleanup:
	CORBA_exception_free (&ev);
	CORBA_free (groups);
}

static void
maybe_add_shortcut (MailConfigAccount *account)
{
	CamelProvider *prov;
	gchar *name;
	gchar *url;
	
	/* no source, don't bother. */
	if (!account->source || !account->source->url)
		return;

	prov = camel_session_get_provider (session, account->source->url, NULL);

	/* not a storage, don't bother. */

	if (!(prov->flags & CAMEL_PROVIDER_IS_STORAGE))
		return;

	/* right now, the URL always works basically as a matter of luck...
	 * both IMAP and mbox spool stores have INBOX as their inbox folder
	 * name. I don't think this will work with maildir. How can we figure out
	 * what shortcut to insert?
	 */

	name = g_strdup_printf (_("%s: Inbox"), account->name);
	url = g_strdup_printf ("evolution:/%s/INBOX", account->name);
	add_shortcut_entry (name, url, "mail");
	g_free (name);
	g_free (url);
}

void
mail_config_add_account (MailConfigAccount *account)
{
	config->accounts = g_slist_append (config->accounts, account);

	if (account->source && account->source->url)
		maybe_add_shortcut (account);
}

static void
remove_account_shortcuts (MailConfigAccount *account)
{
	extern EvolutionShellClient *global_shell_client;
	CORBA_Environment ev;
	GNOME_Evolution_Shortcuts shortcuts_interface;
	GNOME_Evolution_Shortcuts_GroupList *groups;
	int i, j, len;;

	CORBA_exception_init (&ev);

	shortcuts_interface = evolution_shell_client_get_shortcuts_interface (global_shell_client);
	if (CORBA_Object_is_nil (shortcuts_interface, &ev)) {
		g_warning ("No ::Shortcut interface on the shell");
		CORBA_exception_free (&ev);
		return;
	}

	groups = GNOME_Evolution_Shortcuts__get_groups (shortcuts_interface, &ev);
	if (ev._major != CORBA_NO_EXCEPTION) {
		g_warning ("Exception getting the groups: %s", ev._repo_id);
		CORBA_exception_free (&ev);
		return;
	}

	len = strlen (account->name);

	for (i = 0; i < groups->_length; i++) {
		GNOME_Evolution_Shortcuts_Group *iter;
		
		iter = groups->_buffer + i;

		for (j = 0; j < iter->shortcuts._length; j++) {
			GNOME_Evolution_Shortcuts_Shortcut *sc;

			sc = iter->shortcuts._buffer + j;

			/* "evolution:/" = 11 */
			if (!strncmp (sc->uri + 11, account->name, len)) {
				GNOME_Evolution_Shortcuts_remove (shortcuts_interface, i, j, &ev);

				if (ev._major != CORBA_NO_EXCEPTION) {
					g_warning ("Exception removing shortcut \"%s\": %s", sc->name, ev._repo_id);
					break;
				}
			}
		}
	}

	CORBA_exception_free (&ev);
	CORBA_free (groups);
}

const GSList *
mail_config_remove_account (MailConfigAccount *account)
{
	/* Removing the current default, so make the first account the
           default */
	if (account == mail_config_get_default_account ())
		config->default_account = 0;

	config->accounts = g_slist_remove (config->accounts, account);
	remove_account_shortcuts (account);
	account_destroy (account);

	return config->accounts;
}

gint
mail_config_get_default_account_num (void)
{
	return config->default_account;
}

static void
mail_config_set_default_account_num (gint new_default)
{
	config->default_account = new_default;
}

void
mail_config_set_default_account (const MailConfigAccount *account)
{
	int position;

	position = g_slist_index (config->accounts, (void*)account);

	config->default_account = position;

	return;
}

const MailConfigIdentity *
mail_config_get_default_identity (void)
{
	const MailConfigAccount *account;
	
	account = mail_config_get_default_account ();
	if (account)
		return account->id;
	else
		return NULL;
}

const MailConfigService *
mail_config_get_default_transport (void)
{
	const MailConfigAccount *account;
	
	account = mail_config_get_default_account ();
	if (account)
		return account->transport;
	else
		return NULL;
}

const MailConfigService *
mail_config_get_default_news (void)
{
	if (!config->news)
		return NULL;
	
	return (MailConfigService *)config->news->data;
}

const GSList *
mail_config_get_news (void)
{
	return config->news;
}

void
mail_config_add_news (MailConfigService *news) 
{
	config->news = g_slist_append (config->news, news);
}

const GSList *
mail_config_remove_news (MailConfigService *news)
{
	config->news = g_slist_remove (config->news, news);
	service_destroy (news);
	
	return config->news;
}

GSList *
mail_config_get_sources (void)
{
	const GSList *accounts;
	GSList *sources = NULL;
	
	accounts = mail_config_get_accounts ();
	while (accounts) {
		const MailConfigAccount *account = accounts->data;
		
		if (account->source)
			sources = g_slist_append (sources, account->source);
		
		accounts = accounts->next;
	}
	
	return sources;
}

void 
mail_config_service_set_save_passwd (MailConfigService *service, gboolean save_passwd)
{
	service->save_passwd = save_passwd;
	mail_config_write (); /*bleah*/
}

char *
mail_config_folder_to_cachename (CamelFolder *folder, const char *prefix)
{
	CamelService *service = CAMEL_SERVICE (folder->parent_store);
	char *url, *filename;

	/* This is the way it is for backward compatibility with
	 * the way it was, not because it's necessarily a good thing.
	 */

	url = camel_url_to_string (service->url, CAMEL_URL_HIDE_PASSWORD | CAMEL_URL_HIDE_PARAMS);

	/* Really we want to check CAMEL_IS_LOCAL_FOLDER here, but we
	 * can't do that.
	 */
	if (service->provider->flags & CAMEL_PROVIDER_IS_REMOTE) {
		char *store_url = url;
		url = g_strdup_printf ("%s/%s", store_url, folder->full_name);
		g_free (store_url);
	}
	e_filename_make_safe (url);

	filename = g_strdup_printf ("%s/config/%s%s", evolution_dir, prefix, url);
	g_free (url);
	
	return filename;
}


/* Async service-checking/authtype-lookup code. */
struct _check_msg {
	struct _mail_msg msg;

	const char *url;
	CamelProviderType type;
	GList **authtypes;
	gboolean *success;
};

static char *
check_service_describe (struct _mail_msg *mm, int complete)
{
	return g_strdup (_("Checking Service"));
}

static void
check_service_check (struct _mail_msg *mm)
{
	struct _check_msg *m = (struct _check_msg *)mm;
	CamelService *service = NULL;

	camel_operation_register(mm->cancel);

	service = camel_session_get_service (session, m->url, m->type, &mm->ex);
	if (!service) {
		camel_operation_unregister(mm->cancel);
		return;
	}

	if (m->authtypes)
		*m->authtypes = camel_service_query_auth_types (service, &mm->ex);
	else
		camel_service_connect (service, &mm->ex);

	camel_object_unref (CAMEL_OBJECT (service));
	*m->success = !camel_exception_is_set(&mm->ex);

	camel_operation_unregister(mm->cancel);
}

static struct _mail_msg_op check_service_op = {
	check_service_describe,
	check_service_check,
	NULL,
	NULL
};

static void
check_cancelled (GnomeDialog *dialog, int button, gpointer data)
{
	int *msg_id = data;

	mail_msg_cancel (*msg_id);
}

/**
 * mail_config_check_service:
 * @url: service url
 * @type: provider type
 * @authtypes: set to list of supported authtypes on return if non-%NULL.
 *
 * Checks the service for validity. If @authtypes is non-%NULL, it will
 * be filled in with a list of supported authtypes.
 *
 * Return value: %TRUE on success or %FALSE on error.
 **/
gboolean
mail_config_check_service (const char *url, CamelProviderType type, GList **authtypes)
{
	gboolean ret = FALSE;
	struct _check_msg *m;
	int id;
	GtkWidget *dialog, *label;

	m = mail_msg_new(&check_service_op, NULL, sizeof(*m));
	m->url = url;
	m->type = type;
	m->authtypes = authtypes;
	m->success = &ret;

	id = m->msg.seq;
	e_thread_put(mail_thread_queued, (EMsg *)m);

	dialog = gnome_dialog_new (_("Connecting to server..."),
				   GNOME_STOCK_BUTTON_CANCEL,
				   NULL);
	label = gtk_label_new (_("Connecting to server..."));
	gtk_box_pack_start (GTK_BOX(GNOME_DIALOG (dialog)->vbox),
			    label, TRUE, TRUE, 10);
	gnome_dialog_set_close (GNOME_DIALOG (dialog), FALSE);
	gtk_signal_connect (GTK_OBJECT (dialog), "clicked",
			    GTK_SIGNAL_FUNC (check_cancelled), &id);
	gtk_window_set_modal (GTK_WINDOW (dialog), TRUE);
	gtk_widget_show_all (dialog);

	mail_msg_wait(id);

	gtk_widget_destroy (dialog);

	return ret;
}

/* MailConfig Bonobo object */
#define PARENT_TYPE BONOBO_X_OBJECT_TYPE
static BonoboObjectClass *parent_class = NULL;

/* For the bonobo object */
typedef struct _EvolutionMailConfig EvolutionMailConfig;
typedef struct _EvolutionMailConfigClass EvolutionMailConfigClass;

struct _EvolutionMailConfig {
	BonoboXObject parent;
};

struct _EvolutionMailConfigClass {
	BonoboXObjectClass parent_class;

	POA_GNOME_Evolution_MailConfig__epv epv;
};

static void
impl_GNOME_Evolution_MailConfig_addAccount (PortableServer_Servant servant,
					    const GNOME_Evolution_MailConfig_Account *account,
					    CORBA_Environment *ev)
{
	GNOME_Evolution_MailConfig_Service source, transport;
	GNOME_Evolution_MailConfig_Identity id;
	MailConfigAccount *mail_account;
	MailConfigService *mail_service;
	MailConfigIdentity *mail_id;

	mail_account = g_new0 (MailConfigAccount, 1);
	mail_account->name = g_strdup (account->name);

	/* Copy ID */
	id = account->id;
	mail_id = g_new0 (MailConfigIdentity, 1);
	mail_id->name = g_strdup (id.name);
	mail_id->address = g_strdup (id.address);
	mail_id->organization = g_strdup (id.organization);
	mail_id->signature = g_strdup (id.signature);
	mail_id->html_signature = g_strdup (id.html_signature);
	mail_id->has_html_signature = id.has_html_signature;

	mail_account->id = mail_id;

	/* Copy source */
	source = account->source;
	mail_service = g_new0 (MailConfigService, 1);
	mail_service->url = g_strdup (source.url);
	mail_service->keep_on_server = source.keep_on_server;
	mail_service->auto_check = source.auto_check;
	mail_service->auto_check_time = source.auto_check_time;
	mail_service->save_passwd = source.save_passwd;
	mail_service->enabled = source.enabled;

	mail_account->source = mail_service;

	/* Copy transport */
	transport = account->transport;
	mail_service = g_new0 (MailConfigService, 1);
	mail_service->url = g_strdup (transport.url);
	mail_service->keep_on_server = transport.keep_on_server;
	mail_service->auto_check = transport.auto_check;
	mail_service->auto_check_time = transport.auto_check_time;
	mail_service->save_passwd = transport.save_passwd;
	mail_service->enabled = transport.enabled;

	mail_account->transport = mail_service;

	/* Add new account */
	mail_config_add_account (mail_account);
}

static void
evolution_mail_config_class_init (EvolutionMailConfigClass *klass)
{
	POA_GNOME_Evolution_MailConfig__epv *epv = &klass->epv;

	parent_class = gtk_type_class (PARENT_TYPE);
	epv->addAccount = impl_GNOME_Evolution_MailConfig_addAccount;
}

static void
evolution_mail_config_init (EvolutionMailConfig *config)
{
}

BONOBO_X_TYPE_FUNC_FULL (EvolutionMailConfig,
			 GNOME_Evolution_MailConfig,
			 PARENT_TYPE,
			 evolution_mail_config);

static BonoboObject *
evolution_mail_config_factory_fn (BonoboGenericFactory *factory,
				  void *closure)
{
	EvolutionMailConfig *config;

	g_warning ("Made");
	config = gtk_type_new (evolution_mail_config_get_type ());
	return BONOBO_OBJECT (config);
}

void
evolution_mail_config_factory_init (void)
{
	BonoboGenericFactory *factory;
	
	g_warning ("Starting mail config");
	factory = bonobo_generic_factory_new (MAIL_CONFIG_IID, 
					      evolution_mail_config_factory_fn,
					      NULL);
	if (factory == NULL) {
		g_warning ("Error starting MailConfig");
	}

	g_warning ("Registered");
	bonobo_running_context_auto_exit_unref (BONOBO_OBJECT (factory));
}
graph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=2ca1db97c9db0d22865b668bf0f3a1d03f77cdb6'>Minor Changes.</a></td><td>Aaron Weber</td><td><span title='2001-02-09 04:44:25 +0800'>2001-02-09</span></td><td>7</td><td><span class='deletions'>-108</span>/<span class='insertions'>+168</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=a214731656835afc502b48d01570bf1f3b4b7a6c'>s/contact manager/address book/ and revised text.</a></td><td>Aaron Weber</td><td><span title='2001-02-08 02:20:19 +0800'>2001-02-08</span></td><td>5</td><td><span class='deletions'>-47</span>/<span class='insertions'>+69</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=609933378dab3b1df305afef4c51195373ab526f'>Final docs.</a></td><td>Iain Holmes</td><td><span title='2001-02-02 08:28:04 +0800'>2001-02-02</span></td><td>3</td><td><span class='deletions'>-2</span>/<span class='insertions'>+18</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=c002ddaf4faa6cc4a32752af29dccd1d9918af63'>More docs...</a></td><td>Iain Holmes</td><td><span title='2001-02-02 08:27:17 +0800'>2001-02-02</span></td><td>7</td><td><span class='deletions'>-51</span>/<span class='insertions'>+76</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=f8918d44539c1df3a3eacc2afe1507aa8c0b5093'>Wheeee pretty documentation</a></td><td>Iain Holmes</td><td><span title='2001-02-02 08:25:59 +0800'>2001-02-02</span></td><td>14</td><td><span class='deletions'>-0</span>/<span class='insertions'>+1097</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=0fda3e923ec78c749b3542bec0509844af9f0056'>Change (nonexistant) importer.sgml references to evolution-importer.sgml</a></td><td>John R. Sheets</td><td><span title='2001-01-28 01:17:59 +0800'>2001-01-28</span></td><td>2</td><td><span class='deletions'>-12</span>/<span class='insertions'>+17</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=50b55e669f8db4d0cb6ff621e30ce831995537f0'>Doc updates - Federico</a></td><td>Federico Mena Quintero</td><td><span title='2001-01-20 23:37:58 +0800'>2001-01-20</span></td><td>3</td><td><span class='deletions'>-228</span>/<span class='insertions'>+228</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=3532a74349645ca733bafe1417822ba2bfb9bd26'>create a new cal component alarm (cal_component_add_alarm): add alarm to</a></td><td>JP Rosevear</td><td><span title='2001-01-19 22:57:09 +0800'>2001-01-19</span></td><td>3</td><td><span class='deletions'>-230</span>/<span class='insertions'>+245</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=788351db0a44bbbb19c2bc4b3962e5abfd001c69'>More of Megan's revisions, and Field Chooser functions in the Sort</a></td><td>Aaron Weber</td><td><span title='2001-01-19 15:25:16 +0800'>2001-01-19</span></td><td>6</td><td><span class='deletions'>-242</span>/<span class='insertions'>+290</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=e3297a5f71f408b9ed93c81a25af54c13b93f848'>Um, why was the doc directory removed from SUBDIRS?</a></td><td>Federico Mena Quintero</td><td><span title='2001-01-19 02:00:31 +0800'>2001-01-19</span></td><td>1</td><td><span class='deletions'>-18</span>/<span class='insertions'>+18</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=26dd492af6580330cd6a893717a237d47a3efd01'>Use "typedef enum { ... } Blah;" instead of "typedef enum _Blah Blah; enum</a></td><td>Federico Mena Quintero</td><td><span title='2001-01-18 06:31:35 +0800'>2001-01-18</span></td><td>4</td><td><span class='deletions'>-51</span>/<span class='insertions'>+46</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=b77c7192f536108e07ffaf19a58e6bff9b011a93'>Some API documentation for the importer</a></td><td>Iain Holmes</td><td><span title='2001-01-18 02:27:02 +0800'>2001-01-18</span></td><td>16</td><td><span class='deletions'>-2</span>/<span class='insertions'>+465</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=0d98ffff7025693ccdf75fd11fe05b34b1d8fc6e'>Ximianified.</a></td><td>Federico Mena Quintero</td><td><span title='2001-01-17 18:48:30 +0800'>2001-01-17</span></td><td>13</td><td><span class='deletions'>-290</span>/<span class='insertions'>+376</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=84d79685129c2c31a99eef621aa6bb03112e4573'>remove old config message</a></td><td>JP Rosevear</td><td><span title='2001-01-15 09:34:54 +0800'>2001-01-15</span></td><td>1</td><td><span class='deletions'>-82</span>/<span class='insertions'>+82</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=80b2b2222ea67c50e0e3f9fdeb1797fb7874f862'>pass -module and -avoid-version to conduit linker</a></td><td>JP Rosevear</td><td><span title='2001-01-14 22:58:15 +0800'>2001-01-14</span></td><td>4</td><td><span class='deletions'>-168</span>/<span class='insertions'>+144</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=8fa5361a5ffd43d4bbcff617d5baa8cc019482b7'>Make it work when gtk-doc is not installed.</a></td><td>Federico Mena Quintero</td><td><span title='2001-01-11 23:25:25 +0800'>2001-01-11</span></td><td>6</td><td><span class='deletions'>-0</span>/<span class='insertions'>+91</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=2e3bf2d247de7646868bc45167b5e3afa8b48e10'>More Makefile organization to compile</a></td><td>Miguel de Icaza</td><td><span title='2001-01-10 10:15:08 +0800'>2001-01-10</span></td><td>10</td><td><span class='deletions'>-121</span>/<span class='insertions'>+71</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=e6e6a76a4ed43e566aae7c5cc1f39e5cbdd61fd5'>Added calendar/gui/alarm-notify/Makefile.</a></td><td>Federico Mena Quintero</td><td><span title='2001-01-10 05:41:00 +0800'>2001-01-10</span></td><td>2</td><td><span class='deletions'>-83</span>/<span class='insertions'>+93</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=5ff5cd81532edda57a0793273fee0cdadef07dd9'>Remove non-existent file</a></td><td>JP Rosevear</td><td><span title='2001-01-05 05:56:16 +0800'>2001-01-05</span></td><td>2</td><td><span class='deletions'>-92</span>/<span class='insertions'>+91</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=b3e4ed6da61c048e670a0623f18645f5519c3cd0'>Unconditionally remove the client from the alarm notification system.</a></td><td>Federico Mena Quintero</td><td><span title='2001-01-03 00:35:57 +0800'>2001-01-03</span></td><td>3</td><td><span class='deletions'>-136</span>/<span class='insertions'>+136</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=c7e6af5698a90f837f71709af3413569d1ff216a'>Remove deleted file</a></td><td>JP Rosevear</td><td><span title='2000-12-23 14:44:45 +0800'>2000-12-23</span></td><td>4</td><td><span class='deletions'>-137</span>/<span class='insertions'>+136</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=4369c400fc801eef03a6fdda2b5256972f018246'>Alarm trigger queueing for the GUI part.</a></td><td>Federico Mena Quintero</td><td><span title='2000-12-23 01:29:39 +0800'>2000-12-23</span></td><td>2</td><td><span class='deletions'>-11</span>/<span class='insertions'>+11</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=e90aa50001b8014497651628666455ab5c12c7b0'>Added proper dependency lists to the gtk-doc mess.</a></td><td>Federico Mena Quintero</td><td><span title='2000-12-20 02:13:34 +0800'>2000-12-20</span></td><td>16</td><td><span class='deletions'>-562</span>/<span class='insertions'>+875</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=8d96fe16f15f653d0809603ccaecd677e5708d8d'>Alarm instance generation support for the Wombat.</a></td><td>Federico Mena Quintero</td><td><span title='2000-12-19 07:47:52 +0800'>2000-12-19</span></td><td>5</td><td><span class='deletions'>-0</span>/<span class='insertions'>+69</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=3ba61815e2430e91dcaf310ad458feab9d78a2c4'>Revisions as suggested by Dan. Especially to filter dialogs... which still</a></td><td>Aaron Weber</td><td><span title='2000-12-15 07:57:29 +0800'>2000-12-15</span></td><td>4</td><td><span class='deletions'>-125</span>/<span class='insertions'>+189</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=25d1434052a54439e07a9f21937c5bb9d9d27f10'>make it public-reference.sgml not referenc.sgml here.</a></td><td>Larry Ewing</td><td><span title='2000-12-14 04:03:08 +0800'>2000-12-14</span></td><td>2</td><td><span class='deletions'>-1</span>/<span class='insertions'>+6</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=b16856bf76e33707ca8fcaa6ccad78c01d08e119'>upd.</a></td><td>Michael Meeks</td><td><span title='2000-12-10 07:37:08 +0800'>2000-12-10</span></td><td>1</td><td><span class='deletions'>-1</span>/<span class='insertions'>+5</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=30b66ebe39c81139ae135c4985a16783b221e492'>upd.</a></td><td>Michael Meeks</td><td><span title='2000-12-05 04:39:41 +0800'>2000-12-05</span></td><td>1</td><td><span class='deletions'>-0</span>/<span class='insertions'>+33</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=042e514a262c922d258ca8f0557500199f7088d9'>return NULL if we can't create a view.</a></td><td>Michael Meeks</td><td><span title='2000-12-05 01:56:54 +0800'>2000-12-05</span></td><td>1</td><td><span class='deletions'>-0</span>/<span class='insertions'>+28</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=ce1f72922f81fa83d2531adc93d3b733ec475f59'>Finished the calendar architecture chapter.</a></td><td>Federico Mena Quintero</td><td><span title='2000-11-30 10:43:57 +0800'>2000-11-30</span></td><td>2</td><td><span class='deletions'>-3</span>/<span class='insertions'>+76</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=cb5a1deee0c9cb099fdf5d561018febbc3c294df'>added some &lt;glossterms&gt;, added linkends to existing glossterms.</a></td><td>Aaron Weber</td><td><span title='2000-11-30 01:33:19 +0800'>2000-11-30</span></td><td>10</td><td><span class='deletions'>-107</span>/<span class='insertions'>+342</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=ef585975d00ddbc021fa9a1181723c67b3223a82'>Added an id for the API reference &lt;part&gt;. Added the FDL &lt;legalnotice&gt;.</a></td><td>Federico Mena Quintero</td><td><span title='2000-11-30 00:26:59 +0800'>2000-11-30</span></td><td>11</td><td><span class='deletions'>-87</span>/<span class='insertions'>+963</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=710b5855179220dbc19af61ecc4f65e22f6465ed'>Fixed validation errors.</a></td><td>Aaron Weber</td><td><span title='2000-11-02 10:44:40 +0800'>2000-11-02</span></td><td>8</td><td><span class='deletions'>-217</span>/<span class='insertions'>+610</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=a6eeb1e1624c399b56b8e670be9a5c9cefd20745'>added composer keybindings description</a></td><td>Radek Doulik</td><td><span title='2000-11-02 05:02:03 +0800'>2000-11-02</span></td><td>2</td><td><span class='deletions'>-0</span>/<span class='insertions'>+13</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=282366db85d5be6b8b590a481edff110bb597713'>Add Keybindings, please populate</a></td><td>Miguel de Icaza</td><td><span title='2000-11-02 00:45:58 +0800'>2000-11-02</span></td><td>1</td><td><span class='deletions'>-0</span>/<span class='insertions'>+4</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=b271cff341184f785f263a82921d6b09d4401074'>Actions -&gt; New Directory Server added.</a></td><td>Aaron Weber</td><td><span title='2000-10-26 06:17:03 +0800'>2000-10-26</span></td><td>5</td><td><span class='deletions'>-11</span>/<span class='insertions'>+111</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=8858c786e7efa88da2790d42f9aa09b5aaa11736'>Re-checked validity of all files. Made minor changes to menuref.sgml,</a></td><td>Aaron Weber</td><td><span title='2000-10-12 06:13:35 +0800'>2000-10-12</span></td><td>9</td><td><span class='deletions'>-67</span>/<span class='insertions'>+99</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=169085b6806eac8a49ab32ee6b7aba6c530a39ea'>Re-took most screenshots; last batch had wrong Sawfish theme.</a></td><td>Aaron Weber</td><td><span title='2000-10-11 07:17:55 +0800'>2000-10-11</span></td><td>12</td><td><span class='deletions'>-76</span>/<span class='insertions'>+174</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=5d5c636e5a8a3264a6a860c7f8ace9ebdf137ff5'>Described Search features.</a></td><td>Aaron Weber</td><td><span title='2000-10-05 16:35:01 +0800'>2000-10-05</span></td><td>9</td><td><span class='deletions'>-180</span>/<span class='insertions'>+410</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=774584fd4dc7e4dd6f8ed878407aaa3d885c03e8'>Spellcheck. Fixed some wording, and responded to clahey's suggestions--</a></td><td>Aaron Weber</td><td><span title='2000-10-04 13:18:55 +0800'>2000-10-04</span></td><td>11</td><td><span class='deletions'>-391</span>/<span class='insertions'>+503</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=0b1e68cb22f92bfe82b3fcbca4d57814cc26ad4f'>Switched to the "official" FSF markup. I will have to make changes to the</a></td><td>Aaron Weber</td><td><span title='2000-09-22 02:14:44 +0800'>2000-09-22</span></td><td>6</td><td><span class='deletions'>-795</span>/<span class='insertions'>+649</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=b9401b5e1d56efe83087574adad21155c65a4793'>Fixed sig stuff here and in setupassist.</a></td><td>Aaron Weber</td><td><span title='2000-09-20 15:46:07 +0800'>2000-09-20</span></td><td>5</td><td><span class='deletions'>-35</span>/<span class='insertions'>+46</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=8617011337e9cf39c7c98676908f44d2b28878a8'>Fixed to install the stylesheet-images as well.</a></td><td>Federico Mena Quintero</td><td><span title='2000-09-20 07:41:07 +0800'>2000-09-20</span></td><td>4</td><td><span class='deletions'>-7</span>/<span class='insertions'>+22</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=4aee454eba98a1c0052ec400bacc061af72d50cb'>Made the toplevel &lt;book&gt; id be "index".</a></td><td>Federico Mena Quintero</td><td><span title='2000-09-16 06:36:48 +0800'>2000-09-16</span></td><td>2</td><td><span class='deletions'>-1</span>/<span class='insertions'>+6</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=9964204c9c080650f79863a483a4c42886d55239'>The Commit from hell that breaks all UI related stuff;</a></td><td>Michael Meeks</td><td><span title='2000-09-14 07:40:42 +0800'>2000-09-14</span></td><td>1</td><td><span class='deletions'>-7</span>/<span class='insertions'>+0</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=972c515f0fbcd96be5b87275c82376d9394a0078'>contact-editor.png, mail-composer.png, filter-assist-fig.png,</a></td><td>Aaron Weber</td><td><span title='2000-09-08 05:56:22 +0800'>2000-09-08</span></td><td>4</td><td><span class='deletions'>-0</span>/<span class='insertions'>+0</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=722a05828e68522a639a04ae0b13855e6b70820b'>Redid "soft" intro stuff, worked on mail a little. minor commit.</a></td><td>Aaron Weber</td><td><span title='2000-09-08 00:25:04 +0800'>2000-09-08</span></td><td>2</td><td><span class='deletions'>-19</span>/<span class='insertions'>+21</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=64119bc6be1866141e7a48935d6e6b907608a880'>Accidentally broke docs, now valid.</a></td><td>Aaron Weber</td><td><span title='2000-09-08 00:02:44 +0800'>2000-09-08</span></td><td>7</td><td><span class='deletions'>-188</span>/<span class='insertions'>+298</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=69b79e75f6f32d1b61ac38ab0a797eac92f391fc'>Grammar, links, screenshots.</a></td><td>Aaron Weber</td><td><span title='2000-09-06 05:04:15 +0800'>2000-09-06</span></td><td>7</td><td><span class='deletions'>-0</span>/<span class='insertions'>+0</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=acfe848315c12b21544e0273fe2d99c9e23c188d'>Added coverage of news, clarified POP/IMAP distinction (there's a theme to</a></td><td>Aaron Weber</td><td><span title='2000-09-02 02:18:02 +0800'>2000-09-02</span></td><td>4</td><td><span class='deletions'>-47</span>/<span class='insertions'>+136</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=95c68912699be41ba05576c180e37613bf72c25e'>Added regular expressions to glossary. Explanation should be removed from</a></td><td>Aaron Weber</td><td><span title='2000-08-31 22:53:41 +0800'>2000-08-31</span></td><td>6</td><td><span class='deletions'>-223</span>/<span class='insertions'>+262</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=04865e57d321a7d35e5165e8ec6de8f505ab54de'>Added "quickref and pointers" sections. Props to O'Reilly for the copy of</a></td><td>Aaron Weber</td><td><span title='2000-08-31 14:02:03 +0800'>2000-08-31</span></td><td>5</td><td><span class='deletions'>-58</span>/<span class='insertions'>+326</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=07052702e460c9739ab71fd11e3101feb012c55f'>Redid filter and vFolder assistant descriptions.</a></td><td>Aaron Weber</td><td><span title='2000-08-25 15:26:52 +0800'>2000-08-25</span></td><td>5</td><td><span class='deletions'>-133</span>/<span class='insertions'>+641</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=ce8ba9444287f5a39e5ecec8cf185b09ed088f75'>Message Composer File and Edit menus.</a></td><td>Aaron Weber</td><td><span title='2000-08-24 12:25:21 +0800'>2000-08-24</span></td><td>2</td><td><span class='deletions'>-2</span>/<span class='insertions'>+193</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=c3d7a35a9f00bae329978b56abb09c1500797b49'>Added editor sections.</a></td><td>Aaron Weber</td><td><span title='2000-08-23 14:44:11 +0800'>2000-08-23</span></td><td>2</td><td><span class='deletions'>-1</span>/<span class='insertions'>+29</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=051e2979b263245d1e3d122add3becacfbab9bb1'>Included Menu Reference Appendix.</a></td><td>Aaron Weber</td><td><span title='2000-08-23 14:10:16 +0800'>2000-08-23</span></td><td>5</td><td><span class='deletions'>-112</span>/<span class='insertions'>+783</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=bf9f26b7733b298c31415734d6f41d30e9213b54'>Added the cal-util library to the documentation framework - Federico</a></td><td>Federico Mena Quintero</td><td><span title='2000-08-15 07:59:13 +0800'>2000-08-15</span></td><td>22</td><td><span class='deletions'>-24</span>/<span class='insertions'>+2536</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=13263cdb400a2cda1b57f96490a43aa53709dbbd'>Fix make maintainer-clean</a></td><td>Peter Williams</td><td><span title='2000-08-10 05:24:40 +0800'>2000-08-10</span></td><td>2</td><td><span class='deletions'>-1</span>/<span class='insertions'>+6</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=b3d0e151a2aaf59c8150d184cdec56db6caa2b11'>Fixed bugs in validation. Went home to sleep.</a></td><td>Aaron Weber</td><td><span title='2000-08-10 03:00:27 +0800'>2000-08-10</span></td><td>3</td><td><span class='deletions'>-12</span>/<span class='insertions'>+12</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=5c56e0419549b1b4ad2275482facbf3aed5498eb'>Redid menubar description.</a></td><td>Aaron Weber</td><td><span title='2000-08-10 01:23:10 +0800'>2000-08-10</span></td><td>6</td><td><span class='deletions'>-62</span>/<span class='insertions'>+320</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=0d99e1d70e42c96e8521fd4bc0dc3120e51d5816'>New file. Contains contents of "COPYING", but marked up (probably not very</a></td><td>Aaron Weber</td><td><span title='2000-08-05 14:34:50 +0800'>2000-08-05</span></td><td>7</td><td><span class='deletions'>-197</span>/<span class='insertions'>+657</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=1265f5c0b1f6aba78139605f4df86f87f399832a'>Spellchecking, proofing in all .sgml files except FDL and authors.</a></td><td>Aaron Weber</td><td><span title='2000-07-27 03:26:26 +0800'>2000-07-27</span></td><td>10</td><td><span class='deletions'>-117</span>/<span class='insertions'>+158</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=cfa918989ab23e88aa01a3d4672ee39b86e87a93'>proofing all over.</a></td><td>Aaron Weber</td><td><span title='2000-07-26 09:06:03 +0800'>2000-07-26</span></td><td>18</td><td><span class='deletions'>-208</span>/<span class='insertions'>+308</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=31f6fc71f2b1095f0cb2423358c3da09f0e82121'>Added password remembering/forgetting feature.</a></td><td>Aaron Weber</td><td><span title='2000-07-21 20:21:17 +0800'>2000-07-21</span></td><td>9</td><td><span class='deletions'>-230</span>/<span class='insertions'>+333</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=fe922f643779c83d9c71b7fc19a0f66d9f15d37a'>lots of minor fixes to language. added desc. of clahey's cool</a></td><td>Aaron Weber</td><td><span title='2000-07-19 22:20:34 +0800'>2000-07-19</span></td><td>4</td><td><span class='deletions'>-171</span>/<span class='insertions'>+243</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=7672cda86c2632fef0284b5a62ba5fcaa5a32037'>Sync - Federico</a></td><td>Federico Mena Quintero</td><td><span title='2000-07-19 01:19:25 +0800'>2000-07-19</span></td><td>1</td><td><span class='deletions'>-1</span>/<span class='insertions'>+47</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=f4f267580923e9cee563b151edb18edd7996b45e'>Altered category addition stuff, plus suggestions from Kevin.</a></td><td>Aaron Weber</td><td><span title='2000-07-18 18:05:03 +0800'>2000-07-18</span></td><td>5</td><td><span class='deletions'>-213</span>/<span class='insertions'>+295</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=9cad440d041093c75b601364d3038c082686c81a'>More docs - Federico</a></td><td>Federico Mena Quintero</td><td><span title='2000-07-18 12:20:46 +0800'>2000-07-18</span></td><td>2</td><td><span class='deletions'>-4</span>/<span class='insertions'>+36</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=86ec303a21211ab79c4e7a0c160e59b5605bfe15'>Docs docs docs - Federico</a></td><td>Federico Mena Quintero</td><td><span title='2000-07-18 07:57:22 +0800'>2000-07-18</span></td><td>2</td><td><span class='deletions'>-42</span>/<span class='insertions'>+108</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=af439c73e3770527174a54c2c28ab5e2e3615126'>Added the doc/devel Makefiles. (EVOLUTION_DIR): Substitute EVOLUTION_DIR</a></td><td>Federico Mena Quintero</td><td><span title='2000-07-18 05:09:46 +0800'>2000-07-18</span></td><td>2</td><td><span class='deletions'>-1</span>/<span class='insertions'>+5</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=e38c9ea0ed0f14ce563d355a0cea24460df26363'>New &lt;book&gt; toplevel for the Evolution Developer's Guide.</a></td><td>Federico Mena Quintero</td><td><span title='2000-07-18 05:08:41 +0800'>2000-07-18</span></td><td>20</td><td><span class='deletions'>-0</span>/<span class='insertions'>+715</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=592a45a9c07d92648ca2e791fa04e23ebd1afe62'>Remove conflict marks.</a></td><td>Ettore Perazzoli</td><td><span title='2000-07-11 08:37:05 +0800'>2000-07-11</span></td><td>1</td><td><span class='deletions'>-8</span>/<span class='insertions'>+0</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=66de89050fed92eb4ad979d193bf281ce8dddb67'>Minor fixes.</a></td><td>Aaron Weber</td><td><span title='2000-06-30 07:06:11 +0800'>2000-06-30</span></td><td>8</td><td><span class='deletions'>-23</span>/<span class='insertions'>+121</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=63485301d58b008af700a308d382fbfa24db3887'>commented out future features; redid contact editor stuff.</a></td><td>Aaron Weber</td><td><span title='2000-06-29 08:13:03 +0800'>2000-06-29</span></td><td>2</td><td><span class='deletions'>-127</span>/<span class='insertions'>+204</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=97bf430fbb1980da4b683dbe4b63128f69483c5b'>Fix Makefile.am for dependencies on removed devel docs</a></td><td>Peter Williams</td><td><span title='2000-06-28 23:24:55 +0800'>2000-06-28</span></td><td>2</td><td><span class='deletions'>-3</span>/<span class='insertions'>+5</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=18f1b73bcbeb9ed43090ca7894fc95491ab08ca7'>Removed file. Same. Same. Removed references to devel section. Removed</a></td><td>Aaron Weber</td><td><span title='2000-06-28 08:06:55 +0800'>2000-06-28</span></td><td>5</td><td><span class='deletions'>-96</span>/<span class='insertions'>+2</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=3b196ffb90e8d17f22cfc8f0422936d936de96f6'>Made moderate to major stylistic updates to this, apx-gloss.sgml, and to</a></td><td>Aaron Weber</td><td><span title='2000-06-24 04:32:12 +0800'>2000-06-24</span></td><td>6</td><td><span class='deletions'>-483</span>/<span class='insertions'>+587</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=8f9d4477d4692e44583ea0aa085f4b9a07e1bffd'>added evolution-guide and evolution-guide.junk so we don't get the '?</a></td><td>Damon Chaplin</td><td><span title='2000-06-16 14:54:41 +0800'>2000-06-16</span></td><td>2</td><td><span class='deletions'>-0</span>/<span class='insertions'>+8</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=a861e97686aa498cd9a9a9683ac8ec06e36952d0'>Category stuff improved.</a></td><td>Aaron Weber</td><td><span title='2000-06-15 19:02:42 +0800'>2000-06-15</span></td><td>2</td><td><span class='deletions'>-157</span>/<span class='insertions'>+240</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=f7074dc95ecbae890a52b085e42b45ad790b03a7'>added sect on menubar, other minor changes.</a></td><td>Aaron Weber</td><td><span title='2000-06-14 18:49:54 +0800'>2000-06-14</span></td><td>5</td><td><span class='deletions'>-1351</span>/<span class='insertions'>+1488</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=6aac85ab5b50dc9e3cc454c37858755a564120c3'>finished adding calendar prefs. screenshots. (may be second commit for</a></td><td>Aaron Weber</td><td><span title='2000-06-07 19:02:32 +0800'>2000-06-07</span></td><td>1</td><td><span class='deletions'>-20</span>/<span class='insertions'>+215</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=edca846bebfc9e446e67d1e79438f9ad1e9cd9fa'>finished adding calendar prefs. screenshots. new file (screenshot for</a></td><td>Aaron Weber</td><td><span title='2000-06-07 19:01:44 +0800'>2000-06-07</span></td><td>2</td><td><span class='deletions'>-0</span>/<span class='insertions'>+0</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=6e571188232f777da9d66737a78e4bc195ceff49'>Incorporated chgs from Kevin.</a></td><td>Aaron Weber</td><td><span title='2000-06-05 19:30:19 +0800'>2000-06-05</span></td><td>4</td><td><span class='deletions'>-107</span>/<span class='insertions'>+163</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=29a3e72881d3874ffaa4fd6dfce679239ea60bf8'>build and install docs</a></td><td>Dan Winship</td><td><span title='2000-06-02 07:37:49 +0800'>2000-06-02</span></td><td>5</td><td><span class='deletions'>-1</span>/<span class='insertions'>+67</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=0432ec4d0ff907163693849b1c3ddb08ba3b33d3'>improved filter instructions, vFolder instructions. still need work</a></td><td>Aaron Weber</td><td><span title='2000-06-02 07:24:58 +0800'>2000-06-02</span></td><td>10</td><td><span class='deletions'>-36</span>/<span class='insertions'>+219</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=c7ea21299d51a17280e2400bda29e80bcf01cb73'>fix my email address</a></td><td>Dan Winship</td><td><span title='2000-06-02 05:59:30 +0800'>2000-06-02</span></td><td>1</td><td><span class='deletions'>-1</span>/<span class='insertions'>+1</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=316db85df610bfbea1cd6e5ae9ab44f10d30ccb4'>incorporated kevins notes. incorporated kevins notes.</a></td><td>Aaron Weber</td><td><span title='2000-05-30 09:50:31 +0800'>2000-05-30</span></td><td>3</td><td><span class='deletions'>-59</span>/<span class='insertions'>+84</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=81bab650bb4ca76d93578064794d78190d0e9527'>added Kevin Breit to author and copyright.</a></td><td>Aaron Weber</td><td><span title='2000-05-28 12:05:59 +0800'>2000-05-28</span></td><td>7</td><td><span class='deletions'>-206</span>/<span class='insertions'>+270</span></td></tr>
<tr><td class='commitgraph'>* </td><td><a href='/~lantw44/cgit/gsoc2013-evolution/commit/doc?h=R_5_2&amp;id=7434b2831bd5604c6ee939c604cec5a91205b4d2'>new file new file New directory, for figure graphics.</a></td><td>Aaron Weber</td><td><span title='2000-05-27 04:06:55 +0800'>2000-05-27</span>