gapic-generator


Namegapic-generator JSON
Version 1.28.3 PyPI version JSON
download
home_pagehttps://github.com/googleapis/gapic-generator-python
SummaryGoogle API Client Generator for Python
upload_time2025-10-21 16:37:00
maintainerNone
docs_urlNone
authorGoogle LLC
requires_python>=3.7
licenseApache 2.0
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage
            .. _codingstyle:

API Client Generator for Python
===============================

|release level| |pypi| |versions|

    A generator for protocol buffer described APIs for and in Python 3.

This is a generator for API client libraries for APIs
specified by `protocol buffers`_, such as those inside Google.
It takes a protocol buffer (with particular annotations) and uses it
to generate a client library.

.. _protocol buffers: https://developers.google.com/protocol-buffers/

Purpose
-------

This library replaces the `monolithic generator`_
with some improvements:

- An explicit normalized format for specifying APIs.
- Light weight, in-language code generators.

.. _monolithic generator: https://github.com/googleapis/gapic-generator


Bazel
-------------
This generator can be called from Bazel, which is a recommended way of using it inside a continuous integration build or any other automated pipeline.

Clone the googleapis repository
$ git clone https://github.com/googleapis/googleapis.git

Create the targets
------------------
You need to add the following targets to your BUILD.bazel file.

.. code-block:: c

        load(
            "@gapic_generator_python//rules_python_gapic:py_gapic.bzl",
            "py_gapic_library"
        )

        load(
            "@gapic_generator_python//rules_python_gapic:py_gapic_pkg.bzl",
            "py_gapic_assembly_pkg"
        )

        py_gapic_library(
            name = "documentai_py_gapic",
            srcs = [":documentai_proto"],
        )

        py_gapic_assembly_pkg(
            name = "documentai-v1beta2-py",
            deps = [
                ":documentai_py_gapic",
            ],
        )


Compiling an API
----------------

Using Bazel:

.. code-block:: c

        bazel build //google/cloud/documentai/v1beta2:documentai-v1beta2-py

Using Protoc:

