Skip to content

Commit

Permalink
remove npm-install-plugin:* tasks
Browse files Browse the repository at this point in the history
  • Loading branch information
joaomoreno committed Nov 20, 2015
1 parent 96d34d9 commit e5e7912
Showing 1 changed file with 56 additions and 77 deletions.
133 changes: 56 additions & 77 deletions build/gulpfile.plugins.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,6 @@ function getTSConfig(plugin) {
}

var pluginRoot = path.join(extensionsPath, plugin.desc.name);

var options = null;

if (match[2]) {
Expand Down Expand Up @@ -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; }));
Expand Down

0 comments on commit e5e7912

Please sign in to comment.