stylelint
Version:
A mighty, modern CSS linter.
49 lines (39 loc) • 1.34 kB
JavaScript
const filterFilePaths = require('./utils/filterFilePaths');
const getFileIgnorer = require('./utils/getFileIgnorer');
const micromatch = require('micromatch');
const path = require('path');
const slash = require('slash');
/**
* 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').StylelintInternalApi} stylelint
* @param {string} [filePath]
* @return {Promise<boolean>}
*/
module.exports = function (stylelint, filePath) {
if (!filePath) {
return Promise.resolve(false);
}
const cwd = process.cwd();
const ignorer = getFileIgnorer(stylelint._options);
return stylelint.getConfigForFile(filePath).then((result) => {
if (!result) {
return true;
}
// Glob patterns for micromatch should be in POSIX-style
const ignoreFiles = /** @type {Array<string>} */ (result.config.ignoreFiles || []).map(slash);
const absoluteFilePath = path.isAbsolute(filePath)
? filePath
: path.resolve(process.cwd(), filePath);
if (micromatch([absoluteFilePath], ignoreFiles).length) {
return true;
}
// Check filePath with .stylelintignore file
if (filterFilePaths(ignorer, [path.relative(cwd, absoluteFilePath)]).length === 0) {
return true;
}
return false;
});
};
;