π Search Terms
skipLibCheck specific files
β
Viability Checklist
β Suggestion
Currently skipLibCheck is an all or nothing proposition. You either suppress all errors from declaration files or you get errors from all declaration files. This is not really an accurate reflection of how declaration files are usually used. Almost all projects use declaration files from a trusted source, like npm. Errors from these files are usually not relevant and can be safely suppressed. Many projects however also have declaration files they write by hand (usually for interop with js files, or for libraries that are not typed) - these generally should be type checked since they are actively authored as part of the project.
Ideally skipLibCheck would allow us to more granularly control which declaration files are checked and which are not. This allows us to reap the performance benefits of skipLibCheck while not sacrificing type checking on authored code.
Proposal
One possible solution would be to allow skipLibCheck to be a list of glob patterns for which type checking should be skipped. This would be a simple solution allowing users to decide what declaration files they want and don't want checked.
While this solution is probably the simplest one to implement, we should consider other ones.
π Motivating Example
We have a custom build tool that uses the compiler API to force some declaration files to skip checking by setting their hasDefaultLib flag and using skipDefaultLibCheck instead of skipLibCheck. While this solution worked well in the past this is not really a supported solution which we expect will break (6.0 already breaks our current implementation - we have found an alternate implementation, 7.0 will make any sort of custom solution much more difficult)
π» Use Cases
-
What do you want to use this for?
Improve build performance of TypeScript projects.
-
What shortcomings exist with current approaches?
You can suppress errors from all declaration files or from none. There is no granular control over it.
-
What workarounds are you using in the meantime?
Use the compiler API to control which declaration files are checked.
π Search Terms
skipLibCheck specific files
β Viability Checklist
β Suggestion
Currently
skipLibCheckis an all or nothing proposition. You either suppress all errors from declaration files or you get errors from all declaration files. This is not really an accurate reflection of how declaration files are usually used. Almost all projects use declaration files from a trusted source, like npm. Errors from these files are usually not relevant and can be safely suppressed. Many projects however also have declaration files they write by hand (usually for interop with js files, or for libraries that are not typed) - these generally should be type checked since they are actively authored as part of the project.Ideally
skipLibCheckwould allow us to more granularly control which declaration files are checked and which are not. This allows us to reap the performance benefits ofskipLibCheckwhile not sacrificing type checking on authored code.Proposal
One possible solution would be to allow
skipLibCheckto be a list of glob patterns for which type checking should be skipped. This would be a simple solution allowing users to decide what declaration files they want and don't want checked.While this solution is probably the simplest one to implement, we should consider other ones.
π Motivating Example
We have a custom build tool that uses the compiler API to force some declaration files to skip checking by setting their
hasDefaultLibflag and usingskipDefaultLibCheckinstead ofskipLibCheck. While this solution worked well in the past this is not really a supported solution which we expect will break (6.0 already breaks our current implementation - we have found an alternate implementation, 7.0 will make any sort of custom solution much more difficult)π» Use Cases
What do you want to use this for?
Improve build performance of TypeScript projects.
What shortcomings exist with current approaches?
You can suppress errors from all declaration files or from none. There is no granular control over it.
What workarounds are you using in the meantime?
Use the compiler API to control which declaration files are checked.