summaryrefslogtreecommitdiff
path: root/libs/hwui/GradientCache.cpp
diff options
context:
space:
mode:
author Paul Duffin <paulduffin@google.com> 2017-10-02 10:23:25 +0100
committer Paul Duffin <paulduffin@google.com> 2017-10-23 16:14:40 +0100
commit14062f2382388a3a15802bf8b8b24d1f41d548c6 (patch)
treea4e2b6876b5feafbcf9eaa162a238e0ae457ea5b /libs/hwui/GradientCache.cpp
parentd5d697b023a02a81de8add89556596d4b3587034 (diff)
Preserve order of shared library files
Shared libraries are stored in a list so order is preserved. However, when they are resolved to files, e.g. for use as a class path the file names are added to an ArraySet which loses the order. Presumably they are added to a Set to eliminate duplicates. This switches to a LinkedHashSet which will preserve the order in which the files are added while still avoiding duplicates. It is possible that this could cause app compatibility issues as the order in which shared libraries is being added is changing. Problems can only arise if two libraries whose order changes have duplicate classes and/or resources. In that case the app was only working by luck, as the order provided by ArraySet is based on the numerical order of hash codes. This was found while investigating performance regressions in GoogleDialer, unfortunately it does not fix the regressions. Bug: 65552462 Test: flash -w and systrace GoogleDialer to ensure correct order Change-Id: I0e94471cc481437712f7cf0dab63d88f50cf3b14 Merged-In: Ia01ce4821fa53e4785716b72c4f87a0b0ab4dcc8
Diffstat (limited to 'libs/hwui/GradientCache.cpp')
0 files changed, 0 insertions, 0 deletions