123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- 'use strict';
- const path = require('path');
- const fs = require('fs');
- const getDocumentationUrl = require('./get-documentation-url.js');
- const isIterable = object => typeof object[Symbol.iterator] === 'function';
- function reportListenerProblems(listener, context) {
- // Listener arguments can be `codePath, node` or `node`
- return function (...listenerArguments) {
- let problems = listener(...listenerArguments);
- if (!problems) {
- return;
- }
- if (!isIterable(problems)) {
- problems = [problems];
- }
- // TODO: Allow `fix` function to abort
- for (const problem of problems) {
- if (problem) {
- context.report(problem);
- }
- }
- };
- }
- // `checkVueTemplate` function will wrap `create` function, there is no need to wrap twice
- const wrappedFunctions = new Set();
- function reportProblems(create) {
- if (wrappedFunctions.has(create)) {
- return create;
- }
- const wrapped = context => Object.fromEntries(
- Object.entries(create(context))
- .map(([selector, listener]) => [selector, reportListenerProblems(listener, context)]),
- );
- wrappedFunctions.add(wrapped);
- return wrapped;
- }
- function checkVueTemplate(create, options) {
- const {
- visitScriptBlock,
- } = {
- visitScriptBlock: true,
- ...options,
- };
- create = reportProblems(create);
- const wrapped = context => {
- const listeners = create(context);
- // `vue-eslint-parser`
- if (
- context.parserServices
- && context.parserServices.defineTemplateBodyVisitor
- ) {
- return visitScriptBlock
- ? context.parserServices.defineTemplateBodyVisitor(listeners, listeners)
- : context.parserServices.defineTemplateBodyVisitor(listeners);
- }
- return listeners;
- };
- wrappedFunctions.add(wrapped);
- return wrapped;
- }
- /** @returns {import('eslint').Rule.RuleModule} */
- function loadRule(ruleId) {
- const rule = require(`../${ruleId}`);
- return {
- meta: {
- // If there is are, options add `[]` so ESLint can validate that no data is passed to the rule.
- // https://github.com/not-an-aardvark/eslint-plugin-eslint-plugin/blob/master/docs/rules/require-meta-schema.md
- schema: [],
- ...rule.meta,
- docs: {
- ...rule.meta.docs,
- url: getDocumentationUrl(ruleId),
- },
- },
- create: reportProblems(rule.create),
- };
- }
- function loadRules() {
- return Object.fromEntries(
- fs.readdirSync(path.join(__dirname, '..'), {withFileTypes: true})
- .filter(file => file.isFile())
- .map(file => {
- const ruleId = path.basename(file.name, '.js');
- return [ruleId, loadRule(ruleId)];
- }),
- );
- }
- module.exports = {
- loadRule,
- loadRules,
- checkVueTemplate,
- };
|