diff options
author | Paul Duffin <paulduffin@google.com> | 2021-04-07 17:05:24 +0000 |
---|---|---|
committer | Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> | 2021-04-07 17:05:24 +0000 |
commit | f9ea5ff1b2f59dea36e9e4a61b00aba7c43136b8 (patch) | |
tree | aa7a6df23c19a97834b25422cdddb98b5de0f0c5 /tools | |
parent | f790b8fc70eb148a456aed5483877c781f10e733 (diff) | |
parent | a220ff9b2d2d638a8afdd703108008ade6c49747 (diff) |
Merge "Improve hiddenapi exclude.sh script" am: b1becf7cfb am: 8637b71f39 am: a220ff9b2d
Original change: https://android-review.googlesource.com/c/platform/frameworks/base/+/1660362
Change-Id: I4432d589a73377cb97b0e9779439e226357640c3
Diffstat (limited to 'tools')
-rwxr-xr-x | tools/hiddenapi/exclude.sh | 37 |
1 files changed, 26 insertions, 11 deletions
diff --git a/tools/hiddenapi/exclude.sh b/tools/hiddenapi/exclude.sh index 73eacc0641e5..2924e0109830 100755 --- a/tools/hiddenapi/exclude.sh +++ b/tools/hiddenapi/exclude.sh @@ -7,11 +7,9 @@ LOCAL_DIR="$( dirname ${BASH_SOURCE} )" # the team email to use in the event of this detecting an entry in a <team> package. Also # add <team> to the TEAMS list. LIBCORE_PACKAGES="\ - android.icu \ android.system \ android.test \ com.android.bouncycastle \ - com.android.conscrypt \ com.android.i18n.phonenumbers \ com.android.okhttp \ com.sun \ @@ -24,37 +22,54 @@ LIBCORE_PACKAGES="\ org.json \ org.w3c.dom \ org.xml.sax \ + org.xmlpull.v1 \ sun \ " LIBCORE_EMAIL=libcore-team@android.com +I18N_PACKAGES="\ + android.icu \ + " + +I18N_EMAIL=$LIBCORE_EMAIL + +CONSCRYPT_PACKAGES="\ + com.android.org.conscrypt \ + " + +CONSCRYPT_EMAIL=$LIBCORE_EMAIL + # List of teams. -TEAMS=LIBCORE +TEAMS="LIBCORE I18N CONSCRYPT" + +SHA=$1 # Generate the list of packages and convert to a regular expression. PACKAGES=$(for t in $TEAMS; do echo $(eval echo \${${t}_PACKAGES}); done) RE=$(echo ${PACKAGES} | sed "s/ /|/g") -git show --name-only --pretty=format: $1 | grep "config/hiddenapi-.*txt" | while read file; do - ENTRIES=$(grep -E "^L(${RE})/" || true <(git show $1:$file)) +EXIT_CODE=0 +for file in $(git show --name-only --pretty=format: $SHA | grep "config/hiddenapi-.*txt"); do + ENTRIES=$(grep -E "^\+L(${RE})/" <(git diff ${SHA}~1 ${SHA} $file) | sed "s|^\+||" || echo) if [[ -n "${ENTRIES}" ]]; then - echo -e "\e[1m\e[31m$file $1 contains the following entries\e[0m" + echo -e "\e[1m\e[31m$file $SHA contains the following entries\e[0m" echo -e "\e[1m\e[31mfor packages that are handled using UnsupportedAppUsage. Please remove\e[0m" echo -e "\e[1m\e[31mthese entries and add annotations instead.\e[0m" # Partition the entries by team and provide contact details to aid in fixing the issue. for t in ${TEAMS} do PACKAGES=$(eval echo \${${t}_PACKAGES}) - RE=$(echo ${PACKAGES} | sed "s/ /|/g") - TEAM_ENTRIES=$(grep -E "^L(${RE})/" <(echo "${ENTRIES}")) + TEAM_RE=$(echo ${PACKAGES} | sed "s/ /|/g") + TEAM_ENTRIES=$(grep -E "^L(${TEAM_RE})/" <(echo "${ENTRIES}") || echo) if [[ -n "${TEAM_ENTRIES}" ]]; then EMAIL=$(eval echo \${${t}_EMAIL}) - echo -e "\e[33mContact ${EMAIL} or compat- for help with the following:\e[0m" - for i in ${ENTRIES} + echo -e "\e[33mContact ${EMAIL} for help with the following:\e[0m" + for i in ${TEAM_ENTRIES} do echo -e "\e[33m ${i}\e[0m" done fi done - exit 1 + EXIT_CODE=1 fi done +exit $EXIT_CODE |