|                                              |  | /** * @fileoverview Module for loading rules from files and directories. * @author Michael Ficarra */
"use strict";
//------------------------------------------------------------------------------
// Requirements
//------------------------------------------------------------------------------
const fs = require("fs"),    path = require("path");
const rulesDirCache = {};
//------------------------------------------------------------------------------
// Public Interface
//------------------------------------------------------------------------------
/** * Load all rule modules from specified directory. * @param {string} relativeRulesDir Path to rules directory, may be relative. * @param {string} cwd Current working directory * @returns {Object} Loaded rule modules. */module.exports = function(relativeRulesDir, cwd) {    const rulesDir = path.resolve(cwd, relativeRulesDir);
    // cache will help performance as IO operation are expensive
    if (rulesDirCache[rulesDir]) {        return rulesDirCache[rulesDir];    }
    const rules = Object.create(null);
    fs.readdirSync(rulesDir).forEach(file => {        if (path.extname(file) !== ".js") {            return;        }        rules[file.slice(0, -3)] = require(path.join(rulesDir, file));    });    rulesDirCache[rulesDir] = rules;
    return rules;};
 |