Standardize all protocol header guard macros.
[pidgin-git.git] / libpurple / presence.h
blob8f68a78a01ce16f99e155aa88004f9ed143b7ccd
1 /*
2 * purple
4 * Purple is the legal property of its developers, whose names are too numerous
5 * to list here. Please refer to the COPYRIGHT file distributed with this
6 * source distribution.
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
23 #ifndef PURPLE_PRESENCE_H
24 #define PURPLE_PRESENCE_H
25 /**
26 * SECTION:presence
27 * @section_id: libpurple-presence
28 * @short_description: <filename>presence.h</filename>
29 * @title: Presence Objects API
31 * This file contains the presence base type, account presence, and buddy
32 * presence API.
35 /**
36 * PurplePresence:
38 * A PurplePresence is like a collection of PurpleStatuses (plus some
39 * other random info). For any buddy, or for any one of your accounts,
40 * or for any person with which you're chatting, you may know various
41 * amounts of information. This information is all contained in
42 * one PurplePresence. If one of your buddies is away and idle,
43 * then the presence contains the PurpleStatus for their awayness,
44 * and it contains their current idle time. PurplePresences are
45 * never saved to disk. The information they contain is only relevant
46 * for the current PurpleSession.
48 * Note: When a presence is destroyed with the last g_object_unref(), all
49 * statuses added to this list will be destroyed along with the presence.
51 typedef struct _PurplePresence PurplePresence;
53 #include "account.h"
54 #include "buddylist.h"
55 #include "status.h"
57 /**
58 * PurplePresenceClass:
59 * @update_idle: Updates the logs and the UI when the idle state or time of the
60 * presence changes.
62 * Base class for all #PurplePresence's
64 struct _PurplePresenceClass {
65 GObjectClass parent_class;
67 void (*update_idle)(PurplePresence *presence, gboolean old_idle);
69 /*< private >*/
70 void (*_purple_reserved1)(void);
71 void (*_purple_reserved2)(void);
72 void (*_purple_reserved3)(void);
73 void (*_purple_reserved4)(void);
76 G_BEGIN_DECLS
78 /**************************************************************************/
79 /* PurplePresence API */
80 /**************************************************************************/
82 #define PURPLE_TYPE_PRESENCE purple_presence_get_type()
84 /**
85 * purple_presence_get_type:
87 * Returns: The #GType for the #PurplePresence object.
89 G_DECLARE_DERIVABLE_TYPE(PurplePresence, purple_presence, PURPLE,
90 PRESENCE, GObject)
92 /**
93 * purple_presence_set_status_active:
94 * @presence: The presence.
95 * @status_id: The ID of the status.
96 * @active: The active state.
98 * Sets the active state of a status in a presence.
100 * Only independent statuses can be set unactive. Normal statuses can only
101 * be set active, so if you wish to disable a status, set another
102 * non-independent status to active, or use purple_presence_switch_status().
104 void purple_presence_set_status_active(PurplePresence *presence,
105 const char *status_id, gboolean active);
108 * purple_presence_switch_status:
109 * @presence: The presence.
110 * @status_id: The status ID to switch to.
112 * Switches the active status in a presence.
114 * This is similar to purple_presence_set_status_active(), except it won't
115 * activate independent statuses.
117 void purple_presence_switch_status(PurplePresence *presence,
118 const char *status_id);
121 * purple_presence_set_idle:
122 * @presence: The presence.
123 * @idle: The idle state.
124 * @idle_time: The idle time, if @idle is TRUE. This
125 * is the time at which the user became idle,
126 * in seconds since the epoch. If this value is
127 * unknown then 0 should be used.
129 * Sets the idle state and time on a presence.
131 void purple_presence_set_idle(PurplePresence *presence, gboolean idle,
132 time_t idle_time);
135 * purple_presence_set_login_time:
136 * @presence: The presence.
137 * @login_time: The login time.
139 * Sets the login time on a presence.
141 void purple_presence_set_login_time(PurplePresence *presence, time_t login_time);
144 * purple_presence_get_statuses:
145 * @presence: The presence.
147 * Returns all the statuses in a presence.
149 * Returns: (element-type PurpleStatus) (transfer none): The statuses.
151 GList *purple_presence_get_statuses(PurplePresence *presence);
154 * purple_presence_get_status:
155 * @presence: The presence.
156 * @status_id: The ID of the status.
158 * Returns the status with the specified ID from a presence.
160 * Returns: (transfer none): The status if found, or %NULL.
162 PurpleStatus *purple_presence_get_status(PurplePresence *presence,
163 const char *status_id);
166 * purple_presence_get_active_status:
167 * @presence: The presence.
169 * Returns the active exclusive status from a presence.
171 * Returns: (transfer none): The active exclusive status.
173 PurpleStatus *purple_presence_get_active_status(PurplePresence *presence);
176 * purple_presence_is_available:
177 * @presence: The presence.
179 * Returns whether or not a presence is available.
181 * Available presences are online and possibly invisible, but not away or idle.
183 * Returns: TRUE if the presence is available, or FALSE otherwise.
185 gboolean purple_presence_is_available(PurplePresence *presence);
188 * purple_presence_is_online:
189 * @presence: The presence.
191 * Returns whether or not a presence is online.
193 * Returns: TRUE if the presence is online, or FALSE otherwise.
195 gboolean purple_presence_is_online(PurplePresence *presence);
198 * purple_presence_is_status_active:
199 * @presence: The presence.
200 * @status_id: The ID of the status.
202 * Returns whether or not a status in a presence is active.
204 * A status is active if itself or any of its sub-statuses are active.
206 * Returns: TRUE if the status is active, or FALSE.
208 gboolean purple_presence_is_status_active(PurplePresence *presence,
209 const char *status_id);
212 * purple_presence_is_status_primitive_active:
213 * @presence: The presence.
214 * @primitive: The status primitive.
216 * Returns whether or not a status with the specified primitive type
217 * in a presence is active.
219 * A status is active if itself or any of its sub-statuses are active.
221 * Returns: TRUE if the status is active, or FALSE.
223 gboolean purple_presence_is_status_primitive_active(
224 PurplePresence *presence, PurpleStatusPrimitive primitive);
227 * purple_presence_is_idle:
228 * @presence: The presence.
230 * Returns whether or not a presence is idle.
232 * Returns: TRUE if the presence is idle, or FALSE otherwise.
233 * If the presence is offline (purple_presence_is_online()
234 * returns FALSE) then FALSE is returned.
236 gboolean purple_presence_is_idle(PurplePresence *presence);
239 * purple_presence_get_idle_time:
240 * @presence: The presence.
242 * Returns the presence's idle time.
244 * Returns: The presence's idle time.
246 time_t purple_presence_get_idle_time(PurplePresence *presence);
249 * purple_presence_get_login_time:
250 * @presence: The presence.
252 * Returns the presence's login time.
254 * Returns: The presence's login time.
256 time_t purple_presence_get_login_time(PurplePresence *presence);
258 /**************************************************************************/
259 /* PurpleAccountPresence API */
260 /**************************************************************************/
262 #define PURPLE_TYPE_ACCOUNT_PRESENCE (purple_account_presence_get_type())
265 * purple_account_presence_get_type:
267 * Returns: The #GType for the #PurpleAccountPresence object.
269 G_DECLARE_FINAL_TYPE(PurpleAccountPresence, purple_account_presence,
270 PURPLE, ACCOUNT_PRESENCE, PurplePresence)
273 * purple_account_presence_new:
274 * @account: The account to associate with the presence.
276 * Creates a presence for an account.
278 * Returns: The new presence.
280 PurpleAccountPresence *purple_account_presence_new(PurpleAccount *account);
283 * purple_account_presence_get_account:
284 * @presence: The presence.
286 * Returns an account presence's account.
288 * Returns: (transfer none): The presence's account.
290 PurpleAccount *purple_account_presence_get_account(PurpleAccountPresence *presence);
292 /**************************************************************************/
293 /* PurpleBuddyPresence API */
294 /**************************************************************************/
296 #define PURPLE_TYPE_BUDDY_PRESENCE (purple_buddy_presence_get_type())
299 * purple_buddy_presence_get_type:
301 * Returns: The #GType for the #PurpleBuddyPresence object.
303 G_DECLARE_FINAL_TYPE(PurpleBuddyPresence, purple_buddy_presence, PURPLE,
304 BUDDY_PRESENCE, PurplePresence)
307 * purple_buddy_presence_new:
308 * @buddy: The buddy to associate with the presence.
310 * Creates a presence for a buddy.
312 * Returns: The new presence.
314 PurpleBuddyPresence *purple_buddy_presence_new(PurpleBuddy *buddy);
317 * purple_buddy_presence_get_buddy:
318 * @presence: The presence.
320 * Returns the buddy presence's buddy.
322 * Returns: (transfer none): The presence's buddy.
324 PurpleBuddy *purple_buddy_presence_get_buddy(PurpleBuddyPresence *presence);
327 * purple_buddy_presence_compare:
328 * @buddy_presence1: The first presence.
329 * @buddy_presence2: The second presence.
331 * Compares two buddy presences for availability.
333 * Returns: -1 if @buddy_presence1 is more available than @buddy_presence2.
334 * 0 if @buddy_presence1 is equal to @buddy_presence2.
335 * 1 if @buddy_presence1 is less available than @buddy_presence2.
337 gint purple_buddy_presence_compare(PurpleBuddyPresence *buddy_presence1,
338 PurpleBuddyPresence *buddy_presence2);
340 G_END_DECLS
342 #endif /* PURPLE_PRESENCE_H */