qulogic/pidgin
Clone
Summary
Browse
Changes
Graph
Update the ChangeLog for the certificate updates
release-2.x.y
v2.11.0
2016-06-19, Gary Kramlich
0b7591cc7360
Update the ChangeLog for the certificate updates
/**
* @file gtkconv.h GTK+ Conversation API
* @ingroup pidgin
* @see @ref gtkconv-signals
*/
/* pidgin
*
* Pidgin is the legal property of its developers, whose names are too numerous
* to list here. Please refer to the COPYRIGHT file distributed with this
* source distribution.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
*/
#ifndef _PIDGIN_CONVERSATION_H_
#define _PIDGIN_CONVERSATION_H_
typedef
struct
_PidginImPane
PidginImPane
;
typedef
struct
_PidginChatPane
PidginChatPane
;
typedef
struct
_PidginConversation
PidginConversation
;
/**
* Unseen text states.
*/
typedef
enum
{
PIDGIN_UNSEEN_NONE
,
/**< No unseen text in the conversation. */
PIDGIN_UNSEEN_EVENT
,
/**< Unseen events in the conversation. */
PIDGIN_UNSEEN_NO_LOG
,
/**< Unseen text with NO_LOG flag. */
PIDGIN_UNSEEN_TEXT
,
/**< Unseen text in the conversation. */
PIDGIN_UNSEEN_NICK
/**< Unseen text and the nick was said. */
}
PidginUnseenState
;
enum
{
CHAT_USERS_ICON_COLUMN
,
CHAT_USERS_ALIAS_COLUMN
,
CHAT_USERS_ALIAS_KEY_COLUMN
,
CHAT_USERS_NAME_COLUMN
,
CHAT_USERS_FLAGS_COLUMN
,
CHAT_USERS_COLOR_COLUMN
,
CHAT_USERS_WEIGHT_COLUMN
,
CHAT_USERS_ICON_STOCK_COLUMN
,
/** @since 2.6.0 */
CHAT_USERS_COLUMNS
};
#define PIDGIN_CONVERSATION(conv) \
((PidginConversation *)(conv)->ui_data)
#define PIDGIN_IS_PIDGIN_CONVERSATION(conv) \
(purple_conversation_get_ui_ops(conv) == \
pidgin_conversations_get_conv_ui_ops())
#include
"pidgin.h"
#include
"conversation.h"
#include
"gtkconvwin.h"
/**************************************************************************
* @name Structures
**************************************************************************/
/*@{*/
/**
* A GTK+ representation of a graphical window containing one or more
* conversations.
*/
/**
* A GTK+ Instant Message pane.
*/
struct
_PidginImPane
{
GtkWidget
*
block
;
GtkWidget
*
send_file
;
GtkWidget
*
sep1
;
GtkWidget
*
sep2
;
GtkWidget
*
check
;
GtkWidget
*
progress
;
guint32
typing_timer
;
/* Buddy icon stuff */
GtkWidget
*
icon_container
;
GtkWidget
*
icon
;
gboolean
show_icon
;
gboolean
animate
;
GdkPixbufAnimation
*
anim
;
GdkPixbufAnimationIter
*
iter
;
guint32
icon_timer
;
};
/**
* GTK+ Chat panes.
*/
struct
_PidginChatPane
{
GtkWidget
*
count
;
GtkWidget
*
list
;
GtkWidget
*
topic_text
;
};
/**
* A GTK+ conversation pane.
*/
struct
_PidginConversation
{
PurpleConversation
*
active_conv
;
GList
*
convs
;
GList
*
send_history
;
PidginWindow
*
win
;
gboolean
make_sound
;
GtkTooltips
*
tooltips
;
GtkWidget
*
tab_cont
;
GtkWidget
*
tabby
;
GtkWidget
*
menu_tabby
;
GtkWidget
*
imhtml
;
GtkTextBuffer
*
entry_buffer
;
GtkWidget
*
entry
;
gboolean
auto_resize
;
/* this is set to TRUE if the conversation
* is being resized by a non-user-initiated
* event, such as the buddy icon appearing
*/
gboolean
entry_growing
;
/* True if the size of the entry was set
* automatically by typing too much to fit
* in one line */
GtkWidget
*
close
;
/* "x" on the tab */
GtkWidget
*
icon
;
GtkWidget
*
tab_label
;
GtkWidget
*
menu_icon
;
GtkWidget
*
menu_label
;
#if !(defined PIDGIN_DISABLE_DEPRECATED) || (defined _PIDGIN_GTKCONV_C_)
/** @deprecated */
GtkSizeGroup
*
sg
;
#else
gpointer
depr1
;
#endif
GtkWidget
*
lower_hbox
;
GtkWidget
*
toolbar
;
PidginUnseenState
unseen_state
;
guint
unseen_count
;
union
{
PidginImPane
*
im
;
PidginChatPane
*
chat
;
}
u
;
time_t
newday
;
GtkWidget
*
infopane_hbox
;
GtkWidget
*
infopane
;
GtkListStore
*
infopane_model
;
GtkTreeIter
infopane_iter
;
/* Used when attaching a PidginConversation to a PurpleConversation
* with message history */
struct
{
int
timer
;
GList
*
current
;
}
attach
;
/**
* Quick Find.
*
* @since 2.7.0
*/
struct
{
GtkWidget
*
entry
;
GtkWidget
*
container
;
}
quickfind
;
};
/*@}*/
/**************************************************************************
* @name GTK+ Conversation API
**************************************************************************/
/*@{*/
/**
* Returns the UI operations structure for GTK+ conversations.
*
* @return The GTK+ conversation operations structure.
*/
PurpleConversationUiOps
*
pidgin_conversations_get_conv_ui_ops
(
void
);
/**
* Updates the buddy icon on a conversation.
*
* @param conv The conversation.
*/
void
pidgin_conv_update_buddy_icon
(
PurpleConversation
*
conv
);
/**
* Sets the active conversation within a GTK-conversation.
*
* @param conv The conversation
*/
void
pidgin_conv_switch_active_conversation
(
PurpleConversation
*
conv
);
/**
* Updates conversation buttons by protocol.
*
* @param conv The conversation.
*/
void
pidgin_conv_update_buttons_by_protocol
(
PurpleConversation
*
conv
);
/**
* Returns a list of conversations of the given type which have an unseen
* state greater than or equal to the specified minimum state. Using the
* hidden_only parameter, this search can be limited to hidden
* conversations. The max_count parameter will limit the total number of
* converations returned if greater than zero. The returned list should
* be freed by the caller.
*
* @param type The type of conversation.
* @param min_state The minimum unseen state.
* @param hidden_only If TRUE, only consider hidden conversations.
* @param max_count Maximum number of conversations to return, or 0 for
* no maximum.
* @return List of PurpleConversation matching criteria, or NULL.
*/
GList
*
pidgin_conversations_find_unseen_list
(
PurpleConversationType
type
,
PidginUnseenState
min_state
,
gboolean
hidden_only
,
guint
max_count
);
/**
* Fill a menu with a list of conversations. Clicking the conversation
* menu item will present that conversation to the user.
*
* @param menu Menu widget to add items to.
* @param convs List of PurpleConversation to add to menu.
* @return Number of conversations added to menu.
*/
guint
pidgin_conversations_fill_menu
(
GtkWidget
*
menu
,
GList
*
convs
);
/**
* Presents a purple conversation to the user.
*
* @param conv The conversation.
*/
void
pidgin_conv_present_conversation
(
PurpleConversation
*
conv
);
/**
* Reattach Pidgin UI to a conversation.
*
* @param conv The conversation.
*
* @return Wheter Pidgin UI was successfully attached.
*
* @since 2.2.0
*/
gboolean
pidgin_conv_attach_to_conversation
(
PurpleConversation
*
conv
);
PidginWindow
*
pidgin_conv_get_window
(
PidginConversation
*
gtkconv
);
GdkPixbuf
*
pidgin_conv_get_tab_icon
(
PurpleConversation
*
conv
,
gboolean
small_icon
);
void
pidgin_conv_new
(
PurpleConversation
*
conv
);
int
pidgin_conv_get_tab_at_xy
(
PidginWindow
*
win
,
int
x
,
int
y
,
gboolean
*
to_right
);
gboolean
pidgin_conv_is_hidden
(
PidginConversation
*
gtkconv
);
/*@}*/
/**************************************************************************/
/** @name GTK+ Conversations Subsystem */
/**************************************************************************/
/*@{*/
/**
* Returns the gtk conversations subsystem handle.
*
* @return The conversations subsystem handle.
*/
void
*
pidgin_conversations_get_handle
(
void
);
/**
* Initializes the GTK+ conversations subsystem.
*/
void
pidgin_conversations_init
(
void
);
/**
* Uninitialized the GTK+ conversation subsystem.
*/
void
pidgin_conversations_uninit
(
void
);
/*@}*/
#endif
/* _PIDGIN_CONVERSATION_H_ */