diff options
author | Jeffrey Stedfast <fejj@ximian.com> | 2001-09-22 03:52:58 +0800 |
---|---|---|
committer | Jeffrey Stedfast <fejj@src.gnome.org> | 2001-09-22 03:52:58 +0800 |
commit | 0ddaedf4d698305250f84f29f2e20631b4b5cc61 (patch) | |
tree | 183b3970d94474ae4503be5ef92d75aaffb204b7 /camel | |
parent | 4d97946e705c10d3125f94ed8500ac0ed1af39d8 (diff) | |
download | gsoc2013-evolution-0ddaedf4d698305250f84f29f2e20631b4b5cc61.tar gsoc2013-evolution-0ddaedf4d698305250f84f29f2e20631b4b5cc61.tar.gz gsoc2013-evolution-0ddaedf4d698305250f84f29f2e20631b4b5cc61.tar.bz2 gsoc2013-evolution-0ddaedf4d698305250f84f29f2e20631b4b5cc61.tar.lz gsoc2013-evolution-0ddaedf4d698305250f84f29f2e20631b4b5cc61.tar.xz gsoc2013-evolution-0ddaedf4d698305250f84f29f2e20631b4b5cc61.tar.zst gsoc2013-evolution-0ddaedf4d698305250f84f29f2e20631b4b5cc61.zip |
Go back to not using camel_folder_info_build() here because this seems to
2001-09-21 Jeffrey Stedfast <fejj@ximian.com>
* providers/imap/camel-imap-store.c (create_folder): Go back to
not using camel_folder_info_build() here because this seems to
break folder creation (returning nodes from the root path when it
shouldn't be?).
svn path=/trunk/; revision=13054
Diffstat (limited to 'camel')
-rw-r--r-- | camel/ChangeLog | 7 | ||||
-rw-r--r-- | camel/providers/imap/camel-imap-store.c | 15 |
2 files changed, 18 insertions, 4 deletions
diff --git a/camel/ChangeLog b/camel/ChangeLog index 9ce9e3e9dd..550e99f6d5 100644 --- a/camel/ChangeLog +++ b/camel/ChangeLog @@ -1,3 +1,10 @@ +2001-09-21 Jeffrey Stedfast <fejj@ximian.com> + + * providers/imap/camel-imap-store.c (create_folder): Go back to + not using camel_folder_info_build() here because this seems to + break folder creation (returning nodes from the root path when it + shouldn't be?). + 2001-09-21 <NotZed@Ximian.com> * camel-vee-store.c (vee_get_folder_info): Force a refresh of diff --git a/camel/providers/imap/camel-imap-store.c b/camel/providers/imap/camel-imap-store.c index a632c6f0d6..6f058a7c60 100644 --- a/camel/providers/imap/camel-imap-store.c +++ b/camel/providers/imap/camel-imap-store.c @@ -1118,6 +1118,8 @@ create_folder (CamelStore *store, const char *parent_name, g_free (full_name); if (response) { + CamelFolderInfo *parent, *fi; + camel_imap_response_free (imap_store, response); /* We have to do this in case we are creating a @@ -1136,7 +1138,9 @@ create_folder (CamelStore *store, const char *parent_name, goto exception; } - for (i = 1; pathnames[i]; i++) { + root = parent = folders->pdata[i]; + + for (i = 1; parent && pathnames[i]; i++) { full_name = imap_concat (imap_store, parent_name, pathnames[i]); g_free (pathnames[i]); @@ -1149,13 +1153,16 @@ create_folder (CamelStore *store, const char *parent_name, if (folders->len != i + 1) break; + + fi = folders->pdata[i]; + camel_folder_info_build_path (fi, imap_store->dir_sep); + parent->child = fi; + fi->parent = parent; + parent = fi; } g_free (pathnames); - root = camel_folder_info_build (folders, camel_url_get_param (CAMEL_SERVICE (store)->url, "namespace"), - imap_store->dir_sep, TRUE); - g_ptr_array_free (folders, TRUE); } |