UNPKG

3.18 kBJavaScriptView Raw
1"use strict";
2var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3 if (k2 === undefined) k2 = k;
4 Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5}) : (function(o, m, k, k2) {
6 if (k2 === undefined) k2 = k;
7 o[k2] = m[k];
8}));
9var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10 Object.defineProperty(o, "default", { enumerable: true, value: v });
11}) : function(o, v) {
12 o["default"] = v;
13});
14var __importStar = (this && this.__importStar) || function (mod) {
15 if (mod && mod.__esModule) return mod;
16 var result = {};
17 if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18 __setModuleDefault(result, mod);
19 return result;
20};
21var _a;
22Object.defineProperty(exports, "__esModule", { value: true });
23const utils_1 = require("@typescript-eslint/utils");
24const getESLintCoreRule_1 = require("../util/getESLintCoreRule");
25const util = __importStar(require("../util"));
26const baseRule = (0, getESLintCoreRule_1.getESLintCoreRule)('no-useless-constructor');
27/**
28 * Check if method with accessibility is not useless
29 */
30function checkAccessibility(node) {
31 switch (node.accessibility) {
32 case 'protected':
33 case 'private':
34 return false;
35 case 'public':
36 if (node.parent &&
37 node.parent.type === utils_1.AST_NODE_TYPES.ClassBody &&
38 node.parent.parent &&
39 'superClass' in node.parent.parent &&
40 node.parent.parent.superClass) {
41 return false;
42 }
43 break;
44 }
45 return true;
46}
47/**
48 * Check if method is not unless due to typescript parameter properties
49 */
50function checkParams(node) {
51 return (!node.value.params ||
52 !node.value.params.some(param => param.type === utils_1.AST_NODE_TYPES.TSParameterProperty));
53}
54exports.default = util.createRule({
55 name: 'no-useless-constructor',
56 meta: {
57 type: 'problem',
58 docs: {
59 description: 'Disallow unnecessary constructors',
60 recommended: false,
61 extendsBaseRule: true,
62 },
63 hasSuggestions: baseRule.meta.hasSuggestions,
64 schema: baseRule.meta.schema,
65 // TODO: this rule has only had messages since v7.0 - remove this when we remove support for v6
66 messages: (_a = baseRule.meta.messages) !== null && _a !== void 0 ? _a : {
67 noUselessConstructor: 'Useless constructor.',
68 },
69 },
70 defaultOptions: [],
71 create(context) {
72 const rules = baseRule.create(context);
73 return {
74 MethodDefinition(node) {
75 if (node.value &&
76 node.value.type === utils_1.AST_NODE_TYPES.FunctionExpression &&
77 node.value.body &&
78 checkAccessibility(node) &&
79 checkParams(node)) {
80 rules.MethodDefinition(node);
81 }
82 },
83 };
84 },
85});
86//# sourceMappingURL=no-useless-constructor.js.map
\No newline at end of file