Skip to content

Commit

Permalink
Fix findFileConfig() matching
Browse files Browse the repository at this point in the history
  • Loading branch information
yanthomasdev committed Sep 12, 2024
1 parent 093a352 commit 70e39d0
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 16 deletions.
7 changes: 3 additions & 4 deletions packages/core/src/files/paths.ts
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ export function createPathResolver(
return {
// `match` returns an object if true, here we're forcing it to return a boolean.
/**
* Explanation: why does `isSourcePathMatch` checks if it isn't a locales path but `isLocalesPathMatch` doesn't?
* Explanation: why does `isSourcePath` checks if it isn't a locales path but `isLocalesPath` doesn't?
* In a few cases, the source path can end up matching the locales path, like so:
*
* - Source path: `docs/test.mdx` (sourcePattern: `docs/@path`)
Expand All @@ -73,9 +73,8 @@ export function createPathResolver(
* In this case, the locales path fulfills the source pattern match, but the opposite can't happen, considering
* the locales path strictly requires the `@lang` parameter that is limited to the configured locales.
*/
isSourcePathMatch: (path: string) =>
!!match(sourcePattern)(path) && !match(localesPattern)(path),
isLocalesPathMatch: (path: string) => !!match(localesPattern)(path),
isSourcePath: (path: string) => !!match(sourcePattern)(path) && !match(localesPattern)(path),
isLocalesPath: (path: string) => !!match(localesPattern)(path),
toPath: (fromPath: string, toLang: string) => {
// Since the path for the same source and localized content can have different patterns,
// we have to check if the `toLang` is from the sourceLocale (i.e. source content) or
Expand Down
4 changes: 2 additions & 2 deletions packages/core/src/files/types.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
export interface PathResolver {
/** Checks if a path matches an source locale path. */
isSourcePathMatch: (path: string) => boolean;
isSourcePath: (path: string) => boolean;
/** Checks if a path matches an localized path. */
isLocalesPathMatch: (path: string) => boolean;
isLocalesPath: (path: string) => boolean;
/** Creates a path from one locale to the equivalent of another. */
toPath: (fromPath: string, toLang: string) => string;
/** The resolved source pattern used by the path resolver. */
Expand Down
32 changes: 22 additions & 10 deletions packages/core/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { existsSync } from 'node:fs';
import { resolve } from 'node:path';
import { type ConsolaInstance, createConsola } from 'consola';
import picomatch from 'picomatch';
import { glob } from 'tinyglobby';
import { loadConfig, validateConfig } from './config/config.js';
import type { LunariaConfig, LunariaUserConfig, Pattern } from './config/types.js';
Expand Down Expand Up @@ -97,7 +98,7 @@ export class Lunaria {
// We keep track of those to warn the user about them.
const filteredOutPaths: string[] = [];

const { isSourcePathMatch } = this.getPathResolver(pattern);
const { isSourcePath } = this.getPathResolver(pattern);
// Lunaria initially globs only the source files, and then proceed to
// check the status of each localization file through dynamically
// generated paths using `pattern`.
Expand All @@ -107,7 +108,7 @@ export class Lunaria {
ignore: exclude,
})
).filter((path) => {
if (!isSourcePathMatch(path)) {
if (!isSourcePath(path)) {
filteredOutPaths.push(path);
return false;
}
Expand Down Expand Up @@ -140,12 +141,10 @@ export class Lunaria {
return undefined;
}

const { isSourcePathMatch, toPath } = this.getPathResolver(fileConfig.pattern);
const { isSourcePath, toPath } = this.getPathResolver(fileConfig.pattern);

/** The given path can be of another locale, therefore we always convert it to the source path */
const sourcePath = isSourcePathMatch(path)
? path
: toPath(path, this.#config.sourceLocale.lang);
const sourcePath = isSourcePath(path) ? path : toPath(path, this.#config.sourceLocale.lang);

const isLocalizable = isFileLocalizable(path, this.#config.tracking.localizableProperty);

Expand Down Expand Up @@ -228,10 +227,23 @@ export class Lunaria {
findFileConfig(path: string) {
return this.#config.files.find((file) => {
// TODO: We should update this since the pattern might match, but not the include that determines a different type for it.
const { isSourcePathMatch, isLocalesPathMatch } = this.getPathResolver(file.pattern);
// We're checking if the path matches either the source or locales pattern,
// that way we can determine the `files` entry that should be used for the path.
return isSourcePathMatch(path) || isLocalesPathMatch(path);
const { isSourcePath, toPath } = this.getPathResolver(file.pattern);

try {
const sourcePath = isSourcePath(path) ? path : toPath(path, this.#config.sourceLocale.lang);

// There's a few cases in which the pattern might match, but the include/exclude filters don't,
// therefore we need to test both to find the correct `files` config.
return (
isSourcePath(path) &&
picomatch.isMatch(sourcePath, file.include, {
ignore: file.exclude,
})
);
// If it fails to match, we assume it's not the respective `files` config and return false.
} catch {
return false;
}
});
}
}

0 comments on commit 70e39d0

Please sign in to comment.