summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJerome Poichet <jpoichet@google.com>2014-10-01 22:34:24 +0000
committerAndroid Git Automerger <android-git-automerger@android.com>2014-10-01 22:34:24 +0000
commit8be1828ae9c1f6b423240c97dd93f67ce2120245 (patch)
tree1aa3b3a430a5fab8003120e6f16f4d0d42d0429b
parentd1ac9bd2bd599e9bbefd2143cea4ae886157815c (diff)
parent72079f7f9b644e57169e26597ec7c727786071a1 (diff)
downloadframeworks_base-8be1828ae9c1f6b423240c97dd93f67ce2120245.zip
frameworks_base-8be1828ae9c1f6b423240c97dd93f67ce2120245.tar.gz
frameworks_base-8be1828ae9c1f6b423240c97dd93f67ce2120245.tar.bz2
am 72079f7f: Merge "Make sure cancel is called on tear down." into lmp-dev
* commit '72079f7f9b644e57169e26597ec7c727786071a1': Make sure cancel is called on tear down.
-rw-r--r--core/java/android/speech/RecognitionService.java13
-rw-r--r--core/java/android/speech/SpeechRecognizer.java8
2 files changed, 20 insertions, 1 deletions
diff --git a/core/java/android/speech/RecognitionService.java b/core/java/android/speech/RecognitionService.java
index 32b2d8f..45eb0bf 100644
--- a/core/java/android/speech/RecognitionService.java
+++ b/core/java/android/speech/RecognitionService.java
@@ -91,9 +91,20 @@ public abstract class RecognitionService extends Service {
}
};
- private void dispatchStartListening(Intent intent, IRecognitionListener listener) {
+ private void dispatchStartListening(Intent intent, final IRecognitionListener listener) {
if (mCurrentCallback == null) {
if (DBG) Log.d(TAG, "created new mCurrentCallback, listener = " + listener.asBinder());
+ try {
+ listener.asBinder().linkToDeath(new IBinder.DeathRecipient() {
+ @Override
+ public void binderDied() {
+ mHandler.sendMessage(mHandler.obtainMessage(MSG_CANCEL, listener));
+ }
+ }, 0);
+ } catch (RemoteException re) {
+ Log.e(TAG, "dead listener on startListening");
+ return;
+ }
mCurrentCallback = new Callback(listener);
RecognitionService.this.onStartListening(intent, mCurrentCallback);
} else {
diff --git a/core/java/android/speech/SpeechRecognizer.java b/core/java/android/speech/SpeechRecognizer.java
index 91c3799..88e2ede 100644
--- a/core/java/android/speech/SpeechRecognizer.java
+++ b/core/java/android/speech/SpeechRecognizer.java
@@ -396,6 +396,14 @@ public class SpeechRecognizer {
* Destroys the {@code SpeechRecognizer} object.
*/
public void destroy() {
+ if (mService != null) {
+ try {
+ mService.cancel(mListener);
+ } catch (final RemoteException e) {
+ // Not important
+ }
+ }
+
if (mConnection != null) {
mContext.unbindService(mConnection);
}