libpurple/protocol.h

Sat, 22 Aug 2020 02:58:07 -0500

author
Gary Kramlich <grim@reaperworld.com>
date
Sat, 22 Aug 2020 02:58:07 -0500
changeset 40516
fefaa6596e74
parent 40507
77d7bc9e5151
child 40521
c4269b37a13a
permissions
-rw-r--r--

Remove the Gtk Ticker plugin as it doesn't scale to today's IM networks

Remove the ticker plugin as it doesn't scale to todays typical IM usage.

Testing Done:
Compile and install.

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

36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
1 /* purple
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
2 *
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
3 * Purple is the legal property of its developers, whose names are too numerous
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
4 * to list here. Please refer to the COPYRIGHT file distributed with this
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
5 * source distribution.
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
6 *
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
7 * This program is free software; you can redistribute it and/or modify
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
8 * it under the terms of the GNU General Public License as published by
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
9 * the Free Software Foundation; either version 2 of the License, or
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
10 * (at your option) any later version.
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
11 *
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
12 * This program is distributed in the hope that it will be useful,
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
15 * GNU General Public License for more details.
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
16 *
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
17 * You should have received a copy of the GNU General Public License
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
18 * along with this program; if not, write to the Free Software
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
20 */
37094
84873ce721dc Merge gtkdoc-conversion
Ankit Vani <a@nevitus.org>
parents: 37092
diff changeset
21
40474
1341be8e3402 Make it so only libpurple can directly include libpurple header files.
Gary Kramlich <grim@reaperworld.com>
parents: 40439
diff changeset
22 #if !defined(PURPLE_GLOBAL_HEADER_INSIDE) && !defined(PURPLE_COMPILATION)
1341be8e3402 Make it so only libpurple can directly include libpurple header files.
Gary Kramlich <grim@reaperworld.com>
parents: 40439
diff changeset
23 # error "only <purple.h> may be included directly"
1341be8e3402 Make it so only libpurple can directly include libpurple header files.
Gary Kramlich <grim@reaperworld.com>
parents: 40439
diff changeset
24 #endif
1341be8e3402 Make it so only libpurple can directly include libpurple header files.
Gary Kramlich <grim@reaperworld.com>
parents: 40439
diff changeset
25
39659
e4dfb99b0cef Fix libpurple header guards using reserved names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39597
diff changeset
26 #ifndef PURPLE_PROTOCOL_H
e4dfb99b0cef Fix libpurple header guards using reserved names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39597
diff changeset
27 #define PURPLE_PROTOCOL_H
37060
e5206d7698e5 Add section blocks for plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37054
diff changeset
28 /**
e5206d7698e5 Add section blocks for plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37054
diff changeset
29 * SECTION:protocol
e5206d7698e5 Add section blocks for plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37054
diff changeset
30 * @section_id: libpurple-protocol
e5206d7698e5 Add section blocks for plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37054
diff changeset
31 * @short_description: <filename>protocol.h</filename>
37062
f9b1a70fb9d6 Fix case in protocol(s).h
Ankit Vani <a@nevitus.org>
parents: 37060
diff changeset
32 * @title: Protocol Object and Interfaces
37060
e5206d7698e5 Add section blocks for plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37054
diff changeset
33 */
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
34
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
35 #define PURPLE_TYPE_PROTOCOL (purple_protocol_get_type())
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
36 #define PURPLE_PROTOCOL(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), PURPLE_TYPE_PROTOCOL, PurpleProtocol))
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
37 #define PURPLE_PROTOCOL_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), PURPLE_TYPE_PROTOCOL, PurpleProtocolClass))
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
38 #define PURPLE_IS_PROTOCOL(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), PURPLE_TYPE_PROTOCOL))
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
39 #define PURPLE_IS_PROTOCOL_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), PURPLE_TYPE_PROTOCOL))
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
40 #define PURPLE_PROTOCOL_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), PURPLE_TYPE_PROTOCOL, PurpleProtocolClass))
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
41
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
42 typedef struct _PurpleProtocol PurpleProtocol;
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
43 typedef struct _PurpleProtocolClass PurpleProtocolClass;
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
44
36569
264e4c0cc0d1 Included required headers
Ankit Vani <a@nevitus.org>
parents: 36567
diff changeset
45 #include "account.h"
36624
38043ecaf4a6 Finished implementing functions for protocols.[ch].
Ankit Vani <a@nevitus.org>
parents: 36621
diff changeset
46 #include "buddyicon.h"
36569
264e4c0cc0d1 Included required headers
Ankit Vani <a@nevitus.org>
parents: 36567
diff changeset
47 #include "buddylist.h"
40439
e9838d634d5e Make sure that internal.h can only be included by libpurple and split out some pieces to purpleprivate.h
Gary Kramlich <grim@reaperworld.com>
parents: 40350
diff changeset
48 #include "chat.h"
36569
264e4c0cc0d1 Included required headers
Ankit Vani <a@nevitus.org>
parents: 36567
diff changeset
49 #include "connection.h"
264e4c0cc0d1 Included required headers
Ankit Vani <a@nevitus.org>
parents: 36567
diff changeset
50 #include "conversations.h"
36613
0e96218aa13a Refactored the protocols to use the new macros, to allow for static or dynamic loading of types as configured
Ankit Vani <a@nevitus.org>
parents: 36611
diff changeset
51 #include "debug.h"
36688
e49025233301 Merged soc.2013.gobjectification branch
Ankit Vani <a@nevitus.org>
parents: 36686
diff changeset
52 #include "xfer.h"
37134
07746c9a04bf Merged default branch
Ankit Vani <a@nevitus.org>
parents: 37132
diff changeset
53 #include "image.h"
37148
50f361d39a1e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 37134
diff changeset
54 #include "message.h"
36610
3d99b9c0bf90 Refactored account, blist, buddyicon, connection, conversation, presence to use the new protocol API
Ankit Vani <a@nevitus.org>
parents: 36609
diff changeset
55 #include "notify.h"
36613
0e96218aa13a Refactored the protocols to use the new macros, to allow for static or dynamic loading of types as configured
Ankit Vani <a@nevitus.org>
parents: 36611
diff changeset
56 #include "plugins.h"
39970
cc7d4ff5a205 rename accountopt.[ch] to purpleaccountoption.[ch]
Gary Kramlich <grim@reaperworld.com>
parents: 39968
diff changeset
57 #include "purpleaccountoption.h"
39968
71622ee1354e move PurpleAccountUserSplit to their own file
Gary Kramlich <grim@reaperworld.com>
parents: 39896
diff changeset
58 #include "purpleaccountusersplit.h"
36569
264e4c0cc0d1 Included required headers
Ankit Vani <a@nevitus.org>
parents: 36567
diff changeset
59 #include "roomlist.h"
36587
69cdb86cfbc5 Added missing includes
Ankit Vani <a@nevitus.org>
parents: 36583
diff changeset
60 #include "status.h"
36569
264e4c0cc0d1 Included required headers
Ankit Vani <a@nevitus.org>
parents: 36567
diff changeset
61 #include "whiteboard.h"
264e4c0cc0d1 Included required headers
Ankit Vani <a@nevitus.org>
parents: 36567
diff changeset
62
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
63 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
64 * PurpleProtocol:
37038
8832d14d7d0c Rename 'protocol_options' field of PurpleProtocol to more appropriate 'account_options'
Ankit Vani <a@nevitus.org>
parents: 37036
diff changeset
65 * @id: Protocol ID
8832d14d7d0c Rename 'protocol_options' field of PurpleProtocol to more appropriate 'account_options'
Ankit Vani <a@nevitus.org>
parents: 37036
diff changeset
66 * @name: Translated name of the protocol
8832d14d7d0c Rename 'protocol_options' field of PurpleProtocol to more appropriate 'account_options'
Ankit Vani <a@nevitus.org>
parents: 37036
diff changeset
67 * @options: Protocol options
8832d14d7d0c Rename 'protocol_options' field of PurpleProtocol to more appropriate 'account_options'
Ankit Vani <a@nevitus.org>
parents: 37036
diff changeset
68 * @user_splits: A GList of PurpleAccountUserSplit
8832d14d7d0c Rename 'protocol_options' field of PurpleProtocol to more appropriate 'account_options'
Ankit Vani <a@nevitus.org>
parents: 37036
diff changeset
69 * @account_options: A GList of PurpleAccountOption
8832d14d7d0c Rename 'protocol_options' field of PurpleProtocol to more appropriate 'account_options'
Ankit Vani <a@nevitus.org>
parents: 37036
diff changeset
70 * @icon_spec: The icon spec.
8832d14d7d0c Rename 'protocol_options' field of PurpleProtocol to more appropriate 'account_options'
Ankit Vani <a@nevitus.org>
parents: 37036
diff changeset
71 * @whiteboard_ops: Whiteboard operations
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
72 *
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
73 * Represents an instance of a protocol registered with the protocols
36681
9c38716c8eb7 Moved protocol class members to instance. Protocol definitions now require *_init, *_class_init instead of *_base_init.
Ankit Vani <a@nevitus.org>
parents: 36680
diff changeset
74 * subsystem. Protocols must initialize the members to appropriate values.
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
75 */
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
76 struct _PurpleProtocol
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
77 {
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
78 GObject gparent;
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
79
37073
baf45dc13ffd Fix some gtk-doc warnings in protocol(s).h (not all)
Ankit Vani <a@nevitus.org>
parents: 37062
diff changeset
80 /*< public >*/
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
81 const char *id;
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
82 const char *name;
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
83
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
84 PurpleProtocolOptions options;
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
85
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
86 GList *user_splits;
37038
8832d14d7d0c Rename 'protocol_options' field of PurpleProtocol to more appropriate 'account_options'
Ankit Vani <a@nevitus.org>
parents: 37036
diff changeset
87 GList *account_options;
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
88
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
89 PurpleBuddyIconSpec *icon_spec;
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
90 PurpleWhiteboardOps *whiteboard_ops;
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
91
36896
3865997e388b Merged soc.2013.gobjectification branch
Ankit Vani <a@nevitus.org>
parents: 36731
diff changeset
92 /*< private >*/
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
93 void (*_purple_reserved1)(void);
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
94 void (*_purple_reserved2)(void);
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
95 void (*_purple_reserved3)(void);
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
96 void (*_purple_reserved4)(void);
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
97 };
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
98
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
99 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
100 * PurpleProtocolClass:
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
101 * @login: Log in to the server.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
102 * @close: Close connection with the server.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
103 * @status_types: Returns a list of #PurpleStatusType which exist for this
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
104 * account; and must add at least the offline and online states.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
105 * @list_icon: Returns the base icon name for the given buddy and account. If
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
106 * buddy is %NULL and the account is non-%NULL, it will return
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
107 * the name to use for the account's icon. If both are %NULL, it
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
108 * will return the name to use for the protocol's icon.
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
109 *
36681
9c38716c8eb7 Moved protocol class members to instance. Protocol definitions now require *_init, *_class_init instead of *_base_init.
Ankit Vani <a@nevitus.org>
parents: 36680
diff changeset
110 * The base class for all protocols.
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
111 *
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
112 * All protocol types must implement the methods in this class.
36681
9c38716c8eb7 Moved protocol class members to instance. Protocol definitions now require *_init, *_class_init instead of *_base_init.
Ankit Vani <a@nevitus.org>
parents: 36680
diff changeset
113 */
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
114 /* If adding new methods to this class, ensure you add checks for them in
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
115 purple_protocols_add().
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
116 */
36681
9c38716c8eb7 Moved protocol class members to instance. Protocol definitions now require *_init, *_class_init instead of *_base_init.
Ankit Vani <a@nevitus.org>
parents: 36680
diff changeset
117 struct _PurpleProtocolClass
9c38716c8eb7 Moved protocol class members to instance. Protocol definitions now require *_init, *_class_init instead of *_base_init.
Ankit Vani <a@nevitus.org>
parents: 36680
diff changeset
118 {
9c38716c8eb7 Moved protocol class members to instance. Protocol definitions now require *_init, *_class_init instead of *_base_init.
Ankit Vani <a@nevitus.org>
parents: 36680
diff changeset
119 GObjectClass parent_class;
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
120
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
121 void (*login)(PurpleAccount *account);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
122
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
123 void (*close)(PurpleConnection *connection);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
124
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
125 GList *(*status_types)(PurpleAccount *account);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
126
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
127 const char *(*list_icon)(PurpleAccount *account, PurpleBuddy *buddy);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
128
36896
3865997e388b Merged soc.2013.gobjectification branch
Ankit Vani <a@nevitus.org>
parents: 36731
diff changeset
129 /*< private >*/
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
130 void (*_purple_reserved1)(void);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
131 void (*_purple_reserved2)(void);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
132 void (*_purple_reserved3)(void);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
133 void (*_purple_reserved4)(void);
36681
9c38716c8eb7 Moved protocol class members to instance. Protocol definitions now require *_init, *_class_init instead of *_base_init.
Ankit Vani <a@nevitus.org>
parents: 36680
diff changeset
134 };
9c38716c8eb7 Moved protocol class members to instance. Protocol definitions now require *_init, *_class_init instead of *_base_init.
Ankit Vani <a@nevitus.org>
parents: 36680
diff changeset
135
39760
217330c81a30 Rename *_TYPE_*_IFACE to more standard *_TYPE_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39759
diff changeset
136 #define PURPLE_TYPE_PROTOCOL_CLIENT (purple_protocol_client_iface_get_type())
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
137
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
138 typedef struct _PurpleProtocolClientInterface PurpleProtocolClientInterface;
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
139
36681
9c38716c8eb7 Moved protocol class members to instance. Protocol definitions now require *_init, *_class_init instead of *_base_init.
Ankit Vani <a@nevitus.org>
parents: 36680
diff changeset
140 /**
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
141 * PurpleProtocolClientInterface:
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
142 * @get_actions: Returns the actions the protocol can perform. These will
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
143 * show up in the Accounts menu, under a submenu with the name
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
144 * of the account.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
145 * @list_emblem: Fills the four <type>char**</type>'s with string
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
146 * identifiers for "emblems" that the UI will interpret and
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
147 * display as relevant
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
148 * @status_text: Gets a short string representing this buddy's status. This
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
149 * will be shown on the buddy list.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
150 * @tooltip_text: Allows the protocol to add text to a buddy's tooltip.
39481
4db28449567d Rename PurpleMenuAction to PurpleActionMenu
Gary Kramlich <grim@reaperworld.com>
parents: 38859
diff changeset
151 * @blist_node_menu: Returns a list of #PurpleActionMenu structs, which
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
152 * represent extra actions to be shown in (for example) the
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
153 * right-click menu for @node.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
154 * @normalize: Convert the username @who to its canonical form. Also checks for
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
155 * validity.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
156 * <sbr/>For example, AIM treats "fOo BaR" and "foobar" as the same
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
157 * user; this function should return the same normalized string for
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
158 * both of those. On the other hand, both of these are invalid for
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
159 * protocols with number-based usernames, so function should return
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
160 * %NULL in such case.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
161 * <sbr/>@account: The account the username is related to. Can be
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
162 * %NULL.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
163 * <sbr/>@who: The username to convert.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
164 * <sbr/>Returns: Normalized username, or %NULL, if it's invalid.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
165 * @offline_message: Checks whether offline messages to @buddy are supported.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
166 * <sbr/>Returns: %TRUE if @buddy can be sent messages while
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
167 * they are offline, or %FALSE if not.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
168 * @get_account_text_table: This allows protocols to specify additional strings
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
169 * to be used for various purposes. The idea is to
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
170 * stuff a bunch of strings in this hash table instead
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
171 * of expanding the struct for every addition. This
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
172 * hash table is allocated every call and
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
173 * <emphasis>MUST</emphasis> be unrefed by the caller.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
174 * <sbr/>@account: The account to specify. This can be
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
175 * %NULL.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
176 * <sbr/>Returns: The protocol's string hash table.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
177 * The hash table should be destroyed
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
178 * by the caller when it's no longer
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
179 * needed.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
180 * @get_moods: Returns an array of #PurpleMood's, with the last one having
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
181 * "mood" set to %NULL.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
182 * @get_max_message_size: Gets the maximum message size in bytes for the
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
183 * conversation.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
184 * <sbr/>It may depend on connection-specific or
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
185 * conversation-specific variables, like channel or
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
186 * buddy's name length.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
187 * <sbr/>This value is intended for plaintext message,
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
188 * the exact value may be lower because of:
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
189 * <sbr/> - used newlines (some protocols count them as
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
190 * more than one byte),
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
191 * <sbr/> - formatting,
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
192 * <sbr/> - used special characters.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
193 * <sbr/>@conv: The conversation to query, or NULL to
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
194 * get safe minimum for the protocol.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
195 * <sbr/>Returns: Maximum message size, 0 if unspecified,
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
196 * -1 for infinite.
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
197 *
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
198 * The protocol client interface.
36682
cf89caae5d1e List the required protocol implementations in PurpleProtocolInterface's documentation
Ankit Vani <a@nevitus.org>
parents: 36681
diff changeset
199 *
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
200 * This interface provides a gateway between purple and the protocol.
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
201 */
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
202 struct _PurpleProtocolClientInterface
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
203 {
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
204 /*< private >*/
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
205 GTypeInterface parent_iface;
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
206
37073
baf45dc13ffd Fix some gtk-doc warnings in protocol(s).h (not all)
Ankit Vani <a@nevitus.org>
parents: 37062
diff changeset
207 /*< public >*/
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
208 GList *(*get_actions)(PurpleConnection *connection);
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
209
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
210 const char *(*list_emblem)(PurpleBuddy *buddy);
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
211
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
212 char *(*status_text)(PurpleBuddy *buddy);
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
213
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
214 void (*tooltip_text)(PurpleBuddy *buddy, PurpleNotifyUserInfo *user_info,
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
215 gboolean full);
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
216
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
217 GList *(*blist_node_menu)(PurpleBlistNode *node);
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
218
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
219 void (*buddy_free)(PurpleBuddy *buddy);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
220
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
221 void (*convo_closed)(PurpleConnection *connection, const char *who);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
222
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
223 const char *(*normalize)(const PurpleAccount *account, const char *who);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
224
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
225 PurpleChat *(*find_blist_chat)(PurpleAccount *account, const char *name);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
226
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
227 gboolean (*offline_message)(const PurpleBuddy *buddy);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
228
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
229 GHashTable *(*get_account_text_table)(PurpleAccount *account);
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
230
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
231 PurpleMood *(*get_moods)(PurpleAccount *account);
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
232
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
233 gssize (*get_max_message_size)(PurpleConversation *conv);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
234 };
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
235
39761
59c4ebe9ef67 Rename PURPLE_PROTOCOL_IS_* to PURPLE_IS_PROTOCOL_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39760
diff changeset
236 #define PURPLE_IS_PROTOCOL_CLIENT(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), PURPLE_TYPE_PROTOCOL_CLIENT))
39760
217330c81a30 Rename *_TYPE_*_IFACE to more standard *_TYPE_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39759
diff changeset
237 #define PURPLE_PROTOCOL_CLIENT_GET_IFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE((obj), PURPLE_TYPE_PROTOCOL_CLIENT, \
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
238 PurpleProtocolClientInterface))
37092
3dca8b4caa7f Move the HAS_IFACE and GET_IFACE macros after the iface structs
Ankit Vani <a@nevitus.org>
parents: 37091
diff changeset
239
39760
217330c81a30 Rename *_TYPE_*_IFACE to more standard *_TYPE_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39759
diff changeset
240 #define PURPLE_TYPE_PROTOCOL_SERVER (purple_protocol_server_iface_get_type())
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
241
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
242 typedef struct _PurpleProtocolServerInterface PurpleProtocolServerInterface;
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
243
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
244 /**
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
245 * PurpleProtocolServerInterface:
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
246 * @register_user: New user registration
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
247 * @unregister_user: Remove the user from the server. The account can either be
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
248 * connected or disconnected. After the removal is finished,
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
249 * the connection will stay open and has to be closed!
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
250 * @get_info: Should arrange for purple_notify_userinfo() to be called
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
251 * with @who's user info.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
252 * @add_buddy: Add a buddy to a group on the server.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
253 * <sbr/>This protocol function may be called in situations in
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
254 * which the buddy is already in the specified group. If the
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
255 * protocol supports authorization and the user is not already
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
256 * authorized to see the status of @buddy, @add_buddy should
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
257 * request authorization.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
258 * <sbr/>If authorization is required, then use the supplied
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
259 * invite message.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
260 * @keepalive: If implemented, this will be called regularly for this
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
261 * protocol's active connections. You'd want to do this if you
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
262 * need to repeatedly send some kind of keepalive packet to
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
263 * the server to avoid being disconnected. ("Regularly" is
40244
7a330cab3546 Remove documentation for non-public struct fields.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 40188
diff changeset
264 * defined to be 30 unless @get_keepalive_interval is
39518
6141cf90e5b8 libpurple: Make keepalive interval configurable
Petteri Pitkänen <petepitk@gmail.com>
parents: 38859
diff changeset
265 * implemented to override it).
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
266 * <filename>libpurple/connection.c</filename>.)
39518
6141cf90e5b8 libpurple: Make keepalive interval configurable
Petteri Pitkänen <petepitk@gmail.com>
parents: 38859
diff changeset
267 * @get_keepalive_interval: If implemented, this will override the default
6141cf90e5b8 libpurple: Make keepalive interval configurable
Petteri Pitkänen <petepitk@gmail.com>
parents: 38859
diff changeset
268 * keepalive interval.
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
269 * @alias_buddy: Save/store buddy's alias on server list/roster
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
270 * @group_buddy: Change a buddy's group on a server list/roster
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
271 * @rename_group: Rename a group on a server list/roster
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
272 * @set_buddy_icon: Set the buddy icon for the given connection to @img. The
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
273 * protocol does <emphasis>NOT</emphasis> own a reference to
37134
07746c9a04bf Merged default branch
Ankit Vani <a@nevitus.org>
parents: 37132
diff changeset
274 * @img; if it needs one, it must #g_object_ref(@img)
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
275 * itself.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
276 * @send_raw: For use in plugins that may understand the underlying
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
277 * protocol
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
278 * @set_public_alias: Set the user's "friendly name" (or alias or nickname or
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
279 * whatever term you want to call it) on the server. The
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
280 * protocol should call @success_cb or @failure_cb
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
281 * <emphasis>asynchronously</emphasis> (if it knows
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
282 * immediately that the set will fail, call one of the
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
283 * callbacks from an idle/0-second timeout) depending on if
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
284 * the nickname is set successfully. See
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
285 * purple_account_set_public_alias().
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
286 * <sbr/>@gc: The connection for which to set an alias
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
287 * <sbr/>@alias: The new server-side alias/nickname for this
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
288 * account, or %NULL to unset the
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
289 * alias/nickname (or return it to a
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
290 * protocol-specific "default").
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
291 * <sbr/>@success_cb: Callback to be called if the public
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
292 * alias is set
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
293 * <sbr/>@failure_cb: Callback to be called if setting the
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
294 * public alias fails
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
295 * @get_public_alias: Retrieve the user's "friendly name" as set on the server.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
296 * The protocol should call @success_cb or @failure_cb
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
297 * <emphasis>asynchronously</emphasis> (even if it knows
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
298 * immediately that the get will fail, call one of the
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
299 * callbacks from an idle/0-second timeout) depending on if
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
300 * the nickname is retrieved. See
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
301 * purple_account_get_public_alias().
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
302 * <sbr/>@gc: The connection for which to retireve
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
303 * the alias
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
304 * <sbr/>@success_cb: Callback to be called with the
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
305 * retrieved alias
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
306 * <sbr/>@failure_cb: Callback to be called if the protocol
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
307 * is unable to retrieve the alias
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
308 *
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
309 * The protocol server interface.
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
310 *
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
311 * This interface provides a gateway between purple and the protocol's server.
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
312 */
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
313 struct _PurpleProtocolServerInterface
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
314 {
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
315 /*< private >*/
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
316 GTypeInterface parent_iface;
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
317
37073
baf45dc13ffd Fix some gtk-doc warnings in protocol(s).h (not all)
Ankit Vani <a@nevitus.org>
parents: 37062
diff changeset
318 /*< public >*/
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
319 void (*register_user)(PurpleAccount *account);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
320
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
321 void (*unregister_user)(PurpleAccount *account, PurpleAccountUnregistrationCb cb,
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
322 void *user_data);
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
323
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
324 void (*set_info)(PurpleConnection *connection, const char *info);
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
325
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
326 void (*get_info)(PurpleConnection *connection, const char *who);
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
327
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
328 void (*set_status)(PurpleAccount *account, PurpleStatus *status);
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
329
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
330 void (*set_idle)(PurpleConnection *connection, int idletime);
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
331
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
332 void (*change_passwd)(PurpleConnection *connection, const char *old_pass,
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
333 const char *new_pass);
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
334
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
335 void (*add_buddy)(PurpleConnection *pc, PurpleBuddy *buddy,
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
336 PurpleGroup *group, const char *message);
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
337
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
338 void (*add_buddies)(PurpleConnection *pc, GList *buddies, GList *groups,
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
339 const char *message);
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
340
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
341 void (*remove_buddy)(PurpleConnection *connection, PurpleBuddy *buddy,
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
342 PurpleGroup *group);
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
343
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
344 void (*remove_buddies)(PurpleConnection *connection, GList *buddies, GList *groups);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
345
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
346 void (*keepalive)(PurpleConnection *connection);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
347
39518
6141cf90e5b8 libpurple: Make keepalive interval configurable
Petteri Pitkänen <petepitk@gmail.com>
parents: 38859
diff changeset
348 int (*get_keepalive_interval)(void);
6141cf90e5b8 libpurple: Make keepalive interval configurable
Petteri Pitkänen <petepitk@gmail.com>
parents: 38859
diff changeset
349
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
350 void (*alias_buddy)(PurpleConnection *connection, const char *who,
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
351 const char *alias);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
352
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
353 void (*group_buddy)(PurpleConnection *connection, const char *who,
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
354 const char *old_group, const char *new_group);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
355
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
356 void (*rename_group)(PurpleConnection *connection, const char *old_name,
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
357 PurpleGroup *group, GList *moved_buddies);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
358
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
359 void (*set_buddy_icon)(PurpleConnection *connection, PurpleImage *img);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
360
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
361 void (*remove_group)(PurpleConnection *gc, PurpleGroup *group);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
362
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
363 int (*send_raw)(PurpleConnection *gc, const char *buf, int len);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
364
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
365 void (*set_public_alias)(PurpleConnection *gc, const char *alias,
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
366 PurpleSetPublicAliasSuccessCallback success_cb,
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
367 PurpleSetPublicAliasFailureCallback failure_cb);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
368
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
369 void (*get_public_alias)(PurpleConnection *gc,
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
370 PurpleGetPublicAliasSuccessCallback success_cb,
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
371 PurpleGetPublicAliasFailureCallback failure_cb);
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
372 };
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
373
39761
59c4ebe9ef67 Rename PURPLE_PROTOCOL_IS_* to PURPLE_IS_PROTOCOL_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39760
diff changeset
374 #define PURPLE_IS_PROTOCOL_SERVER(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), PURPLE_TYPE_PROTOCOL_SERVER))
39760
217330c81a30 Rename *_TYPE_*_IFACE to more standard *_TYPE_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39759
diff changeset
375 #define PURPLE_PROTOCOL_SERVER_GET_IFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE((obj), PURPLE_TYPE_PROTOCOL_SERVER, \
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
376 PurpleProtocolServerInterface))
37092
3dca8b4caa7f Move the HAS_IFACE and GET_IFACE macros after the iface structs
Ankit Vani <a@nevitus.org>
parents: 37091
diff changeset
377
39760
217330c81a30 Rename *_TYPE_*_IFACE to more standard *_TYPE_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39759
diff changeset
378 #define PURPLE_TYPE_PROTOCOL_CHAT (purple_protocol_chat_iface_get_type())
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
379
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
380 typedef struct _PurpleProtocolChatInterface PurpleProtocolChatInterface;
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
381
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
382 /**
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
383 * PurpleProtocolChatInterface:
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
384 * @info: Returns a list of #PurpleProtocolChatEntry structs, which represent
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
385 * information required by the protocol to join a chat. libpurple will
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
386 * call join_chat along with the information filled by the user.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
387 * <sbr/>Returns: A list of #PurpleProtocolChatEntry's
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
388 * @info_defaults: Returns a hashtable which maps #PurpleProtocolChatEntry
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
389 * struct identifiers to default options as strings based on
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
390 * @chat_name. The resulting hashtable should be created with
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
391 * #g_hash_table_new_full(#g_str_hash, #g_str_equal, %NULL,
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
392 * #g_free). Use @get_name if you instead need to extract a chat
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
393 * name from a hashtable.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
394 * <sbr/>@chat_name: The chat name to be turned into components
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
395 * <sbr/>Returns: Hashtable containing the information extracted
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
396 * from @chat_name
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
397 * @join: Called when the user requests joining a chat. Should arrange for
37101
8ba9a23354ff Merge gtkdoc-conversion
Ankit Vani <a@nevitus.org>
parents: 37094
diff changeset
398 * purple_serv_got_joined_chat() to be called.
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
399 * <sbr/>@components: A hashtable containing information required to join
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
400 * the chat as described by the entries returned by
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
401 * @info. It may also be called when accepting an
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
402 * invitation, in which case this matches the data
37103
cdc96a002b33 Merge gtkdoc-conversion
Ankit Vani <a@nevitus.org>
parents: 37101
diff changeset
403 * parameter passed to purple_serv_got_chat_invite().
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
404 * @reject: Called when the user refuses a chat invitation.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
405 * <sbr/>@components: A hashtable containing information required to
37103
cdc96a002b33 Merge gtkdoc-conversion
Ankit Vani <a@nevitus.org>
parents: 37101
diff changeset
406 * join the chat as passed to purple_serv_got_chat_invite().
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
407 * @get_name: Returns a chat name based on the information in components. Use
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
408 * @info_defaults if you instead need to generate a hashtable from a
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
409 * chat name.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
410 * <sbr/>@components: A hashtable containing information about the
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
411 * chat.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
412 * @invite: Invite a user to join a chat.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
413 * <sbr/>@id: The id of the chat to invite the user to.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
414 * <sbr/>@message: A message displayed to the user when the invitation
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
415 * is received.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
416 * <sbr/>@who: The name of the user to send the invation to.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
417 * @leave: Called when the user requests leaving a chat.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
418 * <sbr/>@id: The id of the chat to leave
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
419 * @send: Send a message to a chat.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
420 * <sbr/>This protocol function should return a positive value on
37087
197d965cec97 Fix gtk-doc warnings
Ankit Vani <a@nevitus.org>
parents: 37086
diff changeset
421 * success. If the message is too big to be sent, return
197d965cec97 Fix gtk-doc warnings
Ankit Vani <a@nevitus.org>
parents: 37086
diff changeset
422 * <literal>-E2BIG</literal>. If the account is not connected,
197d965cec97 Fix gtk-doc warnings
Ankit Vani <a@nevitus.org>
parents: 37086
diff changeset
423 * return <literal>-ENOTCONN</literal>. If the protocol is unable
197d965cec97 Fix gtk-doc warnings
Ankit Vani <a@nevitus.org>
parents: 37086
diff changeset
424 * to send the message for another reason, return some other
197d965cec97 Fix gtk-doc warnings
Ankit Vani <a@nevitus.org>
parents: 37086
diff changeset
425 * negative value. You can use one of the valid #errno values, or
197d965cec97 Fix gtk-doc warnings
Ankit Vani <a@nevitus.org>
parents: 37086
diff changeset
426 * just big something.
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
427 * <sbr/>@id: The id of the chat to send the message to.
37148
50f361d39a1e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 37134
diff changeset
428 * <sbr/>@msg: The message to send to the chat.
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
429 * <sbr/>Returns: A positive number or 0 in case of success, a
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
430 * negative error number in case of failure.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
431 * @get_user_real_name: Gets the real name of a participant in a chat. For
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
432 * example, on XMPP this turns a chat room nick
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
433 * <literal>foo</literal> into
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
434 * <literal>room\@server/foo</literal>.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
435 * <sbr/>@gc: the connection on which the room is.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
436 * <sbr/>@id: the ID of the chat room.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
437 * <sbr/>@who: the nickname of the chat participant.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
438 * <sbr/>Returns: the real name of the participant. This
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
439 * string must be freed by the caller.
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
440 *
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
441 * The protocol chat interface.
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
442 *
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
443 * This interface provides callbacks needed by protocols that implement chats.
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
444 */
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
445 struct _PurpleProtocolChatInterface
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
446 {
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
447 /*< private >*/
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
448 GTypeInterface parent_iface;
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
449
37073
baf45dc13ffd Fix some gtk-doc warnings in protocol(s).h (not all)
Ankit Vani <a@nevitus.org>
parents: 37062
diff changeset
450 /*< public >*/
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
451 GList *(*info)(PurpleConnection *connection);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
452
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
453 GHashTable *(*info_defaults)(PurpleConnection *connection, const char *chat_name);
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
454
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
455 void (*join)(PurpleConnection *connection, GHashTable *components);
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
456
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
457 void (*reject)(PurpleConnection *connection, GHashTable *components);
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
458
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
459 char *(*get_name)(GHashTable *components);
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
460
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
461 void (*invite)(PurpleConnection *connection, int id,
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
462 const char *message, const char *who);
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
463
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
464 void (*leave)(PurpleConnection *connection, int id);
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
465
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
466 int (*send)(PurpleConnection *connection, int id, PurpleMessage *msg);
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
467
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
468 char *(*get_user_real_name)(PurpleConnection *gc, int id, const char *who);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
469
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
470 void (*set_topic)(PurpleConnection *gc, int id, const char *topic);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
471 };
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
472
39761
59c4ebe9ef67 Rename PURPLE_PROTOCOL_IS_* to PURPLE_IS_PROTOCOL_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39760
diff changeset
473 #define PURPLE_IS_PROTOCOL_CHAT(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), PURPLE_TYPE_PROTOCOL_CHAT))
39760
217330c81a30 Rename *_TYPE_*_IFACE to more standard *_TYPE_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39759
diff changeset
474 #define PURPLE_PROTOCOL_CHAT_GET_IFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE((obj), PURPLE_TYPE_PROTOCOL_CHAT, \
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
475 PurpleProtocolChatInterface))
37092
3dca8b4caa7f Move the HAS_IFACE and GET_IFACE macros after the iface structs
Ankit Vani <a@nevitus.org>
parents: 37091
diff changeset
476
39760
217330c81a30 Rename *_TYPE_*_IFACE to more standard *_TYPE_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39759
diff changeset
477 #define PURPLE_TYPE_PROTOCOL_PRIVACY (purple_protocol_privacy_iface_get_type())
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
478
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
479 typedef struct _PurpleProtocolPrivacyInterface PurpleProtocolPrivacyInterface;
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
480
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
481 /**
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
482 * PurpleProtocolPrivacyInterface:
37162
3336df05de5b Add introspection gtkdocs for server.h
Jorge Villaseñor <salinasv@pidgin.im>
parents: 37148
diff changeset
483 * @add_permit: Add the buddy on the required authorized list.
3336df05de5b Add introspection gtkdocs for server.h
Jorge Villaseñor <salinasv@pidgin.im>
parents: 37148
diff changeset
484 * @add_deny: Add the buddy on the required blocked list.
3336df05de5b Add introspection gtkdocs for server.h
Jorge Villaseñor <salinasv@pidgin.im>
parents: 37148
diff changeset
485 * @rem_permit: Remove the buddy from the requried authorized list.
3336df05de5b Add introspection gtkdocs for server.h
Jorge Villaseñor <salinasv@pidgin.im>
parents: 37148
diff changeset
486 * @rem_deny: Remove the buddy from the required blocked list.
3336df05de5b Add introspection gtkdocs for server.h
Jorge Villaseñor <salinasv@pidgin.im>
parents: 37148
diff changeset
487 * @set_permit_deny:Update the server with the privacy information on the permit and deny lists.
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
488 *
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
489 * The protocol privacy interface.
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
490 *
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
491 * This interface provides privacy callbacks such as to permit/deny users.
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
492 */
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
493 struct _PurpleProtocolPrivacyInterface
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
494 {
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
495 /*< private >*/
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
496 GTypeInterface parent_iface;
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
497
37073
baf45dc13ffd Fix some gtk-doc warnings in protocol(s).h (not all)
Ankit Vani <a@nevitus.org>
parents: 37062
diff changeset
498 /*< public >*/
37162
3336df05de5b Add introspection gtkdocs for server.h
Jorge Villaseñor <salinasv@pidgin.im>
parents: 37148
diff changeset
499 void (*add_permit)(PurpleConnection *gc, const char *name);
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
500
37162
3336df05de5b Add introspection gtkdocs for server.h
Jorge Villaseñor <salinasv@pidgin.im>
parents: 37148
diff changeset
501 void (*add_deny)(PurpleConnection *gc, const char *name);
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
502
37162
3336df05de5b Add introspection gtkdocs for server.h
Jorge Villaseñor <salinasv@pidgin.im>
parents: 37148
diff changeset
503 void (*rem_permit)(PurpleConnection *gc, const char *name);
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
504
37162
3336df05de5b Add introspection gtkdocs for server.h
Jorge Villaseñor <salinasv@pidgin.im>
parents: 37148
diff changeset
505 void (*rem_deny)(PurpleConnection *gc, const char *name);
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
506
37162
3336df05de5b Add introspection gtkdocs for server.h
Jorge Villaseñor <salinasv@pidgin.im>
parents: 37148
diff changeset
507 void (*set_permit_deny)(PurpleConnection *gc);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
508 };
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
509
39761
59c4ebe9ef67 Rename PURPLE_PROTOCOL_IS_* to PURPLE_IS_PROTOCOL_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39760
diff changeset
510 #define PURPLE_IS_PROTOCOL_PRIVACY(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), PURPLE_TYPE_PROTOCOL_PRIVACY))
39760
217330c81a30 Rename *_TYPE_*_IFACE to more standard *_TYPE_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39759
diff changeset
511 #define PURPLE_PROTOCOL_PRIVACY_GET_IFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE((obj), PURPLE_TYPE_PROTOCOL_PRIVACY, \
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
512 PurpleProtocolPrivacyInterface))
37092
3dca8b4caa7f Move the HAS_IFACE and GET_IFACE macros after the iface structs
Ankit Vani <a@nevitus.org>
parents: 37091
diff changeset
513
39760
217330c81a30 Rename *_TYPE_*_IFACE to more standard *_TYPE_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39759
diff changeset
514 #define PURPLE_TYPE_PROTOCOL_MEDIA (purple_protocol_media_iface_get_type())
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
515
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
516 typedef struct _PurpleProtocolMediaInterface PurpleProtocolMediaInterface;
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
517
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
518 /**
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
519 * PurpleProtocolMediaInterface:
37086
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
520 * @initiate_session: Initiate a media session with the given contact.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
521 * <sbr/>@account: The account to initiate the media session
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
522 * on.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
523 * <sbr/>@who: The remote user to initiate the session with.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
524 * <sbr/>@type: The type of media session to initiate.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
525 * <sbr/>Returns: %TRUE if the call succeeded else %FALSE.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
526 * (Doesn't imply the media session or stream
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
527 * will be successfully created)
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
528 * @get_caps: Checks to see if the given contact supports the given type of
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
529 * media session.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
530 * <sbr/>@account: The account the contact is on.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
531 * <sbr/>@who: The remote user to check for media capability with.
b78048ba0fbb Convert protocol interfaces doc to gtk-doc format
Ankit Vani <a@nevitus.org>
parents: 37084
diff changeset
532 * <sbr/>Returns: The media caps the contact supports.
37164
aea7e3b20138 Added send_dtmf to protocol media interface
Ankit Vani <a@nevitus.org>
parents: 37148
diff changeset
533 * @send_dtmf: Sends DTMF codes out-of-band in a protocol-specific way if the
aea7e3b20138 Added send_dtmf to protocol media interface
Ankit Vani <a@nevitus.org>
parents: 37148
diff changeset
534 * protocol supports it, or failing that in-band if the media backend
aea7e3b20138 Added send_dtmf to protocol media interface
Ankit Vani <a@nevitus.org>
parents: 37148
diff changeset
535 * can do so. See purple_media_send_dtmf().
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
536 *
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
537 * The protocol media interface.
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
538 *
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
539 * This interface provides callbacks for media sessions on the protocol.
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
540 */
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
541 struct _PurpleProtocolMediaInterface
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
542 {
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
543 /*< private >*/
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
544 GTypeInterface parent_iface;
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
545
37073
baf45dc13ffd Fix some gtk-doc warnings in protocol(s).h (not all)
Ankit Vani <a@nevitus.org>
parents: 37062
diff changeset
546 /*< public >*/
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
547 gboolean (*initiate_session)(PurpleAccount *account, const char *who,
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
548 PurpleMediaSessionType type);
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
549
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
550 PurpleMediaCaps (*get_caps)(PurpleAccount *account,
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
551 const char *who);
37164
aea7e3b20138 Added send_dtmf to protocol media interface
Ankit Vani <a@nevitus.org>
parents: 37148
diff changeset
552
aea7e3b20138 Added send_dtmf to protocol media interface
Ankit Vani <a@nevitus.org>
parents: 37148
diff changeset
553 gboolean (*send_dtmf)(PurpleMedia *media, gchar dtmf,
aea7e3b20138 Added send_dtmf to protocol media interface
Ankit Vani <a@nevitus.org>
parents: 37148
diff changeset
554 guint8 volume, guint8 duration);
36717
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
555 };
6c4736862534 Split up PurpleProtocolInterface into 10 smaller interfaces
Ankit Vani <a@nevitus.org>
parents: 36716
diff changeset
556
39761
59c4ebe9ef67 Rename PURPLE_PROTOCOL_IS_* to PURPLE_IS_PROTOCOL_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39760
diff changeset
557 #define PURPLE_IS_PROTOCOL_MEDIA(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), PURPLE_TYPE_PROTOCOL_MEDIA))
39760
217330c81a30 Rename *_TYPE_*_IFACE to more standard *_TYPE_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39759
diff changeset
558 #define PURPLE_PROTOCOL_MEDIA_GET_IFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE((obj), PURPLE_TYPE_PROTOCOL_MEDIA, \
39757
4a5ba806d8c9 Rename *Iface to more standard names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39739
diff changeset
559 PurpleProtocolMediaInterface))
37092
3dca8b4caa7f Move the HAS_IFACE and GET_IFACE macros after the iface structs
Ankit Vani <a@nevitus.org>
parents: 37091
diff changeset
560
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
561 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
562 * PURPLE_PROTOCOL_IMPLEMENTS:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
563 * @protocol: The protocol in which to check
39759
ea1401483849 Rename *_GET_*_IFACE to more standard *_GET_IFACE.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39758
diff changeset
564 * @IFACE: The interface name in caps. e.g. <literal>CLIENT</literal>
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
565 * @func: The function to check
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
566 *
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
567 * Returns: %TRUE if a protocol implements a function in an interface,
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
568 * %FALSE otherwise.
36620
c76013b145f4 Added PURPLE_PROTOCOL_IMPLEMENTS(protocol,func) to check if a protocol implements a function
Ankit Vani <a@nevitus.org>
parents: 36618
diff changeset
569 */
36720
465f02116328 Refactored account, blistnodetypes, buddylist, connection to use the new protocol interfaces
Ankit Vani <a@nevitus.org>
parents: 36718
diff changeset
570 #define PURPLE_PROTOCOL_IMPLEMENTS(protocol, IFACE, func) \
39761
59c4ebe9ef67 Rename PURPLE_PROTOCOL_IS_* to PURPLE_IS_PROTOCOL_*.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39760
diff changeset
571 (PURPLE_IS_PROTOCOL_##IFACE(protocol) && \
39759
ea1401483849 Rename *_GET_*_IFACE to more standard *_GET_IFACE.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39758
diff changeset
572 PURPLE_PROTOCOL_##IFACE##_GET_IFACE(protocol)->func != NULL)
36620
c76013b145f4 Added PURPLE_PROTOCOL_IMPLEMENTS(protocol,func) to check if a protocol implements a function
Ankit Vani <a@nevitus.org>
parents: 36618
diff changeset
573
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
574 G_BEGIN_DECLS
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
575
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
576 /**************************************************************************/
37090
c45c70779582 Remove @name from new plugin and protocol stuff
Ankit Vani <a@nevitus.org>
parents: 37089
diff changeset
577 /* Protocol Object API */
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
578 /**************************************************************************/
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
579
36617
be16459a68e9 Finished implementation of protocol object and interface stuff in protocol.[ch].
Ankit Vani <a@nevitus.org>
parents: 36613
diff changeset
580 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
581 * purple_protocol_get_type:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
582 *
37073
baf45dc13ffd Fix some gtk-doc warnings in protocol(s).h (not all)
Ankit Vani <a@nevitus.org>
parents: 37062
diff changeset
583 * Returns: The #GType for #PurpleProtocol.
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
584 */
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
585 GType purple_protocol_get_type(void);
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
586
36617
be16459a68e9 Finished implementation of protocol object and interface stuff in protocol.[ch].
Ankit Vani <a@nevitus.org>
parents: 36613
diff changeset
587 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
588 * purple_protocol_get_id:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
589 * @protocol: The protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
590 *
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
591 * Returns the ID of a protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
592 *
37034
9d6765962b22 Initial replacements for this branch
Ankit Vani <a@nevitus.org>
parents: 37023
diff changeset
593 * Returns: The ID of the protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
594 */
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
595 const char *purple_protocol_get_id(const PurpleProtocol *protocol);
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
596
36617
be16459a68e9 Finished implementation of protocol object and interface stuff in protocol.[ch].
Ankit Vani <a@nevitus.org>
parents: 36613
diff changeset
597 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
598 * purple_protocol_get_name:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
599 * @protocol: The protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
600 *
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
601 * Returns the translated name of a protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
602 *
37034
9d6765962b22 Initial replacements for this branch
Ankit Vani <a@nevitus.org>
parents: 37023
diff changeset
603 * Returns: The translated name of the protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
604 */
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
605 const char *purple_protocol_get_name(const PurpleProtocol *protocol);
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
606
36617
be16459a68e9 Finished implementation of protocol object and interface stuff in protocol.[ch].
Ankit Vani <a@nevitus.org>
parents: 36613
diff changeset
607 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
608 * purple_protocol_get_options:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
609 * @protocol: The protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
610 *
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
611 * Returns the options of a protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
612 *
37034
9d6765962b22 Initial replacements for this branch
Ankit Vani <a@nevitus.org>
parents: 37023
diff changeset
613 * Returns: The options of the protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
614 */
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
615 PurpleProtocolOptions purple_protocol_get_options(const PurpleProtocol *protocol);
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
616
36617
be16459a68e9 Finished implementation of protocol object and interface stuff in protocol.[ch].
Ankit Vani <a@nevitus.org>
parents: 36613
diff changeset
617 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
618 * purple_protocol_get_user_splits:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
619 * @protocol: The protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
620 *
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
621 * Returns the user splits of a protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
622 *
39739
ed1cd735639b Add some missing element-type annotations.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39672
diff changeset
623 * Returns: (element-type PurpleAccountUserSplit) (transfer none): The user
ed1cd735639b Add some missing element-type annotations.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39672
diff changeset
624 * splits of the protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
625 */
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
626 GList *purple_protocol_get_user_splits(const PurpleProtocol *protocol);
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
627
36617
be16459a68e9 Finished implementation of protocol object and interface stuff in protocol.[ch].
Ankit Vani <a@nevitus.org>
parents: 36613
diff changeset
628 /**
37038
8832d14d7d0c Rename 'protocol_options' field of PurpleProtocol to more appropriate 'account_options'
Ankit Vani <a@nevitus.org>
parents: 37036
diff changeset
629 * purple_protocol_get_account_options:
37034
9d6765962b22 Initial replacements for this branch
Ankit Vani <a@nevitus.org>
parents: 37023
diff changeset
630 * @protocol: The protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
631 *
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
632 * Returns the account options for a protocol.
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
633 *
39739
ed1cd735639b Add some missing element-type annotations.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39672
diff changeset
634 * Returns: (element-type PurpleAccountOption) (transfer none): The account
ed1cd735639b Add some missing element-type annotations.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39672
diff changeset
635 * options for the protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
636 */
37038
8832d14d7d0c Rename 'protocol_options' field of PurpleProtocol to more appropriate 'account_options'
Ankit Vani <a@nevitus.org>
parents: 37036
diff changeset
637 GList *purple_protocol_get_account_options(const PurpleProtocol *protocol);
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
638
36617
be16459a68e9 Finished implementation of protocol object and interface stuff in protocol.[ch].
Ankit Vani <a@nevitus.org>
parents: 36613
diff changeset
639 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
640 * purple_protocol_get_icon_spec:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
641 * @protocol: The protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
642 *
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
643 * Returns the icon spec of a protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
644 *
37034
9d6765962b22 Initial replacements for this branch
Ankit Vani <a@nevitus.org>
parents: 37023
diff changeset
645 * Returns: The icon spec of the protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
646 */
36608
bb8dbeba5bed Changed icon spec member of a protocol to a pointer. Use purple_buddy_icon_spec_new() to create an icon spec instance
Ankit Vani <a@nevitus.org>
parents: 36605
diff changeset
647 PurpleBuddyIconSpec *purple_protocol_get_icon_spec(const PurpleProtocol *protocol);
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
648
36617
be16459a68e9 Finished implementation of protocol object and interface stuff in protocol.[ch].
Ankit Vani <a@nevitus.org>
parents: 36613
diff changeset
649 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
650 * purple_protocol_get_whiteboard_ops:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
651 * @protocol: The protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
652 *
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
653 * Returns the whiteboard ops of a protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
654 *
40188
80e78796edb2 Revert (skip) annotations
qarkai <qarkai@gmail.com>
parents: 40186
diff changeset
655 * Returns: (transfer none): The whiteboard ops of the protocol.
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
656 */
36637
9b0109ae118d Renamed some prpl stuff to protocol stuff.
Ankit Vani <a@nevitus.org>
parents: 36624
diff changeset
657 PurpleWhiteboardOps *purple_protocol_get_whiteboard_ops(const PurpleProtocol *protocol);
36581
09d5842255a2 Added missing includes and functions to headers
Ankit Vani <a@nevitus.org>
parents: 36580
diff changeset
658
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
659 /**************************************************************************/
37090
c45c70779582 Remove @name from new plugin and protocol stuff
Ankit Vani <a@nevitus.org>
parents: 37089
diff changeset
660 /* Protocol Class API */
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
661 /**************************************************************************/
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
662
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
663 void purple_protocol_class_login(PurpleProtocol *protocol, PurpleAccount *account);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
664
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
665 void purple_protocol_class_close(PurpleProtocol *protocol, PurpleConnection *connection);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
666
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
667 GList *purple_protocol_class_status_types(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
668 PurpleAccount *account);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
669
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
670 const char *purple_protocol_class_list_icon(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
671 PurpleAccount *account, PurpleBuddy *buddy);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
672
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
673 /**************************************************************************/
37090
c45c70779582 Remove @name from new plugin and protocol stuff
Ankit Vani <a@nevitus.org>
parents: 37089
diff changeset
674 /* Protocol Client Interface API */
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
675 /**************************************************************************/
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
676
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
677 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
678 * purple_protocol_client_iface_get_type:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
679 *
37073
baf45dc13ffd Fix some gtk-doc warnings in protocol(s).h (not all)
Ankit Vani <a@nevitus.org>
parents: 37062
diff changeset
680 * Returns: The #GType for the protocol client interface.
39597
bd90a84a84a4 add since tags to the client_iface methods as well
Gary Kramlich <grim@reaperworld.com>
parents: 39596
diff changeset
681 *
bd90a84a84a4 add since tags to the client_iface methods as well
Gary Kramlich <grim@reaperworld.com>
parents: 39596
diff changeset
682 * Since: 3.0.0
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
683 */
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
684 GType purple_protocol_client_iface_get_type(void);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
685
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
686 /**
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
687 * purple_protocol_client_iface_get_actions:
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
688 * @protocol: The #PurpleProtocol instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
689 * @connection: The #PurpleConnection instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
690 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
691 * Gets a list of actions for @connection.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
692 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
693 * Returns: (transfer full) (element-type PurpleProtocolAction): The list of actions for @connection.
39597
bd90a84a84a4 add since tags to the client_iface methods as well
Gary Kramlich <grim@reaperworld.com>
parents: 39596
diff changeset
694 *
bd90a84a84a4 add since tags to the client_iface methods as well
Gary Kramlich <grim@reaperworld.com>
parents: 39596
diff changeset
695 * Since: 3.0.0
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
696 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
697 GList *purple_protocol_client_iface_get_actions(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
698 PurpleConnection *connection);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
699
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
700 /**
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
701 * purple_protocol_client_iface_list_emblem:
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
702 * @protocol: The #PurpleProtocol instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
703 * @buddy: The #PurpleBuddy instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
704 *
39595
0c9f3c4f1afb Various typo and whitespace fixes found in review
Gary Kramlich <grim@reaperworld.com>
parents: 39594
diff changeset
705 * Gets the icon name of the emblem that should be used for @buddy.
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
706 *
39595
0c9f3c4f1afb Various typo and whitespace fixes found in review
Gary Kramlich <grim@reaperworld.com>
parents: 39594
diff changeset
707 * Returns: The icon name of the emblem or NULL.
39597
bd90a84a84a4 add since tags to the client_iface methods as well
Gary Kramlich <grim@reaperworld.com>
parents: 39596
diff changeset
708 *
bd90a84a84a4 add since tags to the client_iface methods as well
Gary Kramlich <grim@reaperworld.com>
parents: 39596
diff changeset
709 * Since: 3.0.0
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
710 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
711 const char *purple_protocol_client_iface_list_emblem(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
712 PurpleBuddy *buddy);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
713
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
714 /**
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
715 * purple_protocol_client_iface_status_text:
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
716 * @protocol: The #PurpleProtocol instance.
39868
d2958d6e483e There's no such thing as a ProtocolBuddy, so renamed to PurpleBuddy
Gary Kramlich <grim@reaperworld.com>
parents: 39818
diff changeset
717 * @buddy: The #PurpleBuddy instance.
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
718 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
719 * Gets the status text for @buddy.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
720 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
721 * Returns: (transfer full): The status text for @buddy or NULL.
39597
bd90a84a84a4 add since tags to the client_iface methods as well
Gary Kramlich <grim@reaperworld.com>
parents: 39596
diff changeset
722 *
bd90a84a84a4 add since tags to the client_iface methods as well
Gary Kramlich <grim@reaperworld.com>
parents: 39596
diff changeset
723 * Since: 3.0.0
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
724 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
725 char *purple_protocol_client_iface_status_text(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
726 PurpleBuddy *buddy);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
727
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
728 /**
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
729 * purple_protocol_client_iface_tooltip_text:
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
730 * @protocol: The #PurpleProtocol instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
731 * @buddy: The #PurpleBuddy instance.
39596
17d54aaad818 Finish an imcomplete doc comment and clean up the wording on another
Gary Kramlich <grim@reaperworld.com>
parents: 39595
diff changeset
732 * @user_info: The #PurpleNotifyUserInfo instance.
17d54aaad818 Finish an imcomplete doc comment and clean up the wording on another
Gary Kramlich <grim@reaperworld.com>
parents: 39595
diff changeset
733 * @full: Whether or not additional info should be added.
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
734 *
39596
17d54aaad818 Finish an imcomplete doc comment and clean up the wording on another
Gary Kramlich <grim@reaperworld.com>
parents: 39595
diff changeset
735 * Asks @protocol to update @user_info for @buddy. If @full is %TRUE then
17d54aaad818 Finish an imcomplete doc comment and clean up the wording on another
Gary Kramlich <grim@reaperworld.com>
parents: 39595
diff changeset
736 * more detailed information will added.
39597
bd90a84a84a4 add since tags to the client_iface methods as well
Gary Kramlich <grim@reaperworld.com>
parents: 39596
diff changeset
737 *
bd90a84a84a4 add since tags to the client_iface methods as well
Gary Kramlich <grim@reaperworld.com>
parents: 39596
diff changeset
738 * Since: 3.0.0
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
739 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
740 void purple_protocol_client_iface_tooltip_text(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
741 PurpleBuddy *buddy, PurpleNotifyUserInfo *user_info, gboolean full);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
742
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
743 GList *purple_protocol_client_iface_blist_node_menu(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
744 PurpleBlistNode *node);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
745
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
746 void purple_protocol_client_iface_buddy_free(PurpleProtocol *protocol, PurpleBuddy *buddy);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
747
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
748 void purple_protocol_client_iface_convo_closed(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
749 PurpleConnection *connection, const char *who);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
750
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
751 const char *purple_protocol_client_iface_normalize(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
752 const PurpleAccount *account, const char *who);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
753
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
754 PurpleChat *purple_protocol_client_iface_find_blist_chat(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
755 PurpleAccount *account, const char *name);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
756
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
757 gboolean purple_protocol_client_iface_offline_message(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
758 const PurpleBuddy *buddy);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
759
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
760 GHashTable *purple_protocol_client_iface_get_account_text_table(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
761 PurpleAccount *account);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
762
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
763 PurpleMood *purple_protocol_client_iface_get_moods(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
764 PurpleAccount *account);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
765
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
766 gssize purple_protocol_client_iface_get_max_message_size(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
767 PurpleConversation *conv);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
768
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
769 /**************************************************************************/
37090
c45c70779582 Remove @name from new plugin and protocol stuff
Ankit Vani <a@nevitus.org>
parents: 37089
diff changeset
770 /* Protocol Server Interface API */
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
771 /**************************************************************************/
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
772
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
773 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
774 * purple_protocol_server_iface_get_type:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
775 *
37073
baf45dc13ffd Fix some gtk-doc warnings in protocol(s).h (not all)
Ankit Vani <a@nevitus.org>
parents: 37062
diff changeset
776 * Returns: The #GType for the protocol server interface.
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
777 */
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
778 GType purple_protocol_server_iface_get_type(void);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
779
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
780 void purple_protocol_server_iface_register_user(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
781 PurpleAccount *account);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
782
37132
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
783 /**
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
784 * purple_protocol_server_iface_unregister_user:
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
785 * @cb: (scope call):
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
786 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
787 void purple_protocol_server_iface_unregister_user(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
788 PurpleAccount *account, PurpleAccountUnregistrationCb cb, void *user_data);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
789
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
790 void purple_protocol_server_iface_set_info(PurpleProtocol *protocol, PurpleConnection *connection,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
791 const char *info);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
792
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
793 void purple_protocol_server_iface_get_info(PurpleProtocol *protocol, PurpleConnection *connection,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
794 const char *who);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
795
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
796 void purple_protocol_server_iface_set_status(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
797 PurpleAccount *account, PurpleStatus *status);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
798
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
799 void purple_protocol_server_iface_set_idle(PurpleProtocol *protocol, PurpleConnection *connection,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
800 int idletime);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
801
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
802 void purple_protocol_server_iface_change_passwd(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
803 PurpleConnection *connection, const char *old_pass, const char *new_pass);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
804
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
805 void purple_protocol_server_iface_add_buddy(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
806 PurpleConnection *pc, PurpleBuddy *buddy, PurpleGroup *group,
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
807 const char *message);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
808
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
809 void purple_protocol_server_iface_add_buddies(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
810 PurpleConnection *pc, GList *buddies, GList *groups,
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
811 const char *message);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
812
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
813 void purple_protocol_server_iface_remove_buddy(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
814 PurpleConnection *connection, PurpleBuddy *buddy, PurpleGroup *group);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
815
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
816 void purple_protocol_server_iface_remove_buddies(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
817 PurpleConnection *connection, GList *buddies, GList *groups);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
818
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
819 void purple_protocol_server_iface_keepalive(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
820 PurpleConnection *connection);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
821
39518
6141cf90e5b8 libpurple: Make keepalive interval configurable
Petteri Pitkänen <petepitk@gmail.com>
parents: 38859
diff changeset
822 int purple_protocol_server_iface_get_keepalive_interval(PurpleProtocol *protocol);
6141cf90e5b8 libpurple: Make keepalive interval configurable
Petteri Pitkänen <petepitk@gmail.com>
parents: 38859
diff changeset
823
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
824 void purple_protocol_server_iface_alias_buddy(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
825 PurpleConnection *connection, const char *who, const char *alias);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
826
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
827 void purple_protocol_server_iface_group_buddy(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
828 PurpleConnection *connection, const char *who, const char *old_group,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
829 const char *new_group);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
830
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
831 void purple_protocol_server_iface_rename_group(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
832 PurpleConnection *connection, const char *old_name, PurpleGroup *group,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
833 GList *moved_buddies);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
834
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
835 void purple_protocol_server_iface_set_buddy_icon(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
836 PurpleConnection *connection, PurpleImage *img);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
837
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
838 void purple_protocol_server_iface_remove_group(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
839 PurpleConnection *gc, PurpleGroup *group);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
840
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
841 int purple_protocol_server_iface_send_raw(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
842 PurpleConnection *gc, const char *buf, int len);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
843
37132
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
844 /**
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
845 * purple_protocol_server_iface_set_public_alias:
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
846 * @success_cb: (scope call):
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
847 * @failure_cb: (scope call):
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
848 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
849 void purple_protocol_server_iface_set_public_alias(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
850 PurpleConnection *gc, const char *alias,
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
851 PurpleSetPublicAliasSuccessCallback success_cb,
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
852 PurpleSetPublicAliasFailureCallback failure_cb);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
853
37132
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
854 /**
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
855 * purple_protocol_server_iface_get_public_alias:
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
856 * @success_cb: (scope call):
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
857 * @failure_cb: (scope call):
f4740b6e7525 Add (scope) annotation to callback parameters in plugins.h, protocol.h, protocols.h
Ankit Vani <a@nevitus.org>
parents: 37103
diff changeset
858 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
859 void purple_protocol_server_iface_get_public_alias(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
860 PurpleConnection *gc, PurpleGetPublicAliasSuccessCallback success_cb,
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
861 PurpleGetPublicAliasFailureCallback failure_cb);
36686
9807e4acf281 Added PurpleProtocolOverrideFlags and purple_protocol_override()
Ankit Vani <a@nevitus.org>
parents: 36682
diff changeset
862
36566
029a5f652427 Moved all of protocol API to protocol.h
Ankit Vani <a@nevitus.org>
parents: 36564
diff changeset
863 /**************************************************************************/
37090
c45c70779582 Remove @name from new plugin and protocol stuff
Ankit Vani <a@nevitus.org>
parents: 37089
diff changeset
864 /* Protocol Chat Interface API */
36566
029a5f652427 Moved all of protocol API to protocol.h
Ankit Vani <a@nevitus.org>
parents: 36564
diff changeset
865 /**************************************************************************/
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
866
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
867 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
868 * purple_protocol_chat_iface_get_type:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
869 *
37073
baf45dc13ffd Fix some gtk-doc warnings in protocol(s).h (not all)
Ankit Vani <a@nevitus.org>
parents: 37062
diff changeset
870 * Returns: The #GType for the protocol chat interface.
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
871 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
872 * Since: 3.0.0
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
873 */
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
874 GType purple_protocol_chat_iface_get_type(void);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
875
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
876 /**
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
877 * purple_protocol_chat_iface_info:
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
878 * @protocol: The #PurpleProtocol instance.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
879 * @connection: The #PurpleConnection instance.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
880 *
39596
17d54aaad818 Finish an imcomplete doc comment and clean up the wording on another
Gary Kramlich <grim@reaperworld.com>
parents: 39595
diff changeset
881 * Gets the list of #PurpleProtocolChatEntry's that are required to join a
17d54aaad818 Finish an imcomplete doc comment and clean up the wording on another
Gary Kramlich <grim@reaperworld.com>
parents: 39595
diff changeset
882 * multi user chat.
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
883 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
884 * Returns: (transfer full) (element-type PurpleProtocolChatEntry): The list
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
885 * of #PurpleProtocolChatEntry's that are used to join a chat.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
886 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
887 * Since: 3.0.0
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
888 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
889 GList *purple_protocol_chat_iface_info(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
890 PurpleConnection *connection);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
891
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
892 /**
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
893 * purple_protocol_chat_iface_info_defaults:
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
894 * @protocol: The #PurpleProtocol instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
895 * @connection: The #PurpleConnection instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
896 * @chat_name: The name of the chat
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
897 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
898 * Returns a #GHashTable of the default protocol dependent components that will
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
899 * be passed to #purple_protocol_chat_iface_join.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
900 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
901 * Returns: (transfer full) (element-type utf8 utf8): The values that will be
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
902 * used to join the chat.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
903 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
904 * Since: 3.0.0
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
905 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
906 GHashTable *purple_protocol_chat_iface_info_defaults(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
907 PurpleConnection *connection, const char *chat_name);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
908
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
909 /**
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
910 * purple_protocol_chat_iface_join:
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
911 * @protocol: The #PurpleProtocol instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
912 * @connection: The #PurpleConnection instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
913 * @components: (element-type utf8 utf8): The protocol dependent join
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
914 * components
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
915 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
916 * Joins the chat described in @components.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
917 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
918 * Since: 3.0.0
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
919 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
920 void purple_protocol_chat_iface_join(PurpleProtocol *protocol, PurpleConnection *connection,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
921 GHashTable *components);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
922
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
923 /**
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
924 * purple_protocol_chat_iface_reject:
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
925 * @protocol: The #PurpleProtocol instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
926 * @connection: The #PurpleConnection instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
927 * @components: (element-type utf8 utf8): The protocol dependent join
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
928 * components
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
929 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
930 * Not quite sure exactly what this does or where it's used. Please fill in
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
931 * the details if you know.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
932 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
933 * Since: 3.0.0
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
934 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
935 void purple_protocol_chat_iface_reject(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
936 PurpleConnection *connection, GHashTable *components);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
937
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
938 /**
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
939 * purple_protocol_chat_iface_get_name:
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
940 * @protocol: The #PurpleProtocol instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
941 * @components: (element-type utf8 utf8): The protocol dependent join
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
942 * components
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
943 *
39595
0c9f3c4f1afb Various typo and whitespace fixes found in review
Gary Kramlich <grim@reaperworld.com>
parents: 39594
diff changeset
944 * Gets the name from @components.
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
945 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
946 * Returns: (transfer full): The chat name from @components.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
947 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
948 * Since: 3.0.0
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
949 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
950 char *purple_protocol_chat_iface_get_name(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
951 GHashTable *components);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
952
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
953 /**
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
954 * purple_protocol_chat_iface_invite:
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
955 * @protocol: The #PurpleProtocol instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
956 * @connection: The #PurpleConnection instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
957 * @id: The id of the chat
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
958 * @message: The invite message
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
959 * @who: The target of the invite
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
960 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
961 * Sends an invite to @who with @message.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
962 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
963 * Since: 3.0.0
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
964 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
965 void purple_protocol_chat_iface_invite(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
966 PurpleConnection *connection, int id, const char *message, const char *who);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
967
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
968 /**
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
969 * purple_protocol_chat_iface_leave:
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
970 * @protocol: The #PurpleProtocol instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
971 * @connection: The #PurpleConnection instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
972 * @id: The id of the chat
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
973 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
974 * Leaves the chat identified by @id.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
975 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
976 * Since: 3.0.0
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
977 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
978 void purple_protocol_chat_iface_leave(PurpleProtocol *protocol, PurpleConnection *connection,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
979 int id);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
980
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
981 /**
39595
0c9f3c4f1afb Various typo and whitespace fixes found in review
Gary Kramlich <grim@reaperworld.com>
parents: 39594
diff changeset
982 * purple_protocol_chat_iface_send:
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
983 * @protocol: The #PurpleProtocol instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
984 * @connection: The #PurpleConnection instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
985 * @id: The id of the chat
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
986 * @msg: The message to send
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
987 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
988 * Sends @msg to the chat identified by @id.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
989 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
990 * Returns: 0 on success, non-zero on failure.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
991 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
992 * Since: 3.0.0
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
993 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
994 int purple_protocol_chat_iface_send(PurpleProtocol *protocol, PurpleConnection *connection,
37148
50f361d39a1e Merged default branch
Ankit Vani <a@nevitus.org>
parents: 37134
diff changeset
995 int id, PurpleMessage *msg);
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
996
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
997 /**
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
998 * purple_protocol_chat_iface_get_user_real_name:
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
999 * @protocol: The #PurpleProtocol instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1000 * @gc: The #PurpleConnection instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1001 * @id: The id of the chat
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1002 * @who: The username
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1003 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1004 * Gets the real name of @who.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1005 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1006 * Returns: (transfer full): The realname of @who.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1007 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1008 * Since: 3.0.0
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1009 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1010 char *purple_protocol_chat_iface_get_user_real_name(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1011 PurpleConnection *gc, int id, const char *who);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1012
39593
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1013 /**
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1014 * purple_protocol_chat_iface_set_topic:
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1015 * @protocol: The #PurpleProtocol instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1016 * @gc: The #PurpleConnection instance
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1017 * @id: The id of the chat
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1018 * @topic: The new topic
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1019 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1020 * Sets the topic for the chat with id @id to @topic.
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1021 *
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1022 * Since: 3.0.0
2d41781914e7 Document the protocol whiteboard and chat interfaces
Gary Kramlich <grim@reaperworld.com>
parents: 39592
diff changeset
1023 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1024 void purple_protocol_chat_iface_set_topic(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1025 PurpleConnection *gc, int id, const char *topic);
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1026
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1027 /**************************************************************************/
37090
c45c70779582 Remove @name from new plugin and protocol stuff
Ankit Vani <a@nevitus.org>
parents: 37089
diff changeset
1028 /* Protocol Privacy Interface API */
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1029 /**************************************************************************/
36566
029a5f652427 Moved all of protocol API to protocol.h
Ankit Vani <a@nevitus.org>
parents: 36564
diff changeset
1030
36617
be16459a68e9 Finished implementation of protocol object and interface stuff in protocol.[ch].
Ankit Vani <a@nevitus.org>
parents: 36613
diff changeset
1031 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
1032 * purple_protocol_privacy_iface_get_type:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
1033 *
37073
baf45dc13ffd Fix some gtk-doc warnings in protocol(s).h (not all)
Ankit Vani <a@nevitus.org>
parents: 37062
diff changeset
1034 * Returns: The #GType for the protocol privacy interface.
39594
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1035 *
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1036 * Since: 3.0.0
36617
be16459a68e9 Finished implementation of protocol object and interface stuff in protocol.[ch].
Ankit Vani <a@nevitus.org>
parents: 36613
diff changeset
1037 */
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1038 GType purple_protocol_privacy_iface_get_type(void);
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
1039
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1040 /**
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1041 * purple_protocol_privacy_iface_add_permit:
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1042 * @protocol: The #PurpleProtocol instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1043 * @connection: The #PurpleConnection instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1044 * @name: The username to permit.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1045 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1046 * Adds a permit to the privacy settings for @connection to allow @name to
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1047 * contact the user.
39594
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1048 *
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1049 * Since: 3.0.0
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1050 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1051 void purple_protocol_privacy_iface_add_permit(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1052 PurpleConnection *connection, const char *name);
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
1053
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1054 /**
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1055 * purple_protocol_privacy_iface_add_deny:
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1056 * @protocol: The #PurpleProtocol instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1057 * @connection: The #PurpleConnection instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1058 * @name: The username to deny.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1059 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1060 * Adds a deny to the privacy settings for @connection to deny @name from
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1061 * contacting the user.
39594
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1062 *
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1063 * Since: 3.0.0
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1064 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1065 void purple_protocol_privacy_iface_add_deny(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1066 PurpleConnection *connection, const char *name);
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
1067
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1068 /**
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1069 * purple_protocol_privacy_iface_rem_permit:
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1070 * @protocol: The #PurpleProtocol instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1071 * @connection: The #PurpleConnection instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1072 * @name: The username to remove from the permit privacy settings.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1073 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1074 * Removes an existing permit for @name.
39594
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1075 *
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1076 * Since: 3.0.0
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1077 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1078 void purple_protocol_privacy_iface_rem_permit(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1079 PurpleConnection *connection, const char *name);
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
1080
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1081 /**
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1082 * purple_protocol_privacy_iface_rem_deny:
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1083 * @protocol: The #PurpleProtocol instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1084 * @connection: The #PurpleConnection instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1085 * @name: The username to remove from the deny privacy settings.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1086 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1087 * Removes an existing deny for @name.
39594
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1088 *
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1089 * Since: 3.0.0
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1090 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1091 void purple_protocol_privacy_iface_rem_deny(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1092 PurpleConnection *connection, const char *name);
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
1093
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1094 /**
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1095 * purple_protocol_privacy_iface_set_permit_deny:
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1096 * @protocol: The #PurpleProtocol instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1097 * @connection: The #PurpleConnection instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1098 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1099 * Forces a sync of the privacy settings with server.
39594
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1100 *
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1101 * Since: 3.0.0
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1102 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1103 void purple_protocol_privacy_iface_set_permit_deny(PurpleProtocol *protocol,
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1104 PurpleConnection *connection);
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
1105
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1106 /**************************************************************************/
37090
c45c70779582 Remove @name from new plugin and protocol stuff
Ankit Vani <a@nevitus.org>
parents: 37089
diff changeset
1107 /* Protocol Media Interface API */
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1108 /**************************************************************************/
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
1109
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1110 /**
37036
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
1111 * purple_protocol_media_iface_get_type:
a8e12bcb0a74 Convert the new .h files for this branch for gtk-doc
Ankit Vani <a@nevitus.org>
parents: 37034
diff changeset
1112 *
37073
baf45dc13ffd Fix some gtk-doc warnings in protocol(s).h (not all)
Ankit Vani <a@nevitus.org>
parents: 37062
diff changeset
1113 * Returns: The #GType for the protocol media interface.
39594
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1114 *
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1115 * Since: 3.0.0
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1116 */
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1117 GType purple_protocol_media_iface_get_type(void);
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
1118
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1119 /**
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1120 * purple_protocol_media_iface_initiate_session:
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1121 * @protocol: The #PurpleProtocol instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1122 * @account: The #PurpleAccount instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1123 * @who: The user to initiate a media session with.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1124 * @type: The type of media session to create.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1125 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1126 * Initiates a media connection of @type to @who.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1127 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1128 * Returns: TRUE if successful, FALSE otherwise.
39594
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1129 *
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1130 * Since: 3.0.0
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1131 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1132 gboolean purple_protocol_media_iface_initiate_session(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1133 PurpleAccount *account, const char *who, PurpleMediaSessionType type);
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
1134
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1135 /**
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1136 * purple_protocol_media_iface_get_caps:
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1137 * @protocol: The #PurpleProtocol instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1138 * @account: The #PurpleAccount instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1139 * @who: The user to get the media capabilites for.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1140 *
39595
0c9f3c4f1afb Various typo and whitespace fixes found in review
Gary Kramlich <grim@reaperworld.com>
parents: 39594
diff changeset
1141 * Gets the #PurpleMediaCaps for @who which determine what types of media are
0c9f3c4f1afb Various typo and whitespace fixes found in review
Gary Kramlich <grim@reaperworld.com>
parents: 39594
diff changeset
1142 * available.
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1143 *
39595
0c9f3c4f1afb Various typo and whitespace fixes found in review
Gary Kramlich <grim@reaperworld.com>
parents: 39594
diff changeset
1144 * Returns: the media capabilities of @who.
39594
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1145 *
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1146 * Since: 3.0.0
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1147 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1148 PurpleMediaCaps purple_protocol_media_iface_get_caps(PurpleProtocol *protocol,
36718
24f9c085897a Finished splitting up the protocol interface
Ankit Vani <a@nevitus.org>
parents: 36717
diff changeset
1149 PurpleAccount *account, const char *who);
36564
2d423b459d4b Declared functions to call interface methods from PurpleProtocol * objects
Ankit Vani <a@nevitus.org>
parents: 36563
diff changeset
1150
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1151 /**
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1152 * purple_protocol_media_iface_send_dtmf:
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1153 * @protocol: The #PurpleProtocol instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1154 * @media: The #PurpleMedia instance.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1155 * @dtmf: A DTMF to send.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1156 * @volume: The volume to send @dtmf at.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1157 * @duration: The duration to send @dtmf (in ms?)
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1158 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1159 * Sends a DTMF (dual-tone multi-frequency) signal via the established @media
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1160 * for the given @duration at the given @volume.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1161 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1162 * It is up to the specific implementation if DTMF is send in or out of band.
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1163 *
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1164 * Returns: TRUE if successful, FALSE otherwise.
39594
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1165 *
3b42f3b5f643 Add since tags and remove stuff from ChangeLog.API
Gary Kramlich <grim@reaperworld.com>
parents: 39593
diff changeset
1166 * Since: 3.0.0
39592
445e2cf29f4d Start of cleaning up missing docs in protocol.h
Gary Kramlich <grim@reaperworld.com>
parents: 39521
diff changeset
1167 */
38745
f4376b1f4682 A ton more of introspection cleanups
Gary Kramlich <grim@reaperworld.com>
parents: 37167
diff changeset
1168 gboolean purple_protocol_media_iface_send_dtmf(PurpleProtocol *protocol,
37164
aea7e3b20138 Added send_dtmf to protocol media interface
Ankit Vani <a@nevitus.org>
parents: 37148
diff changeset
1169 PurpleMedia *media, gchar dtmf, guint8 volume, guint8 duration);
aea7e3b20138 Added send_dtmf to protocol media interface
Ankit Vani <a@nevitus.org>
parents: 37148
diff changeset
1170
36563
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
1171 G_END_DECLS
5ecb9a6c4611 Added protocol.[ch] and moved PurpleProtocol and PurpleProtocolInterface to it
Ankit Vani <a@nevitus.org>
parents:
diff changeset
1172
39659
e4dfb99b0cef Fix libpurple header guards using reserved names.
Elliott Sales de Andrade <qulogic@pidgin.im>
parents: 39597
diff changeset
1173 #endif /* PURPLE_PROTOCOL_H */

mercurial