diff options
| -rw-r--r-- | core/java/android/speech/RecognitionService.java | 14 | 
1 files changed, 12 insertions, 2 deletions
| diff --git a/core/java/android/speech/RecognitionService.java b/core/java/android/speech/RecognitionService.java index 75a5ed563600..32b2d8f4baf3 100644 --- a/core/java/android/speech/RecognitionService.java +++ b/core/java/android/speech/RecognitionService.java @@ -68,6 +68,8 @@ public abstract class RecognitionService extends Service {      private static final int MSG_CANCEL = 3; +    private static final int MSG_RESET = 4; +      private final Handler mHandler = new Handler() {          @Override          public void handleMessage(Message msg) { @@ -81,6 +83,10 @@ public abstract class RecognitionService extends Service {                      break;                  case MSG_CANCEL:                      dispatchCancel((IRecognitionListener) msg.obj); +                    break; +                case MSG_RESET: +                    dispatchClearCallback(); +                    break;              }          }      }; @@ -128,6 +134,10 @@ public abstract class RecognitionService extends Service {          }      } +    private void dispatchClearCallback() { +        mCurrentCallback = null; +    } +      private class StartListeningArgs {          public final Intent mIntent; @@ -241,7 +251,7 @@ public abstract class RecognitionService extends Service {           * @param error code is defined in {@link SpeechRecognizer}           */          public void error(int error) throws RemoteException { -            mCurrentCallback = null; +            Message.obtain(mHandler, MSG_RESET).sendToTarget();              mListener.onError(error);          } @@ -278,7 +288,7 @@ public abstract class RecognitionService extends Service {           *        {@link SpeechRecognizer#RESULTS_RECOGNITION} as a parameter           */          public void results(Bundle results) throws RemoteException { -            mCurrentCallback = null; +            Message.obtain(mHandler, MSG_RESET).sendToTarget();              mListener.onResults(results);          } |