| # Copyright 2023 The Bazel Authors. All rights reserved. |
| # |
| # 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. |
| |
| """Public entry point for current_py_toolchain rule.""" |
| |
| load("//python/private:toolchain_types.bzl", "TARGET_TOOLCHAIN_TYPE") |
| |
| def _current_py_toolchain_impl(ctx): |
| toolchain = ctx.toolchains[ctx.attr._toolchain] |
| |
| direct = [] |
| transitive = [] |
| vars = {} |
| |
| if toolchain.py3_runtime and toolchain.py3_runtime.interpreter: |
| direct.append(toolchain.py3_runtime.interpreter) |
| transitive.append(toolchain.py3_runtime.files) |
| vars["PYTHON3"] = toolchain.py3_runtime.interpreter.path |
| |
| if toolchain.py2_runtime and toolchain.py2_runtime.interpreter: |
| direct.append(toolchain.py2_runtime.interpreter) |
| transitive.append(toolchain.py2_runtime.files) |
| vars["PYTHON2"] = toolchain.py2_runtime.interpreter.path |
| |
| files = depset(direct, transitive = transitive) |
| return [ |
| toolchain, |
| platform_common.TemplateVariableInfo(vars), |
| DefaultInfo( |
| runfiles = ctx.runfiles(transitive_files = files), |
| files = files, |
| ), |
| ] |
| |
| current_py_toolchain = rule( |
| doc = """ |
| This rule exists so that the current python toolchain can be used in the `toolchains` attribute of |
| other rules, such as genrule. It allows exposing a python toolchain after toolchain resolution has |
| happened, to a rule which expects a concrete implementation of a toolchain, rather than a |
| toolchain_type which could be resolved to that toolchain. |
| """, |
| implementation = _current_py_toolchain_impl, |
| attrs = { |
| "_toolchain": attr.string(default = str(TARGET_TOOLCHAIN_TYPE)), |
| }, |
| toolchains = [ |
| str(TARGET_TOOLCHAIN_TYPE), |
| ], |
| ) |