espree
typescript-eslint
espree | typescript-eslint | |
---|---|---|
5 | 123 | |
2,246 | 14,701 | |
0.2% | 0.8% | |
6.2 | 9.9 | |
17 days ago | 2 days ago | |
JavaScript | TypeScript | |
BSD 2-clause "Simplified" License | GNU General Public License v3.0 or later |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
espree
-
ESLint: under the hood
Focusing again on ESLint, the parser used by the linter is called Espree. This is an in-house parser built by the ESLint folks to fully support ECMAScript 6 and JSX on top of the already existing Esprima. The Espree module provide APIs for both tokenization and parsing that you can easily test out.
-
Abstract Syntax Trees and Practical Applications in JavaScript
Why do we then have other JavaScript parsers like babel parser, swc parser, acorn, espree and the likes since JavaScript engines have their own internal parsers?
-
Quick start with ESLint
How does ESLint work? ESLint uses Espree for Javascript parsing. It uses an AST to evaluate patterns in code. It does all this before runtime.. meaning, without running your Javascript code it will find the bugs, syntax and stylistic errors.
-
Gentle Introduction To ESLint Rules
ESLint doesn't process the code into the compiler phases, rather it provides an option to let you specify a Parser. By default, ESLint uses Espree which essentially converts JS source code to AST data structure, so in case you want to write a rule targeting TypeScript source code, you'll need to specify a different parser in your .eslintrc.json configuration file, same applies for different file extension, for HTML you might use this or creating your own parser!
- Show HN: Monocle – bidirectional code generation library
typescript-eslint
-
Mastering Type-Safe JSON Serialization in TypeScript
Typescript-eslint can assist in this task. This tool helps identify all instances of unsafe any usage. Specifically, all usages of JSON.parse can be found and it can be ensured that the received data's format is checked. More about getting rid of the any type in a codebase can be read in the article Making TypeScript Truly "Strongly Typed".
-
Oxlint – written in Rust – 50-100 Times Faster than ESLint
> Only lint files that have changed? How hard that is?
Quite hard, especially since type-aware rules from e.g. https://typescript-eslint.io/ mean that changing the type of a variable in file A can break your code in file B, even if file B hasn't changed.
-
How to Do a TypeScript Conversion: an opinionated take on gradual conversions
The article only touches this: when converting to TypeScript, `any` is useful, but in the end you don't want this type in your codebase - so don't forget to use typescript-eslint [0] and turn on those no-unsafe-* rules which guard against `any` leaking into your code.
[0] https://github.com/typescript-eslint/typescript-eslint
- How do I add additional rules to my typescript-eslint settings?
- What's the best config for typescript-eslint?
- How do you add angular-eslint to your typescript-eslint config?
- What's the best typescript-eslint config?
-
The Best ESLint Rules for React Projects
By convention, React components should be named in PascalCase. @typescript-eslint has the config we need, and though we can't specifically target React components, we can target variables (and set some other conventions while we're at it):
- Open source public fund experiment - One and a half years update
- Never touch those //ts-ignores
What are some alternatives?
escodegen - ECMAScript code generator
eslint-config-google - ESLint shareable config for the Google JavaScript style guide
recast - JavaScript syntax tree transformer, nondestructive pretty-printer, and automatic source map generator
angular-eslint - :sparkles: Monorepo for all the tooling related to using ESLint with Angular
Babel (Formerly 6to5) - 🐠 Babel is a compiler for writing next generation JavaScript.
ts-standard - Typescript style guide, linter, and formatter using StandardJS
Acorn - A small, fast, JavaScript-based JavaScript parser
zod - TypeScript-first schema validation with static type inference
estree - The ESTree Spec
node-clinic - Clinic.js diagnoses your Node.js performance issues
babel-plugin-handbook - How to create Babel plugins
ts-node - TypeScript execution and REPL for node.js