Microsoft/TypeScript
View on GitHubMove away from Classic module resolution as default for all module kinds
Open
#11,434 opened on Oct 6, 2016
CommittedEffort: ModerateHelp WantedSuggestion
Description
TypeScript's original module resolution strategy (the Classic resolution strategy) has some strange behavior that apparently doesn't actually reflect any other resolution strategy. It seems strange that those using non-CommonJS emit targets get this behavior by default.
Classic resolution also causes many disk probes during the walk up the project root - assuming that this strategy does eventually succeed in most cases, it seems like most uses could be subsumed by:
- Using relative paths.
- Modifying the
baseUrlandpathsproperties intsconfig.json.
After discussing with @vladima, we think it is worth considering switching the default resolution strategy for all module targets to Node.
Here's what needs to be done:
- Investigate existing
tsconfig.jsons that target esXXXX` and have no explicit/implied resolution strategy. - Determine the downstream effects to a change to defaults
- Determine if this change outweighs the potential breakage
- Implement if appropriate