0.0.7 • Published 4 months ago

google-protocol-compiler v0.0.7

Weekly downloads
2
License
BSD-3-Clause
Repository
github
Last release
4 months ago

Google Protocol Compiler

This is an experimental web assembly version of Google Protocol Compiler compiled from protobuf C++ source code. It can be used to generate code for .proto files just like the native protoc binary but works with node.js and can even work in the browser.

As a command line tool

Install the package using npm and the protoc command line tool will be ready to use:

$ npm install -g google-protocol-compiler
$ protoc —help
Usage: protoc [OPTION] PROTO_FILES
Parse PROTO_FILES and generate output based on the options given:
  -IPATH, --proto_path=PATH   Specify the directory in which to search for
                              imports.  May be specified multiple times;
                              directories will be searched in order.  If not
                              given, the current working directory is used.
  --version                   Show version info and exit.
  -h, --help                  Show this text and exit.
  --encode=MESSAGE_TYPE       Read a text-format message of the given type
                              from standard input and write it in binary
                              to standard output.  The message type must
                              be defined in PROTO_FILES or their imports.
...
$ cat > foo.proto <<EOF
syntax = "proto3";
package test;
message Foo {
  int32 value = 1;
}
EOF
$ protoc —js_out=import_style=commonjs:. foo.proto
$ cat foo_pb.js
/**
 * @fileoverview
 * @enhanceable
 * @suppress {messageConventions} JS Compiler reports an error if a variable or
 *     field starts with 'MSG_' and isn't a translatable message.
 * @public
 */
// GENERATED CODE -- DO NOT EDIT!

var jspb = require('google-protobuf');
var goog = jspb;
var global = Function('return this')();

goog.exportSymbol('proto.test.Foo', null, global);
...

In the browser

Visit https://unpkg.com/google-protocol-compiler/index.html to access the browser version of this protocol compiler. Type the .proto file content in the input boxes and click the “Generate” button to see what protoc generates. It’s useful to do some quick experiments to understand how protoc works.

As a node.js module

Add a dependency on "google-protocol-compiler" and then you can generate code on the fly. Example:

var generator = require('google-protocol-compiler');

generator.onReady(() => {
  console.log(generator.versionNumber);
  console.log(generator.languageList);

  const name = 'foo.proto';
  const content = `
    syntax = "proto3";
    package test;
    message Foo {
      int32 value = 1;
    }
  `;
  const language = 'Javascript';
  const parameters = 'import_style=commonjs';
  const result = generator.generateCode(name, content, language, parameters);
  if (result.error) {
    console.log('Failed to generate code: ', result.error);
  } else {
    console.log(result.files);
  }
});
0.0.7

4 months ago

0.0.6

6 years ago

0.0.5

6 years ago

0.0.4

6 years ago

0.0.3

6 years ago

0.0.2

6 years ago

0.0.1

6 years ago