fix(ivy): always convert `rootDirs` to `AbsoluteFsPath` in `getRootDirs` (#29151)
`getCurrentDirectory` directory doesn't return a posix separated normalized path. While `rootDir` and `rootDirs` should return posix separated paths, it's best to not assume as other paths within the compiler options can be returned not posix separated such as `basePath` See: https://github.com/Microsoft/TypeScript/blob/master/src/compiler/sys.ts#L635 This partially fixes #29140, however there needs to be a change in the CLI as well to handle this, as at the moment we are leaking devkit paths which is not correct. Fixes #29140 PR Close #29151
This commit is contained in:
parent
a5b8420234
commit
ca20f571b8
|
@ -78,7 +78,12 @@ export function getRootDirs(host: ts.CompilerHost, options: ts.CompilerOptions):
|
||||||
} else {
|
} else {
|
||||||
rootDirs.push(host.getCurrentDirectory());
|
rootDirs.push(host.getCurrentDirectory());
|
||||||
}
|
}
|
||||||
return rootDirs.map(rootDir => AbsoluteFsPath.fromUnchecked(rootDir));
|
|
||||||
|
// In Windows the above might not always return posix separated paths
|
||||||
|
// See:
|
||||||
|
// https://github.com/Microsoft/TypeScript/blob/3f7357d37f66c842d70d835bc925ec2a873ecfec/src/compiler/sys.ts#L650
|
||||||
|
// Also compiler options might be set via an API which doesn't normalize paths
|
||||||
|
return rootDirs.map(rootDir => AbsoluteFsPath.from(rootDir));
|
||||||
}
|
}
|
||||||
|
|
||||||
export function nodeDebugInfo(node: ts.Node): string {
|
export function nodeDebugInfo(node: ts.Node): string {
|
||||||
|
|
Loading…
Reference in New Issue