From e5e791215f2fa0c74d82497bc03295104cb4059f Mon Sep 17 00:00:00 2001 From: Joao Moreno Date: Fri, 20 Nov 2015 15:52:38 +0100 Subject: [PATCH] remove npm-install-plugin:* tasks --- build/gulpfile.plugins.js | 133 ++++++++++++++++---------------------- 1 file changed, 56 insertions(+), 77 deletions(-) diff --git a/build/gulpfile.plugins.js b/build/gulpfile.plugins.js index ace7acadab55b..51f0b50c6fadb 100644 --- a/build/gulpfile.plugins.js +++ b/build/gulpfile.plugins.js @@ -33,7 +33,6 @@ function getTSConfig(plugin) { } var pluginRoot = path.join(extensionsPath, plugin.desc.name); - var options = null; if (match[2]) { @@ -82,97 +81,77 @@ function readAllPlugins() { var tasks = readAllPlugins() .map(function (plugin) { + var options = getTSConfig(plugin); + + if (!options) { + return null; + } + var name = plugin.desc.name; var pluginRoot = path.join(extensionsPath, name); - var clean = 'clean-plugin:' + name; var compile = 'compile-plugin:' + name; var watch = 'watch-plugin:' + name; - var npmInstall = 'npm-install-plugin:' + name; - var hasnpmTask = (plugin.desc.dependencies && Object.keys(plugin.desc.dependencies).length > 0); + var sources = 'extensions/' + name + '/src/**'; + var deps = [ + 'src/vs/vscode.d.ts', + 'src/typings/mocha.d.ts', + 'extensions/declares.d.ts', + 'extensions/node.d.ts', + 'extensions/lib.core.d.ts' + ]; + + var pipeline = (function () { + var reporter = quiet ? null : createReporter(); + var compilation = tsb.create(options, null, null, quiet ? null : function (err) { reporter(err.toString()); }); + + return function () { + var input = es.through(); + var tsFilter = filter(['**/*.ts', '!**/lib/lib*.d.ts'], { restore: true }); + + var output = input + .pipe(tsFilter) + .pipe(compilation()) + .pipe(tsFilter.restore) + .pipe(quiet ? es.through() : reporter()); + + return es.duplex(input, output); + }; + })(); + + var sourcesRoot = path.join(pluginRoot, 'src'); + var sourcesOpts = { cwd: path.dirname(__dirname), base: sourcesRoot }; + var depsOpts = { cwd: path.dirname(__dirname) }; + + gulp.task(clean, function (cb) { + rimraf(path.join(pluginRoot, 'out'), cb); + }); - if (hasnpmTask) { - gulp.task(npmInstall, function (cb) { - cp.exec('npm install', { cwd: pluginRoot }, cb); - }); - } + gulp.task(compile, [clean], function () { + var src = es.merge(gulp.src(sources, sourcesOpts), gulp.src(deps, depsOpts)); - var options = getTSConfig(plugin); + return src + .pipe(pipeline()) + .pipe(gulp.dest('extensions/' + name + '/out')); + }); - if (options) { - var sources = 'extensions/' + name + '/src/**'; - var deps = [ - 'src/vs/vscode.d.ts', - 'src/typings/mocha.d.ts', - 'extensions/declares.d.ts', - 'extensions/node.d.ts', - 'extensions/lib.core.d.ts' - ]; - - var pipeline = (function () { - var reporter = quiet ? null : createReporter(); - var compilation = tsb.create(options, null, null, quiet ? null : function (err) { reporter(err.toString()); }); - - return function () { - var input = es.through(); - var tsFilter = filter(['**/*.ts', '!**/lib/lib*.d.ts'], { restore: true }); - - var output = input - .pipe(tsFilter) - .pipe(compilation()) - .pipe(tsFilter.restore) - .pipe(quiet ? es.through() : reporter()); - - return es.duplex(input, output); - }; - })(); - - var sourcesRoot = path.join(pluginRoot, 'src'); - var sourcesOpts = { cwd: path.dirname(__dirname), base: sourcesRoot }; - var depsOpts = { cwd: path.dirname(__dirname) }; - - gulp.task(clean, function (cb) { - rimraf(path.join(pluginRoot, 'out'), cb); - }); - - gulp.task(compile, hasnpmTask ? [clean, npmInstall] : [clean], function () { - var src = es.merge(gulp.src(sources, sourcesOpts), gulp.src(deps, depsOpts)); - - return src - .pipe(pipeline()) - .pipe(gulp.dest('extensions/' + name + '/out')); - }); - - gulp.task(watch, [clean], function () { - var src = es.merge(gulp.src(sources, sourcesOpts), gulp.src(deps, depsOpts)); - var watchSrc = es.merge(watcher(sources, sourcesOpts), watcher(deps, depsOpts)); - - return watchSrc - .pipe(util.incremental(pipeline, src)) - .pipe(gulp.dest('extensions/' + name + '/out')); - }); - } else { - if (hasnpmTask) { - gulp.task(clean, noop); - gulp.task(compile, [npmInstall], noop); - gulp.task(watch, noop); - } else { - return null; - } - } + gulp.task(watch, [clean], function () { + var src = es.merge(gulp.src(sources, sourcesOpts), gulp.src(deps, depsOpts)); + var watchSrc = es.merge(watcher(sources, sourcesOpts), watcher(deps, depsOpts)); + + return watchSrc + .pipe(util.incremental(pipeline, src)) + .pipe(gulp.dest('extensions/' + name + '/out')); + }); return { clean: clean, compile: compile, watch: watch }; - }); - -// remove null tasks -tasks = tasks.filter(function(task) { - return !!task; -}) + }) + .filter(function(task) { return !!task; }); gulp.task('clean-plugins', tasks.map(function (t) { return t.clean; })); gulp.task('compile-plugins', tasks.map(function (t) { return t.compile; }));