All Projects → google → Apis Client Generator

google / Apis Client Generator

Licence: apache-2.0
The Google APIs Client Generator is a tool for generating client libraries for APIs based on the Google API Discovery format. It is based on the same core technology Google uses to publish their API libraries. Current support is for C++, C#/.NET, Dart, Java, Java/GWT, and PHP.

Programming Languages

python
139335 projects - #7 most used programming language

Copyright 2011 Google, Inc.

Licensed under the Apache License, Version 2.0 (the "License");

you may not use this file except in compliance with the License.

You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software

distributed under the License is distributed on an "AS IS" BASIS,

WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.

See the License for the specific language governing permissions and

limitations under the License.

Google APIs Code Generator https://github.com/google/apis-client-generator/

January 29, 2019

Introduction

This is a tool for generating client libraries from Google APIs Discovery documents. It builds a rich (but language neutral) model of the API and then invokes a language specific backend to emit the library. The language generators are template driven, so it is easy for a developer knowning language X to write templates for code in X, without having to learn much Python.

The generator currently has templates for Java, C++, CSharp, GWT, PHP and Dart. There may be multiple variations of each language. For each, the variant used by default (typically also named "default") matches the head of the respective base client libraries.

Warning: This project is maintained as a volunteer effort. There is no full time staffing.

Installation

Python 2.7 is required. Python3 is not supported.

Everything can be installed quickly with easy_install or pip. E.g.:

pip install google-apis-client-generator

The following dependencies will be installed:

Usage

To run the library generator, use the "generate_library" script. This is normally what you'd want to do. E.g.:

generate_library
--input=src/googleapis/codegen/testdata/moderator.v1.json
--language=java
--output_dir=/tmp/generated

To expand arbitrary templates, the "expand_templates" script is also available:

expand_templates
--discovery=src/googleapis/codegen/testdata/moderator.v1.json
--language=any --templates=discovery_check
--output_dir=/tmp/generated

Contact

Tony Aiuto ([email protected]) Jacob Smullyan ([email protected])

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].