diff options
author | Matthew Xie <mattx@google.com> | 2011-08-01 10:20:30 -0700 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2011-08-01 10:20:30 -0700 |
commit | 569980c349217e5b128e1a4daa7a1446ffaea2da (patch) | |
tree | e8a1243d97439409e8d59d1b22db7360e670452f /core/jni | |
parent | 7702a5934454bd1665b4c0e5c1e6a805175dcb9c (diff) | |
parent | 3fd36737b3bdf0100045cf46fe98534431c3fd5c (diff) | |
download | frameworks_base-569980c349217e5b128e1a4daa7a1446ffaea2da.zip frameworks_base-569980c349217e5b128e1a4daa7a1446ffaea2da.tar.gz frameworks_base-569980c349217e5b128e1a4daa7a1446ffaea2da.tar.bz2 |
Merge "Change setDevicePropertyNative to no block."
Diffstat (limited to 'core/jni')
-rw-r--r-- | core/jni/android_server_BluetoothService.cpp | 20 |
1 files changed, 7 insertions, 13 deletions
diff --git a/core/jni/android_server_BluetoothService.cpp b/core/jni/android_server_BluetoothService.cpp index 41056fd..819449a 100644 --- a/core/jni/android_server_BluetoothService.cpp +++ b/core/jni/android_server_BluetoothService.cpp @@ -846,14 +846,13 @@ static jboolean setDevicePropertyNative(JNIEnv *env, jobject object, jstring pat LOGV("%s", __FUNCTION__); native_data_t *nat = get_native_data(env, object); if (nat) { - DBusMessage *reply, *msg; + DBusMessage *msg; DBusMessageIter iter; - DBusError err; + dbus_bool_t reply = JNI_FALSE; const char *c_key = env->GetStringUTFChars(key, NULL); const char *c_path = env->GetStringUTFChars(path, NULL); - dbus_error_init(&err); msg = dbus_message_new_method_call(BLUEZ_DBUS_BASE_IFC, c_path, DBUS_DEVICE_IFACE, "SetProperty"); if (!msg) { @@ -867,19 +866,14 @@ static jboolean setDevicePropertyNative(JNIEnv *env, jobject object, jstring pat dbus_message_iter_init_append(msg, &iter); append_variant(&iter, type, value); - reply = dbus_connection_send_with_reply_and_block(nat->conn, msg, -1, &err); + // Asynchronous call - the callbacks come via Device propertyChange + reply = dbus_connection_send_with_reply(nat->conn, msg, NULL, -1); dbus_message_unref(msg); - env->ReleaseStringUTFChars(key, c_key); env->ReleaseStringUTFChars(path, c_path); - if (!reply) { - if (dbus_error_is_set(&err)) { - LOG_AND_FREE_DBUS_ERROR(&err); - } else - LOGE("DBus reply is NULL in function %s", __FUNCTION__); - return JNI_FALSE; - } - return JNI_TRUE; + env->ReleaseStringUTFChars(key, c_key); + + return reply ? JNI_TRUE : JNI_FALSE; } #endif return JNI_FALSE; |