/usr/include/telepathy-1.0/telepathy-glib/properties-mixin.h is in libtelepathy-glib-dev 0.24.1-1.1.
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 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 | /*
* properties-mixin.h - Header for TpPropertiesMixin
* Copyright (C) 2006 Collabora Ltd.
* Copyright (C) 2006 Nokia Corporation
* @author Ole Andre Vadla Ravnaas <ole.andre.ravnaas@collabora.co.uk>
* @author Robert McQueen <robert.mcqueen@collabora.co.uk>
*
* 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_PROPERTIES_MIXIN_H__
#define __TP_PROPERTIES_MIXIN_H__
#include <glib-object.h>
#include <dbus/dbus-glib.h>
#define _TP_IN_META_HEADER
#include <telepathy-glib/enums.h>
#include <telepathy-glib/gtypes.h>
#include <telepathy-glib/intset.h>
#include <telepathy-glib/svc-properties-interface.h>
#include <telepathy-glib/util.h>
G_BEGIN_DECLS
/**
* TpPropertySignature:
* @name: Name of the property as seen in the Telepathy D-Bus protocol
* @type: GType which the variant value must have. We currently support
* only %G_TYPE_UINT, %G_TYPE_INT, %G_TYPE_STRING, %G_TYPE_BOOLEAN,
* corresponding to D-Bus signatures 'u', 'i', 's', 'b'.
*
* Signature of a property in the Telepathy properties interface.
*/
struct _TpPropertySignature {
gchar *name;
GType type;
};
typedef struct _TpPropertySignature TpPropertySignature;
/**
* TpProperty:
* @value: The value of the property
* @flags: #TpPropertyFlags indicating the property's permissions
*
* Structure representing the current state of a property.
*/
struct _TpProperty {
/* FIXME: if we ever break ABI, make this a (GValue) rather than a
* (GValue *) */
GValue *value;
guint flags;
};
typedef struct _TpProperty TpProperty;
/**
* TpPropertiesContext:
*
* Opaque pointer representing an incomplete property-setting operation, used
* in the implementation of SetProperties.
*/
typedef struct _TpPropertiesContext TpPropertiesContext;
/**
* TpPropertiesSetFunc:
* @obj: An object with the properties mixin
* @ctx: A properties context
* @error: Set to the error if %FALSE is returned
*
* A callback used to implement the SetProperties D-Bus method by setting
* properties in the underlying IM protocol.
*
* The callback must either:
*
* * return %FALSE to indicate immediate failure
* * call tp_properties_context_return() with an error to indicate failure
* * call tp_properties_context_remove() to remove each property from the set
* of pending properties, then call tp_properties_context_return_if_done()
* or tp_properties_context_return() when all were set
*
* Returns: %FALSE on immediate failure, %TRUE otherwise
*/
typedef gboolean (*TpPropertiesSetFunc) (GObject *obj,
TpPropertiesContext *ctx, GError **error);
typedef struct _TpPropertiesMixinClass TpPropertiesMixinClass;
typedef struct _TpPropertiesMixinPrivate TpPropertiesMixinPrivate;
typedef struct _TpPropertiesMixin TpPropertiesMixin;
/* Doesn't yet exist. For future expansion. */
typedef struct _TpPropertiesMixinClassPrivate TpPropertiesMixinClassPrivate;
/**
* TpPropertiesMixin:
* @properties: Array of property values, of length klass->num_props.
* Should be considered read-only.
* @priv: Pointer to opaque private data.
*
* Structure to be placed in a GObject-derived structure containing
* instance data for the properties mixin (i.e. the properties). Initialize
* it using tp_properties_mixin_init().
*/
struct _TpPropertiesMixin {
TpProperty *properties;
TpPropertiesMixinPrivate *priv;
};
/**
* TpPropertiesMixinClass:
* @signatures: Array of property signatures, as provided via
* tp_properties_mixin_class_init(), of length @num_props.
* @num_props: Number of properties supported.
* @set_properties: Properties setting function, as supplied to
* tp_properties_mixin_class_init().
* @priv: Pointer to opaque private data.
*
* Structure to be placed in a GObjectClass-derived structure containing
* settings for the properties mixin. Initialize it using
* tp_properties_mixin_class_init().
*
* All fields should be considered read-only.
*/
struct _TpPropertiesMixinClass {
const TpPropertySignature *signatures;
guint num_props;
TpPropertiesSetFunc set_properties;
TpPropertiesMixinClassPrivate *priv;
};
/* TYPE MACROS */
#define TP_PROPERTIES_MIXIN_CLASS_OFFSET_QUARK \
(tp_properties_mixin_class_get_offset_quark ())
#define TP_PROPERTIES_MIXIN_CLASS_OFFSET(o) \
tp_mixin_class_get_offset (o, TP_PROPERTIES_MIXIN_CLASS_OFFSET_QUARK)
#define TP_PROPERTIES_MIXIN_CLASS(o) \
((TpPropertiesMixinClass *) tp_mixin_offset_cast (o,\
TP_PROPERTIES_MIXIN_CLASS_OFFSET (o)))
#define TP_PROPERTIES_MIXIN_OFFSET_QUARK \
(tp_properties_mixin_get_offset_quark ())
#define TP_PROPERTIES_MIXIN_OFFSET(o) \
tp_mixin_instance_get_offset (o, TP_PROPERTIES_MIXIN_OFFSET_QUARK)
#define TP_PROPERTIES_MIXIN(o) \
((TpPropertiesMixin *) tp_mixin_offset_cast (o, \
TP_PROPERTIES_MIXIN_OFFSET (o)))
/**
* TP_TYPE_PROPERTY_INFO_STRUCT:
*
* The GType of the structures with D-Bus signature '(ussu)' returned by
* ListProperties.
*
* @Deprecated: Since 0.7.0. Use TP_STRUCT_TYPE_PROPERTY_SPEC instead.
*/
#define TP_TYPE_PROPERTY_INFO_STRUCT TP_STRUCT_TYPE_PROPERTY_SPEC
/**
* TP_TYPE_PROPERTY_INFO_LIST:
*
* The GType of the return from ListProperties (i.e. a GPtrArray
* of structures of type TP_TYPE_PROPERTY_INFO_STRUCT), corresponding to
* D-Bus signature 'a(ussu)'.
*
* @Deprecated: Since 0.7.0. Use TP_ARRAY_TYPE_PROPERTY_SPEC_LIST instead.
*/
#define TP_TYPE_PROPERTY_INFO_LIST TP_ARRAY_TYPE_PROPERTY_SPEC_LIST
/**
* TP_TYPE_PROPERTY_VALUE_STRUCT:
*
* The GType of the structures with signature '(uv)' returned by
* GetProperties and emitted in PropertiesChanged.
*
* @Deprecated: Since 0.7.0. Use TP_STRUCT_TYPE_PROPERTY_VALUE instead.
*/
#define TP_TYPE_PROPERTY_VALUE_STRUCT TP_STRUCT_TYPE_PROPERTY_VALUE
/**
* TP_TYPE_PROPERTY_VALUE_LIST
*
* The GType of the return from GetProperties and the parameter to
* PropertiesChanged (i.e. a GPtrArray of structures of type
* TP_TYPE_PROPERTY_VALUE_STRUCT), corresponding to D-Bus signature 'a(uv)'.
*
* @Deprecated: Since 0.7.0. Use TP_ARRAY_TYPE_PROPERTY_VALUE_LIST instead.
*/
#define TP_TYPE_PROPERTY_VALUE_LIST TP_ARRAY_TYPE_PROPERTY_VALUE_LIST
/**
* TP_TYPE_PROPERTY_FLAGS_STRUCT:
*
* The GType of the structures with D-Bus signature '(uu)' emitted in
* PropertyFlagsChanged.
*
* @Deprecated: Since 0.7.0. Use TP_STRUCT_TYPE_PROPERTY_FLAGS_CHANGE instead.
*/
#define TP_TYPE_PROPERTY_FLAGS_STRUCT TP_STRUCT_TYPE_PROPERTY_FLAGS_CHANGE
/**
* TP_TYPE_PROPERTY_FLAGS_LIST
*
* The GType of the parameter to PropertyFlagsChanged (i.e. a GPtrArray of
* structures of type TP_TYPE_PROPERTY_FLAGS_STRUCT), corresponding to
* D-Bus signature 'a(uu)'.
*
* @Deprecated: Since 0.7.0. Use TP_ARRAY_TYPE_PROPERTY_FLAGS_CHANGE_LIST
* instead.
*/
#define TP_TYPE_PROPERTY_FLAGS_LIST TP_ARRAY_TYPE_PROPERTY_FLAGS_CHANGE_LIST
GQuark tp_properties_mixin_class_get_offset_quark (void);
GQuark tp_properties_mixin_get_offset_quark (void);
void tp_properties_mixin_class_init (GObjectClass *obj_cls, glong offset,
const TpPropertySignature *signatures, guint num_properties,
TpPropertiesSetFunc set_func);
void tp_properties_mixin_init (GObject *obj, glong offset);
void tp_properties_mixin_finalize (GObject *obj);
gboolean tp_properties_mixin_list_properties (GObject *obj, GPtrArray **ret,
GError **error);
gboolean tp_properties_mixin_get_properties (GObject *obj,
const GArray *properties, GPtrArray **ret, GError **error);
void tp_properties_mixin_set_properties (GObject *obj,
const GPtrArray *properties, DBusGMethodInvocation *context);
gboolean tp_properties_mixin_has_property (GObject *obj, const gchar *name,
guint *property);
gboolean tp_properties_context_has (TpPropertiesContext *ctx, guint property);
gboolean tp_properties_context_has_other_than (TpPropertiesContext *ctx,
guint property);
const GValue *tp_properties_context_get (TpPropertiesContext *ctx,
guint property);
guint tp_properties_context_get_value_count (TpPropertiesContext *ctx);
void tp_properties_context_remove (TpPropertiesContext *ctx, guint property);
void tp_properties_context_return (TpPropertiesContext *ctx, GError *error);
gboolean tp_properties_context_return_if_done (TpPropertiesContext *ctx);
void tp_properties_mixin_change_value (GObject *obj, guint prop_id,
const GValue *new_value, TpIntset *props);
void tp_properties_mixin_change_flags (GObject *obj, guint prop_id,
TpPropertyFlags add, TpPropertyFlags del, TpIntset *props);
void tp_properties_mixin_emit_changed (GObject *obj, const TpIntset *props);
void tp_properties_mixin_emit_flags (GObject *obj, const TpIntset *props);
gboolean tp_properties_mixin_is_readable (GObject *obj, guint prop_id);
gboolean tp_properties_mixin_is_writable (GObject *obj, guint prop_id);
void tp_properties_mixin_iface_init (gpointer g_iface, gpointer iface_data);
G_END_DECLS
#endif /* #ifndef __TP_PROPERTIES_MIXIN_H__ */
|