Name | pyprotostuben JSON |
Version |
0.3.4
JSON |
| download |
home_page | None |
Summary | Generate Python MyPy stub modules from protobuf files. |
upload_time | 2025-01-16 23:24:21 |
maintainer | None |
docs_url | None |
author | zerlok |
requires_python | <4.0,>=3.9 |
license | MIT |
keywords |
python
codegen
protobuf
grpc
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
# pyprotostuben
[![Latest Version](https://img.shields.io/pypi/v/pyprotostuben.svg)](https://pypi.python.org/pypi/pyprotostuben)
[![Python Supported Versions](https://img.shields.io/pypi/pyversions/pyprotostuben.svg)](https://pypi.python.org/pypi/pyprotostuben)
[![MyPy Strict](https://img.shields.io/badge/mypy-strict-blue)](https://mypy.readthedocs.io/en/stable/getting_started.html#strict-mode-and-configuration)
[![Test Coverage](https://codecov.io/gh/zerlok/pyprotostuben/branch/main/graph/badge.svg)](https://codecov.io/gh/zerlok/pyprotostuben)
[![Downloads](https://img.shields.io/pypi/dm/pyprotostuben.svg)](https://pypistats.org/packages/pyprotostuben)
[![GitHub stars](https://img.shields.io/github/stars/zerlok/pyprotostuben)](https://github.com/zerlok/pyprotostuben/stargazers)
Generate Python modules from protobuf files.
## usage
[pypi package](https://pypi.python.org/pypi/pyprotostuben)
install with your favorite python package manager
```bash
pip install pyprotostuben
```
Then use protoc plugins to generate python code. See [greeting examples](examples/greeting/README.md) for more info.
## protoc plugins
### protoc-gen-mypy-stub
Generates python stubs (`*_pb2.pyi` & `*_pb2_grpc.pyi` files which then used by MyPy type checker / IDE syntax highlits
& suggestions).
**features:**
* choose message structure immutability / mutability
* choose async / sync grpc module stubs
* grpc servicer abstract methods have full signature (with appropriate type args in generics), thus it is easier to
implement methods in IDE
**plugin options:**
* `message-mutable` -- add setters for fields, use mutable containers
* `message-all-init-args-optional` -- each field is optional in message constructor (even if field is not optional)
* `grpc-sync` -- use sync grpc stubs instead of grpc.aio module and async defs
* `grpc-skip-servicer` -- don't generate code for servicers
* `grpc-skip-stub` -- don't generate code for stubs
* `no-parallel` -- disable multiprocessing
* `debug` -- turn on plugin debugging
### protoc-gen-brokrpc
Generates `*_brokrpc.py` modules for [BrokRPC](https://github.com/zerlok/BrokRPC) framework. This is similar to gRPC
codegen (`*_pb2_grpc.py` modules).
**plugin options:**
* `no-parallel` -- disable multiprocessing
* `debug` -- turn on plugin debugging
### protoc-gen-echo
Saves protoc plugin input to a file. Helps develop protoc plugins.
**plugin options:**
* `format={raw|binary|json}` (default = `raw`) -- specify output format
* `dest={path}` (default = `request.json`) -- specify file destination
Raw data
{
"_id": null,
"home_page": null,
"name": "pyprotostuben",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0,>=3.9",
"maintainer_email": null,
"keywords": "python, codegen, protobuf, grpc",
"author": "zerlok",
"author_email": "danil.troshnev@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/f0/aa/7700c1aa3acce362224ce8344811a77f17c32cfc6bb0eb4fc41ab96917c0/pyprotostuben-0.3.4.tar.gz",
"platform": null,
"description": "# pyprotostuben\n\n[![Latest Version](https://img.shields.io/pypi/v/pyprotostuben.svg)](https://pypi.python.org/pypi/pyprotostuben)\n[![Python Supported Versions](https://img.shields.io/pypi/pyversions/pyprotostuben.svg)](https://pypi.python.org/pypi/pyprotostuben)\n[![MyPy Strict](https://img.shields.io/badge/mypy-strict-blue)](https://mypy.readthedocs.io/en/stable/getting_started.html#strict-mode-and-configuration)\n[![Test Coverage](https://codecov.io/gh/zerlok/pyprotostuben/branch/main/graph/badge.svg)](https://codecov.io/gh/zerlok/pyprotostuben)\n[![Downloads](https://img.shields.io/pypi/dm/pyprotostuben.svg)](https://pypistats.org/packages/pyprotostuben)\n[![GitHub stars](https://img.shields.io/github/stars/zerlok/pyprotostuben)](https://github.com/zerlok/pyprotostuben/stargazers)\n\nGenerate Python modules from protobuf files.\n\n## usage\n\n[pypi package](https://pypi.python.org/pypi/pyprotostuben)\n\ninstall with your favorite python package manager\n\n```bash\npip install pyprotostuben\n```\n\nThen use protoc plugins to generate python code. See [greeting examples](examples/greeting/README.md) for more info.\n\n## protoc plugins\n\n### protoc-gen-mypy-stub\n\nGenerates python stubs (`*_pb2.pyi` & `*_pb2_grpc.pyi` files which then used by MyPy type checker / IDE syntax highlits\n& suggestions).\n\n**features:**\n\n* choose message structure immutability / mutability\n* choose async / sync grpc module stubs\n* grpc servicer abstract methods have full signature (with appropriate type args in generics), thus it is easier to\n implement methods in IDE\n\n**plugin options:**\n\n* `message-mutable` -- add setters for fields, use mutable containers\n* `message-all-init-args-optional` -- each field is optional in message constructor (even if field is not optional)\n* `grpc-sync` -- use sync grpc stubs instead of grpc.aio module and async defs\n* `grpc-skip-servicer` -- don't generate code for servicers\n* `grpc-skip-stub` -- don't generate code for stubs\n* `no-parallel` -- disable multiprocessing\n* `debug` -- turn on plugin debugging\n\n### protoc-gen-brokrpc\n\nGenerates `*_brokrpc.py` modules for [BrokRPC](https://github.com/zerlok/BrokRPC) framework. This is similar to gRPC\ncodegen (`*_pb2_grpc.py` modules).\n\n**plugin options:**\n\n* `no-parallel` -- disable multiprocessing\n* `debug` -- turn on plugin debugging\n\n### protoc-gen-echo\n\nSaves protoc plugin input to a file. Helps develop protoc plugins.\n\n**plugin options:**\n\n* `format={raw|binary|json}` (default = `raw`) -- specify output format\n* `dest={path}` (default = `request.json`) -- specify file destination\n\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Generate Python MyPy stub modules from protobuf files.",
"version": "0.3.4",
"project_urls": {
"Homepage": "https://github.com/zerlok/pyprotostuben",
"Issues": "https://github.com/zerlok/pyprotostuben/issues"
},
"split_keywords": [
"python",
" codegen",
" protobuf",
" grpc"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "0ed8722239a3814adf7cc1df51cba7b65be41cb537f9938b50e6d93435a5dfea",
"md5": "3f93e8d50a053f81715c02e8cf5f27a3",
"sha256": "e565265fea9746a48ec63ce36eec73b0323dde3a4de429e9a9c6a7c724935dc5"
},
"downloads": -1,
"filename": "pyprotostuben-0.3.4-py3-none-any.whl",
"has_sig": false,
"md5_digest": "3f93e8d50a053f81715c02e8cf5f27a3",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0,>=3.9",
"size": 37390,
"upload_time": "2025-01-16T23:24:18",
"upload_time_iso_8601": "2025-01-16T23:24:18.406173Z",
"url": "https://files.pythonhosted.org/packages/0e/d8/722239a3814adf7cc1df51cba7b65be41cb537f9938b50e6d93435a5dfea/pyprotostuben-0.3.4-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "f0aa7700c1aa3acce362224ce8344811a77f17c32cfc6bb0eb4fc41ab96917c0",
"md5": "650a9fa5528fa8f25b225461c60df4d2",
"sha256": "eb7daf4faeb54d5d382f73cca7a39961f3cf6f9264fda433f525876a15efaa5a"
},
"downloads": -1,
"filename": "pyprotostuben-0.3.4.tar.gz",
"has_sig": false,
"md5_digest": "650a9fa5528fa8f25b225461c60df4d2",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0,>=3.9",
"size": 26731,
"upload_time": "2025-01-16T23:24:21",
"upload_time_iso_8601": "2025-01-16T23:24:21.196148Z",
"url": "https://files.pythonhosted.org/packages/f0/aa/7700c1aa3acce362224ce8344811a77f17c32cfc6bb0eb4fc41ab96917c0/pyprotostuben-0.3.4.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-16 23:24:21",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "zerlok",
"github_project": "pyprotostuben",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "pyprotostuben"
}