# 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` 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` """ 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}", )