libpurple/purplepresencemanager.h

Thu, 07 Aug 2025 21:40:13 -0500

author
Gary Kramlich <grim@reaperworld.com>
date
Thu, 07 Aug 2025 21:40:13 -0500
changeset 43302
e7b0bbfec5d5
parent 42594
eddde70cedd8
permissions
-rw-r--r--

Add an avatar-for-display property to Purple.ContactInfo

Testing Done:
Ran the tests under valgrind and called in the turtles.

Reviewed at https://reviews.imfreedom.org/r/4086/

42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
1 /*
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
2 * Purple - Internet Messaging Library
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
3 * Copyright (C) Pidgin Developers <devel@pidgin.im>
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
4 *
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
5 * Purple is the legal property of its developers, whose names are too numerous
42594
eddde70cedd8 Create a test for verifying license headers and correct the ones that were wrong
Gary Kramlich <grim@reaperworld.com>
parents: 42571
diff changeset
6 * to list here. Please refer to the COPYRIGHT file distributed with this
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
7 * source distribution.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
8 *
42594
eddde70cedd8 Create a test for verifying license headers and correct the ones that were wrong
Gary Kramlich <grim@reaperworld.com>
parents: 42571
diff changeset
9 * This library is free software; you can redistribute it and/or modify it
eddde70cedd8 Create a test for verifying license headers and correct the ones that were wrong
Gary Kramlich <grim@reaperworld.com>
parents: 42571
diff changeset
10 * under the terms of the GNU General Public License as published by the Free
eddde70cedd8 Create a test for verifying license headers and correct the ones that were wrong
Gary Kramlich <grim@reaperworld.com>
parents: 42571
diff changeset
11 * Software Foundation; either version 2 of the License, or (at your option)
eddde70cedd8 Create a test for verifying license headers and correct the ones that were wrong
Gary Kramlich <grim@reaperworld.com>
parents: 42571
diff changeset
12 * any later version.
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
13 *
42594
eddde70cedd8 Create a test for verifying license headers and correct the ones that were wrong
Gary Kramlich <grim@reaperworld.com>
parents: 42571
diff changeset
14 * This library is distributed in the hope that it will be useful, but WITHOUT
eddde70cedd8 Create a test for verifying license headers and correct the ones that were wrong
Gary Kramlich <grim@reaperworld.com>
parents: 42571
diff changeset
15 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
eddde70cedd8 Create a test for verifying license headers and correct the ones that were wrong
Gary Kramlich <grim@reaperworld.com>
parents: 42571
diff changeset
16 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
eddde70cedd8 Create a test for verifying license headers and correct the ones that were wrong
Gary Kramlich <grim@reaperworld.com>
parents: 42571
diff changeset
17 * more details.
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
18 *
42594
eddde70cedd8 Create a test for verifying license headers and correct the ones that were wrong
Gary Kramlich <grim@reaperworld.com>
parents: 42571
diff changeset
19 * You should have received a copy of the GNU General Public License along with
eddde70cedd8 Create a test for verifying license headers and correct the ones that were wrong
Gary Kramlich <grim@reaperworld.com>
parents: 42571
diff changeset
20 * this library; if not, see <https://www.gnu.org/licenses/>.
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
21 */
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
22
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
23 #if !defined(PURPLE_GLOBAL_HEADER_INSIDE) && !defined(PURPLE_COMPILATION)
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
24 # error "only <purple.h> may be included directly"
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
25 #endif
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
26
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
27 #ifndef PURPLE_PRESENCE_MANAGER_H
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
28 #define PURPLE_PRESENCE_MANAGER_H
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
29
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
30 #include <glib.h>
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
31 #include <glib-object.h>
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
32
42475
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
33 #include <gio/gio.h>
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
34
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
35 #include "purplesavedpresence.h"
42387
d9350cda1556 Export symbols added for 3.0.0
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42384
diff changeset
36 #include "purpleversion.h"
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
37
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
38 G_BEGIN_DECLS
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
39
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
40 #define PURPLE_TYPE_PRESENCE_MANAGER purple_presence_manager_get_type()
42387
d9350cda1556 Export symbols added for 3.0.0
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42384
diff changeset
41
d9350cda1556 Export symbols added for 3.0.0
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42384
diff changeset
42 PURPLE_AVAILABLE_IN_3_0
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
43 G_DECLARE_FINAL_TYPE(PurplePresenceManager, purple_presence_manager, PURPLE,
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
44 PRESENCE_MANAGER, GObject)
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
45
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
46 /**
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
47 * PurplePresenceManager:
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
48 *
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
49 * A manager for [class@SavedPresence]'s.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
50 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
51 * Since: 3.0
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
52 */
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
53
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
54 /**
42475
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
55 * purple_presence_manager_get_default:
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
56 *
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
57 * Gets the default [class@PresenceManager] that should be used.
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
58 *
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
59 * This may be %NULL if libpurple hasn't been initialized or if someone
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
60 * incorrectly unref'd it.
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
61 *
42486
594f84a2c97f Fix some small doc issues
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42475
diff changeset
62 * See also [func@PresenceManager.get_default_as_model].
594f84a2c97f Fix some small doc issues
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42475
diff changeset
63 *
42475
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
64 * Returns: (transfer none) (nullable): The default presence manager.
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
65 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
66 * Since: 3.0
42475
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
67 */
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
68 PURPLE_AVAILABLE_IN_3_0
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
69 PurplePresenceManager *purple_presence_manager_get_default(void);
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
70
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
71 /**
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
72 * purple_presence_manager_get_default_as_model:
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
73 *
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
74 * Gets the default [class@PresenceManager] as a [iface@Gio.ListModel].
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
75 *
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
76 * This is the equivalent to calling [func@PresenceManager.get_default] and
42486
594f84a2c97f Fix some small doc issues
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42475
diff changeset
77 * type casting it to [iface@Gio.ListModel].
42475
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
78 *
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
79 * This may be %NULL if libpurple hasn't been initialized or if someone
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
80 * incorrectly unref'd it.
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
81 *
42486
594f84a2c97f Fix some small doc issues
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42475
diff changeset
82 * See also [func@PresenceManager.get_default].
594f84a2c97f Fix some small doc issues
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42475
diff changeset
83 *
42475
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
84 * Returns: (transfer none) (nullable): The default presence manager type cast
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
85 * to a list model.
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
86 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
87 * Since: 3.0
42475
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
88 */
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
89 PURPLE_AVAILABLE_IN_3_0
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
90 GListModel *purple_presence_manager_get_default_as_model(void);
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
91
ce06ca18db9b Integrate PurplePresenceManager with the core and uis
Gary Kramlich <grim@reaperworld.com>
parents: 42387
diff changeset
92 /**
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
93 * purple_presence_manager_new:
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
94 * @path: (nullable): An optional directory path where settings will be stored.
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
95 *
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
96 * Creates a new presence manager instance.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
97 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
98 * If @path is %NULL, settings will not be stored to disk.
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
99 *
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
100 * Returns: (transfer full): The new instance.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
101 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
102 * Since: 3.0
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
103 */
42387
d9350cda1556 Export symbols added for 3.0.0
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42384
diff changeset
104 PURPLE_AVAILABLE_IN_3_0
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
105 PurplePresenceManager *purple_presence_manager_new(const char *path);
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
106
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
107 /**
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
108 * purple_presence_manager_get_path:
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
109 * @manager: The instance.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
110 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
111 * Gets the directory path that @manager is using for storage.
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
112 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
113 * Returns: (nullable): The directory path where settings are being saved to
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
114 * disk or %NULL.
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
115 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
116 * Since: 3.0
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
117 */
42387
d9350cda1556 Export symbols added for 3.0.0
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42384
diff changeset
118 PURPLE_AVAILABLE_IN_3_0
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
119 const char *purple_presence_manager_get_path(PurplePresenceManager *manager);
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
120
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
121 /**
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
122 * purple_presence_manager_get_active:
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
123 * @manager: The instance.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
124 *
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
125 * Gets the active [class@SavedPresence] from @manager.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
126 *
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
127 * Returns: (transfer none) (nullable): The active presence if there is one,
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
128 * otherwise %NULL.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
129 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
130 * Since: 3.0
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
131 */
42387
d9350cda1556 Export symbols added for 3.0.0
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42384
diff changeset
132 PURPLE_AVAILABLE_IN_3_0
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
133 PurpleSavedPresence *purple_presence_manager_get_active(PurplePresenceManager *manager);
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
134
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
135 /**
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
136 * purple_presence_manager_set_active:
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
137 * @manager: The instance.
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
138 * @presence: The presence to set as active.
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
139 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
140 * Sets the active presence to @presence.
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
141 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
142 * If @manager doesn't know about @presence, %FALSE will be returned to
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
143 * indicate a failure.
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
144 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
145 * Returns: %TRUE if a presence was found and made active, otherwise %FALSE.
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
146 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
147 * Since: 3.0
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
148 */
42387
d9350cda1556 Export symbols added for 3.0.0
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42384
diff changeset
149 PURPLE_AVAILABLE_IN_3_0
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
150 gboolean purple_presence_manager_set_active(PurplePresenceManager *manager, PurpleSavedPresence *presence);
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
151
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
152 /**
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
153 * purple_presence_manager_create:
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
154 * @manager: The instance.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
155 *
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
156 * Creates a new [class@SavedPresence] that is automatically added to @manager.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
157 *
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
158 * This is the only way to add a [class@SavedPresence] to @manager. This means
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
159 * that user interfaces will need to call this before displaying an editor to
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
160 * create a [class@SavedPresence].
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
161 *
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
162 * Returns: (transfer full): The new [class@SavedPresence].
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
163 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
164 * Since: 3.0
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
165 */
42387
d9350cda1556 Export symbols added for 3.0.0
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42384
diff changeset
166 PURPLE_AVAILABLE_IN_3_0
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
167 PurpleSavedPresence *purple_presence_manager_create(PurplePresenceManager *manager);
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
168
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
169 /**
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
170 * purple_presence_manager_remove:
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
171 * @manager: The instance.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
172 * @id: The id of the [class@SavedPresence].
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
173 *
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
174 * Attempts to remove the [class@SavedPresence] identified by @id from
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
175 * @manager.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
176 *
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
177 * Returns: %TRUE if a [class@SavedPresence] was found with @id and removed,
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
178 * otherwise %FALSE.
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
179 *
42571
722be3b1a8aa Redesign the presence manager a bit
Gary Kramlich <grim@reaperworld.com>
parents: 42486
diff changeset
180 * Since: 3.0
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
181 */
42387
d9350cda1556 Export symbols added for 3.0.0
Elliott Sales de Andrade <quantum.analyst@gmail.com>
parents: 42384
diff changeset
182 PURPLE_AVAILABLE_IN_3_0
42384
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
183 gboolean purple_presence_manager_remove(PurplePresenceManager *manager, const char *id);
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
184
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
185 G_END_DECLS
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
186
835faf0ddcb6 Implement PurplePresenceManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
187 #endif /* PURPLE_PRESENCE_MANAGER_H */

mercurial