.. code-block:: c

        # This is assumed to be in the `googleapis` project root.
        $ protoc google/cloud/vision/v1/*.proto \
            --python_gapic_out=/dest/

Development
-------------
`Development`_

.. _Development: https://github.com/googleapis/gapic-generator-python/blob/main/DEVELOPMENT.md

Contributing
-------------
If you are looking to contribute to the project, please see `Contributing`_
for guidlines.

.. _Contributing: https://github.com/googleapis/gapic-generator-python/blob/main/CONTRIBUTING.md

Documentation
-------------

See the `documentation`_.

.. _documentation: https://googleapis.dev/python/gapic-generator/latest/

.. |release level| image:: https://img.shields.io/badge/support-stable-gold.svg
  :target: https://github.com/googleapis/google-cloud-python/blob/main/README.rst#general-availability
.. |pypi| image:: https://img.shields.io/pypi/v/gapic-generator.svg
  :target: https://pypi.org/project/gapic-generator/
.. |versions| image:: https://img.shields.io/pypi/pyversions/gapic-generator.svg
  :target: https://pypi.org/project/gapic-generator/

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/googleapis/gapic-generator-python",
    "name": "gapic-generator",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.7",
    "maintainer_email": null,
    "keywords": null,
    "author": "Google LLC",
    "author_email": "googleapis-packages@google.com",
    "download_url": "https://files.pythonhosted.org/packages/38/d4/7cb67d375bed509c5e9d45d0a76cb5359d1857ced7bb126038d1bd454f13/gapic_generator-1.28.3.tar.gz",
    "platform": "Posix; MacOS X",
    "description": ".. _codingstyle:\n\nAPI Client Generator for Python\n===============================\n\n|release level| |pypi| |versions|\n\n    A generator for protocol buffer described APIs for and in Python 3.\n\nThis is a generator for API client libraries for APIs\nspecified by `protocol buffers`_, such as those inside Google.\nIt takes a protocol buffer (with particular annotations) and uses it\nto generate a client library.\n\n.. _protocol buffers: https://developers.google.com/protocol-buffers/\n\nPurpose\n-------\n\nThis library replaces the `monolithic generator`_\nwith some improvements:\n\n- An explicit normalized format for specifying APIs.\n- Light weight, in-language code generators.\n\n.. _monolithic generator: https://github.com/googleapis/gapic-generator\n\n\nBazel\n-------------\nThis generator can be called from Bazel, which is a recommended way of using it inside a continuous integration build or any other automated pipeline.\n\nClone the googleapis repository\n$ git clone https://github.com/googleapis/googleapis.git\n\nCreate the targets\n------------------\nYou need to add the following targets to your BUILD.bazel file.\n\n.. code-block:: c\n\n        load(\n            \"@gapic_generator_python//rules_python_gapic:py_gapic.bzl\",\n            \"py_gapic_library\"\n        )\n\n        load(\n            \"@gapic_generator_python//rules_python_gapic:py_gapic_pkg.bzl\",\n            \"py_gapic_assembly_pkg\"\n        )\n\n        py_gapic_library(\n            name = \"documentai_py_gapic\",\n            srcs = [\":documentai_proto\"],\n        )\n\n        py_gapic_assembly_pkg(\n            name = \"documentai-v1beta2-py\",\n            deps = [\n                \":documentai_py_gapic\",\n            ],\n        )\n\n\nCompiling an API\n----------------\n\nUsing Bazel:\n\n.. code-block:: c\n\n        bazel build //google/cloud/documentai/v1beta2:documentai-v1beta2-py\n\nUsing Protoc:\n\n.. code-block:: c\n\n        # This is assumed to be in the `googleapis` project root.\n        $ protoc google/cloud/vision/v1/*.proto \\\n            --python_gapic_out=/dest/\n\nDevelopment\n-------------\n`Development`_\n\n.. _Development: https://github.com/googleapis/gapic-generator-python/blob/main/DEVELOPMENT.md\n\nContributing\n-------------\nIf you are looking to contribute to the project, please see `Contributing`_\nfor guidlines.\n\n.. _Contributing: https://github.com/googleapis/gapic-generator-python/blob/main/CONTRIBUTING.md\n\nDocumentation\n-------------\n\nSee the `documentation`_.\n\n.. _documentation: https://googleapis.dev/python/gapic-generator/latest/\n\n.. |release level| image:: https://img.shields.io/badge/support-stable-gold.svg\n  :target: https://github.com/googleapis/google-cloud-python/blob/main/README.rst#general-availability\n.. |pypi| image:: https://img.shields.io/pypi/v/gapic-generator.svg\n  :target: https://pypi.org/project/gapic-generator/\n.. |versions| image:: https://img.shields.io/pypi/pyversions/gapic-generator.svg\n  :target: https://pypi.org/project/gapic-generator/\n",
    "bugtrack_url": null,
    "license": "Apache 2.0",
    "summary": "Google API Client Generator for Python",
    "version": "1.28.3",
    "project_urls": {
        "Homepage": "https://github.com/googleapis/gapic-generator-python"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "397f55ecc4d0ca3ad847c1d32af54cf94f11aae731c30088746cece29a62c5f6",
                "md5": "a5e70b8933ae2ba8301a60e054e6a883",
                "sha256": "26a601708a847f811d097efc55d8bb0b176cd03e31020cfcc1ca796b0fdc3434"
            },
            "downloads": -1,
            "filename": "gapic_generator-1.28.3-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "a5e70b8933ae2ba8301a60e054e6a883",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.7",
            "size": 2241947,
            "upload_time": "2025-10-21T16:36:58",
            "upload_time_iso_8601": "2025-10-21T16:36:58.358316Z",
            "url": "https://files.pythonhosted.org/packages/39/7f/55ecc4d0ca3ad847c1d32af54cf94f11aae731c30088746cece29a62c5f6/gapic_generator-1.28.3-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "38d47cb67d375bed509c5e9d45d0a76cb5359d1857ced7bb126038d1bd454f13",
                "md5": "6e38982673c26f9c14252cceb151d107",
                "sha256": "2bf503f7a53fe74c29a9633c21fff70d3d66ccf1e7635ce811ddee31d508a241"
            },
            "downloads": -1,
            "filename": "gapic_generator-1.28.3.tar.gz",
            "has_sig": false,
            "md5_digest": "6e38982673c26f9c14252cceb151d107",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.7",
            "size": 1491259,
            "upload_time": "2025-10-21T16:37:00",
            "upload_time_iso_8601": "2025-10-21T16:37:00.007222Z",
            "url": "https://files.pythonhosted.org/packages/38/d4/7cb67d375bed509c5e9d45d0a76cb5359d1857ced7bb126038d1bd454f13/gapic_generator-1.28.3.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-10-21 16:37:00",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "googleapis",
    "github_project": "gapic-generator-python",
    "travis_ci": false,
    "coveralls": true,
    "github_actions": true,
    "requirements": [],
    "lcname": "gapic-generator"
}
        
Elapsed time: 1.60809s