aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mail/ChangeLog17
-rw-r--r--mail/evolution-mail.schemas2
-rw-r--r--mail/folder-browser.c2
-rw-r--r--mail/mail-account-gui.c2
-rw-r--r--mail/mail-composer-prefs.c2
-rw-r--r--mail/mail-config.c346
-rw-r--r--mail/mail-config.h2
7 files changed, 224 insertions, 149 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index 6b481c4874..03773cdf9c 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,20 @@
+2003-01-16 Jeffrey Stedfast <fejj@ximian.com>
+
+ * mail-composer-prefs.c (sig_fill_clist): Same as below.
+
+ * mail-account-gui.c (sig_fill_options):
+ mail_config_get_signature_list() now returns a GSList instead of a
+ GList.
+
+ * mail-config.c (signature_new_from_xml): New function to parse a
+ signature xml blob into a MailConfigSignature structure.
+ (config_read_signatures): Rewritten to use above function.
+ (signature_to_xml): New function to write a signature to xml.
+ (config_write_signatures_num): Removed.
+ (config_write_signature): Removed.
+ (config_write_signatures): Rewritten to use signature_to_xml and
+ gconf.
+
2003-01-16 Dan Winship <danw@ximian.com>
* mail-config.h (MailConfigAccount): Add a UID field (to match
diff --git a/mail/evolution-mail.schemas b/mail/evolution-mail.schemas
index 81737cd759..9ef63074b7 100644
--- a/mail/evolution-mail.schemas
+++ b/mail/evolution-mail.schemas
@@ -223,7 +223,7 @@
<applyto>/apps/evolution/mail/display/paned_size</applyto>
<owner>evolution-mail</owner>
<type>long</type>
- <default>122</default>
+ <default>130</default>
<locale name="C">
<short>Height of the message-list pane</short>
<long>
diff --git a/mail/folder-browser.c b/mail/folder-browser.c
index 3836959a02..f611f126f4 100644
--- a/mail/folder-browser.c
+++ b/mail/folder-browser.c
@@ -2454,7 +2454,7 @@ folder_browser_gui_init (FolderBrowser *fb)
gtk_paned_add1 (GTK_PANED (fb->vpaned), GTK_WIDGET (fb->message_list));
gtk_widget_show (GTK_WIDGET (fb->message_list));
- fb->paned_resize_id = g_signal_connect (fb->message_list, "size_allocate",
+ fb->paned_resize_id = g_signal_connect (fb->message_list, "size-allocate",
G_CALLBACK (fb_resize_cb), fb);
gconf = gconf_client_get_default ();
diff --git a/mail/mail-account-gui.c b/mail/mail-account-gui.c
index cf9285f154..da8b35074b 100644
--- a/mail/mail-account-gui.c
+++ b/mail/mail-account-gui.c
@@ -1215,7 +1215,7 @@ sig_fill_options (MailAccountGui *gui)
{
GtkWidget *menu;
GtkWidget *mi;
- GList *l;
+ GSList *l;
MailConfigSignature *sig;
menu = gtk_option_menu_get_menu (GTK_OPTION_MENU (gui->sig_option_menu));
diff --git a/mail/mail-composer-prefs.c b/mail/mail-composer-prefs.c
index 2ca3997e45..7d6e56eba6 100644
--- a/mail/mail-composer-prefs.c
+++ b/mail/mail-composer-prefs.c
@@ -359,7 +359,7 @@ sig_selection_changed(GtkTreeSelection *selection, MailComposerPrefs *prefs)
static void
sig_fill_clist (GtkTreeView *clist)
{
- GList *l;
+ GSList *l;
GtkListStore *model;
GtkTreeIter iter;
diff --git a/mail/mail-config.c b/mail/mail-config.c
index ae02d57616..54ffbb1d31 100644
--- a/mail/mail-config.c
+++ b/mail/mail-config.c
@@ -83,8 +83,8 @@ typedef struct {
GHashTable *threaded_hash;
- GList *signature_list;
- int signatures;
+ GSList *signatures;
+ int sig_nextid;
MailConfigLabel labels[5];
@@ -322,18 +322,21 @@ xml_get_content (xmlNodePtr node)
}
static MailConfigSignature *
-lookup_signature (int i)
+lookup_signature (int id)
{
MailConfigSignature *sig;
- GList *l;
+ GSList *l;
- if (i == -1)
+ if (id == -1)
return NULL;
- for (l = config->signature_list; l; l = l->next) {
+ l = config->signatures;
+ while (l != NULL) {
sig = (MailConfigSignature *) l->data;
- if (sig->id == i)
+ if (sig->id == id)
return sig;
+
+ l = l->next;
}
return NULL;
@@ -699,114 +702,159 @@ mail_config_clear (void)
}
static MailConfigSignature *
-config_read_signature (int i)
+signature_new_from_xml (char *in, int id)
{
MailConfigSignature *sig;
- char *path, *val;
+ xmlNodePtr node, cur;
+ xmlDocPtr doc;
+ char *buf;
- sig = g_new0 (MailConfigSignature, 1);
+ if (!(doc = xmlParseDoc (in)))
+ return NULL;
- sig->id = i;
-
-#warning "need to rewrite the config_read_signature()"
-#if 0
- path = g_strdup_printf ("/apps/Evolution/Mail/Signatures/name_%d", i);
- val = e_config_listener_get_string (config->db, path);
- g_free (path);
- if (val && *val)
- sig->name = val;
- else
- g_free (val);
+ node = doc->children;
+ if (strcmp (node->name, "signature") != 0) {
+ xmlFreeDoc (doc);
+ return NULL;
+ }
- path = g_strdup_printf ("/apps/Evolution/Mail/Signatures/filename_%d", i);
- val = e_config_listener_get_string (config->db, path);
- g_free (path);
- if (val && *val)
- sig->filename = val;
- else
- g_free (val);
+ sig = g_new0 (MailConfigSignature, 1);
+ sig->name = xml_get_prop (node, "name");
+ sig->id = id;
- path = g_strdup_printf ("/apps/Evolution/Mail/Signatures/script_%d", i);
- val = e_config_listener_get_string (config->db, path);
- g_free (path);
- if (val && *val)
- sig->script = val;
+ buf = xml_get_prop (node, "format");
+ if (!strcmp (buf, "text/html"))
+ sig->html = TRUE;
else
- g_free (val);
+ sig->html = FALSE;
+ g_free (buf);
+
+ cur = node->children;
+ while (cur) {
+ if (!strcmp (cur->name, "filename")) {
+ g_free (sig->filename);
+ sig->filename = xml_get_content (cur);
+ } else if (!strcmp (cur->name, "script")) {
+ g_free (sig->script);
+ sig->script = xml_get_content (cur);
+ }
+
+ cur = cur->next;
+ }
- path = g_strdup_printf ("/apps/Evolution/Mail/Signatures/html_%d", i);
- sig->html = e_config_listener_get_boolean_with_default (config->db, path, FALSE, NULL);
- g_free (path);
-#endif
+ xmlDocFree (doc);
return sig;
}
static void
-config_read_signatures ()
+config_read_signatures (void)
{
MailConfigSignature *sig;
- int i;
+ GSList *list, *l, *tail, *n;
+ int i = 0;
- config->signature_list = NULL;
- config->signatures = 0;
+ config->signatures = NULL;
-#warning "need to rewrite config_read_signatures()"
-#if 0
- config->signatures = e_config_listener_get_long_with_default (config->db, "/apps/Evolution/Mail/Signatures/num", 0, NULL);
+ tail = NULL;
+ list = gconf_client_get_list (config->gconf, "/apps/evolution/mail/signatures",
+ GCONF_VALUE_STRING, NULL);
- for (i = 0; i < config->signatures; i ++) {
- sig = config_read_signature (i);
- config->signature_list = g_list_append (config->signature_list, sig);
+ l = list;
+ while (l != NULL) {
+ MailConfigSignature *sig;
+
+ if ((sig = signature_new_from_xml ((char *) l->data, i++))) {
+ n = g_slist_alloc ();
+ n->next = NULL;
+ n->data = sig;
+
+ if (tail == NULL)
+ config->signatures = n;
+ else
+ tail->next = n;
+ tail = n;
+ }
+
+ n = l->next;
+ g_slist_free_1 (l);
+ l = n;
}
-#endif
+
+ config->sig_nextid = i + 1;
}
-static void
-config_write_signature (MailConfigSignature *sig, gint i)
+static char *
+signature_to_xml (MailConfigSignature *sig)
{
-#warning "need to rewrite config_write_signature()"
-#if 0
- char *path;
+ char *xmlbuf, *tmp;
+ xmlNodePtr root;
+ xmlDocPtr doc;
+ int n;
- printf ("config_write_signature i: %d id: %d\n", i, sig->id);
+ doc = xmlNewDoc ("1.0");
- path = g_strdup_printf ("/apps/Evolution/Mail/Signatures/name_%d", i);
- e_config_listener_set_string (config->db, path, sig->name ? sig->name : "");
- g_free (path);
+ root = xmlNewDocNode (doc, NULL, "signature", NULL);
+ xmlDocSetRootElement (doc, root);
- path = g_strdup_printf ("/apps/Evolution/Mail/Signatures/filename_%d", i);
- e_config_listener_set_string (config->db, path, sig->filename ? sig->filename : "");
- g_free (path);
+ xmlSetProp (root, "name", sig->name);
+ xmlSetProp (root, "format", sig->html ? "text/html" : "text/plain");
- path = g_strdup_printf ("/apps/Evolution/Mail/Signatures/script_%d", i);
- e_config_listener_set_string (config->db, path, sig->script ? sig->script : "");
- g_free (path);
+ if (sig->filename)
+ xmlNewTextChild (root, NULL, "filename", sig->filename);
- path = g_strdup_printf ("/apps/Evolution/Mail/Signatures/html_%d", i);
- e_config_listener_set_boolean (config->db, path, sig->html);
- g_free (path);
-#endif
-}
-
-static void
-config_write_signatures_num ()
-{
-#warning "need to rewrite config_write_signatures_num()"
- /*e_config_listener_set_long (config->db, "/apps/Evolution/Mail/Signatures/num", config->signatures);*/
+ if (sig->script)
+ xmlNewTextChild (root, NULL, "script", sig->script);
+
+ xmlDocDumpMemory (doc, (xmlChar **) &xmlbuf, &n);
+ xmlFreeDoc (doc);
+
+ /* remap to glib memory */
+ tmp = g_malloc (n + 1);
+ memcpy (tmp, xmlbuf, n);
+ tmp[n] = '\0';
+ xmlFree (xmlbuf);
+
+ return tmp;
}
static void
-config_write_signatures ()
+config_write_signatures (void)
{
- GList *l;
- int id;
+ GSList *list, *tail, *n, *l;
+ char *xmlbuf;
- for (id = 0, l = config->signature_list; l; l = l->next, id ++) {
- config_write_signature ((MailConfigSignature *) l->data, id);
+ list = NULL;
+ tail = NULL;
+
+ l = config->signatures;
+ while (l != NULL) {
+ if ((xmlbuf = signature_to_xml ((MailConfigSignature *) l->data))) {
+ n = g_slist_alloc ();
+ n->data = xmlbuf;
+ n->next = NULL;
+
+ if (tail == NULL)
+ list = n;
+ else
+ tail->next = n;
+ tail = n;
+ }
+
+ l = l->next;
}
- config_write_signatures_num ();
+ gconf_client_set_list (config->gconf, "/apps/evolution/mail/signatures", GCONF_VALUE_STRING, list, NULL);
+
+ l = list;
+ while (l != NULL) {
+ n = l->next;
+ g_free (l->data);
+ g_slist_free_1 (l);
+ l = n;
+ }
+
+ gconf_client_suggest_sync (config->gconf, NULL);
}
void
@@ -1711,21 +1759,21 @@ evolution_mail_config_factory_init (void)
return TRUE;
}
-GList *
+GSList *
mail_config_get_signature_list (void)
{
- return config->signature_list;
+ return config->signatures;
}
-static gchar *
-get_new_signature_filename ()
+static char *
+get_new_signature_filename (void)
{
- struct stat st_buf;
- gchar *filename;
- gint i;
-
+ char *filename, *id;
+ struct stat st;
+ int i;
+
filename = g_build_filename (evolution_dir, "/signatures", NULL);
- if (lstat (filename, &st_buf)) {
+ if (lstat (filename, &st)) {
if (errno == ENOENT) {
if (mkdir (filename, 0700))
g_warning ("Fatal problem creating %s/signatures directory.", evolution_dir);
@@ -1733,109 +1781,119 @@ get_new_signature_filename ()
g_warning ("Fatal problem with %s/signatures directory.", evolution_dir);
}
g_free (filename);
-
- for (i = 0; ; i ++) {
- filename = g_strdup_printf ("%s/signatures/signature-%d", evolution_dir, i);
- if (lstat (filename, &st_buf) == - 1 && errno == ENOENT) {
- gint fd;
-
+
+ filename = g_malloc (strlen (evolution_dir) + sizeof ("/signatures/signature-") + 12);
+ id = g_stpcpy (filename, evolution_dir);
+ id = g_stpcpy (id, "/signatures/signature-");
+
+ for (i = 0; i < (INT_MAX - 1); i++) {
+ sprintf (id, "%d", i);
+ if (lstat (filename, &st) == -1 && errno == ENOENT) {
+ int fd;
+
fd = creat (filename, 0600);
if (fd >= 0) {
close (fd);
return filename;
}
}
- g_free (filename);
}
-
+
+ g_free (filename);
+
return NULL;
}
MailConfigSignature *
-mail_config_signature_add (gboolean html, const gchar *script)
+mail_config_signature_add (gboolean html, const char *script)
{
MailConfigSignature *sig;
-
+
sig = g_new0 (MailConfigSignature, 1);
-
- /* printf ("mail_config_signature_add %d\n", config->signatures); */
- sig->id = config->signatures;
+
+ /* printf ("mail_config_signature_add %d\n", config->sig_nextid); */
+ sig->id = config->sig_nextid++;
sig->name = g_strdup (_("Unnamed"));
if (script)
sig->script = g_strdup (script);
else
sig->filename = get_new_signature_filename ();
sig->html = html;
-
- config->signature_list = g_list_append (config->signature_list, sig);
- config->signatures ++;
-
- config_write_signature (sig, sig->id);
- config_write_signatures_num ();
-
+
+ config->signatures = g_slist_append (config->signatures, sig);
+
+ config_write_signatures ();
+
mail_config_signature_emit_event (MAIL_CONFIG_SIG_EVENT_ADDED, sig);
/* printf ("mail_config_signature_add end\n"); */
-
+
return sig;
}
static void
-delete_unused_signature_file (const gchar *filename)
+delete_unused_signature_file (const char *filename)
{
- gint len;
- gchar *signatures_dir;
-
+ char *signatures_dir;
+ int len;
+
signatures_dir = g_strconcat (evolution_dir, "/signatures", NULL);
-
+
/* remove signature file if it's in evolution dir and no other signature uses it */
len = strlen (signatures_dir);
if (filename && !strncmp (filename, signatures_dir, len)) {
- GList *l;
gboolean only_one = TRUE;
-
- for (l = config->signature_list; l; l = l->next) {
- if (((MailConfigSignature *)l->data)->filename
- && !strcmp (filename, ((MailConfigSignature *)l->data)->filename)) {
+ GSList *node;
+
+ node = config->signatures;
+ while (node != NULL) {
+ MailConfigSignature *sig = node->data;
+
+ if (sig->filename && !strcmp (filename, sig->filename)) {
only_one = FALSE;
break;
}
+
+ node = node->next;
}
-
- if (only_one) {
+
+ if (only_one)
unlink (filename);
- }
}
-
+
g_free (signatures_dir);
}
void
mail_config_signature_delete (MailConfigSignature *sig)
{
- GList *l, *next;
- GSList *al;
+ GSList *node, *next;
gboolean after = FALSE;
-
- for (al = config->accounts; al; al = al->next) {
- MailConfigAccount *account;
-
- account = (MailConfigAccount *) al->data;
-
+
+ node = config->accounts;
+ while (node != NULL) {
+ MailConfigAccount *account = node->data;
+
if (account->id->def_signature == sig)
account->id->def_signature = NULL;
+
+ node = node->next;
}
-
- for (l = config->signature_list; l; l = next) {
- next = l->next;
- if (after)
- ((MailConfigSignature *) l->data)->id --;
- else if (l->data == sig) {
- config->signature_list = g_list_remove_link (config->signature_list, l);
+
+ node = config->signatures;
+ while (node != NULL) {
+ next = node->next;
+
+ if (after) {
+ ((MailConfigSignature *) node->data)->id--;
+ } else if (node->data == sig) {
+ config->signatures = g_slist_remove_link (config->signatures, node);
+ config->sig_nextid--;
after = TRUE;
- config->signatures --;
}
+
+ node = next;
}
-
+
config_write_signatures ();
delete_unused_signature_file (sig->filename);
/* printf ("signatures: %d\n", config->signatures); */
@@ -1850,7 +1908,7 @@ mail_config_signature_write (MailConfigSignature *sig)
}
void
-mail_config_signature_set_filename (MailConfigSignature *sig, const gchar *filename)
+mail_config_signature_set_filename (MailConfigSignature *sig, const char *filename)
{
gchar *old_filename = sig->filename;
@@ -1863,7 +1921,7 @@ mail_config_signature_set_filename (MailConfigSignature *sig, const gchar *filen
}
void
-mail_config_signature_set_name (MailConfigSignature *sig, const gchar *name)
+mail_config_signature_set_name (MailConfigSignature *sig, const char *name)
{
g_free (sig->name);
sig->name = g_strdup (name);
diff --git a/mail/mail-config.h b/mail/mail-config.h
index 970c718777..239a6d2feb 100644
--- a/mail/mail-config.h
+++ b/mail/mail-config.h
@@ -203,7 +203,7 @@ gboolean mail_config_check_service (const char *url, CamelProviderType type, GLi
gboolean evolution_mail_config_factory_init (void);
-GList *mail_config_get_signature_list (void);
+GSList *mail_config_get_signature_list (void);
MailConfigSignature *mail_config_signature_add (gboolean html, const gchar *script);
void mail_config_signature_delete (MailConfigSignature *sig);
void mail_config_signature_write (MailConfigSignature *sig);