# HG changeset patch # User Sadrul Habib Chowdhury # Date 1180761005 0 # Node ID 8ca45d6a1281894bf7e4cb820cbf53603a62562c # Parent 1bccb9641ef3e73c6f08aa2d99fd44e646eff443# Parent df911a06e09eca8acdaf074f7aab43c611b53995 merge of '3f054ce0972c8cbd8f8cfc16dfa6c8dcb81d3c0a' and '7523dcce0ac4ae98a74e3611efc953b8e0e20cde' diff -r 1bccb9641ef3 -r 8ca45d6a1281 libpurple/dbus-bindings.h --- a/libpurple/dbus-bindings.h Sat Jun 02 03:49:53 2007 +0000 +++ b/libpurple/dbus-bindings.h Sat Jun 02 05:10:05 2007 +0000 @@ -35,9 +35,9 @@ extern "C" { #endif -gint purple_dbus_pointer_to_id(gpointer node); +gint purple_dbus_pointer_to_id(gconstpointer node); gpointer purple_dbus_id_to_pointer(gint id, PurpleDBusType *type); -gint purple_dbus_pointer_to_id_error(gpointer ptr, DBusError *error); +gint purple_dbus_pointer_to_id_error(gconstpointer ptr, DBusError *error); gpointer purple_dbus_id_to_pointer_error(gint id, PurpleDBusType *type, const char *typename, DBusError *error); diff -r 1bccb9641ef3 -r 8ca45d6a1281 libpurple/dbus-server.c --- a/libpurple/dbus-server.c Sat Jun 02 03:49:53 2007 +0000 +++ b/libpurple/dbus-server.c Sat Jun 02 05:10:05 2007 +0000 @@ -108,7 +108,7 @@ } gint -purple_dbus_pointer_to_id(gpointer node) +purple_dbus_pointer_to_id(gconstpointer node) { gint id = GPOINTER_TO_INT(g_hash_table_lookup(map_node_id, node)); if ((id == 0) && (node != NULL)) @@ -138,7 +138,7 @@ } gint -purple_dbus_pointer_to_id_error(gpointer ptr, DBusError *error) +purple_dbus_pointer_to_id_error(gconstpointer ptr, DBusError *error) { gint id = purple_dbus_pointer_to_id(ptr); diff -r 1bccb9641ef3 -r 8ca45d6a1281 libpurple/status.c --- a/libpurple/status.c Sat Jun 02 03:49:53 2007 +0000 +++ b/libpurple/status.c Sat Jun 02 05:10:05 2007 +0000 @@ -1275,6 +1275,7 @@ purple_presence_set_idle(PurplePresence *presence, gboolean idle, time_t idle_time) { gboolean old_idle; + time_t current_time; g_return_if_fail(presence != NULL); @@ -1285,14 +1286,14 @@ presence->idle = idle; presence->idle_time = (idle ? idle_time : 0); + current_time = time(NULL); + if (purple_presence_get_context(presence) == PURPLE_PRESENCE_CONTEXT_BUDDY) { - time_t current_time = time(NULL); - update_buddy_idle(purple_presence_get_buddy(presence), presence, current_time, - old_idle, idle); + old_idle, idle); } - else if(purple_presence_get_context(presence) == PURPLE_PRESENCE_CONTEXT_ACCOUNT) + else if (purple_presence_get_context(presence) == PURPLE_PRESENCE_CONTEXT_ACCOUNT) { PurpleAccount *account; PurpleConnection *gc; @@ -1312,9 +1313,10 @@ msg = g_strdup_printf(_("+++ %s became idle"), purple_account_get_username(account)); else msg = g_strdup_printf(_("+++ %s became unidle"), purple_account_get_username(account)); + purple_log_write(log, PURPLE_MESSAGE_SYSTEM, - purple_account_get_username(account), - idle_time, msg); + purple_account_get_username(account), + (idle ? idle_time : current_time), msg); g_free(msg); } } @@ -1326,7 +1328,7 @@ prpl_info = PURPLE_PLUGIN_PROTOCOL_INFO(gc->prpl); if (prpl_info && prpl_info->set_idle) - prpl_info->set_idle(gc, (idle ? (time(NULL) - idle_time) : 0)); + prpl_info->set_idle(gc, (idle ? (current_time - idle_time) : 0)); } }