diff options
| author | dequis <dx@dxzone.com.ar> | 2015-12-08 19:31:05 -0300 | 
|---|---|---|
| committer | dequis <dx@dxzone.com.ar> | 2016-03-20 00:58:05 -0300 | 
| commit | a42fda42abad6af64ac9a905856ee9a3095954cd (patch) | |
| tree | 25ed1239ee6f58f39fa98d54ea02c1c1999bff92 /protocols | |
| parent | 14f912d4c1e818d39234c874036e4fe60227d1dc (diff) | |
Add imcb_buddy_nick_change(), like nick_hint but stronger
nick_hint only works when creating new users, it's a no-op after the
user is online. This new function takes care of nick changes after that.
It also helps clean up couple of hacks in irc_im.c \o/
Diffstat (limited to 'protocols')
| -rw-r--r-- | protocols/bee.h | 1 | ||||
| -rw-r--r-- | protocols/nogaim.c | 20 | ||||
| -rw-r--r-- | protocols/nogaim.h | 1 | 
3 files changed, 18 insertions, 4 deletions
| diff --git a/protocols/bee.h b/protocols/bee.h index 4a053845..d22e4d85 100644 --- a/protocols/bee.h +++ b/protocols/bee.h @@ -130,6 +130,7 @@ typedef struct bee_ui_funcs {  	void (*ft_finished)(struct im_connection *ic, struct file_transfer *ft);  	void (*log)(bee_t *bee, const char *tag, const char *msg); +	gboolean (*user_nick_change)(bee_t *bee, bee_user_t *bu, const char *hint);  } bee_ui_funcs_t; diff --git a/protocols/nogaim.c b/protocols/nogaim.c index a5eda2e0..a1aba51f 100644 --- a/protocols/nogaim.c +++ b/protocols/nogaim.c @@ -478,9 +478,8 @@ void imcb_remove_buddy(struct im_connection *ic, const char *handle, char *group  	bee_user_free(ic->bee, bee_user_by_handle(ic->bee, ic, handle));  } -/* Mainly meant for ICQ (and now also for Jabber conferences) to allow IM -   modules to suggest a nickname for a handle. */ -void imcb_buddy_nick_hint(struct im_connection *ic, const char *handle, const char *nick) +/* Implements either imcb_buddy_nick_hint() or imcb_buddy_nick_change() depending on the value of 'change' */ +static void buddy_nick_hint_or_change(struct im_connection *ic, const char *handle, const char *nick, gboolean change)  {  	bee_t *bee = ic->bee;  	bee_user_t *bu = bee_user_by_handle(bee, ic, handle); @@ -492,11 +491,24 @@ void imcb_buddy_nick_hint(struct im_connection *ic, const char *handle, const ch  	g_free(bu->nick);  	bu->nick = g_strdup(nick); -	if (bee->ui->user_nick_hint) { +	if (change && bee->ui->user_nick_change) { +		bee->ui->user_nick_change(bee, bu, nick); +	} else if (!change && bee->ui->user_nick_hint) {  		bee->ui->user_nick_hint(bee, bu, nick);  	}  } +/* Soft variant, for newly created users. Does nothing if it's already online */ +void imcb_buddy_nick_hint(struct im_connection *ic, const char *handle, const char *nick) +{ +	buddy_nick_hint_or_change(ic, handle, nick, FALSE); +} + +/* Hard variant, always changes the nick */ +void imcb_buddy_nick_change(struct im_connection *ic, const char *handle, const char *nick) +{ +	buddy_nick_hint_or_change(ic, handle, nick, TRUE); +}  struct imcb_ask_cb_data {  	struct im_connection *ic; diff --git a/protocols/nogaim.h b/protocols/nogaim.h index 3b271b45..40b1ed7b 100644 --- a/protocols/nogaim.h +++ b/protocols/nogaim.h @@ -323,6 +323,7 @@ G_MODULE_EXPORT void imcb_add_buddy(struct im_connection *ic, const char *handle  G_MODULE_EXPORT void imcb_remove_buddy(struct im_connection *ic, const char *handle, char *group);  G_MODULE_EXPORT void imcb_rename_buddy(struct im_connection *ic, const char *handle, const char *realname);  G_MODULE_EXPORT void imcb_buddy_nick_hint(struct im_connection *ic, const char *handle, const char *nick); +G_MODULE_EXPORT void imcb_buddy_nick_change(struct im_connection *ic, const char *handle, const char *nick);  G_MODULE_EXPORT void imcb_buddy_action_response(bee_user_t *bu, const char *action, char * const args[], void *data);  G_MODULE_EXPORT void imcb_buddy_typing(struct im_connection *ic, const char *handle, guint32 flags); | 
