xref: /aosp_15_r20/build/bazel/rules/apex/sdk_versions.bzl (revision 7594170e27e0732bc44b93d1440d87a54b6ffe7c)
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