Mercurial > pidgin.yaz
view doc/conversation-signals.dox @ 12689:e893563d965d
[gaim-migrate @ 15032]
Fix another crash because a callback was happening after the account was disconnected. I wonder whether the sip->listenfd should be also closed.
committer: Tailor Script <tailor@pidgin.im>
author | Daniel Atallah <daniel.atallah@gmail.com> |
---|---|
date | Tue, 03 Jan 2006 04:44:08 +0000 |
parents | 366326fa9cb4 |
children | 49b2347863b2 |
line wrap: on
line source
/** @page conversation-signals Conversation Signals @signals @signal writing-im-msg @signal wrote-im-msg @signal sending-im-msg @signal sent-im-msg @signal receiving-im-msg @signal received-im-msg @signal writing-chat-msg @signal wrote-chat-msg @signal sending-chat-msg @signal sent-chat-msg @signal receiving-chat-msg @signal received-chat-msg @signal conversation-created @signal conversation-updated @signal deleting-conversation @signal buddy-typing @signal buddy-typing-stopped @signal chat-buddy-joining @signal chat-buddy-joined @signal chat-buddy-flags @signal chat-buddy-leaving @signal chat-buddy-left @signal chat-inviting-user @signal chat-invited-user @signal chat-invited @signal chat-joined @signal chat-left @signal chat-topic-changed @endsignals @signaldef writing-im-msg @signalproto gboolean (*writing_im_msg)(GaimAccount *account, GaimConversation *conv, char **message); @endsignalproto @signaldesc Emitted before a message is displayed in an IM conversation or sent to a remote user. @a message is a pointer to a string, so the plugin can replace the message that will be displayed along with the message that will be sent. This can also be used to cancel an outgoing message by returning @c TRUE. @note Make sure to free @a *message before you replace it! @param account The account the message is being displayed and sent on. @param conv The conversation the message is being displayed and sent on. @param message A pointer to the message that will be displayed and sent. @return @c TRUE if the message should be canceled, or @c FALSE otherwise. @endsignaldef @signaldef wrote-im-msg @signalproto void (*wrote_im_msg)(GaimAccount *account, GaimConversation *conv, const char *message); @endsignalproto @signaldesc Emitted after a message is entered by the user, but before it is sent and displyed. When sending an IM, the order that the im-msg callbacks will be called is: writing-im-msg, wrote-im-msg, sending-im-msg, and finally sent-im-msg. @param account The account the message was displayed on. @param conv The conversation the message was displayed on. @param message The message that was displayed. @endsignaldef @signaldef sending-im-msg @signalproto void (*sending_im_msg)(GaimAccount *account, const char *receiver, char **message); @endsignalproto @signaldesc Emitted before sending an IM to a user. @a message is a pointer to the message string, so the plugin can replace the message before being sent. @note Make sure to free @a *message before you replace it! @param account The account the message is being sent on. @param receiver The username of the receiver. @param message A pointer to the outgoing message. This can be modified. @endsignaldef @signaldef sent-im-msg @signalproto void (*sent_im_msg)(GaimAccount *account, const char *receiver, const char *message); @endsignalproto @signaldesc Emitted after sending an IM to a user. @param account The account the message was sent on. @param receiver The username of the receiver. @param message The message that was sent. @endsignaldef @signaldef receiving-im-msg @signalproto gboolean (*receiving_im_msg)(GaimAccount *account, char **sender, char **message, GaimConversation *conv, int *flags); @endsignalproto @signaldesc 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 @c TRUE. @note Make sure to free @a *sender and @a *message before you replace them! @return @c TRUE if the message should be canceled, or @c FALSE otherwise. @param account The account the message was received on. @param sender A pointer to the username of the sender. @param message A pointer to the message that was sent. @param conv The IM conversation. @param flags A pointer to the IM message flags. @endsignaldef @signaldef received-im-msg @signalproto void (*received_im_msg)(GaimAccount *account, char *sender, char *message, GaimConversation *conv, int flags); @endsignalproto @signaldesc Emitted after an IM is received. @param account The account the message was received on. @param sender The username of the sender. @param message The message that was sent. @param conv The IM conversation. @param flags The IM message flags. @endsignaldef @signaldef writing-chat-msg @signalproto gboolean (*writing_chat_msg)(GaimAccount *account, GaimConversation *conv, char **message); @endsignalproto @signaldesc Emitted before a message is displayed in a chat conversation or sent to a remote chat. @a message is a pointer to a string, so the plugin can replace the message that will be displayed along with the message that will be sent. This can also be used to cancel an outgoing message by returning @c TRUE. @note Make sure to free @a *message before you replace it! @param account The account the message is being displayed and sent on. @param conv The conversation the message is being displayed and sent on. @param message A pointer to the message that will be displayed and sent. @return @c TRUE if the message should be canceled, or @c FALSE otherwise. @endsignaldef @signaldef wrote-chat-msg @signalproto void (*wrote_chat_msg)(GaimAccount *account, GaimConversation *conv, const char *message); @endsignalproto @signaldesc Emitted after a message is entered by the user, but before it is sent and displyed. When sending an IM, the order that the im-msg callbacks will be called is: writing-chat-msg, wrote-chat-msg, sending-chat-msg, and finally sent-chat-msg. @param account The account the message was displayed on. @param conv The conversation the message was displayed on. @param message The message that was displayed. @endsignaldef @signaldef sending-chat-msg @signalproto void (*sending_chat_msg)(GaimAccount *account, char **message, int id); @endsignalproto @signaldesc Emitted before sending a message to a chat. @a message is a pointer to the message string, so the plugin can replace the message before being sent. @note Make sure to free @a *message before you replace it! @param account The account the message is being sent on. @param message A pointer to the message that will be sent. @param id The ID of the chat. @endsignaldef @signaldef sent-chat-msg @signalproto void (*sent_chat_msg)(GaimAccount *account, const char *message, int id); @endsignalproto @signaldesc Emitted after sending a message to a chat. @param account The account the message was sent on. @param message The message that was sent. @param id The ID of the chat. @endsignaldef @signaldef receiving-chat-msg @signalproto gboolean (*receiving_chat_msg)(GaimAccount *account, char **sender, char **message, GaimConversation *conv, int *flags); @endsignalproto @signaldesc 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 @c TRUE. @note Make sure to free @a *sender and @a *message before you replace them! @return @c TRUE if the message should be canceled, or @c FALSE otherwise. @param account The account the message was received on. @param sender A pointer to the username of the sender. @param message A pointer to the message that was sent. @param conv The chat conversation. @param flags A pointer to the chat message flags @endsignaldef @signaldef received-chat-msg @signalproto void (*received_chat_msg)(GaimAccount *account, char *sender, char *message, GaimConversation *conv, int flags); @endsignalproto @signaldesc Emitted after a chat message is received. @param account The account the message was received on. @param sender The username of the sender. @param message The message that was sent. @param conv The chat conversation. @param flags The chat message flags. @endsignaldef @signaldef conversation-created @signalproto void (*conversation_created)(GaimConversation *conv); @endsignalproto @signaldesc Emitted when a new conversation is created. @param conv The new conversation. @endsignaldef @signaldef conversation-updated @signalproto void (*conversation_updated)(GaimConversation *conv, GaimConvUpdateType type); @endsignalproto @signaldesc Emitted when a conversation is updated. @param conv The conversation that was updated. @param type The type of update that was made. @endsignaldef @signaldef deleting-conversation @signalproto void (*deleting_conversation)(GaimConversation *conv); @endsignalproto @signaldesc Emitted just before a conversation is to be destroyed. @param conv The conversation that's about to be destroyed. @endsignaldef @signaldef buddy-typing @signalproto void (*buddy_typing)(GaimAccount *account, const char *name); @endsignalproto @signaldesc Emitted when a buddy starts typing in a conversation window. @param account The account of the user which is typing. @param name The name of the user which is typing. @endsignaldef @signaldef buddy-typing-stopped @signalproto void (*buddy_typing_stopped)(GaimAccount *account, const char *name); @endsignalproto @signaldesc Emitted when a buddy stops typing in a conversation window. @param account The account of the user which stopped typing. @param name The name of the user which stopped typing. @endsignaldef @signaldef chat-buddy-joining @signalproto gboolean (*chat_buddy_joining)(GaimConversation *conv, const char *name, GaimConvChatBuddyFlags flags); @endsignalproto @signaldesc Emitted when a buddy is joining a chat, before the list of users in the chat updates to include the new user. @return @c TRUE if the join should be hidden, or @c FALSE otherwise. @param conv The chat conversation. @param name The name of the user that is joining the conversation. @param flags The flags of the user that is joining the conversation. @endsignaldef @signaldef chat-buddy-joined @signalproto void (*chat_buddy_joined)(GaimConversation *conv, const char *name, GaimConvChatBuddyFlags flags); @endsignalproto @signaldesc Emitted when a buddy joined a chat, after the users list is updated. @param conv The chat conversation. @param name The name of the user that has joined the conversation. @param flags The flags of the user that has joined the conversation. @endsignaldef @signaldef chat-buddy-flags @signalproto void (*chat_buddy_flags)(GaimConversation *conv, const char *name, GaimConvChatBuddyFlags oldflags, GaimConvChatBuddyFlags newflags); @endsignalproto @signaldesc Emitted when a user in a chat changes flags. @param conv The chat conversation. @param name The name of the user. @param oldflags The old flags. @param newflags The new flags. @endsignaldef @signaldef chat-buddy-leaving @signalproto gboolean (*chat_buddy_leaving)(GaimConversation *conv, const char *name, const char *reason); @endsignalproto @signaldesc 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. @return @c TRUE if the leave should be hidden, or @c FALSE otherwise. @param conv The chat conversation. @param name The name of the user that is leaving the chat. @param reason The optional reason why the user is leaving. @endsignaldef @signaldef chat-buddy-left @signalproto void (*chat_buddy_left)(GaimConversation *conv, const char *name, const char *reason); @endsignalproto @signaldesc Emitted when a user leaves a chat, after the user list is updated. This may include an optional reason why the user is leaving. @param conv The chat conversation. @param name The name of the user that left the chat. @param reason The optional reason why the user left the chat. @endsignaldef @signaldef chat-inviting-user @signalproto void (*chat_inviting_user)(GaimConversation *conv, const char *name, char **invite_message); @endsignalproto @signaldesc 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. @note Make sure to free @a *invite_message before you replace it! @param conv The chat conversation. @param name The name of the user being invited. @param invite_message A pointer to the reason why a user is being invited. @endsignaldef @signaldef chat-invited-user @signalproto void (*chat_invited_user)(GaimConversation *conv, const char *name, const char *invite_message); @endsignalproto @signaldesc Emitted when a user invited another user to a chat. @param conv The chat conversation. @param conv The name of the user that was invited. @param invite_message The message to be sent to the user when invited. @endsignaldef @signaldef chat-invited @signalproto gint (*chat_invited)(GaimAccount *account, const char *inviter, const char *chat, const char *invite_message const GHashTable *components); @endsignalproto @signaldesc Emitted when an account was invited to a chat. @param account The account being invited. @param inviter The username of the person inviting the account. @param chat The name of the chat you're being invited to. @param invite_message The optional invite message. @param components The components necessary if you want to call serv_join_chat @return 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. @endsignaldef @signaldef chat-joined @signalproto void (*chat_joined)(GaimConversation *conv); @endsignalproto @signaldesc Emitted when an account joins a chat room. @param conv The conversation that joined the chat room. @endsignaldef @signaldef chat-left @signalproto void (*chat_left)(GaimConversation *conv); @endsignalproto @signaldesc Emitted when an account leaves a chat room. @param conv The conversation that left the chat room. @endsignaldef @signaldef chat-topic-changed @signalproto void (*chat_topic_changed)(GaimConversation *conv, const char *who, const char *topic); @endsignalproto @signaldesc Emitted when the topic is changed in a chat. @param conv The conversation whose topic changed. @param who The name of the person that changed the topic. @param topic The new topic. @endsignaldef */ // vim: syntax=c tw=75 et