From 3d163b0aa03ca89693e3f30a8382ae5bc45f9043 Mon Sep 17 00:00:00 2001 From: Matthias Osswald Date: Mon, 25 Mar 2024 11:13:52 +0100 Subject: [PATCH] refactor: Use direct path mapping --- src/detectors/typeChecker/host.ts | 48 +++++++++++------------------- src/detectors/typeChecker/index.ts | 18 +---------- 2 files changed, 18 insertions(+), 48 deletions(-) diff --git a/src/detectors/typeChecker/host.ts b/src/detectors/typeChecker/host.ts index da26a50a3..cb32ced24 100644 --- a/src/detectors/typeChecker/host.ts +++ b/src/detectors/typeChecker/host.ts @@ -5,7 +5,7 @@ import fs from "node:fs/promises"; import {createRequire} from "node:module"; const require = createRequire(import.meta.url); -const SAPUI5_TYPES_FILES = [ +const SAPUI5_TYPES_LIBS = [ "sap.apf", "sap.chart", "sap.ui.codeeditor", @@ -70,6 +70,19 @@ const SAPUI5_TYPES_FILES = [ "sap.ui.webc.main", ]; +function addSapui5TypesMappingToCompilerOptions(options: ts.CompilerOptions) { + const paths = options.paths ?? (options.paths = {}); + SAPUI5_TYPES_LIBS.forEach((lib) => { + if (lib === "sap.ui.core") { + // No need to add a mapping for sap.ui.core, as it is loaded by default + return; + } + const namespace = lib.replace(/\./g, "/") + "/*"; + const pathsEntry = paths[namespace] ?? (paths[namespace] = []); + pathsEntry.push(`/types/@sapui5/types/types/${lib}.d.ts`); + }); +} + interface PackageJson { dependencies: Record; } @@ -121,6 +134,8 @@ export async function createVirtualCompilerHost( "/types/@sapui5/types/types/sap.ui.core.d.ts", ]; + addSapui5TypesMappingToCompilerOptions(options); + // Create regex matching all path mapping keys const pathMappingRegex = new RegExp( `^\\/types\\/(${Array.from(typePathMappings.keys()).join("|").replaceAll("/", "\\/")})\\/(.*)`); @@ -193,9 +208,6 @@ export async function createVirtualCompilerHost( if (fsPath) { return ts.sys.directoryExists(fsPath); } - if (directory.startsWith("/types/@ui5/linter/dynamic-types/")) { - return true; - } } return false; }, @@ -210,9 +222,6 @@ export async function createVirtualCompilerHost( if (fsPath) { return ts.sys.fileExists(fsPath); } - if (fileName.startsWith("/types/@ui5/linter/dynamic-types/") && fileName.endsWith(".d.ts")) { - return true; - } } return false; }, @@ -244,30 +253,7 @@ export async function createVirtualCompilerHost( if (sourceFileCache.has(fileName)) { return sourceFileCache.get(fileName); } - - let sourceText: string | undefined = undefined; - - if (fileName.startsWith("/types/@ui5/linter/dynamic-types/") && fileName.endsWith(".d.ts")) { - const moduleName = fileName.match(/\/types\/@ui5\/linter\/dynamic-types\/(.*)\.d\.ts/)?.[1]; - if (moduleName) { - const libraryNameCheck = moduleName?.replace(/\//g, "."); - if (libraryNameCheck.startsWith("sap.ui.core.") || !libraryNameCheck.startsWith("sap.")) { - // sap.ui.core is loaded by default - return; - } - const libraryName = SAPUI5_TYPES_FILES.find(($) => libraryNameCheck.startsWith($ + ".")); - if (libraryName) { - sourceText = `/// `; - } else { - // Can happen e.g. for sap/ui/base/Event.d.ts, but sap.ui.core.d.ts is loaded by default - return; - } - } - } - - if (!sourceText) { - sourceText = getFile(fileName); - } + const sourceText = getFile(fileName); if (sourceText === undefined) { throw new Error(`File not found: ${fileName}`); } diff --git a/src/detectors/typeChecker/index.ts b/src/detectors/typeChecker/index.ts index 9a95d6769..1f8279776 100644 --- a/src/detectors/typeChecker/index.ts +++ b/src/detectors/typeChecker/index.ts @@ -57,21 +57,8 @@ export class TsProjectDetector extends ProjectBasedDetector { const namespace = project.getNamespace(); this.#projectBasePath = `/resources/${namespace}/`; - - const namespacePathMapping = [ - `${this.#projectBasePath}*`, - ]; - - // Special handling when linting sap/* namespaces (UI5 framework libraries): - // Add mapping for dynamic type lookup. Otherwise types within the sap library itself - // can't be resolved. - if (namespace.startsWith("sap/")) { - namespacePathMapping.push(`/types/@ui5/linter/dynamic-types/${namespace}/*`); - } - this.compilerOptions.paths = { - "sap/*": ["/types/@ui5/linter/dynamic-types/sap/*"], - [`${namespace}/*`]: namespacePathMapping, + [`${namespace}/*`]: [`${this.#projectBasePath}*`], }; } @@ -276,9 +263,6 @@ export class TsFileDetector extends FileBasedDetector { const options: ts.CompilerOptions = { ...DEFAULT_OPTIONS, rootDir: this.rootDir, - paths: { - "sap/*": ["/types/@ui5/linter/dynamic-types/sap/*"], - }, }; const resources = new Map();