Skip to main content

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ansys_tools_protoc_helper-0.5.0.tar.gz (6.0 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file ansys_tools_protoc_helper-0.5.0.tar.gz.

File metadata

File hashes

Hashes for ansys_tools_protoc_helper-0.5.0.tar.gz
Algorithm Hash digest
SHA256 3af6b5d78e1edd389890b54fed4f3fd3e0862463366a2e3bc4e2b2dffbb6158f
MD5 112c3c82b2373a49fcad7b8f4d8d3c9e
BLAKE2b-256 4ac53acd5f8953333cb43376e1c6eaf4277224dd5f12682537ff3b438df03f8d

See more details on using hashes here.

File details

Details for the file ansys_tools_protoc_helper-0.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for ansys_tools_protoc_helper-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 852a0118a5a6e521ea2148cc10617136d321bc88376b4496ef12e4e94266ac66
MD5 33866bc3d3c1e18da2761b13f5dc7321
BLAKE2b-256 ed94899aaa75784659eb95a4aa923cfe99358f877572a24039f69e182979e13b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page