🚧 Work in progress, follow for updates
tsrf is a build tool that elevates developer experience and performance of type-checking TypeScript code in a monorepo.
It combines the power of npm workspaces with TypeScript Project References
It automatically maintains the dependencies tree for each module, removing the need for you to manually update tsconfig.json
or package.json
for every module.
Type-checking in a monorepo was always a compromise:
-
You either run separate
tsc
instances for each module and have accurate but messy reports and poor performance. -
Or you give up on accuracy and use a single
tsconfig.json
but open doors for bugs and incompatibility between modules. -
Or you use TypeScript Project References to address said problems but spend your time tediously maintaining references between modules.
tsrf solves this dilemma by automatically detecting and updating references so you can have accuracy, performance, and time to work on what's important.
Additionally, it maintains module dependencies so you don't have to add a workspace module to package.json
every time you start using it.
To get started, install tsrf
npm package:
npm install tsrf
Now run the doctor command to check the compatibility and required changes:
npx tsrf doctor
It will give you a breakdown of required changes that can be made via doctor --fix
:
npx tsrf doctor --fix
Now you're ready to start the watch mode:
npx tsrf
It will patch the project configs to match the necessary settings and run the compiler in watch mode.
tsrf wraps the TypeScript compiler and updates references in the background using the build information reported by TypeScript.
You simply run tsrf
instead of tsc --build --watch
, and tsrf will do the rest.
-
It creates
tsconfig.tsrf.json
in the project's root and assigns thereferences
to include all matching modules within the workspaces specified in thepackage.json
. -
It updates
references
andpath
aliases in each matching moduletsconfig.json
using the dependencies tree parsed from the build info provided by the compiler. tsrf also sets the required settings. -
It updates
package.json
dependencies and adds missing workspace modules when you start using one.
I personally use it with Turborepo, and I'm sure you can use it with any or no monorepo build tool at all.
A matching module is a module specified or matched by the glob pattern in the package.json
workspaces
property. Additionally, the module should have a valid package.json
and tsconfig.json
.
See the changelog.