remove npm-install-plugin:* tasks

pull/398/merge
Joao Moreno 2015-11-20 15:52:38 +01:00
parent 96d34d983d
commit e5e791215f
1 changed files with 49 additions and 70 deletions

View File

@ -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'
];
if (hasnpmTask) {
gulp.task(npmInstall, function (cb) {
cp.exec('npm install', { cwd: pluginRoot }, cb);
});
}
var pipeline = (function () {
var reporter = quiet ? null : createReporter();
var compilation = tsb.create(options, null, null, quiet ? null : function (err) { reporter(err.toString()); });
var options = getTSConfig(plugin);
return function () {
var input = es.through();
var tsFilter = filter(['**/*.ts', '!**/lib/lib*.d.ts'], { restore: true });
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 output = input
.pipe(tsFilter)
.pipe(compilation())
.pipe(tsFilter.restore)
.pipe(quiet ? es.through() : reporter());
var pipeline = (function () {
var reporter = quiet ? null : createReporter();
var compilation = tsb.create(options, null, null, quiet ? null : function (err) { reporter(err.toString()); });
return es.duplex(input, output);
};
})();
return function () {
var input = es.through();
var tsFilter = filter(['**/*.ts', '!**/lib/lib*.d.ts'], { restore: true });
var sourcesRoot = path.join(pluginRoot, 'src');
var sourcesOpts = { cwd: path.dirname(__dirname), base: sourcesRoot };
var depsOpts = { cwd: path.dirname(__dirname) };
var output = input
.pipe(tsFilter)
.pipe(compilation())
.pipe(tsFilter.restore)
.pipe(quiet ? es.through() : reporter());
gulp.task(clean, function (cb) {
rimraf(path.join(pluginRoot, 'out'), cb);
});
return es.duplex(input, output);
};
})();
gulp.task(compile, [clean], function () {
var src = es.merge(gulp.src(sources, sourcesOpts), gulp.src(deps, depsOpts));
var sourcesRoot = path.join(pluginRoot, 'src');
var sourcesOpts = { cwd: path.dirname(__dirname), base: sourcesRoot };
var depsOpts = { cwd: path.dirname(__dirname) };
return src
.pipe(pipeline())
.pipe(gulp.dest('extensions/' + name + '/out'));
});
gulp.task(clean, function (cb) {
rimraf(path.join(pluginRoot, 'out'), cb);
});
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));
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;
}
}
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; }));