From 4647acb60e407670356c628d3a823c172dfeea64 Mon Sep 17 00:00:00 2001 From: Robert Carr Date: Mon, 5 Dec 2016 20:33:10 -0800 Subject: [PATCH] Correct error in Configuration.updateFrom When updating the non direction members of screenLayout we check that they are not in total undefined, before accepting the new value in full. This was enough for LONG/SIZE which are always undefined or set together. It seems we have paths now where SCREENLAYOUT_ROUND however can be undefined and the others will be set. In this case if we pass a configuration with SCREENLAYOUT_ROUND_UNDEFINED but LONG/SIZE set to updateFrom then we will overwrite our previous SCREENLAYOUT_ROUND value. This triggers extra configuration changes. Bug: 33098677 Test: bit FrameworksCoreTests:android.content.res.ConfigurationTest Change-Id: I6eb321d27011a2af2134d0ed5b6864d4cd902dc3 --- .../android/content/res/Configuration.java | 31 ++++++++---- .../content/res/ConfigurationTest.java | 47 +++++++++++++++++++ 2 files changed, 68 insertions(+), 10 deletions(-) create mode 100644 core/tests/coretests/src/android/content/res/ConfigurationTest.java diff --git a/core/java/android/content/res/Configuration.java b/core/java/android/content/res/Configuration.java index ee1f1907fcb87..e039512f4fe4c 100644 --- a/core/java/android/content/res/Configuration.java +++ b/core/java/android/content/res/Configuration.java @@ -1047,18 +1047,29 @@ public final class Configuration implements Parcelable, Comparable