blob: a0c0b31308b0e891d70484e25926472fd48256f8 [file] [log] [blame]
Yang Guo4fd355c2019-09-19 10:59:03 +02001/**
2 * @fileoverview Rule to disallow a duplicate case label.
3 * @author Dieter Oberkofler
4 * @author Burak Yigit Kaya
5 */
6
7"use strict";
8
9//------------------------------------------------------------------------------
Tim van der Lippe16aca392020-11-13 11:37:13 +000010// Requirements
11//------------------------------------------------------------------------------
12
13const astUtils = require("./utils/ast-utils");
14
15//------------------------------------------------------------------------------
Yang Guo4fd355c2019-09-19 10:59:03 +020016// Rule Definition
17//------------------------------------------------------------------------------
18
Tim van der Lippe0ceb4652022-01-06 14:23:36 +010019/** @type {import('../shared/types').Rule} */
Yang Guo4fd355c2019-09-19 10:59:03 +020020module.exports = {
21 meta: {
22 type: "problem",
23
24 docs: {
25 description: "disallow duplicate case labels",
Yang Guo4fd355c2019-09-19 10:59:03 +020026 recommended: true,
27 url: "https://eslint.org/docs/rules/no-duplicate-case"
28 },
29
30 schema: [],
31
32 messages: {
33 unexpected: "Duplicate case label."
34 }
35 },
36
37 create(context) {
38 const sourceCode = context.getSourceCode();
39
Tim van der Lippe16aca392020-11-13 11:37:13 +000040 /**
41 * Determines whether the two given nodes are considered to be equal.
42 * @param {ASTNode} a First node.
43 * @param {ASTNode} b Second node.
44 * @returns {boolean} `true` if the nodes are considered to be equal.
45 */
46 function equal(a, b) {
47 if (a.type !== b.type) {
48 return false;
49 }
50
51 return astUtils.equalTokens(a, b, sourceCode);
52 }
Yang Guo4fd355c2019-09-19 10:59:03 +020053 return {
54 SwitchStatement(node) {
Tim van der Lippe16aca392020-11-13 11:37:13 +000055 const previousTests = [];
Yang Guo4fd355c2019-09-19 10:59:03 +020056
Tim van der Lippec8f6ffd2020-04-06 13:42:00 +010057 for (const switchCase of node.cases) {
58 if (switchCase.test) {
Tim van der Lippe16aca392020-11-13 11:37:13 +000059 const test = switchCase.test;
Yang Guo4fd355c2019-09-19 10:59:03 +020060
Tim van der Lippe16aca392020-11-13 11:37:13 +000061 if (previousTests.some(previousTest => equal(previousTest, test))) {
Tim van der Lippec8f6ffd2020-04-06 13:42:00 +010062 context.report({ node: switchCase, messageId: "unexpected" });
63 } else {
Tim van der Lippe16aca392020-11-13 11:37:13 +000064 previousTests.push(test);
Tim van der Lippec8f6ffd2020-04-06 13:42:00 +010065 }
Yang Guo4fd355c2019-09-19 10:59:03 +020066 }
Tim van der Lippec8f6ffd2020-04-06 13:42:00 +010067 }
Yang Guo4fd355c2019-09-19 10:59:03 +020068 }
69 };
70 }
71};