libpurple/purpleprotocolmanager.h

Wed, 20 Oct 2021 02:55:04 -0500

author
Gary Kramlich <grim@reaperworld.com>
date
Wed, 20 Oct 2021 02:55:04 -0500
changeset 41132
a528d27e81e2
parent 41010
d0abbb616bea
child 41155
922c9e70900c
permissions
-rw-r--r--

Make PurpleProtocolManager a final type

Testing Done:
Ran the unit tests and connected an XMPP account.

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

40735
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
1 /*
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
2 * Purple - Internet Messaging Library
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
3 * Copyright (C) Pidgin Developers <devel@pidgin.im>
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
4 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
5 * This program is free software; you can redistribute it and/or modify
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
6 * it under the terms of the GNU General Public License as published by
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
7 * the Free Software Foundation; either version 2 of the License, or
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
8 * (at your option) any later version.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
9 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
10 * This program is distributed in the hope that it will be useful,
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
13 * GNU General Public License for more details.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
14 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
16 * along with this program; if not, see <https://www.gnu.org/licenses/>.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
17 */
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
18
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
19 #if !defined(PURPLE_GLOBAL_HEADER_INSIDE) && !defined(PURPLE_COMPILATION)
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
20 # error "only <pidgin.h> may be included directly"
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
21 #endif
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
22
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
23 #ifndef PURPLE_PROTOCOL_MANAGER_H
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
24 #define PURPLE_PROTOCOL_MANAGER_H
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
25
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
26 #include <glib.h>
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
27 #include <glib-object.h>
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
28
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
29 #include "protocol.h"
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
30
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
31 G_BEGIN_DECLS
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
32
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
33 /**
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
34 * SECTION:purpleprotocolmanager
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
35 * @section_id: libpurple-purpleprotocolmanager
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
36 * @title: Purple Protocol Manager
41010
d0abbb616bea A bunch of random libpurple documentation fixes
Gary Kramlich <grim@reaperworld.com>
parents: 40986
diff changeset
37 * @short_description: Management of protocols.
40735
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
38 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
39 * #PurpleProtocolManager keeps track of all protocols and emits signals when
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
40 * protocols are registered and unregistered.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
41 */
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
42
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
43 /**
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
44 * PURPLE_PROTOCOL_MANAGER_DOMAIN:
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
45 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
46 * A #GError domain for errors from #PurpleProtocolManager.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
47 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
48 * Since: 3.0.0
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
49 */
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
50 #define PURPLE_PROTOCOL_MANAGER_DOMAIN (g_quark_from_static_string("purple-protocol-manager"))
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
51
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
52 /**
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
53 * PURPLE_TYPE_PROTOCOL_MANAGER:
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
54 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
55 * The standard _get_type macro for #PurpleProtocolManager.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
56 */
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
57 #define PURPLE_TYPE_PROTOCOL_MANAGER (purple_protocol_manager_get_type())
41132
a528d27e81e2 Make PurpleProtocolManager a final type
Gary Kramlich <grim@reaperworld.com>
parents: 41010
diff changeset
58 G_DECLARE_FINAL_TYPE(PurpleProtocolManager, purple_protocol_manager, PURPLE,
a528d27e81e2 Make PurpleProtocolManager a final type
Gary Kramlich <grim@reaperworld.com>
parents: 41010
diff changeset
59 PROTOCOL_MANAGER, GObject)
40735
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
60
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
61 /**
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
62 * PurpleProtocolManager:
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
63 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
64 * An opaque data structure that manages protocols.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
65 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
66 * Since: 3.0.0
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
67 */
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
68
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
69 /**
40986
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
70 * PurpleProtocolManagerForeachFunc:
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
71 * @protocol: The #PurpleProtocol instance.
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
72 * @data: User supplied data.
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
73 *
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
74 * A function to be used as a callback with purple_protocol_manager_foreach().
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
75 *
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
76 * Since: 3.0.0
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
77 */
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
78 typedef void (*PurpleProtocolManagerForeachFunc)(PurpleProtocol *protocol, gpointer data);
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
79
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
80 /**
40735
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
81 * purple_protocol_manager_get_default:
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
82 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
83 * Gets the default #PurpleProtocolManager instance.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
84 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
85 * Returns: (transfer none): The default #PurpleProtocolManager instance.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
86 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
87 * Since: 3.0.0
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
88 */
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
89 PurpleProtocolManager *purple_protocol_manager_get_default(void);
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
90
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
91 /**
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
92 * purple_protocol_manager_register:
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
93 * @manager: The #PurpleProtocolManager instance.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
94 * @protocol: The #PurpleProtocol to register.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
95 * @error: (out) (optional) (nullable): A return address for a #GError.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
96 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
97 * Registers @protocol with @manager.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
98 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
99 * Returns: %TRUE if @protocol was successfully registered with @manager,
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
100 * %FALSE otherwise.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
101 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
102 * Since: 3.0.0
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
103 */
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
104 gboolean purple_protocol_manager_register(PurpleProtocolManager *manager, PurpleProtocol *protocol, GError **error);
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
105
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
106 /**
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
107 * purple_protocol_manager_unregister:
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
108 * @manager: The #PurpleProtocolManager instance.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
109 * @protocol: The #PurpleProtocol to unregister.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
110 * @error: (out) (optional) (nullable): A return address for a #GError.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
111 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
112 * Unregisters @protocol from @manager.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
113 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
114 * Returns: %TRUE if @protocol was successfully unregistered from @manager,
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
115 * %FALSE otherwise.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
116 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
117 * Since: 3.0.0
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
118 */
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
119 gboolean purple_protocol_manager_unregister(PurpleProtocolManager *manager, PurpleProtocol *protocol, GError **error);
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
120
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
121 /**
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
122 * purple_protocol_manager_find:
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
123 * @manager: The #PurpleProtocolManager instance.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
124 * @id: The id of the #PurpleProtocol to find.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
125 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
126 * Gets the #PurpleProtocol identified by @id if found, otherwise %NULL.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
127 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
128 * Returns: (transfer none): The #PurpleProtocol identified by @id or %NULL.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
129 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
130 * Since: 3.0.0
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
131 */
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
132 PurpleProtocol *purple_protocol_manager_find(PurpleProtocolManager *manager, const gchar *id);
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
133
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
134 /**
40986
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
135 * purple_protocol_manager_foreach:
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
136 * @manager: The #PurpleProtocolManager instance.
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
137 * @func: (scope call): The #PurpleProtocolManagerForeachFunc to call.
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
138 * @data: User data to pass to @func.
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
139 *
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
140 * Calls @func for each #PurpleProtocol that @manager knows about.
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
141 *
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
142 * Since: 3.0.0
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
143 */
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
144 void purple_protocol_manager_foreach(PurpleProtocolManager *manager, PurpleProtocolManagerForeachFunc func, gpointer data);
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
145
e5564f7d6ebd Add _foreach functions to PurpleConversationManager and PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents: 40735
diff changeset
146 /**
40735
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
147 * purple_protocol_manager_get_all:
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
148 * @manager: The #PurpleProtocolManager instance.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
149 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
150 * Gets a sorted list of all #PurpleProtocols that are currently registered in
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
151 * @manager.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
152 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
153 * Returns: (transfer container) (element-type PurpleProtocol): The list
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
154 * containing all of the #PurpleProtocols registered with @manager.
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
155 *
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
156 * Since: 3.0.0
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
157 */
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
158 GList *purple_protocol_manager_get_all(PurpleProtocolManager *manager);
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
159
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
160 G_END_DECLS
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
161
cc0679f47fd9 Create a new PurpleProtocolManager
Gary Kramlich <grim@reaperworld.com>
parents:
diff changeset
162 #endif /* PURPLE_PROTOCOL_MANAGER_H */

mercurial