diff --git a/lint/src/util/misc.ts b/lint/src/util/misc.ts index 47357e7cd31..61e4e771c80 100644 --- a/lint/src/util/misc.ts +++ b/lint/src/util/misc.ts @@ -14,3 +14,15 @@ export function match(rangeA: number[], rangeB: number[]) { export function stringLiteral(value: string): string { return `'${value}'`; } + +/** + * Transform Windows-style paths into Unix-style paths + */ +export function toUnixStylePath(path: string): string { + // note: we're assuming that + if (path.includes('\\')) { + return path.replace(/^[A-Z]:\\/, '/') + .replaceAll('\\', '/'); + } + return path; +} \ No newline at end of file diff --git a/lint/src/util/theme-support.ts b/lint/src/util/theme-support.ts index 1f74b315041..fc3e32956be 100644 --- a/lint/src/util/theme-support.ts +++ b/lint/src/util/theme-support.ts @@ -152,6 +152,7 @@ class ThemeableComponentRegistry { const glob = require('glob'); + // note: this outputs Unix-style paths on Windows const wrappers: string[] = glob.GlobSync(prefix + 'src/app/**/themed-*.component.ts', { ignore: 'node_modules/**' }).found; for (const wrapper of wrappers) { @@ -245,17 +246,6 @@ export function inThemedComponentOverrideFile(filename: string): boolean { return themeableComponents.byBasePath.has(`src/${match[1]}`); } -export function inThemedComponentFile(context: AnyRuleContext): boolean { - themeableComponents.initialize(); - const filename = getFilename(context); - - return [ - () => themeableComponents.byBasePath.has(filename), - () => themeableComponents.byWrapperPath.has(filename), - () => inThemedComponentOverrideFile(filename), - ].some(predicate => predicate()); -} - export function allThemeableComponents(): ThemeableComponentRegistryEntry[] { themeableComponents.initialize(); return [...themeableComponents.entries]; diff --git a/lint/src/util/typescript.ts b/lint/src/util/typescript.ts index c0ede13967e..3fecad270e6 100644 --- a/lint/src/util/typescript.ts +++ b/lint/src/util/typescript.ts @@ -10,14 +10,21 @@ import { TSESTree, } from '@typescript-eslint/utils'; -import { match } from './misc'; +import { + match, + toUnixStylePath, +} from './misc'; export type AnyRuleContext = TSESLint.RuleContext; +/** + * Return the current filename based on the ESLint rule context as a Unix-style path. + * This is easier for regex and comparisons to glob paths. + */ export function getFilename(context: AnyRuleContext): string { // TSESLint claims this is deprecated, but the suggested alternative is undefined (could be a version mismatch between ESLint and TSESlint?) // eslint-disable-next-line deprecation/deprecation - return context.getFilename(); + return toUnixStylePath(context.getFilename()); } export function getSourceCode(context: AnyRuleContext): TSESLint.SourceCode {