├── .editorconfig ├── .eslintrc ├── .gitignore ├── .travis.yml ├── .vscode └── launch.json ├── LICENSE ├── README.md ├── docs └── rules │ ├── no-unhandled-errors.md │ ├── no-yield-in-race.md │ └── yield-effects.md ├── index.js ├── lib ├── rules │ ├── no-unhandled-errors.js │ ├── no-yield-in-race.js │ └── yield-effects.js └── utils │ └── effects.js ├── package-lock.json ├── package.json └── test ├── .vscode └── launch.json ├── index.js ├── lib └── rules │ ├── no-unhandled-errors-spec.js │ ├── no-yield-in-race-spec.js │ └── yield-effects-spec.js └── parserOptions.js /.editorconfig: -------------------------------------------------------------------------------- 1 | root = true 2 | 3 | [*] 4 | indent_style = space 5 | indent_size = 2 6 | charset = utf-8 7 | trim_trailing_whitespace = true 8 | insert_final_newline = true 9 | 10 | [*.md] 11 | trim_trailing_whitespace = false 12 | -------------------------------------------------------------------------------- /.eslintrc: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "node": true 4 | }, 5 | "parserOptions": { 6 | "ecmaFeatures": { 7 | "jsx": true 8 | } 9 | }, 10 | "globals": { 11 | }, 12 | "plugins": [ 13 | ], 14 | "rules": { 15 | // Possible Errors 16 | "comma-dangle": [2, "never"], 17 | "no-cond-assign": 2, 18 | "no-console": 2, 19 | "no-constant-condition": 2, 20 | "no-control-regex": 2, 21 | "no-debugger": 2, 22 | "no-dupe-keys": 2, 23 | "no-empty": 2, 24 | "no-empty-character-class": 2, 25 | "no-ex-assign": 2, 26 | "no-extra-boolean-cast": 2, 27 | "no-extra-parens": 0, 28 | "no-extra-semi": 2, 29 | "no-func-assign": 2, 30 | "no-inner-declarations": 2, 31 | "no-invalid-regexp": 2, 32 | "no-irregular-whitespace": 2, 33 | "no-negated-in-lhs": 2, 34 | "no-obj-calls": 2, 35 | "no-regex-spaces": 2, 36 | "no-reserved-keys": 0, 37 | "no-sparse-arrays": 2, 38 | "no-unreachable": 2, 39 | "use-isnan": 2, 40 | "valid-jsdoc": 0, 41 | "valid-typeof": 2, 42 | // Best Practices 43 | "block-scoped-var": 2, 44 | "complexity": 0, 45 | "consistent-return": 2, 46 | "curly": 2, 47 | "default-case": 2, 48 | "dot-notation": 2, 49 | "eqeqeq": 2, 50 | "guard-for-in": 2, 51 | "no-alert": 2, 52 | "no-caller": 2, 53 | "no-div-regex": 2, 54 | "no-else-return": 2, 55 | "no-eq-null": 2, 56 | "no-eval": 2, 57 | "no-extend-native": 2, 58 | "no-extra-bind": 2, 59 | "no-fallthrough": 2, 60 | "no-floating-decimal": 2, 61 | "no-implied-eval": 2, 62 | "no-iterator": 2, 63 | "no-labels": 2, 64 | "no-lone-blocks": 2, 65 | "no-loop-func": 0, 66 | "no-multi-spaces": 2, 67 | "no-multi-str": 0, 68 | "no-native-reassign": 2, 69 | "no-new": 2, 70 | "no-new-func": 2, 71 | "no-new-wrappers": 2, 72 | "no-octal": 2, 73 | "no-octal-escape": 2, 74 | "no-process-env": 2, 75 | "no-proto": 2, 76 | "no-redeclare": 2, 77 | "no-return-assign": 2, 78 | "no-script-url": 2, 79 | "no-self-compare": 2, 80 | "no-sequences": 2, 81 | "no-unused-expressions": 2, 82 | "no-void": 0, 83 | "no-warning-comments": 2, 84 | "no-with": 2, 85 | "radix": 2, 86 | "vars-on-top": 0, 87 | "wrap-iife": 2, 88 | "yoda": 2, 89 | // Strict Mode 90 | "strict": [2, "global"], 91 | // Variables 92 | "no-catch-shadow": 2, 93 | "no-delete-var": 2, 94 | "no-label-var": 2, 95 | "no-shadow": 2, 96 | "no-shadow-restricted-names": 2, 97 | "no-undef": 2, 98 | "no-undef-init": 2, 99 | "no-undefined": 2, 100 | "no-unused-vars": 2, 101 | "no-use-before-define": 2, 102 | // Stylistic Issues 103 | "indent": [2, 2, { 104 | "SwitchCase": 1 105 | }], 106 | "brace-style": 2, 107 | "camelcase": 0, 108 | "comma-spacing": 2, 109 | "comma-style": 2, 110 | "consistent-this": 0, 111 | "eol-last": 2, 112 | "func-names": 0, 113 | "func-style": 0, 114 | "key-spacing": [2, { 115 | "beforeColon": false, 116 | "afterColon": true 117 | }], 118 | "max-nested-callbacks": 0, 119 | "new-cap": 2, 120 | "new-parens": 2, 121 | "no-array-constructor": 2, 122 | "no-inline-comments": 0, 123 | "no-lonely-if": 2, 124 | "no-mixed-spaces-and-tabs": 2, 125 | "no-nested-ternary": 2, 126 | "no-new-object": 2, 127 | "semi-spacing": [2, { 128 | "before": false, 129 | "after": true 130 | }], 131 | "no-spaced-func": 2, 132 | "no-ternary": 0, 133 | "no-trailing-spaces": 2, 134 | "no-multiple-empty-lines": 2, 135 | "no-underscore-dangle": 0, 136 | "one-var": 0, 137 | "operator-assignment": [2, "always"], 138 | "padded-blocks": 0, 139 | "quotes": [2, "double"], 140 | "semi": [2, "never"], 141 | "sort-vars": [2, {"ignoreCase": true}], 142 | "keyword-spacing": 2, 143 | "space-before-blocks": 2, 144 | "object-curly-spacing": [2, "never"], 145 | "array-bracket-spacing": [2, "never"], 146 | "space-in-parens": 2, 147 | "space-infix-ops": 2, 148 | "space-unary-ops": 2, 149 | "spaced-comment": 2, 150 | "wrap-regex": 0, 151 | // Legacy 152 | "max-depth": 0, 153 | "max-len": [2, 120], 154 | "max-params": 0, 155 | "max-statements": 0, 156 | "no-plusplus": 0 157 | } 158 | } 159 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | 6 | # Runtime data 7 | pids 8 | *.pid 9 | *.seed 10 | 11 | # Directory for instrumented libs generated by jscoverage/JSCover 12 | lib-cov 13 | 14 | # Coverage directory used by tools like istanbul 15 | coverage 16 | 17 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 18 | .grunt 19 | 20 | # node-waf configuration 21 | .lock-wscript 22 | 23 | # Compiled binary addons (http://nodejs.org/api/addons.html) 24 | build/Release 25 | 26 | # Dependency directory 27 | node_modules 28 | 29 | # Optional npm cache directory 30 | .npm 31 | 32 | # Optional REPL history 33 | .node_repl_history 34 | 35 | # vscode 36 | .vscode 37 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: 3 | - lts/* 4 | - node 5 | env: 6 | matrix: 7 | - REDUX_SAGA_VERSION=^0.11.1 8 | - REDUX_SAGA_VERSION=^1.0.0 9 | before_script: 10 | - npm install redux-saga@${REDUX_SAGA_VERSION} 11 | deploy: 12 | on: 13 | branch: master 14 | provider: npm 15 | email: "$NPM_EMAIL" 16 | api_key: "$NPM_TOKEN" 17 | -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | { 2 | "version": "0.2.0", 3 | "configurations": [ 4 | { 5 | "name": "Launch", 6 | "type": "node", 7 | "request": "launch", 8 | "program": "${file}", 9 | "stopOnEntry": false, 10 | "args": [ 11 | ], 12 | "cwd": "${workspaceRoot}", 13 | "preLaunchTask": null, 14 | "runtimeExecutable": null, 15 | "runtimeArgs": [ 16 | "--nolazy" 17 | ], 18 | "env": { 19 | "NODE_ENV": "development" 20 | }, 21 | "externalConsole": false, 22 | "sourceMaps": false, 23 | "outDir": null 24 | }, 25 | { 26 | "name": "Attach", 27 | "type": "node", 28 | "request": "attach", 29 | "port": 5858, 30 | "address": "localhost", 31 | "restart": false, 32 | "sourceMaps": false, 33 | "outDir": null, 34 | "localRoot": "${workspaceRoot}", 35 | "remoteRoot": null 36 | } 37 | ] 38 | } 39 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2016 Philipp Kursawe 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # eslint-plugin-redux-saga 2 | 3 | 4 | 5 | [![Build Status](https://img.shields.io/travis/pke/eslint-plugin-redux-saga/master.svg?style=flat-square)](https://travis-ci.org/pke/eslint-plugin-redux-saga) 6 | [![npm version](https://img.shields.io/npm/v/eslint-plugin-redux-saga.svg?style=flat-square)](https://badge.fury.io/js/eslint-plugin-redux-saga) 7 | [![License](https://img.shields.io/npm/l/eslint-plugin-redux-saga.svg?style=flat-square)](LICENSE) 8 | 9 | [ESLint](https://github.com/eslint/eslint) rules for [redux-saga](https://github.com/yelouafi/redux-saga). 10 | 11 | ## Usage 12 | 13 | Install the plugin: 14 | 15 | ### npm 16 | 17 | `npm i -D eslint-plugin-redux-saga` 18 | 19 | ### yarn 20 | 21 | `yarn add -D eslint-plugin-redux-saga` 22 | 23 | And add it to your `.eslintrc` file: 24 | 25 | ```json 26 | { 27 | "plugins": [ 28 | "redux-saga" 29 | ] 30 | } 31 | ``` 32 | 33 | ## Rules 34 | 35 | | Rule | Description | Recommended | Fixable | 36 | |-------------|------|-------------|---------| 37 | | [yield-effects](docs/rules/yield-effects.md) | Ensure effects are yielded | ![recommended](https://img.shields.io/badge/-recommended-lightgrey.svg) | ![suggestion fixable](https://img.shields.io/badge/-suggestion%20fixable-green.svg) | 38 | | [no-yield-in-race](docs/rules/no-yield-in-race.md) | Prevent usage of yield in race entries | ![recommended](https://img.shields.io/badge/-recommended-lightgrey.svg) | ![fixable](https://img.shields.io/badge/-fixable-green.svg) 39 | | [no-unhandled-errors](docs/rules/no-unhandled-errors.md) | Ensures error handling on sagas | ![recommended](https://img.shields.io/badge/-recommended-lightgrey.svg) | 40 | 41 | ## Recommended configuration 42 | 43 | This plugin exports the `recommended` configuration that enforces all the rules. To use it, add following property to `.eslintrc` file: 44 | 45 | ```json 46 | { 47 | "extends": [ 48 | "plugin:redux-saga/recommended" 49 | ] 50 | } 51 | ``` 52 | -------------------------------------------------------------------------------- /docs/rules/no-unhandled-errors.md: -------------------------------------------------------------------------------- 1 | # Ensures error handling on sagas 2 | 3 | ![](https://img.shields.io/badge/-recommended-lightgrey.svg "recommended") 4 | 5 | This rule ensures that all `redux-saga` effects are inside a try/catch block for error handling. 6 | 7 | An uncaught error can cause all other sagas waiting to complete to be inadvertedly canceled. 8 | 9 | ```es6 10 | import { call } from "redux-saga" 11 | 12 | // good 13 | function* good() { 14 | try { 15 | yield call(action) 16 | } catch (error) { 17 | yield call(handleError, error) 18 | } 19 | } 20 | 21 | // bad 22 | function* bad() { 23 | call(action) 24 | } 25 | ``` 26 | -------------------------------------------------------------------------------- /docs/rules/no-yield-in-race.md: -------------------------------------------------------------------------------- 1 | # Prevent usage of yield in race entries (no-yield-in-race) 2 | 3 | ![](https://img.shields.io/badge/-recommended-lightgrey.svg "recommended") ![fixable](https://img.shields.io/badge/-fixable-green.svg "The `--fix` option on the command line automatically fixes problems reported by this rule.") 4 | 5 | ```es6 6 | import { race, call } from "redux-saga" 7 | 8 | // Good 9 | function* good() { 10 | yield race({ 11 | posts: call(fetchApis) 12 | }) 13 | } 14 | 15 | function* good() { 16 | yield race({ 17 | watchers: [call(watcher1), call(watcher2)] 18 | }) 19 | } 20 | 21 | // Bad 22 | function* bad() { 23 | yield race({ posts: yield call(fetchApis) }) 24 | } 25 | 26 | function* bad() { 27 | yield race({ 28 | watchers: yield [call(watcher1), call(watcher2)] 29 | }) 30 | } 31 | 32 | ``` 33 | 34 | The `--fix` option on the command line automatically fixes problems reported by this rule. 35 | -------------------------------------------------------------------------------- /docs/rules/yield-effects.md: -------------------------------------------------------------------------------- 1 | # Ensures effects are yielded (yield-effects) 2 | 3 | ![](https://img.shields.io/badge/-recommended-lightgrey.svg "recommended") ![suggestion fixable](https://img.shields.io/badge/-suggestion%20fixable-green.svg "Editors that supports eslint suggestions will provide a fix option") 4 | 5 | This rule ensures that all `redux-saga` effects are properly `yield`'ed. 6 | 7 | Not `yield`'ing an effect might result in strange control flow behaviour. 8 | 9 | ```es6 10 | import { take } from "redux-saga" 11 | 12 | // good 13 | function* good() { 14 | yield take("action") 15 | } 16 | 17 | // bad 18 | function* bad() { 19 | take("action") 20 | } 21 | ``` 22 | 23 | Note: There is no autofix for this rule since it would change the runtime behavior of the code and potentially break things. This would goes against the eslint [best practices for fixes](https://eslint.org/docs/developer-guide/working-with-rules#applying-fixes-1). If you use an editor that supports the eslint [suggestions API](https://eslint.org/docs/developer-guide/working-with-rules#providing-suggestions), however, (for example the [VSCode ESLint plugin](https://marketplace.visualstudio.com/items?itemName=dbaeumer.vscode-eslint)), the editor will provide a suggestion for how to fix it. 24 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | "use strict" 2 | 3 | var rules = { 4 | "no-yield-in-race": require("./lib/rules/no-yield-in-race"), 5 | "yield-effects": require("./lib/rules/yield-effects"), 6 | "no-unhandled-errors": require("./lib/rules/no-unhandled-errors") 7 | } 8 | 9 | var allRules = Object.keys(rules).reduce(function(result, name) { 10 | result["redux-saga/" + name] = 2 11 | return result 12 | }, {}) 13 | 14 | module.exports = { 15 | rules: rules, 16 | configs: { 17 | recommended: { 18 | plugins: ["redux-saga"], 19 | rules: { 20 | "redux-saga/no-yield-in-race": 2, 21 | "redux-saga/yield-effects": 2, 22 | "redux-saga/no-unhandled-errors": 2 23 | } 24 | }, 25 | all: { 26 | plugins: ["redux-saga"], 27 | rules: allRules 28 | } 29 | } 30 | } 31 | -------------------------------------------------------------------------------- /lib/rules/no-unhandled-errors.js: -------------------------------------------------------------------------------- 1 | /** 2 | * @fileoverview Rule to enforce error handling on sagas 3 | * @author Nicolas @BuraBure Fernandez 4 | */ 5 | /** eslint-disable semi */ 6 | "use strict" 7 | 8 | var Effects = require("../utils/effects") 9 | 10 | var nonCatchableEffects = ["fork", "takeEvery", "takeLatest", "takeLeading", "throttle"] 11 | var knowEffects = Effects.knowEffects().filter(function(item) { 12 | return nonCatchableEffects.indexOf(item) === -1 13 | }) 14 | 15 | module.exports = { 16 | meta: { 17 | docs: { 18 | description: "enforce error handling on sagas", 19 | category: "Possible Errors", 20 | recommended: true 21 | }, 22 | schema: [] 23 | }, 24 | 25 | create: function(context) { 26 | var effectLocalNames = [] 27 | var effectImportedNames = [] 28 | var inTryStatementDepth = 0 29 | return { 30 | "ImportDeclaration": function(node) { 31 | if (Effects.isEffectImport(node.source.value)) { 32 | node.specifiers.forEach(function(specifier) { 33 | if (specifier.type === "ImportSpecifier" && knowEffects.indexOf(specifier.imported.name) !== -1) { 34 | effectLocalNames.push(specifier.local.name) 35 | effectImportedNames.push(specifier.imported.name) 36 | } 37 | }) 38 | } 39 | }, 40 | "TryStatement": function() { 41 | inTryStatementDepth += 1 42 | }, 43 | "TryStatement:exit": function() { 44 | inTryStatementDepth -= 1 45 | }, 46 | "CallExpression": function(node) { 47 | var callee = node.callee 48 | var localNameIndex = effectLocalNames.indexOf(callee.name) 49 | if (localNameIndex !== -1) { 50 | var importedName = effectImportedNames[localNameIndex] 51 | var effectName = callee.name 52 | if (importedName !== effectName) { 53 | effectName += " (" + importedName + ")" 54 | } 55 | if (inTryStatementDepth === 0) { 56 | context.report({ 57 | node: node, 58 | message: "A Saga must handle its effects' errors (use try/catch)" 59 | }) 60 | } 61 | } 62 | } 63 | } 64 | } 65 | } 66 | -------------------------------------------------------------------------------- /lib/rules/no-yield-in-race.js: -------------------------------------------------------------------------------- 1 | /** 2 | * @fileoverview Rule to flag use of yield inside race effects 3 | * @author Philipp Kursawe 4 | */ 5 | "use strict" 6 | 7 | function checkYieldInObject(context, node) { 8 | var properties = node.arguments[0].properties 9 | for (var i = 0, len = properties.length; i < len; ++i) { 10 | var property = properties[i] 11 | var name = property.key.name 12 | if (property.value.type === "YieldExpression") { 13 | var yieldExpression = property.value 14 | context.report({ 15 | node: property, 16 | message: "yield not allowed inside race: " + name, 17 | fix: function(fixer) { 18 | var nextToken = property.value.argument 19 | return fixer.removeRange([yieldExpression.range[0], nextToken.range[0]]) 20 | } 21 | }) 22 | } 23 | } 24 | } 25 | 26 | function checkYieldInArray(context, node) { 27 | var elements = node.arguments[0].elements 28 | for (var i = 0, len = elements.length; i < len; ++i) { 29 | var element = elements[i] 30 | if (element.type === "YieldExpression") { 31 | var yieldExpression = element 32 | context.report({ 33 | node: element, 34 | message: "yield not allowed inside race array at index: " + i, 35 | fix: function(fixer) { 36 | var nextToken = element.argument 37 | return fixer.removeRange([yieldExpression.range[0], nextToken.range[0]]) 38 | } 39 | }) 40 | } 41 | } 42 | } 43 | 44 | function checkCallExpression(context, node) { 45 | var callee = node.arguments[0].callee 46 | var object = callee && callee.object 47 | if (object) { 48 | var name = object.name 49 | var foundVariable = context.getScope().variables.find(function(variable) { 50 | return variable.name === name 51 | }) 52 | if (foundVariable) { 53 | var def = foundVariable.defs[foundVariable.defs.length - 1] 54 | if (def.node.init.type === "ArrayExpression" && callee.property.name !== "map") { 55 | context.report(node, "race must have Array.map as the only argument") 56 | } 57 | } 58 | } 59 | } 60 | 61 | module.exports = { 62 | meta: { 63 | docs: { 64 | description: "flag use of yield inside race effects", 65 | category: "Possible Errors", 66 | recommended: true 67 | }, 68 | fixable: "code", 69 | schema: [] 70 | }, 71 | 72 | create: function(context) { 73 | return { 74 | "CallExpression": function(node) { 75 | var callee = node.callee 76 | if (callee.name === "race") { 77 | var type = node.arguments[0].type 78 | if (node.arguments.length !== 1) { 79 | context.report(node, "race must have on object hash or array as the only argument") 80 | } else if (type === "ObjectExpression") { 81 | checkYieldInObject(context, node) 82 | } else if (type === "ArrayExpression") { 83 | checkYieldInArray(context, node) 84 | } else if (type === "CallExpression") { 85 | checkCallExpression(context, node) 86 | } else if (type === "YieldExpression") { 87 | var yieldExpression = node.arguments[0] 88 | context.report({ 89 | node: yieldExpression, 90 | message: "yield not allowed inside race", 91 | fix: function(fixer) { 92 | var nextToken = yieldExpression.argument 93 | return fixer.removeRange([yieldExpression.range[0], nextToken.range[0]]) 94 | } 95 | }) 96 | return 97 | } else { 98 | context.report(node, "race must have on object hash or array as the only argument") 99 | } 100 | } 101 | } 102 | } 103 | } 104 | } 105 | -------------------------------------------------------------------------------- /lib/rules/yield-effects.js: -------------------------------------------------------------------------------- 1 | /** 2 | * @fileoverview Rule to enforce yield in front of effects 3 | * @author Philipp Kursawe 4 | */ 5 | /** eslint-disable semi */ 6 | "use strict" 7 | 8 | var Effects = require("../utils/effects") 9 | 10 | var knowEffects = Effects.knowEffects() 11 | 12 | module.exports = { 13 | meta: { 14 | docs: { 15 | description: "enforce yield in front of effects", 16 | category: "Possible Errors", 17 | recommended: true 18 | }, 19 | hasSuggestions: true, 20 | schema: [] 21 | }, 22 | 23 | create: function(context) { 24 | var inYieldDepth = 0 25 | var inGeneratorDepth = 0 26 | var effectLocalNames = [] 27 | var effectImportedNames = [] 28 | 29 | function enterFunction(node) { 30 | if (node.generator) { 31 | ++inGeneratorDepth 32 | } 33 | } 34 | function exitFunction(node) { 35 | if (node.generator) { 36 | --inGeneratorDepth 37 | } 38 | } 39 | return { 40 | "ImportDeclaration": function(node) { 41 | if (Effects.isEffectImport(node.source.value)) { 42 | node.specifiers.forEach(function(specifier) { 43 | if (specifier.type === "ImportSpecifier" && knowEffects.indexOf(specifier.imported.name) !== -1) { 44 | effectLocalNames.push(specifier.local.name) 45 | effectImportedNames.push(specifier.imported.name) 46 | } 47 | }) 48 | } 49 | }, 50 | "FunctionDeclaration": enterFunction, 51 | "FunctionDeclaration:exit": exitFunction, 52 | "FunctionExpression": enterFunction, 53 | "FunctionExpression:exit": exitFunction, 54 | "YieldExpression": function() { 55 | inYieldDepth += 1 56 | }, 57 | "YieldExpression:exit": function() { 58 | inYieldDepth -= 1 59 | }, 60 | "CallExpression": function(node) { 61 | var callee = node.callee 62 | var localNameIndex = effectLocalNames.indexOf(callee.name) 63 | if (localNameIndex !== -1) { 64 | var importedName = effectImportedNames[localNameIndex] 65 | var effectName = callee.name 66 | if (importedName !== effectName) { 67 | effectName += " (" + importedName + ")" 68 | } 69 | if (inYieldDepth === 0 && inGeneratorDepth) { 70 | context.report({ 71 | node: node, 72 | message: effectName + " effect must be yielded", 73 | suggest: [ 74 | { 75 | desc: "Add yield", 76 | fix: function(fixer) { 77 | return fixer.insertTextBefore(node, "yield ") 78 | } 79 | } 80 | ] 81 | }) 82 | } 83 | } 84 | } 85 | } 86 | } 87 | } 88 | -------------------------------------------------------------------------------- /lib/utils/effects.js: -------------------------------------------------------------------------------- 1 | "use strict" 2 | 3 | var miscEffects = ["delay"] 4 | 5 | function knowEffects() { 6 | var other = Object.keys(require("redux-saga")).filter(function(effect) { 7 | return miscEffects.includes(effect) 8 | }) 9 | 10 | var reduxSagaEffects 11 | try { 12 | reduxSagaEffects = require("redux-saga/lib/effects") 13 | } catch (err) { 14 | reduxSagaEffects = require("redux-saga/effects") 15 | } 16 | 17 | return Object.keys(reduxSagaEffects).concat(other) 18 | } 19 | 20 | function isEffectImport(value) { 21 | return /^redux-saga(\/effects)?/.test(value) 22 | } 23 | 24 | module.exports = { 25 | isEffectImport: isEffectImport, 26 | knowEffects: knowEffects 27 | } 28 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "eslint-plugin-redux-saga", 3 | "version": "1.3.2", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/runtime": { 8 | "version": "7.11.2", 9 | "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.11.2.tgz", 10 | "integrity": "sha512-TeWkU52so0mPtDcaCTxNBI/IHiz0pZgr8VEFqXFtZWpYD08ZB6FaSwVAS8MKRQAP3bYKiVjwysOJgMFY28o6Tw==", 11 | "dev": true, 12 | "requires": { 13 | "regenerator-runtime": "^0.13.4" 14 | } 15 | }, 16 | "@eslint/eslintrc": { 17 | "version": "1.0.5", 18 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.0.5.tgz", 19 | "integrity": "sha512-BLxsnmK3KyPunz5wmCCpqy0YelEoxxGmH73Is+Z74oOTMtExcjkr3dDR6quwrjh1YspA8DH9gnX1o069KiS9AQ==", 20 | "dev": true, 21 | "requires": { 22 | "ajv": "^6.12.4", 23 | "debug": "^4.3.2", 24 | "espree": "^9.2.0", 25 | "globals": "^13.9.0", 26 | "ignore": "^4.0.6", 27 | "import-fresh": "^3.2.1", 28 | "js-yaml": "^4.1.0", 29 | "minimatch": "^3.0.4", 30 | "strip-json-comments": "^3.1.1" 31 | } 32 | }, 33 | "@humanwhocodes/config-array": { 34 | "version": "0.9.2", 35 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.9.2.tgz", 36 | "integrity": "sha512-UXOuFCGcwciWckOpmfKDq/GyhlTf9pN/BzG//x8p8zTOFEcGuA68ANXheFS0AGvy3qgZqLBUkMs7hqzqCKOVwA==", 37 | "dev": true, 38 | "requires": { 39 | "@humanwhocodes/object-schema": "^1.2.1", 40 | "debug": "^4.1.1", 41 | "minimatch": "^3.0.4" 42 | } 43 | }, 44 | "@humanwhocodes/object-schema": { 45 | "version": "1.2.1", 46 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 47 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 48 | "dev": true 49 | }, 50 | "@redux-saga/core": { 51 | "version": "1.1.3", 52 | "resolved": "https://registry.npmjs.org/@redux-saga/core/-/core-1.1.3.tgz", 53 | "integrity": "sha512-8tInBftak8TPzE6X13ABmEtRJGjtK17w7VUs7qV17S8hCO5S3+aUTWZ/DBsBJPdE8Z5jOPwYALyvofgq1Ws+kg==", 54 | "dev": true, 55 | "requires": { 56 | "@babel/runtime": "^7.6.3", 57 | "@redux-saga/deferred": "^1.1.2", 58 | "@redux-saga/delay-p": "^1.1.2", 59 | "@redux-saga/is": "^1.1.2", 60 | "@redux-saga/symbols": "^1.1.2", 61 | "@redux-saga/types": "^1.1.0", 62 | "redux": "^4.0.4", 63 | "typescript-tuple": "^2.2.1" 64 | } 65 | }, 66 | "@redux-saga/deferred": { 67 | "version": "1.1.2", 68 | "resolved": "https://registry.npmjs.org/@redux-saga/deferred/-/deferred-1.1.2.tgz", 69 | "integrity": "sha512-908rDLHFN2UUzt2jb4uOzj6afpjgJe3MjICaUNO3bvkV/kN/cNeI9PMr8BsFXB/MR8WTAZQq/PlTq8Kww3TBSQ==", 70 | "dev": true 71 | }, 72 | "@redux-saga/delay-p": { 73 | "version": "1.1.2", 74 | "resolved": "https://registry.npmjs.org/@redux-saga/delay-p/-/delay-p-1.1.2.tgz", 75 | "integrity": "sha512-ojc+1IoC6OP65Ts5+ZHbEYdrohmIw1j9P7HS9MOJezqMYtCDgpkoqB5enAAZrNtnbSL6gVCWPHaoaTY5KeO0/g==", 76 | "dev": true, 77 | "requires": { 78 | "@redux-saga/symbols": "^1.1.2" 79 | } 80 | }, 81 | "@redux-saga/is": { 82 | "version": "1.1.2", 83 | "resolved": "https://registry.npmjs.org/@redux-saga/is/-/is-1.1.2.tgz", 84 | "integrity": "sha512-OLbunKVsCVNTKEf2cH4TYyNbbPgvmZ52iaxBD4I1fTif4+MTXMa4/Z07L83zW/hTCXwpSZvXogqMqLfex2Tg6w==", 85 | "dev": true, 86 | "requires": { 87 | "@redux-saga/symbols": "^1.1.2", 88 | "@redux-saga/types": "^1.1.0" 89 | } 90 | }, 91 | "@redux-saga/symbols": { 92 | "version": "1.1.2", 93 | "resolved": "https://registry.npmjs.org/@redux-saga/symbols/-/symbols-1.1.2.tgz", 94 | "integrity": "sha512-EfdGnF423glv3uMwLsGAtE6bg+R9MdqlHEzExnfagXPrIiuxwr3bdiAwz3gi+PsrQ3yBlaBpfGLtDG8rf3LgQQ==", 95 | "dev": true 96 | }, 97 | "@redux-saga/types": { 98 | "version": "1.1.0", 99 | "resolved": "https://registry.npmjs.org/@redux-saga/types/-/types-1.1.0.tgz", 100 | "integrity": "sha512-afmTuJrylUU/0OtqzaRkbyYFFNgCF73Bvel/sw90pvGrWIZ+vyoIJqA6eMSoA6+nb443kTmulmBtC9NerXboNg==", 101 | "dev": true 102 | }, 103 | "@ungap/promise-all-settled": { 104 | "version": "1.1.2", 105 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 106 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 107 | "dev": true 108 | }, 109 | "acorn": { 110 | "version": "8.6.0", 111 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.6.0.tgz", 112 | "integrity": "sha512-U1riIR+lBSNi3IbxtaHOIKdH8sLFv3NYfNv8sg7ZsNhcfl4HF2++BfqqrNAxoCLQW1iiylOj76ecnaUxz+z9yw==", 113 | "dev": true 114 | }, 115 | "acorn-jsx": { 116 | "version": "5.3.2", 117 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 118 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 119 | "dev": true 120 | }, 121 | "ajv": { 122 | "version": "6.12.6", 123 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 124 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 125 | "dev": true, 126 | "requires": { 127 | "fast-deep-equal": "^3.1.1", 128 | "fast-json-stable-stringify": "^2.0.0", 129 | "json-schema-traverse": "^0.4.1", 130 | "uri-js": "^4.2.2" 131 | } 132 | }, 133 | "ansi-colors": { 134 | "version": "4.1.1", 135 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 136 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 137 | "dev": true 138 | }, 139 | "ansi-regex": { 140 | "version": "5.0.1", 141 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 142 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 143 | "dev": true 144 | }, 145 | "ansi-styles": { 146 | "version": "4.3.0", 147 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 148 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 149 | "dev": true, 150 | "requires": { 151 | "color-convert": "^2.0.1" 152 | } 153 | }, 154 | "anymatch": { 155 | "version": "3.1.2", 156 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 157 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 158 | "dev": true, 159 | "requires": { 160 | "normalize-path": "^3.0.0", 161 | "picomatch": "^2.0.4" 162 | } 163 | }, 164 | "argparse": { 165 | "version": "2.0.1", 166 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 167 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 168 | "dev": true 169 | }, 170 | "balanced-match": { 171 | "version": "1.0.0", 172 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 173 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 174 | "dev": true 175 | }, 176 | "binary-extensions": { 177 | "version": "2.2.0", 178 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 179 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 180 | "dev": true 181 | }, 182 | "brace-expansion": { 183 | "version": "1.1.11", 184 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 185 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 186 | "dev": true, 187 | "requires": { 188 | "balanced-match": "^1.0.0", 189 | "concat-map": "0.0.1" 190 | } 191 | }, 192 | "braces": { 193 | "version": "3.0.2", 194 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 195 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 196 | "dev": true, 197 | "requires": { 198 | "fill-range": "^7.0.1" 199 | } 200 | }, 201 | "browser-stdout": { 202 | "version": "1.3.1", 203 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 204 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 205 | "dev": true 206 | }, 207 | "callsites": { 208 | "version": "3.1.0", 209 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 210 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 211 | "dev": true 212 | }, 213 | "camelcase": { 214 | "version": "6.2.1", 215 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.1.tgz", 216 | "integrity": "sha512-tVI4q5jjFV5CavAU8DXfza/TJcZutVKo/5Foskmsqcm0MsL91moHvwiGNnqaa2o6PF/7yT5ikDRcVcl8Rj6LCA==", 217 | "dev": true 218 | }, 219 | "chalk": { 220 | "version": "4.1.2", 221 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 222 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 223 | "dev": true, 224 | "requires": { 225 | "ansi-styles": "^4.1.0", 226 | "supports-color": "^7.1.0" 227 | } 228 | }, 229 | "chokidar": { 230 | "version": "3.5.2", 231 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 232 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 233 | "dev": true, 234 | "requires": { 235 | "anymatch": "~3.1.2", 236 | "braces": "~3.0.2", 237 | "fsevents": "~2.3.2", 238 | "glob-parent": "~5.1.2", 239 | "is-binary-path": "~2.1.0", 240 | "is-glob": "~4.0.1", 241 | "normalize-path": "~3.0.0", 242 | "readdirp": "~3.6.0" 243 | } 244 | }, 245 | "cliui": { 246 | "version": "7.0.4", 247 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 248 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 249 | "dev": true, 250 | "requires": { 251 | "string-width": "^4.2.0", 252 | "strip-ansi": "^6.0.0", 253 | "wrap-ansi": "^7.0.0" 254 | }, 255 | "dependencies": { 256 | "ansi-regex": { 257 | "version": "5.0.1", 258 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 259 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 260 | "dev": true 261 | }, 262 | "emoji-regex": { 263 | "version": "8.0.0", 264 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 265 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 266 | "dev": true 267 | }, 268 | "is-fullwidth-code-point": { 269 | "version": "3.0.0", 270 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 271 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 272 | "dev": true 273 | }, 274 | "string-width": { 275 | "version": "4.2.3", 276 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 277 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 278 | "dev": true, 279 | "requires": { 280 | "emoji-regex": "^8.0.0", 281 | "is-fullwidth-code-point": "^3.0.0", 282 | "strip-ansi": "^6.0.1" 283 | } 284 | }, 285 | "strip-ansi": { 286 | "version": "6.0.1", 287 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 288 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 289 | "dev": true, 290 | "requires": { 291 | "ansi-regex": "^5.0.1" 292 | } 293 | } 294 | } 295 | }, 296 | "color-convert": { 297 | "version": "2.0.1", 298 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 299 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 300 | "dev": true, 301 | "requires": { 302 | "color-name": "~1.1.4" 303 | } 304 | }, 305 | "color-name": { 306 | "version": "1.1.4", 307 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 308 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 309 | "dev": true 310 | }, 311 | "concat-map": { 312 | "version": "0.0.1", 313 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 314 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 315 | "dev": true 316 | }, 317 | "cross-spawn": { 318 | "version": "7.0.3", 319 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 320 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 321 | "dev": true, 322 | "requires": { 323 | "path-key": "^3.1.0", 324 | "shebang-command": "^2.0.0", 325 | "which": "^2.0.1" 326 | } 327 | }, 328 | "debug": { 329 | "version": "4.3.3", 330 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 331 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 332 | "dev": true, 333 | "requires": { 334 | "ms": "2.1.2" 335 | } 336 | }, 337 | "decamelize": { 338 | "version": "4.0.0", 339 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 340 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 341 | "dev": true 342 | }, 343 | "deep-is": { 344 | "version": "0.1.4", 345 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 346 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 347 | "dev": true 348 | }, 349 | "diff": { 350 | "version": "5.0.0", 351 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 352 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 353 | "dev": true 354 | }, 355 | "doctrine": { 356 | "version": "3.0.0", 357 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 358 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 359 | "dev": true, 360 | "requires": { 361 | "esutils": "^2.0.2" 362 | } 363 | }, 364 | "enquirer": { 365 | "version": "2.3.6", 366 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 367 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 368 | "dev": true, 369 | "requires": { 370 | "ansi-colors": "^4.1.1" 371 | } 372 | }, 373 | "escalade": { 374 | "version": "3.1.1", 375 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 376 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 377 | "dev": true 378 | }, 379 | "escape-string-regexp": { 380 | "version": "4.0.0", 381 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 382 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 383 | "dev": true 384 | }, 385 | "eslint": { 386 | "version": "8.4.1", 387 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.4.1.tgz", 388 | "integrity": "sha512-TxU/p7LB1KxQ6+7aztTnO7K0i+h0tDi81YRY9VzB6Id71kNz+fFYnf5HD5UOQmxkzcoa0TlVZf9dpMtUv0GpWg==", 389 | "dev": true, 390 | "requires": { 391 | "@eslint/eslintrc": "^1.0.5", 392 | "@humanwhocodes/config-array": "^0.9.2", 393 | "ajv": "^6.10.0", 394 | "chalk": "^4.0.0", 395 | "cross-spawn": "^7.0.2", 396 | "debug": "^4.3.2", 397 | "doctrine": "^3.0.0", 398 | "enquirer": "^2.3.5", 399 | "escape-string-regexp": "^4.0.0", 400 | "eslint-scope": "^7.1.0", 401 | "eslint-utils": "^3.0.0", 402 | "eslint-visitor-keys": "^3.1.0", 403 | "espree": "^9.2.0", 404 | "esquery": "^1.4.0", 405 | "esutils": "^2.0.2", 406 | "fast-deep-equal": "^3.1.3", 407 | "file-entry-cache": "^6.0.1", 408 | "functional-red-black-tree": "^1.0.1", 409 | "glob-parent": "^6.0.1", 410 | "globals": "^13.6.0", 411 | "ignore": "^4.0.6", 412 | "import-fresh": "^3.0.0", 413 | "imurmurhash": "^0.1.4", 414 | "is-glob": "^4.0.0", 415 | "js-yaml": "^4.1.0", 416 | "json-stable-stringify-without-jsonify": "^1.0.1", 417 | "levn": "^0.4.1", 418 | "lodash.merge": "^4.6.2", 419 | "minimatch": "^3.0.4", 420 | "natural-compare": "^1.4.0", 421 | "optionator": "^0.9.1", 422 | "progress": "^2.0.0", 423 | "regexpp": "^3.2.0", 424 | "semver": "^7.2.1", 425 | "strip-ansi": "^6.0.1", 426 | "strip-json-comments": "^3.1.0", 427 | "text-table": "^0.2.0", 428 | "v8-compile-cache": "^2.0.3" 429 | }, 430 | "dependencies": { 431 | "glob-parent": { 432 | "version": "6.0.2", 433 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 434 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 435 | "dev": true, 436 | "requires": { 437 | "is-glob": "^4.0.3" 438 | }, 439 | "dependencies": { 440 | "is-glob": { 441 | "version": "4.0.3", 442 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 443 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 444 | "dev": true, 445 | "requires": { 446 | "is-extglob": "^2.1.1" 447 | } 448 | } 449 | } 450 | } 451 | } 452 | }, 453 | "eslint-scope": { 454 | "version": "7.1.0", 455 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.0.tgz", 456 | "integrity": "sha512-aWwkhnS0qAXqNOgKOK0dJ2nvzEbhEvpy8OlJ9kZ0FeZnA6zpjv1/Vei+puGFFX7zkPCkHHXb7IDX3A+7yPrRWg==", 457 | "dev": true, 458 | "requires": { 459 | "esrecurse": "^4.3.0", 460 | "estraverse": "^5.2.0" 461 | } 462 | }, 463 | "eslint-utils": { 464 | "version": "3.0.0", 465 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 466 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 467 | "dev": true, 468 | "requires": { 469 | "eslint-visitor-keys": "^2.0.0" 470 | }, 471 | "dependencies": { 472 | "eslint-visitor-keys": { 473 | "version": "2.1.0", 474 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 475 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 476 | "dev": true 477 | } 478 | } 479 | }, 480 | "eslint-visitor-keys": { 481 | "version": "3.1.0", 482 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.1.0.tgz", 483 | "integrity": "sha512-yWJFpu4DtjsWKkt5GeNBBuZMlNcYVs6vRCLoCVEJrTjaSB6LC98gFipNK/erM2Heg/E8mIK+hXG/pJMLK+eRZA==", 484 | "dev": true 485 | }, 486 | "espree": { 487 | "version": "9.2.0", 488 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.2.0.tgz", 489 | "integrity": "sha512-oP3utRkynpZWF/F2x/HZJ+AGtnIclaR7z1pYPxy7NYM2fSO6LgK/Rkny8anRSPK/VwEA1eqm2squui0T7ZMOBg==", 490 | "dev": true, 491 | "requires": { 492 | "acorn": "^8.6.0", 493 | "acorn-jsx": "^5.3.1", 494 | "eslint-visitor-keys": "^3.1.0" 495 | } 496 | }, 497 | "esquery": { 498 | "version": "1.4.0", 499 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 500 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 501 | "dev": true, 502 | "requires": { 503 | "estraverse": "^5.1.0" 504 | } 505 | }, 506 | "esrecurse": { 507 | "version": "4.3.0", 508 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 509 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 510 | "dev": true, 511 | "requires": { 512 | "estraverse": "^5.2.0" 513 | } 514 | }, 515 | "estraverse": { 516 | "version": "5.3.0", 517 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 518 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 519 | "dev": true 520 | }, 521 | "esutils": { 522 | "version": "2.0.3", 523 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 524 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 525 | "dev": true 526 | }, 527 | "fast-deep-equal": { 528 | "version": "3.1.3", 529 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 530 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 531 | "dev": true 532 | }, 533 | "fast-json-stable-stringify": { 534 | "version": "2.1.0", 535 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 536 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 537 | "dev": true 538 | }, 539 | "fast-levenshtein": { 540 | "version": "2.0.6", 541 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 542 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 543 | "dev": true 544 | }, 545 | "file-entry-cache": { 546 | "version": "6.0.1", 547 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 548 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 549 | "dev": true, 550 | "requires": { 551 | "flat-cache": "^3.0.4" 552 | } 553 | }, 554 | "fill-range": { 555 | "version": "7.0.1", 556 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 557 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 558 | "dev": true, 559 | "requires": { 560 | "to-regex-range": "^5.0.1" 561 | } 562 | }, 563 | "find-up": { 564 | "version": "5.0.0", 565 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 566 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 567 | "dev": true, 568 | "requires": { 569 | "locate-path": "^6.0.0", 570 | "path-exists": "^4.0.0" 571 | } 572 | }, 573 | "flat": { 574 | "version": "5.0.2", 575 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 576 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 577 | "dev": true 578 | }, 579 | "flat-cache": { 580 | "version": "3.0.4", 581 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 582 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 583 | "dev": true, 584 | "requires": { 585 | "flatted": "^3.1.0", 586 | "rimraf": "^3.0.2" 587 | } 588 | }, 589 | "flatted": { 590 | "version": "3.2.4", 591 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.4.tgz", 592 | "integrity": "sha512-8/sOawo8tJ4QOBX8YlQBMxL8+RLZfxMQOif9o0KUKTNTjMYElWPE0r/m5VNFxTRd0NSw8qSy8dajrwX4RYI1Hw==", 593 | "dev": true 594 | }, 595 | "fs.realpath": { 596 | "version": "1.0.0", 597 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 598 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 599 | "dev": true 600 | }, 601 | "fsevents": { 602 | "version": "2.3.2", 603 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 604 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 605 | "dev": true, 606 | "optional": true 607 | }, 608 | "functional-red-black-tree": { 609 | "version": "1.0.1", 610 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 611 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 612 | "dev": true 613 | }, 614 | "get-caller-file": { 615 | "version": "2.0.5", 616 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 617 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 618 | "dev": true 619 | }, 620 | "glob": { 621 | "version": "7.2.0", 622 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 623 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 624 | "dev": true, 625 | "requires": { 626 | "fs.realpath": "^1.0.0", 627 | "inflight": "^1.0.4", 628 | "inherits": "2", 629 | "minimatch": "^3.0.4", 630 | "once": "^1.3.0", 631 | "path-is-absolute": "^1.0.0" 632 | } 633 | }, 634 | "glob-parent": { 635 | "version": "5.1.2", 636 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 637 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 638 | "dev": true, 639 | "requires": { 640 | "is-glob": "^4.0.1" 641 | } 642 | }, 643 | "globals": { 644 | "version": "13.12.0", 645 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.12.0.tgz", 646 | "integrity": "sha512-uS8X6lSKN2JumVoXrbUz+uG4BYG+eiawqm3qFcT7ammfbUHeCBoJMlHcec/S3krSk73/AE/f0szYFmgAA3kYZg==", 647 | "dev": true, 648 | "requires": { 649 | "type-fest": "^0.20.2" 650 | } 651 | }, 652 | "growl": { 653 | "version": "1.10.5", 654 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 655 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 656 | "dev": true 657 | }, 658 | "has-flag": { 659 | "version": "4.0.0", 660 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 661 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 662 | "dev": true 663 | }, 664 | "he": { 665 | "version": "1.2.0", 666 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 667 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 668 | "dev": true 669 | }, 670 | "ignore": { 671 | "version": "4.0.6", 672 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 673 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 674 | "dev": true 675 | }, 676 | "import-fresh": { 677 | "version": "3.3.0", 678 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 679 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 680 | "dev": true, 681 | "requires": { 682 | "parent-module": "^1.0.0", 683 | "resolve-from": "^4.0.0" 684 | } 685 | }, 686 | "imurmurhash": { 687 | "version": "0.1.4", 688 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 689 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 690 | "dev": true 691 | }, 692 | "inflight": { 693 | "version": "1.0.6", 694 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 695 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 696 | "dev": true, 697 | "requires": { 698 | "once": "^1.3.0", 699 | "wrappy": "1" 700 | } 701 | }, 702 | "inherits": { 703 | "version": "2.0.4", 704 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 705 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 706 | "dev": true 707 | }, 708 | "is-binary-path": { 709 | "version": "2.1.0", 710 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 711 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 712 | "dev": true, 713 | "requires": { 714 | "binary-extensions": "^2.0.0" 715 | } 716 | }, 717 | "is-extglob": { 718 | "version": "2.1.1", 719 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 720 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 721 | "dev": true 722 | }, 723 | "is-glob": { 724 | "version": "4.0.1", 725 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 726 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 727 | "dev": true, 728 | "requires": { 729 | "is-extglob": "^2.1.1" 730 | } 731 | }, 732 | "is-number": { 733 | "version": "7.0.0", 734 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 735 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 736 | "dev": true 737 | }, 738 | "is-plain-obj": { 739 | "version": "2.1.0", 740 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 741 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 742 | "dev": true 743 | }, 744 | "is-unicode-supported": { 745 | "version": "0.1.0", 746 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 747 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 748 | "dev": true 749 | }, 750 | "isexe": { 751 | "version": "2.0.0", 752 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 753 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 754 | "dev": true 755 | }, 756 | "js-tokens": { 757 | "version": "4.0.0", 758 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 759 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 760 | "dev": true 761 | }, 762 | "js-yaml": { 763 | "version": "4.1.0", 764 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 765 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 766 | "dev": true, 767 | "requires": { 768 | "argparse": "^2.0.1" 769 | } 770 | }, 771 | "json-schema-traverse": { 772 | "version": "0.4.1", 773 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 774 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 775 | "dev": true 776 | }, 777 | "json-stable-stringify-without-jsonify": { 778 | "version": "1.0.1", 779 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 780 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 781 | "dev": true 782 | }, 783 | "levn": { 784 | "version": "0.4.1", 785 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 786 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 787 | "dev": true, 788 | "requires": { 789 | "prelude-ls": "^1.2.1", 790 | "type-check": "~0.4.0" 791 | } 792 | }, 793 | "locate-path": { 794 | "version": "6.0.0", 795 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 796 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 797 | "dev": true, 798 | "requires": { 799 | "p-locate": "^5.0.0" 800 | } 801 | }, 802 | "lodash.merge": { 803 | "version": "4.6.2", 804 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 805 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 806 | "dev": true 807 | }, 808 | "log-symbols": { 809 | "version": "4.1.0", 810 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 811 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 812 | "dev": true, 813 | "requires": { 814 | "chalk": "^4.1.0", 815 | "is-unicode-supported": "^0.1.0" 816 | }, 817 | "dependencies": { 818 | "ansi-styles": { 819 | "version": "4.3.0", 820 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 821 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 822 | "dev": true, 823 | "requires": { 824 | "color-convert": "^2.0.1" 825 | } 826 | }, 827 | "chalk": { 828 | "version": "4.1.2", 829 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 830 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 831 | "dev": true, 832 | "requires": { 833 | "ansi-styles": "^4.1.0", 834 | "supports-color": "^7.1.0" 835 | } 836 | }, 837 | "color-convert": { 838 | "version": "2.0.1", 839 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 840 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 841 | "dev": true, 842 | "requires": { 843 | "color-name": "~1.1.4" 844 | } 845 | }, 846 | "color-name": { 847 | "version": "1.1.4", 848 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 849 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 850 | "dev": true 851 | }, 852 | "has-flag": { 853 | "version": "4.0.0", 854 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 855 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 856 | "dev": true 857 | }, 858 | "supports-color": { 859 | "version": "7.2.0", 860 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 861 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 862 | "dev": true, 863 | "requires": { 864 | "has-flag": "^4.0.0" 865 | } 866 | } 867 | } 868 | }, 869 | "loose-envify": { 870 | "version": "1.4.0", 871 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 872 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 873 | "dev": true, 874 | "requires": { 875 | "js-tokens": "^3.0.0 || ^4.0.0" 876 | } 877 | }, 878 | "lru-cache": { 879 | "version": "6.0.0", 880 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 881 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 882 | "dev": true, 883 | "requires": { 884 | "yallist": "^4.0.0" 885 | } 886 | }, 887 | "minimatch": { 888 | "version": "3.0.4", 889 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 890 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 891 | "dev": true, 892 | "requires": { 893 | "brace-expansion": "^1.1.7" 894 | } 895 | }, 896 | "mocha": { 897 | "version": "9.1.3", 898 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.1.3.tgz", 899 | "integrity": "sha512-Xcpl9FqXOAYqI3j79pEtHBBnQgVXIhpULjGQa7DVb0Po+VzmSIK9kanAiWLHoRR/dbZ2qpdPshuXr8l1VaHCzw==", 900 | "dev": true, 901 | "requires": { 902 | "@ungap/promise-all-settled": "1.1.2", 903 | "ansi-colors": "4.1.1", 904 | "browser-stdout": "1.3.1", 905 | "chokidar": "3.5.2", 906 | "debug": "4.3.2", 907 | "diff": "5.0.0", 908 | "escape-string-regexp": "4.0.0", 909 | "find-up": "5.0.0", 910 | "glob": "7.1.7", 911 | "growl": "1.10.5", 912 | "he": "1.2.0", 913 | "js-yaml": "4.1.0", 914 | "log-symbols": "4.1.0", 915 | "minimatch": "3.0.4", 916 | "ms": "2.1.3", 917 | "nanoid": "3.1.25", 918 | "serialize-javascript": "6.0.0", 919 | "strip-json-comments": "3.1.1", 920 | "supports-color": "8.1.1", 921 | "which": "2.0.2", 922 | "workerpool": "6.1.5", 923 | "yargs": "16.2.0", 924 | "yargs-parser": "20.2.4", 925 | "yargs-unparser": "2.0.0" 926 | }, 927 | "dependencies": { 928 | "argparse": { 929 | "version": "2.0.1", 930 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 931 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 932 | "dev": true 933 | }, 934 | "debug": { 935 | "version": "4.3.2", 936 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 937 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 938 | "dev": true, 939 | "requires": { 940 | "ms": "2.1.2" 941 | }, 942 | "dependencies": { 943 | "ms": { 944 | "version": "2.1.2", 945 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 946 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 947 | "dev": true 948 | } 949 | } 950 | }, 951 | "escape-string-regexp": { 952 | "version": "4.0.0", 953 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 954 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 955 | "dev": true 956 | }, 957 | "glob": { 958 | "version": "7.1.7", 959 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 960 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 961 | "dev": true, 962 | "requires": { 963 | "fs.realpath": "^1.0.0", 964 | "inflight": "^1.0.4", 965 | "inherits": "2", 966 | "minimatch": "^3.0.4", 967 | "once": "^1.3.0", 968 | "path-is-absolute": "^1.0.0" 969 | } 970 | }, 971 | "has-flag": { 972 | "version": "4.0.0", 973 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 974 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 975 | "dev": true 976 | }, 977 | "js-yaml": { 978 | "version": "4.1.0", 979 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 980 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 981 | "dev": true, 982 | "requires": { 983 | "argparse": "^2.0.1" 984 | } 985 | }, 986 | "ms": { 987 | "version": "2.1.3", 988 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 989 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 990 | "dev": true 991 | }, 992 | "supports-color": { 993 | "version": "8.1.1", 994 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 995 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 996 | "dev": true, 997 | "requires": { 998 | "has-flag": "^4.0.0" 999 | } 1000 | }, 1001 | "which": { 1002 | "version": "2.0.2", 1003 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1004 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1005 | "dev": true, 1006 | "requires": { 1007 | "isexe": "^2.0.0" 1008 | } 1009 | } 1010 | } 1011 | }, 1012 | "ms": { 1013 | "version": "2.1.2", 1014 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1015 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1016 | "dev": true 1017 | }, 1018 | "nanoid": { 1019 | "version": "3.1.25", 1020 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.25.tgz", 1021 | "integrity": "sha512-rdwtIXaXCLFAQbnfqDRnI6jaRHp9fTcYBjtFKE8eezcZ7LuLjhUaQGNeMXf1HmRoCH32CLz6XwX0TtxEOS/A3Q==", 1022 | "dev": true 1023 | }, 1024 | "natural-compare": { 1025 | "version": "1.4.0", 1026 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1027 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1028 | "dev": true 1029 | }, 1030 | "normalize-path": { 1031 | "version": "3.0.0", 1032 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1033 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1034 | "dev": true 1035 | }, 1036 | "once": { 1037 | "version": "1.4.0", 1038 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1039 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1040 | "dev": true, 1041 | "requires": { 1042 | "wrappy": "1" 1043 | } 1044 | }, 1045 | "optionator": { 1046 | "version": "0.9.1", 1047 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1048 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1049 | "dev": true, 1050 | "requires": { 1051 | "deep-is": "^0.1.3", 1052 | "fast-levenshtein": "^2.0.6", 1053 | "levn": "^0.4.1", 1054 | "prelude-ls": "^1.2.1", 1055 | "type-check": "^0.4.0", 1056 | "word-wrap": "^1.2.3" 1057 | } 1058 | }, 1059 | "p-limit": { 1060 | "version": "3.1.0", 1061 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1062 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1063 | "dev": true, 1064 | "requires": { 1065 | "yocto-queue": "^0.1.0" 1066 | } 1067 | }, 1068 | "p-locate": { 1069 | "version": "5.0.0", 1070 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1071 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1072 | "dev": true, 1073 | "requires": { 1074 | "p-limit": "^3.0.2" 1075 | } 1076 | }, 1077 | "parent-module": { 1078 | "version": "1.0.1", 1079 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1080 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1081 | "dev": true, 1082 | "requires": { 1083 | "callsites": "^3.0.0" 1084 | } 1085 | }, 1086 | "path-exists": { 1087 | "version": "4.0.0", 1088 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1089 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1090 | "dev": true 1091 | }, 1092 | "path-is-absolute": { 1093 | "version": "1.0.1", 1094 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1095 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1096 | "dev": true 1097 | }, 1098 | "path-key": { 1099 | "version": "3.1.1", 1100 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1101 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1102 | "dev": true 1103 | }, 1104 | "picomatch": { 1105 | "version": "2.3.0", 1106 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 1107 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 1108 | "dev": true 1109 | }, 1110 | "prelude-ls": { 1111 | "version": "1.2.1", 1112 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1113 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1114 | "dev": true 1115 | }, 1116 | "progress": { 1117 | "version": "2.0.3", 1118 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1119 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1120 | "dev": true 1121 | }, 1122 | "punycode": { 1123 | "version": "2.1.1", 1124 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1125 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1126 | "dev": true 1127 | }, 1128 | "randombytes": { 1129 | "version": "2.1.0", 1130 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1131 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1132 | "dev": true, 1133 | "requires": { 1134 | "safe-buffer": "^5.1.0" 1135 | } 1136 | }, 1137 | "readdirp": { 1138 | "version": "3.6.0", 1139 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1140 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1141 | "dev": true, 1142 | "requires": { 1143 | "picomatch": "^2.2.1" 1144 | } 1145 | }, 1146 | "redux": { 1147 | "version": "4.0.5", 1148 | "resolved": "https://registry.npmjs.org/redux/-/redux-4.0.5.tgz", 1149 | "integrity": "sha512-VSz1uMAH24DM6MF72vcojpYPtrTUu3ByVWfPL1nPfVRb5mZVTve5GnNCUV53QM/BZ66xfWrm0CTWoM+Xlz8V1w==", 1150 | "dev": true, 1151 | "requires": { 1152 | "loose-envify": "^1.4.0", 1153 | "symbol-observable": "^1.2.0" 1154 | } 1155 | }, 1156 | "redux-saga": { 1157 | "version": "1.1.3", 1158 | "resolved": "https://registry.npmjs.org/redux-saga/-/redux-saga-1.1.3.tgz", 1159 | "integrity": "sha512-RkSn/z0mwaSa5/xH/hQLo8gNf4tlvT18qXDNvedihLcfzh+jMchDgaariQoehCpgRltEm4zHKJyINEz6aqswTw==", 1160 | "dev": true, 1161 | "requires": { 1162 | "@redux-saga/core": "^1.1.3" 1163 | } 1164 | }, 1165 | "regenerator-runtime": { 1166 | "version": "0.13.7", 1167 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.7.tgz", 1168 | "integrity": "sha512-a54FxoJDIr27pgf7IgeQGxmqUNYrcV338lf/6gH456HZ/PhX+5BcwHXG9ajESmwe6WRO0tAzRUrRmNONWgkrew==", 1169 | "dev": true 1170 | }, 1171 | "regexpp": { 1172 | "version": "3.2.0", 1173 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 1174 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 1175 | "dev": true 1176 | }, 1177 | "require-directory": { 1178 | "version": "2.1.1", 1179 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1180 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1181 | "dev": true 1182 | }, 1183 | "resolve-from": { 1184 | "version": "4.0.0", 1185 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1186 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1187 | "dev": true 1188 | }, 1189 | "rimraf": { 1190 | "version": "3.0.2", 1191 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1192 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1193 | "dev": true, 1194 | "requires": { 1195 | "glob": "^7.1.3" 1196 | } 1197 | }, 1198 | "safe-buffer": { 1199 | "version": "5.2.1", 1200 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1201 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1202 | "dev": true 1203 | }, 1204 | "semver": { 1205 | "version": "7.3.5", 1206 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 1207 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 1208 | "dev": true, 1209 | "requires": { 1210 | "lru-cache": "^6.0.0" 1211 | } 1212 | }, 1213 | "serialize-javascript": { 1214 | "version": "6.0.0", 1215 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 1216 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 1217 | "dev": true, 1218 | "requires": { 1219 | "randombytes": "^2.1.0" 1220 | } 1221 | }, 1222 | "shebang-command": { 1223 | "version": "2.0.0", 1224 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1225 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1226 | "dev": true, 1227 | "requires": { 1228 | "shebang-regex": "^3.0.0" 1229 | } 1230 | }, 1231 | "shebang-regex": { 1232 | "version": "3.0.0", 1233 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1234 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1235 | "dev": true 1236 | }, 1237 | "strip-ansi": { 1238 | "version": "6.0.1", 1239 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1240 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1241 | "dev": true, 1242 | "requires": { 1243 | "ansi-regex": "^5.0.1" 1244 | } 1245 | }, 1246 | "strip-json-comments": { 1247 | "version": "3.1.1", 1248 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1249 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1250 | "dev": true 1251 | }, 1252 | "supports-color": { 1253 | "version": "7.2.0", 1254 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1255 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1256 | "dev": true, 1257 | "requires": { 1258 | "has-flag": "^4.0.0" 1259 | } 1260 | }, 1261 | "symbol-observable": { 1262 | "version": "1.2.0", 1263 | "resolved": "https://registry.npmjs.org/symbol-observable/-/symbol-observable-1.2.0.tgz", 1264 | "integrity": "sha512-e900nM8RRtGhlV36KGEU9k65K3mPb1WV70OdjfxlG2EAuM1noi/E/BaW/uMhL7bPEssK8QV57vN3esixjUvcXQ==", 1265 | "dev": true 1266 | }, 1267 | "text-table": { 1268 | "version": "0.2.0", 1269 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1270 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1271 | "dev": true 1272 | }, 1273 | "to-regex-range": { 1274 | "version": "5.0.1", 1275 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1276 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1277 | "dev": true, 1278 | "requires": { 1279 | "is-number": "^7.0.0" 1280 | } 1281 | }, 1282 | "type-check": { 1283 | "version": "0.4.0", 1284 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1285 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1286 | "dev": true, 1287 | "requires": { 1288 | "prelude-ls": "^1.2.1" 1289 | } 1290 | }, 1291 | "type-fest": { 1292 | "version": "0.20.2", 1293 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1294 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1295 | "dev": true 1296 | }, 1297 | "typescript-compare": { 1298 | "version": "0.0.2", 1299 | "resolved": "https://registry.npmjs.org/typescript-compare/-/typescript-compare-0.0.2.tgz", 1300 | "integrity": "sha512-8ja4j7pMHkfLJQO2/8tut7ub+J3Lw2S3061eJLFQcvs3tsmJKp8KG5NtpLn7KcY2w08edF74BSVN7qJS0U6oHA==", 1301 | "dev": true, 1302 | "requires": { 1303 | "typescript-logic": "^0.0.0" 1304 | } 1305 | }, 1306 | "typescript-logic": { 1307 | "version": "0.0.0", 1308 | "resolved": "https://registry.npmjs.org/typescript-logic/-/typescript-logic-0.0.0.tgz", 1309 | "integrity": "sha512-zXFars5LUkI3zP492ls0VskH3TtdeHCqu0i7/duGt60i5IGPIpAHE/DWo5FqJ6EjQ15YKXrt+AETjv60Dat34Q==", 1310 | "dev": true 1311 | }, 1312 | "typescript-tuple": { 1313 | "version": "2.2.1", 1314 | "resolved": "https://registry.npmjs.org/typescript-tuple/-/typescript-tuple-2.2.1.tgz", 1315 | "integrity": "sha512-Zcr0lbt8z5ZdEzERHAMAniTiIKerFCMgd7yjq1fPnDJ43et/k9twIFQMUYff9k5oXcsQ0WpvFcgzK2ZKASoW6Q==", 1316 | "dev": true, 1317 | "requires": { 1318 | "typescript-compare": "^0.0.2" 1319 | } 1320 | }, 1321 | "uri-js": { 1322 | "version": "4.4.1", 1323 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1324 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1325 | "dev": true, 1326 | "requires": { 1327 | "punycode": "^2.1.0" 1328 | } 1329 | }, 1330 | "v8-compile-cache": { 1331 | "version": "2.3.0", 1332 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 1333 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 1334 | "dev": true 1335 | }, 1336 | "which": { 1337 | "version": "2.0.2", 1338 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1339 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1340 | "dev": true, 1341 | "requires": { 1342 | "isexe": "^2.0.0" 1343 | } 1344 | }, 1345 | "word-wrap": { 1346 | "version": "1.2.3", 1347 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1348 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1349 | "dev": true 1350 | }, 1351 | "workerpool": { 1352 | "version": "6.1.5", 1353 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.1.5.tgz", 1354 | "integrity": "sha512-XdKkCK0Zqc6w3iTxLckiuJ81tiD/o5rBE/m+nXpRCB+/Sq4DqkfXZ/x0jW02DG1tGsfUGXbTJyZDP+eu67haSw==", 1355 | "dev": true 1356 | }, 1357 | "wrap-ansi": { 1358 | "version": "7.0.0", 1359 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1360 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1361 | "dev": true, 1362 | "requires": { 1363 | "ansi-styles": "^4.0.0", 1364 | "string-width": "^4.1.0", 1365 | "strip-ansi": "^6.0.0" 1366 | }, 1367 | "dependencies": { 1368 | "ansi-regex": { 1369 | "version": "5.0.1", 1370 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1371 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1372 | "dev": true 1373 | }, 1374 | "ansi-styles": { 1375 | "version": "4.3.0", 1376 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1377 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1378 | "dev": true, 1379 | "requires": { 1380 | "color-convert": "^2.0.1" 1381 | } 1382 | }, 1383 | "color-convert": { 1384 | "version": "2.0.1", 1385 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1386 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1387 | "dev": true, 1388 | "requires": { 1389 | "color-name": "~1.1.4" 1390 | } 1391 | }, 1392 | "color-name": { 1393 | "version": "1.1.4", 1394 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1395 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1396 | "dev": true 1397 | }, 1398 | "emoji-regex": { 1399 | "version": "8.0.0", 1400 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1401 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1402 | "dev": true 1403 | }, 1404 | "is-fullwidth-code-point": { 1405 | "version": "3.0.0", 1406 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1407 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1408 | "dev": true 1409 | }, 1410 | "string-width": { 1411 | "version": "4.2.3", 1412 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1413 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1414 | "dev": true, 1415 | "requires": { 1416 | "emoji-regex": "^8.0.0", 1417 | "is-fullwidth-code-point": "^3.0.0", 1418 | "strip-ansi": "^6.0.1" 1419 | } 1420 | }, 1421 | "strip-ansi": { 1422 | "version": "6.0.1", 1423 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1424 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1425 | "dev": true, 1426 | "requires": { 1427 | "ansi-regex": "^5.0.1" 1428 | } 1429 | } 1430 | } 1431 | }, 1432 | "wrappy": { 1433 | "version": "1.0.2", 1434 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1435 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1436 | "dev": true 1437 | }, 1438 | "y18n": { 1439 | "version": "5.0.8", 1440 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1441 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1442 | "dev": true 1443 | }, 1444 | "yallist": { 1445 | "version": "4.0.0", 1446 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1447 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1448 | "dev": true 1449 | }, 1450 | "yargs": { 1451 | "version": "16.2.0", 1452 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 1453 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 1454 | "dev": true, 1455 | "requires": { 1456 | "cliui": "^7.0.2", 1457 | "escalade": "^3.1.1", 1458 | "get-caller-file": "^2.0.5", 1459 | "require-directory": "^2.1.1", 1460 | "string-width": "^4.2.0", 1461 | "y18n": "^5.0.5", 1462 | "yargs-parser": "^20.2.2" 1463 | }, 1464 | "dependencies": { 1465 | "ansi-regex": { 1466 | "version": "5.0.1", 1467 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1468 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1469 | "dev": true 1470 | }, 1471 | "emoji-regex": { 1472 | "version": "8.0.0", 1473 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1474 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1475 | "dev": true 1476 | }, 1477 | "is-fullwidth-code-point": { 1478 | "version": "3.0.0", 1479 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1480 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1481 | "dev": true 1482 | }, 1483 | "string-width": { 1484 | "version": "4.2.3", 1485 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1486 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1487 | "dev": true, 1488 | "requires": { 1489 | "emoji-regex": "^8.0.0", 1490 | "is-fullwidth-code-point": "^3.0.0", 1491 | "strip-ansi": "^6.0.1" 1492 | } 1493 | }, 1494 | "strip-ansi": { 1495 | "version": "6.0.1", 1496 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1497 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1498 | "dev": true, 1499 | "requires": { 1500 | "ansi-regex": "^5.0.1" 1501 | } 1502 | } 1503 | } 1504 | }, 1505 | "yargs-parser": { 1506 | "version": "20.2.4", 1507 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 1508 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 1509 | "dev": true 1510 | }, 1511 | "yargs-unparser": { 1512 | "version": "2.0.0", 1513 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 1514 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 1515 | "dev": true, 1516 | "requires": { 1517 | "camelcase": "^6.0.0", 1518 | "decamelize": "^4.0.0", 1519 | "flat": "^5.0.2", 1520 | "is-plain-obj": "^2.1.0" 1521 | } 1522 | }, 1523 | "yocto-queue": { 1524 | "version": "0.1.0", 1525 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1526 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1527 | "dev": true 1528 | } 1529 | } 1530 | } 1531 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "eslint-plugin-redux-saga", 3 | "version": "1.3.2", 4 | "description": "redux-saga eslint rules", 5 | "author": "Philipp Kursawe = 6.7.0", 36 | "redux-saga": ">= 0.11.1 < 1 || >= 1.0.0" 37 | }, 38 | "devDependencies": { 39 | "eslint": "8.4.1", 40 | "mocha": "9.1.3", 41 | "redux-saga": ">= 0.11.1 < 1 || >= 1.0.0" 42 | }, 43 | "keywords": [ 44 | "eslint", 45 | "eslint-plugin", 46 | "eslintplugin", 47 | "redux-saga" 48 | ], 49 | "license": "MIT", 50 | "dependencies": {} 51 | } 52 | -------------------------------------------------------------------------------- /test/.vscode/launch.json: -------------------------------------------------------------------------------- 1 | { 2 | "version": "0.2.0", 3 | "configurations": [ 4 | { 5 | "name": "Launch", 6 | "type": "node", 7 | "request": "launch", 8 | "program": "${workspaceRoot}/best-before.js", 9 | "stopOnEntry": false, 10 | "args": [], 11 | "cwd": "${workspaceRoot}", 12 | "runtimeExecutable": null, 13 | "runtimeArgs": [ 14 | "--nolazy" 15 | ], 16 | "env": { 17 | "NODE_ENV": "development" 18 | }, 19 | "externalConsole": false, 20 | "sourceMaps": false, 21 | "outDir": null 22 | }, 23 | { 24 | "name": "Attach", 25 | "type": "node", 26 | "request": "attach", 27 | "port": 5858, 28 | "sourceMaps": false, 29 | "outDir": null, 30 | "localRoot": "${workspaceRoot}", 31 | "remoteRoot": null 32 | } 33 | ] 34 | } -------------------------------------------------------------------------------- /test/index.js: -------------------------------------------------------------------------------- 1 | "use strict" 2 | 3 | var RuleTester = require("eslint").RuleTester 4 | var parserOptions = require("./parserOptions") 5 | 6 | RuleTester.setDefaultConfig({ 7 | parserOptions: parserOptions 8 | }) 9 | -------------------------------------------------------------------------------- /test/lib/rules/no-unhandled-errors-spec.js: -------------------------------------------------------------------------------- 1 | "use strict" 2 | var rule = require("../../../lib/rules/no-unhandled-errors") 3 | var RuleTester = require("eslint").RuleTester 4 | 5 | var ruleTester = new RuleTester() 6 | 7 | function buildTest(imports, code) { 8 | var result = (imports && (imports + ";")) || "" 9 | result += "function* test() { " + code + " }" 10 | return result 11 | } 12 | 13 | ruleTester.run("no-unhandled-errors", rule, { 14 | valid: [ 15 | { 16 | code: buildTest( 17 | "import { take } from 'redux-saga'", 18 | "try { yield take('ACTION') } catch (e) { errorHandler(e) }" 19 | ) 20 | }, 21 | { 22 | code: buildTest( 23 | "import { take as t } from 'redux-saga'", 24 | "try { yield t('ACTION') } catch (e) { errorHandler(e) }" 25 | ) 26 | }, 27 | { 28 | code: buildTest( 29 | "import { take } from 'redux-saga/effects'", 30 | "try { yield take('ACTION') } catch (e) { errorHandler(e) }" 31 | ) 32 | }, 33 | { 34 | code: buildTest(null, "try { yield take('ACTION') } catch (e) { errorHandler(e) }") 35 | }, 36 | { 37 | code: buildTest("import { take } from 'redux-saga'", "notAnEffectDoesNotNeedYield()") 38 | }, 39 | { 40 | code: "import createSagaMiddleware from 'redux-saga'; const sagaMiddleware = createSagaMiddleware();" 41 | }, 42 | { 43 | code: buildTest("import { noop } from 'redux-saga'", "noop()") 44 | }, 45 | { 46 | code: buildTest( 47 | "import { call } from 'redux-saga'", 48 | "try { yield call('ACTION') } catch (e) { errorHandler(e) }" 49 | ) 50 | }, 51 | { 52 | code: buildTest( 53 | "import { call } from 'redux-saga'", 54 | "try { someStuff() } catch (e) { yield call('ACTION') }" 55 | ) 56 | }, 57 | { 58 | code: buildTest( 59 | "import { call, fork } from 'redux-saga/effects'", 60 | "yield fork(function*(){})" 61 | ) 62 | }, 63 | { 64 | code: buildTest( 65 | "import { takeEvery, takeLatest, takeLeading, throttle } from 'redux-saga'", 66 | "yield takeEvery('ACTION', function*(){});" + 67 | "yield takeLatest('ACTION', function*(){});" + 68 | "yield takeLeading('ACTION', function*(){});" + 69 | "yield throttle('ACTION', function*(){})" 70 | ) 71 | } 72 | ], 73 | invalid: [ 74 | { 75 | code: buildTest("import { call } from 'redux-saga'", "yield call('ACTION')"), 76 | errors: [{message: "A Saga must handle its effects' errors (use try/catch)"}] 77 | }, 78 | { 79 | code: buildTest("import { put as p } from 'redux-saga'", "yield p('ACTION')"), 80 | errors: [{message: "A Saga must handle its effects' errors (use try/catch)"}] 81 | }, 82 | { 83 | code: buildTest( 84 | "import { call } from 'redux-saga'", 85 | "try { yield call('ACTION') } catch (e) { errorHandler(e) } yield call('ACTION')" 86 | ), 87 | errors: [{message: "A Saga must handle its effects' errors (use try/catch)"}] 88 | } 89 | ] 90 | }) 91 | -------------------------------------------------------------------------------- /test/lib/rules/no-yield-in-race-spec.js: -------------------------------------------------------------------------------- 1 | "use strict" 2 | var rule = require("../../../lib/rules/no-yield-in-race") 3 | var RuleTester = require("eslint").RuleTester 4 | 5 | var ruleTester = new RuleTester() 6 | 7 | ruleTester.run("no-yield-in-race", rule, { 8 | valid: [ 9 | { 10 | code: "function* test() { yield race({ posts: call(fetchApis) }) }" 11 | }, 12 | { 13 | code: "function* test() { yield race({ watchers: [call(watcher1), call(watcher2)] }) }" 14 | }, 15 | { 16 | code: "function* test() { yield race([ call(watcher1), call(watcher2) ]) }" 17 | }, 18 | { 19 | code: "function* foo() { const actions = ['LOGIN', 'LOGOUT']; yield race(actions.map(take)) }" 20 | } 21 | ], 22 | invalid: [ 23 | { 24 | code: "function* test() { yield race({}, {}) }", 25 | errors: [{message: "race must have on object hash or array as the only argument"}] 26 | }, 27 | { 28 | code: "function* test() { yield race(call(fetch1), call(fetch2)) }", 29 | errors: [{message: "race must have on object hash or array as the only argument"}] 30 | }, 31 | { 32 | code: "function* test() { yield race({ posts: yield call(fetchApis) }) }", 33 | output: "function* test() { yield race({ posts: call(fetchApis) }) }", 34 | errors: [{message: "yield not allowed inside race: posts"}] 35 | }, 36 | { 37 | code: "function* test() { yield race({ watchers: yield [call(watcher1), call(watcher2)] }) }", 38 | output: "function* test() { yield race({ watchers: [call(watcher1), call(watcher2)] }) }", 39 | errors: [{message: "yield not allowed inside race: watchers"}] 40 | }, 41 | { 42 | code: "function* test() { yield race([yield call(watcher1), call(watcher2)]) }", 43 | output: "function* test() { yield race([call(watcher1), call(watcher2)]) }", 44 | errors: [{message: "yield not allowed inside race array at index: 0"}] 45 | }, 46 | { 47 | code: "function* foo() { const actions = ['LOGIN', 'LOGOUT']; yield race(yield actions.map(take)) }", 48 | output: "function* foo() { const actions = ['LOGIN', 'LOGOUT']; yield race(actions.map(take)) }", 49 | errors: [{message: "yield not allowed inside race"}] 50 | }, 51 | { 52 | code: "function* foo() { const actions = ['LOGIN', 'LOGOUT']; yield race(actions.every(take)) }", 53 | errors: [{message: "race must have Array.map as the only argument"}] 54 | } 55 | ] 56 | }) 57 | 58 | -------------------------------------------------------------------------------- /test/lib/rules/yield-effects-spec.js: -------------------------------------------------------------------------------- 1 | "use strict" 2 | var rule = require("../../../lib/rules/yield-effects") 3 | var RuleTester = require("eslint").RuleTester 4 | 5 | var ruleTester = new RuleTester() 6 | 7 | function buildTest(imports, code) { 8 | var result = (imports && (imports + ";")) || "" 9 | result += "function* test() { " + code + " }" 10 | return result 11 | } 12 | 13 | ruleTester.run("yield-effects", rule, { 14 | valid: [ 15 | { 16 | code: buildTest("import { take } from 'redux-saga'", "yield take('ACTION')") 17 | }, 18 | { 19 | code: buildTest("import { delay } from 'redux-saga'", "yield delay(1000)") 20 | }, 21 | { 22 | code: buildTest("import { take } from 'redux-saga/effects'", "yield take('ACTION')") 23 | }, 24 | { 25 | code: buildTest("import { take as t } from 'redux-saga'", "yield t('ACTION')") 26 | }, 27 | { 28 | code: buildTest("import { delay as d } from 'redux-saga'", "yield d(1000)") 29 | }, 30 | { 31 | // If it is an effect name but not imported from `redux-saga` then its valid 32 | code: buildTest(null, "take('ACTION')") 33 | }, 34 | { 35 | // If it is an effect name but not imported from `redux-saga` then its valid 36 | code: buildTest(null, "delay(1000)") 37 | }, 38 | { 39 | code: buildTest("import { take } from 'redux-saga'", "notAnEffectDoesNotNeedYield()") 40 | }, 41 | { 42 | code: "import createSagaMiddleware from 'redux-saga'; const sagaMiddleware = createSagaMiddleware();" 43 | }, 44 | { 45 | code: buildTest("import { noop } from 'redux-saga'", "noop()") 46 | }, 47 | { 48 | code: buildTest( 49 | "import { call } from 'redux-saga'", 50 | "const [foo, bar] = yield [call(something), call(somethingElse)]" 51 | ) 52 | }, 53 | { 54 | code: 55 | "import { put } from 'redux-saga';\n" + 56 | "expect(generator.next().value).toEqual(put({}));" 57 | }, 58 | { 59 | code: buildTest( 60 | "import { call, all, delay, fetchResources } from 'redux-saga'", 61 | "yield all([" + 62 | "call(fetchResource, 'users')," + 63 | "call(fetchResource, 'comments')," + 64 | "call(delay, 1000)" + 65 | "])" 66 | ) 67 | }, 68 | { 69 | code: 70 | "import { takeEvery } from 'redux-saga';\n" + 71 | "export const fooSagas = [" + 72 | "takeEvery('FOO_A', fooASaga)," + 73 | "takeEvery('FOO_B', fooBSaga)];" 74 | }, 75 | { 76 | code: 77 | "import { call } from 'redux-saga';\n" + 78 | "export class FooSaga {" + 79 | "static* someSaga() {" + 80 | " yield call(() => {})" + 81 | "}" + 82 | "}" 83 | } 84 | ], 85 | invalid: [ 86 | { 87 | code: buildTest("import { take } from 'redux-saga'", "take('ACTION')"), 88 | errors: [{ 89 | message: "take effect must be yielded", 90 | suggestions: [ 91 | { 92 | desc: "Add yield", 93 | output: buildTest("import { take } from 'redux-saga'", "yield take('ACTION')") 94 | } 95 | ] 96 | }] 97 | }, 98 | { 99 | code: buildTest("import { delay } from 'redux-saga'", "delay('ACTION')"), 100 | errors: [{ 101 | message: "delay effect must be yielded", 102 | suggestions: [ 103 | { 104 | desc: "Add yield", 105 | output: buildTest("import { delay } from 'redux-saga'", "yield delay('ACTION')") 106 | } 107 | ] 108 | }] 109 | }, 110 | { 111 | code: buildTest("import { take as t } from 'redux-saga'", "t('ACTION')"), 112 | errors: [{ 113 | message: "t (take) effect must be yielded", 114 | suggestions: [ 115 | { 116 | desc: "Add yield", 117 | output: buildTest("import { take as t } from 'redux-saga'", "yield t('ACTION')") 118 | } 119 | ] 120 | }] 121 | }, 122 | { 123 | code: buildTest("import { delay as d } from 'redux-saga'", "d('ACTION')"), 124 | errors: [{ 125 | message: "d (delay) effect must be yielded", 126 | suggestions: [ 127 | { 128 | desc: "Add yield", 129 | output: buildTest("import { delay as d } from 'redux-saga'", "yield d('ACTION')") 130 | } 131 | ] 132 | }] 133 | }, 134 | { 135 | code: 136 | "import { call } from 'redux-saga';\n" + 137 | "export class FooSaga {" + 138 | "static* someSaga() {" + 139 | " call(() => {})" + 140 | "}" + 141 | "}", 142 | errors: [{ 143 | message: "call effect must be yielded", 144 | suggestions: [ 145 | { 146 | desc: "Add yield", 147 | output: 148 | "import { call } from 'redux-saga';\n" + 149 | "export class FooSaga {" + 150 | "static* someSaga() {" + 151 | " yield call(() => {})" + 152 | "}" + 153 | "}" 154 | } 155 | ] 156 | }] 157 | } 158 | ] 159 | }) 160 | -------------------------------------------------------------------------------- /test/parserOptions.js: -------------------------------------------------------------------------------- 1 | "use strict" 2 | 3 | module.exports = { 4 | ecmaVersion: 6, 5 | sourceType: "module" 6 | } 7 | --------------------------------------------------------------------------------