A parser that converts TypeScript into an ESTree-compatible form so it can be used in ESLint.
Important: This parser is not fully compatible with all ESLint rules and plugins. Some rules will improperly mark source code as failing or not find problems where it should.
We will always endeavor to support the latest stable version of TypeScript.
The version of TypeScript currently supported by this parser is ~2.6.1
. This is reflected in the devDependency
requirement within the package.json file, and it is what the tests will be run against. We have an open peerDependency
requirement in order to allow for experimentation on newer/beta versions of TypeScript.
If you use a non-supported version of TypeScript, the parser will log a warning to the console.
Please ensure that you are using a supported version before submitting any issues/bug reports.
The following ESLint rules will fail on acceptable code:
The follow ESLint plugins have issues when used with this parser:
- eslint-plugin-react #213
- eslint-plugin-import
- prefer-default-export - Will fail exports inside of Namespaces or Modules
The following TypeScript syntax will cause rules to fail or ESLint v3 to crash:
- Empty body functions
- Abstract methods
- Function overloading
- Declared functions
Install:
npm i typescript-eslint-parser --save-dev
And in your ESLint configuration file:
"parser": "typescript-eslint-parser"
If you're familiar with TypeScript and ESLint, and you'd like to see this project progress, please consider contributing. We need people with a good knowledge of TypeScript to ensure this parser is useful.
Please check the current list of open and known issues and ensure the bug has not been reported before. When creating a new issue provide as much information about your environment as possible. This includes:
- ESLint Version
- TypeScript version
- TypeScript parser version
- ESLint config or rules and plugins currently enabled
As well include a small code sample that can be used to reproduce the issue.
Issues and pull requests will be triaged and responded to as quickly as possible. We operate under the ESLint Contributor Guidelines, so please be sure to read them before contributing. If you're not sure where to dig in, check out the issues.
npm test
- run all linting and testsnpm run lint
- run all linting
TypeScript ESLint Parser is licensed under a permissive BSD 2-clause license.