summaryrefslogtreecommitdiff
path: root/docs/html/sdk/api_diff/22/changes.html
diff options
context:
space:
mode:
authorWale Ogunwale <ogunwale@google.com>2016-12-05 11:38:02 -0800
committerWale Ogunwale <ogunwale@google.com>2016-12-05 16:50:03 -0800
commit3d0bfd9530bc51c52aec027eaf6d0dba918efc99 (patch)
tree7a01b8c37b8fda3c5b72216cbc67824da48cb40a /docs/html/sdk/api_diff/22/changes.html
parentd291683d9fa42588739ac79a5f60e80a5d8514e2 (diff)
Prevent orphaning of windows when token is removed
When the owner of a window token requests window manager to remove the token, we were removing it from it's parent which orphaned the token and all it's windows and prevented them from being accessed from calls like forAllWindows(). This problem wasn't visible before as the token windows would still be in the window list, so they can still be accessed for the exit animation transition which eventually removes them. We no longer remove tokens from their parent we when are asked to remove them from the system. We just set WindowToken.setExiting() so the token can be removed once all its windows are removed at the end of the exit animation. Also, - In AppWindowToken.removeIfPossible() and Task.removeIfPossible(), call removeImmediately() instead of parent.removeChild() to make sure the token and its windows are properly clean-up and avoid orphaning if they aren't. - Added DisplayContent.reParentWindowToken() for changing the display a window token is on which is different from DisplayContent.removeWindowToken which prepares the token and it's windows to be removed from the system. - Renamed WindowToken.explicit to WindowToken.mPersistOnEmpty which is what it does. Fixes: 33098800 Test: bit FrameworksServicesTests:com.android.server.wm.WindowTokenTests Test: Make sure toast windows don't persist on screen. Change-Id: I40e0e8832141514b614e79d8e95cd27f24e52366
Diffstat (limited to 'docs/html/sdk/api_diff/22/changes.html')
0 files changed, 0 insertions, 0 deletions