|
|
- /**
- * @author Toru Nagashima
- * See LICENSE file in root directory for full license.
- */
- "use strict"
-
- const path = require("path")
- const { CALL, ReferenceTracker, getStringIfConstant } = require("eslint-utils")
- const resolve = require("resolve")
- const getResolvePaths = require("./get-resolve-paths")
- const getTryExtensions = require("./get-try-extensions")
- const ImportTarget = require("./import-target")
- const stripImportPathParams = require("./strip-import-path-params")
-
- /**
- * Gets a list of `require()` targets.
- *
- * Core modules of Node.js (e.g. `fs`, `http`) are excluded.
- *
- * @param {RuleContext} context - The rule context.
- * @param {Object} [options] - The flag to include core modules.
- * @param {boolean} [options.includeCore] - The flag to include core modules.
- * @param {function(ImportTarget[]):void} callback The callback function to get result.
- * @returns {Object} The visitor.
- */
- module.exports = function visitRequire(
- context,
- { includeCore = false } = {},
- callback
- ) {
- const targets = []
- const basedir = path.dirname(path.resolve(context.getFilename()))
- const paths = getResolvePaths(context)
- const extensions = getTryExtensions(context)
- const options = { basedir, paths, extensions }
-
- return {
- "Program:exit"() {
- const tracker = new ReferenceTracker(context.getScope())
- const references = tracker.iterateGlobalReferences({
- require: {
- [CALL]: true,
- resolve: { [CALL]: true },
- },
- })
-
- for (const { node } of references) {
- const targetNode = node.arguments[0]
- const rawName = getStringIfConstant(targetNode)
- const name = rawName && stripImportPathParams(rawName)
- if (name && (includeCore || !resolve.isCore(name))) {
- targets.push(new ImportTarget(targetNode, name, options))
- }
- }
-
- callback(targets)
- },
- }
- }
|