| Index: third_party/protobuf/js/gulpfile.js
|
| diff --git a/third_party/protobuf/js/gulpfile.js b/third_party/protobuf/js/gulpfile.js
|
| index 79095d657b98d105c7595d756d94cb1db437c0a6..c5220153b5bd7da95dbdad8d429a06e184c02e2e 100644
|
| --- a/third_party/protobuf/js/gulpfile.js
|
| +++ b/third_party/protobuf/js/gulpfile.js
|
| @@ -1,25 +1,93 @@
|
| var gulp = require('gulp');
|
| -var exec = require('child_process').exec;
|
| +var execFile = require('child_process').execFile;
|
| +var glob = require('glob');
|
|
|
| -gulp.task('genproto', function (cb) {
|
| - exec('../src/protoc --js_out=library=testproto_libs,binary:. -I ../src -I . *.proto ../src/google/protobuf/descriptor.proto',
|
| +function exec(command, cb) {
|
| + execFile('sh', ['-c', command], cb);
|
| +}
|
| +
|
| +var protoc = process.env.PROTOC || '../src/protoc';
|
| +
|
| +gulp.task('genproto_closure', function (cb) {
|
| + exec(protoc + ' --js_out=library=testproto_libs,binary:. -I ../src -I . *.proto ../src/google/protobuf/descriptor.proto',
|
| + function (err, stdout, stderr) {
|
| + console.log(stdout);
|
| + console.log(stderr);
|
| + cb(err);
|
| + });
|
| +});
|
| +
|
| +gulp.task('genproto_commonjs', function (cb) {
|
| + exec('mkdir -p commonjs_out && ' + protoc + ' --js_out=import_style=commonjs,binary:commonjs_out -I ../src -I commonjs -I . *.proto commonjs/test*/*.proto ../src/google/protobuf/descriptor.proto',
|
| + function (err, stdout, stderr) {
|
| + console.log(stdout);
|
| + console.log(stderr);
|
| + cb(err);
|
| + });
|
| +});
|
| +
|
| +gulp.task('dist', function (cb) {
|
| + // TODO(haberman): minify this more aggressively.
|
| + // 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',
|
| + function (err, stdout, stderr) {
|
| + console.log(stdout);
|
| + console.log(stderr);
|
| + cb(err);
|
| + });
|
| +});
|
| +
|
| +gulp.task('commonjs_asserts', function (cb) {
|
| + exec('mkdir -p commonjs_out/test_node_modules && ./node_modules/google-closure-library/closure/bin/calcdeps.py -i commonjs/export_asserts.js -p . -p node_modules/google-closure-library/closure -o compiled --compiler_jar node_modules/google-closure-compiler/compiler.jar > commonjs_out/test_node_modules/closure_asserts_commonjs.js',
|
| + function (err, stdout, stderr) {
|
| + console.log(stdout);
|
| + console.log(stderr);
|
| + cb(err);
|
| + });
|
| +});
|
| +
|
| +gulp.task('commonjs_testdeps', function (cb) {
|
| + exec('mkdir -p commonjs_out/test_node_modules && ./node_modules/google-closure-library/closure/bin/calcdeps.py -i commonjs/export_testdeps.js -p . -p node_modules/google-closure-library/closure -o compiled --compiler_jar node_modules/google-closure-compiler/compiler.jar > commonjs_out/test_node_modules/testdeps_commonjs.js',
|
| function (err, stdout, stderr) {
|
| console.log(stdout);
|
| console.log(stderr);
|
| cb(err);
|
| });
|
| -})
|
| +});
|
| +
|
| +gulp.task('make_commonjs_out', ['dist', 'genproto_commonjs', 'commonjs_asserts', 'commonjs_testdeps'], function (cb) {
|
| + // TODO(haberman): minify this more aggressively.
|
| + // Will require proper externs/exports.
|
| + var cmd = "mkdir -p commonjs_out/binary && mkdir -p commonjs_out/test_node_modules && ";
|
| + function addTestFile(file) {
|
| + cmd += 'node commonjs/rewrite_tests_for_commonjs.js < ' + file +
|
| + ' > commonjs_out/' + file + '&& ';
|
| + }
|
|
|
| -gulp.task('deps', ['genproto'], function (cb) {
|
| + glob.sync('*_test.js').forEach(addTestFile);
|
| + glob.sync('binary/*_test.js').forEach(addTestFile);
|
| +
|
| + exec(cmd +
|
| + 'cp commonjs/jasmine.json commonjs_out/jasmine.json && ' +
|
| + 'cp google-protobuf.js commonjs_out/test_node_modules && ' +
|
| + 'cp commonjs/import_test.js commonjs_out/import_test.js',
|
| + function (err, stdout, stderr) {
|
| + console.log(stdout);
|
| + console.log(stderr);
|
| + cb(err);
|
| + });
|
| +});
|
| +
|
| +gulp.task('deps', ['genproto_closure'], function (cb) {
|
| exec('./node_modules/google-closure-library/closure/bin/build/depswriter.py *.js binary/*.js > deps.js',
|
| function (err, stdout, stderr) {
|
| console.log(stdout);
|
| console.log(stderr);
|
| cb(err);
|
| });
|
| -})
|
| +});
|
|
|
| -gulp.task('test', ['genproto', 'deps'], function (cb) {
|
| +gulp.task('test_closure', ['genproto_closure', 'deps'], function (cb) {
|
| exec('JASMINE_CONFIG_PATH=jasmine.json ./node_modules/.bin/jasmine',
|
| function (err, stdout, stderr) {
|
| console.log(stdout);
|
| @@ -27,3 +95,16 @@ gulp.task('test', ['genproto', 'deps'], function (cb) {
|
| cb(err);
|
| });
|
| });
|
| +
|
| +gulp.task('test_commonjs', ['make_commonjs_out'], function (cb) {
|
| + exec('cd commonjs_out && JASMINE_CONFIG_PATH=jasmine.json NODE_PATH=test_node_modules ../node_modules/.bin/jasmine',
|
| + function (err, stdout, stderr) {
|
| + console.log(stdout);
|
| + console.log(stderr);
|
| + cb(err);
|
| + });
|
| +});
|
| +
|
| +gulp.task('test', ['test_closure', 'test_commonjs'], function(cb) {
|
| + cb();
|
| +});
|
|
|