mirror of
https://github.com/OliveTin/OliveTin
synced 2025-12-17 11:35:36 +00:00
44 lines
1.2 KiB
JavaScript
44 lines
1.2 KiB
JavaScript
import { isAbsolute, relative, resolve } from 'path';
|
|
|
|
import micromatch from 'micromatch';
|
|
|
|
import filterFilePaths from './utils/filterFilePaths.mjs';
|
|
import getConfigForFile from './getConfigForFile.mjs';
|
|
import getFileIgnorer from './utils/getFileIgnorer.mjs';
|
|
|
|
/**
|
|
* To find out if a path is ignored, we need to load the config,
|
|
* which may have an ignoreFiles property. We then check the path
|
|
* against these.
|
|
* @param {import('stylelint').InternalApi} stylelint
|
|
* @param {string} [filePath]
|
|
* @returns {Promise<boolean>}
|
|
*/
|
|
export default async function isPathIgnored(stylelint, filePath) {
|
|
if (!filePath) {
|
|
return false;
|
|
}
|
|
|
|
const cwd = stylelint._options.cwd;
|
|
const result = await getConfigForFile({ stylelint, searchPath: filePath, filePath });
|
|
|
|
if (!result) {
|
|
return true;
|
|
}
|
|
|
|
const ignoreFiles = result.config.ignoreFiles || [];
|
|
const absoluteFilePath = isAbsolute(filePath) ? filePath : resolve(cwd, filePath);
|
|
|
|
if (micromatch([absoluteFilePath], ignoreFiles).length > 0) {
|
|
return true;
|
|
}
|
|
|
|
const ignorer = getFileIgnorer(stylelint._options);
|
|
|
|
if (filterFilePaths(ignorer, [relative(cwd, absoluteFilePath)]).length === 0) {
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|