Add support for diagnostic severities
See original GitHub issueTypeScript has added compiler options for lint level checks like noUnusedParameters
or noUnusedLocals
in tsconfig.json (which is goodness). Today when such an option is enabled then the corresponding issues are reported by TypeScript in the same way as semantic or syntax errors. There is no notion of severity.
Background
We are using tslint to develop VS Code and we have used tslint rules to detect unused locals. TSLint rule failures are reported in VS code as warnings and we had the setup that lint style issue are shown as warnings and the typescript issues (syntax, semantic) are shown as errors. Now that typescript added more lint style checks we no longer get the distinction when developing between lint level warnings and semantic errors. The situation has become worse with tslint 4.0, there tslint has started to deprecate rules which are covered by TypeScript compiler options. This makes good sense, but it means we are now starting to see ‘unused locals’ reported as errors and no longer as warnings as we did before.
Suggestion
Support that the user can define in the tsconfig.json whether a check enabled by compiler option should be reported as error
or warning
.
eslint
supports to configure the severity of an option. Here is an example the eslint documentation:
{
"rules": {
"eqeqeq": "off",
"curly": "warn",
"quotes": ["error", "double"]
}
}
Issue Analytics
- State:
- Created 7 years ago
- Reactions:108
- Comments:39 (26 by maintainers)
Top GitHub Comments
As a newcomer to TypeScript, I find it rather confusing that there are two places to define similar rules:
tsconfig.json:
noUnusedLocals
tslint.json:no-unused-variables
In fact, in VS Code, the latter will not even check properly unless the former is defined. But if I set
noUnusedLocals
totrue
, there are no severity levels (everything is an error) and it causes my app to fail to load if I have an unused var. This isn’t a great developer experience.I’d love to see this feature in the roadmap. Could this become part of 2.3?
I personally need this for warnings for