Уменьшение времени выполнения закрытия Google с помощью gulp
Я пытаюсь найти альтернативу для plovr во время разработки, потому что plovr немного отстает, и обновление закрытия Google каждый раз становится проблематичным.
Поэтому я решил использовать глоток. Я настроил веб-сервер gulp, используя gulp connect, и в аварийном режиме он запускает компиляцию google closure, затем ждет, пока файл не будет сгенерирован, и затем отправит его клиенту. Проблема, с которой я сталкиваюсь, заключается в том, что время компиляции намного больше, чем plovr ~40 с ~20 с. Разработчику внешнего интерфейса, который будет долго ждать загрузки страницы после небольшого изменения. Любая идея, что можно сделать, чтобы оптимизировать время компиляции закрывающего компилятора. Вот мой gulpfile.js, чтобы дать вам представление о моей настройке.
var gulp = require('gulp'),
closureCompiler = require('google-closure-compiler').gulp({
extraArguments: ['-Xms2048m']
}),
fs = require('fs-extra'),
grepit = require('grepit'),
connect = require('gulp-connect'),
sleep = require('system-sleep'),
outputPath = './target/js',
pathToJavascriptCode = './project/',
compilationLevel = 'ADVANCED',
entryPoint = undefined;
gulp.task('js-clean', function() {
fs.removeSync(outputPath);
});
gulp.task('js-compile', function() {
var outputFileName = entryPoint + '.' + compilationLevel.toLowerCase() + '.js.compiled';
return gulp.src([
pathToJavascriptCode + '/**/*.js',
'./node_modules/google-closure-library/closure/goog/**/*.js',
'!./node_modules/google-closure-library/closure/goog/**/*_test.js'],
{base: './'})
.pipe(closureCompiler({
closure_entry_point: entryPoint,
externs: [
'./public/javascripts/libs/jquery-1.7-externs.js'],
compilation_level: compilationLevel,
warning_level: 'VERBOSE',
js_output_file: './' + outputFileName,
manage_closure_dependencies: true,
language_in: 'ECMASCRIPT6',
language_out: 'ECMASCRIPT5'
}))
.pipe(gulp.dest(outputPath))
.pipe(connect.reload());
});
gulp.task('webserver', function () {
connect.server({
root: ['./target/js/'],
port: 8080,
livereload: true,
middleware: function() {
return [function(req, res, next) {
res.setHeader('Access-Control-Allow-Origin', '*');
next();
}];
},
fallback: function(req, res) {
var requestedFileName = req.url.replace('/', '');
var requestedFileNameParts = requestedFileName.split('.');
compilationLevel = requestedFileNameParts[3] === 'simple' ? 'SIMPLE' : 'ADVANCED';
entryPoint = requestedFileNameParts[2] !== 'all' ? requestedFileNameParts.splice(0, 3).join('.') : undefined;
gulp.start('js-compile');
var path = './target/js' + req.url;
while(fs.existsSync(path) !== true) {
console.log(path + ' does not exist yet, sleeping for 1 second');
sleep(1000)
}
return path;
}
})
});
gulp.task('watch', function() {
gulp.watch('./project/pauljs/**/*.js', ['js-clean']);
});
gulp.task('default', ['js-clean', 'webserver', 'watch']);
После некоторого исследования я думаю, что проблема в медленном времени запуска jvm, я нашел этот https://www.npmjs.com/package/closure-gun который использует nailgun для запуска компилятора Google Closure, но я не уверен, как можно Я интегрирую это с моей текущей настройкой, любые указатели будут оценены:)
1 ответ
Я нашел ответ и добавил решение в readme google-closure-compiler npm repo https://github.com/google/closure-compiler-npm/pull/77/files