diff options
author | 2025-01-01 22:57:41 -0800 | |
---|---|---|
committer | 2025-01-01 22:57:41 -0800 | |
commit | 4660f140cb293fa859a183bd98593c817f287ced (patch) | |
tree | d4f42b9ba50e1e2cbe8a6922976dddf29baf7f8e | |
parent | cb2bca5f6da5472cb69e4fe1860aeee5a50a5921 (diff) | |
parent | d16b5596bcef50d9a7793588575130935e3cb648 (diff) |
Merge "fix the NPE problem due to add null InsetsControlTarget object to map ." into main am: d16b5596bc
Original change: https://android-review.googlesource.com/c/platform/frameworks/base/+/3428481
Change-Id: Ic2b629d69191408c207b4a52934b8f5ee387e41d
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
3 files changed, 4 insertions, 3 deletions
diff --git a/services/core/java/com/android/server/wm/ImeInsetsSourceProvider.java b/services/core/java/com/android/server/wm/ImeInsetsSourceProvider.java index e178203fed92..8763c8f18f70 100644 --- a/services/core/java/com/android/server/wm/ImeInsetsSourceProvider.java +++ b/services/core/java/com/android/server/wm/ImeInsetsSourceProvider.java @@ -100,7 +100,8 @@ final class ImeInsetsSourceProvider extends InsetsSourceProvider { // isLeashReadyForDispatching (used to dispatch the leash of the control) is // depending on mGivenInsetsReady. Therefore, triggering notifyControlChanged here // again, so that the control with leash can be eventually dispatched - if (!mGivenInsetsReady && mServerVisible && !givenInsetsPending) { + if (!mGivenInsetsReady && mServerVisible && !givenInsetsPending + && mControlTarget != null) { mGivenInsetsReady = true; ImeTracker.forLogging().onProgress(mStatsToken, ImeTracker.PHASE_WM_POST_LAYOUT_NOTIFY_CONTROLS_CHANGED); diff --git a/services/core/java/com/android/server/wm/InsetsSourceProvider.java b/services/core/java/com/android/server/wm/InsetsSourceProvider.java index d3cae4c7b940..8d7447c5182f 100644 --- a/services/core/java/com/android/server/wm/InsetsSourceProvider.java +++ b/services/core/java/com/android/server/wm/InsetsSourceProvider.java @@ -379,7 +379,7 @@ class InsetsSourceProvider { final boolean serverVisibleChanged = mServerVisible != isServerVisible; setServerVisible(isServerVisible); final boolean positionChanged = updateInsetsControlPosition(windowState); - if (mControl != null && !positionChanged + if (mControl != null && mControlTarget != null && !positionChanged // The insets hint would be updated if the position is changed. Here updates it for // the possible change of the bounds or the server visibility. && (updateInsetsHint() diff --git a/services/core/java/com/android/server/wm/InsetsStateController.java b/services/core/java/com/android/server/wm/InsetsStateController.java index 3e39a45fa5f3..6ae23410864e 100644 --- a/services/core/java/com/android/server/wm/InsetsStateController.java +++ b/services/core/java/com/android/server/wm/InsetsStateController.java @@ -373,7 +373,7 @@ class InsetsStateController { array.add(provider); } - void notifyControlChanged(InsetsControlTarget target, InsetsSourceProvider provider) { + void notifyControlChanged(@NonNull InsetsControlTarget target, InsetsSourceProvider provider) { addToPendingControlMaps(target, provider); notifyPendingInsetsControlChanged(); |