1*60517a1eSAndroid Build Coastguard Worker# Copyright 2023 The Bazel Authors. All rights reserved. 2*60517a1eSAndroid Build Coastguard Worker# 3*60517a1eSAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License"); 4*60517a1eSAndroid Build Coastguard Worker# you may not use this file except in compliance with the License. 5*60517a1eSAndroid Build Coastguard Worker# You may obtain a copy of the License at 6*60517a1eSAndroid Build Coastguard Worker# 7*60517a1eSAndroid Build Coastguard Worker# http://www.apache.org/licenses/LICENSE-2.0 8*60517a1eSAndroid Build Coastguard Worker# 9*60517a1eSAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software 10*60517a1eSAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS, 11*60517a1eSAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12*60517a1eSAndroid Build Coastguard Worker# See the License for the specific language governing permissions and 13*60517a1eSAndroid Build Coastguard Worker# limitations under the License. 14*60517a1eSAndroid Build Coastguard Worker 15*60517a1eSAndroid Build Coastguard Worker"""Python toolchain module extensions for use with bzlmod. 16*60517a1eSAndroid Build Coastguard Worker 17*60517a1eSAndroid Build Coastguard Worker:::{topic} Basic usage 18*60517a1eSAndroid Build Coastguard Worker 19*60517a1eSAndroid Build Coastguard WorkerThe simplest way to configure the toolchain with `rules_python` is as follows. 20*60517a1eSAndroid Build Coastguard Worker 21*60517a1eSAndroid Build Coastguard Worker```starlark 22*60517a1eSAndroid Build Coastguard Workerpython = use_extension("@rules_python//python/extensions:python.bzl", "python") 23*60517a1eSAndroid Build Coastguard Workerpython.toolchain( 24*60517a1eSAndroid Build Coastguard Worker is_default = True, 25*60517a1eSAndroid Build Coastguard Worker python_version = "3.11", 26*60517a1eSAndroid Build Coastguard Worker) 27*60517a1eSAndroid Build Coastguard Workeruse_repo(python, "python_3_11") 28*60517a1eSAndroid Build Coastguard Worker``` 29*60517a1eSAndroid Build Coastguard Worker 30*60517a1eSAndroid Build Coastguard Worker::::{seealso} 31*60517a1eSAndroid Build Coastguard WorkerFor more in-depth documentation see the {obj}`python.toolchain`. 32*60517a1eSAndroid Build Coastguard Worker:::: 33*60517a1eSAndroid Build Coastguard Worker::: 34*60517a1eSAndroid Build Coastguard Worker 35*60517a1eSAndroid Build Coastguard Worker:::{topic} Overrides 36*60517a1eSAndroid Build Coastguard Worker 37*60517a1eSAndroid Build Coastguard WorkerOverrides can be done at 3 different levels: 38*60517a1eSAndroid Build Coastguard Worker* Overrides affecting all python toolchain versions on all platforms - {obj}`python.override`. 39*60517a1eSAndroid Build Coastguard Worker* Overrides affecting a single toolchain versions on all platforms - {obj}`python.single_version_override`. 40*60517a1eSAndroid Build Coastguard Worker* Overrides affecting a single toolchain versions on a single platforms - {obj}`python.single_version_platform_override`. 41*60517a1eSAndroid Build Coastguard Worker 42*60517a1eSAndroid Build Coastguard Worker::::{seealso} 43*60517a1eSAndroid Build Coastguard WorkerThe main documentation page on registering [toolchains](/toolchains). 44*60517a1eSAndroid Build Coastguard Worker:::: 45*60517a1eSAndroid Build Coastguard Worker::: 46*60517a1eSAndroid Build Coastguard Worker""" 47*60517a1eSAndroid Build Coastguard Worker 48*60517a1eSAndroid Build Coastguard Workerload("//python/private:python.bzl", _python = "python") 49*60517a1eSAndroid Build Coastguard Worker 50*60517a1eSAndroid Build Coastguard Workerpython = _python 51