/usr/include/telepathy-1.0/telepathy-glib/channel-factory-iface.h is in libtelepathy-glib-dev 0.18.0-1ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 | /*
* tp-channel-factory-iface.h - Headers for Telepathy Channel Factory interface
*
* Copyright (C) 2006 Collabora Ltd.
* Copyright (C) 2006 Nokia Corporation
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef __TP_CHANNEL_FACTORY_IFACE_H__
#define __TP_CHANNEL_FACTORY_IFACE_H__
#include <glib-object.h>
#include <telepathy-glib/channel-iface.h>
#include <telepathy-glib/enums.h>
#include <telepathy-glib/handle.h>
G_BEGIN_DECLS
#ifndef TP_DISABLE_DEPRECATED
#define TP_TYPE_CHANNEL_FACTORY_IFACE (tp_channel_factory_iface_get_type ())
#define TP_CHANNEL_FACTORY_IFACE(obj) \
(G_TYPE_CHECK_INSTANCE_CAST ((obj), \
TP_TYPE_CHANNEL_FACTORY_IFACE, TpChannelFactoryIface))
#define TP_IS_CHANNEL_FACTORY_IFACE(obj) \
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), \
TP_TYPE_CHANNEL_FACTORY_IFACE))
#define TP_CHANNEL_FACTORY_IFACE_GET_CLASS(obj) \
(G_TYPE_INSTANCE_GET_INTERFACE ((obj), \
TP_TYPE_CHANNEL_FACTORY_IFACE, TpChannelFactoryIfaceClass))
/**
* TpChannelFactoryIface:
*
* Opaque typedef representing any channel factory implementation.
*
* Deprecated since version 0.11.7. Use #TpChannelManager instead.
*
* Deprecated: 0.11.7
*/
typedef struct _TpChannelFactoryIface TpChannelFactoryIface;
/* documented below */
typedef struct _TpChannelFactoryIfaceClass TpChannelFactoryIfaceClass;
/**
* TpChannelFactoryRequestStatus:
* @TP_CHANNEL_FACTORY_REQUEST_STATUS_NOT_IMPLEMENTED: Same as the Telepathy
* error NotImplemented. The connection will try the next factory in its
* list; if all return this, the overall result of the request will be
* NotImplemented. *@ret and *@error are not set
* @TP_CHANNEL_FACTORY_REQUEST_STATUS_NOT_AVAILABLE: Same as the Telepathy
* error NotAvailable. *@ret and *@error are not set
* @TP_CHANNEL_FACTORY_REQUEST_STATUS_INVALID_HANDLE: Same as the Telepathy
* error InvalidHandle. *@ret and *@error are not set
* @TP_CHANNEL_FACTORY_REQUEST_STATUS_ERROR: An error other than the above.
* *@ret is not set, *@error is set
* @TP_CHANNEL_FACTORY_REQUEST_STATUS_CREATED: A new channel was created
* (possibly in response to more than one request). new-channel has already
* been emitted and *@ret is set to the new channel.
* @TP_CHANNEL_FACTORY_REQUEST_STATUS_QUEUED: A new channel will be created,
* or was created but is not ready yet. Either new-channel or channel-error
* will be emitted later. *@ret and *@error are not set.
* @TP_CHANNEL_FACTORY_REQUEST_STATUS_EXISTING: An existing channel
* satisfies the request: new-channel was not emitted. *@ret is set to the
* existing channel.
*
* Indicates the result of a channel request.
*
* Deprecated since version 0.11.7. Use #TpChannelManager instead.
*
* Deprecated: 0.11.7
*/
typedef enum { /*< skip >*/
TP_CHANNEL_FACTORY_REQUEST_STATUS_NOT_IMPLEMENTED = 0,
TP_CHANNEL_FACTORY_REQUEST_STATUS_NOT_AVAILABLE,
TP_CHANNEL_FACTORY_REQUEST_STATUS_INVALID_HANDLE,
TP_CHANNEL_FACTORY_REQUEST_STATUS_ERROR,
TP_CHANNEL_FACTORY_REQUEST_STATUS_CREATED,
TP_CHANNEL_FACTORY_REQUEST_STATUS_QUEUED,
TP_CHANNEL_FACTORY_REQUEST_STATUS_EXISTING
} TpChannelFactoryRequestStatus;
/**
* TpChannelFactoryIfaceProc:
* @self: An object implementing #TpChannelFactoryIface
*
* A virtual method on a channel factory that takes no extra parameters
* and returns nothing.
*
* Deprecated since version 0.11.7. Use #TpChannelManager instead.
*
* Deprecated: 0.11.7
*/
typedef void (*TpChannelFactoryIfaceProc) (TpChannelFactoryIface *self);
/**
* TpChannelFactoryIfaceRequestImpl:
* @self: An object implementing #TpChannelFactoryIface
* @chan_type: The channel type, e.g. %TP_IFACE_CHANNEL_TYPE_TEXT
* @handle_type: The handle type of the channel's associated handle,
* or 0 if the channel has no associated handle
* @handle: The channel's associated handle, of type @handle_type,
* or 0 if the channel has no associated handle
* @request: An opaque data structure representing the channel request;
* if this request is satisfied by a newly created channel,
* this structure MUST be included in the new-channel signal
* if the newly created channel has handle 0, and MAY be
* included in the signal if the newly created channel has
* nonzero handle.
* @ret: Set to the new channel if it is available immediately, as
* documented in the description of #TpChannelFactoryRequestStatus
* @error: Set to the error if the return is
* %TP_CHANNEL_FACTORY_REQUEST_STATUS_ERROR, unset otherwise
*
* Signature of an implementation of RequestChannel.
*
* Deprecated since version 0.11.7. Use #TpChannelManager instead.
*
* Deprecated: 0.11.7
*
* Returns: one of the values of #TpChannelFactoryRequestStatus, and
* behaves as documented for that return value
*/
typedef TpChannelFactoryRequestStatus (*TpChannelFactoryIfaceRequestImpl) (
TpChannelFactoryIface *self, const gchar *chan_type,
TpHandleType handle_type, guint handle, gpointer request,
TpChannelIface **ret, GError **error);
/**
* TpChannelFactoryIfaceForeachImpl:
* @self: An object implementing #TpChannelFactoryIface
* @func: A function
* @data: Arbitrary data to pass to @func as the second argument
*
* Signature of an implementation of foreach, which must call
* func(channel, data) for each channel managed by this factory.
*
* Deprecated since version 0.11.7. Use #TpChannelManager instead.
*
* Deprecated: 0.11.7
*/
typedef void (*TpChannelFactoryIfaceForeachImpl) (TpChannelFactoryIface *self,
TpChannelFunc func, gpointer data);
/**
* TpChannelFactoryIfaceClass:
* @parent_class: Fields shared with GTypeInterface
* @close_all: Close all channels and shut down the channel factory. It is not
* expected to be usable afterwards. This is called when the connection goes
* to disconnected state, before emitting the StatusChanged signal or calling
* disconnected(). Must be filled in by implementations.
* @connecting: Called just after the connection goes from disconnected to
* connecting state. May be NULL if nothing special needs to happen.
* @connected: Called just after the connection goes from connecting to
* connected state. May be NULL if nothing special needs to happen.
* @disconnected: Called just after the connection goes to disconnected state.
* This is always called after @close_all. May be NULL if nothing special
* needs to happen.
* @foreach: Call func(channel, data) for each channel managed by this
* factory. Must be filled in by implementations.
* @request: Respond to a request for a channel. Must be filled in by
* implementations. See #TpChannelFactoryIfaceRequestImpl for details.
*
* The class structure and vtable for a channel factory implementation.
*
* Deprecated since version 0.11.7. Use #TpChannelManager instead.
*
* Deprecated: 0.11.7
*/
struct _TpChannelFactoryIfaceClass {
GTypeInterface parent_class;
TpChannelFactoryIfaceProc close_all;
TpChannelFactoryIfaceProc connecting;
TpChannelFactoryIfaceProc connected;
TpChannelFactoryIfaceProc disconnected;
TpChannelFactoryIfaceForeachImpl foreach;
TpChannelFactoryIfaceRequestImpl request;
} _TP_GNUC_DEPRECATED;
GType tp_channel_factory_iface_get_type (void);
void tp_channel_factory_iface_close_all (TpChannelFactoryIface *self);
void tp_channel_factory_iface_connecting (TpChannelFactoryIface *self);
void tp_channel_factory_iface_connected (TpChannelFactoryIface *self);
void tp_channel_factory_iface_disconnected (TpChannelFactoryIface *self);
void tp_channel_factory_iface_foreach (TpChannelFactoryIface *self,
TpChannelFunc func, gpointer data);
TpChannelFactoryRequestStatus tp_channel_factory_iface_request (
TpChannelFactoryIface *self, const gchar *chan_type,
TpHandleType handle_type, guint handle, gpointer request,
TpChannelIface **ret, GError **error);
void tp_channel_factory_iface_emit_new_channel (gpointer instance,
TpChannelIface *channel, gpointer request);
void tp_channel_factory_iface_emit_channel_error (gpointer instance,
TpChannelIface *channel, GError *error, gpointer request);
#endif /* not TP_DISABLE_DEPRECATED */
G_END_DECLS
#endif /* __TP_CHANNEL_FACTORY_IFACE_H__ */
|