You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
109 lines
4.0 KiB
109 lines
4.0 KiB
/** |
|
* @fileoverview Tools for obtaining SourceCode objects. |
|
* @author Ian VanSchooten |
|
*/ |
|
|
|
"use strict"; |
|
|
|
//------------------------------------------------------------------------------ |
|
// Requirements |
|
//------------------------------------------------------------------------------ |
|
|
|
const { CLIEngine } = require("../cli-engine"); |
|
|
|
/* |
|
* This is used for: |
|
* |
|
* 1. Enumerate target file because we have not expose such a API on `CLIEngine` |
|
* (https://github.com/eslint/eslint/issues/11222). |
|
* 2. Create `SourceCode` instances. Because we don't have any function which |
|
* instantiate `SourceCode` so it needs to take the created `SourceCode` |
|
* instance out after linting. |
|
* |
|
* TODO1: Expose the API that enumerates target files. |
|
* TODO2: Extract the creation logic of `SourceCode` from `Linter` class. |
|
*/ |
|
const { getCLIEngineInternalSlots } = require("../cli-engine/cli-engine"); // eslint-disable-line node/no-restricted-require |
|
|
|
const debug = require("debug")("eslint:source-code-utils"); |
|
|
|
//------------------------------------------------------------------------------ |
|
// Helpers |
|
//------------------------------------------------------------------------------ |
|
|
|
/** |
|
* Get the SourceCode object for a single file |
|
* @param {string} filename The fully resolved filename to get SourceCode from. |
|
* @param {Object} engine A CLIEngine. |
|
* @returns {Array} Array of the SourceCode object representing the file |
|
* and fatal error message. |
|
*/ |
|
function getSourceCodeOfFile(filename, engine) { |
|
debug("getting sourceCode of", filename); |
|
const results = engine.executeOnFiles([filename]); |
|
|
|
if (results && results.results[0] && results.results[0].messages[0] && results.results[0].messages[0].fatal) { |
|
const msg = results.results[0].messages[0]; |
|
|
|
throw new Error(`(${filename}:${msg.line}:${msg.column}) ${msg.message}`); |
|
} |
|
|
|
// TODO: extract the logic that creates source code objects to `SourceCode#parse(text, options)` or something like. |
|
const { linter } = getCLIEngineInternalSlots(engine); |
|
const sourceCode = linter.getSourceCode(); |
|
|
|
return sourceCode; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// Public Interface |
|
//------------------------------------------------------------------------------ |
|
|
|
|
|
/** |
|
* This callback is used to measure execution status in a progress bar |
|
* @callback progressCallback |
|
* @param {number} The total number of times the callback will be called. |
|
*/ |
|
|
|
/** |
|
* Gets the SourceCode of a single file, or set of files. |
|
* @param {string[]|string} patterns A filename, directory name, or glob, or an array of them |
|
* @param {Object} options A CLIEngine options object. If not provided, the default cli options will be used. |
|
* @param {progressCallback} callback Callback for reporting execution status |
|
* @returns {Object} The SourceCode of all processed files. |
|
*/ |
|
function getSourceCodeOfFiles(patterns, options, callback) { |
|
const sourceCodes = {}; |
|
const globPatternsList = typeof patterns === "string" ? [patterns] : patterns; |
|
const engine = new CLIEngine({ ...options, rules: {} }); |
|
|
|
// TODO: make file iteration as a public API and use it. |
|
const { fileEnumerator } = getCLIEngineInternalSlots(engine); |
|
const filenames = |
|
Array.from(fileEnumerator.iterateFiles(globPatternsList)) |
|
.filter(entry => !entry.ignored) |
|
.map(entry => entry.filePath); |
|
|
|
if (filenames.length === 0) { |
|
debug(`Did not find any files matching pattern(s): ${globPatternsList}`); |
|
} |
|
|
|
filenames.forEach(filename => { |
|
const sourceCode = getSourceCodeOfFile(filename, engine); |
|
|
|
if (sourceCode) { |
|
debug("got sourceCode of", filename); |
|
sourceCodes[filename] = sourceCode; |
|
} |
|
if (callback) { |
|
callback(filenames.length); // eslint-disable-line node/callback-return |
|
} |
|
}); |
|
|
|
return sourceCodes; |
|
} |
|
|
|
module.exports = { |
|
getSourceCodeOfFiles |
|
};
|
|
|