Mercurial > pidgin.yaz
view doc/account-signals.dox @ 12476:18b16e801e6f
[gaim-migrate @ 14787]
SF Patch #1379107 from evands
'Properly notify the UI when a buddy icon changes
gaim_buddy_set_icon() currently does nothing if the incoming
GaimBuddyIcon* is the same as buddy->icon.
This is wrong, however, because gaim_buddy_icon_new() will recycle an
existing GaimBuddyIcon* object for the buddy, replacing its data with the
new buddy icon data, if possible. The recycling means that just because
(icon == buddy->icon) we can't assume nothing has changed.
This patch makes the "buddy-icon-changed" signal be sent and the
gaim_blist_update_buddy_icon() function be called appropriately when the
buddy icon changes.
Call stack that gets us here from prpl code, for those keeping score at
home:
gaim_buddy_icons_set_for_user() -> gaim_buddy_icon_new() ->
gaim_buddy_icon_set_data() -> gaim_buddy_icon_update() ->
gaim_buddy_set_icon()'
committer: Tailor Script <tailor@pidgin.im>
author | Richard Laager <rlaager@wiktel.com> |
---|---|
date | Tue, 13 Dec 2005 08:10:28 +0000 |
parents | 944c97d11bb1 |
children | e629076386f1 |
line wrap: on
line source
/** @page account-signals Account Signals @signals @signal account-added @signal account-connecting @signal account-removed @signal account-disabled @signal account-enabled @signal account-setting-info @signal account-set-info @signal account-status-changed @endsignals <hr> @signaldef account-added @signalproto void (*account_added)(GaimAccount *account); @endsignalproto @signaldesc Emitted when an account is added. @param account The account that was added. @endsignaldef @signaldef account-connecting @signalproto void (*account_connecting)(GaimAccount *account); @endsignalproto @signaldesc This is called when an account is in the process of connecting. @param account The account in the process of connecting. @endsignaldef @signaldef account-removed @signalproto void (*account_removed)(GaimAccount *account); @endsignalproto @signaldesc Emitted when an account is removed. @param account The account that was removed. @endsignaldef @signaldef account-disabled @signalproto void (*account_disabled)(GaimAccount *account); @endsignalproto @signaldesc Emitted when an account is disabled. @param account The account that was disabled. @endsignaldef @signaldef account-enabled @signalproto void (*account_enabled)(GaimAccount *account); @endsignalproto @signaldesc Emitted when an account is enabled. @param account The account that was enabled. @endsignaldef @signaldef account-setting-info @signalproto void (*account_setting_info)(GaimAccount *account, const char *new_info); @endsignalproto @signaldesc Emitted when a user is about to send his new user info, or profile, to the server. @param account The account that the info will be set on. @param new_info The new information to set. @endsignaldef @signaldef account-set-info @signalproto void (*account_set_info)(GaimAccount *account, const char *new_info); @endsignalproto @signaldesc Emitted when a user sent his new user info, or profile, to the server. @param account The account that the info was set on. @param new_info The new information set. @endsignaldef @signaldef account-status-changed @signalproto void (*account_status_changed)(GaimAccount *account, GaimStatus *old, GaimStatus *new); @endsignalproto @signaldesc Emitted when the status of an account changes (after the change). @param account The account that changed status. @param old The status before change. @param new The status after change. @endsignaldef */ // vim: syntax=c tw=75 et