diff options
author | Not Zed <NotZed@Ximian.com> | 2002-06-06 17:53:36 +0800 |
---|---|---|
committer | Michael Zucci <zucchi@src.gnome.org> | 2002-06-06 17:53:36 +0800 |
commit | 1f993cacd1ac269ea4e7a77c57edbce732b9e8b5 (patch) | |
tree | b5e1562300b44d813a50320e80eff96e63559a41 /camel/camel-object.c | |
parent | a58c048d65965fd3b543f06dd1c4e2928c60ed68 (diff) | |
download | gsoc2013-evolution-1f993cacd1ac269ea4e7a77c57edbce732b9e8b5.tar.gz gsoc2013-evolution-1f993cacd1ac269ea4e7a77c57edbce732b9e8b5.tar.zst gsoc2013-evolution-1f993cacd1ac269ea4e7a77c57edbce732b9e8b5.zip |
Remove the CONF_DEFAULT_PATH entry, as this is handled by the url config
2002-06-04 Not Zed <NotZed@Ximian.com>
* providers/local/camel-local-provider.c: Remove the
CONF_DEFAULT_PATH entry, as this is handled by the url config
stuff. This made it basically impossible to configure any local
folder from the gui.
* providers/local/camel-local-folder.c (local_refresh_info): Force
a refresh. Should work for all local folders to force them to
refresh.
* providers/local/camel-maildir-folder.c (maildir_refresh_info):
Removed, moved into camel-local-folder.
* providers/local/camel-mh-summary.c (mh_summary_next_uid_string):
Once we assign or get a uid, tell the summary of this, so the next
uid we get will be higher than any previously.
* camel-object.c (camel_object_ref, camel_object_unref): I got
sick of casting, these now take void * like they should, and
perform their own run-time type checking.
* providers/local/camel-mh-store.c (recursive_scan): Changed to
use stat, not lstat (*shrug* maybe someone wants to softlink their
maildir tree?).
(inode_hash):
(inode_equal):
(inode_free): Copied from camel-maildir store (should put into
camel-local-store or utils?).
(recursive_scan): Changed to check for re-visiting inodes. Also,
it builds the tree itself, rather than using folder_info_build.
(add_folder): Changed to folder_info_new.
(recursive_scan): Properly honour the recursive flag. Also,
lookup unread count from folder.
(folder_info_new): Init unread message count to -1, since we dont
know yet.
(folder_info_new): Take the name as an argument, and perform the
merging here.
(folders_update): Util func to add/remove folders from .folders
file. I'm assuming its sorted.
(get_folder): Add the folder to .folders if we created a new one,
and if it exists.
(delete_folder): Remove from .folders, etc.
(folders_scan): If we have a .folders file, read and use that
instead.
(recursive_scan): Handle scanning from a particular directory
properly.
(rename_folder): Implement so we can track any changes to the
.folders file if its turned on.
** Applied patch below from Greg Hudson.
2002-05-10 Greg Hudson <ghudson@mit.edu>
* camel-mh-store.c (get_inbox, get_folder_info, recursive_scan,
add_folder): Implement support for MH stores.
* camel-mh-summary.c (mh_summary_check, sort_uid_cmp): Sort MH
messages by message number (uid), like we sort maildir messages by
date.
* camel-local-provider.c (mh_provider): Turn on source and store
flags.
svn path=/trunk/; revision=17130
Diffstat (limited to 'camel/camel-object.c')
-rw-r--r-- | camel/camel-object.c | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/camel/camel-object.c b/camel/camel-object.c index eebcbf35d2..5e7eac7504 100644 --- a/camel/camel-object.c +++ b/camel/camel-object.c @@ -409,18 +409,27 @@ camel_object_new(CamelType type) } void -camel_object_ref(CamelObject *o) +camel_object_ref(void *vo) { + register CamelObject *o = vo; + + g_return_if_fail(CAMEL_IS_OBJECT(o)); + CLASS_LOCK(o->klass); o->ref_count++; CLASS_UNLOCK(o->klass); } void -camel_object_unref(CamelObject *o) +camel_object_unref(void *vo) { - register CamelObjectClass *klass = o->klass, *k; + register CamelObject *o = vo; + register CamelObjectClass *klass, *k; + + g_return_if_fail(CAMEL_IS_OBJECT(o)); + klass = o->klass; + CLASS_LOCK(klass); o->ref_count--; if (o->ref_count > 0 |