From: Patrik Flykt Date: Wed, 12 Oct 2011 10:56:38 +0000 (+0300) Subject: notifier: Don't unnecessarily report "online" state on disconnect X-Git-Tag: 0.78~143 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=96dc543b4e23be2969db1295518c24317af572d1;p=platform%2Fupstream%2Fconnman.git notifier: Don't unnecessarily report "online" state on disconnect When a service disconnects, don't send an extra 'online' net.connman.Manager.StateChanged signal if another service is still connected. Fixes BMC#23421 --- diff --git a/src/notifier.c b/src/notifier.c index 722f997..332bafb 100644 --- a/src/notifier.c +++ b/src/notifier.c @@ -176,7 +176,7 @@ const char *__connman_notifier_get_state(void) return "offline"; } -static void state_changed(void) +static void state_changed(connman_bool_t connected) { unsigned int count = __connman_notifier_count_connected(); char *state = "offline"; @@ -185,8 +185,12 @@ static void state_changed(void) if (count > 1) return; - if (count > 0) + if (count == 1) { + if (connected == FALSE) + return; + state = "online"; + } connman_dbus_property_changed_basic(CONNMAN_MANAGER_PATH, CONNMAN_MANAGER_INTERFACE, "State", @@ -212,7 +216,7 @@ static void technology_connected(enum connman_service_type type, CONNMAN_MANAGER_INTERFACE, "ConnectedTechnologies", DBUS_TYPE_STRING, __connman_notifier_list_connected, NULL); - state_changed(); + state_changed(connected); } void __connman_notifier_register(enum connman_service_type type)