1*7594170eSAndroid Build Coastguard Worker# Copyright (C) 2023 The Android Open Source Project 2*7594170eSAndroid Build Coastguard Worker# 3*7594170eSAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License"); 4*7594170eSAndroid Build Coastguard Worker# you may not use this file except in compliance with the License. 5*7594170eSAndroid Build Coastguard Worker# You may obtain a copy of the License at 6*7594170eSAndroid Build Coastguard Worker# 7*7594170eSAndroid Build Coastguard Worker# http://www.apache.org/licenses/LICENSE-2.0 8*7594170eSAndroid Build Coastguard Worker# 9*7594170eSAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software 10*7594170eSAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS, 11*7594170eSAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12*7594170eSAndroid Build Coastguard Worker# See the License for the specific language governing permissions and 13*7594170eSAndroid Build Coastguard Worker# limitations under the License. 14*7594170eSAndroid Build Coastguard Worker 15*7594170eSAndroid Build Coastguard Workerload("//build/bazel/rules/common:api.bzl", "api") 16*7594170eSAndroid Build Coastguard Worker 17*7594170eSAndroid Build Coastguard Workerdef maybe_override_min_sdk_version(min_sdk_version, override_min_sdk_version): 18*7594170eSAndroid Build Coastguard Worker """ 19*7594170eSAndroid Build Coastguard Worker Override a min_sdk_version with another if higher. 20*7594170eSAndroid Build Coastguard Worker 21*7594170eSAndroid Build Coastguard Worker Normalizes string codenames to API ints for direct comparisons. 22*7594170eSAndroid Build Coastguard Worker 23*7594170eSAndroid Build Coastguard Worker Args: 24*7594170eSAndroid Build Coastguard Worker min_sdk_version: The min_sdk_version to potentially be overridden, as a string. 25*7594170eSAndroid Build Coastguard Worker Can be "current", or a number. 26*7594170eSAndroid Build Coastguard Worker override_min_sdk_version: The version to potentially override min_sdk_version with, as a string. 27*7594170eSAndroid Build Coastguard Worker Can be a number, of a known api level codename. 28*7594170eSAndroid Build Coastguard Worker Returns: 29*7594170eSAndroid Build Coastguard Worker Either min_sdk_version or override_min_sdk_version, converted to a string representation of a number. 30*7594170eSAndroid Build Coastguard Worker """ 31*7594170eSAndroid Build Coastguard Worker if min_sdk_version == "current": 32*7594170eSAndroid Build Coastguard Worker min_sdk_version = "10000" 33*7594170eSAndroid Build Coastguard Worker if not str(min_sdk_version).isdigit(): 34*7594170eSAndroid Build Coastguard Worker fail("%s must only contain digits." % min_sdk_version) 35*7594170eSAndroid Build Coastguard Worker 36*7594170eSAndroid Build Coastguard Worker min_api_level = int(min_sdk_version) 37*7594170eSAndroid Build Coastguard Worker 38*7594170eSAndroid Build Coastguard Worker if str(override_min_sdk_version).isdigit(): 39*7594170eSAndroid Build Coastguard Worker override_api_level = int(override_min_sdk_version) 40*7594170eSAndroid Build Coastguard Worker else: 41*7594170eSAndroid Build Coastguard Worker override_api_level = api.api_levels.get(override_min_sdk_version, -1) 42*7594170eSAndroid Build Coastguard Worker 43*7594170eSAndroid Build Coastguard Worker # Only override version numbers upwards. 44*7594170eSAndroid Build Coastguard Worker if override_api_level > min_api_level: 45*7594170eSAndroid Build Coastguard Worker min_api_level = override_api_level 46*7594170eSAndroid Build Coastguard Worker 47*7594170eSAndroid Build Coastguard Worker return str(min_api_level) 48