From d0c6f66e03793c19c034c26c1267f9382167b3ad Mon Sep 17 00:00:00 2001 From: Lennart Poettering Date: Sat, 20 Aug 2005 17:44:43 +0000 Subject: * complete error handling in avahi-client git-svn-id: file:///home/lennart/svn/public/avahi/trunk@362 941a03a8-eaeb-0310-b9a0-b1bbd8fe43fe --- avahi-client/browser.c | 647 +++++++++++++++++++++++++++++++------------------ 1 file changed, 413 insertions(+), 234 deletions(-) (limited to 'avahi-client/browser.c') diff --git a/avahi-client/browser.c b/avahi-client/browser.c index dfc70f1..5de4824 100644 --- a/avahi-client/browser.c +++ b/avahi-client/browser.c @@ -38,380 +38,559 @@ #include "client.h" #include "internal.h" -/* AvahiDomainBrowser */ +static int simple_method_call(AvahiClient *client, const char *path, const char *interface, const char *method) { + DBusMessage *message = NULL, *reply = NULL; + DBusError error; + int r = AVAHI_OK; + + dbus_error_init(&error); + + assert(client); + assert(path); + assert(interface); + assert(method); + + if (!(message = dbus_message_new_method_call(AVAHI_DBUS_NAME, path, interface, method))) { + r = avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } + + if (!(reply = dbus_connection_send_with_reply_and_block(client->bus, message, -1, &error)) || + dbus_error_is_set (&error)) { + r = avahi_client_set_errno(client, AVAHI_ERR_DBUS_ERROR); + goto fail; + } + + if (!dbus_message_get_args(reply, &error, DBUS_TYPE_INVALID) || + dbus_error_is_set (&error)) { + r = avahi_client_set_errno(client, AVAHI_ERR_DBUS_ERROR); + goto fail; + } + + dbus_message_unref(message); + dbus_message_unref(reply); + + return AVAHI_OK; + +fail: + if (dbus_error_is_set(&error)) { + r = avahi_client_set_dbus_error(client, &error); + dbus_error_free(&error); + } + + if (message) + dbus_message_unref(message); + + if (reply) + dbus_message_unref(reply); + + return r; +} -AvahiDomainBrowser* avahi_domain_browser_new (AvahiClient *client, AvahiIfIndex interface, AvahiProtocol protocol, const char *domain, AvahiDomainBrowserType btype, AvahiDomainBrowserCallback callback, void *userdata) -{ - AvahiDomainBrowser *tmp = NULL; +AvahiDomainBrowser* avahi_domain_browser_new( + AvahiClient *client, + AvahiIfIndex interface, + AvahiProtocol protocol, + const char *domain, + AvahiDomainBrowserType btype, + AvahiDomainBrowserCallback callback, + void *userdata) { + + AvahiDomainBrowser *db = NULL; DBusMessage *message = NULL, *reply; DBusError error; char *path; + int32_t i_interface, i_protocol, bt; - if (client == NULL) - return NULL; + assert(client); + assert(callback); dbus_error_init (&error); - message = dbus_message_new_method_call (AVAHI_DBUS_NAME, AVAHI_DBUS_PATH_SERVER, - AVAHI_DBUS_INTERFACE_SERVER, "DomainBrowserNew"); + if (client->state == AVAHI_CLIENT_DISCONNECTED) { + avahi_client_set_errno(client, AVAHI_ERR_BAD_STATE); + goto fail; + } - if (!dbus_message_append_args (message, DBUS_TYPE_INT32, &interface, DBUS_TYPE_INT32, &protocol, DBUS_TYPE_STRING, &domain, DBUS_TYPE_INT32, &btype, DBUS_TYPE_INVALID)) - goto dbus_error; + if (!domain) + domain = ""; - reply = dbus_connection_send_with_reply_and_block (client->bus, message, -1, &error); + if (!(db = avahi_new (AvahiDomainBrowser, 1))) { + avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } - if (dbus_error_is_set (&error) || reply == NULL) - goto dbus_error; + db->client = client; + db->callback = callback; + db->userdata = userdata; + db->path = NULL; - if (!dbus_message_get_args (reply, &error, DBUS_TYPE_OBJECT_PATH, &path, DBUS_TYPE_INVALID)) - goto dbus_error; + AVAHI_LLIST_PREPEND(AvahiDomainBrowser, domain_browsers, client->domain_browsers, db); - if (dbus_error_is_set (&error) || path == NULL) - goto dbus_error; + if (!(message = dbus_message_new_method_call (AVAHI_DBUS_NAME, AVAHI_DBUS_PATH_SERVER, AVAHI_DBUS_INTERFACE_SERVER, "DomainBrowserNew"))) { + avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } - tmp = avahi_new (AvahiDomainBrowser, 1); - tmp->client = client; - tmp->callback = callback; - tmp->userdata = userdata; - tmp->path = strdup (path); + i_interface = interface; + i_protocol = protocol; + bt = btype; + + if (!(dbus_message_append_args( + message, + DBUS_TYPE_INT32, &i_interface, + DBUS_TYPE_INT32, &i_protocol, + DBUS_TYPE_STRING, &domain, + DBUS_TYPE_INT32, &bt, + DBUS_TYPE_INVALID))) { + avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } - AVAHI_LLIST_PREPEND(AvahiDomainBrowser, domain_browsers, client->domain_browsers, tmp); + if (!(reply = dbus_connection_send_with_reply_and_block (client->bus, message, -1, &error)) || + dbus_error_is_set(&error)) { + avahi_client_set_errno(client, AVAHI_ERR_DBUS_ERROR); + goto fail; + } - return tmp; + if (!dbus_message_get_args (reply, &error, DBUS_TYPE_OBJECT_PATH, &path, DBUS_TYPE_INVALID) || + dbus_error_is_set(&error) || + !path) { + avahi_client_set_errno(client, AVAHI_ERR_DBUS_ERROR); + goto fail; + } -dbus_error: - dbus_error_free (&error); - avahi_client_set_errno (client, AVAHI_ERR_DBUS_ERROR); + if (!(db->path = avahi_strdup(path))) { - return NULL; -} + /* FIXME: We don't remove the object on the server side */ -int -avahi_domain_browser_free (AvahiDomainBrowser *b) -{ - AvahiClient *client = b->client; - DBusMessage *message = NULL; + avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } - if (b == NULL || b->path == NULL) - return avahi_client_set_errno (client, AVAHI_ERR_INVALID_OBJECT); + dbus_message_unref(message); + dbus_message_unref(reply); + + return db; - message = dbus_message_new_method_call (AVAHI_DBUS_NAME, - b->path, - AVAHI_DBUS_INTERFACE_DOMAIN_BROWSER, "Free"); +fail: - if (message == NULL) - return avahi_client_set_errno (client, AVAHI_ERR_DBUS_ERROR); + if (dbus_error_is_set(&error)) { + avahi_client_set_dbus_error(client, &error); + dbus_error_free(&error); + } - dbus_connection_send (client->bus, message, NULL); + if (db) + avahi_domain_browser_free(db); + + if (message) + dbus_message_unref(message); + + if (reply) + dbus_message_unref(reply); + + return NULL; +} + +int avahi_domain_browser_free (AvahiDomainBrowser *b) { + AvahiClient *client; + int r = AVAHI_OK; + + assert(b); + client = b->client; + + if (b->path && client->state != AVAHI_CLIENT_DISCONNECTED) + r = simple_method_call(client, b->path, AVAHI_DBUS_INTERFACE_DOMAIN_BROWSER, "Free"); AVAHI_LLIST_REMOVE(AvahiDomainBrowser, domain_browsers, client->domain_browsers, b); - avahi_free (b); + avahi_free(b->path); + avahi_free(b); - return avahi_client_set_errno (client, AVAHI_OK); + return r; } -const char* -avahi_domain_browser_path (AvahiDomainBrowser *b) -{ +const char* avahi_domain_browser_get_dbus_path(AvahiDomainBrowser *b) { + assert(b); + return b->path; } -DBusHandlerResult -avahi_domain_browser_event (AvahiClient *client, AvahiBrowserEvent event, DBusMessage *message) -{ - AvahiDomainBrowser *n, *db = NULL; +DBusHandlerResult avahi_domain_browser_event (AvahiClient *client, AvahiBrowserEvent event, DBusMessage *message) { + AvahiDomainBrowser *db = NULL; DBusError error; const char *path; char *domain; - int interface, protocol; + int32_t interface, protocol; + assert(client); + assert(message); + dbus_error_init (&error); - path = dbus_message_get_path (message); - - if (path == NULL) - goto out; + if (!(path = dbus_message_get_path(message))) + goto fail; - for (n = client->domain_browsers; n != NULL; n = n->domain_browsers_next) - { - if (strcmp (n->path, path) == 0) { - db = n; + for (db = client->domain_browsers; db; db = db->domain_browsers_next) + if (strcmp (db->path, path) == 0) break; - } - } - - if (db == NULL) - goto out; - dbus_message_get_args (message, &error, DBUS_TYPE_INT32, &interface, - DBUS_TYPE_INT32, &protocol, DBUS_TYPE_STRING, &domain, DBUS_TYPE_INVALID); - - if (dbus_error_is_set (&error)) - goto out; + if (!db) + goto fail; + + if (!dbus_message_get_args( + message, &error, + DBUS_TYPE_INT32, &interface, + DBUS_TYPE_INT32, &protocol, + DBUS_TYPE_STRING, &domain, + DBUS_TYPE_INVALID) || + dbus_error_is_set (&error)) { + fprintf(stderr, "Failed to parse browser event.\n"); + goto fail; + } - db->callback (db, interface, protocol, event, domain, db->userdata); + db->callback(db, (AvahiIfIndex) interface, (AvahiProtocol) protocol, event, domain, db->userdata); return DBUS_HANDLER_RESULT_HANDLED; -out: +fail: dbus_error_free (&error); return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; } /* AvahiServiceTypeBrowser */ -AvahiServiceTypeBrowser* avahi_service_type_browser_new (AvahiClient *client, AvahiIfIndex interface, AvahiProtocol protocol, const char *domain, AvahiServiceTypeBrowserCallback callback, void *userdata) -{ - AvahiServiceTypeBrowser *tmp = NULL; +AvahiServiceTypeBrowser* avahi_service_type_browser_new( + AvahiClient *client, + AvahiIfIndex interface, + AvahiProtocol protocol, + const char *domain, + AvahiServiceTypeBrowserCallback callback, + void *userdata) { + + AvahiServiceTypeBrowser *b = NULL; DBusMessage *message = NULL, *reply; DBusError error; char *path; + int32_t i_interface, i_protocol; - if (client == NULL) - return NULL; + assert(client); + assert(callback); - dbus_error_init (&error); + dbus_error_init(&error); - message = dbus_message_new_method_call (AVAHI_DBUS_NAME, - AVAHI_DBUS_PATH_SERVER, - AVAHI_DBUS_INTERFACE_SERVER, - "ServiceTypeBrowserNew"); + if (client->state == AVAHI_CLIENT_DISCONNECTED) { + avahi_client_set_errno(client, AVAHI_ERR_BAD_STATE); + goto fail; + } - if (!dbus_message_append_args (message, DBUS_TYPE_INT32, &interface, DBUS_TYPE_INT32, &protocol, DBUS_TYPE_STRING, &domain, DBUS_TYPE_INVALID)) - goto dbus_error; + if (!domain) + domain = ""; - reply = dbus_connection_send_with_reply_and_block (client->bus, message, -1, &error); + if (!(b = avahi_new(AvahiServiceTypeBrowser, 1))) { + avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } - if (dbus_error_is_set (&error) || reply == NULL) - goto dbus_error; + b->client = client; + b->callback = callback; + b->userdata = userdata; + b->path = NULL; - if (!dbus_message_get_args (reply, &error, DBUS_TYPE_OBJECT_PATH, &path, DBUS_TYPE_INVALID)) - goto dbus_error; + AVAHI_LLIST_PREPEND(AvahiServiceTypeBrowser, service_type_browsers, client->service_type_browsers, b); - if (dbus_error_is_set (&error) || path == NULL) - goto dbus_error; + if (!(message = dbus_message_new_method_call (AVAHI_DBUS_NAME, AVAHI_DBUS_PATH_SERVER, AVAHI_DBUS_INTERFACE_SERVER, "ServiceTypeBrowserNew"))) { + avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } + + i_interface = interface; + i_protocol = protocol; - tmp = avahi_new(AvahiServiceTypeBrowser, 1); - tmp->client = client; - tmp->callback = callback; - tmp->userdata = userdata; - tmp->path = strdup (path); + if (!dbus_message_append_args( + message, + DBUS_TYPE_INT32, &interface, + DBUS_TYPE_INT32, &protocol, + DBUS_TYPE_STRING, &domain, + DBUS_TYPE_INVALID)) { + avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } - AVAHI_LLIST_PREPEND(AvahiServiceTypeBrowser, service_type_browsers, client->service_type_browsers, tmp); + if (!(reply = dbus_connection_send_with_reply_and_block (client->bus, message, -1, &error)) || + dbus_error_is_set(&error)) { + avahi_client_set_errno(client, AVAHI_ERR_DBUS_ERROR); + goto fail; + } - return tmp; + if (!dbus_message_get_args (reply, &error, DBUS_TYPE_OBJECT_PATH, &path, DBUS_TYPE_INVALID) || + dbus_error_is_set(&error) || + !path) { + avahi_client_set_errno(client, AVAHI_ERR_DBUS_ERROR); + goto fail; + } -dbus_error: - dbus_error_free (&error); - avahi_client_set_errno (client, AVAHI_ERR_DBUS_ERROR); + if (!(b->path = avahi_strdup(path))) { - return NULL; -} + /* FIXME: We don't remove the object on the server side */ -int -avahi_service_type_browser_free (AvahiServiceTypeBrowser *b) -{ - AvahiClient *client = b->client; - DBusMessage *message = NULL; + avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } - if (b == NULL || b->path == NULL) - return avahi_client_set_errno (client, AVAHI_ERR_INVALID_OBJECT); + dbus_message_unref(message); + dbus_message_unref(reply); - message = dbus_message_new_method_call (AVAHI_DBUS_NAME, - b->path, - AVAHI_DBUS_INTERFACE_SERVICE_TYPE_BROWSER, "Free"); + return b; - if (message == NULL) - return avahi_client_set_errno (client, AVAHI_ERR_DBUS_ERROR); +fail: + + if (dbus_error_is_set(&error)) { + avahi_client_set_dbus_error(client, &error); + dbus_error_free(&error); + } - dbus_connection_send (b->client->bus, message, NULL); + if (b) + avahi_service_type_browser_free(b); + + if (message) + dbus_message_unref(message); - AVAHI_LLIST_REMOVE(AvahiServiceTypeBrowser, service_type_browsers, b->client->service_type_browsers, b); + if (reply) + dbus_message_unref(reply); + + return NULL; +} + +int avahi_service_type_browser_free (AvahiServiceTypeBrowser *b) { + AvahiClient *client; + int r = AVAHI_OK; - avahi_free (b); + assert(b); + client = b->client; - return avahi_client_set_errno (client, AVAHI_OK); + if (b->path && client->state != AVAHI_CLIENT_DISCONNECTED) + r = simple_method_call(client, b->path, AVAHI_DBUS_INTERFACE_SERVICE_TYPE_BROWSER, "Free"); + + AVAHI_LLIST_REMOVE(AvahiServiceTypeBrowser, service_type_browsers, b->client->service_type_browsers, b); + + avahi_free(b->path); + avahi_free(b); + return r; } -const char* -avahi_service_type_browser_path (AvahiServiceTypeBrowser *b) -{ +const char* avahi_service_type_browser_get_dbus_path(AvahiServiceTypeBrowser *b) { + assert(b); + return b->path; } -DBusHandlerResult -avahi_service_type_browser_event (AvahiClient *client, AvahiBrowserEvent event, DBusMessage *message) -{ - AvahiServiceTypeBrowser *n, *db = NULL; +DBusHandlerResult avahi_service_type_browser_event (AvahiClient *client, AvahiBrowserEvent event, DBusMessage *message) { + AvahiServiceTypeBrowser *b = NULL; DBusError error; const char *path; char *domain, *type; - int interface, protocol; + int32_t interface, protocol; + assert(client); + assert(message); + dbus_error_init (&error); - path = dbus_message_get_path (message); - - if (path == NULL) - goto out; + if (!(path = dbus_message_get_path(message))) + goto fail; - for (n = client->service_type_browsers; n != NULL; n = n->service_type_browsers_next) - { - if (strcmp (n->path, path) == 0) { - db = n; + for (b = client->service_type_browsers; b; b = b->service_type_browsers_next) + if (strcmp (b->path, path) == 0) break; - } - } - if (db == NULL) - goto out; - - dbus_message_get_args (message, &error, - DBUS_TYPE_INT32, &interface, - DBUS_TYPE_INT32, &protocol, - DBUS_TYPE_STRING, &type, - DBUS_TYPE_STRING, &domain, - DBUS_TYPE_INVALID); - - if (dbus_error_is_set (&error)) - goto out; + if (!b) + goto fail; + + if (!dbus_message_get_args( + message, &error, + DBUS_TYPE_INT32, &interface, + DBUS_TYPE_INT32, &protocol, + DBUS_TYPE_STRING, &type, + DBUS_TYPE_STRING, &domain, + DBUS_TYPE_INVALID) || + dbus_error_is_set(&error)) { + fprintf(stderr, "Failed to parse browser event.\n"); + goto fail; + } - db->callback (db, interface, protocol, event, type, domain, db->userdata); + b->callback(b, (AvahiIfIndex) interface, (AvahiProtocol) protocol, event, type, domain, b->userdata); return DBUS_HANDLER_RESULT_HANDLED; -out: +fail: dbus_error_free (&error); return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; } /* AvahiServiceBrowser */ -AvahiServiceBrowser* avahi_service_browser_new (AvahiClient *client, AvahiIfIndex interface, AvahiProtocol protocol, const char *type, const char *domain, AvahiServiceBrowserCallback callback, void *userdata) -{ - AvahiServiceBrowser *tmp = NULL; +AvahiServiceBrowser* avahi_service_browser_new( + AvahiClient *client, + AvahiIfIndex interface, + AvahiProtocol protocol, + const char *type, + const char *domain, + AvahiServiceBrowserCallback callback, + void *userdata) { + + AvahiServiceBrowser *b = NULL; DBusMessage *message = NULL, *reply; DBusError error; char *path; + int32_t i_protocol, i_interface; - if (client == NULL) - return NULL; + assert(client); + assert(type); + assert(callback); - dbus_error_init (&error); + dbus_error_init(&error); + + if (client->state == AVAHI_CLIENT_DISCONNECTED) { + avahi_client_set_errno(client, AVAHI_ERR_BAD_STATE); + goto fail; + } + + if (!domain) + domain = ""; + + if (!(b = avahi_new(AvahiServiceBrowser, 1))) { + avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } + + b->client = client; + b->callback = callback; + b->userdata = userdata; + b->path = NULL; - message = dbus_message_new_method_call (AVAHI_DBUS_NAME, AVAHI_DBUS_PATH_SERVER, - AVAHI_DBUS_INTERFACE_SERVER, "ServiceBrowserNew"); + AVAHI_LLIST_PREPEND(AvahiServiceBrowser, service_browsers, client->service_browsers, b); - if (!dbus_message_append_args (message, - DBUS_TYPE_INT32, &interface, - DBUS_TYPE_INT32, &protocol, - DBUS_TYPE_STRING, &type, - DBUS_TYPE_STRING, &domain, - DBUS_TYPE_INVALID)) - goto dbus_error; + if (!(message = dbus_message_new_method_call (AVAHI_DBUS_NAME, AVAHI_DBUS_PATH_SERVER, AVAHI_DBUS_INTERFACE_SERVER, "ServiceBrowserNew"))) { + avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } - reply = dbus_connection_send_with_reply_and_block (client->bus, message, -1, &error); + i_interface = interface; + i_protocol = protocol; + - if (dbus_error_is_set (&error) || reply == NULL) - goto dbus_error; + if (!dbus_message_append_args( + message, + DBUS_TYPE_INT32, &i_interface, + DBUS_TYPE_INT32, &i_protocol, + DBUS_TYPE_STRING, &type, + DBUS_TYPE_STRING, &domain, + DBUS_TYPE_INVALID)) { + avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } - if (!dbus_message_get_args (reply, &error, DBUS_TYPE_OBJECT_PATH, &path, DBUS_TYPE_INVALID)) - goto dbus_error; + if (!(reply = dbus_connection_send_with_reply_and_block (client->bus, message, -1, &error)) || + dbus_error_is_set(&error)) { + avahi_client_set_errno(client, AVAHI_ERR_DBUS_ERROR); + goto fail; + } - if (dbus_error_is_set (&error) || path == NULL) - goto dbus_error; + if (!dbus_message_get_args (reply, &error, DBUS_TYPE_OBJECT_PATH, &path, DBUS_TYPE_INVALID) || + dbus_error_is_set(&error) || + !path) { + avahi_client_set_errno(client, AVAHI_ERR_DBUS_ERROR); + goto fail; + } - tmp = avahi_new(AvahiServiceBrowser, 1); - tmp->client = client; - tmp->callback = callback; - tmp->userdata = userdata; - tmp->path = strdup (path); + if (!(b->path = avahi_strdup(path))) { - AVAHI_LLIST_PREPEND(AvahiServiceBrowser, service_browsers, client->service_browsers, tmp); + /* FIXME: We don't remove the object on the server side */ - return tmp; + avahi_client_set_errno(client, AVAHI_ERR_NO_MEMORY); + goto fail; + } -dbus_error: - dbus_error_free (&error); - avahi_client_set_errno (client, AVAHI_ERR_DBUS_ERROR); + dbus_message_unref(message); + dbus_message_unref(reply); + + return b; + +fail: + if (dbus_error_is_set(&error)) { + avahi_client_set_dbus_error(client, &error); + dbus_error_free(&error); + } + + if (b) + avahi_service_browser_free(b); + + if (message) + dbus_message_unref(message); + + if (reply) + dbus_message_unref(reply); return NULL; } -int -avahi_service_browser_free (AvahiServiceBrowser *b) -{ - AvahiClient *client = b->client; - DBusMessage *message = NULL; - - if (b == NULL || b->path == NULL) - return avahi_client_set_errno (client, AVAHI_ERR_INVALID_OBJECT); +int avahi_service_browser_free (AvahiServiceBrowser *b) { + AvahiClient *client; + int r = AVAHI_OK; - message = dbus_message_new_method_call (AVAHI_DBUS_NAME, - b->path, - AVAHI_DBUS_INTERFACE_SERVICE_BROWSER, "Free"); + assert(b); + client = b->client; - if (message == NULL) - return avahi_client_set_errno (client, AVAHI_ERR_DBUS_ERROR); - - dbus_connection_send (b->client->bus, message, NULL); + if (b->path && client->state != AVAHI_CLIENT_DISCONNECTED) + r = simple_method_call(client, b->path, AVAHI_DBUS_INTERFACE_SERVICE_BROWSER, "Free"); AVAHI_LLIST_REMOVE(AvahiServiceBrowser, service_browsers, b->client->service_browsers, b); - avahi_free (b); - - return avahi_client_set_errno (client, AVAHI_OK); + avahi_free(b->path); + avahi_free(b); + return r; } -const char* -avahi_service_browser_path (AvahiServiceBrowser *b) -{ +const char* avahi_service_browser_get_dbus_path(AvahiServiceBrowser *b) { + assert(b); + return b->path; } -DBusHandlerResult -avahi_service_browser_event (AvahiClient *client, AvahiBrowserEvent event, DBusMessage *message) -{ - AvahiServiceBrowser *n, *db = NULL; +DBusHandlerResult avahi_service_browser_event (AvahiClient *client, AvahiBrowserEvent event, DBusMessage *message) { + AvahiServiceBrowser *b = NULL; DBusError error; const char *path; char *name, *type, *domain; - int interface, protocol; + int32_t interface, protocol; dbus_error_init (&error); - path = dbus_message_get_path (message); - - if (path == NULL) - goto out; + if (!(path = dbus_message_get_path(message))) + goto fail; - for (n = client->service_browsers; n != NULL; n = n->service_browsers_next) - { - if (strcmp (n->path, path) == 0) { - db = n; + for (b = client->service_browsers; b; b = b->service_browsers_next) + if (strcmp (b->path, path) == 0) break; - } - } - if (db == NULL) - goto out; - - dbus_message_get_args (message, &error, - DBUS_TYPE_INT32, &interface, - DBUS_TYPE_INT32, &protocol, - DBUS_TYPE_STRING, &name, - DBUS_TYPE_STRING, &type, - DBUS_TYPE_STRING, &domain, - DBUS_TYPE_INVALID); - - if (dbus_error_is_set (&error)) - goto out; + if (!dbus_message_get_args ( + message, &error, + DBUS_TYPE_INT32, &interface, + DBUS_TYPE_INT32, &protocol, + DBUS_TYPE_STRING, &name, + DBUS_TYPE_STRING, &type, + DBUS_TYPE_STRING, &domain, + DBUS_TYPE_INVALID) || + dbus_error_is_set(&error)) { + fprintf(stderr, "Failed to parse browser event.\n"); + goto fail; + } - db->callback (db, interface, protocol, event, name, type, domain, db->userdata); + b->callback(b, (AvahiIfIndex) interface, (AvahiProtocol) protocol, event, name, type, domain, b->userdata); return DBUS_HANDLER_RESULT_HANDLED; -out: +fail: dbus_error_free (&error); return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; } -- cgit