Commit c348af2f authored by Josh Haberman's avatar Josh Haberman

Addressed more code review comments.

parent 7726cd20
...@@ -30,17 +30,16 @@ To use Protocol Buffers with JavaScript, you need two main components: ...@@ -30,17 +30,16 @@ To use Protocol Buffers with JavaScript, you need two main components:
Setup Setup
===== =====
First, compile the Protocol Compiler. First, obtain the Protocol Compiler. The easiest way is to download
You can compile `protoc` from GitHub or a source tarball. From the a pre-built binary from [https://github.com/google/protobuf/releases](https://github.com/google/protobuf/releases).
top level directory type:
$ ./autogen.sh (only necessary for GitHub)
$ ./configure
$ make
If you want, you can compile `protoc` from source instead. To do this
follow the instructions in [the top-level
README](https://github.com/google/protobuf/blob/master/src/README.md).
Once you have `protoc` compiled, you can run the tests by typing: Once you have `protoc` compiled, you can run the tests by typing:
$ cd js
$ npm install $ npm install
$ npm test $ npm test
......
...@@ -19,7 +19,16 @@ ...@@ -19,7 +19,16 @@
* *
* This script parses that special comment and uses it to generate proper * This script parses that special comment and uses it to generate proper
* CommonJS require() statements so that the tests can run and pass using * CommonJS require() statements so that the tests can run and pass using
* CommonJS imports. * CommonJS imports. The script will change the above statements into:
*
* var test_pb = require('test_pb');
* googleProtobuf.exportSymbol('proto.jspb.test.CloneExtension', test_pb.CloneExtension, global);
* googleProtobuf.exportSymbol('proto.jspb.test.Complex', test_pb.Complex, global);
* googleProtobuf.exportSymbol('proto.jspb.test.DefaultValues', test_pb.DefaultValues, global);
*
* (The "exportSymbol" function will define the given names in the global
* namespace, taking care not to overwrite any previous value for
* "proto.jspb.test").
*/ */
var lineReader = require('readline').createInterface({ var lineReader = require('readline').createInterface({
...@@ -37,18 +46,16 @@ function tryStripPrefix(str, prefix) { ...@@ -37,18 +46,16 @@ function tryStripPrefix(str, prefix) {
var module = null; var module = null;
var pkg = null; var pkg = null;
lineReader.on('line', function(line) { lineReader.on('line', function(line) {
var is_require = line.match(/goog\.require\('([^']*)'\)/); var isRequire = line.match(/goog\.require\('([^']*)'\)/);
var is_loadfromfile = line.match(/CommonJS-LoadFromFile: ([^ ]*) (.*)/); var isLoadFromFile = line.match(/CommonJS-LoadFromFile: (\S*) (.*)/);
var is_settestonly = line.match(/goog.setTestOnly()/); var isSetTestOnly = line.match(/goog.setTestOnly()/);
if (is_settestonly) { if (isRequire) {
// Remove this line.
} else if (is_require) {
if (module) { // Skip goog.require() lines before the first directive. if (module) { // Skip goog.require() lines before the first directive.
var full_sym = is_require[1]; var fullSym = isRequire[1];
var sym = tryStripPrefix(full_sym, pkg); var sym = tryStripPrefix(fullSym, pkg);
console.log("googleProtobuf.exportSymbol('" + full_sym + "', " + module + sym + ', global);'); console.log("googleProtobuf.exportSymbol('" + fullSym + "', " + module + sym + ', global);');
} }
} else if (is_loadfromfile) { } else if (isLoadFromFile) {
if (!module) { if (!module) {
console.log("var googleProtobuf = require('google-protobuf');"); console.log("var googleProtobuf = require('google-protobuf');");
console.log("var asserts = require('closure_asserts_commonjs');"); console.log("var asserts = require('closure_asserts_commonjs');");
...@@ -57,13 +64,13 @@ lineReader.on('line', function(line) { ...@@ -57,13 +64,13 @@ lineReader.on('line', function(line) {
console.log("// Bring asserts into the global namespace."); console.log("// Bring asserts into the global namespace.");
console.log("googleProtobuf.object.extend(global, asserts);"); console.log("googleProtobuf.object.extend(global, asserts);");
} }
module = is_loadfromfile[1].replace("-", "_"); module = isLoadFromFile[1].replace("-", "_");
pkg = is_loadfromfile[2]; pkg = isLoadFromFile[2];
if (module != "googleProtobuf") { // We unconditionally require this in the header. if (module != "googleProtobuf") { // We unconditionally require this in the header.
console.log("var " + module + " = require('" + is_loadfromfile[1] + "');"); console.log("var " + module + " = require('" + isLoadFromFile[1] + "');");
} }
} else { } else if (!isSetTestOnly) { // Remove goog.setTestOnly() lines.
console.log(line); console.log(line);
} }
}); });
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment