Json protocol buffer code generator
Project description
json-protobuf provides a Json interface to Google's Protocol Buffers compiled in C++ code. The idea is that you can convert a protocol buffer object to a json representation which can be used in API:s.
Producing Code
json-protobuf provides a plugin for the protoc protocol buffer compiler (it ships with protocol buffers). This plugin tells protoc to produce a set of C++ output files, which define the JSON interface to protocol buffers using the json-spirit library (other libraries will/coul be supported).
First, obtain a copy of json-protobuf:
$ git clone git@github.com:mickem/json-protobuf.git
$ cd json-protobuf
Next, install json-protobuf:
$ python setup.py install
Finally, launch protoc and tell it to produce Lua output:
$ protoc -I/path/to/your/proto/files --json_out=/output/path file1.proto file2.proto
You simply need to add --json_out to the arguments to protoc to get it to produce the Json output files.
Under the hood, protoc is looking for the program protoc-gen-json somewhere in your $PATH. You can modify $PATH in lieux of installing the package, if you desire.
Missing plugin_pb2 Python Module
The protocol buffers Python installer does not install a file required by protoc-gen-lua at this time. The missing file is the Python interface to the compiler plugin plugin.proto. The protoc-gen-lua Python script may fail when importing the google.protobuf.compiler.plugin_pb2 module.
A thread on the protocol buffers mailing list discusses the issue.
At this time, the issue can be worked around by manually installing the missing file.
Assuming you have a working protoc compiler on your system and have the existing Python protocol buffers package installed, from the protocol buffers source code directory, run the following:
$ protoc -Isrc --python_out=/path/to/output/directory src/google/protobuf/compiler/plugin.proto
The command should produce no output if successful. Additionally, the file /path/to/output/directory/google/protobuf/compiler/plugin_pb2.py should have been created.
Next, find the location of the installed protocol buffer Python package. If you have locate, try finding it via locate descriptor_pb2.py
. A common location is something like /usr/lib/python2.6/site-packages/protobuf-2.3.0-py2.6.egg/google/protobuf/. Navigate to this directory and:
$ mkdir compiler
$ touch compiler/__init__.py
$ cp /path/to/plugin_pb2.py compiler/plugin_pb2.py
In common English:
- Create a new directory, from the install root, google/protobuf/compiler
- Create an empty file, __init__.py in this directory. This tells Python that the directory contains Python modules.
- Copy the plugin_pb2.py file produced by protoc to this new directory.
Depending on the installed location of protocol buffers, these actions may require superuser or administrator privileges.
Compiling Produced Files
You should be able to compile the produced .h and .cc files like you would for protocol buffer output files. If you have an existing Makefile, project, etc, just add the produced .h and .cc files to it.
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
Built Distribution
Hashes for json_protobuf-0.0.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0762ff8c0e4b2b64363be5cb82f2ccc3b2a00ceec0f92ac660c5af47584e5184 |
|
MD5 | c5995ef857d40d5414bd09df467940af |
|
BLAKE2b-256 | 5c332c97ef6fa6dc9612a1a0c23be396fae9777fa167b52ea6f64f93ea65034f |