我在 vscode (0.9) 中使用 gulp 任务来尝试从 typescript 和 tslint 中获取错误。
gulp 任务正在监视我的 ts 文件的更改,并在更改时同时运行 gulp-tslint 和 gulp-typescript。我还在 vscode tasks.json 和问题匹配器中定义了一个任务来解析结果。
错误被解析并正确报告到 vscode 中。然而,即使代码被修复和保存,它们有时也会被保留。
是否有一些额外的配置可以提供给 vscode 问题匹配器,以便它正确清除错误或者它是 vscode 错误?作为一种解决方法,有没有办法手动清除所有错误?我发现清除它们的唯一方法是重新启动 vscode,这不是很好。
请注意,如果任务不是监视任务而是简单执行,则此方法可以正常工作。
我的 vscode tasks.json
{
"version": "0.1.0",
"command": "gulp",
"isShellCommand": true,
"tasks": [
{
"taskName": "watch",
// Make this the default build command.
"isBuildCommand": true,
// Watching
"isWatching": true,
// Show the output window only if unrecognized errors occur.
"showOutput": "always",
// Use the standard less compilation problem matcher.
"problemMatcher": [
{
"owner": "gulp-tslint",
"fileLocation": [
"relative",
"${workspaceRoot}/app"
],
"pattern": {
"regexp": ".*\\[gulp-tslint\\] (error|warning) (.*)\\[(\\d*), (\\d*)\\]: (.*)",
"severity": 1,
"file": 2,
"line": 3,
"column": 4,
"message": 5
}
},
{
"owner": "gulp-typescript",
"fileLocation": "absolute",
"pattern": {
"regexp": "\\[gulp-typescript\\] (.*)\\((\\d*),(\\d*)\\): (error|warning) (.*)",
"file": 1,
"line": 2,
"column": 3,
"severity": 4,
"message": 5
}
}
]
}
]
}
我的 gulp 任务定义:
const tslint = require('gulp-tslint');
const typescript = require('gulp-typescript');
gulp.task('watch', function () {
gulp.watch(srcTsFiles, ['tslint', 'compile']);
});
gulp.task('tslint', function () {
return gulp.src(srcTsFiles)
.pipe(tslint())
.pipe(tslint.report('prose', {
emitError: false,
summarizeFailureOutput: true
}));
});
var tsProject = typescript.createProject('tsconfig.json');
gulp.task('compile', function () {
tsProject.src()
.pipe(typescript(tsProject, undefined, typescript.reporter.longReporter()))
.pipe(gulp.dest('dist'));
});