UNPKG

2.9 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};
21Object.defineProperty(exports, "__esModule", { value: true });
22const utils_1 = require("@typescript-eslint/utils");
23const getESLintCoreRule_1 = require("../util/getESLintCoreRule");
24const util = __importStar(require("../util"));
25const baseRule = (0, getESLintCoreRule_1.getESLintCoreRule)('lines-between-class-members');
26const schema = util.deepMerge(Object.assign({}, baseRule.meta.schema), {
27 1: {
28 exceptAfterOverload: {
29 type: 'boolean',
30 default: true,
31 },
32 },
33});
34exports.default = util.createRule({
35 name: 'lines-between-class-members',
36 meta: {
37 type: 'layout',
38 docs: {
39 description: 'Require or disallow an empty line between class members',
40 recommended: false,
41 extendsBaseRule: true,
42 },
43 fixable: 'whitespace',
44 hasSuggestions: baseRule.meta.hasSuggestions,
45 schema,
46 messages: baseRule.meta.messages,
47 },
48 defaultOptions: [
49 'always',
50 {
51 exceptAfterOverload: true,
52 exceptAfterSingleLine: false,
53 },
54 ],
55 create(context, [firstOption, secondOption]) {
56 const rules = baseRule.create(context);
57 const exceptAfterOverload = (secondOption === null || secondOption === void 0 ? void 0 : secondOption.exceptAfterOverload) && firstOption === 'always';
58 function isOverload(node) {
59 return ((node.type === utils_1.AST_NODE_TYPES.TSAbstractMethodDefinition ||
60 node.type === utils_1.AST_NODE_TYPES.MethodDefinition) &&
61 node.value.type === utils_1.AST_NODE_TYPES.TSEmptyBodyFunctionExpression);
62 }
63 return {
64 ClassBody(node) {
65 const body = exceptAfterOverload
66 ? node.body.filter(node => !isOverload(node))
67 : node.body;
68 rules.ClassBody(Object.assign(Object.assign({}, node), { body }));
69 },
70 };
71 },
72});
73//# sourceMappingURL=lines-between-class-members.js.map
\No newline at end of file