| # 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 py_binary.""" |
| |
| load("@rules_python_internal//:rules_python_config.bzl", "config") |
| load("//python/private:register_extension_info.bzl", "register_extension_info") |
| load("//python/private:util.bzl", "add_migration_tag") |
| load("//python/private/common:py_binary_macro_bazel.bzl", _starlark_py_binary = "py_binary") |
| |
| # buildifier: disable=native-python |
| _py_binary_impl = _starlark_py_binary if config.enable_pystar else native.py_binary |
| |
| def py_binary(**attrs): |
| """Creates an executable Python program. |
| |
| This is the public macro wrapping the underlying rule. Args are forwarded |
| on as-is unless otherwise specified. See |
| the underlying {bzl:obj}`py_binary rule<//python/private/common:py_binary_rule_bazel.bzl%py_binary>` |
| for detailed attribute documentation. |
| |
| This macro affects the following args: |
| * `python_version`: cannot be `PY2` |
| * `srcs_version`: cannot be `PY2` or `PY2ONLY` |
| * `tags`: May have special marker values added, if not already present. |
| |
| Args: |
| **attrs: Rule attributes forwarded onto the underlying |
| {bzl:obj}`py_binary rule<//python/private/common:py_binary_rule_bazel.bzl%py_binary>` |
| """ |
| if attrs.get("python_version") == "PY2": |
| fail("Python 2 is no longer supported: https://github.com/bazelbuild/rules_python/issues/886") |
| if attrs.get("srcs_version") in ("PY2", "PY2ONLY"): |
| fail("Python 2 is no longer supported: https://github.com/bazelbuild/rules_python/issues/886") |
| |
| _py_binary_impl(**add_migration_tag(attrs)) |
| |
| register_extension_info( |
| extension = py_binary, |
| label_regex_for_dep = "{extension_name}", |
| ) |