diff options
author | David Brazdil <dbrazdil@google.com> | 2018-03-27 17:23:54 +0000 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2018-03-27 17:23:54 +0000 |
commit | 3f3487d64e274fdd2730d75d2e0de8fa30c2371e (patch) | |
tree | 63cf821095a02a6d920670203bde23d6e65f8cfb /Android.mk | |
parent | 5ecbcc6ca9b59ea76bbea703a927e00ca8902f72 (diff) | |
parent | 02175b78479af9534c89470675c9c36277ee8bdd (diff) |
Merge "Add serialization methods to hidden API light greylist" into pi-dev
am: 02175b7847
Change-Id: Ie625488ec40b3fd18d11043a1d25f5ccb487c351
Diffstat (limited to 'Android.mk')
-rw-r--r-- | Android.mk | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/Android.mk b/Android.mk index cf1f3d7887d8..5cea043b2fcd 100644 --- a/Android.mk +++ b/Android.mk @@ -764,11 +764,27 @@ include $(BUILD_STATIC_JAVA_LIBRARY) $(eval $(call copy-one-file,frameworks/base/config/hiddenapi-blacklist.txt,\ $(INTERNAL_PLATFORM_HIDDENAPI_BLACKLIST))) +# Automatically add all methods which match the following signatures. +# These need to be greylisted in order to allow applications to write their +# own serializers. +$(INTERNAL_PLATFORM_HIDDENAPI_LIGHT_GREYLIST): REGEX_SERIALIZATION := \ + "readObject\(Ljava/io/ObjectInputStream;\)V" \ + "readObjectNoData\(\)V" \ + "readResolve\(\)Ljava/lang/Object;" \ + "serialVersionUID:J" \ + "serialPersistentFields:\[Ljava/io/ObjectStreamField;" \ + "writeObject\(Ljava/io/ObjectOutputStream;\)V" \ + "writeReplace\(\)Ljava/lang/Object;" +$(INTERNAL_PLATFORM_HIDDENAPI_LIGHT_GREYLIST): PRIVATE_API := $(INTERNAL_PLATFORM_PRIVATE_DEX_API_FILE) # Temporarily merge light greylist from two files. Vendor list will become dark # grey once we remove the UI toast. $(INTERNAL_PLATFORM_HIDDENAPI_LIGHT_GREYLIST): frameworks/base/config/hiddenapi-light-greylist.txt \ - frameworks/base/config/hiddenapi-vendor-list.txt - sort $^ > $@ + frameworks/base/config/hiddenapi-vendor-list.txt \ + $(INTERNAL_PLATFORM_PRIVATE_DEX_API_FILE) + sort frameworks/base/config/hiddenapi-light-greylist.txt \ + frameworks/base/config/hiddenapi-vendor-list.txt \ + <(grep -E "\->("$(subst $(space),"|",$(REGEX_SERIALIZATION))")$$" $(PRIVATE_API)) \ + > $@ # Generate dark greylist as private API minus (blacklist plus light greylist). |