Loading core/java/android/database/ContentObserver.java +24 −3 Original line number Diff line number Diff line Loading @@ -31,6 +31,7 @@ import android.os.UserHandle; import java.util.Arrays; import java.util.Collection; import java.util.concurrent.Executor; /** * Receives call backs for changes to content. Loading @@ -54,6 +55,7 @@ public abstract class ContentObserver { private Transport mTransport; // guarded by mLock Handler mHandler; private final Executor mExecutor; /** * Creates a content observer. Loading @@ -62,6 +64,18 @@ public abstract class ContentObserver { */ public ContentObserver(Handler handler) { mHandler = handler; mExecutor = null; } /** * @hide * Creates a content observer with an executor. * * @param executor The executor to run {@link #onChange} on, or null if none. * @param unused a second argument to avoid source incompatibility. */ public ContentObserver(@Nullable Executor executor, int unused) { mExecutor = executor; } /** Loading Loading @@ -306,12 +320,19 @@ public abstract class ContentObserver { /** @hide */ public final void dispatchChange(boolean selfChange, @NonNull Collection<Uri> uris, @NotifyFlags int flags, @UserIdInt int userId) { if (mHandler == null) { if (mExecutor != null) { mExecutor.execute(() -> { onChange(selfChange, uris, flags, userId); } else { }); } else if (mHandler != null) { // Supporting Handler directly rather than wrapping in a HandlerExecutor // avoids introducing a RejectedExecutionException for legacy code when // the post fails. mHandler.post(() -> { onChange(selfChange, uris, flags, userId); }); } else { onChange(selfChange, uris, flags, userId); } } Loading core/java/android/database/ExecutorContentObserver.java 0 → 100644 +38 −0 Original line number Diff line number Diff line /* * Copyright (C) 2023 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package android.database; import android.annotation.Nullable; import java.util.concurrent.Executor; /** * @hide * * Receives callbacks for changes to content. * Must be implemented by objects which are added to a {@link ContentObservable}. */ public abstract class ExecutorContentObserver extends ContentObserver { /** * Creates a content observer that uses an executor for change handling. * * @param executor The executor to run {@link #onChange} on, or null if none. */ public ExecutorContentObserver(@Nullable Executor executor) { super(executor, 0); } } Loading
core/java/android/database/ContentObserver.java +24 −3 Original line number Diff line number Diff line Loading @@ -31,6 +31,7 @@ import android.os.UserHandle; import java.util.Arrays; import java.util.Collection; import java.util.concurrent.Executor; /** * Receives call backs for changes to content. Loading @@ -54,6 +55,7 @@ public abstract class ContentObserver { private Transport mTransport; // guarded by mLock Handler mHandler; private final Executor mExecutor; /** * Creates a content observer. Loading @@ -62,6 +64,18 @@ public abstract class ContentObserver { */ public ContentObserver(Handler handler) { mHandler = handler; mExecutor = null; } /** * @hide * Creates a content observer with an executor. * * @param executor The executor to run {@link #onChange} on, or null if none. * @param unused a second argument to avoid source incompatibility. */ public ContentObserver(@Nullable Executor executor, int unused) { mExecutor = executor; } /** Loading Loading @@ -306,12 +320,19 @@ public abstract class ContentObserver { /** @hide */ public final void dispatchChange(boolean selfChange, @NonNull Collection<Uri> uris, @NotifyFlags int flags, @UserIdInt int userId) { if (mHandler == null) { if (mExecutor != null) { mExecutor.execute(() -> { onChange(selfChange, uris, flags, userId); } else { }); } else if (mHandler != null) { // Supporting Handler directly rather than wrapping in a HandlerExecutor // avoids introducing a RejectedExecutionException for legacy code when // the post fails. mHandler.post(() -> { onChange(selfChange, uris, flags, userId); }); } else { onChange(selfChange, uris, flags, userId); } } Loading
core/java/android/database/ExecutorContentObserver.java 0 → 100644 +38 −0 Original line number Diff line number Diff line /* * Copyright (C) 2023 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package android.database; import android.annotation.Nullable; import java.util.concurrent.Executor; /** * @hide * * Receives callbacks for changes to content. * Must be implemented by objects which are added to a {@link ContentObservable}. */ public abstract class ExecutorContentObserver extends ContentObserver { /** * Creates a content observer that uses an executor for change handling. * * @param executor The executor to run {@link #onChange} on, or null if none. */ public ExecutorContentObserver(@Nullable Executor executor) { super(executor, 0); } }