Merge "Hold a strong reference to the callback in TextClassifierService" into qt-qpr1-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
8247b5f5a6
@@ -51,7 +51,6 @@ import android.view.textclassifier.TextSelection;
|
||||
|
||||
import com.android.internal.util.Preconditions;
|
||||
|
||||
import java.lang.ref.WeakReference;
|
||||
import java.util.concurrent.ExecutorService;
|
||||
import java.util.concurrent.Executors;
|
||||
|
||||
@@ -431,23 +430,18 @@ public abstract class TextClassifierService extends Service {
|
||||
* Forwards the callback result to a wrapped binder callback.
|
||||
*/
|
||||
private static final class ProxyCallback<T extends Parcelable> implements Callback<T> {
|
||||
private WeakReference<ITextClassifierCallback> mTextClassifierCallback;
|
||||
private ITextClassifierCallback mTextClassifierCallback;
|
||||
|
||||
private ProxyCallback(ITextClassifierCallback textClassifierCallback) {
|
||||
mTextClassifierCallback =
|
||||
new WeakReference<>(Preconditions.checkNotNull(textClassifierCallback));
|
||||
mTextClassifierCallback = Preconditions.checkNotNull(textClassifierCallback);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onSuccess(T result) {
|
||||
ITextClassifierCallback callback = mTextClassifierCallback.get();
|
||||
if (callback == null) {
|
||||
return;
|
||||
}
|
||||
try {
|
||||
Bundle bundle = new Bundle(1);
|
||||
bundle.putParcelable(KEY_RESULT, result);
|
||||
callback.onSuccess(bundle);
|
||||
mTextClassifierCallback.onSuccess(bundle);
|
||||
} catch (RemoteException e) {
|
||||
Slog.d(LOG_TAG, "Error calling callback");
|
||||
}
|
||||
@@ -455,12 +449,8 @@ public abstract class TextClassifierService extends Service {
|
||||
|
||||
@Override
|
||||
public void onFailure(CharSequence error) {
|
||||
ITextClassifierCallback callback = mTextClassifierCallback.get();
|
||||
if (callback == null) {
|
||||
return;
|
||||
}
|
||||
try {
|
||||
callback.onFailure();
|
||||
mTextClassifierCallback.onFailure();
|
||||
} catch (RemoteException e) {
|
||||
Slog.d(LOG_TAG, "Error calling callback");
|
||||
}
|
||||
|
||||
@@ -999,6 +999,7 @@ public final class SelectionActionModeHelper {
|
||||
}
|
||||
|
||||
private void onTimeOut() {
|
||||
Log.d(LOG_TAG, "Timeout in TextClassificationAsyncTask");
|
||||
if (getStatus() == Status.RUNNING) {
|
||||
onPostExecute(mTimeOutResultSupplier.get());
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user