2003-08-16 Havoc Pennington <hp@pobox.com>

* dbus/dbus-object-registry.c (add_and_remove_objects): remove
	broken assertion

	* glib/dbus-gproxy.c: some hacking
This commit is contained in:
Havoc Pennington 2003-08-16 21:28:47 +00:00
parent a1b0bd3340
commit 7c3693a53b
5 changed files with 132 additions and 15 deletions

View file

@ -1,3 +1,10 @@
2003-08-16 Havoc Pennington <hp@pobox.com>
* dbus/dbus-object-registry.c (add_and_remove_objects): remove
broken assertion
* glib/dbus-gproxy.c: some hacking
2003-08-15 Havoc Pennington <hp@redhat.com> 2003-08-15 Havoc Pennington <hp@redhat.com>
* dbus/dbus-pending-call.c (dbus_pending_call_block): implement * dbus/dbus-pending-call.c (dbus_pending_call_block): implement

View file

@ -4471,6 +4471,10 @@ _dbus_message_loader_return_buffer (DBusMessageLoader *loader,
* @todo we need to check that the proper named header fields exist * @todo we need to check that the proper named header fields exist
* for each message type. * for each message type.
* *
* @todo If a message has unknown type, we should probably eat it
* right here rather than passing it out to applications. However
* it's not an error to see messages of unknown type.
*
* @param loader the loader. * @param loader the loader.
* @returns #TRUE if we had enough memory to finish. * @returns #TRUE if we had enough memory to finish.
*/ */

View file

@ -1274,7 +1274,6 @@ add_and_remove_objects (DBusObjectRegistry *registry)
interfaces = three_interfaces; interfaces = three_interfaces;
break; break;
} }
_dbus_assert (interfaces != NULL);
if (!_dbus_object_registry_add_and_unlock (registry, if (!_dbus_object_registry_add_and_unlock (registry,
interfaces, interfaces,

View file

@ -30,6 +30,7 @@
struct DBusGProxy struct DBusGProxy
{ {
GStaticMutex lock;
int refcount; int refcount;
DBusConnection *connection; DBusConnection *connection;
char *service; char *service;
@ -37,6 +38,9 @@ struct DBusGProxy
DBusObjectID object_id; DBusObjectID object_id;
}; };
#define LOCK_PROXY(proxy) (g_static_mutex_lock (&(proxy)->lock))
#define UNLOCK_PROXY(proxy) (g_static_mutex_unlock (&(proxy)->lock))
static DBusGProxy* static DBusGProxy*
_dbus_gproxy_new (DBusConnection *connection) _dbus_gproxy_new (DBusConnection *connection)
{ {
@ -48,6 +52,8 @@ _dbus_gproxy_new (DBusConnection *connection)
proxy->connection = connection; proxy->connection = connection;
dbus_connection_ref (connection); dbus_connection_ref (connection);
g_static_mutex_init (&proxy->lock);
return proxy; return proxy;
} }
@ -96,6 +102,8 @@ dbus_gproxy_new_for_service (DBusConnection *connection,
/** /**
* Increment reference count on proxy object. * Increment reference count on proxy object.
* *
* @todo use GAtomic to avoid locking
*
* @param proxy the proxy * @param proxy the proxy
*/ */
void void
@ -103,12 +111,18 @@ dbus_gproxy_ref (DBusGProxy *proxy)
{ {
g_return_if_fail (proxy != NULL); g_return_if_fail (proxy != NULL);
LOCK_PROXY (proxy);
proxy->refcount += 1; proxy->refcount += 1;
UNLOCK_PROXY (proxy);
} }
/** /**
* Decrement reference count on proxy object. * Decrement reference count on proxy object.
* *
* @todo use GAtomic to avoid locking
*
* @param proxy the proxy * @param proxy the proxy
*/ */
void void
@ -116,23 +130,35 @@ dbus_gproxy_unref (DBusGProxy *proxy)
{ {
g_return_if_fail (proxy != NULL); g_return_if_fail (proxy != NULL);
LOCK_PROXY (proxy);
proxy->refcount -= 1; proxy->refcount -= 1;
if (proxy->refcount == 0) if (proxy->refcount == 0)
{ {
UNLOCK_PROXY (proxy);
dbus_connection_unref (proxy->connection); dbus_connection_unref (proxy->connection);
g_free (proxy->interface); g_free (proxy->interface);
g_free (proxy->service); g_free (proxy->service);
g_static_mutex_free (&proxy->lock);
g_free (proxy); g_free (proxy);
} }
else
{
UNLOCK_PROXY (proxy);
}
} }
/** /**
* Invokes a method on a remote interface. This function does not * Invokes a method on a remote interface. This function does not
* block; instead it returns an opaque #DBusGPendingCall object that * block; instead it returns an opaque #DBusPendingCall object that
* tracks the pending call. The method call will not be sent over the * tracks the pending call. The method call will not be sent over the
* wire until the application returns to the main loop, or blocks in * wire until the application returns to the main loop, or blocks in
* dbus_connection_flush() to write out pending data. The call will * dbus_connection_flush() to write out pending data. The call will
* be completed after a timeout, or when a reply is received. * be completed after a timeout, or when a reply is received.
* To collect the results of the call (which may be an error,
* or a reply), use dbus_gproxy_end_call().
* *
* @param proxy a proxy for a remote interface * @param proxy a proxy for a remote interface
* @param method the name of the method to invoke * @param method the name of the method to invoke
@ -141,14 +167,96 @@ dbus_gproxy_unref (DBusGProxy *proxy)
* @returns opaque pending call object * @returns opaque pending call object
* *
*/ */
DBusGPendingCall* DBusPendingCall*
dbus_gproxy_begin_call (DBusGProxy *proxy, dbus_gproxy_begin_call (DBusGProxy *proxy,
const char *method, const char *method,
int first_arg_type, int first_arg_type,
...) ...)
{ {
g_return_val_if_fail (proxy != NULL, NULL);
LOCK_PROXY (proxy);
UNLOCK_PROXY (proxy);
}
/**
* Collects the results of a method call. The method call was normally
* initiated with dbus_gproxy_end_call(). This function will block if
* the results haven't yet been received; use
* dbus_pending_call_set_notify() to be notified asynchronously that a
* pending call has been completed.
*
* If the call results in an error, the error is set as normal for
* GError and the function returns #FALSE.
*
* Otherwise, the "out" parameters and return value of the
* method are stored in the provided varargs list.
* The list should be terminated with DBUS_TYPE_INVALID.
*
* @param proxy a proxy for a remote interface
* @param pending the pending call from dbus_gproxy_begin_call()
* @param error return location for an error
* @param first_arg_type type of first "out" argument
* @returns #FALSE if an error is set
*/
gboolean
dbus_gproxy_end_call (DBusGProxy *proxy,
DBusPendingCall *pending,
GError **error,
int first_arg_type,
...)
{
g_return_val_if_fail (proxy != NULL, FALSE);
LOCK_PROXY (proxy);
UNLOCK_PROXY (proxy);
}
/**
* Sends a message to the interface we're proxying for. Does not
* block or wait for a reply. The message is only actually written out
* when you return to the main loop or block in
* dbus_connection_flush().
*
* The message is modified to be addressed to the target interface.
* That is, a destination service field or whatever is needed
* will be added to the message.
*
* This function adds a reference to the message, so the caller
* still owns its original reference.
*
* @todo fix for sending to interfaces and object IDs
*
* @param proxy a proxy for a remote interface
* @param message the message to address and send
* @param client_serial return location for message's serial, or #NULL
*/
void
dbus_gproxy_send (DBusGProxy *proxy,
DBusMessage *message,
dbus_uint32_t *client_serial)
{
g_return_if_fail (proxy != NULL);
LOCK_PROXY (proxy);
if (proxy->service)
{
if (!dbus_message_set_destination (message, proxy->service))
g_error ("Out of memory\n");
}
if (proxy->interface)
{
/* FIXME */
}
if (!dbus_object_id_is_null (&proxy->object_id))
{
/* FIXME */
}
if (!dbus_connection_send (proxy->connection, message, client_serial))
g_error ("Out of memory\n");
UNLOCK_PROXY (proxy);
} }
/** @} End of DBusGLib public */ /** @} End of DBusGLib public */

View file

@ -34,7 +34,6 @@
G_BEGIN_DECLS G_BEGIN_DECLS
typedef struct DBusGProxy DBusGProxy; typedef struct DBusGProxy DBusGProxy;
typedef struct DBusPendingCall DBusPendingCall;
DBusGProxy* dbus_gproxy_new_for_service (DBusConnection *connection, DBusGProxy* dbus_gproxy_new_for_service (DBusConnection *connection,
const char *service_name, const char *service_name,
@ -60,18 +59,18 @@ DBusPendingCall* dbus_gproxy_begin_call (DBusGProxy *proxy,
const char *method, const char *method,
int first_arg_type, int first_arg_type,
...); ...);
gboolean dbus_gproxy_end_call (DBusGProxy *proxy,
DBusPendingCall *pending,
GError **error,
int first_arg_type,
...);
void dbus_gproxy_oneway_call (DBusGProxy *proxy, void dbus_gproxy_oneway_call (DBusGProxy *proxy,
const char *method, const char *method,
int first_arg_type, int first_arg_type,
...); ...);
gboolean dbus_pending_call_is_complete (DBusPendingCall *call); void dbus_gproxy_send (DBusGProxy *proxy,
void dbus_pending_call_cancel_and_free (DBusPendingCall *call); DBusMessage *message,
gboolean dbus_pending_call_block_and_free (DBusPendingCall *call, dbus_uint32_t *client_serial);
GError **error,
int first_arg_type,
...);
G_END_DECLS G_END_DECLS