A utility for compiling '.proto' files to Python source.
Project description
A utility to compile .proto files to Python source when building the package wheel. It supports dependencies to .proto files of different packages.
Quickstart
The simplest way to get started is using the template repository.
Manual use
To manually enable the use of ansys-tools-protoc-helper in your project, the following things need to be defined:
A pyproject.toml file with the following contents:
[build-system] requires = ["setuptools>=42.0", "wheel", "ansys-tools-protoc-helper", <additional_dependencies>] build-backend = "setuptools.build_meta:__legacy__"
where <additional_dependencies> are the packages that you depend on for .proto files.
In the setuptools configuration (either setup.cfg or setup.py). We only show the setuptools.setup() keywords (setup.py variant) here:
Run-time dependencies on the same <additional_dependencies> used above:
install_requires=[grpcio, protobuf, <additional_dependencies>],
Refer to the gRPC version strategy section for details on which grpc and protobuf versions can be used.
The package_data declares additional file names which are included in the package:
package_data={ "": ["*.proto", "*.pyi", "py.typed"], }
Note that *.proto is only needed if other packages should be able to depend on the *.proto files defined in your package.
The py.typed file is used to communicate that the package contains type information, see PEP 561. This file needs to be manually added.
The cmdclass is used to specify that some setuptools commands should be executed by ansys-tools-protoc-helper:
from ansys.tools.protoc_helper import CMDCLASS_OVERRIDE setup( <...>, cmdclass=CMDCLASS_OVERRIDE )
The two commands which are overridden can also be specified individually. This may be useful in particular if you want to use the setup.cfg format:
from ansys.tools.protoc_helper import BuildPyCommand, DevelopCommand setup( <...>, cmdclass={"build_py": BuildPyCommand, "develop": DevelopCommand} )
If other projects should be able to depend on the .proto files contained in your project, an entry point needs to be defined declaring the presence of the *.proto files:
entry_points={ "ansys.tools.protoc_helper.proto_provider": { "<your.package.name>=<your.package.name>" }, },
where <your.package.name> is the _importable_ name of your package. In other words, import <your.package.name> should work after installing the package.
By default, the .proto files will be copied to your/package/name. If a different location should be used, append a semicolon to the entry point name, followed by the dot-separated target location:
entry_points={ "ansys.tools.protoc_helper.proto_provider": { "<your.package.name>:<target.location>=<your.package.name>" }, },
For a complete example, see the test/test_data/testpkg-greeter-protos package.
gRPC version strategy
The ansys-tools-protoc-helper pins the versions of gRPC and protobuf that it depends on, in the dependencies = ... section of the pyproject.toml file.
For your own project, you can use any version of grpcio and protobuf that’s newer (or equal) to the version pinned here, as long as it is the same major version.
For example, if ansys-tools-protoc-helper pins
dependencies = [
"grpcio-tools==1.20.0",
"protobuf==3.19.3",
]
your own dependencies could be grpcio-tools~=1.20, protobuf~=3.19 (using the ~= compatible version operator).
The versions pinned by ansys-tools-protoc-helper were originally chosen as follows:
The first version of grpcio-tools for which binary wheels are available on PyPI, for at least one of the Python versions we support.
The first version of protobuf which is compatible with mypy-protobuf, for generating type stubs.
Upgrade plans
The current plan for upgrading grpcio-tools and protobuf is as follows:
ansys-tools-protoc-helper version |
release date |
grpcio-tools version |
protobuf version |
protoc version |
---|---|---|---|---|
0.2.x |
2022-12-09 |
1.20.x |
3.19.3 |
3.7.x |
0.3.x |
2023-02-20 |
1.25.x |
3.19.3 |
3.8.x |
0.4.x |
2023-02-20 |
1.44.x |
3.19.3 |
3.19.2 |
0.5.x |
TBD |
1.49.x |
4.21.x |
3.21.5 |
The strategy for these upgrades is as follows:
Upgrade grpcio-tools as necessary. For example, 0.5.x enables building with Python 3.11.
Match the version of protobuf to the version of protoc bundled into grpcio-tools, or at least 3.19.3.
Each upgrade is a breaking upgrade for the semantic version. Since we are currently using 0.x versions, the minor version is bumped.
The protobuf Python runtime introduced a backwards-incompatible change with version 4.21 (matching protoc release 3.21). Code generated with protoc==3.19 or newer should be compatible with the 4.x runtime, which corresponds to the 0.4 release of ansys-tools-protoc-helper.
If you need to support a specific older version of protobuf and / or gRPC, we encourage pinning ansys-tools-protoc-helper to its minor version.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ansys_tools_protoc_helper-0.5.0.tar.gz
.
File metadata
- Download URL: ansys_tools_protoc_helper-0.5.0.tar.gz
- Upload date:
- Size: 6.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3af6b5d78e1edd389890b54fed4f3fd3e0862463366a2e3bc4e2b2dffbb6158f |
|
MD5 | 112c3c82b2373a49fcad7b8f4d8d3c9e |
|
BLAKE2b-256 | 4ac53acd5f8953333cb43376e1c6eaf4277224dd5f12682537ff3b438df03f8d |
File details
Details for the file ansys_tools_protoc_helper-0.5.0-py3-none-any.whl
.
File metadata
- Download URL: ansys_tools_protoc_helper-0.5.0-py3-none-any.whl
- Upload date:
- Size: 7.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 852a0118a5a6e521ea2148cc10617136d321bc88376b4496ef12e4e94266ac66 |
|
MD5 | 33866bc3d3c1e18da2761b13f5dc7321 |
|
BLAKE2b-256 | ed94899aaa75784659eb95a4aa923cfe99358f877572a24039f69e182979e13b |