telepathy-glib Reference Manual | ||||
---|---|---|---|---|
#include <telepathy-glib/proxy.h> TpProxy; TpProxyClass; #define tp_proxy_has_interface (self, interface) gboolean tp_proxy_has_interface_by_id (gpointer self, GQuark interface); TpProxyPendingCall; void tp_proxy_pending_call_cancel (TpProxyPendingCall *pc); TpProxySignalConnection; void tp_proxy_signal_connection_disconnect (TpProxySignalConnection *sc); TpDBusDaemon* tp_proxy_get_dbus_daemon (gpointer self); DBusGConnection* tp_proxy_get_dbus_connection (gpointer self); const gchar* tp_proxy_get_bus_name (gpointer self); const gchar* tp_proxy_get_object_path (gpointer self); const GError* tp_proxy_get_invalidated (gpointer self); void tp_proxy_dbus_error_to_gerror (gpointer self, const char *dbus_error, const char *debug_message, GError **error); #define TP_DBUS_ERRORS enum TpDBusError;
GObject +----TpProxy +----TpAccount +----TpAccountManager +----TpChannel +----TpChannelDispatcher +----TpChannelDispatchOperation +----TpChannelRequest +----TpClient +----TpConnection +----TpConnectionManager +----TpDBusDaemon +----TpMediaSessionHandler +----TpMediaStreamHandler
"bus-name" gchar* : Read / Write / Construct Only "dbus-connection" DBusGConnection* : Read / Write / Construct Only "dbus-daemon" TpDBusDaemon* : Read / Write / Construct Only "interfaces" GStrv* : Read "object-path" gchar* : Read / Write / Construct Only
TpProxy is a base class for Telepathy client-side proxies, which represent an object accessed via D-Bus and provide access to its methods and signals.
typedef struct _TpProxy TpProxy;
Structure representing a Telepathy client-side proxy.
Since 0.7.1
typedef struct { GObjectClass parent_class; GQuark interface; unsigned int must_have_unique_name:1; guint _reserved_flags:31; GCallback _reserved[4]; gpointer priv; } TpProxyClass;
The class of a TpProxy.
GObjectClass parent_class ; |
The parent class structure |
GQuark interface ; |
If set non-zero by a subclass, TpProxy will automatically add this interface in its constructor |
unsigned int must_have_unique_name :1; |
If set TRUE by a subclass, the TpProxy
constructor will fail if a well-known bus name is given
|
guint _reserved_flags :31; |
Reserved for future expansion |
GCallback _reserved [4]; |
Reserved for future expansion |
gpointer priv ; |
Opaque pointer for private data |
Since 0.7.1
#define tp_proxy_has_interface(self, interface)
A macro wrapping tp_proxy_has_interface_by_id()
. Returns TRUE
if this
proxy implements the given interface.
self : |
the TpProxy (or subclass) |
interface : |
the interface required, as a string |
Since 0.7.1
gboolean tp_proxy_has_interface_by_id (gpointer self, GQuark interface);
self : |
the TpProxy (or subclass) |
interface : |
quark representing the interface required |
Returns : | TRUE if this proxy implements the given interface.
|
Since 0.7.1
typedef struct _TpProxyPendingCall TpProxyPendingCall;
Opaque structure representing a pending D-Bus call.
Since 0.7.1
void tp_proxy_pending_call_cancel (TpProxyPendingCall *pc);
Cancel the given pending call. After this function returns, you must not assume that the pending call remains valid, but you must not explicitly free it either.
pc : |
a pending call |
Since 0.7.1
typedef struct _TpProxySignalConnection TpProxySignalConnection;
Opaque structure representing a D-Bus signal connection.
Since 0.7.1
void tp_proxy_signal_connection_disconnect (TpProxySignalConnection *sc);
Disconnect the given signal connection. After this function returns, you must not assume that the signal connection remains valid, but you must not explicitly free it either.
It is not safe to call this function if sc
has been disconnected already,
which happens in each of these situations:
weak_object
used when sc
was created has been
destroyed
sc : |
a signal connection |
Since 0.7.1
TpDBusDaemon* tp_proxy_get_dbus_daemon (gpointer self);
self : |
a TpProxy or subclass |
Returns : | a borrowed reference to the TpDBusDaemon for this object, if any;
always NULL if this object is itself a TpDBusDaemon. The caller must
reference the returned object with g_object_ref() if it will be kept.
|
Since 0.7.17
DBusGConnection* tp_proxy_get_dbus_connection (gpointer self);
self : |
a TpProxy or subclass |
Returns : | a borrowed reference to the D-Bus connection used by this object.
The caller must reference the returned pointer with
dbus_g_connection_ref() if it will be kept.
|
Since 0.7.17
const gchar* tp_proxy_get_bus_name (gpointer self);
self : |
a TpProxy or subclass |
Returns : | the bus name of the application exporting the object. The caller
must copy the string with g_strdup() if it will be kept.
|
Since 0.7.17
const gchar* tp_proxy_get_object_path (gpointer self);
self : |
a TpProxy or subclass |
Returns : | the object path of the remote object. The caller must copy the
string with g_strdup() if it will be kept.
|
Since 0.7.17
const GError* tp_proxy_get_invalidated (gpointer self);
self : |
a TpProxy or subclass |
Returns : | the reason this proxy was invalidated, or NULL if has not been
invalidated. The caller must copy the error, for instance with
g_error_copy() , if it will be kept.
|
Since 0.7.17
void tp_proxy_dbus_error_to_gerror (gpointer self, const char *dbus_error, const char *debug_message, GError **error);
Convert a D-Bus error name into a GError as if it was returned by a method on this proxy. This method is useful when D-Bus error names are emitted in signals, such as Connection.ConnectionError and Group.MembersChangedDetailed.
self : |
a TpProxy or subclass |
dbus_error : |
a D-Bus error name, for instance from the callback for
tp_cli_connection_connect_to_connection_error()
|
debug_message : |
a debug message that accompanied the error name, or NULL
|
error : |
used to return the corresponding GError |
Since 0.7.24
#define TP_DBUS_ERRORS (tp_dbus_errors_quark ())
GError domain representing D-Bus errors not directly related to
Telepathy, for use by TpProxy. The code
in a GError with this
domain must be a member of TpDBusError.
This macro expands to a function call returning a GQuark.
Since 0.7.1
typedef enum { TP_DBUS_ERROR_UNKNOWN_REMOTE_ERROR = 0, TP_DBUS_ERROR_PROXY_UNREFERENCED = 1, TP_DBUS_ERROR_NO_INTERFACE = 2, TP_DBUS_ERROR_NAME_OWNER_LOST = 3, TP_DBUS_ERROR_INVALID_BUS_NAME = 4, TP_DBUS_ERROR_INVALID_INTERFACE_NAME = 5, TP_DBUS_ERROR_INVALID_OBJECT_PATH = 6, TP_DBUS_ERROR_INVALID_MEMBER_NAME = 7, TP_DBUS_ERROR_OBJECT_REMOVED = 8, TP_DBUS_ERROR_CANCELLED = 9, TP_DBUS_ERROR_INCONSISTENT = 10, NUM_TP_DBUS_ERRORS } TpDBusError;
GError codes for use with the TP_DBUS_ERRORS
domain.
TP_DBUS_ERROR_UNKNOWN_REMOTE_ERROR
|
Raised if the error raised by a remote D-Bus object is not recognised |
TP_DBUS_ERROR_PROXY_UNREFERENCED
|
Emitted in "invalidated" when the TpProxy has lost its last reference |
TP_DBUS_ERROR_NO_INTERFACE
|
Raised by TpProxy methods if the remote object does not appear to have the required interface |
TP_DBUS_ERROR_NAME_OWNER_LOST
|
Emitted in "invalidated" if the remote process loses ownership of its bus name, and raised by any TpProxy methods that have not had a reply at that time or are called after the proxy becomes invalid in this way (usually meaning it crashed) |
TP_DBUS_ERROR_INVALID_BUS_NAME
|
Raised if a D-Bus bus name given is not valid, or is of an unacceptable type (e.g. well-known vs. unique) |
TP_DBUS_ERROR_INVALID_INTERFACE_NAME
|
Raised if a D-Bus interface or error name given is not valid |
TP_DBUS_ERROR_INVALID_OBJECT_PATH
|
Raised if a D-Bus object path given is not valid |
TP_DBUS_ERROR_INVALID_MEMBER_NAME
|
Raised if a D-Bus method or signal name given is not valid |
TP_DBUS_ERROR_OBJECT_REMOVED
|
A generic error which can be used with "invalidated" to indicate an application-specific indication that the remote object no longer exists, if no more specific error is available. |
TP_DBUS_ERROR_CANCELLED
|
Raised from calls that re-enter the main loop (*_run_*) if they are cancelled |
TP_DBUS_ERROR_INCONSISTENT
|
Raised if information received from a remote object is inconsistent or otherwise obviously wrong (added in 0.7.17) |
NUM_TP_DBUS_ERRORS
|
1 more than the highest valid TpDBusError at the time of compilation |
Since 0.7.1
"bus-name"
property"bus-name" gchar* : Read / Write / Construct Only
The D-Bus bus name for this object. Read-only except during construction.
Default value: NULL
"dbus-connection"
property"dbus-connection" DBusGConnection* : Read / Write / Construct Only
The D-Bus connection for this object. Read-only except during construction.
"dbus-daemon"
property"dbus-daemon" TpDBusDaemon* : Read / Write / Construct Only
The D-Bus daemon for this object (this object itself, if it is a TpDBusDaemon). Read-only except during construction.
"interface-added"
signalvoid user_function (TpProxy *self, guint id, DBusGProxy *proxy, gpointer user_data) : Run Last / Has Details
Emitted when this proxy has gained an interface. It is not guaranteed
to be emitted immediately, but will be emitted before the interface is
first used (at the latest: before it's returned from
tp_proxy_borrow_interface_by_id()
, any signal is connected, or any
method is called).
The intended use is to call dbus_g_proxy_add_signals()
. This signal
should only be used by TpProy implementations
self : |
the proxy object |
id : |
the GQuark representing the interface |
proxy : |
the dbus-glib proxy representing the interface |
user_data : |
user data set when the signal handler was connected. |
"invalidated"
signalvoid user_function (TpProxy *self, guint domain, gint code, gchar *message, gpointer user_data) : Run Last / Has Details
Emitted when this proxy has been become invalid for whatever reason. Any more specific signal should be emitted first.
self : |
the proxy object |
domain : |
domain of a GError indicating why this proxy was invalidated |
code : |
error code of a GError indicating why this proxy was invalidated |
message : |
a message associated with the error |
user_data : |
user data set when the signal handler was connected. |