123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- /**
- * @fileoverview Reports useless `catch` clauses that just rethrow their error.
- * @author Teddy Katz
- */
-
- "use strict";
-
- //------------------------------------------------------------------------------
- // Rule Definition
- //------------------------------------------------------------------------------
-
- module.exports = {
- meta: {
- type: "suggestion",
-
- docs: {
- description: "disallow unnecessary `catch` clauses",
- category: "Best Practices",
- recommended: true,
- url: "https://eslint.org/docs/rules/no-useless-catch"
- },
-
- schema: [],
-
- messages: {
- unnecessaryCatchClause: "Unnecessary catch clause.",
- unnecessaryCatch: "Unnecessary try/catch wrapper."
- }
- },
-
- create(context) {
- return {
- CatchClause(node) {
- if (
- node.param &&
- node.param.type === "Identifier" &&
- node.body.body.length &&
- node.body.body[0].type === "ThrowStatement" &&
- node.body.body[0].argument.type === "Identifier" &&
- node.body.body[0].argument.name === node.param.name
- ) {
- if (node.parent.finalizer) {
- context.report({
- node,
- messageId: "unnecessaryCatchClause"
- });
- } else {
- context.report({
- node: node.parent,
- messageId: "unnecessaryCatch"
- });
- }
- }
- }
- };
- }
- };
|