|
@@ -8,6 +8,21 @@ function exec(command, cb) {
|
|
|
|
|
|
var protoc = process.env.PROTOC || '../src/protoc';
|
|
var protoc = process.env.PROTOC || '../src/protoc';
|
|
|
|
|
|
|
|
+var wellKnownTypes = [
|
|
|
|
+ '../src/google/protobuf/any.proto',
|
|
|
|
+ '../src/google/protobuf/api.proto',
|
|
|
|
+ '../src/google/protobuf/compiler/plugin.proto',
|
|
|
|
+ '../src/google/protobuf/descriptor.proto',
|
|
|
|
+ '../src/google/protobuf/duration.proto',
|
|
|
|
+ '../src/google/protobuf/empty.proto',
|
|
|
|
+ '../src/google/protobuf/field_mask.proto',
|
|
|
|
+ '../src/google/protobuf/source_context.proto',
|
|
|
|
+ '../src/google/protobuf/struct.proto',
|
|
|
|
+ '../src/google/protobuf/timestamp.proto',
|
|
|
|
+ '../src/google/protobuf/type.proto',
|
|
|
|
+ '../src/google/protobuf/wrappers.proto',
|
|
|
|
+];
|
|
|
|
+
|
|
gulp.task('genproto_closure', function (cb) {
|
|
gulp.task('genproto_closure', function (cb) {
|
|
exec(protoc + ' --js_out=library=testproto_libs,binary:. -I ../src -I . *.proto ../src/google/protobuf/descriptor.proto',
|
|
exec(protoc + ' --js_out=library=testproto_libs,binary:. -I ../src -I . *.proto ../src/google/protobuf/descriptor.proto',
|
|
function (err, stdout, stderr) {
|
|
function (err, stdout, stderr) {
|
|
@@ -26,7 +41,25 @@ gulp.task('genproto_commonjs', function (cb) {
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
|
|
-gulp.task('dist', function (cb) {
|
|
|
|
|
|
+gulp.task('genproto_commonjs_wellknowntypes', function (cb) {
|
|
|
|
+ exec('mkdir -p commonjs_out/node_modules/google-protobuf && ' + protoc + ' --js_out=import_style=commonjs,binary:commonjs_out/node_modules/google-protobuf -I ../src ../src/google/protobuf/descriptor.proto',
|
|
|
|
+ function (err, stdout, stderr) {
|
|
|
|
+ console.log(stdout);
|
|
|
|
+ console.log(stderr);
|
|
|
|
+ cb(err);
|
|
|
|
+ });
|
|
|
|
+});
|
|
|
|
+
|
|
|
|
+gulp.task('genproto_wellknowntypes', function (cb) {
|
|
|
|
+ exec(protoc + ' --js_out=import_style=commonjs,binary:. -I ../src ' + wellKnownTypes.join(' '),
|
|
|
|
+ function (err, stdout, stderr) {
|
|
|
|
+ console.log(stdout);
|
|
|
|
+ console.log(stderr);
|
|
|
|
+ cb(err);
|
|
|
|
+ });
|
|
|
|
+});
|
|
|
|
+
|
|
|
|
+gulp.task('dist', ['genproto_wellknowntypes'], function (cb) {
|
|
// TODO(haberman): minify this more aggressively.
|
|
// TODO(haberman): minify this more aggressively.
|
|
// Will require proper externs/exports.
|
|
// Will require proper externs/exports.
|
|
exec('./node_modules/google-closure-library/closure/bin/calcdeps.py -i message.js -i binary/reader.js -i binary/writer.js -i commonjs/export.js -p . -p node_modules/google-closure-library/closure -o compiled --compiler_jar node_modules/google-closure-compiler/compiler.jar > google-protobuf.js',
|
|
exec('./node_modules/google-closure-library/closure/bin/calcdeps.py -i message.js -i binary/reader.js -i binary/writer.js -i commonjs/export.js -p . -p node_modules/google-closure-library/closure -o compiled --compiler_jar node_modules/google-closure-compiler/compiler.jar > google-protobuf.js',
|
|
@@ -55,7 +88,7 @@ gulp.task('commonjs_testdeps', function (cb) {
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
|
|
-gulp.task('make_commonjs_out', ['dist', 'genproto_commonjs', 'commonjs_asserts', 'commonjs_testdeps'], function (cb) {
|
|
|
|
|
|
+gulp.task('make_commonjs_out', ['dist', 'genproto_commonjs', 'genproto_commonjs_wellknowntypes', 'commonjs_asserts', 'commonjs_testdeps'], function (cb) {
|
|
// TODO(haberman): minify this more aggressively.
|
|
// TODO(haberman): minify this more aggressively.
|
|
// Will require proper externs/exports.
|
|
// Will require proper externs/exports.
|
|
var cmd = "mkdir -p commonjs_out/binary && mkdir -p commonjs_out/test_node_modules && ";
|
|
var cmd = "mkdir -p commonjs_out/binary && mkdir -p commonjs_out/test_node_modules && ";
|