Fix getEntryType failure on spaces in file name (#6218)

* fix: avoid url -> file -> url parsing

* chore: changeset
This commit is contained in:
Ben Holmes 2023-02-13 10:10:33 -05:00 committed by GitHub
parent 2d72ea30ae
commit baa2dbb3b5
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 10 additions and 7 deletions

View file

@ -0,0 +1,5 @@
---
'astro': patch
---
Fix: internal content collection error on spaces in file name

View file

@ -163,11 +163,10 @@ export function getEntryType(
entryPath: string,
paths: Pick<ContentPaths, 'config'>
): 'content' | 'config' | 'ignored' | 'unsupported' {
const { dir: rawDir, ext, base } = path.parse(entryPath);
const dir = appendForwardSlash(pathToFileURL(rawDir).href);
const fileUrl = new URL(base, dir);
const { ext, base } = path.parse(entryPath);
const fileUrl = pathToFileURL(entryPath);
if (hasUnderscoreInPath(fileUrl) || isOnIgnoreList(fileUrl)) {
if (hasUnderscoreInPath(fileUrl) || isOnIgnoreList(base)) {
return 'ignored';
} else if ((contentFileExts as readonly string[]).includes(ext)) {
return 'content';
@ -178,9 +177,8 @@ export function getEntryType(
}
}
function isOnIgnoreList(fileUrl: URL) {
const { base } = path.parse(fileURLToPath(fileUrl));
return ['.DS_Store'].includes(base);
function isOnIgnoreList(fileName: string) {
return ['.DS_Store'].includes(fileName);
}
function hasUnderscoreInPath(fileUrl: URL): boolean {