fork-ts-checker-webpack-plugin
Last updated
Was this helpful?
Last updated
Was this helpful?
Webpack plugin that runs TypeScript type checker on a separate process.
This plugin requires minimum webpack 2.3, TypeScript 2.1 and optionally ESLint 6.0.0 or TSLint 4.0
Basic webpack config (with )
To debug TypeScript's modules resolution, you can use tsc --traceResolution
command.
yarn add eslint @typescript-eslint/parser @typescript-eslint/eslint-plugin --dev
You should have an ESLint configuration file in your root project directory. Here is a sample .eslintrc.js
configuration for a TypeScript project:
tsconfig string
: Path to tsconfig.json file. Default: path.resolve(compiler.options.context, './tsconfig.json')
.
compilerOptions object
: Allows overriding TypeScript options. Should be specified in the same format as you would do for the compilerOptions
property in tsconfig.json. Default: {}
.
eslint true | undefined
:
If true
, this activates eslint support.
eslintOptions object
:
Options that can be used to initialise ESLint. See https://eslint.org/docs/1.0.0/developer-guide/nodejs-api#cliengine
tslint string | true | undefined
:
If string
, path to tslint.json file to check source files against.
If true
, path to tslint.json
file will be computed with respect to currently checked file, just like TSLint CLI would do. Suppose you have a project:
In such a case src/file.ts
and src/anotherFile.ts
would be checked against root tslint.json
, and src/lib/someHelperFile.ts
would be checked against src/lib/tslint.json
.
Default: undefined
.
tslintAutoFix boolean
: Passes on --fix
flag while running tslint
to auto fix linting errors. Default: false.
watch string | string[]
: Directories or files to watch by service. Not necessary but improves performance (reduces number of fs.stat
calls). Not applicable when useTypescriptIncrementalApi
is true
, in which case watching is handled automatically.
async boolean
: True by default - async: false
can block webpack's emit to wait for type checker/linter and to add errors to the webpack's compilation. We recommend to set this to false
in projects where type checking is faster than webpack's build - it's better for integration with other plugins. Another scenario where you might want to set this to false
is if you use the overlay
functionality of webpack-dev-server
.
ignoreDiagnostics number[]
: List of TypeScript diagnostic codes to ignore.
ignoreLints string[]
: List of tslint rule names to ignore.
ignoreLintWarnings boolean
: If true, will ignore all lint warnings.
colors boolean
: If false
, disables built-in colors in logger messages. Default: true
.
logger object
: Logger instance. It should be object that implements method: error
, warn
, info
. Default: console
.
formatter 'default' | 'codeframe' | ((message: NormalizedMessage, useColors: boolean) => string)
: Formatter for diagnostics and lints. By default uses default
formatter. You can also pass your own formatter as a function (see src/NormalizedMessage.js
and src/formatter/
for api reference).
silent boolean
: If true
, logger will not be used. Default: false
.
memoryLimit number
: Memory limit for service process in MB. If service exits with allocation failed error, increase this number. Default: 2048
.
workers number
: You can split type checking to a few workers to speed-up increment build. Be careful - if you don't want to increase build time, you should keep free 1 core for build and 1 core for a system (for example system with 4 CPUs should use max 2 workers). Second thing - node doesn't share memory between workers - keep in mind that memory usage will increase. Be aware that in some scenarios increasing workers number can increase checking time. Default: ForkTsCheckerWebpackPlugin.ONE_CPU
.
useTypescriptIncrementalApi boolean
: If true, the plugin will use incremental compilation API introduced in TypeScript 2.7. In this mode you can only have 1 worker, but if the changes in your code are small (like you normally have when you work in 'watch' mode), the compilation may be much faster, even compared to multi-threaded compilation. Defaults to true
when working with TypeScript 3+ and false
when below 3. The default can be overridden by directly specifying a value.
measureCompilationTime boolean
: If true, the plugin will measure the time spent inside the compilation code. This may be useful to compare modes, especially if there are other loaders/plugins involved in the compilation. requires node 8+
typescript string
: If supplied this is a custom path where typescript
can be found. Defaults to require.resolve('typescript')
.
resolveModuleNameModule and resolveTypeReferenceDirectiveModule string
: Both of those options refer to files on the disk that respectively export a resolveModuleName
or a resolveTypeReferenceDirectiveModule
function. These functions will be used to resolve the import statements and the <reference types="...">
directives instead of the default TypeScript implementation. Check the following code for an example of what those functions should look like:
ForkTsCheckerWebpackPlugin.ONE_CPU
- always use one CPU
ForkTsCheckerWebpackPlugin.ALL_CPUS
- always use all CPUs (will increase build time)
ForkTsCheckerWebpackPlugin.ONE_CPU_FREE
- leave only one CPU for build (probably will increase build time)
ForkTsCheckerWebpackPlugin.TWO_CPUS_FREE
- recommended - leave two CPUs free (one for build, one for system)
You can either set silent: false
to show the logging from fork-ts-checker-notifier-webpack-plugin
or set async: false
. Now webpack itself will log type errors again, but note that this can slow down your builds depending on the size of your project.
At present there is an issue with the plugin regarding the triggering of type-checking when a change is made in a source file that will not emit js. If you have a file which contains only interface
s and / or type
s then changes to it will not trigger the type checker whilst in watch mode. Sorry about that.
This plugin provides some custom webpack hooks (all are sync):
fork-ts-checker-cancel
cancel
Cancellation has been requested
cancellationToken
fork-ts-checker-waiting
waiting
Waiting for results
hasTsLint
fork-ts-checker-service-before-start
serviceBeforeStart
Async plugin that can be used for delaying fork-ts-checker-service-start
-
fork-ts-checker-service-start
serviceStart
Service will be started
tsconfigPath
, tslintPath
, watchPaths
, workersNumber
, memoryLimit
fork-ts-checker-service-start-error
serviceStartError
Cannot start service
error
fork-ts-checker-service-out-of-memory
serviceOutOfMemory
Service is out of memory
-
fork-ts-checker-receive
receive
Plugin receives diagnostics and lints from service
diagnostics
, lints
fork-ts-checker-emit
emit
Service will add errors and warnings to webpack compilation ('build' mode)
diagnostics
, lints
, elapsed
fork-ts-checker-done
done
Service finished type checking and webpack finished compilation ('watch' mode)
diagnostics
, lints
, elapsed
The Event name is there for backward compatibility with webpack 2/3. Regardless of the version of webpack (2, 3 or 4) you are using, we will always access plugin hooks with Hook Access Keys as described below.
Calling .tap()
on any hooks, requires two arguments.
name
(string
)
callback
(function
)
The second argument is the callback function. Depending on the hook you are tapping into, several arguments are passed to the function. Do check the table above to find out which arguments are passed to which hooks.
Turn on the vue option in the plugin in your webpack config:
To activate TypeScript in your .vue
files, you need to ensure your script tag's language attribute is set to ts
or tsx
(also make sure you include the .vue
extension in all your import statements as shown below):
Ideally you are also using ts-loader
(in transpileOnly mode). Your Webpack config rules may look something like this:
Ensure your tsconfig.json
includes .vue files:
It accepts any wildcard in your TypeScript configuration:
MIT License
There was already similar solution - . You can add CheckerPlugin
and delegate checker to the separate process. The problem with awesome-typescript-loader
was that, in our case, it was a lot slower than on an incremental build (~20s vs ~3s). Secondly, we used and we wanted to run this, along with type checker, in a separate process. This is why this plugin was created. To provide better performance, the plugin reuses Abstract Syntax Trees between compilations and shares these trees with TSLint. It can be scaled with a multi-process mode to utilize maximum CPU power.
It's very important to be aware that this plugin uses 's, not 's modules resolution. It means that you have to setup tsconfig.json
correctly. For example if you set files: ['./src/someFile.ts']
in tsconfig.json
, this plugin will check only someFile.ts
for semantic errors. It's because of performance. The goal of this plugin is to be as fast as possible. With TypeScript's module resolution we don't have to wait for webpack to compile files (which traverses dependency graph during compilation) - we have a full list of files from the begin.
If you'd like to use eslint with the plugin, supply this option: eslint: true
and ensure you have the relevant dependencies installed:
There's a good explanation on setting up TypeScript ESLint support by Robert Cooper .
. https://eslint.org/blog/2019/01/future-typescript-eslint. As a consequence, support for TSLint in fork-ts-checker-webpack-plugin will be deprecated and removed in future versions of the plugin.
If you have installed , you can enable it by setting tslint: true
or tslint: './path/to/tslint.json'
. We recommend changing defaultSeverity
to a "warning"
in tslint.json
file. It helps to distinguish lints from TypeScript's diagnostics.
reportFiles string[]
: Only report errors on files matching these glob patterns. This can be useful when certain types definitions have errors that are not fatal to your application. Default: []
. Please note that this may behave unexpectedly if using the incremental API as the incremental API doesn't look for global and semantic errors .
formatterOptions object
: Options passed to formatters (currently only codeframe
- see )
checkSyntacticErrors boolean
: This option is useful if you're using ts-loader in happyPackMode
with or to parallelise your builds. If true
it will ensure that the plugin checks for both syntactic errors (eg const array = [{} {}];
) and semantic errors (eg const x: number = '1';
). By default the plugin only checks for semantic errors. This is because when ts-loader is used in transpileOnly
mode, ts-loader will still report syntactic errors. When used in happyPackMode
it does not. Default: false
.
vue boolean | { enabled: boolean, compiler: string }
: If true
or enabled: true
, the linter and compiler will process VueJs single-file-component (.vue) files. See the further down for information on how to correctly setup your project.
If you turn on the fork-ts-checker-notifier-webpack-plugin
will take care of logging type errors, not webpack itself. That means if you set silent: true
you won't see type errors in your console in watch mode.
You may already be using the excellent plugin to make build failures more obvious in the form of system notifications. There's an equivalent notifier plugin designed to work with the fork-ts-checker-webpack-plugin
. It is the fork-ts-checker-notifier-webpack-plugin
and can be found . This notifier deliberately has a similar API as the webpack-notifier
plugin to make migration easier.
We hope this will be resolved in future; the issue can be tracked .
All plugin hooks are compatible with both version 4 and version 2. To access plugin hooks and tap into the event, we need to use the getCompilerHooks
static method. When we call this method with a , it returns the series of hooks where you can pass in your callbacks.
The first argument passed to .tap
is the name of your listener callback (yourListenerName
). It doesn't need to correspond to anything special. It is intended to be used as the name
of the hook.
The above method will not work on webpack instance. The reason is getCompilerHooks
expects (at lease as of now) the same compiler instance to be passed where the plugin was attached. So in case of multi compiler, we need to access individual compiler instances.
Optionally change default to if you use
Add rules to your tslint.json
and they will be applied to Vue files. For example, you could apply the Standard JS rules like this:
If you are working in VSCode, you can get extensions and to complete the developer workflow.
This plugin was created in in 2017. Thank you for supporting Open Source.