Skip to content

Commit

Permalink
chore: improve formatting
Browse files Browse the repository at this point in the history
  • Loading branch information
alexeagle committed Oct 2, 2024
1 parent 489893f commit a2120c5
Show file tree
Hide file tree
Showing 8 changed files with 182 additions and 62 deletions.
14 changes: 13 additions & 1 deletion docs/pex.md

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

43 changes: 38 additions & 5 deletions docs/py_binary.md

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

35 changes: 34 additions & 1 deletion docs/py_test.md

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

34 changes: 33 additions & 1 deletion docs/venv.md

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

41 changes: 37 additions & 4 deletions py/defs.bzl
Original file line number Diff line number Diff line change
@@ -1,5 +1,38 @@
"""Re-implementations of [py_binary](https://bazel.build/reference/be/python#py_binary)
and [py_test](https://bazel.build/reference/be/python#py_test)
## Choosing the Python version
The `python_version` attribute must refer to a python toolchain version
which has been registered in the WORKSPACE or MODULE.bazel file.
When using WORKSPACE, this may look like this:
```starlark
load("@rules_python//python:repositories.bzl", "py_repositories", "python_register_toolchains")
python_register_toolchains(
name = "python_toolchain_3_8",
python_version = "3.8.12",
# setting set_python_version_constraint makes it so that only matches py_* rule
# which has this exact version set in the `python_version` attribute.
set_python_version_constraint = True,
)
# It's important to register the default toolchain last it will match any py_* target.
python_register_toolchains(
name = "python_toolchain",
python_version = "3.9",
)
```
Configuring for MODULE.bazel may look like this:
```starlark
python = use_extension("@rules_python//python/extensions:python.bzl", "python")
python.toolchain(python_version = "3.8.12", is_default = False)
python.toolchain(python_version = "3.9", is_default = True)
```
"""

load("@aspect_bazel_lib//lib:utils.bzl", "propagate_common_rule_attributes")
Expand Down Expand Up @@ -59,17 +92,17 @@ def _py_binary_or_test(name, rule, srcs, main, deps = [], resolutions = {}, **kw
def py_binary(name, srcs = [], main = None, **kwargs):
"""Wrapper macro for [`py_binary_rule`](#py_binary_rule).
Creates a virtualenv to constrain the interpreter and packages used at runtime.
Users can `bazel run [name].venv` to create the virtualenv, then use it in the editor or other tools.
Creates a [py_venv](./venv.md) target to constrain the interpreter and packages used at runtime.
Users can `bazel run [name].venv` to create this virtualenv, then use it in the editor or other tools.
Args:
name: Name of the rule.
srcs: Python source files.
main: Entry point.
Like rules_python, this is treated as a suffix of a file that should appear among the srcs.
If absent, then "[name].py" is tried. As a final fallback, if the srcs has a single file,
If absent, then `[name].py` is tried. As a final fallback, if the srcs has a single file,
that is used as the main.
**kwargs: additional named parameters to the py_binary_rule.
**kwargs: additional named parameters to `py_binary_rule`.
"""

# For a clearer DX when updating resolutions, the resolutions dict is "string" -> "label",
Expand Down
34 changes: 1 addition & 33 deletions py/private/py_binary.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -141,39 +141,7 @@ _attrs = dict({
mandatory = True,
),
"python_version": attr.string(
doc = """Whether to build this target and its transitive deps for a specific python version.
Note that setting this attribute alone will not be enough as the python toolchain for the desired version
also needs to be registered in the WORKSPACE or MODULE.bazel file.
When using WORKSPACE, this may look like this,
```
load("@rules_python//python:repositories.bzl", "py_repositories", "python_register_toolchains")
python_register_toolchains(
name = "python_toolchain_3_8",
python_version = "3.8.12",
# setting set_python_version_constraint makes it so that only matches py_* rule
# which has this exact version set in the `python_version` attribute.
set_python_version_constraint = True,
)
# It's important to register the default toolchain last it will match any py_* target.
python_register_toolchains(
name = "python_toolchain",
python_version = "3.9",
)
```
Configuring for MODULE.bazel may look like this:
```
python = use_extension("@rules_python//python/extensions:python.bzl", "python")
python.toolchain(python_version = "3.8.12", is_default = False)
python.toolchain(python_version = "3.9", is_default = True)
```
""",
doc = """Whether to build this target and its transitive deps for a specific python version.""",
),
"package_collisions": attr.string(
doc = """The action that should be taken when a symlink collision is encountered when creating the venv.
Expand Down
Loading

0 comments on commit a2120c5

Please sign in to comment.