Webpack crashes gulp watch when it fails to compile typescript code
Webpack crashes gulp watch when it fails to compile typescript code
我有一个 gulp-watch 任务 运行ning 正在编译我的前端应用程序。当我遇到打字稿错误时(可能只是因为我过早地点击了保存),整个过程崩溃了,我必须手动重新启动它。我希望 webpack 和 typescript 编译器只报告错误,只要它们 运行 处于监视模式,而不是使进程崩溃。
我的 gulp 使用 webpack 编译我的 typescript 应用程序的任务:
gulp.task('scripts', function (callback) {
var isWatching = watchEnabled;
var webpackOptions = {
resolve: { extensions: ['', '.ts'] },
watch: watchEnabled,
module: {
preLoaders: [{ test: /\.ts$/, exclude: /node_modules/, loader: 'tslint-loader' }],
loaders: [{ test: /\.ts$/, exclude: /node_modules/, loader: 'awesome-typescript-loader' }]
},
output: { filename: 'app.js' },
tslint: { emitErrors: !watchEnabled } // tslint crashes gulp when emitting errors, so don't do it while watch is enabled
};
if (debugEnabled) {
webpackOptions.devtool = 'inline-source-map';
}
var webpackChangeHandler = function (err, stats) {
if (err) {
console.error('Webpack', err);
}
$.util.log(stats.toString({
colors: $.util.colors.supportsColor,
chunks: false,
hash: false,
version: false
}));
if (isWatching) {
isWatching = false;
callback();
}
};
return gulp.src('./Scripts/application/app.ts')
.pipe(webpack(webpackOptions, null, webpackChangeHandler))
.pipe($.if(!debugEnabled, $.uglify()))
.pipe($.if(!watchEnabled, $.rev()))
.pipe(gulp.dest(tmpFolder + 'Content/'));
});
在 CI 服务器中编译时,编译和 tslint 错误会使进程崩溃并且 CI 服务器报告错误是好的。
但是开发的时候很烦人。只要 gulp watch 和 webpack watch 是 运行ning,我就通过关闭 emitErrors 解决了 tslint 问题。但是对于打字稿编译,我不确定该怎么做。
我应该在 webpack 或 awesome-typescript-loader 上找到这个选项吗?
我在 awesome-typescript-loader github 仓库中没有找到任何适合这个问题的东西,这让我觉得我应该启用一些 webpack 选项,但是哪个?
有同样的问题。这对我有用
var wp = webpack(webpackOptions, null, webpackChangeHandler);
// can bind error to console, but it will be duplicated with webpackChangeHandler err
// wp.on('error', console.error.bind(console));
wp.on('error', function() {});
return gulp.src('./Scripts/application/app.ts')
.pipe(wp)
.pipe($.if(!debugEnabled, $.uglify()))
.pipe($.if(!watchEnabled, $.rev()))
.pipe(gulp.dest(tmpFolder + 'Content/'));
我有一个 gulp-watch 任务 运行ning 正在编译我的前端应用程序。当我遇到打字稿错误时(可能只是因为我过早地点击了保存),整个过程崩溃了,我必须手动重新启动它。我希望 webpack 和 typescript 编译器只报告错误,只要它们 运行 处于监视模式,而不是使进程崩溃。
我的 gulp 使用 webpack 编译我的 typescript 应用程序的任务:
gulp.task('scripts', function (callback) {
var isWatching = watchEnabled;
var webpackOptions = {
resolve: { extensions: ['', '.ts'] },
watch: watchEnabled,
module: {
preLoaders: [{ test: /\.ts$/, exclude: /node_modules/, loader: 'tslint-loader' }],
loaders: [{ test: /\.ts$/, exclude: /node_modules/, loader: 'awesome-typescript-loader' }]
},
output: { filename: 'app.js' },
tslint: { emitErrors: !watchEnabled } // tslint crashes gulp when emitting errors, so don't do it while watch is enabled
};
if (debugEnabled) {
webpackOptions.devtool = 'inline-source-map';
}
var webpackChangeHandler = function (err, stats) {
if (err) {
console.error('Webpack', err);
}
$.util.log(stats.toString({
colors: $.util.colors.supportsColor,
chunks: false,
hash: false,
version: false
}));
if (isWatching) {
isWatching = false;
callback();
}
};
return gulp.src('./Scripts/application/app.ts')
.pipe(webpack(webpackOptions, null, webpackChangeHandler))
.pipe($.if(!debugEnabled, $.uglify()))
.pipe($.if(!watchEnabled, $.rev()))
.pipe(gulp.dest(tmpFolder + 'Content/'));
});
在 CI 服务器中编译时,编译和 tslint 错误会使进程崩溃并且 CI 服务器报告错误是好的。
但是开发的时候很烦人。只要 gulp watch 和 webpack watch 是 运行ning,我就通过关闭 emitErrors 解决了 tslint 问题。但是对于打字稿编译,我不确定该怎么做。
我应该在 webpack 或 awesome-typescript-loader 上找到这个选项吗?
我在 awesome-typescript-loader github 仓库中没有找到任何适合这个问题的东西,这让我觉得我应该启用一些 webpack 选项,但是哪个?
有同样的问题。这对我有用
var wp = webpack(webpackOptions, null, webpackChangeHandler);
// can bind error to console, but it will be duplicated with webpackChangeHandler err
// wp.on('error', console.error.bind(console));
wp.on('error', function() {});
return gulp.src('./Scripts/application/app.ts')
.pipe(wp)
.pipe($.if(!debugEnabled, $.uglify()))
.pipe($.if(!watchEnabled, $.rev()))
.pipe(gulp.dest(tmpFolder + 'Content/'));