"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const utils_1 = require("@typescript-eslint/utils"); const util_1 = require("../util"); exports.default = (0, util_1.createRule)({ name: 'prefer-literal-enum-member', meta: { type: 'suggestion', docs: { description: 'Require all enum members to be literal values', recommended: 'strict', requiresTypeChecking: false, }, messages: { notLiteral: `Explicit enum value must only be a literal value (string, number, boolean, etc).`, }, schema: [ { type: 'object', properties: { allowBitwiseExpressions: { type: 'boolean', }, }, additionalProperties: false, }, ], }, defaultOptions: [ { allowBitwiseExpressions: false, }, ], create(context, [{ allowBitwiseExpressions }]) { function isIdentifierWithName(node, name) { return node.type === utils_1.AST_NODE_TYPES.Identifier && node.name === name; } function hasEnumMember(decl, name) { return decl.members.some(member => isIdentifierWithName(member.id, name) || (member.id.type === utils_1.AST_NODE_TYPES.Literal && (0, util_1.getStaticStringValue)(member.id) === name)); } function isSelfEnumMember(decl, node) { if (node.type === utils_1.AST_NODE_TYPES.Identifier) { return hasEnumMember(decl, node.name); } if (node.type === utils_1.AST_NODE_TYPES.MemberExpression && isIdentifierWithName(node.object, decl.id.name)) { if (node.property.type === utils_1.AST_NODE_TYPES.Identifier) { return hasEnumMember(decl, node.property.name); } if (node.computed) { const propertyName = (0, util_1.getStaticStringValue)(node.property); if (propertyName) { return hasEnumMember(decl, propertyName); } } } return false; } function isAllowedBitwiseOperand(decl, node) { return (node.type === utils_1.AST_NODE_TYPES.Literal || isSelfEnumMember(decl, node)); } return { TSEnumMember(node) { // If there is no initializer, then this node is just the name of the member, so ignore. if (node.initializer == null) { return; } // any old literal if (node.initializer.type === utils_1.AST_NODE_TYPES.Literal) { return; } // TemplateLiteral without expressions if (node.initializer.type === utils_1.AST_NODE_TYPES.TemplateLiteral && node.initializer.expressions.length === 0) { return; } const declaration = node.parent; // -1 and +1 if (node.initializer.type === utils_1.AST_NODE_TYPES.UnaryExpression) { if (node.initializer.argument.type === utils_1.AST_NODE_TYPES.Literal && ['+', '-'].includes(node.initializer.operator)) { return; } if (allowBitwiseExpressions && node.initializer.operator === '~' && isAllowedBitwiseOperand(declaration, node.initializer.argument)) { return; } } if (node.initializer.type === utils_1.AST_NODE_TYPES.UnaryExpression && node.initializer.argument.type === utils_1.AST_NODE_TYPES.Literal && (['+', '-'].includes(node.initializer.operator) || (allowBitwiseExpressions && node.initializer.operator === '~'))) { return; } if (allowBitwiseExpressions && node.initializer.type === utils_1.AST_NODE_TYPES.BinaryExpression && ['|', '&', '^', '<<', '>>', '>>>'].includes(node.initializer.operator) && isAllowedBitwiseOperand(declaration, node.initializer.left) && isAllowedBitwiseOperand(declaration, node.initializer.right)) { return; } context.report({ node: node.id, messageId: 'notLiteral', }); }, }; }, }); //# sourceMappingURL=prefer-literal-enum-member.js.map