mirror of
https://github.com/microsoft/TypeScript.git
synced 2026-02-14 19:16:17 -06:00
Search up for all node_modules directories available
This commit is contained in:
parent
c5c6acf883
commit
0e8e5ec3e5
@ -183,31 +183,33 @@ namespace ts {
|
||||
}
|
||||
|
||||
function getDefaultTypeRoots(currentDirectory: string, host: ModuleResolutionHost): string[] | undefined {
|
||||
const nodeModules = getNearestNodeModules(currentDirectory, host);
|
||||
return nodeModules && [combinePaths(nodeModules, "@types")];
|
||||
return map(getAllNodeModulesDirectories(currentDirectory, host), nodeModules => combinePaths(nodeModules, "@types"));
|
||||
}
|
||||
|
||||
function getNearestNodeModules(currentDirectory: string, host: ModuleResolutionHost): string | undefined {
|
||||
/** Returns the path to every node_modules directory from some ancestor directory. */
|
||||
function getAllNodeModulesDirectories(currentDirectory: string, host: ModuleResolutionHost): string[] | undefined {
|
||||
if (!host.directoryExists) {
|
||||
return combinePaths(currentDirectory, "node_modules");
|
||||
return [combinePaths(currentDirectory, "node_modules")];
|
||||
// And if it doesn't exist, tough.
|
||||
}
|
||||
|
||||
const all: string[] = [];
|
||||
|
||||
while (true) {
|
||||
const nodeModules = combinePaths(currentDirectory, "node_modules");
|
||||
if (host.directoryExists(nodeModules)) {
|
||||
return nodeModules;
|
||||
all.push(nodeModules);
|
||||
}
|
||||
else {
|
||||
const parent = getDirectoryPath(currentDirectory);
|
||||
if (parent === currentDirectory) {
|
||||
return undefined;
|
||||
}
|
||||
currentDirectory = parent;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
const parent = getDirectoryPath(currentDirectory);
|
||||
if (parent === currentDirectory) {
|
||||
break;
|
||||
}
|
||||
currentDirectory = parent;
|
||||
}
|
||||
|
||||
return all;
|
||||
}
|
||||
/**
|
||||
* @param {string | undefined} containingFile - file that contains type reference directive, can be undefined if containing file is unknown.
|
||||
* This is possible in case if resolution is performed for directives specified via 'types' parameter. In this case initial path for secondary lookups
|
||||
|
||||
@ -0,0 +1,31 @@
|
||||
//// [tests/cases/compiler/typeRootsFromMultipleNodeModulesDirectories.ts] ////
|
||||
|
||||
//// [index.d.ts]
|
||||
|
||||
declare module "xyz" {
|
||||
export const x: number;
|
||||
}
|
||||
|
||||
//// [index.d.ts]
|
||||
declare module "pdq" {
|
||||
export const y: number;
|
||||
}
|
||||
|
||||
//// [index.d.ts]
|
||||
declare module "abc" {
|
||||
export const z: number;
|
||||
}
|
||||
|
||||
//// [a.ts]
|
||||
import { x } from "xyz";
|
||||
import { y } from "pdq";
|
||||
import { z } from "abc";
|
||||
x + y + z;
|
||||
|
||||
|
||||
//// [a.js]
|
||||
"use strict";
|
||||
var xyz_1 = require("xyz");
|
||||
var pdq_1 = require("pdq");
|
||||
var abc_1 = require("abc");
|
||||
xyz_1.x + pdq_1.y + abc_1.z;
|
||||
@ -0,0 +1,34 @@
|
||||
=== /foo/bar/a.ts ===
|
||||
import { x } from "xyz";
|
||||
>x : Symbol(x, Decl(a.ts, 0, 8))
|
||||
|
||||
import { y } from "pdq";
|
||||
>y : Symbol(y, Decl(a.ts, 1, 8))
|
||||
|
||||
import { z } from "abc";
|
||||
>z : Symbol(z, Decl(a.ts, 2, 8))
|
||||
|
||||
x + y + z;
|
||||
>x : Symbol(x, Decl(a.ts, 0, 8))
|
||||
>y : Symbol(y, Decl(a.ts, 1, 8))
|
||||
>z : Symbol(z, Decl(a.ts, 2, 8))
|
||||
|
||||
=== /node_modules/@types/dopey/index.d.ts ===
|
||||
|
||||
declare module "xyz" {
|
||||
export const x: number;
|
||||
>x : Symbol(x, Decl(index.d.ts, 2, 16))
|
||||
}
|
||||
|
||||
=== /foo/node_modules/@types/grumpy/index.d.ts ===
|
||||
declare module "pdq" {
|
||||
export const y: number;
|
||||
>y : Symbol(y, Decl(index.d.ts, 1, 16))
|
||||
}
|
||||
|
||||
=== /foo/node_modules/@types/sneezy/index.d.ts ===
|
||||
declare module "abc" {
|
||||
export const z: number;
|
||||
>z : Symbol(z, Decl(index.d.ts, 1, 16))
|
||||
}
|
||||
|
||||
@ -0,0 +1,157 @@
|
||||
[
|
||||
"======== Resolving module 'xyz' from '/foo/bar/a.ts'. ========",
|
||||
"Module resolution kind is not specified, using 'NodeJs'.",
|
||||
"Loading module 'xyz' from 'node_modules' folder.",
|
||||
"File '/foo/bar/node_modules/xyz.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/xyz.tsx' does not exist.",
|
||||
"File '/foo/bar/node_modules/xyz.d.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/xyz/package.json' does not exist.",
|
||||
"File '/foo/bar/node_modules/xyz/index.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/xyz/index.tsx' does not exist.",
|
||||
"File '/foo/bar/node_modules/xyz/index.d.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/xyz.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/xyz.tsx' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/xyz.d.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/xyz/package.json' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/xyz/index.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/xyz/index.tsx' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/xyz/index.d.ts' does not exist.",
|
||||
"File '/foo/node_modules/xyz.ts' does not exist.",
|
||||
"File '/foo/node_modules/xyz.tsx' does not exist.",
|
||||
"File '/foo/node_modules/xyz.d.ts' does not exist.",
|
||||
"File '/foo/node_modules/xyz/package.json' does not exist.",
|
||||
"File '/foo/node_modules/xyz/index.ts' does not exist.",
|
||||
"File '/foo/node_modules/xyz/index.tsx' does not exist.",
|
||||
"File '/foo/node_modules/xyz/index.d.ts' does not exist.",
|
||||
"File '/foo/node_modules/@types/xyz.ts' does not exist.",
|
||||
"File '/foo/node_modules/@types/xyz.tsx' does not exist.",
|
||||
"File '/foo/node_modules/@types/xyz.d.ts' does not exist.",
|
||||
"File '/foo/node_modules/@types/xyz/package.json' does not exist.",
|
||||
"File '/foo/node_modules/@types/xyz/index.ts' does not exist.",
|
||||
"File '/foo/node_modules/@types/xyz/index.tsx' does not exist.",
|
||||
"File '/foo/node_modules/@types/xyz/index.d.ts' does not exist.",
|
||||
"File '/node_modules/xyz.ts' does not exist.",
|
||||
"File '/node_modules/xyz.tsx' does not exist.",
|
||||
"File '/node_modules/xyz.d.ts' does not exist.",
|
||||
"File '/node_modules/xyz/package.json' does not exist.",
|
||||
"File '/node_modules/xyz/index.ts' does not exist.",
|
||||
"File '/node_modules/xyz/index.tsx' does not exist.",
|
||||
"File '/node_modules/xyz/index.d.ts' does not exist.",
|
||||
"File '/node_modules/@types/xyz.ts' does not exist.",
|
||||
"File '/node_modules/@types/xyz.tsx' does not exist.",
|
||||
"File '/node_modules/@types/xyz.d.ts' does not exist.",
|
||||
"File '/node_modules/@types/xyz/package.json' does not exist.",
|
||||
"File '/node_modules/@types/xyz/index.ts' does not exist.",
|
||||
"File '/node_modules/@types/xyz/index.tsx' does not exist.",
|
||||
"File '/node_modules/@types/xyz/index.d.ts' does not exist.",
|
||||
"======== Module name 'xyz' was not resolved. ========",
|
||||
"======== Resolving module 'pdq' from '/foo/bar/a.ts'. ========",
|
||||
"Module resolution kind is not specified, using 'NodeJs'.",
|
||||
"Loading module 'pdq' from 'node_modules' folder.",
|
||||
"File '/foo/bar/node_modules/pdq.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/pdq.tsx' does not exist.",
|
||||
"File '/foo/bar/node_modules/pdq.d.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/pdq/package.json' does not exist.",
|
||||
"File '/foo/bar/node_modules/pdq/index.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/pdq/index.tsx' does not exist.",
|
||||
"File '/foo/bar/node_modules/pdq/index.d.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/pdq.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/pdq.tsx' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/pdq.d.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/pdq/package.json' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/pdq/index.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/pdq/index.tsx' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/pdq/index.d.ts' does not exist.",
|
||||
"File '/foo/node_modules/pdq.ts' does not exist.",
|
||||
"File '/foo/node_modules/pdq.tsx' does not exist.",
|
||||
"File '/foo/node_modules/pdq.d.ts' does not exist.",
|
||||
"File '/foo/node_modules/pdq/package.json' does not exist.",
|
||||
"File '/foo/node_modules/pdq/index.ts' does not exist.",
|
||||
"File '/foo/node_modules/pdq/index.tsx' does not exist.",
|
||||
"File '/foo/node_modules/pdq/index.d.ts' does not exist.",
|
||||
"File '/foo/node_modules/@types/pdq.ts' does not exist.",
|
||||
"File '/foo/node_modules/@types/pdq.tsx' does not exist.",
|
||||
"File '/foo/node_modules/@types/pdq.d.ts' does not exist.",
|
||||
"File '/foo/node_modules/@types/pdq/package.json' does not exist.",
|
||||
"File '/foo/node_modules/@types/pdq/index.ts' does not exist.",
|
||||
"File '/foo/node_modules/@types/pdq/index.tsx' does not exist.",
|
||||
"File '/foo/node_modules/@types/pdq/index.d.ts' does not exist.",
|
||||
"File '/node_modules/pdq.ts' does not exist.",
|
||||
"File '/node_modules/pdq.tsx' does not exist.",
|
||||
"File '/node_modules/pdq.d.ts' does not exist.",
|
||||
"File '/node_modules/pdq/package.json' does not exist.",
|
||||
"File '/node_modules/pdq/index.ts' does not exist.",
|
||||
"File '/node_modules/pdq/index.tsx' does not exist.",
|
||||
"File '/node_modules/pdq/index.d.ts' does not exist.",
|
||||
"File '/node_modules/@types/pdq.ts' does not exist.",
|
||||
"File '/node_modules/@types/pdq.tsx' does not exist.",
|
||||
"File '/node_modules/@types/pdq.d.ts' does not exist.",
|
||||
"File '/node_modules/@types/pdq/package.json' does not exist.",
|
||||
"File '/node_modules/@types/pdq/index.ts' does not exist.",
|
||||
"File '/node_modules/@types/pdq/index.tsx' does not exist.",
|
||||
"File '/node_modules/@types/pdq/index.d.ts' does not exist.",
|
||||
"======== Module name 'pdq' was not resolved. ========",
|
||||
"======== Resolving module 'abc' from '/foo/bar/a.ts'. ========",
|
||||
"Module resolution kind is not specified, using 'NodeJs'.",
|
||||
"Loading module 'abc' from 'node_modules' folder.",
|
||||
"File '/foo/bar/node_modules/abc.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/abc.tsx' does not exist.",
|
||||
"File '/foo/bar/node_modules/abc.d.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/abc/package.json' does not exist.",
|
||||
"File '/foo/bar/node_modules/abc/index.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/abc/index.tsx' does not exist.",
|
||||
"File '/foo/bar/node_modules/abc/index.d.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/abc.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/abc.tsx' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/abc.d.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/abc/package.json' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/abc/index.ts' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/abc/index.tsx' does not exist.",
|
||||
"File '/foo/bar/node_modules/@types/abc/index.d.ts' does not exist.",
|
||||
"File '/foo/node_modules/abc.ts' does not exist.",
|
||||
"File '/foo/node_modules/abc.tsx' does not exist.",
|
||||
"File '/foo/node_modules/abc.d.ts' does not exist.",
|
||||
"File '/foo/node_modules/abc/package.json' does not exist.",
|
||||
"File '/foo/node_modules/abc/index.ts' does not exist.",
|
||||
"File '/foo/node_modules/abc/index.tsx' does not exist.",
|
||||
"File '/foo/node_modules/abc/index.d.ts' does not exist.",
|
||||
"File '/foo/node_modules/@types/abc.ts' does not exist.",
|
||||
"File '/foo/node_modules/@types/abc.tsx' does not exist.",
|
||||
"File '/foo/node_modules/@types/abc.d.ts' does not exist.",
|
||||
"File '/foo/node_modules/@types/abc/package.json' does not exist.",
|
||||
"File '/foo/node_modules/@types/abc/index.ts' does not exist.",
|
||||
"File '/foo/node_modules/@types/abc/index.tsx' does not exist.",
|
||||
"File '/foo/node_modules/@types/abc/index.d.ts' does not exist.",
|
||||
"File '/node_modules/abc.ts' does not exist.",
|
||||
"File '/node_modules/abc.tsx' does not exist.",
|
||||
"File '/node_modules/abc.d.ts' does not exist.",
|
||||
"File '/node_modules/abc/package.json' does not exist.",
|
||||
"File '/node_modules/abc/index.ts' does not exist.",
|
||||
"File '/node_modules/abc/index.tsx' does not exist.",
|
||||
"File '/node_modules/abc/index.d.ts' does not exist.",
|
||||
"File '/node_modules/@types/abc.ts' does not exist.",
|
||||
"File '/node_modules/@types/abc.tsx' does not exist.",
|
||||
"File '/node_modules/@types/abc.d.ts' does not exist.",
|
||||
"File '/node_modules/@types/abc/package.json' does not exist.",
|
||||
"File '/node_modules/@types/abc/index.ts' does not exist.",
|
||||
"File '/node_modules/@types/abc/index.tsx' does not exist.",
|
||||
"File '/node_modules/@types/abc/index.d.ts' does not exist.",
|
||||
"======== Module name 'abc' was not resolved. ========",
|
||||
"======== Resolving type reference directive 'grumpy', containing file '/src/__inferred type names__.ts', root directory '/foo/node_modules/@types,/node_modules/@types'. ========",
|
||||
"Resolving with primary search path '/foo/node_modules/@types, /node_modules/@types'",
|
||||
"File '/foo/node_modules/@types/grumpy/package.json' does not exist.",
|
||||
"File '/foo/node_modules/@types/grumpy/index.d.ts' exist - use it as a name resolution result.",
|
||||
"======== Type reference directive 'grumpy' was successfully resolved to '/foo/node_modules/@types/grumpy/index.d.ts', primary: true. ========",
|
||||
"======== Resolving type reference directive 'sneezy', containing file '/src/__inferred type names__.ts', root directory '/foo/node_modules/@types,/node_modules/@types'. ========",
|
||||
"Resolving with primary search path '/foo/node_modules/@types, /node_modules/@types'",
|
||||
"File '/foo/node_modules/@types/sneezy/package.json' does not exist.",
|
||||
"File '/foo/node_modules/@types/sneezy/index.d.ts' exist - use it as a name resolution result.",
|
||||
"======== Type reference directive 'sneezy' was successfully resolved to '/foo/node_modules/@types/sneezy/index.d.ts', primary: true. ========",
|
||||
"======== Resolving type reference directive 'dopey', containing file '/src/__inferred type names__.ts', root directory '/foo/node_modules/@types,/node_modules/@types'. ========",
|
||||
"Resolving with primary search path '/foo/node_modules/@types, /node_modules/@types'",
|
||||
"File '/foo/node_modules/@types/dopey/package.json' does not exist.",
|
||||
"File '/foo/node_modules/@types/dopey/index.d.ts' does not exist.",
|
||||
"File '/node_modules/@types/dopey/package.json' does not exist.",
|
||||
"File '/node_modules/@types/dopey/index.d.ts' exist - use it as a name resolution result.",
|
||||
"======== Type reference directive 'dopey' was successfully resolved to '/node_modules/@types/dopey/index.d.ts', primary: true. ========"
|
||||
]
|
||||
@ -0,0 +1,36 @@
|
||||
=== /foo/bar/a.ts ===
|
||||
import { x } from "xyz";
|
||||
>x : number
|
||||
|
||||
import { y } from "pdq";
|
||||
>y : number
|
||||
|
||||
import { z } from "abc";
|
||||
>z : number
|
||||
|
||||
x + y + z;
|
||||
>x + y + z : number
|
||||
>x + y : number
|
||||
>x : number
|
||||
>y : number
|
||||
>z : number
|
||||
|
||||
=== /node_modules/@types/dopey/index.d.ts ===
|
||||
|
||||
declare module "xyz" {
|
||||
export const x: number;
|
||||
>x : number
|
||||
}
|
||||
|
||||
=== /foo/node_modules/@types/grumpy/index.d.ts ===
|
||||
declare module "pdq" {
|
||||
export const y: number;
|
||||
>y : number
|
||||
}
|
||||
|
||||
=== /foo/node_modules/@types/sneezy/index.d.ts ===
|
||||
declare module "abc" {
|
||||
export const z: number;
|
||||
>z : number
|
||||
}
|
||||
|
||||
@ -0,0 +1,27 @@
|
||||
// @noImplicitReferences: true
|
||||
// @traceResolution: true
|
||||
// @currentDirectory: /src
|
||||
|
||||
// @Filename: /node_modules/@types/dopey/index.d.ts
|
||||
declare module "xyz" {
|
||||
export const x: number;
|
||||
}
|
||||
|
||||
// @Filename: /foo/node_modules/@types/grumpy/index.d.ts
|
||||
declare module "pdq" {
|
||||
export const y: number;
|
||||
}
|
||||
|
||||
// @Filename: /foo/node_modules/@types/sneezy/index.d.ts
|
||||
declare module "abc" {
|
||||
export const z: number;
|
||||
}
|
||||
|
||||
// @Filename: /foo/bar/a.ts
|
||||
import { x } from "xyz";
|
||||
import { y } from "pdq";
|
||||
import { z } from "abc";
|
||||
x + y + z;
|
||||
|
||||
// @Filename: /foo/bar/tsconfig.json
|
||||
{}
|
||||
Loading…
x
Reference in New Issue
Block a user