rules_python Changelog
This is a human-friendly changelog in a keepachangelog.com style format. Because this changelog is for end-user consumption of meaningful changes, only a summary of a release’s changes is described. This means every commit is not necessarily mentioned, and internal refactors or code cleanups are omitted unless they’re particularly notable.
A brief description of the categories of changes:
Changed: Some behavior changed. If the change is expected to break a public API or supported behavior, it will be marked as BREAKING. Note that beta APIs will not have breaking API changes called out.Fixed: A bug, or otherwise incorrect behavior, was fixed.Added: A new feature, API, or behavior was added in a backwards compatible manner.Particular sub-systems are identified using parentheses, e.g.
(bzlmod)or(docs).
Unreleased
Removed
Nothing removed.
Changed
(binaries/tests) The
PYTHONBREAKPOINTenvironment variable is automatically inherited(binaries/tests) The
stampattribute now transitions the Bazel builtin--stampflag.(pypi) Now the RECORD file patches will follow the quoted or unquoted filenames convention in order to make
pytorchand friends easier to patch.
Fixed
Added
(binaries/tests)
--debugger: allows specifying an extra dependency to add to binaries/tests for custom debuggers.(binaries/tests) Build information is now included in binaries and tests. Use the
bazel_binary_infomodule to access it. The--stampflag will add--workspace_statusinformation.(gazelle) A new directive
python_generate_pyi_depshas been added. Whentrue, apy_*target’spyi_srcsattribute will be set if any.pyifiles that are associated with the target’ssrcsare present. (#3354).
[1.8.2] - 2026-01-24
Fixed
(venvs) relax the C library filename check to make tensorflow work Fixes #3524.
[1.8.1] - 2026-01-20
Fixed
(pipstar) Extra resolution that refers back to the package being resolved works again. Fixes #3524.
1.8.0 - 2025-12-19
Known Issues
(gazelle) Windows support for the Gazelle plugin may be broken. See #3416 for details and possible workarounds.
Removed
(toolchain) Remove all of the python 3.8 toolchain support out of the box. Users need to pass the
TOOL_VERSIONSthat include 3.8 toolchains or use thebzlmodAPIs to add them back. This means any hubpip.parsecalls that target3.8will be ignored from now on. (#2704) , like:python = use_extension("@rules_python//python/extensions:python.bzl", "python") python.single_version_override( python_version = "3.8.20", sha256 = { "aarch64-apple-darwin": "2ddfc04bdb3e240f30fb782fa1deec6323799d0e857e0b63fa299218658fd3d4", "aarch64-unknown-linux-gnu": "9d8798f9e79e0fc0f36fcb95bfa28a1023407d51a8ea5944b4da711f1f75f1ed", "x86_64-apple-darwin": "68d060cd373255d2ca5b8b3441363d5aa7cc45b0c11bbccf52b1717c2b5aa8bb", "x86_64-pc-windows-msvc": "41b6709fec9c56419b7de1940d1f87fa62045aff81734480672dcb807eedc47e", "x86_64-unknown-linux-gnu": "285e141c36f88b2e9357654c5f77d1f8fb29cc25132698fe35bb30d787f38e87", }, urls = ["https://github.com/astral-sh/python-build-standalone/releases/download/20241002/cpython-{python_version}+20241002-{platform}-{build}.tar.gz"], )
(toolchain) Remove all of the python 3.9 toolchain versions except for the
3.9.25. This version has reached EOL and will no longer receive any security fixes, please update to3.10or above. (#2704)(toolchain)
ignore_root_user_errorhas now been flipped to be always enabled and thechmodof the python toolchain directories have been removed. From now onrules_pythonalways adds thepycfiles to the glob excludes and in order to avoid any problems when using the toolchains in the repository phase, ensure that you pass-Bto the python interpreter. (#2016)
Changed
(toolchains) Use toolchains from the 20251031 release.
(gazelle) Internally split modules mapping generation to be per-wheel for concurrency and caching.
(pip)
pipstarhas been enabled for allwhl_libraryinstances where the whl is passed through a label or downloaded using the bazel downloader (#2949).(pypi)
pipstarflag default has been flipped to be on by default. It can be disabled throughRULES_PYTHON_ENABLE_PIPSTAR=0environment variable. If you do need to disable it, please add a comment to #2949.(gazelle deps) rules_go bumped from 0.55.1 to 0.59.0
(gazelle deps) gazelle bumped from 0.36.0 to 0.47.0
Fixed
(gazelle) Remove
py_binarytargets with invalidsrcs. This includes files that are not generated or regular files. #3046(runfiles) Fix incorrect Python runfiles path assumption - the existing implementation assumes that it is always four levels below the runfiles directory, leading to incorrect path checks (#3085).
(toolchains) local toolchains now tell the
sys.abiflagsvalue of the underlying runtime.(toolchains) various local toolchain fixes: add abi3 header targets, fixes to linking, Windows DLL detection, and defines for free threaded runtimes.
(toolchains) The
python_headerstarget is now compatible with layering_check.(performance) 90% reduction in py_binary/py_test analysis phase cost. (#3381).
(gazelle) Fix
gazelle_python_manifest.testso that it accesses manifest files viarunfilepath handling rather than directly (#3397).(core rules) For the system_python bootstrap, the runfiles root is added to sys.path.
(sphinxdocs) The sphinxdocs
.servetarget is now compatible with Bazel’s--symlink_prefixflag (#3410).
Added
(toolchains)
3.9.25Python toolchain from 20251031 release.(toolchains)
3.13.10,3.14.1Python toolchain from 20251202 release.(toolchains)
3.13.11,3.14.2,3.15.0a2Python toolchains from 20251209 release.(pypi) API to tell
pip.parsewhich platforms users care about. This is very useful to ensure that when users dobazel queryfor their deps, they don’t have to download all of the dependencies for all of the available wheels. Torch wheels can be up of 1GB and it takes a lot of time to download those, which is unnecessary if only the host platform builds are necessary to be performed. This is mainly for backwards/forwards compatibility whilst rolling outRULES_PYTHON_ENABLE_PIPSTAR=1by default. Users ofexperimental_index_urlthat perform cross-builds should addtarget_platformsto theirpip.parseinvocations, which will become mandatory if any cross-builds are required from the next release.(py_library) Attribute
namespace_package_filesadded. It is a hint for optimizing venv creation.
1.7.0 - 2025-10-11
Removed
(core rules) Support for Bazel’s long deprecated “extra actions” has been removed (#3215).
Changed
(deps) bumped rules_cc dependency to
0.1.5.(bootstrap) For
--bootstrap_impl=system_python,PYTHONPATHis no longer used to add import paths. The sys.path order has changed from[app paths, stdlib, runtime site-packages]to[stdlib, app paths, runtime site-packages].(bootstrap) For
--bootstrap_impl=system_python, the sys.path order has changed from[app paths, stdlib, runtime site-packages]to[stdlib, app paths, runtime site-packages].(pip) Publishing deps are no longer pulled via
experimental_index_url. (#2937).(toolchains)
py_runtimeandPyRuntimeInforeject Python 2 settings. Settingpy_runtime.python_version = "PY2"or non-NonePyRuntimeInfo.py2_runtimeis an error.(pypi)
pipstarflag has been implemented forWORKSPACEand can be flipped to be enabled usingRULES_PYTHON_ENABLE_PIPSTAR=1environment variable. If you do, please add a comment to #2949 if you run into any problems. With this release we are deprecatingpip.parse.experimental_target_platformsandpip_repository.experimental_target_platforms. For users usingWORKSPACEand vendoring therequirements.bzlfile, please re-vendor so that downstream is unaffected when the APIs get removed. If you need to customize the way the dependencies get evaluated, see our docs on customizingRequires-Distresolution.(toolchains) Added Python versions 3.15.0a1, 3.14.0, 3.13.9, 3.12.12, 3.11.14, 3.10.19, and 3.9.24 from the 20251014 release.
(deps) (bzlmod) Upgraded to
bazel-skylibversion 1.8.2
Fixed
(rules) The
PyInfoconstructor was setting the wrong value forhas_py3_only_sources- this is now fixed.(bootstrap) The stage1 bootstrap script now correctly handles nested
RUNFILES_DIRenvironments, fixing issues where apy_binarycalls anotherpy_binary(#3187).(bootstrap) For Windows, having many dependencies no longer results in max length errors due to too long environment variables.
(bootstrap)
--bootstrap_impl=scriptnow supports the-Sinterpreter setting.(venvs)
--venvs_site_packages=yesno longer errors when packages with overlapping files or directories are used together. (#3204).(venvs)
--venvs_site_packages=yesworks for packages that dynamically link to shared libraries (#3228).(venvs)
--venvs_site_packages=yesincludespthfiles at the root of the site-packages folder (#3339).(uv)
//python/uv:lock.bzl%locknow works with a local platform runtime.(pypi)
linux_riscv64is added to the platforms list in_pip_repository_impl, which fixes a build issue for tensorflow on riscv64.(toolchains) WORKSPACE builds now correctly register musl and freethreaded variants. Setting
--py_linux_libc=musland--py_freethreaded=yesnow activate them, respectively. (#3262).(rules)
py_console_script_binaryis now compatible with symbolic macros (#3195).
Added
(runfiles) The Python runfiles library now supports Bazel’s
--incompatible_compact_repo_mapping_manifestflag.(bootstrap)
--bootstrap_impl=system_pythonnow supports themain_moduleattribute.(bootstrap)
--bootstrap_impl=system_pythonnow supports theRULES_PYTHON_ADDITIONAL_INTERPRETER_ARGSenvironment variable.(rules) The
py_binary,py_test, andpy_wheelrules now have aconfig_settingsattribute to control build flags within the build graph. Custom settings can be added usingconfig.add_transition_settinginMODULE.bazelfiles, orpy_repositories(transition_settings=...)inWORKSPACEfiles. See the How to use a common set of dependencies with multiple PyPI versions guide on using common dependencies with multiple PyPI versions` for an example.(toolchains) Stable ABI headers support added. To use, depend on
//python/cc:current_py_cc_headers_abi3. This allows Windows builds a way to depend on headers without the potentially Python unstable ABI objects from the regular//python/cc:current_py_cc_headerstarget being included.Adds
//python/cc:current_py_cc_headers_abi3,py_cc_toolchain.headers_abi3, andPyCcToolchainInfo.headers_abi3.//python:features.bzl%features.headers_abi3can be used to feature-detect the presense of the above.
(toolchains) Local toolchains can use a label for the interpreter to use.
(pypi) Support for environment marker handling and
experimental_index_urlhandling for Windows ARM64 for Python 3.11 and later (#2276).
1.6.3 - 2025-09-21
Fixed
(pypi) We now use the Minimal Version Selection (MVS) algorithm to select the right wheel when there are multiple wheels for the target platform (e.g.
musllinux_1_1_x86_64andmusllinux_1_2_x86_64). If the user wants to set the minimum version for the selection algorithm, use thepip.defaults.whl_platform_tagsattribute to configure that. Ifmusllinux_*_x86_64is specified, we will choose the lowest available wheel version. Fixes #3250.
1.6.0 - 2025-08-23
Changed
(gazelle) update minimum gazelle version to 0.36.0 - may cause BUILD file changes
(gazelle) update minimum rules_go version to 0.55.1
(gazelle) remove custom go-tree-sitter module BUILD file
(gazelle) For package mode, resolve dependencies when imports are relative to the package path. This is enabled via the
# gazelle:python_experimental_allow_relative_importstrue directive (#2203 issue).(gazelle) Types for exposed members of
python.ParserOutputare now all public.(gazelle) Removed the requirement for
__init__.py,__main__.py, or__test__.pyfiles to be present in a directory to generate aBUILD.bazelfile.(toolchain) Updated the following toolchains to build 20250808 to patch CVE-2025-47273:
3.9.23
3.10.18
3.11.13
3.12.11
3.14.0rc1
(toolchain) Python 3.13 now references 3.13.6
(gazelle) Switched back to smacker/go-tree-sitter, fixing #2630
(pypi) From now on the list of default platforms only includes
linux_x86_64,linux_aarch64,osx_x86_64,osx_aarch64andwindows_x86_64. If you are on other platforms, you need to use thepip.defaultto configure it yourself. If you are interested in graduating the platform, consider helping set us up CI for them and update the documentation.(ci) We are now testing on Ubuntu 22.04 for RBE and non-RBE configurations.
(core)
#!/usr/bin/env bashis now used as a shebang in the stage1 bootstrap template.(gazelle:docs) The Gazelle docs have been migrated from gazelle/README.md to gazelle/docs and are now available on the primary documentation site at https://rules-python.readthedocs.io/en/latest/gazelle/docs/index.html
Fixed
(toolchains)
local_runtime_reponow respects changes to theDEVELOPER_DIRandXCODE_VERSIONrepo env vars, fixing stale cache issues on macOS with system (i.e. Xcode-supplied) Python (#3123).(pypi) Fixes an issue where builds using a
bazel vendorvendor directory would fail if the constraints file contained environment markers. Fixes #2996.(pypi) Wheels with BUILD.bazel (or other special Bazel files) no longer result in missing files at runtime (#2782).
(runfiles) The pypi runfiles package now includes
py.typedto indicate it supports type checking (#2503).(pypi) The pipstar
defaultsconfiguration now supports any custom platform name.(pypi) The selection of the whls has been changed and should no longer result in ambiguous select matches (#2759 issue) and should be much more efficient when running
bazel querydue to fewer repositories being included (#2849 issue).Multi-line python imports (e.g. with escaped newlines) are now correctly processed by Gazelle.
(toolchains)
local_runtime_repoworks with multiarch Debian with Python 3.8 (#3099).(pypi) Expose pypi packages only common to all Python versions in
all_requirements(#2921).(repl) Normalize the path for the
REPLstub to make it possible to use the default stub template from outsiderules_python(#3101 issue).(gazelle) Fixes gazelle adding sibling module dependencies to resolve absolute imports (Python 2’s behavior without
absolute_import). Previous behavior can be restored using the directive# gazelle:python_resolve_sibling_imports true(pypi) Show overridden index URL of packages when downloading metadata have failed. (#2985).
(toolchains) use “command -v” to find interpreter in
$PATH(#3150).(pypi)
bazel vendornow works inbzlmod(#3079 issue).(toolchains)
local_runtime_reponow works on Windows (#3055).(toolchains)
local_runtime_reposupports more types of Python installations (Mac frameworks, missing dynamic libraries, and other esoteric cases, see #3148 for details).(pypi) Support
requirements.txtfiles that use different versions of the same package targeting different target platforms. (#2797).(py_wheel) Add directories in deterministic order.
Added
(repl) Default stub now has tab completion, where
readlinesupport is available, see (#3114). (#3114).(pypi) To configure the environment for
requirements.txtevaluation, use the newly added developer preview of thepip.defaulttag class. Onlyrules_pythonand root modules can use this feature. You can also configure customconfig_settingsusingpip.default. It can also be used to set the globalnetrcorauth_patternsvariables.(pypi) PyPI dependencies now expose an
:extracted_whl_filesfilegroup target of all the files extracted from the wheel. This can be used in lieu ofwhl_filegroupto avoid copying/extracting wheel multiple times to get a subset of their files.(gazelle) New directive
gazelle:python_generate_pyi_deps; whentrue, dependencies added to satisfy type-only imports (if TYPE_CHECKING) and type stub packages are added topyi_depsinstead ofdeps.(toolchain) Add toolchains for aarch64 windows for
3.11.13
3.12.11
3.13.6
3.14.0rc1
(gazelle): New annotation
gazelle:include_pytest_conftest. When not set (the default) ortrue, gazelle will inject anyconftest.pyfile found in the same directory as apy_testtarget to thatpy_testtarget’sdeps. This behavior is unchanged from previous versions. Whenfalse, the:conftestdep is not added to thepy_testtarget.(gazelle) New directive
gazelle:python_generate_proto; whentrue, Gazelle generatespy_proto_libraryrules forproto_library.falseby default.Note: Users must manually configure their Gazelle target to support the proto language.
(gazelle) New directive
gazelle:python_proto_naming_convention; controls naming ofpy_proto_libraryrules.
Removed
Nothing removed.
1.5.4 - 2025-08-27
Fixed
(toolchains)
local_runtime_reponow checks if the include directory exists before attempting to watch it, fixing issues on macOS with system Python (#3043).
1.5.3 - 2025-08-11
Fixed
(toolchains)
local_runtime_reponow checks if the include directory exists before attempting to watch it, fixing issues on macOS with system Python (#3043).
1.5.2 - 2025-08-11
Changed
(deps) (bzlmod) Upgraded to
bazel-skylibversion 1.8.1 to remove deprecation warnings.
Fixed
1.5.1 - 2025-07-06
Fixed
(pypi) Namespace packages work by default (pkgutil shims are generated by default again) (#3038).
1.5.0 - 2025-06-11
Changed
(toolchain) Bundled toolchain version updates:
3.9 now references 3.9.23
3.10 now references 3.10.18
3.11 now references 3.11.13
3.12 now references 3.12.11
3.13 now references 3.13.4
(rules) On Windows,
--bootstrap_impl=system_pythonis forced. This allows setting--bootstrap_impl=scriptin bazelrc for mixed-platform environments.(rules)
compile_pip_requirementsnow generates a.testtarget. The_testtarget is deprecated and will be removed in the next major release. (#2794(py_wheel) py_wheel always creates zip64-capable wheel zips
(providers) (experimental)
PyInfo.venv_symlinksreplacesPyInfo.site_packages_symlinks(deps) Updated setuptools to 78.1.1 to patch CVE-2025-47273. This effectively makes Python 3.9 the minimum supported version for using
pip_parse.
Fixed
(rules) PyInfo provider is now advertised by py_test, py_binary, and py_library; this allows aspects using required_providers to function correctly. (#2506).
Fixes when using
--bootstrap_impl=script:compile_pip_requirementsnow works with itThe
sys._base_executablevalue will reflect the underlying interpreter, not venv interpreter.The
//python/runtime_env_toolchains:alltoolchain now works with it.
(rules) Better handle flakey platform.win32_ver() calls by calling them multiple times.
(tools/wheelmaker.py) Extras are now preserved in Requires-Dist metadata when using requires_file to specify the requirements.
(pypi) Use bazel downloader for direct URL references and correctly detect the filenames from various URL formats - URL encoded version strings get correctly resolved, sha256 value can be also retrieved from the URL as opposed to only the
--hashparameter. Fixes #2363.(pypi)
whl_librarynow infers file names from itsurlsattribute correctly.(pypi) When running under
bazel test, be sure that temporaryrequirementsfile remains writable.(py_test, py_binary) Allow external files to be used for main
(pypi) Correctly aggregate the sources when the hashes specified in the lockfile differ by platform even though the same version is used. Fixes #2648.
(pypi)
compile_pip_requirementstest rule works behind the proxy(toolchains) The hermetic toolchains now correctly statically advertise the
releaselevelandserialfor pre-release hermetic toolchains (#2837 issue).
Added
Repo utilities
execute_unchecked,execute_checked, andexecute_checked_stdoutnow supportlog_stdoutandlog_stderrkeyword arg booleans. When these areTrue(the default), the subprocess’s stdout/stderr will be logged.(toolchains) Local toolchains can be activated with custom flags. See [Conditionally using local toolchains] docs for how to configure.
(pypi) Starlark-based evaluation of environment markers (requirements.txt conditionals) available (not enabled by default) for improved multi-platform build support. Set the
RULES_PYTHON_ENABLE_PIPSTAR=1environment variable to enable it.(utils) Add a way to run a REPL for any
rules_pythontarget that returns aPyInfoprovider.(uv) Handle
.netrcandauth_patternsauth when downloadinguv. Work towards #1975.(toolchains) Arbitrary python-build-standalone runtimes can be registered and activated with custom flags. See the [Registering custom runtimes] docs and
single_version_platform_override()API docs for more information.(rules) Added support for a using constraints files with
compile_pip_requirements. Useful when an intermediate dependency needs to be upgraded to pull in security patches.(toolchains): 3.14.0b2 has been added as a preview.
Removed
Nothing removed.
1.4.2 - 2025-08-13
Fixed
(toolchains)
local_runtime_reponow checks if the include directory exists before attempting to watch it, fixing issues on macOS with system Python (#3043).
1.4.1 - 2025-05-08
Fixed
(pypi) Fix a typo not allowing users to benefit from using the downloader when the hashes in the requirements file are not present. Fixes #2863.
1.4.0 - 2025-04-19
Changed
(toolchain) The
execconfiguration toolchain now has the forwardedexec_interpreternow also forwards theToolchainInfoprovider. This is for increased compatibility with theRBEsetups where access to theexecconfiguration interpreter is needed.(toolchains) Use the latest astral-sh toolchain release 20250317 for Python versions:
3.9.21
3.10.16
3.11.11
3.12.9
3.13.2
(pypi) Use
xcrun xcodebuild --showsdksto find XCode root.(toolchains) Remove all but
3.8.20versions of the Python3.8interpreter who has reached EOL. If users still need other versions of the3.8interpreter, please supply the URLs manuallypython.toolchainorpython_register_toolchainscalls.(toolchains) Previously #2636 changed the semantics of
ignore_root_user_errorfrom “ignore” to “warning”. This is now flipped back to ignoring the issue, and will only emit a warning when the attribute is setFalse.(pypi) The PyPI extension will no longer write the lock file entries as the extension has been marked reproducible. Fixes #2434.
(gazelle) Lazily load and parse manifest files when running Gazelle. This ensures no manifest files are loaded when Gazelle is run over a set of non-python directories PR #2746.
(rules)
py_binary.srcsandpy_test.srcsis no longer mandatory whenmain_moduleis specified (for--bootstrap_impl=script)
Fixed
(pypi) Platform specific extras are now correctly handled when using universal lock files with environment markers. Fixes #2690.
(runfiles) (
--bootstrap_impl=script) Follow symlinks when searching for runfiles.(toolchains) Do not try to run
chmodwhen downloading non-windows hermetic toolchain repositories on Windows. Fixes #2660.(logging) Allow repo rule logging level to be set to
FAILvia theRULES_PYTHON_REPO_DEBUG_VERBOSITYenvironment variable.(toolchains) The toolchain matching is has been fixed when writing transitions transitioning on the
python_versionflag. Fixes #2685.(toolchains) Run the check on the Python interpreter in isolated mode, to ensure it’s not affected by userland environment variables, such as
PYTHONPATH.(toolchains) Ensure temporary
.pycand.pyofiles are also excluded from the interpreters repository files.(pypi) Run interpreter version call in isolated mode, to ensure it’s not affected by userland environment variables, such as
PYTHONPATH.(packaging) An empty
requires_fileis treated as if it were omitted, resulting in a validMETADATAfile.(rules) py_wheel and sphinxdocs rules now propagate
target_compatible_withto all targets they create. PR #2788.(pypi) Correctly handle
METADATAentries whenpython_full_versionis used in the environment marker. Fixes #2319.(pypi) Correctly handle
python_versionparameter and transition the requirement locking to the right interpreter version when usingcompile_pip_requirementsrule. See #2819.
Added
(pypi) From now on
sha256values in therequirements.txtis no longer mandatory when enablingpip.parse.experimental_index_urlfeature. This means thatrules_pythonwill attempt to fetch metadata for all packages through SimpleAPI unless they are pulled through direct URL references. Fixes #2023. In case you see issues withrules_pythonbeing too eager to fetch the SimpleAPI metadata, you can use the newly addedpip.parse.simpleapi_skipto skip metadata fetching for those packages.(uv) A
lockrule that is the replacement for thecompile_pip_requirements. This may still have rough corners so please report issues with it in the #1975. Main highlights - the locking can be done within a build action or outside it, there is no more automatictesttarget (but it can be added on the user side by usingnative_test). For customizing theuvversion that is used, please check theuv.configuretag class.Add support for riscv64 linux platform.
(toolchains) Add python 3.13.2 and 3.12.9 toolchains
(providers) (experimental)
PyInfo.site_packages_symlinksfield added to allow specifying links to create within the venv site packages (only applicable with--bootstrap_impl=script) (#2156).(toolchains) Local Python installs can be used to create a toolchain equivalent to the standard toolchains. See [Local toolchains] docs for how to configure them.
(toolchains) Expose
$(PYTHON2_ROOTPATH)and$(PYTHON3_ROOTPATH)which are runfiles locations equivalents of$(PYTHON2)and `$(PYTHON3) respectively.
Removed
Nothing removed.
1.3.0 - 2025-03-27
Changed
(deps) platforms 0.0.4 -> 0.0.11
(py_wheel) Package
py_library.pyi_srcs(.pyifiles) in the wheel.(py_package) Package
py_library.pyi_srcs(.pyifiles) inpy_package.(gazelle) The generated manifest file (default:
gazelle_python.yaml) will now include the YAML document start---line. Implemented in #2656.
Fixed
(pypi) The
ppc64leis now pointing to the right target in theplatformspackage.(gazelle) No longer incorrectly merge
py_binarytargets during partial updates infilegeneration mode. Fixed in #2619.(bzlmod) Running as root is no longer an error.
ignore_root_user_error=Trueis now the default. Note that running as root may still cause spurious Bazel cache invalidation (#1169).(gazelle) Don’t collapse depsets to a list or into args when generating the modules mapping file. Support spilling modules mapping args into a params file.
(coverage) Fix missing files in the coverage report if they have no tests.
(pypi) From now on
pythoninvocations in repository and module extension evaluation contexts will invoke Python interpreter with-Bto avoid creating.pycfiles.(deps) doublestar 4.7.1 (required for recent Gazelle versions)
Added
(python)
python.defaultshas been added to allow users to set the default python version in the root module by reading the default version number from a file or an environment variable.//python/bin:python: convenience target for directly running an interpreter.--//python/bin:python_srccan be used to specify a binary whose interpreter to use.(uv) Now the extension can be fully configured via
bzlmodAPIs without the need to patchrules_python. The documentation has been added torules_pythondocs but usage of the extension may result in your setup breaking without any notice. What is more, the URLs and SHA256 values will be retrieved from the GitHub releases page metadata published by theuvproject.(pypi) An extra argument to add the interpreter lib dir to
LDFLAGSwhen building wheels fromsdist.(pypi) Direct HTTP urls for wheels and sdists are now supported when using
experimental_index_url(bazel downloader). Partially fixes #2363.(rules) APIs for creating custom rules based on the core py_binary, py_test, and py_library rules (#1647)
(rules) Added env-var to allow additional interpreter args for stage1 bootstrap. See
RULES_PYTHON_ADDITIONAL_INTERPRETER_ARGSenvironment variable. Only applicable for--bootstrap_impl=script.(rules) Added
interpreter_argsattribute topy_binaryandpy_test, which allows pass arguments to the interpreter before the regular args.(rules) Added
main_moduleattribute topy_binaryandpy_test, which allows specifying a module name to run (i.e.python -m <module>).
Removed
Nothing removed.
1.2.0 - 2025-02-21
Changed
(rules)
py_proto_libraryis deprecated in favour of the implementation in https://github.com/protocolbuffers/protobuf. It will be removed in the future release.(pypi)
pip.overridewill now be ignored instead of raising an error, fixes #2550.(rules) deprecation warnings for deprecated symbols have been turned off by default for now and can be enabled with
RULES_PYTHON_DEPRECATION_WARNINGSenv var.(pypi) Downgraded versions of packages:
pipfrom24.3.2to24.0.0andpackagingfrom24.2to24.0.
Fixed
(rules)
python_zip_fileoutput with--bootstrap_impl=scriptworks again (#2596).(docs) Using
python_versionattribute for specifying python versions introduced inv1.1.0(gazelle) Providing multiple input requirements files to
gazelle_python_manifestnow works correctly.(pypi) Handle trailing slashes in pip index URLs in environment variables, fixes #2554.
(runfiles) Runfile manifest and repository mapping files are now interpreted as UTF-8 on all platforms.
(coverage) Coverage with
--bootstrap_impl=scriptis fixed (#2572).(pypi) Non deterministic behaviour in requirement file usage has been fixed by reverting #2514. The related issue is #908.
(sphinxdocs) Do not crash when
tag_classdoes not have a populateddocvalue. Fixes (#2579).(binaries/tests) Fix packaging when using
--bootstrap_impl=script: set--venvs_use_declare_symlink=noto have it not create symlinks at build time (they will be created at runtime instead). (Fixes #2489)
Added
Nothing added.
Removed
Nothing removed.
1.1.0 - 2025-01-07
Changed
(toolchains) 3.13 means 3.13.1 (previously 3.13.0)
Bazel 6 support is dropped and Bazel 7.4.1 is the minimum supported version, per our Bazel support matrix. Earlier versions are not tested by CI, so functionality cannot be guaranteed.
(
pip.parse) From now we will make fewer calls to indexes when fetching the metadata from SimpleAPI. The calls will be done in parallel to each index separately, so the extension evaluation time might slow down if not usingpip.parse.experimental_index_url_overrides.(
pip.parse) Only query SimpleAPI for packages that have sha values in therequirements.txtfile.(rules) The version-aware rules have been folded into the base rules and the version-aware rules are now simply aliases for the base rules. The
python_versionattribute is still used to specify the Python version.(pypi) Updated versions of packages:
pipto 24.3.1 andpackagingto 24.2.
Deprecations
//python/config_settings:transitions.bzland itspy_binaryandpy_testwrappers are deprecated. Use the regular rules instead.
Fixed
(py_wheel) Use the default shell environment when building wheels to allow toolchains that search PATH to be used for the wheel builder tool.
(pypi) The requirement argument parsed to
whl_librarywill now not have env marker information allowingbazel queryto work in cases where thewhlis available for all of the platforms and the sdist can be built. This fix is for both WORKSPACE andbzlmodsetups. Fixes #2450.(gazelle) Gazelle will now correctly parse Python3.12 files that use PEP 695 Type Parameter Syntax. (#2396)
(pypi) Using
pip_parse.experimental_requirement_cyclesandpip_parse.use_hub_alias_dependenciestogether now works when using WORKSPACE files.(pypi) The error messages when the wheel distributions do not match anything are now printing more details and include the currently active flag values. Fixes #2466.
(py_proto_library) Fix import paths in Bazel 8.
(whl_library) Now the changes to the dependencies are correctly tracked when PyPI packages used in
whl_libraryduring the repository rule phase change. Fixes #2468.
(gazelle) Gazelle no longer ignores
setup.pyfiles by default. To restore this behavior, apply the# gazelle:python_ignore_files setup.pydirective.
Don’t re-fetch whl_library, python_repository, etc. repository rules whenever
PATHchanges. Fixes #2551.
Added
(gazelle) Added
include_stub_packagesflag tomodules_mapping. When set toTrue, this automatically includes corresponding stub packages for third-party libraries that are present and used (e.g.,boto3→boto3-stubs), improving type-checking support.(pypi) Freethreaded packages are now fully supported in the
experimental_index_urlusage or the regularpip.parseusage. To select the free-threaded interpreter in the repo phase, please use the documented env variables. Fixes #2386.(toolchains) Use the latest astral-sh toolchain release 20241206 for Python versions:
3.9.21
3.10.16
3.11.11
3.12.8
3.13.1
(rules) Attributes for type definition files (
.pyifiles) and type-checking only dependencies added. Seepy_library.pyi_srcsandpy_library.pyi_deps(and the same named attributes forpy_binaryandpy_test).(pypi) pypi-generated targets set
pyi_srcsto include*.pyifiles.(providers)
PyInfohas new fields to aid static analysis tools:direct_original_sources,direct_pyi_files,transitive_original_sources,transitive_pyi_files.
Removed
find_requirementsin//python:defs.bzlhas been removed.
1.0.0 - 2024-12-05
Changed
Breaking:
(toolchains) stop exposing config settings in python toolchain alias repos. Please consider depending on the flags defined in
//python/config_setting/...and the@platformspackage instead.(toolchains) consumers who were depending on the
MACOS_NAMEand thearchattribute in thePLATFORMSlist, please update your code to respect the new values. The values now correspond to the values available in the@platforms//package constraint values.(toolchains)
host_platformandinterpreterconstants are no longer created in thetoolchaingenerated alias.bzlfiles. If you need to access the host interpreter during therepository_ruleevaluation, please use the@python_{version}_host//:pythontargets created bypython_register_toolchainsandpython_register_multi_toolchainsmacros or thepythonbzlmod extension.(bzlmod)
pip.parse.parse_all_requirements_filesattribute has been removed. See notes in the previous versions about what to do.(deps) rules_cc 0.1.0 (workspace) and 0.0.16 (bzlmod).
(deps) protobuf 29.0-rc2 (workspace; bzlmod already specifying that version).
Other changes:
(python_repository) Start honoring the
strip_prefixfield forzstdarchives.(pypi)
pip_parse.extra_hub_aliasesnow works in WORKSPACE files.(binaries/tests) For
--bootstrap_impl=script, a binary-specific (but otherwise empty) virtual env is used to customizesys.pathinitialization.(deps) bazel_skylib 1.7.0 (workspace; bzlmod already specifying that version)
(deps) bazel_features 1.21.0; necessary for compatibility with Bazel 8 rc3
(deps) stardoc 0.7.2 to support Bazel 8.
Fixed
(toolchains) stop depending on
unameto get the value of the host platform.(pypi): Correctly handle multiple versions of the same package in the requirements files which is useful when including different PyTorch builds (e.g. <pytorch+cpu> vs <pytorch+cu118> ) for different target platforms. Fixes (2337).
(uv): Correct the sha256sum for the
uvbinary for aarch64-apple-darwin. Fixes (2411).(binaries/tests) (
--bootstrap_impl=scipt) Usingsys.executablewill use the samesys.pathsetup as the calling binary. (2169).(workspace) Corrected protobuf’s name to com_google_protobuf, the name is hardcoded in Bazel, WORKSPACE mode.
(pypi):
compile_pip_requirementsno longer fails on Windows when--enable_runfilesis not enabled.(pypi):
compile_pip_requirementsnow correctly updates files in the source tree on Windows when--windows_enable_symlinksis not enabled.(repositories): Add libs/python3.lib and pythonXY.dll to the
libpythontarget defined by a repository template. This enables stable ABI builds of Python extensions on Windows (by defining Py_LIMITED_API).(rules)
py_testandpy_binarytargets no longer incorrectly remove the firstsys.pathentry when using--bootstrap_impl=script
Added
(gazelle): Parser failures will now be logged to the terminal. Additional details can be logged by setting
RULES_PYTHON_GAZELLE_VERBOSE=1.(toolchains) allow users to select which variant of the support host toolchain they would like to use through
RULES_PYTHON_REPO_TOOLCHAIN_{VERSION}_{OS}_{ARCH}env variable setting. For example, this allows one to usefreethreadedpython interpreter in therepository_ruleto build a wheel fromsdist.(toolchain) The python interpreters targeting
muslclibc have been added for the latest toolchain versions for each minor Python version. You can control the toolchain selection by using the//python/config_settings:py_linux_libcbuild flag.(providers) Added
PyRuntimeInfo.site_init_templateandPyRuntimeInfo.site_init_templatefor specifying the template to use to initialize the interpreter via venv startup hooks.(runfiles) (Bazel 7.4+) Added support for spaces and newlines in runfiles paths
Removed
(pypi): Remove
pypi_install_dependenciesmacro that has been included inpy_repositoriesfor a long time.(bzlmod): Remove
DEFAULT_PYTHON_VERSIONfrominterpreters.bzlfile. If you need the version, please use it from theversions.bzlfile instead.
0.40.0 - 2024-11-17
Changed
Nothing changed.
Fixed
(rules) Don’t drop custom import paths if Bazel-builtin PyInfo is removed. (2414).
Added
Nothing added.
Removed
(publish) Remove deprecated
requirements.txtfor thetwinedependencies. Please userequirements_linux.txtinstead.(python_repository) Use bazel’s built in
zstdsupport and remove attributes for customizing thezstdbinary to be used forzstdarchives in thepython_repositoryrepository_rule. This affects thepython_register_toolchainsandpython_register_multi_toolchainscallers in theWORKSPACE.
0.39.0 - 2024-11-13
Changed
(deps) bazel_skylib 1.6.1 -> 1.7.1
(deps) rules_cc 0.0.9 -> 0.0.14
(deps) protobuf 24.4 -> 29.0-rc2
(deps) rules_proto 6.0.0-rc1 -> 6.0.2
(deps) stardoc 0.6.2 -> 0.7.1
For bzlmod, Bazel 7.4 is now the minimum Bazel version.
(toolchains) Use the latest indygreg toolchain release 20241016 for Python versions:
3.9.20
3.10.15
3.11.10
3.12.7
3.13.0
(pypi) The naming scheme for the
bzlmodspoke repositories have changed as all of the givenrequirements.txtfiles are now parsed bydefault, to temporarily restore the behavior, you can usepip.parse.extra_hub_aliases, which will be removed or made noop in the future.
Fixed
(precompiling) Skip precompiling (instead of erroring) if the legacy
@bazel_tools//tools/python:autodetecting_toolchainis being used (#2364).
Added
Bazel 8 is now supported.
(toolchain) Support for freethreaded Python toolchains is now available. Use the config flag
//python/config_settings:py_freethreadedto toggle the selection of the free-threaded toolchains.(toolchain)
py_runtime.abi_flagsattribute andPyRuntimeInfo.abi_flagsfield added.
Removed
Support for Bazel 6 using bzlmod has been dropped.
0.38.0 - 2024-11-08
Changed
(deps) (WORKSPACE only) rules_cc 0.0.13 and protobuf 27.0 is now the default version used; this for Bazel 8+ support (previously version was rules_cc 0.0.9 and no protobuf version specified) (2310).
(publish) The dependencies have been updated to the latest available versions for the
twinepublishing rule.(whl_library) Remove
--no-build-isolationto allow non-hermetic sdist builds by default. Users wishing to keep this argument and to enforce more hermetic builds can do so by passing the argument inpip.parse#extra_pip_args(pip.parse)
pip.parse.whl_modificationsnow normalizes the given whl names and nowpyyamlandPyYAMLwill both work.(bzlmod)
pip.parsespoke repository naming will be changed in an upcoming release in places where the users specify different package versions per platform in the same hub repository. The naming of the spoke repos is considered an implementation detail and we advise the users to use thehubrepository directly and make use ofpip.parse.extra_hub_aliasesfeature added in this release.
Fixed
(pypi) (Bazel 7.4+) Allow spaces in filenames included in
whl_librarys (617).(pypi) When
pip.parse.experimental_index_urlis set, we need to still pass theextra_pip_argsvalue when building ansdist.(pypi) The patched wheel filenames from now on are using local version specifiers which fixes usage of the said wheels using standard package managers.
(bzlmod) The extension evaluation has been adjusted to always generate the same lock file irrespective if
experimental_index_urlis set by any module or not. To opt into this behavior, setpip.parse.parse_all_requirements_files, which will become the default in future releases leading up to1.0.0. Fixes #2268. A known issue is that it may breakbazel queryand in these use cases it is advisable to usecqueryor switch todownload_only = True
Added
(publish) The requirements file for the
twinepublishing rules have been updated to have a new convention:requirements_darwin.txt,requirements_linux.txt,requirements_windows.txtfor each respective OS and one extra filerequirements_universal.txtif you prefer a single file. Therequirements.txtfile may be removed in the future.The rules_python version is now reported in
//python/features.bzl#features.version(pip.parse)
pip.parse.extra_hub_aliasescan now be used to expose extra targets created by annotations in whl repositories. Fixes #2187.(bzlmod)
pip.parsenow supportswhl-onlysetup usingdownload_only = Truewhere users can specify multiple requirements files and use thepipbackend to do the downloading. This was only available for users settingpip.parse.experimental_index_url, but now users have more options whilst we continue to work on stabilizing the experimental feature.
0.37.2 - 2024-10-27
Fixed
(bzlmod) Generate
config_settingvalues for all available toolchains instead of only the registered toolchains, which restores the previous behaviour thatbzlmodusers would have observed.
0.37.1 - 2024-10-22
Fixed
(rules) Setting
--incompatible_python_disallow_native_rulesno longer causes rules_python rules to fail (#2326).
0.37.0 - 2024-10-18
Changed
BREAKING
py_libraryno longer puts its source files or generated pyc files in runfiles; it’s the responsibility of consumers (e.g. binaries) to populate runfiles with the necessary files. Adding source files to runfiles can be temporarily restored by setting--add_srcs_to_runfiles=enabled, but this flag will be removed in a subsequent releases.PyInfo.transitive_sourcesis now added to runfiles. These files are.pyfiles that are required to be added to runfiles by downstream binaries (or equivalent).(toolchains)
py_runtime.implementation_namenow defaults tocpython(previously it defaulted to None).(toolchains) The exec tools toolchain is enabled by default. It can be disabled by setting
--@rules_python//python/config_settings:exec_tools_toolchain=disabled.(deps) stardoc 0.6.2 added as dependency.
Fixed
(bzlmod) The
python.override(minor_mapping)now merges the default and the overridden versions ensuring that the resultantminor_mappingwill always have all of the python versions.(bzlmod) The default value for the
--python_versionflag will now be always set to the default python toolchain version value.(bzlmod) correctly wire the
pip.parse.extra_pip_argsall the way towhl_library. What is more we will pass theextra_pip_argstowhl_libraryforsdistdistributions when usingpip.parse.experimental_index_url. See #2239.(whl_filegroup): Provide per default also the
RECORDfile(py_wheel):
RECORDfile entry elements are now quoted if necessary when a wheel is created(whl_library) truncate progress messages from the repo rule to better handle case where a requirement has many
--hash=sha256:...flags(rules)
compile_pip_requirementspassesenvto theX.updatetarget (and not only to theX_testtarget, a bug introduced in #1067).(bzlmod) In hybrid bzlmod with WORKSPACE builds,
python_register_toolchains(register_toolchains=True)is respected (#1675).(precompiling) The
pyc_collectionattribute now correctly enables (or disables) using pyc files from targets transitively(pip) Skip patching wheels not matching
pip.override’sfile(#2294).(chore): Add a
rules_shelldev dependency and moved ash_testtarget outside of the//:BUILD.bazelfile. Fixes #2299.
Added
(py_wheel) Now supports
compress = (True|False)to allow disabling compression to speed up development.(toolchains): A public
//python/config_settings:python_version_major_minorhas been exposed for users to be able to match on theX.Yversion of a Python interpreter.(api) Added
merge_py_infos()so user rules can merge and propagatePyInfowithout losing information.(toolchains) New Python versions available: 3.13.0 using the 20241008 release.
(toolchains): Bump default toolchain versions to:
3.8 -> 3.8.203.9 -> 3.9.203.10 -> 3.10.153.11 -> 3.11.103.12 -> 3.12.7
(coverage) Add support for python 3.13 and bump
coverage.pyto 7.6.1.(bzlmod) Add support for
download_onlyflag to disable usage ofsdistswhenpip.parse.experimental_index_urlis set.(api) PyInfo fields:
PyInfo.transitive_implicit_pyc_files,PyInfo.transitive_implicit_pyc_source_files.
Removed
(precompiling)
--precompile_add_to_runfileshas been removed.(precompiling)
--pyc_collectionhas been removed. Thepyc_collectionattribute now bases its default on--precompile.(precompiling) The
precompile=if_generated_sourcevalue has been removed.(precompiling) The
precompile_source_retention=omit_if_generated_sourcevalue has been removed.
0.36.0 - 2024-09-24
Changed
(gazelle): Update error messages when unable to resolve a dependency to be more human-friendly.
(flags) The
--python_versionflag now also returnsconfig_common.FeatureFlagInfo.(toolchain): The toolchain patches now expose the
patch_stripattribute that one should use when patching toolchains. Please set it if you are patching python interpreter. In the next release the default will be set to0which better reflects the defaults used in publicbazelAPIs.(toolchains) When
py_runtime.interpreter_version_infoisn’t specified, the--python_versionflag will determine the value. This allows specifying the build-time Python version for theruntime_env_toolchains.(toolchains)
py_cc_toolchain.libsandPyCcToolchainInfo.libsis optional. This is to support situations where only the Python headers are available.(bazel) Minimum bazel 7 version that we test against has been bumped to
7.1.
Fixed
(whl_library): Remove
--no-indexand add--no-build-isolationto thepip installcommand when installing a wheel from a local file, which happens whenexperimental_index_urlflag is used.(bzlmod) get the path to the host python interpreter in a way that results in platform non-dependent hashes in the lock file when the requirement markers need to be evaluated.
(bzlmod) correctly watch sources used for evaluating requirement markers for any changes so that the repository rule or module extensions can be re-evaluated when the said files change.
(gazelle): Fix incorrect use of
t.Fatal/t.Fatalfin tests.(toolchain) Omit third-party python packages from coverage reports from stage2 bootstrap template.
(bzlmod) Properly handle relative path URLs in parse_simpleapi_html.bzl
(gazelle) Correctly resolve deps that have top-level module overlap with a gazelle_python.yaml dep module
(rules) Make
RUNFILES_MANIFEST_FILE-based invocations work when used with--bootstrap_impl=script. This fixes invocations using non-sandboxed test execution with--enable_runfiles=false --build_runfile_manifests=true. (#2186).(py_wheel) Fix incorrectly generated
Required-Distwhen specifying requirements with markers in extra_requires in py_wheel rule.(rules) Prevent pytest from trying run the generated stage2 bootstrap .py file when using
--bootstrap_impl=script(toolchain) The
gen_python_config_settingshas been fixed to include the flag_values from the platform definitions.
Added
(bzlmod): Toolchain overrides can now be done using the new
python.override,python.single_version_overrideandpython.single_version_platform_overridetag classes. See #2081.(rules) Executables provide
PyExecutableInfo, which contains executable-specific information useful for packaging an executable or or deriving a new one from the original.(py_wheel) Removed use of bash to avoid failures on Windows machines which do not have it installed.
(docs) Automatically generated documentation for
python_register_toolchainsand related symbols.(toolchains) Added
python_repository.patch_stripattribute for allowing values that are other than1, which has been hard-coded up until now. If you are relying on the undocumentedpatchessupport inTOOL_VERSIONSfor registering patched toolchains please consider setting thepatch_stripexplicitly to1if you depend on this value - in the future the value may change to default to0.(toolchains) Added
//python:none, a special target for use withpy_exec_tools_toolchain.exec_interpreterto treat the value asNone.
Removed
(toolchains): Removed accidentally exposed
http_archivesymbol frompython/repositories.bzl.(toolchains): An internal is_python_config_setting macro has been removed.
0.35.0 - 2024-08-15
Changed
(whl_library) A better log message when the wheel is built from an sdist or when the wheel is downloaded using
download_onlyfeature to aid debugging.(gazelle): Simplify and make gazelle_python.yaml have only top level package name. It would work well in cases to reduce merge conflicts.
(toolchains): Change some old toochain versions to use 20240726 release to include dependency updates
3.8.19,3.9.19,3.10.14,3.11.9(toolchains): Bump default toolchain versions to:
3.12 -> 3.12.4
(rules)
PYTHONSAFEPATHis inherited from the calling environment to allow disabling it (Requires--bootstrap_impl=script) (#2060).
Fixed
(rules)
compile_pip_requirementsnow sets theUSERPROFILEenv variable on Windows to work around an issue wheresetuptoolsfails to locate the user’s home directory.(rules) correctly handle absolute URLs in parse_simpleapi_html.bzl.
(rules) Fixes build targets linking against
@rules_python//python/cc:current_py_cc_libsin host platform builds on macOS, by editing theLC_ID_DYLIBfield of the hermetic interpreter’slibpython3.x.dylibusinginstall_name_tool, setting it to its absolute path under Bazel’s execroot.(rules) Signals are properly received when using
--bootstrap_impl=script(for non-zip builds). (#2043)(rules) Fixes Python builds when the
--build_python_zipis set tofalseon Windows. See #1840.(rules) Fixes Mac +
--build_python_zip+--bootstrap_impl=script(#2030).(rules) User dependencies come before runtime site-packages when using
--bootstrap_impl=script. (#2064).(rules) Version-aware rules now return both
@_builtinsand@rules_pythonproviders instead of only one. (#2114).(pip) Fixed pypi parse_simpleapi_html function for feeds with package metadata containing “>” sign
(toolchains) Added missing executable permission to
//python/runtime_env_toolchainsinterpreter script so that it is runnable. (#2085).(pip) Correctly use the
sdistdownloaded by the bazel downloader when usingexperimental_index_urlfeature. Fixes #2091.(gazelle) Make
gazelle_python_manifest.updatemanual to avoid unnecessary network behavior.(bzlmod): The conflicting toolchains during
pythonextension will no longer cause warnings by default. In order to see the warnings for diagnostic purposes set the env varRULES_PYTHON_REPO_DEBUG_VERBOSITYto one ofINFO,DEBUGorTRACE. Fixes #1818.(runfiles) Make runfiles lookups work for the situation of Bazel 7, Python 3.9 (or earlier, where safepath isn’t present), and the Rlocation call in the same directory as the main file. Fixes #1631.
Added
(rules)
compile_pip_requirementssupports multiple requirements input files assrcs.(rules)
PYTHONSAFEPATHis inherited from the calling environment to allow disabling it (Requires--bootstrap_impl=script) (#2060).(gazelle) Added
python_generation_mode_per_package_require_test_entry_pointin order to better accommodate users who use a custom macro,pytest-bazel, rules_python_pytest orrules_pypy_test_main in order to integrate withpytest. Currently the default flag value is set totruefor backwards compatible behaviour, but in the future the flag will be flipped befalseby default.(toolchains) New Python versions available:
3.12.4using the 20240726 release.(pypi) Support env markers in requirements files. Note, that this means that if your requirements files contain env markers, the Python interpreter will need to be run during bzlmod phase to evaluate them. This may incur downloading an interpreter (for hermetic-based builds) or cause non-hermetic behavior (if using a system Python).
0.34.0 - 2024-07-04
Changed
protobuf/com_google_protobufdependency bumped tov24.4(bzlmod): optimize the creation of config settings used in pip to reduce the total number of targets in the hub repo.
(toolchains) The exec tools toolchain now finds its interpreter by reusing the regular interpreter toolchain. This avoids having to duplicate specifying where the runtime for the exec tools toolchain is.
(toolchains) (
//python:autodetecting_toolchain) is deprecated. It is replaced by//python/runtime_env_toolchains:all. The old target will be removed in a future release.
Fixed
(bzlmod): When using
experimental_index_urltheall_requirements,all_whl_requirementsandall_data_requirementswill now only include common packages that are available on all target platforms. This is to ensure that packages that are only present for some platforms are pulled only via thedepsof the materializedpy_library. If you would like to include platform specific packages, using aselectstatement with references to the specific package will still work (e.g.my_attr = all_requirements + select( { "@platforms//os:linux": ["@pypi//foo_available_only_on_linux"], "//conditions:default": [], } )
(bzlmod): Targets in
all_requirementsnow use the same form as targets returned by therequirementmacro.(rules) Auto exec groups are enabled. This allows actions run by the rules, such as precompiling, to pick an execution platform separately from what other toolchains support.
(providers)
PyRuntimeInfodoesn’t require passing theinterpreter_version_infoarg.(bzlmod) Correctly pass
isolated,quietandtimeoutvalues towhl_libraryand drop the defaults from the lock file.(whl_library) Correctly handle arch-specific dependencies when we encounter a platform specific wheel and use
experimental_target_platforms. Fixes #1996.(rules) The first element of the default outputs is now the executable again.
(pip) Fixed crash when pypi packages lacked a sha (e.g. yanked packages)
Added
(toolchains)
//python/runtime_env_toolchains:all, which is a drop-in replacement for the “autodetecting” toolchain.(gazelle) Added new
python_label_conventionandpython_label_normalizationdirectives. These directive allows altering default Gazelle label format to third-party dependencies useful for re-using Gazelle plugin with other rules, includingrules_pycross. See #1939.
Removed
(pip): Removes the
entrypointmacro that was replaced bypy_console_script_binaryin 0.26.0.
0.33.2 - 2024-06-13
Fixed
(toolchains) The
exec_tools_toolchain_typeis disabled by default. To enable it, set--//python/config_settings:exec_tools_toolchain=enabled. This toolchain must be enabled for precompilation to work. This toolchain will be enabled by default in a future release. Fixes #1967.
0.33.1 - 2024-06-13
Fixed
(py_binary) Fix building of zip file when using
--build_python_zipargument. Fixes #1954.
0.33.0 - 2024-06-12
Changed
(deps) Upgrade the
pip_installdependencies to pick up a new version of pip.(toolchains) Optional toolchain dependency:
py_binary,py_test, andpy_librarynow depend on the//python:exec_tools_toolchain_typefor build tools.(deps): Bumped
bazel_skylibto 1.6.1.(bzlmod): The
pythonand internalrules_pythonextensions have been marked asreproducibleand will not include any lock file entries from now on.(gazelle): Remove gazelle plugin’s python deps and make it hermetic. Introduced a new Go-based helper leveraging tree-sitter for syntax analysis. Implemented the use of
pypi/stdlib-listfor standard library module verification.(pip.parse): Do not ignore yanked packages when using
experimental_index_url. This is to mimic whatuvis doing. We will print a warning instead.(pip.parse): Add references to all supported wheels when using
experimental_index_urlto allowing to correctly fetch the wheels for the right platform. See the updated docs on how to use the feature. This is work towards addressing #735 and #260. The spoke repository names when using this flag will have a structure of{pip_hub_prefix}_{wheel_name}_{py_tag}_{abi_tag}_{platform_tag}_{sha256}, which is an implementation detail which should not be relied on and is there purely for better debugging experience.(bzlmod) The
pythons_hub//:interpreters.bzlno longer has platform-specific labels which where left there for compatibility reasons. Move topython_{version}_hostkeys if you would like to have access to a Python interpreter that can be used in a repository rule context.
Fixed
(gazelle) Remove
visibilityfromNonEmptyAttr. Now empty(have nodeps/main/srcs/importsattr)py_library/test/binaryrules will be automatically deleted correctly. For example, ifpython_generation_modeis set to package, when__init__.pyis deleted, thepy_librarygenerated for this package before will be deleted automatically.(whl_library): Use is_python_config_setting to correctly handle multi-python version dependency select statements when the
experimental_target_platformsincludes the Python ABI. The default python version case within the select is also now handled correctly, stabilizing the implementation.(gazelle) Fix Gazelle failing on Windows with “panic: runtime error: invalid memory address or nil pointer dereference”
(bzlmod) remove
pip.parse(annotations)attribute as it is unused and has been replaced by whl_modifications.(pip) Correctly select wheels when the python tag includes minor versions. See (#1930)
(pip.parse): The lock file is now reproducible on any host platform if the
experimental_index_urlis not used by any of the modules in the dependency chain. To make the lock file identical on eachosandarch, please use theexperimental_index_urlfeature which will fetch metadata from PyPI or a different private index and write the contents to the lock file. Fixes #1643.(pip.parse): Install
yankedpackages and print a warning instead of ignoring them. This better matches the behaviour ofuv pip install.(toolchains): Now matching of the default hermetic toolchain is more robust and explicit and should fix rare edge-cases where the host toolchain autodetection would match a different toolchain than expected. This may yield to toolchain selection failures when the python toolchain is not registered, but is requested via
//python/config_settings:python_versionflag setting.(doc) Fix the
WORKSPACErequirement vendoring example. Fixes #1918.
Added
(rules) Precompiling Python source at build time is available. but is disabled by default, for now. Set
@rules_python//python/config_settings:precompile=enabledto enable it by default. A subsequent release will enable it by default. See the Precompiling docs and API reference docs for more information on precompiling. Note this requires Bazel 7+ and the Pystar rule implementation enabled. (#1761)(rules) Attributes and flags to control precompile behavior:
precompile,precompile_optimize_level,precompile_source_retention,precompile_invalidation_mode, andpyc_collection(toolchains) The target runtime toolchain (
//python:toolchain_type) has two new optional attributes:pyc_tag(tells the pyc filename infix to use) andimplementation_name(tells the Python implementation name).(toolchains) A toolchain type for build tools has been added:
//python:exec_tools_toolchain_type.(providers)
PyInfohas two new attributes:direct_pyc_filesandtransitive_pyc_files, which tell the pyc files a target makes available directly and transitively, respectively.//python:features.bzladded to allow easy feature-detection in the future.(pip) Allow specifying the requirements by (os, arch) and add extra validations when parsing the inputs. This is a non-breaking change for most users unless they have been passing multiple
requirements_*files together withextra_pip_args = ["--platform=manylinux_2_4_x86_64"], that was an invalid usage previously but we were not failing the build. From now on this is explicitly disallowed.(toolchains) Added riscv64 platform definition for python toolchains.
(gazelle) The
python_visibilitydirective now supports the$python_root$placeholder, just like thepython_default_visibilitydirective does.(rules) A new bootstrap implementation that doesn’t require a system Python is available. It can be enabled by setting
--@rules_python//python/config_settings:bootstrap_impl=script. It will become the default in a subsequent release. (#691)(providers)
PyRuntimeInfohas two new attributes:PyRuntimeInfo.stage2_bootstrap_templateandPyRuntimeInfo.zip_main_template.(toolchains) A replacement for the Bazel-builtn autodetecting toolchain is available. The
//python:autodetecting_toolchainalias now uses it.(pip): Support fetching and using the wheels for other platforms. This supports customizing whether the linux wheels are pulled for
muslorglibc, whetheruniversal2or arch-specific MacOS wheels are preferred and it also allows to select a particularlibcversion. All of this is done via thestring_flagsin@rules_python//python/config_settings. If there are no wheels that are supported for the target platform,rules_pythonwill fallback onto building thesdistfrom source. This behaviour can be disabled if desired using one of the available string flags as well.(whl_filegroup) Added a new
whl_filegrouprule to extract files from a wheel file. This is useful to extract headers for use in acc_library.
0.32.2 - 2024-05-14
Fixed
0.32.0 - 2024-05-12
Changed
(bzlmod): The
MODULE.bazel.lockwhl_libraryrule attributes are now sorted in the attributes section. We are also removing values that are not default in order to reduce the size of the lock file.(coverage) Bump
coverage.pyto 7.4.3.(deps): Bumped
bazel_featuresto 1.9.1 to detect optional support non-blocking downloads.(deps): Updated
pip_toolsto >= 7.4.0(toolchains): Change some old toolchain versions to use 20240224 release to include security fixes
3.8.18,3.9.18and3.10.13(toolchains): Bump default toolchain versions to:
3.8 -> 3.8.193.9 -> 3.9.193.10 -> 3.10.143.11 -> 3.11.93.12 -> 3.12.3
Fixed
(whl_library): Fix the experimental_target_platforms overriding for platform specific wheels when the wheels are for any python interpreter version. Fixes #1810.
(whl_library): Stop generating duplicate dependencies when encountering duplicates in the METADATA. Fixes #1873.
(gazelle) In
projectorpackagegeneration modes, do not generatepy_testrules when there are no test files and do not setmain = "__test__.py"when that file doesn’t exist.(whl_library) The group redirection is only added when the package is part of the group potentially fixing aspects that want to traverse a
py_librarygraph. Fixes #1760.(bzlmod) Setting a particular micro version for the interpreter and the
pip.parseextension is now possible, see theexamples/pip_parse/MODULE.bazelfor how to do it. See #1371.(refactor) The pre-commit developer workflow should now pass
isortandblackchecks (see #1674).
Added
(toolchains) Added armv7 platform definition for python toolchains.
(toolchains) New Python versions available:
3.11.8,3.12.2using the 20240224 release.(toolchains) New Python versions available:
3.8.19,3.9.19,3.10.14,3.11.9,3.12.3using the 20240415 release.(gazelle) Added a new
python_visibilitydirective to control visibility of generated targets by appending additional visibility labels.(gazelle) Added a new
python_default_visibilitydirective to control the default visibility of generated targets. See the docs for details.(gazelle) Added a new
python_test_file_patterndirective. This directive tells gazelle which python files should be mapped to thepy_testrule. See the original issue and the docs for details.(wheel) Add support for
data_filesattributes in py_wheel rule (#1777)(py_wheel)
bzlmodinstallations now provide atwinesetup for the default Python toolchain inrules_pythonfor version 3.11.(bzlmod) New
experimental_index_url,experimental_extra_index_urlsandexperimental_index_url_overridestopip.parsefor using the bazel downloader. If you see any issues, report in #1357. The URLs for the whl and sdist files will be written to the lock file. Controlling whether the downloading of metadata is done in parallel can be done usingparallel_downloadattribute.(gazelle) Add a new annotation
include_dep. Also add documentation for annotations togazelle/README.md.(deps):
rules_pythondepends now onrules_cc0.0.9(pip_parse): A new flag
use_hub_alias_dependencieshas been added that is going to become default in the next release. This makes use ofdep_templateflag in thewhl_libraryrule. This also affects theexperimental_requirement_cyclesfeature where the dependencies that are in a group would be only accessible via the hub repo aliases. If you still depend on legacy labels instead of the hub repo aliases and you use theexperimental_requirement_cycles, now is a good time to migrate.
0.31.0 - 2024-02-12
Changed
For Bazel 7, the core rules and providers are now implemented in rules_python directly and the rules bundled with Bazel are not used. Bazel 6 and earlier continue to use the Bazel builtin symbols. Of particular note, this means, under Bazel 7, the builtin global symbol
PyInfois not the same as what is loaded from rules_python. The same is true ofPyRuntimeInfo.
0.30.0 - 2024-02-12
Changed
(toolchains) Windows hosts always ignore pyc files in the downloaded runtimes. This fixes issues due to pyc files being created at runtime and affecting the definition of what files were considered part of the runtime.
(pip_parse) Added the
envsubstparameter, which enables environment variable substitutions in theextra_pip_argsattribute.(pip_repository) Added the
envsubstparameter, which enables environment variable substitutions in theextra_pip_argsattribute.
Fixed
(bzlmod) pip.parse now does not fail with an empty
requirements.txt.(py_wheel) Wheels generated by
py_wheelnow preserve executable bits when being extracted byinstallerand/orpip.(coverage) During the running of lcov, the stdout/stderr was causing test failures. By default, suppress output when generating lcov. This can be overridden by setting ‘VERBOSE_COVERAGE’. This change only affect bazel 7.x.x and above.
(toolchain) Changed the
host_toolchainto symlink all files to support Windows host environments without symlink support.(PyRuntimeInfo) Switch back to builtin PyRuntimeInfo for Bazel 6.4 and when pystar is disabled. This fixes an error about
target ... does not have ... PyRuntimeInfo. (#1732)
Added
(py_wheel) Added
requires_fileandextra_requires_filesattributes.(whl_library) experimental_target_platforms now supports specifying the Python version explicitly and the output
BUILD.bazelfile will be correct irrespective of the python interpreter that is generating the file and extracting thewhldistribution. Multiple python target version can be specified and the code generation will generate version specific dependency closures but that is not yet ready to be used and may break the build if the default python version is not selected usingcommon --@rules_python//python/config_settings:python_version=X.Y.Z.New Python versions available:
3.11.7,3.12.1using https://github.com/indygreg/python-build-standalone/releases/tag/20240107.(toolchain) Allow setting
x.yas thepython_versionparameter in the version-awarepy_binaryandpy_testrules. This allows users to use the same rule import for testing with specific Python versions and rely on toolchain configuration and how the latest version takes precedence if e.g.3.8is selected. That also simplifies.bazelrcfor any users that set the defaultpython_versionstring flag in that way.(toolchain) The runtime’s shared libraries (libpython.so et al) can be accessed using
@rules_python//python/cc:current_py_cc_libs. This uses toolchain resolution, so the files are from the same runtime used to run a target. If you were previously using e.g.@python_3_11//:libpython, then switch to:current_py_cc_libsfor looser coupling to the underlying runtime repo implementation.(repo rules) The environment variable
RULES_PYTHON_REPO_DEBUG=1can be set to make repository rules log detailed information about what they’re up to.(coverage) Add support for python 3.12 and bump
coverage.pyto 7.4.1.
0.29.0 - 2024-01-22
Changed
BREAKING The deprecated
incompatible_generate_aliasesfeature flags frompip_parseandgazellegot removed. They had been flipped toTruein 0.27.0 release.BREAKING (wheel) The
incompatible_normalize_nameandincompatible_normalize_versionflags have been removed. They had been flipped toTruein 0.27.0 release.(bzlmod) The pip hub repository now uses the newly introduced config settings using the
X.Ypython version notation. This improves cross module interoperability and allows to share wheels built by interpreters using different patch versions.
Fixed
(bzlmod pip.parse) Use a platform-independent reference to the interpreter pip uses. This reduces (but doesn’t eliminate) the amount of platform-specific content in
MODULE.bazel.lockfiles; Follow #1643 for removing platform-specific content inMODULE.bazel.lockfiles.(wheel) The stamp variables inside the distribution name are no longer lower-cased when normalizing under PEP440 conventions.
Added
(toolchains)
python_register_toolchainsnow also generates a repository that is suffixed with_host, that has a single label:pythonthat is a symlink to the python interpreter for the host platform. The intended use is mainly inrepository_rule, which are always run usinghostplatform Python. This means thatWORKSPACEusers can now copy therequirements.bzlfile for vendoring as seen in the updatedpip_parse_vendoredexample.(runfiles)
rules_python.python.runfiles.Runfilesnow has a staticCreatemethod to make imports more ergonomic. Users should only need to import theRunfilesobject to locate runfiles.(toolchains)
PyRuntimeInfonow includes ainterpreter_version_infofield that contains the static version information for the given interpreter. This can be set viapy_runtimewhen registering an interpreter toolchain, and will done automatically for the builtin interpreter versions registered viapython_register_toolchains. Note that this only available on the Starlark implementation of the provider.(config_settings) Added
//python/config_settings:is_python_X.Yconfig settings to match on minor Python version. These settings match anyX.Yversion instead of just an exactX.Y.Zversion.
0.28.0 - 2024-01-07
Changed
BREAKING (pip_install) the deprecated
pip_installmacro and related items have been removed.BREAKING Support for Bazel 5 has been officially dropped. This release was only partially tested with Bazel 5 and may or may not work with Bazel 5. Subsequent versions will no longer be tested under Bazel 5.
(runfiles)
rules_python.python.runfilesnow directly implements type hints and drops support for python2 as a result.(toolchains)
py_runtime,py_runtime_pair, andPyRuntimeInfonow use the rules_python Starlark implementation, not the one built into Bazel. NOTE: This only applies to Bazel 6+; Bazel 5 still uses the builtin implementation.(pip_parse) The parameter
experimental_requirement_cyclesmay be provided a map of names to lists of requirements which form a dependency cycle.pip_parsewill break the cycle for you transparently. This behavior is also available under bzlmod aspip.parse(experimental_requirement_cycles={}).(toolchains)
py_runtimecan now take an executable target. Note: runfiles from the target are not supported yet. (#1612)(gazelle) When
python_generation_modeis set tofile, create onepy_binarytarget for each file withif __name__ == "__main__"instead of just onepy_binaryfor the whole module.(gazelle) the Gazelle manifest integrity field is now optional. If the
requirementsargument togazelle_python_manifestis unset, no integrity field will be generated.
Fixed
(gazelle) The gazelle plugin helper was not working with Python toolchains 3.11 and above due to a bug in the helper components not being on PYTHONPATH.
(pip_parse) The repositories created by
whl_librarycan now parse thewhlMETADATA and generate dependency closures irrespective of the host platform the generation is executed on. This can be turned on by supplyingexperimental_target_platforms = ["all"]to thepip_parseor thebzlmodequivalent. This may help in cases where fetching wheels for a different platform usingdownload_only = Truefeature.(bzlmod pip.parse) The
pip.parse(python_interpreter)arg now works for specifying a local system interpreter.(bzlmod pip.parse) Requirements files with duplicate entries for the same package (e.g. one for the package, one for an extra) now work.
(bzlmod python.toolchain) Submodules can now (re)register the Python version that rules_python has set as the default. (#1638)
(whl_library) Actually use the provided patches to patch the whl_library. On Windows the patching may result in files with CRLF line endings, as a result the RECORD file consistency requirement is lifted and now a warning is emitted instead with a location to the patch that could be used to silence the warning. Copy the patch to your workspace and add it to the list if patches for the wheel file if you decide to do so.
(coverage): coverage reports are now created when the version-aware rules are used. (#1600)
(toolchains) Workspace builds register the py cc toolchain (bzlmod already was). This makes e.g.
//python/cc:current_py_cc_headersJust Work. (#1669)(bzlmod python.toolchain) The value of
ignore_root_user_erroris now decided by the root module only. (#1658)
Added
(docs) bzlmod extensions are now documented on rules-python.readthedocs.io
(docs) Support and backwards compatibility policies have been documented. See https://rules-python.readthedocs.io/en/latest/support.html
(gazelle)
filegeneration mode can now also add__init__.pyto the srcs attribute for every target in the package. This is enabled through a separate directivepython_generation_mode_per_file_include_init.
0.27.0 - 2023-11-16
Changed
Make
//python/pip_install:pip_repository_bzlbzl_librarytarget internal as all of the publicly available symbols (etc.package_annotation) are re-exported via//python:pip_bzlbzl_library.(gazelle) Gazelle Python extension no longer has runtime dependencies. Using
GAZELLE_PYTHON_RUNTIME_DEPSfrom@rules_python_gazelle_plugin//:def.bzlis no longer necessary.(pip_parse) The installation of
pip_parserepository rule toolchain dependencies is now done as part ofpy_repositoriescall.(pip_parse) The generated
requirements.bzlfile now has an additional symbolall_whl_requirements_by_packagewhich provides a map from the normalized PyPI package name to the target that provides the built wheel file. Usepip_utils.normalize_namefunction from@rules_python//python:pip.bzlto convert a PyPI package name to a key in theall_whl_requirements_by_packagemap.(pip_parse) The flag
incompatible_generate_aliaseshas been flipped toTrueby default onnon-bzlmodsetups allowing users to use the same label strings during the transition period. For example, instead of@pypi_foo//:pkg, you can now use@pypi//fooor@pypi//foo:pkg. Other labels that are present in thefoopackage aredist_info,whlanddata. Note, that the@pypi_foo//:pkglabels are still present for backwards compatibility.(gazelle) The flag
use_pip_repository_aliasesis now set toTrueby default, which will causegazelleto change third-party dependency labels from@pip_foo//:pkgto@pip//fooby default.The
compile_pip_requirementsnow defaults topyproject.tomlif thesrcorrequirements_inattributes are unspecified, matching the upstreampip-compilebehaviour more closely.(gazelle) Use relative paths if possible for dependencies added through the use of the
resolvedirective.(gazelle) When using
python_generation_mode file, onepy_testtarget is made per test file even if a target named__test__or a file named__test__.pyexists in the same package. Previously in these cases there would only be one test target made.
Breaking changes:
(pip)
pip_installrepository rule in this release has been disabled and will fail by default. The API symbol is going to be removed in the next version, please migrate topip_parseas a replacement. Thepip_parserule no longer supportsrequirementsattribute, please userequirements_lockinstead.(py_wheel) switch
incompatible_normalize_nameandincompatible_normalize_versiontoTrueby default to enforcePEP440for wheel names built byrules_python.(tools/wheelmaker.py) drop support for Python 2 as only Python 3 is tested.
Fixed
Skip aliases for unloaded toolchains. Some Python versions that don’t have full platform support, and referencing their undefined repositories can break operations like
bazel query rdeps(...).Python code generated from
proto_librarywithstrip_import_prefixcan be imported now.(py_wheel) Produce deterministic wheel files and make
RECORDfile entries follow the order of files written to the.whlarchive.(gazelle) Generate a single
py_testtarget whengazelle:python_generation_mode projectis used.(gazelle) Move waiting for the Python interpreter process to exit to the shutdown hook to make the usage of the
exec.Commandmore idiomatic.(toolchains) Keep tcl subdirectory in Windows build of hermetic interpreter.
(bzlmod) sub-modules now don’t have the
//conditions:defaultclause in the hub repos created bypip.parse. This should fix confusing error messages in case there is a misconfiguration of toolchains or a bug inrules_python.
Added
(bzlmod) Added
.whlpatching support viapatchesandpatch_striparguments to the newpip.overridetag class.(pip) Support for using PEP621 compliant
pyproject.tomlfor creating a resolvedrequirements.txtfile.(utils) Added a
pip_utilsstruct with anormalize_namefunction to allow users to find out howrules_pythonwould normalize a PyPI distribution name.
0.26.0 - 2023-10-06
Changed
Python version patch level bumps:
3.8.15 -> 3.8.18
3.9.17 -> 3.9.18
3.10.12 -> 3.10.13
3.11.4 -> 3.11.6
(deps) Upgrade rules_go 0.39.1 -> 0.41.0; this is so gazelle integration works with upcoming Bazel versions
(multi-version) The
distribsattribute is no longer propagated. This attribute has been long deprecated by Bazel and shouldn’t be used.Calling
//python:repositories.bzl#py_repositories()is required. It has always been documented as necessary, but it was possible to omit it in certain cases. An error about@rules_python_internalmeans thepy_repositories()call is missing inWORKSPACE.(bzlmod) The
pip.parseextension will generate os/arch specific lock file entries onbazel>=6.4.
Added
(bzlmod, entry_point) Added
py_console_script_binary, which allows adding custom dependencies to a package’s entry points and customizing thepy_binaryrule used to build it.New Python versions available:
3.8.17,3.11.5using https://github.com/indygreg/python-build-standalone/releases/tag/20230826.(gazelle) New
# gazelle:python_generation_mode filedirective to support generating onepy_libraryper file.(python_repository) Support
netrcandauth_patternsattributes to enable authentication against private HTTP hosts serving Python toolchain binaries.//python:packaging_bzladded, abzl_libraryfor the Starlark files//python:packaging.bzlrequires.(py_wheel) Added the
incompatible_normalize_namefeature flag to normalize the package distribution name according to latest Python packaging standards. Defaults toFalsefor the time being.(py_wheel) Added the
incompatible_normalize_versionfeature flag to normalize the package version according to PEP440 standard. This also adds support for local version specifiers (versions with a+in them), in accordance with PEP440. Defaults toFalsefor the time being.New Python versions available:
3.8.18,3.9.18,3.10.13,3.11.6,3.12.0using https://github.com/indygreg/python-build-standalone/releases/tag/20231002.3.12.0support is considered beta and may have issues.
Removed
(bzlmod) The
entry_pointmacro is no longer supported and has been removed in favour of thepy_console_script_binarymacro forbzlmodusers.(bzlmod) The
pip.parseno longer generates{hub_name}_{py_version}hub repos as theentry_pointmacro has been superseded bypy_console_script_binary.(bzlmod) The
pip.parseno longer generates{hub_name}_{distribution}hub repos.
Fixed
(whl_library) No longer restarts repository rule when fetching external dependencies improving initial build times involving external dependency fetching.
(gazelle) Improve runfiles lookup hermeticity.
0.25.0 - 2023-08-22
Changed
Python version patch level bumps:
3.9.16 -> 3.9.17
3.10.9 -> 3.10.12
3.11.1 -> 3.11.4
(bzlmod)
pip.parsecan no longer automatically use the default Python version; this was an unreliable and unsafe behavior. Thepython_versionarg must always be explicitly specified.
Fixed
(docs) Update docs to use correct bzlmod APIs and clarify how and when to use various APIs.
(multi-version) The
mainarg is now correctly computed and usually optional.(bzlmod)
pip.parseno longer requires a call for whatever the configured default Python version is.
Added
Created a changelog.
(gazelle) Stop generating unnecessary imports.
(toolchains) s390x supported for Python 3.9.17, 3.10.12, and 3.11.4.
0.24.0 - 2023-07-11
Changed
BREAKING (gazelle) Gazelle 0.30.0 or higher is required
(bzlmod)
@python_aliasesrenamed to `@python_versions(bzlmod)
pip.parseargnamerenamed tohub_name(bzlmod)
pip.parseargincompatible_generate_aliasesremoved and always true.
Fixed
(bzlmod) Fixing Windows Python Interpreter symlink issues
(py_wheel) Allow twine tags and args
(toolchain, bzlmod) Restrict coverage tool visibility under bzlmod
(pip) Ignore temporary pyc.NNN files in wheels
(pip) Add format() calls to glob_exclude templates
plugin_output in py_proto_library rule
Added
Using Gazelle’s lifecycle manager to manage external processes
(bzlmod)
pip.parsecan be called multiple times with different Python versions(bzlmod) Allow bzlmod
pip.parseto reference the default python toolchain and interpreter(bzlmod) Implementing wheel annotations via
whl_mods(gazelle) support multiple requirements files in manifest generation
(py_wheel) Support for specifying
Description-Content-TypeandSummaryin METADATA(py_wheel) Support for specifying
Project-URL(compile_pip_requirements) Added
generate_hashesarg (default True) to control generating hashes(pip) Create all_data_requirements alias
Expose Python C headers through the toolchain.