blob: 9012e8fd13c91fba12bc0571c8bb349af88ae60b [file] [log] [blame]
#!/bin/bash
#
# Copyright 2018 The Android Open Source Project
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
set -e
# Special build logic to handle src-ex .java files which have code that only builds on RI.
custom_build_logic() {
[[ -d ignore.src-ex ]] && mv ignore.src-ex src-ex
# src-ex uses code that can only build on RI.
${JAVAC} -source 1.8 -target 1.8 -sourcepath src-ex -sourcepath src -d classes-ex $(find src-ex -name '*.java')
# remove src-ex so that default-build doesn't try to build it.
[[ -d src-ex ]] && mv src-ex ignore.src-ex
}
# Build the jars twice. First with applying hiddenapi, creating a boot jar, then
# a second time without to create a normal jar. We need to do this because we
# want to load the jar once as an app module and once as a member of the boot
# class path. The DexFileVerifier would fail on the former as it does not allow
# hidden API access flags in dex files. DexFileVerifier is not invoked on boot
# class path dex files, so the boot jar loads fine in the latter case.
export USE_HIDDENAPI=true
custom_build_logic
./default-build "$@"
# Move the jar file into the resource folder to be bundled with the test.
mkdir res
mv ${TEST_NAME}.jar res/boot.jar
# Clear all intermediate files otherwise default-build would either skip
# compilation or fail rebuilding.
rm -rf classes*
export USE_HIDDENAPI=false
custom_build_logic
./default-build "$@"