1 <?xml version='1.0' encoding="ISO-8859-1"?>
2 <!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
3 "http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd" [
5 <chapter id="chapter-signals-conversation">
6 <title>Conversation signals</title>
8 <refsect1 id="conversations.signals" role="signal_proto">
9 <title role="signal_proto.title">List of signals</title>
11 "<link linkend="conversations-writing-im-msg">writing-im-msg</link>"
12 "<link linkend="conversations-wrote-im-msg">wrote-im-msg</link>"
13 "<link linkend="conversations-sending-im-msg">sending-im-msg</link>"
14 "<link linkend="conversations-sent-im-msg">sent-im-msg</link>"
15 "<link linkend="conversations-receiving-im-msg">receiving-im-msg</link>"
16 "<link linkend="conversations-received-im-msg">received-im-msg</link>"
17 "<link linkend="conversations-blocked-im-msg">blocked-im-msg</link>"
18 "<link linkend="conversations-writing-chat-msg">writing-chat-msg</link>"
19 "<link linkend="conversations-wrote-chat-msg">wrote-chat-msg</link>"
20 "<link linkend="conversations-sending-chat-msg">sending-chat-msg</link>"
21 "<link linkend="conversations-sent-chat-msg">sent-chat-msg</link>"
22 "<link linkend="conversations-receiving-chat-msg">receiving-chat-msg</link>"
23 "<link linkend="conversations-received-chat-msg">received-chat-msg</link>"
24 "<link linkend="conversations-conversation-created">conversation-created</link>"
25 "<link linkend="conversations-conversation-updated">conversation-updated</link>"
26 "<link linkend="conversations-deleting-conversation">deleting-conversation</link>"
27 "<link linkend="conversations-buddy-typing">buddy-typing</link>"
28 "<link linkend="conversations-buddy-typing-stopped">buddy-typing-stopped</link>"
29 "<link linkend="conversations-chat-user-joining">chat-user-joining</link>"
30 "<link linkend="conversations-chat-user-joined">chat-user-joined</link>"
31 "<link linkend="conversations-chat-user-flags">chat-user-flags</link>"
32 "<link linkend="conversations-chat-user-leaving">chat-user-leaving</link>"
33 "<link linkend="conversations-chat-user-left">chat-user-left</link>"
34 "<link linkend="conversations-chat-inviting-user">chat-inviting-user</link>"
35 "<link linkend="conversations-chat-invited-user">chat-invited-user</link>"
36 "<link linkend="conversations-chat-invited">chat-invited</link>"
37 "<link linkend="conversations-chat-invite-blocked">chat-invite-blocked</link>"
38 "<link linkend="conversations-chat-joined">chat-joined</link>"
39 "<link linkend="conversations-chat-join-failed">chat-join-failed</link>"
40 "<link linkend="conversations-chat-left">chat-left</link>"
41 "<link linkend="conversations-chat-topic-changed">chat-topic-changed</link>"
42 "<link linkend="conversations-cleared-message-history">cleared-message-history</link>"
43 "<link linkend="conversations-conversation-extended-menu">conversation-extended-menu</link>"
44 "<link linkend="conversations-sent-attention">sent-attention</link>"
45 "<link linkend="conversations-got-attention">got-attention</link>"
49 <refsect1 id="conversations.signal-details" role="signals">
50 <title role="signals.title">Signal details</title>
52 <refsect2 id="conversations-writing-im-msg" role="signal">
53 <title>The <literal>"writing-im-msg"</literal> signal</title>
55 gboolean user_function (PurpleAccount *account,
58 PurpleIMConversation *im,
59 PurpleMessageFlags flags,
63 Emitted before a message is written in an IM conversation. If the message is changed, then the changed message is displayed and logged instead of the original message.
66 Make sure to free <literal>*message</literal> before you replace it!
68 <variablelist role="params">
70 <term><parameter>account</parameter> :</term>
71 <listitem><simpara>The account.</simpara></listitem>
74 <term><parameter>who</parameter> :</term>
75 <listitem><simpara>The name of the user.</simpara></listitem>
78 <term><parameter>message</parameter> :</term>
79 <listitem><simpara>A pointer to the message.</simpara></listitem>
82 <term><parameter>im</parameter> :</term>
83 <listitem><simpara>The IM conversation.</simpara></listitem>
86 <term><parameter>flags</parameter> :</term>
87 <listitem><simpara>Flags for this message.</simpara></listitem>
90 <term><parameter>user_data</parameter> :</term>
91 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
94 <term><emphasis>Returns</emphasis> :</term>
95 <listitem><simpara><literal>TRUE</literal> if the message should be canceled, or <literal>FALSE</literal> otherwise.</simpara></listitem>
100 <refsect2 id="conversations-wrote-im-msg" role="signal">
101 <title>The <literal>"wrote-im-msg"</literal> signal</title>
103 void user_function (PurpleAccount *account,
106 PurpleIMConversation *im,
107 PurpleMessageFlags flags,
111 Emitted after a message is written and possibly displayed in a conversation.
113 <variablelist role="params">
115 <term><parameter>account</parameter> :</term>
116 <listitem><simpara>The account.</simpara></listitem>
119 <term><parameter>who</parameter> :</term>
120 <listitem><simpara>The name of the user.</simpara></listitem>
123 <term><parameter>message</parameter> :</term>
124 <listitem><simpara>The message.</simpara></listitem>
127 <term><parameter>im</parameter> :</term>
128 <listitem><simpara>The IM conversation.</simpara></listitem>
131 <term><parameter>flags</parameter> :</term>
132 <listitem><simpara>Flags for this message.</simpara></listitem>
135 <term><parameter>user_data</parameter> :</term>
136 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
141 <refsect2 id="conversations-sending-im-msg" role="signal">
142 <title>The <literal>"sending-im-msg"</literal> signal</title>
144 void user_function (PurpleAccount *account,
145 const char *receiver,
150 Emitted before sending an IM to a user. <literal>message</literal> is a pointer to the message string, so the plugin can replace the message before being sent.
153 Make sure to free <literal>*message</literal> before you replace it!
155 <variablelist role="params">
157 <term><parameter>account</parameter> :</term>
158 <listitem><simpara>The account the message is being sent on.</simpara></listitem>
161 <term><parameter>receiver</parameter> :</term>
162 <listitem><simpara>The username of the receiver.</simpara></listitem>
165 <term><parameter>message</parameter> :</term>
166 <listitem><simpara>A pointer to the outgoing message. This can be modified.</simpara></listitem>
169 <term><parameter>user_data</parameter> :</term>
170 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
175 <refsect2 id="conversations-sent-im-msg" role="signal">
176 <title>The <literal>"sent-im-msg"</literal> signal</title>
178 void user_function (PurpleAccount *account,
179 const char *receiver,
184 Emitted after sending an IM to a user.
186 <variablelist role="params">
188 <term><parameter>account</parameter> :</term>
189 <listitem><simpara>The account the message was sent on.</simpara></listitem>
192 <term><parameter>receiver</parameter> :</term>
193 <listitem><simpara>The username of the receiver.</simpara></listitem>
196 <term><parameter>message</parameter> :</term>
197 <listitem><simpara>The message that was sent.</simpara></listitem>
200 <term><parameter>user_data</parameter> :</term>
201 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
206 <refsect2 id="conversations-receiving-im-msg" role="signal">
207 <title>The <literal>"receiving-im-msg"</literal> signal</title>
209 gboolean user_function (PurpleAccount *account,
212 PurpleIMConversation *im,
213 PurpleMessageFlags *flags,
217 Emitted when an IM is received. The callback can replace the name of the sender, the message, or the flags by modifying the pointer to the strings and integer. This can also be used to cancel a message by returning <literal>TRUE</literal>.
220 Make sure to free <literal>*sender</literal> and <literal>*message</literal> before you replace them!
222 <variablelist role="params">
224 <term><parameter>account</parameter> :</term>
225 <listitem><simpara>The account the message was received on.</simpara></listitem>
228 <term><parameter>sender</parameter> :</term>
229 <listitem><simpara>A pointer to the username of the sender.</simpara></listitem>
232 <term><parameter>message</parameter> :</term>
233 <listitem><simpara>A pointer to the message that was sent.</simpara></listitem>
236 <term><parameter>im</parameter> :</term>
237 <listitem><simpara>The IM conversation.</simpara></listitem>
240 <term><parameter>flags</parameter> :</term>
241 <listitem><simpara>A pointer to the IM message flags.</simpara></listitem>
244 <term><parameter>user_data</parameter> :</term>
245 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
248 <term><emphasis>Returns</emphasis> :</term>
249 <listitem><simpara><literal>TRUE</literal> if the message should be canceled, or <literal>FALSE</literal> otherwise.</simpara></listitem>
254 <refsect2 id="conversations-received-im-msg" role="signal">
255 <title>The <literal>"received-im-msg"</literal> signal</title>
257 void user_function (PurpleAccount *account,
260 PurpleIMConversation *im,
261 PurpleMessageFlags flags,
265 Emitted after an IM is received.
267 <variablelist role="params">
269 <term><parameter>account</parameter> :</term>
270 <listitem><simpara>The account the message was received on.</simpara></listitem>
273 <term><parameter>sender</parameter> :</term>
274 <listitem><simpara>The username of the sender.</simpara></listitem>
277 <term><parameter>message</parameter> :</term>
278 <listitem><simpara>The message that was sent.</simpara></listitem>
281 <term><parameter>im</parameter> :</term>
282 <listitem><simpara>The IM conversation.</simpara></listitem>
285 <term><parameter>flags</parameter> :</term>
286 <listitem><simpara>The IM message flags.</simpara></listitem>
289 <term><parameter>user_data</parameter> :</term>
290 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
295 <refsect2 id="conversations-blocked-im-msg" role="signal">
296 <title>The <literal>"blocked-im-msg"</literal> signal</title>
298 void user_function (PurpleAccount *account,
301 PurpleMessageFlags flags,
306 Emitted after an IM is blocked due to privacy settings.
308 <variablelist role="params">
310 <term><parameter>account</parameter> :</term>
311 <listitem><simpara>The account the message was received on.</simpara></listitem>
314 <term><parameter>sender</parameter> :</term>
315 <listitem><simpara>The username of the sender.</simpara></listitem>
318 <term><parameter>message</parameter> :</term>
319 <listitem><simpara>The message that was blocked.</simpara></listitem>
322 <term><parameter>flags</parameter> :</term>
323 <listitem><simpara>The IM message flags.</simpara></listitem>
326 <term><parameter>when</parameter> :</term>
327 <listitem><simpara>The time the message was sent.</simpara></listitem>
330 <term><parameter>user_data</parameter> :</term>
331 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
336 <refsect2 id="conversations-writing-chat-msg" role="signal">
337 <title>The <literal>"writing-chat-msg"</literal> signal</title>
339 gboolean user_function (PurpleAccount *account,
342 PurpleChatConversation *chat,
343 PurpleMessageFlags flags,
347 Emitted before a message is written in a chat conversation. If the message is changed, then the changed message is displayed and logged instead of the original message.
350 Make sure to free <literal>*message</literal> before you replace it!
352 <variablelist role="params">
354 <term><parameter>account</parameter> :</term>
355 <listitem><simpara>The account.</simpara></listitem>
358 <term><parameter>who</parameter> :</term>
359 <listitem><simpara>The name of the user.</simpara></listitem>
362 <term><parameter>message</parameter> :</term>
363 <listitem><simpara>A pointer to the message.</simpara></listitem>
366 <term><parameter>chat</parameter> :</term>
367 <listitem><simpara>The chat conversation.</simpara></listitem>
370 <term><parameter>flags</parameter> :</term>
371 <listitem><simpara>Flags for this message.</simpara></listitem>
374 <term><parameter>user_data</parameter> :</term>
375 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
378 <term><emphasis>Returns</emphasis> :</term>
379 <listitem><simpara><literal>TRUE</literal> if the message should be canceled, or <literal>FALSE</literal> otherwise.</simpara></listitem>
384 <refsect2 id="conversations-wrote-chat-msg" role="signal">
385 <title>The <literal>"wrote-chat-msg"</literal> signal</title>
387 void user_function (PurpleAccount *account,
390 PurpleChatConversation *chat,
391 PurpleMessageFlags flags,
395 Emitted after a message is written and possibly displayed in a chat.
397 <variablelist role="params">
399 <term><parameter>account</parameter> :</term>
400 <listitem><simpara>The account.</simpara></listitem>
403 <term><parameter>who</parameter> :</term>
404 <listitem><simpara>The name of the user.</simpara></listitem>
407 <term><parameter>message</parameter> :</term>
408 <listitem><simpara>The message.</simpara></listitem>
411 <term><parameter>chat</parameter> :</term>
412 <listitem><simpara>The chat conversation.</simpara></listitem>
415 <term><parameter>flags</parameter> :</term>
416 <listitem><simpara>Flags for this message.</simpara></listitem>
419 <term><parameter>user_data</parameter> :</term>
420 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
425 <refsect2 id="conversations-sending-chat-msg" role="signal">
426 <title>The <literal>"sending-chat-msg"</literal> signal</title>
428 void user_function (PurpleAccount *account,
434 Emitted before sending a message to a chat. <literal>message</literal> is a pointer to the message string, so the plugin can replace the message before being sent.
437 Make sure to free <literal>*message</literal> before you replace it!
439 <variablelist role="params">
441 <term><parameter>account</parameter> :</term>
442 <listitem><simpara>The account the message is being sent on.</simpara></listitem>
445 <term><parameter>message</parameter> :</term>
446 <listitem><simpara>A pointer to the message that will be sent.</simpara></listitem>
449 <term><parameter>id</parameter> :</term>
450 <listitem><simpara>The ID of the chat.</simpara></listitem>
453 <term><parameter>user_data</parameter> :</term>
454 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
459 <refsect2 id="conversations-sent-chat-msg" role="signal">
460 <title>The <literal>"sent-chat-msg"</literal> signal</title>
462 void user_function (PurpleAccount *account,
468 Emitted after sending a message to a chat.
470 <variablelist role="params">
472 <term><parameter>account</parameter> :</term>
473 <listitem><simpara>The account the message was sent on.</simpara></listitem>
476 <term><parameter>message</parameter> :</term>
477 <listitem><simpara>The message that was sent.</simpara></listitem>
480 <term><parameter>id</parameter> :</term>
481 <listitem><simpara>The ID of the chat.</simpara></listitem>
484 <term><parameter>user_data</parameter> :</term>
485 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
490 <refsect2 id="conversations-receiving-chat-msg" role="signal">
491 <title>The <literal>"receiving-chat-msg"</literal> signal</title>
493 gboolean user_function (PurpleAccount *account,
496 PurpleChatConversation *chat,
501 Emitted when a chat message is received. The callback can replace the name of the sender, the message, or the flags by modifying the pointer to the strings. This can also be used to cancel displaying a message by returning <literal>TRUE</literal>.
504 Make sure to free <literal>*sender</literal> and <literal>*message</literal> before you replace them!
506 <variablelist role="params">
508 <term><parameter>account</parameter> :</term>
509 <listitem><simpara>The account the message was received on.</simpara></listitem>
512 <term><parameter>sender</parameter> :</term>
513 <listitem><simpara>A pointer to the username of the sender.</simpara></listitem>
516 <term><parameter>message</parameter> :</term>
517 <listitem><simpara>A pointer to the message that was sent.</simpara></listitem>
520 <term><parameter>chat</parameter> :</term>
521 <listitem><simpara>The chat conversation.</simpara></listitem>
524 <term><parameter>flags</parameter> :</term>
525 <listitem><simpara>A pointer to the chat message flags.</simpara></listitem>
528 <term><parameter>user_data</parameter> :</term>
529 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
532 <term><emphasis>Returns</emphasis> :</term>
533 <listitem><simpara><literal>TRUE</literal> if the message should be canceled, or <literal>FALSE</literal> otherwise.</simpara></listitem>
538 <refsect2 id="conversations-received-chat-msg" role="signal">
539 <title>The <literal>"received-chat-msg"</literal> signal</title>
541 void user_function (PurpleAccount *account,
544 PurpleChatConversation *chat,
545 PurpleMessageFlags flags,
549 Emitted after a chat message is received.
551 <variablelist role="params">
553 <term><parameter>account</parameter> :</term>
554 <listitem><simpara>The account the message was received on.</simpara></listitem>
557 <term><parameter>sender</parameter> :</term>
558 <listitem><simpara>The username of the sender.</simpara></listitem>
561 <term><parameter>message</parameter> :</term>
562 <listitem><simpara>The message that was sent.</simpara></listitem>
565 <term><parameter>chat</parameter> :</term>
566 <listitem><simpara>The chat conversation.</simpara></listitem>
569 <term><parameter>flags</parameter> :</term>
570 <listitem><simpara>The chat message flags.</simpara></listitem>
573 <term><parameter>user_data</parameter> :</term>
574 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
579 <refsect2 id="conversations-conversation-created" role="signal">
580 <title>The <literal>"conversation-created"</literal> signal</title>
582 void user_function (PurpleConversation *conv,
586 Emitted when a new conversation is created.
588 <variablelist role="params">
590 <term><parameter>conv</parameter> :</term>
591 <listitem><simpara>The new conversation.</simpara></listitem>
594 <term><parameter>user_data</parameter> :</term>
595 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
600 <refsect2 id="conversations-conversation-updated" role="signal">
601 <title>The <literal>"conversation-updated"</literal> signal</title>
603 void user_function (PurpleConversation *conv,
604 PurpleConvUpdateType type,
608 Emitted when a conversation is updated.
610 <variablelist role="params">
612 <term><parameter>conv</parameter> :</term>
613 <listitem><simpara>The conversation that was updated.</simpara></listitem>
616 <term><parameter>type</parameter> :</term>
617 <listitem><simpara>The type of update that was made.</simpara></listitem>
620 <term><parameter>user_data</parameter> :</term>
621 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
626 <refsect2 id="conversations-deleting-conversation" role="signal">
627 <title>The <literal>"deleting-conversation"</literal> signal</title>
629 void user_function (PurpleConversation *conv,
633 Emitted just before a conversation is to be destroyed.
635 <variablelist role="params">
637 <term><parameter>conv</parameter> :</term>
638 <listitem><simpara>The conversation that's about to be destroyed.</simpara></listitem>
641 <term><parameter>user_data</parameter> :</term>
642 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
647 <refsect2 id="conversations-buddy-typing" role="signal">
648 <title>The <literal>"buddy-typing"</literal> signal</title>
650 void user_function (PurpleAccount *account,
655 Emitted when a buddy starts typing in a conversation window.
657 <variablelist role="params">
659 <term><parameter>account</parameter> :</term>
660 <listitem><simpara>The account of the user which is typing.</simpara></listitem>
663 <term><parameter>name</parameter> :</term>
664 <listitem><simpara>The name of the user which is typing.</simpara></listitem>
667 <term><parameter>user_data</parameter> :</term>
668 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
673 <refsect2 id="conversations-buddy-typing-stopped" role="signal">
674 <title>The <literal>"buddy-typing-stopped"</literal> signal</title>
676 void user_function (PurpleAccount *account,
681 Emitted when a buddy stops typing in a conversation window.
683 <variablelist role="params">
685 <term><parameter>account</parameter> :</term>
686 <listitem><simpara>The account of the user which stopped typing.</simpara></listitem>
689 <term><parameter>name</parameter> :</term>
690 <listitem><simpara>The name of the user which stopped typing.</simpara></listitem>
693 <term><parameter>user_data</parameter> :</term>
694 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
699 <refsect2 id="conversations-chat-user-joining" role="signal">
700 <title>The <literal>"chat-user-joining"</literal> signal</title>
702 gboolean user_function (PurpleChatConversation *chat,
704 PurpleChatUserFlags flags,
708 Emitted when a buddy is joining a chat, before the list of users in the chat updates to include the new user.
710 <variablelist role="params">
712 <term><parameter>chat</parameter> :</term>
713 <listitem><simpara>The chat conversation.</simpara></listitem>
716 <term><parameter>name</parameter> :</term>
717 <listitem><simpara>The name of the user that is joining the conversation.</simpara></listitem>
720 <term><parameter>flags</parameter> :</term>
721 <listitem><simpara>The flags of the user that is joining the conversation.</simpara></listitem>
724 <term><parameter>user_data</parameter> :</term>
725 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
728 <term><emphasis>Returns</emphasis> :</term>
729 <listitem><simpara><literal>TRUE</literal> if the join should be hidden, or <literal>FALSE</literal> otherwise.</simpara></listitem>
734 <refsect2 id="conversations-chat-user-joined" role="signal">
735 <title>The <literal>"chat-user-joined"</literal> signal</title>
737 void user_function (PurpleChatConversation *chat,
739 PurpleChatUserFlags flags,
740 gboolean new_arrival,
744 Emitted when a buddy joined a chat, after the users list is updated.
746 <variablelist role="params">
748 <term><parameter>chat</parameter> :</term>
749 <listitem><simpara>The chat conversation.</simpara></listitem>
752 <term><parameter>name</parameter> :</term>
753 <listitem><simpara>The name of the user that has joined the conversation.</simpara></listitem>
756 <term><parameter>flags</parameter> :</term>
757 <listitem><simpara>The flags of the user that has joined the conversation.</simpara></listitem>
760 <term><parameter>new_arrival</parameter> :</term>
761 <listitem><simpara>If the buddy is a new arrival.</simpara></listitem>
764 <term><parameter>user_data</parameter> :</term>
765 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
770 <refsect2 id="conversations-chat-join-failed" role="signal">
771 <title>The <literal>"chat-join-failed"</literal> signal</title>
773 void user_function (PurpleConnection *gc,
774 GHashTable *components,
778 Emitted when an account fails to join a chat room.
780 <variablelist role="params">
782 <term><parameter>gc</parameter> :</term>
783 <listitem><simpara>The PurpleConnection of the account which failed to join the chat.</simpara></listitem>
786 <term><parameter>data</parameter> :</term>
787 <listitem><simpara>The components passed to purple_serv_join_chat() originally. The hash function should be g_str_hash() and the equal function should be g_str_equal().</simpara></listitem>
790 <term><parameter>user_data</parameter> :</term>
791 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
796 <refsect2 id="conversations-chat-user-flags" role="signal">
797 <title>The <literal>"chat-user-flags"</literal> signal</title>
799 void user_function (PurpleChatUser *chatuser,
800 PurpleChatUserFlags oldflags,
801 PurpleChatUserFlags newflags,
805 Emitted when a user in a chat changes flags.
807 <variablelist role="params">
809 <term><parameter>chatuser</parameter> :</term>
810 <listitem><simpara>The chat user whose flags changed.</simpara></listitem>
813 <term><parameter>oldflags</parameter> :</term>
814 <listitem><simpara>The old flags.</simpara></listitem>
817 <term><parameter>newflags</parameter> :</term>
818 <listitem><simpara>The new flags.</simpara></listitem>
821 <term><parameter>user_data</parameter> :</term>
822 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
827 <refsect2 id="conversations-chat-user-leaving" role="signal">
828 <title>The <literal>"chat-user-leaving"</literal> signal</title>
830 gboolean user_function (PurpleChatConversation *chat,
836 Emitted when a user is leaving a chat, before the user list is updated. This may include an optional reason why the user is leaving.
838 <variablelist role="params">
840 <term><parameter>chat</parameter> :</term>
841 <listitem><simpara>The chat conversation.</simpara></listitem>
844 <term><parameter>name</parameter> :</term>
845 <listitem><simpara>The name of the user that is leaving the chat.</simpara></listitem>
848 <term><parameter>reason</parameter> :</term>
849 <listitem><simpara>The optional reason why the user is leaving.</simpara></listitem>
852 <term><parameter>user_data</parameter> :</term>
853 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
856 <term><emphasis>Returns</emphasis> :</term>
857 <listitem><simpara><literal>TRUE</literal> if the leave should be hidden, or <literal>FALSE</literal> otherwise.</simpara></listitem>
862 <refsect2 id="conversations-chat-user-left" role="signal">
863 <title>The <literal>"chat-user-left"</literal> signal</title>
865 void user_function (PurpleChatConversation *chat,
871 Emitted when a user leaves a chat, after the user list is updated. This may include an optional reason why the user is leaving.
873 <variablelist role="params">
875 <term><parameter>chat</parameter> :</term>
876 <listitem><simpara>The chat conversation.</simpara></listitem>
879 <term><parameter>name</parameter> :</term>
880 <listitem><simpara>The name of the user that left the chat.</simpara></listitem>
883 <term><parameter>reason</parameter> :</term>
884 <listitem><simpara>The optional reason why the user left the chat.</simpara></listitem>
887 <term><parameter>user_data</parameter> :</term>
888 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
893 <refsect2 id="conversations-chat-inviting-user" role="signal">
894 <title>The <literal>"chat-inviting-user"</literal> signal</title>
896 void user_function (PurpleChatConversation *chat,
898 char **invite_message,
902 Emitted when a user is being invited to the chat. The callback can replace the invite message to the invitee by modifying the pointer to the invite message.
905 Make sure to free <literal>*invite_message</literal> before you replace it!
907 <variablelist role="params">
909 <term><parameter>chat</parameter> :</term>
910 <listitem><simpara>The chat conversation.</simpara></listitem>
913 <term><parameter>name</parameter> :</term>
914 <listitem><simpara>The name of the user being invited.</simpara></listitem>
917 <term><parameter>invite_message</parameter> :</term>
918 <listitem><simpara>A pointer to the reason why a user is being invited.</simpara></listitem>
921 <term><parameter>user_data</parameter> :</term>
922 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
927 <refsect2 id="conversations-chat-invited-user" role="signal">
928 <title>The <literal>"chat-invited-user"</literal> signal</title>
930 void user_function (PurpleChatConversation *conv,
932 const char *invite_message,
936 Emitted when a user invited another user to a chat.
938 <variablelist role="params">
940 <term><parameter>chat</parameter> :</term>
941 <listitem><simpara>The chat conversation.</simpara></listitem>
944 <term><parameter>name</parameter> :</term>
945 <listitem><simpara>The name of the user that was invited.</simpara></listitem>
948 <term><parameter>invite_message</parameter> :</term>
949 <listitem><simpara>The message to be sent to the user when invited.</simpara></listitem>
952 <term><parameter>user_data</parameter> :</term>
953 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
958 <refsect2 id="conversations-chat-invited" role="signal">
959 <title>The <literal>"chat-invited"</literal> signal</title>
961 gint user_function (PurpleAccount *account,
964 const char *invite_messageconst GHashTable *components,
968 Emitted when an account was invited to a chat.
970 <variablelist role="params">
972 <term><parameter>account</parameter> :</term>
973 <listitem><simpara>The account being invited.</simpara></listitem>
976 <term><parameter>inviter</parameter> :</term>
977 <listitem><simpara>The username of the person inviting the account.</simpara></listitem>
980 <term><parameter>chat</parameter> :</term>
981 <listitem><simpara>The name of the chat you're being invited to.</simpara></listitem>
984 <term><parameter>invite_message</parameter> :</term>
985 <listitem><simpara>The optional invite message.</simpara></listitem>
988 <term><parameter>components</parameter> :</term>
989 <listitem><simpara>The components necessary if you want to call purple_serv_join_chat().</simpara></listitem>
992 <term><parameter>user_data</parameter> :</term>
993 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
996 <term><emphasis>Returns</emphasis> :</term>
997 <listitem><simpara>Less than zero if the invitation should be rejected, greater than zero if the invitation should be accepted. If zero is returned, the default behavior will be maintained: the user will be prompted.</simpara></listitem>
1002 <refsect2 id="conversations-chat-invite-blocked" role="signal">
1003 <title>The <literal>"chat-invite-blocked"</literal> signal</title>
1005 void user_function (PurpleAccount *account,
1006 const char *inviter,
1008 const char *message,
1012 Emitted when an invitation to join a chat is blocked.
1014 <variablelist role="params">
1016 <term><parameter>account</parameter> :</term>
1017 <listitem><simpara>The account the invitation was sent to.</simpara></listitem>
1020 <term><parameter>inviter</parameter> :</term>
1021 <listitem><simpara>The name of the person sending the invitation.</simpara></listitem>
1024 <term><parameter>name</parameter> :</term>
1025 <listitem><simpara>The name of the chat invited to.</simpara></listitem>
1028 <term><parameter>message</parameter> :</term>
1029 <listitem><simpara>The invitation message sent.</simpara></listitem>
1032 <term><parameter>data</parameter> :</term>
1033 <listitem><simpara>Hashtable containing data about the invited chat.</simpara></listitem>
1038 <refsect2 id="conversations-chat-joined" role="signal">
1039 <title>The <literal>"chat-joined"</literal> signal</title>
1041 void user_function (PurpleChatConversation *chat,
1045 Emitted when an account joins a chat room.
1047 <variablelist role="params">
1049 <term><parameter>chat</parameter> :</term>
1050 <listitem><simpara>The conversation that joined the chat room.</simpara></listitem>
1053 <term><parameter>user_data</parameter> :</term>
1054 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
1059 <refsect2 id="conversations-chat-left" role="signal">
1060 <title>The <literal>"chat-left"</literal> signal</title>
1062 void user_function (PurpleChatConversation *chat,
1066 Emitted when an account leaves a chat room.
1068 <variablelist role="params">
1070 <term><parameter>chat</parameter> :</term>
1071 <listitem><simpara>The conversation that left the chat room.</simpara></listitem>
1074 <term><parameter>user_data</parameter> :</term>
1075 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
1080 <refsect2 id="conversations-chat-topic-changed" role="signal">
1081 <title>The <literal>"chat-topic-changed"</literal> signal</title>
1083 void user_function (PurpleChatConversation *chat,
1089 Emitted when the topic is changed in a chat.
1091 <variablelist role="params">
1093 <term><parameter>chat</parameter> :</term>
1094 <listitem><simpara>The chat conversation whose topic changed.</simpara></listitem>
1097 <term><parameter>who</parameter> :</term>
1098 <listitem><simpara>The name of the person that changed the topic.</simpara></listitem>
1101 <term><parameter>topic</parameter> :</term>
1102 <listitem><simpara>The new topic.</simpara></listitem>
1105 <term><parameter>user_data</parameter> :</term>
1106 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
1111 <refsect2 id="conversations-conversation-extended-menu" role="signal">
1112 <title>The <literal>"conversation-extended-menu"</literal> signal</title>
1114 void user_function (PurpleConversation *conv,
1119 Emitted when the UI requests a list of plugin actions for a conversation.
1121 <variablelist role="params">
1123 <term><parameter>conv</parameter> :</term>
1124 <listitem><simpara>The conversation.</simpara></listitem>
1127 <term><parameter>list</parameter> :</term>
1128 <listitem><simpara>A pointer to the list of actions.</simpara></listitem>
1131 <term><parameter>user_data</parameter> :</term>
1132 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
1137 <refsect2 id="conversations-cleared-message-history" role="signal">
1138 <title>The <literal>"cleared-message-history"</literal> signal</title>
1140 void user_function (PurpleConversation *conv,
1144 Emitted when the conversation history is cleared.
1146 <variablelist role="params">
1148 <term><parameter>conv</parameter> :</term>
1149 <listitem><simpara>The conversation.</simpara></listitem>
1152 <term><parameter>user_data</parameter> :</term>
1153 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
1158 <refsect2 id="conversations-sent-attention" role="signal">
1159 <title>The <literal>"sent-attention"</literal> signal</title>
1161 void user_function (PurpleAccount *account,
1163 PurpleConversation *conv,
1168 Emitted when receiving an attention message (buzz, nudge, etc.).
1170 <variablelist role="params">
1172 <term><parameter>account</parameter> :</term>
1173 <listitem><simpara>The account.</simpara></listitem>
1176 <term><parameter>who</parameter> :</term>
1177 <listitem><simpara>The name of the person receiving the attention.</simpara></listitem>
1180 <term><parameter>conv</parameter> :</term>
1181 <listitem><simpara>The conversation.</simpara></listitem>
1184 <term><parameter>type</parameter> :</term>
1185 <listitem><simpara>The attention type (an index starting at 0).</simpara></listitem>
1188 <term><parameter>user_data</parameter> :</term>
1189 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>
1194 <refsect2 id="conversations-got-attention" role="signal">
1195 <title>The <literal>"got-attention"</literal> signal</title>
1197 void user_function (PurpleAccount *account,
1199 PurpleConversation *conv,
1204 Emitted when receiving an attention message (buzz, nudge, etc.).
1206 <variablelist role="params">
1208 <term><parameter>account</parameter> :</term>
1209 <listitem><simpara>The account.</simpara></listitem>
1212 <term><parameter>who</parameter> :</term>
1213 <listitem><simpara>The name of the person sending the attention.</simpara></listitem>
1216 <term><parameter>conv</parameter> :</term>
1217 <listitem><simpara>The conversation.</simpara></listitem>
1220 <term><parameter>type</parameter> :</term>
1221 <listitem><simpara>The attention type (an index starting at 0).</simpara></listitem>
1224 <term><parameter>user_data</parameter> :</term>
1225 <listitem><simpara>user data set when the signal handler was connected.</simpara></listitem>