Skip to content

Commit

Permalink
Fix: Increase the instance version when new root files are found
Browse files Browse the repository at this point in the history
  • Loading branch information
davazp committed Jun 20, 2019
1 parent 6e95586 commit 07b1275
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 1 deletion.
20 changes: 19 additions & 1 deletion src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ function successLoader(
)
: rawFilePath;

const fileVersion = updateFileInCache(filePath, contents, instance);
const fileVersion = updateFileInCache(options, filePath, contents, instance);
const referencedProject = getAndCacheProjectReference(filePath, instance);
if (referencedProject !== undefined) {
const [relativeProjectConfigPath, relativeFilePath] = [
Expand Down Expand Up @@ -332,6 +332,7 @@ function makeLoaderOptions(instanceName: string, loaderOptions: LoaderOptions) {
* Also add the file to the modified files
*/
function updateFileInCache(
options: LoaderOptions,
filePath: string,
contents: string,
instance: TSInstance
Expand All @@ -358,6 +359,22 @@ function updateFileInCache(
fileWatcherEventKind = instance.compiler.FileWatcherEventKind.Deleted;
}

// filePath is a root file as it was passed to the loader. But it
// could have been found earlier as a dependency of another file. If
// that is the case, compiling this file changes the structure of
// the program and we need to increase the instance version.
//
// See https://github.com/TypeStrong/ts-loader/issues/943
if (
!instance.rootFileNames.has(filePath) &&
// however, be careful not to add files from node_modules unless
// it is allowed by the options.
(options.allowTsInNodeModules || filePath.indexOf('node_modules') === -1)
) {
instance.version!++;
instance.rootFileNames.add(filePath);
}

if (file.text !== contents) {
file.version++;
file.text = contents;
Expand All @@ -381,6 +398,7 @@ function updateFileInCache(
instance.modifiedFiles = new Map<string, TSFile>();
}
instance.modifiedFiles.set(filePath, file);

return file.version;
}

Expand Down
4 changes: 4 additions & 0 deletions src/instances.ts
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,7 @@ function successfulTypeScriptInstance(
}

const compilerOptions = getCompilerOptions(configParseResult);
const rootFileNames = new Set<string>();
const files: TSFiles = new Map<string, TSFile>();
const otherFiles: TSFiles = new Map<string, TSFile>();

Expand Down Expand Up @@ -200,6 +201,7 @@ function successfulTypeScriptInstance(
compilerOptions,
appendTsTsxSuffixesIfRequired,
loaderOptions,
rootFileNames,
files,
otherFiles,
program,
Expand All @@ -226,6 +228,7 @@ function successfulTypeScriptInstance(
text: fs.readFileSync(normalizedFilePath, 'utf-8'),
version: 0
});
rootFileNames.add(normalizedFilePath);
});
} catch (exc) {
return {
Expand All @@ -249,6 +252,7 @@ function successfulTypeScriptInstance(
compilerOptions,
appendTsTsxSuffixesIfRequired,
loaderOptions,
rootFileNames,
files,
otherFiles,
languageService: null,
Expand Down
1 change: 1 addition & 0 deletions src/interfaces.ts
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ export interface TSInstance {
/** Used for Vue for the most part */
appendTsTsxSuffixesIfRequired: (filePath: string) => string;
loaderOptions: LoaderOptions;
rootFileNames: Set<string>;
/**
* a cache of all the files
*/
Expand Down

0 comments on commit 07b1275

Please sign in to comment.