Skip to content

Latest commit

 

History

History
95 lines (76 loc) · 8.83 KB

README.md

File metadata and controls

95 lines (76 loc) · 8.83 KB

TypeStat

Converts JavaScript to TypeScript and TypeScript to better TypeScript. 🧫

👪 All Contributors: 12 🤝 Code of Conduct: Kept 🧪 Coverage 📝 License: MIT 📦 npm version 💪 TypeScript: Strict

Usage

TypeStat is a CLI utility that modifies TypeScript types in existing code. The built-in mutators will only ever add or remove types and will never change your runtime behavior. TypeStat can:

  • ✨ Convert JavaScript files to TypeScript in a single bound!
  • ✨ Add TypeScript types on files freshly converted from JavaScript to TypeScript!
  • ✨ Infer types to fix --noImplicitAny and --noImplicitThis violations!
  • ✨ Annotate missing nulls and undefineds to get you started with --strictNullChecks!

⚡ To start, the typestat command will launch an interactive guide to setting up a configuration file. ⚡

npx typestat
👋 Welcome to TypeStat! 👋
This will create a new typestat.json for you.
...

After, use typestat --config typestat.json to convert your files.

Configuration

To get a deeper understanding of TypeStat, read the following docs pages in order:

  1. Usage.md for an explanation of how TypeStat works
  2. Fixes.md for the type of fixes TypeStat will generate mutations for
  3. Cleanups.md for the post-fix cleaning TypeStat may apply to files
  4. Types.md for configuring how to work with types in mutations
  5. Filters.md for using tsquery to ignore sections of source files
  6. Custom Mutators.md for including or creating custom mutators

Development

See .github/CONTRIBUTING.md, then .github/DEVELOPMENT.md for general tooling documentation. For understanding the project, see ./docs in general, and especially ./docs/Architecture.md. Thanks! 💖

Contributors

Beyang Liu
Beyang Liu

💻
Daniel Stiner
Daniel Stiner

🐛
Deleted user
Deleted user

🚧
Emerson
Emerson

💻
Girish Sontakke
Girish Sontakke

💻
Guten
Guten

🐛
Ibrahim H.
Ibrahim H.

💻
Josh Goldberg ✨
Josh Goldberg ✨

🚧 🐛 🔧 💻 🚇 📖
Mark Molinaro
Mark Molinaro

🐛 💻
Nigel Gilbert
Nigel Gilbert

🐛
orionna319
orionna319

🐛
rubiesonthesky
rubiesonthesky

🐛 🚧 🔧 💻 ⚠️

💙 This package is based on @JoshuaKGoldberg's TypeStat.