UNPKG

2.81 kBJavaScriptView Raw
1/**
2 * @fileoverview Defines a storage for rules.
3 * @author Nicholas C. Zakas
4 */
5
6"use strict";
7
8//------------------------------------------------------------------------------
9// Requirements
10//------------------------------------------------------------------------------
11
12const loadRules = require("./load-rules");
13
14//------------------------------------------------------------------------------
15// Privates
16//------------------------------------------------------------------------------
17
18let rules = Object.create(null);
19
20//------------------------------------------------------------------------------
21// Public Interface
22//------------------------------------------------------------------------------
23
24/**
25 * Registers a rule module for rule id in storage.
26 * @param {string} ruleId Rule id (file name).
27 * @param {Function} ruleModule Rule handler.
28 * @returns {void}
29 */
30function define(ruleId, ruleModule) {
31 rules[ruleId] = ruleModule;
32}
33
34/**
35 * Loads and registers all rules from passed rules directory.
36 * @param {string} [rulesDir] Path to rules directory, may be relative. Defaults to `lib/rules`.
37 * @param {string} cwd Current working directory
38 * @returns {void}
39 */
40function load(rulesDir, cwd) {
41 const newRules = loadRules(rulesDir, cwd);
42
43 Object.keys(newRules).forEach(function(ruleId) {
44 define(ruleId, newRules[ruleId]);
45 });
46}
47
48/**
49 * Registers all given rules of a plugin.
50 * @param {Object} plugin The plugin object to import.
51 * @param {string} pluginName The name of the plugin without prefix (`eslint-plugin-`).
52 * @returns {void}
53 */
54function importPlugin(plugin, pluginName) {
55 if (plugin.rules) {
56 Object.keys(plugin.rules).forEach(function(ruleId) {
57 const qualifiedRuleId = pluginName + "/" + ruleId,
58 rule = plugin.rules[ruleId];
59
60 define(qualifiedRuleId, rule);
61 });
62 }
63}
64
65/**
66 * Access rule handler by id (file name).
67 * @param {string} ruleId Rule id (file name).
68 * @returns {Function} Rule handler.
69 */
70function getHandler(ruleId) {
71 if (typeof rules[ruleId] === "string") {
72 return require(rules[ruleId]);
73 } else {
74 return rules[ruleId];
75 }
76}
77
78/**
79 * Reset rules storage.
80 * Should be used only in tests.
81 * @returns {void}
82 */
83function testClear() {
84 rules = Object.create(null);
85}
86
87module.exports = {
88 define,
89 load,
90 importPlugin,
91 get: getHandler,
92 testClear,
93
94 /**
95 * Resets rules to its starting state. Use for tests only.
96 * @returns {void}
97 */
98 testReset() {
99 testClear();
100 load();
101 }
102};
103
104//------------------------------------------------------------------------------
105// Initialization
106//------------------------------------------------------------------------------
107
108// loads built-in rules
109load();