3 * Purple is the legal property of its developers, whose names are too numerous
4 * to list here. Please refer to the COPYRIGHT file distributed with this
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
22 #ifndef PURPLE_BLIST_NODE_H
23 #define PURPLE_BLIST_NODE_H
26 * @section_id: libpurple-blistnode
27 * @short_description: <filename>blistnode.h</filename>
28 * @title: Buddy List Node and Counting Node types
32 #include <glib-object.h>
34 #define PURPLE_TYPE_BLIST_NODE (purple_blist_node_get_type())
35 #define PURPLE_BLIST_NODE(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), PURPLE_TYPE_BLIST_NODE, PurpleBlistNode))
36 #define PURPLE_BLIST_NODE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), PURPLE_TYPE_BLIST_NODE, PurpleBlistNodeClass))
37 #define PURPLE_IS_BLIST_NODE(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), PURPLE_TYPE_BLIST_NODE))
38 #define PURPLE_IS_BLIST_NODE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), PURPLE_TYPE_BLIST_NODE))
39 #define PURPLE_BLIST_NODE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), PURPLE_TYPE_BLIST_NODE, PurpleBlistNodeClass))
41 typedef struct _PurpleBlistNode PurpleBlistNode
;
42 typedef struct _PurpleBlistNodeClass PurpleBlistNodeClass
;
46 * @prev: The sibling before this buddy.
47 * @next: The sibling after this buddy.
48 * @parent: The parent of this node.
49 * @child: The child of this node.
50 * @ui_data: The UI data associated with this node. This is a convenience
51 * field provided to the UIs -- it is not used by the libpurple core.
53 * A Buddy list node. This can represent a group, a buddy, or anything else.
54 * This is a base class for PurpleBuddy, PurpleContact, PurpleGroup, and for
55 * anything else that wants to put itself in the buddy list.
57 struct _PurpleBlistNode
{
61 PurpleBlistNode
*prev
;
62 PurpleBlistNode
*next
;
63 PurpleBlistNode
*parent
;
64 PurpleBlistNode
*child
;
69 struct _PurpleBlistNodeClass
{
70 GObjectClass gparent_class
;
73 void (*_purple_reserved1
)(void);
74 void (*_purple_reserved2
)(void);
75 void (*_purple_reserved3
)(void);
76 void (*_purple_reserved4
)(void);
82 * purple_blist_node_get_type:
84 * Returns: The #GType for the #PurpleBlistNode object.
86 GType
purple_blist_node_get_type(void);
89 * purple_blist_node_next:
91 * @offline: Whether to include nodes for offline accounts
93 * Returns the next node of a given node. This function is to be used to iterate
94 * over the tree returned by purple_blist_get_default.
96 * See purple_blist_node_get_parent(), purple_blist_node_get_first_child(),
97 * purple_blist_node_get_sibling_next(), purple_blist_node_get_sibling_prev().
99 * Returns: (transfer none): The next node
101 PurpleBlistNode
*purple_blist_node_next(PurpleBlistNode
*node
, gboolean offline
);
104 * purple_blist_node_get_parent:
107 * Returns the parent node of a given node.
109 * See purple_blist_node_get_first_child(), purple_blist_node_get_sibling_next(),
110 * purple_blist_node_get_sibling_prev(), purple_blist_node_next().
112 * Returns: (transfer none): The parent node.
114 PurpleBlistNode
*purple_blist_node_get_parent(PurpleBlistNode
*node
);
117 * purple_blist_node_get_first_child:
120 * Returns the the first child node of a given node.
122 * See purple_blist_node_get_parent(), purple_blist_node_get_sibling_next(),
123 * purple_blist_node_get_sibling_prev(), purple_blist_node_next().
125 * Returns: (transfer none): The child node.
127 PurpleBlistNode
*purple_blist_node_get_first_child(PurpleBlistNode
*node
);
130 * purple_blist_node_get_sibling_next:
133 * Returns the sibling node of a given node.
135 * See purple_blist_node_get_parent(), purple_blist_node_get_first_child(),
136 * purple_blist_node_get_sibling_prev(), purple_blist_node_next().
138 * Returns: (transfer none): The sibling node.
140 PurpleBlistNode
*purple_blist_node_get_sibling_next(PurpleBlistNode
*node
);
143 * purple_blist_node_get_sibling_prev:
146 * Returns the previous sibling node of a given node.
148 * See purple_blist_node_get_parent(), purple_blist_node_get_first_child(),
149 * purple_blist_node_get_sibling_next(), purple_blist_node_next().
151 * Returns: (transfer none): The sibling node.
153 PurpleBlistNode
*purple_blist_node_get_sibling_prev(PurpleBlistNode
*node
);
156 * purple_blist_node_get_ui_data:
159 * Returns the UI data of a given node.
161 * Returns: The UI data.
163 gpointer
purple_blist_node_get_ui_data(const PurpleBlistNode
*node
);
166 * purple_blist_node_set_ui_data:
168 * @ui_data: The UI data.
170 * Sets the UI data of a given node.
172 void purple_blist_node_set_ui_data(PurpleBlistNode
*node
, gpointer ui_data
);
175 * purple_blist_node_get_settings:
176 * @node: The node to from which to get settings
178 * Returns a node's settings
180 * Returns: (transfer none): The hash table with the node's settings.
182 GHashTable
*purple_blist_node_get_settings(PurpleBlistNode
*node
);
185 * purple_blist_node_has_setting:
186 * @node: The node to check from which to check settings
187 * @key: The identifier of the data
189 * Checks whether a named setting exists for a node in the buddy list
191 * Returns: TRUE if a value exists, or FALSE if there is no setting
193 gboolean
purple_blist_node_has_setting(PurpleBlistNode
*node
, const char *key
);
196 * purple_blist_node_set_bool:
197 * @node: The node to associate the data with
198 * @key: The identifier for the data
199 * @value: The value to set
201 * Associates a boolean with a node in the buddy list
203 void purple_blist_node_set_bool(PurpleBlistNode
*node
, const char *key
, gboolean value
);
206 * purple_blist_node_get_bool:
207 * @node: The node to retrieve the data from
208 * @key: The identifier of the data
210 * Retrieves a named boolean setting from a node in the buddy list
212 * Returns: The value, or FALSE if there is no setting
214 gboolean
purple_blist_node_get_bool(PurpleBlistNode
*node
, const char *key
);
217 * purple_blist_node_set_int:
218 * @node: The node to associate the data with
219 * @key: The identifier for the data
220 * @value: The value to set
222 * Associates an integer with a node in the buddy list
224 void purple_blist_node_set_int(PurpleBlistNode
*node
, const char *key
, int value
);
227 * purple_blist_node_get_int:
228 * @node: The node to retrieve the data from
229 * @key: The identifier of the data
231 * Retrieves a named integer setting from a node in the buddy list
233 * Returns: The value, or 0 if there is no setting
235 int purple_blist_node_get_int(PurpleBlistNode
*node
, const char *key
);
238 * purple_blist_node_set_string:
239 * @node: The node to associate the data with
240 * @key: The identifier for the data
241 * @value: The value to set
243 * Associates a string with a node in the buddy list
245 void purple_blist_node_set_string(PurpleBlistNode
*node
, const char *key
,
249 * purple_blist_node_get_string:
250 * @node: The node to retrieve the data from
251 * @key: The identifier of the data
253 * Retrieves a named string setting from a node in the buddy list
255 * Returns: The value, or NULL if there is no setting
257 const char *purple_blist_node_get_string(PurpleBlistNode
*node
, const char *key
);
260 * purple_blist_node_remove_setting:
261 * @node: The node from which to remove the setting
262 * @key: The name of the setting
264 * Removes a named setting from a blist node
266 void purple_blist_node_remove_setting(PurpleBlistNode
*node
, const char *key
);
269 * purple_blist_node_set_transient:
271 * @transient: TRUE if the node should NOT be saved, FALSE if node should
274 * Sets whether the node should be saved with the buddy list or not
276 void purple_blist_node_set_transient(PurpleBlistNode
*node
, gboolean transient
);
279 * purple_blist_node_is_transient:
282 * Gets whether the node should be saved with the buddy list or not
284 * Returns: TRUE if the node should NOT be saved, FALSE if node should be saved
286 gboolean
purple_blist_node_is_transient(PurpleBlistNode
*node
);
289 * purple_blist_node_get_extended_menu:
290 * @n: The blist node for which to obtain the extended menu items.
292 * Returns: (element-type PurpleActionMenu) (transfer full): The extended menu
293 * items for a buddy list node, as harvested by the
294 * blist-node-extended-menu signal.
296 GList
*purple_blist_node_get_extended_menu(PurpleBlistNode
*n
);
300 #endif /* PURPLE_BLIST_NODE_H */