From 5dc864d7bc0ab25406c5689dc5aad8aac15d8f59 Mon Sep 17 00:00:00 2001 From: pooya parsa Date: Fri, 29 Jul 2022 15:53:35 +0200 Subject: [PATCH] fix(kit): try extensions with `resolvePath` with absolute input (#6233) --- packages/kit/src/resolve.ts | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/packages/kit/src/resolve.ts b/packages/kit/src/resolve.ts index 457425e893..be8fd97ca3 100644 --- a/packages/kit/src/resolve.ts +++ b/packages/kit/src/resolve.ts @@ -28,7 +28,7 @@ export async function resolvePath (path: string, opts: ResolvePathOptions = {}): path = normalize(path) // Fast return if the path exists - if (isAbsolute(path) && existsSync(path)) { + if (isAbsolute(path) && existsSync(path) && !(await isDirectory(path))) { return path } @@ -47,10 +47,10 @@ export async function resolvePath (path: string, opts: ResolvePathOptions = {}): } // Check if resolvedPath is a file - let isDirectory = false + let _isDir = false if (existsSync(path)) { - isDirectory = (await fsp.lstat(path)).isDirectory() - if (!isDirectory) { + _isDir = await isDirectory(path) + if (!_isDir) { return path } } @@ -64,7 +64,7 @@ export async function resolvePath (path: string, opts: ResolvePathOptions = {}): } // path/index.[ext] const pathWithIndex = join(path, 'index' + ext) - if (isDirectory && existsSync(pathWithIndex)) { + if (_isDir && existsSync(pathWithIndex)) { return pathWithIndex } } @@ -89,8 +89,8 @@ export async function findPath (paths: string|string[], opts?: ResolvePathOption for (const path of paths) { const rPath = await resolvePath(path, opts) if (await existsSensitive(rPath)) { - const isDirectory = (await fsp.lstat(rPath)).isDirectory() - if (!pathType || (pathType === 'file' && !isDirectory) || (pathType === 'dir' && isDirectory)) { + const _isDir = await isDirectory(rPath) + if (!pathType || (pathType === 'file' && !_isDir) || (pathType === 'dir' && _isDir)) { return rPath } } @@ -146,6 +146,11 @@ async function existsSensitive (path: string) { return dirFiles.includes(basename(path)) } +// Usage note: We assume path existance is already ensured +async function isDirectory (path: string) { + return (await fsp.lstat(path)).isDirectory() +} + export async function resolveFiles (path: string, pattern: string | string[]) { const files = await globby(pattern, { cwd: path, followSymbolicLinks: true }) return files.map(p => resolve(path, p)).filter(p => !isIgnored(p)).sort()