├── .eslintrc.js ├── .gitignore ├── .husky ├── .gitignore └── pre-commit ├── .huskyrc ├── .npmignore ├── LICENSE ├── README.md ├── index.d.ts ├── index.js ├── package-lock.json ├── package.json └── tests ├── basic.test.js ├── header.test.js ├── test-auto-parse.csv ├── test-header-after-preamble.csv ├── test-header.csv └── test-quoted.csv /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | es6: true, 4 | browser: false, 5 | node: true, 6 | }, 7 | parserOptions: { 8 | ecmaVersion: 2018, 9 | sourceType: "module", 10 | }, 11 | globals: { 12 | "__base": true, 13 | }, 14 | extends: ["eslint:recommended"], 15 | rules: { 16 | "semi": ["warn", "always"], // Require (but only warn). In some cases this could actually prevent bugs. 17 | "comma-dangle": ["warn", "always-multiline"], 18 | "no-var": ["warn"], 19 | "arrow-spacing": ["warn", { "before": true, "after": true }], 20 | "space-infix-ops": ["warn", { "int32Hint": true }], 21 | "keyword-spacing": ["warn", { "before": true, "after": true }], 22 | "space-unary-ops": [ 23 | "warn", 24 | { 25 | "words": true, 26 | "nonwords": false, 27 | }, 28 | ], 29 | "comma-spacing": ["warn", { "before": false, "after": true }], 30 | "object-curly-spacing": ["warn", "always"], 31 | //"arrow-parens": ["warn", "as-needed"], 32 | "no-unused-vars": ["warn", { 33 | "vars": "all", 34 | "args": "after-used", 35 | "varsIgnorePattern": "[iIgnored]|^_", // except variables declared as "ignored" or prefixed with "_" 36 | "ignoreRestSiblings": false, 37 | "argsIgnorePattern": "^_", // except arguments explicitly prefixed with a _ prefix, 38 | "caughtErrors": "all", 39 | "caughtErrorsIgnorePattern": "^ignore", // if an error object should be ignored, call it "ignore/d" 40 | }], 41 | "no-console": "warn", // Could indicate leftovers in code. Error by default, set to warn. 42 | "no-extra-semi": "warn", // A styling issue. Error by default, set to warn. 43 | "no-unreachable": "warn", // In most cases it's a `break` after a `return`, but could point to a bug 44 | "no-fallthrough": ["error", { "commentPattern": "break[\\s\\w]*omitted|fallthrough" }], 45 | "no-useless-escape": "warn", // Could point out a bug in the regex due to typo or misunderstancing 46 | "no-constant-condition": "warn", // might be used in `while (true)`, but could indicate a bug in other cases 47 | }, 48 | 49 | overrides: [ 50 | { 51 | files: [ 52 | "src/browser_adapter.js", 53 | ], 54 | env: { 55 | es6: true, 56 | browser: true, 57 | node: true, 58 | }, 59 | }, 60 | { 61 | files: [ 62 | "tests/**/*tests.js", 63 | "tests/**/*.test.js", 64 | ], 65 | env: { 66 | es6: true, 67 | browser: false, 68 | node: true, 69 | mocha: true, 70 | jest: true, 71 | }, 72 | rules: { 73 | "no-console": "off", 74 | }, 75 | }, 76 | ], 77 | }; 78 | -------------------------------------------------------------------------------- /.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 | # https://docs.npmjs.com/misc/faq#should-i-check-my-node-modules-folder-into-git 28 | node_modules 29 | 30 | # Optional npm cache directory 31 | .npm 32 | 33 | # Optional REPL history 34 | .node_repl_history 35 | 36 | # Webstorm 37 | .idea 38 | -------------------------------------------------------------------------------- /.husky/.gitignore: -------------------------------------------------------------------------------- 1 | _ 2 | -------------------------------------------------------------------------------- /.husky/pre-commit: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | . "$(dirname "$0")/_/husky.sh" 3 | 4 | npm run lint -------------------------------------------------------------------------------- /.huskyrc: -------------------------------------------------------------------------------- 1 | # .huskyrc 2 | "hooks": 3 | "pre-commit": "npm run lint" 4 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | .idea 2 | scripts/ 3 | tests/ 4 | .eslintignore 5 | .eslintrc.js 6 | .huskyrc 7 | .mocharc.yml 8 | .npmignore 9 | .husky/ 10 | example/ 11 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2016 Daniel Cohen Gindi 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 | # csv-reader 2 | 3 | [![npm Version](https://badge.fury.io/js/csv-reader.png)](https://npmjs.org/package/csv-reader) 4 | 5 | A CSV stream reader, with many many features, and ability to work with the largest datasets 6 | 7 | ## Included features: (can be turned on and off) 8 | 9 | * Support for excel-style multiline cells wrapped in quotes 10 | * Choosing a different delimiter instead of the comma 11 | * Automatic skipping empty lines 12 | * Automatic skipping of the first header row 13 | * Automatic parsing of numbers and booleans 14 | * Automatic trimming 15 | * Being a stream transformer, you can `.pause()` if you need some time to process the row and `.resume()` when you are ready to receive and process more rows. 16 | * Consumes and emits rows one-by-one, allowing you to process datasets in any size imaginable. 17 | * Automatically strips the BOM if exists (not handled automatically by node.js stream readers) 18 | 19 | ## Installation: 20 | 21 | ``` 22 | npm install --save csv-reader 23 | ``` 24 | 25 | The options you can pass are: 26 | 27 | Name | Type | Default | Explanation 28 | ---- |-----------|---------| ----------- 29 | `delimiter` | `String` | `,` | The character that separates between cells 30 | `multiline` | `Boolean` | `true` | Allow multiline cells, when the cell is wrapped with quotes ("...\n...") 31 | `allowQuotes` | `Boolean` | `true` | Should quotes be treated as a special character that wraps cells etc. 32 | `skipEmptyLines` | `Boolean` | `false` | Should empty lines be automatically skipped? 33 | ~~`skipHeader`~~ | `Boolean` | `false` | Should the first header row be skipped? (*Deprecated*, please use `skipLines`) 34 | `skipLines` | `Number` | `0` | Number of lines to skip (if `skipHeader` is `true`, then this gets +1) (after the header line if `headerLine` is set) 35 | `headerLine` | `Number` | `0` | Line number of the header (`skipLines` will be lines skipped after the header line) 36 | `asObject` | `Boolean` | `false` | If true, each row will be converted automatically to an object based on the header. This adds `1` to `skipLines`. 37 | `parseNumbers` | `Boolean` | `false` | Should numbers be automatically parsed? This will parse any format supported by `parseFloat` including scientific notation, `Infinity` and `NaN`. 38 | `parseBooleans` | `Boolean` | `false` | Automatically parse booleans (strictly lowercase `true` and `false`) 39 | `ltrim` | `Boolean` | `false` | Automatically left-trims columns 40 | `rtrim` | `Boolean` | `false` | Automatically right-trims columns 41 | `trim` | `Boolean` | `false` | If true, then both 'ltrim' and 'rtrim' are set to true 42 | 43 | ## Events: 44 | 45 | A `'data'` event will be emitted with each row, either in an array format (`(string|number|boolean)[]`) or an Object format (`Object`), depending on the `asObject` option. 46 | A preliminary `'header'` event will be emitted with the first row, only in an array format, and without any interpolation to different types (`string[]`). 47 | Of course other events as usual - `end` and `error`. 48 | 49 | ## Usage example: 50 | 51 | ```javascript 52 | 53 | const Fs = require('fs'); 54 | const CsvReadableStream = require('csv-reader'); 55 | 56 | let inputStream = Fs.createReadStream('my_data.csv', 'utf8'); 57 | 58 | inputStream 59 | .pipe(new CsvReadableStream({ parseNumbers: true, parseBooleans: true, trim: true })) 60 | .on('data', function (row) { 61 | console.log('A row arrived: ', row); 62 | }) 63 | .on('end', function () { 64 | console.log('No more rows!'); 65 | }); 66 | 67 | ``` 68 | 69 | A common issue with CSVs are that Microsoft Excel for some reason *does not save UTF8 files*. Microsoft never liked standards. 70 | In order to automagically handle the possibility of such files with ANSI encodings arriving from user input, you can use the [autodetect-decoder-stream](https://www.npmjs.com/package/autodetect-decoder-stream) like this: 71 | 72 | ```javascript 73 | 74 | const Fs = require('fs'); 75 | const CsvReadableStream = require('csv-reader'); 76 | const AutoDetectDecoderStream = require('autodetect-decoder-stream'); 77 | 78 | let inputStream = Fs.createReadStream('my_data.csv') 79 | .pipe(new AutoDetectDecoderStream({ defaultEncoding: '1255' })); // If failed to guess encoding, default to 1255 80 | 81 | // The AutoDetectDecoderStream will know if the stream is UTF8, windows-1255, windows-1252 etc. 82 | // It will pass a properly decoded data to the CsvReader. 83 | 84 | inputStream 85 | .pipe(new CsvReadableStream({ parseNumbers: true, parseBooleans: true, trim: true })) 86 | .on('data', function (row) { 87 | console.log('A row arrived: ', row); 88 | }).on('end', function () { 89 | console.log('No more rows!'); 90 | }); 91 | 92 | ``` 93 | 94 | ## Contributing 95 | 96 | If you have anything to contribute, or functionality that you lack - you are more than welcome to participate in this! 97 | If anyone wishes to contribute unit tests - that also would be great :-) 98 | 99 | ## Me 100 | * Hi! I am Daniel Cohen Gindi. Or in short- Daniel. 101 | * danielgindi@gmail.com is my email address. 102 | * That's all you need to know. 103 | 104 | ## Help 105 | 106 | If you want to buy me a beer, you are very welcome to 107 | [![Donate](https://www.paypalobjects.com/en_US/i/btn/btn_donate_LG.gif)](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=G6CELS3E997ZE) 108 | Thanks :-) 109 | 110 | ## License 111 | 112 | All the code here is under MIT license. Which means you could do virtually anything with the code. 113 | I will appreciate it very much if you keep an attribution where appropriate. 114 | 115 | The MIT License (MIT) 116 | 117 | Copyright (c) 2013 Daniel Cohen Gindi (danielgindi@gmail.com) 118 | 119 | Permission is hereby granted, free of charge, to any person obtaining a copy 120 | of this software and associated documentation files (the "Software"), to deal 121 | in the Software without restriction, including without limitation the rights 122 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 123 | copies of the Software, and to permit persons to whom the Software is 124 | furnished to do so, subject to the following conditions: 125 | 126 | The above copyright notice and this permission notice shall be included in all 127 | copies or substantial portions of the Software. 128 | -------------------------------------------------------------------------------- /index.d.ts: -------------------------------------------------------------------------------- 1 | /// 2 | 3 | import { Transform, Readable } from "stream"; 4 | 5 | export declare type Options = { 6 | /** 7 | * Specify what is the CSV delimiter 8 | * @default "," 9 | */ 10 | delimiter?: string; 11 | 12 | /** 13 | * Support Excel-like multiline CSV 14 | * @default true 15 | */ 16 | multiline?: boolean; 17 | 18 | /** 19 | * Allow quotation marks to wrap columns 20 | * @default true 21 | */ 22 | allowQuotes?: boolean; 23 | 24 | /** 25 | * Should empty lines be automatically skipped? 26 | * @default false 27 | */ 28 | skipEmptyLines?: boolean; 29 | 30 | /** 31 | * Automatically parse numbers (with a . as the decimal separator) 32 | * @default false 33 | */ 34 | parseNumbers?: boolean; 35 | 36 | /** 37 | * Automatically parse booleans (strictly lowercase `true` and `false`) 38 | * @default false 39 | */ 40 | parseBooleans?: boolean; 41 | 42 | /** 43 | * Automatically left-trims columns 44 | * @default false 45 | */ 46 | ltrim?: boolean; 47 | 48 | /** 49 | * Automatically right-trims columns 50 | * @default false 51 | */ 52 | rtrim?: boolean; 53 | 54 | /** 55 | * If true, then both 'ltrim' and 'rtrim' are set to true 56 | * @default false 57 | */ 58 | trim?: boolean; 59 | 60 | /** 61 | * If true, then skip the first header row 62 | * @default false 63 | * @deprecated please use `skipLines` 64 | */ 65 | skipHeader?: boolean; 66 | 67 | /** 68 | * Number of lines to skip (if `skipHeader` is `true`, then this gets +1) 69 | * (after the header line if `headerLine` is set) 70 | * @default 0 71 | */ 72 | skipLines?: number; 73 | 74 | /** 75 | * If true, each row will be converted automatically to an object based on the header. 76 | * This adds `1` to `skipLines`. 77 | * @default false 78 | */ 79 | asObject?: boolean; 80 | 81 | /** 82 | * Line number of the header (skipLines will be lines skipped after the header line) 83 | * @default 0 84 | */ 85 | headerLine?: number; 86 | }; 87 | 88 | export declare type DataTypes = string | number | boolean; 89 | 90 | export declare type Line = DataTypes[] | { [header: string]: DataTypes }; 91 | 92 | declare interface CsvReadableStream extends Transform { 93 | /** 94 | * Create a new readable stream that parses CSV data into events, line by line 95 | * @constructor 96 | */ 97 | new(options?: Options): this; 98 | 99 | /** 100 | * Create a new readable stream that parses CSV data into events, line by line 101 | */ 102 | (options?: Options): this; 103 | 104 | addListener(event: "close", listener: () => void): this; 105 | addListener(event: "data", listener: (line: Line) => void): this; 106 | addListener(event: "header", listener: (headers: string[]) => void): this; 107 | addListener(event: "end", listener: () => void): this; 108 | addListener(event: "readable", listener: () => void): this; 109 | addListener(event: "drain", listener: () => void): this; 110 | addListener(event: "error", listener: (err: Error) => void): this; 111 | addListener(event: "finish", listener: () => void): this; 112 | addListener(event: "pipe", listener: (src: Readable) => void): this; 113 | addListener(event: "unpipe", listener: (src: Readable) => void): this; 114 | addListener(event: string | symbol, listener: (...args: any[]) => void): this; 115 | 116 | on(event: "close", listener: () => void): this; 117 | on(event: "data", listener: (line: Line) => void): this; 118 | on(event: "header", listener: (headers: string[]) => void): this; 119 | on(event: "end", listener: () => void): this; 120 | on(event: "readable", listener: () => void): this; 121 | on(event: "drain", listener: () => void): this; 122 | on(event: "error", listener: (err: Error) => void): this; 123 | on(event: "finish", listener: () => void): this; 124 | on(event: "pipe", listener: (src: Readable) => void): this; 125 | on(event: "unpipe", listener: (src: Readable) => void): this; 126 | on(event: string | symbol, listener: (...args: any[]) => void): this; 127 | 128 | once(event: "close", listener: () => void): this; 129 | once(event: "data", listener: (line: Line) => void): this; 130 | once(event: "header", listener: (headers: string[]) => void): this; 131 | once(event: "end", listener: () => void): this; 132 | once(event: "readable", listener: () => void): this; 133 | once(event: "drain", listener: () => void): this; 134 | once(event: "error", listener: (err: Error) => void): this; 135 | once(event: "finish", listener: () => void): this; 136 | once(event: "pipe", listener: (src: Readable) => void): this; 137 | once(event: "unpipe", listener: (src: Readable) => void): this; 138 | once(event: string | symbol, listener: (...args: any[]) => void): this; 139 | 140 | prependListener(event: "close", listener: () => void): this; 141 | prependListener(event: "data", listener: (line: Line) => void): this; 142 | prependListener(event: "header", listener: (headers: string[]) => void): this; 143 | prependListener(event: "end", listener: () => void): this; 144 | prependListener(event: "readable", listener: () => void): this; 145 | prependListener(event: "drain", listener: () => void): this; 146 | prependListener(event: "error", listener: (err: Error) => void): this; 147 | prependListener(event: "finish", listener: () => void): this; 148 | prependListener(event: "pipe", listener: (src: Readable) => void): this; 149 | prependListener(event: "unpipe", listener: (src: Readable) => void): this; 150 | prependListener( 151 | event: string | symbol, 152 | listener: (...args: any[]) => void 153 | ): this; 154 | 155 | prependOnceListener(event: "close", listener: () => void): this; 156 | prependOnceListener(event: "data", listener: (line: Line) => void): this; 157 | prependOnceListener( 158 | event: "header", 159 | listener: (headers: string[]) => void 160 | ): this; 161 | prependOnceListener(event: "end", listener: () => void): this; 162 | prependOnceListener(event: "readable", listener: () => void): this; 163 | prependOnceListener(event: "drain", listener: () => void): this; 164 | prependOnceListener(event: "error", listener: (err: Error) => void): this; 165 | prependOnceListener(event: "finish", listener: () => void): this; 166 | prependOnceListener(event: "pipe", listener: (src: Readable) => void): this; 167 | prependOnceListener(event: "unpipe", listener: (src: Readable) => void): this; 168 | prependOnceListener( 169 | event: string | symbol, 170 | listener: (...args: any[]) => void 171 | ): this; 172 | 173 | removeListener(event: "close", listener: () => void): this; 174 | removeListener(event: "data", listener: (line: Line) => void): this; 175 | removeListener(event: "header", listener: (headers: string[]) => void): this; 176 | removeListener(event: "end", listener: () => void): this; 177 | removeListener(event: "readable", listener: () => void): this; 178 | removeListener(event: "drain", listener: () => void): this; 179 | removeListener(event: "error", listener: (err: Error) => void): this; 180 | removeListener(event: "finish", listener: () => void): this; 181 | removeListener(event: "pipe", listener: (src: Readable) => void): this; 182 | removeListener(event: "unpipe", listener: (src: Readable) => void): this; 183 | removeListener( 184 | event: string | symbol, 185 | listener: (...args: any[]) => void 186 | ): this; 187 | } 188 | 189 | declare const CsvReadableStream: CsvReadableStream; 190 | 191 | export default CsvReadableStream; 192 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | const Stream = require('stream'); 2 | const Util = require('util'); 3 | 4 | /** 5 | * @const 6 | * @type {RegExp} 7 | */ 8 | const PARSE_FLOAT_TEST = /^[-+]?\d+(?:\.\d*)?(?:[eE]\+\d+)?$|^(?:\d+)?\.\d+(?:e+\d+)?$|^[-+]?Infinity$|^[-+]?NaN$/; 9 | 10 | const Transform = Stream.Transform; 11 | 12 | /** 13 | * @param {Object?} options 14 | * @param {string} [options.delimiter=','] - Specify what is the CSV delimeter 15 | * @param {boolean} [options.multiline=true] - Support Excel-like multiline CSV 16 | * @param {boolean} [options.allowQuotes=true] - Allow quotation marks to wrap columns 17 | * @param {boolean} [options.skipEmptyLines=false] - Should empty lines be automatically skipped? 18 | * @param {boolean} [options.parseNumbers=false] - Automatically parse numbers (with a . as the decimal separator) 19 | * @param {boolean} [options.parseBooleans=false] - Automatically parse booleans (strictly lowercase `true` and `false`) 20 | * @param {boolean} [options.ltrim=false] - Automatically left-trims columns 21 | * @param {boolean} [options.rtrim=false] - Automatically right-trims columns 22 | * @param {boolean} [options.trim=false] - If true, then both 'ltrim' and 'rtrim' are set to true 23 | * @param {boolean} [options.skipHeader=false] - If true, then skip the first header row [deprecated] 24 | * @param {boolean} [options.skipLines=0] - Number of lines to skip (if `skipHeader` is `true`, then this gets +1) 25 | * @param {boolean} [options.asObject=false] - If true, each row will be converted automatically to an object based 26 | * on the header. This adds `1` to `skipLines`. 27 | * @param {number} [options.headerLine=0] - Line number of the header (skipLines will be lines skipped after the header line) 28 | * @returns {CsvReadableStream} 29 | * @constructor 30 | */ 31 | const CsvReadableStream = function (options) { 32 | options = options || {}; 33 | 34 | //noinspection JSUndefinedPropertyAssignment 35 | options.objectMode = true; 36 | 37 | if (!(this instanceof CsvReadableStream)) { 38 | return new CsvReadableStream(options); 39 | } 40 | 41 | let data = null, 42 | dataIndex = null, 43 | nextIndex = null, 44 | dataLen = null, 45 | column = '', 46 | columnCount = 0, 47 | lastLineEndCR = false, 48 | lookForBOM = true, 49 | isQuoted = false, 50 | rowCount = 0; 51 | 52 | const multiline = !!options.multiline || typeof options.multiline === 'undefined', 53 | delimiter = options.delimiter != null ? options.delimiter.toString() || ',' : ',', 54 | allowQuotes = !!options.allowQuotes || typeof options.allowQuotes === 'undefined', 55 | skipEmptyLines = !!options.skipEmptyLines, 56 | parseNumbers = !!options.parseNumbers, 57 | parseBooleans = !!options.parseBooleans, 58 | ltrim = !!options.ltrim || !!options.trim, 59 | rtrim = !!options.rtrim || !!options.trim, 60 | trim = ltrim && rtrim, 61 | asObject = !!options.asObject, 62 | skipLines = options.headerLine ? options.headerLine + (options.skipLines || 0) : (options.skipLines || 0) + (options.skipHeader || asObject ? 1 : 0), 63 | headerLine = (options.headerLine - 1 || 0), 64 | 65 | postProcessingEnabled = parseNumbers || parseBooleans || ltrim || rtrim; 66 | 67 | let headerRow = []; 68 | 69 | /** @type {*[]|Object} */ 70 | let columns = asObject === true ? {} : []; 71 | 72 | const postProcessColumn = function (column) { 73 | 74 | if (trim) { 75 | column = column.trim(); 76 | } else if (ltrim) { 77 | column = column.replace(/^\s+/, ''); 78 | } else if (rtrim) { 79 | column = column.replace(/\s+$/, ''); 80 | } 81 | 82 | if (parseBooleans) { 83 | if (column === 'true') { 84 | return true; 85 | } 86 | if (column === 'false') { 87 | return false; 88 | } 89 | } 90 | 91 | if (parseNumbers) { 92 | if (PARSE_FLOAT_TEST.test(column)) { 93 | return parseFloat(column); 94 | } 95 | } 96 | 97 | return column; 98 | }; 99 | 100 | this._processChunk = function (newData) { 101 | 102 | if (newData) { 103 | if (data) { 104 | data = data.substring(dataIndex) + newData; 105 | } else { 106 | data = newData; 107 | } 108 | dataLen = data.length; 109 | dataIndex = 0; 110 | 111 | // Node doesn't strip BOMs, that's in user's land 112 | if (lookForBOM) { 113 | if (newData.charCodeAt(0) === 0xfeff) { 114 | dataIndex++; 115 | } 116 | lookForBOM = false; 117 | } 118 | } 119 | 120 | let isFinishedLine = false; 121 | 122 | const rowIndex = rowCount; 123 | 124 | for (; dataIndex < dataLen; dataIndex++) { 125 | const c = data[dataIndex]; 126 | 127 | if (c === '\n' || c === '\r') { 128 | if (!isQuoted || !multiline) { 129 | if (lastLineEndCR && c === '\n') { 130 | lastLineEndCR = false; 131 | continue; 132 | } 133 | lastLineEndCR = c === '\r'; 134 | dataIndex++; 135 | isFinishedLine = true; 136 | rowCount++; 137 | 138 | if (!multiline) { 139 | isQuoted = false; 140 | } 141 | 142 | break; 143 | } 144 | } 145 | 146 | if (isQuoted) { 147 | if (c === '"') { 148 | nextIndex = dataIndex + 1; 149 | 150 | // Do we have enough data to peek at the next character? 151 | if (nextIndex >= dataLen && !this._isStreamDone) { 152 | // Wait for more data to arrive 153 | break; 154 | } 155 | 156 | if (nextIndex < dataLen && data[nextIndex] === '"') { 157 | column += '"'; 158 | dataIndex++; 159 | } else { 160 | isQuoted = false; 161 | } 162 | } else { 163 | column += c; 164 | } 165 | } else { 166 | if (c === delimiter) { 167 | if (rowIndex === headerLine) { 168 | headerRow.push(column.trim()); 169 | } 170 | 171 | if (column.length > 0 && postProcessingEnabled === true) { 172 | column = postProcessColumn(column); 173 | } 174 | 175 | if (asObject === true) { 176 | columns[headerRow[columnCount]] = column; 177 | } else { 178 | columns.push(column); 179 | } 180 | 181 | column = ''; 182 | columnCount++; 183 | } else if (c === '"' && allowQuotes) { 184 | if (column.length) { 185 | column += c; 186 | } else { 187 | isQuoted = true; 188 | } 189 | } else { 190 | column += c; 191 | } 192 | } 193 | } 194 | 195 | if (dataIndex === dataLen) { 196 | data = null; 197 | } 198 | 199 | if (isFinishedLine || (data === null && this._isStreamDone === true)) { 200 | 201 | if (columnCount > 0 || 202 | column.length > 0 || 203 | data !== null || 204 | !this._isStreamDone) { 205 | 206 | const isEmptyRow = columnCount === 1 && column.length === 0; 207 | 208 | // Process last column 209 | if (rowIndex === headerLine) { 210 | headerRow.push(column.trim()); 211 | this.emit('header', headerRow); 212 | } 213 | 214 | if (column.length > 0 && postProcessingEnabled === true) { 215 | column = postProcessColumn(column); 216 | } 217 | 218 | if (asObject === true) { 219 | columns[headerRow[columnCount]] = column; 220 | } else { 221 | columns.push(column); 222 | } 223 | 224 | // Commit this row 225 | let row = columns; 226 | 227 | // Clear row state data 228 | columns = asObject === true ? {} : []; 229 | column = ''; 230 | columnCount = 0; 231 | isQuoted = false; 232 | 233 | if (rowIndex >= skipLines) { 234 | // Is this row full or empty? 235 | if (isEmptyRow === false || skipEmptyLines === false) { 236 | // Emit the parsed row 237 | //noinspection JSUnresolvedFunction 238 | this.push(row); 239 | } 240 | } 241 | 242 | // Look to see if there are more rows in available data 243 | this._processChunk(); 244 | 245 | } else { 246 | // We just ran into a newline at the end of the file, ignore it 247 | } 248 | 249 | } else { 250 | 251 | if (data) { 252 | 253 | // Let more data come in. 254 | // We are probably waiting for a "peek" at the next character 255 | 256 | } else { 257 | 258 | // We have probably hit end of file. 259 | // Let the end event come in. 260 | 261 | } 262 | 263 | } 264 | 265 | }; 266 | 267 | Transform.call(this, options); 268 | }; 269 | 270 | Util.inherits(CsvReadableStream, Transform); 271 | 272 | //noinspection JSUnusedGlobalSymbols 273 | CsvReadableStream.prototype._transform = function (chunk, enc, cb) { 274 | 275 | try { 276 | this._processChunk(chunk); 277 | 278 | cb(); 279 | } catch (err) { 280 | cb(err); 281 | } 282 | }; 283 | 284 | //noinspection JSUnusedGlobalSymbols 285 | CsvReadableStream.prototype._flush = function (cb) { 286 | 287 | try { 288 | this._isStreamDone = true; 289 | 290 | this._processChunk(); 291 | 292 | cb(); 293 | } catch (err) { 294 | cb(err); 295 | } 296 | 297 | }; 298 | 299 | /** 300 | * @module 301 | * @type {CsvReadableStream} 302 | */ 303 | module.exports = CsvReadableStream; 304 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "csv-reader", 3 | "version": "1.0.12", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "csv-reader", 9 | "version": "1.0.10", 10 | "license": "MIT", 11 | "devDependencies": { 12 | "eslint": "^8.29.0", 13 | "eslint-formatter-codeframe": "^7.32.1", 14 | "husky": "^8.0.2", 15 | "mocha": "^10.0.0", 16 | "pinst": "^3.0.0" 17 | }, 18 | "engines": { 19 | "node": ">=8.0.0" 20 | } 21 | }, 22 | "node_modules/@babel/code-frame": { 23 | "version": "7.12.11", 24 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 25 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 26 | "dev": true, 27 | "dependencies": { 28 | "@babel/highlight": "^7.10.4" 29 | } 30 | }, 31 | "node_modules/@babel/helper-validator-identifier": { 32 | "version": "7.19.1", 33 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", 34 | "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==", 35 | "dev": true, 36 | "engines": { 37 | "node": ">=6.9.0" 38 | } 39 | }, 40 | "node_modules/@babel/highlight": { 41 | "version": "7.18.6", 42 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", 43 | "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", 44 | "dev": true, 45 | "dependencies": { 46 | "@babel/helper-validator-identifier": "^7.18.6", 47 | "chalk": "^2.0.0", 48 | "js-tokens": "^4.0.0" 49 | }, 50 | "engines": { 51 | "node": ">=6.9.0" 52 | } 53 | }, 54 | "node_modules/@babel/highlight/node_modules/ansi-styles": { 55 | "version": "3.2.1", 56 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 57 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 58 | "dev": true, 59 | "dependencies": { 60 | "color-convert": "^1.9.0" 61 | }, 62 | "engines": { 63 | "node": ">=4" 64 | } 65 | }, 66 | "node_modules/@babel/highlight/node_modules/chalk": { 67 | "version": "2.4.2", 68 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 69 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 70 | "dev": true, 71 | "dependencies": { 72 | "ansi-styles": "^3.2.1", 73 | "escape-string-regexp": "^1.0.5", 74 | "supports-color": "^5.3.0" 75 | }, 76 | "engines": { 77 | "node": ">=4" 78 | } 79 | }, 80 | "node_modules/@babel/highlight/node_modules/color-convert": { 81 | "version": "1.9.3", 82 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 83 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 84 | "dev": true, 85 | "dependencies": { 86 | "color-name": "1.1.3" 87 | } 88 | }, 89 | "node_modules/@babel/highlight/node_modules/color-name": { 90 | "version": "1.1.3", 91 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 92 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 93 | "dev": true 94 | }, 95 | "node_modules/@babel/highlight/node_modules/escape-string-regexp": { 96 | "version": "1.0.5", 97 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 98 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 99 | "dev": true, 100 | "engines": { 101 | "node": ">=0.8.0" 102 | } 103 | }, 104 | "node_modules/@babel/highlight/node_modules/has-flag": { 105 | "version": "3.0.0", 106 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 107 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 108 | "dev": true, 109 | "engines": { 110 | "node": ">=4" 111 | } 112 | }, 113 | "node_modules/@babel/highlight/node_modules/supports-color": { 114 | "version": "5.5.0", 115 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 116 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 117 | "dev": true, 118 | "dependencies": { 119 | "has-flag": "^3.0.0" 120 | }, 121 | "engines": { 122 | "node": ">=4" 123 | } 124 | }, 125 | "node_modules/@eslint/eslintrc": { 126 | "version": "1.4.1", 127 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.4.1.tgz", 128 | "integrity": "sha512-XXrH9Uarn0stsyldqDYq8r++mROmWRI1xKMXa640Bb//SY1+ECYX6VzT6Lcx5frD0V30XieqJ0oX9I2Xj5aoMA==", 129 | "dev": true, 130 | "dependencies": { 131 | "ajv": "^6.12.4", 132 | "debug": "^4.3.2", 133 | "espree": "^9.4.0", 134 | "globals": "^13.19.0", 135 | "ignore": "^5.2.0", 136 | "import-fresh": "^3.2.1", 137 | "js-yaml": "^4.1.0", 138 | "minimatch": "^3.1.2", 139 | "strip-json-comments": "^3.1.1" 140 | }, 141 | "engines": { 142 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 143 | }, 144 | "funding": { 145 | "url": "https://opencollective.com/eslint" 146 | } 147 | }, 148 | "node_modules/@humanwhocodes/config-array": { 149 | "version": "0.11.8", 150 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.8.tgz", 151 | "integrity": "sha512-UybHIJzJnR5Qc/MsD9Kr+RpO2h+/P1GhOwdiLPXK5TWk5sgTdu88bTD9UP+CKbPPh5Rni1u0GjAdYQLemG8g+g==", 152 | "dev": true, 153 | "dependencies": { 154 | "@humanwhocodes/object-schema": "^1.2.1", 155 | "debug": "^4.1.1", 156 | "minimatch": "^3.0.5" 157 | }, 158 | "engines": { 159 | "node": ">=10.10.0" 160 | } 161 | }, 162 | "node_modules/@humanwhocodes/module-importer": { 163 | "version": "1.0.1", 164 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 165 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 166 | "dev": true, 167 | "engines": { 168 | "node": ">=12.22" 169 | }, 170 | "funding": { 171 | "type": "github", 172 | "url": "https://github.com/sponsors/nzakas" 173 | } 174 | }, 175 | "node_modules/@humanwhocodes/object-schema": { 176 | "version": "1.2.1", 177 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 178 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 179 | "dev": true 180 | }, 181 | "node_modules/@nodelib/fs.scandir": { 182 | "version": "2.1.5", 183 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 184 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 185 | "dev": true, 186 | "dependencies": { 187 | "@nodelib/fs.stat": "2.0.5", 188 | "run-parallel": "^1.1.9" 189 | }, 190 | "engines": { 191 | "node": ">= 8" 192 | } 193 | }, 194 | "node_modules/@nodelib/fs.stat": { 195 | "version": "2.0.5", 196 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 197 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 198 | "dev": true, 199 | "engines": { 200 | "node": ">= 8" 201 | } 202 | }, 203 | "node_modules/@nodelib/fs.walk": { 204 | "version": "1.2.8", 205 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 206 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 207 | "dev": true, 208 | "dependencies": { 209 | "@nodelib/fs.scandir": "2.1.5", 210 | "fastq": "^1.6.0" 211 | }, 212 | "engines": { 213 | "node": ">= 8" 214 | } 215 | }, 216 | "node_modules/acorn": { 217 | "version": "8.8.1", 218 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.1.tgz", 219 | "integrity": "sha512-7zFpHzhnqYKrkYdUjF1HI1bzd0VygEGX8lFk4k5zVMqHEoES+P+7TKI+EvLO9WVMJ8eekdO0aDEK044xTXwPPA==", 220 | "dev": true, 221 | "bin": { 222 | "acorn": "bin/acorn" 223 | }, 224 | "engines": { 225 | "node": ">=0.4.0" 226 | } 227 | }, 228 | "node_modules/acorn-jsx": { 229 | "version": "5.3.2", 230 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 231 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 232 | "dev": true, 233 | "peerDependencies": { 234 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 235 | } 236 | }, 237 | "node_modules/ajv": { 238 | "version": "6.12.6", 239 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 240 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 241 | "dev": true, 242 | "dependencies": { 243 | "fast-deep-equal": "^3.1.1", 244 | "fast-json-stable-stringify": "^2.0.0", 245 | "json-schema-traverse": "^0.4.1", 246 | "uri-js": "^4.2.2" 247 | }, 248 | "funding": { 249 | "type": "github", 250 | "url": "https://github.com/sponsors/epoberezkin" 251 | } 252 | }, 253 | "node_modules/ansi-colors": { 254 | "version": "4.1.1", 255 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 256 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 257 | "dev": true, 258 | "engines": { 259 | "node": ">=6" 260 | } 261 | }, 262 | "node_modules/ansi-regex": { 263 | "version": "5.0.1", 264 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 265 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 266 | "dev": true, 267 | "engines": { 268 | "node": ">=8" 269 | } 270 | }, 271 | "node_modules/ansi-styles": { 272 | "version": "4.3.0", 273 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 274 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 275 | "dev": true, 276 | "dependencies": { 277 | "color-convert": "^2.0.1" 278 | }, 279 | "engines": { 280 | "node": ">=8" 281 | }, 282 | "funding": { 283 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 284 | } 285 | }, 286 | "node_modules/anymatch": { 287 | "version": "3.1.3", 288 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 289 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 290 | "dev": true, 291 | "dependencies": { 292 | "normalize-path": "^3.0.0", 293 | "picomatch": "^2.0.4" 294 | }, 295 | "engines": { 296 | "node": ">= 8" 297 | } 298 | }, 299 | "node_modules/argparse": { 300 | "version": "2.0.1", 301 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 302 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 303 | "dev": true 304 | }, 305 | "node_modules/balanced-match": { 306 | "version": "1.0.2", 307 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 308 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 309 | "dev": true 310 | }, 311 | "node_modules/binary-extensions": { 312 | "version": "2.2.0", 313 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 314 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 315 | "dev": true, 316 | "engines": { 317 | "node": ">=8" 318 | } 319 | }, 320 | "node_modules/brace-expansion": { 321 | "version": "1.1.11", 322 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 323 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 324 | "dev": true, 325 | "dependencies": { 326 | "balanced-match": "^1.0.0", 327 | "concat-map": "0.0.1" 328 | } 329 | }, 330 | "node_modules/braces": { 331 | "version": "3.0.2", 332 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 333 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 334 | "dev": true, 335 | "dependencies": { 336 | "fill-range": "^7.0.1" 337 | }, 338 | "engines": { 339 | "node": ">=8" 340 | } 341 | }, 342 | "node_modules/browser-stdout": { 343 | "version": "1.3.1", 344 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 345 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 346 | "dev": true 347 | }, 348 | "node_modules/callsites": { 349 | "version": "3.1.0", 350 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 351 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 352 | "dev": true, 353 | "engines": { 354 | "node": ">=6" 355 | } 356 | }, 357 | "node_modules/camelcase": { 358 | "version": "6.3.0", 359 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 360 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 361 | "dev": true, 362 | "engines": { 363 | "node": ">=10" 364 | }, 365 | "funding": { 366 | "url": "https://github.com/sponsors/sindresorhus" 367 | } 368 | }, 369 | "node_modules/chalk": { 370 | "version": "4.1.2", 371 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 372 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 373 | "dev": true, 374 | "dependencies": { 375 | "ansi-styles": "^4.1.0", 376 | "supports-color": "^7.1.0" 377 | }, 378 | "engines": { 379 | "node": ">=10" 380 | }, 381 | "funding": { 382 | "url": "https://github.com/chalk/chalk?sponsor=1" 383 | } 384 | }, 385 | "node_modules/chokidar": { 386 | "version": "3.5.3", 387 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 388 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 389 | "dev": true, 390 | "funding": [ 391 | { 392 | "type": "individual", 393 | "url": "https://paulmillr.com/funding/" 394 | } 395 | ], 396 | "dependencies": { 397 | "anymatch": "~3.1.2", 398 | "braces": "~3.0.2", 399 | "glob-parent": "~5.1.2", 400 | "is-binary-path": "~2.1.0", 401 | "is-glob": "~4.0.1", 402 | "normalize-path": "~3.0.0", 403 | "readdirp": "~3.6.0" 404 | }, 405 | "engines": { 406 | "node": ">= 8.10.0" 407 | }, 408 | "optionalDependencies": { 409 | "fsevents": "~2.3.2" 410 | } 411 | }, 412 | "node_modules/chokidar/node_modules/glob-parent": { 413 | "version": "5.1.2", 414 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 415 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 416 | "dev": true, 417 | "dependencies": { 418 | "is-glob": "^4.0.1" 419 | }, 420 | "engines": { 421 | "node": ">= 6" 422 | } 423 | }, 424 | "node_modules/cliui": { 425 | "version": "7.0.4", 426 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 427 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 428 | "dev": true, 429 | "dependencies": { 430 | "string-width": "^4.2.0", 431 | "strip-ansi": "^6.0.0", 432 | "wrap-ansi": "^7.0.0" 433 | } 434 | }, 435 | "node_modules/color-convert": { 436 | "version": "2.0.1", 437 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 438 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 439 | "dev": true, 440 | "dependencies": { 441 | "color-name": "~1.1.4" 442 | }, 443 | "engines": { 444 | "node": ">=7.0.0" 445 | } 446 | }, 447 | "node_modules/color-name": { 448 | "version": "1.1.4", 449 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 450 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 451 | "dev": true 452 | }, 453 | "node_modules/concat-map": { 454 | "version": "0.0.1", 455 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 456 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 457 | "dev": true 458 | }, 459 | "node_modules/cross-spawn": { 460 | "version": "7.0.3", 461 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 462 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 463 | "dev": true, 464 | "dependencies": { 465 | "path-key": "^3.1.0", 466 | "shebang-command": "^2.0.0", 467 | "which": "^2.0.1" 468 | }, 469 | "engines": { 470 | "node": ">= 8" 471 | } 472 | }, 473 | "node_modules/debug": { 474 | "version": "4.3.4", 475 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 476 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 477 | "dev": true, 478 | "dependencies": { 479 | "ms": "2.1.2" 480 | }, 481 | "engines": { 482 | "node": ">=6.0" 483 | }, 484 | "peerDependenciesMeta": { 485 | "supports-color": { 486 | "optional": true 487 | } 488 | } 489 | }, 490 | "node_modules/decamelize": { 491 | "version": "4.0.0", 492 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 493 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 494 | "dev": true, 495 | "engines": { 496 | "node": ">=10" 497 | }, 498 | "funding": { 499 | "url": "https://github.com/sponsors/sindresorhus" 500 | } 501 | }, 502 | "node_modules/deep-is": { 503 | "version": "0.1.4", 504 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 505 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 506 | "dev": true 507 | }, 508 | "node_modules/diff": { 509 | "version": "5.0.0", 510 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 511 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 512 | "dev": true, 513 | "engines": { 514 | "node": ">=0.3.1" 515 | } 516 | }, 517 | "node_modules/doctrine": { 518 | "version": "3.0.0", 519 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 520 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 521 | "dev": true, 522 | "dependencies": { 523 | "esutils": "^2.0.2" 524 | }, 525 | "engines": { 526 | "node": ">=6.0.0" 527 | } 528 | }, 529 | "node_modules/emoji-regex": { 530 | "version": "8.0.0", 531 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 532 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 533 | "dev": true 534 | }, 535 | "node_modules/escalade": { 536 | "version": "3.1.1", 537 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 538 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 539 | "dev": true, 540 | "engines": { 541 | "node": ">=6" 542 | } 543 | }, 544 | "node_modules/escape-string-regexp": { 545 | "version": "4.0.0", 546 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 547 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 548 | "dev": true, 549 | "engines": { 550 | "node": ">=10" 551 | }, 552 | "funding": { 553 | "url": "https://github.com/sponsors/sindresorhus" 554 | } 555 | }, 556 | "node_modules/eslint": { 557 | "version": "8.31.0", 558 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.31.0.tgz", 559 | "integrity": "sha512-0tQQEVdmPZ1UtUKXjX7EMm9BlgJ08G90IhWh0PKDCb3ZLsgAOHI8fYSIzYVZej92zsgq+ft0FGsxhJ3xo2tbuA==", 560 | "dev": true, 561 | "dependencies": { 562 | "@eslint/eslintrc": "^1.4.1", 563 | "@humanwhocodes/config-array": "^0.11.8", 564 | "@humanwhocodes/module-importer": "^1.0.1", 565 | "@nodelib/fs.walk": "^1.2.8", 566 | "ajv": "^6.10.0", 567 | "chalk": "^4.0.0", 568 | "cross-spawn": "^7.0.2", 569 | "debug": "^4.3.2", 570 | "doctrine": "^3.0.0", 571 | "escape-string-regexp": "^4.0.0", 572 | "eslint-scope": "^7.1.1", 573 | "eslint-utils": "^3.0.0", 574 | "eslint-visitor-keys": "^3.3.0", 575 | "espree": "^9.4.0", 576 | "esquery": "^1.4.0", 577 | "esutils": "^2.0.2", 578 | "fast-deep-equal": "^3.1.3", 579 | "file-entry-cache": "^6.0.1", 580 | "find-up": "^5.0.0", 581 | "glob-parent": "^6.0.2", 582 | "globals": "^13.19.0", 583 | "grapheme-splitter": "^1.0.4", 584 | "ignore": "^5.2.0", 585 | "import-fresh": "^3.0.0", 586 | "imurmurhash": "^0.1.4", 587 | "is-glob": "^4.0.0", 588 | "is-path-inside": "^3.0.3", 589 | "js-sdsl": "^4.1.4", 590 | "js-yaml": "^4.1.0", 591 | "json-stable-stringify-without-jsonify": "^1.0.1", 592 | "levn": "^0.4.1", 593 | "lodash.merge": "^4.6.2", 594 | "minimatch": "^3.1.2", 595 | "natural-compare": "^1.4.0", 596 | "optionator": "^0.9.1", 597 | "regexpp": "^3.2.0", 598 | "strip-ansi": "^6.0.1", 599 | "strip-json-comments": "^3.1.0", 600 | "text-table": "^0.2.0" 601 | }, 602 | "bin": { 603 | "eslint": "bin/eslint.js" 604 | }, 605 | "engines": { 606 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 607 | }, 608 | "funding": { 609 | "url": "https://opencollective.com/eslint" 610 | } 611 | }, 612 | "node_modules/eslint-formatter-codeframe": { 613 | "version": "7.32.1", 614 | "resolved": "https://registry.npmjs.org/eslint-formatter-codeframe/-/eslint-formatter-codeframe-7.32.1.tgz", 615 | "integrity": "sha512-DK/3Q3+zVKq/7PdSYiCxPrsDF8H/TRMK5n8Hziwr4IMkMy+XiKSwbpj25AdajS63I/B61Snetq4uVvX9fOLyAg==", 616 | "dev": true, 617 | "dependencies": { 618 | "@babel/code-frame": "7.12.11", 619 | "chalk": "^4.0.0" 620 | }, 621 | "engines": { 622 | "node": "^10.12.0 || >=12.0.0" 623 | } 624 | }, 625 | "node_modules/eslint-scope": { 626 | "version": "7.1.1", 627 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.1.tgz", 628 | "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==", 629 | "dev": true, 630 | "dependencies": { 631 | "esrecurse": "^4.3.0", 632 | "estraverse": "^5.2.0" 633 | }, 634 | "engines": { 635 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 636 | } 637 | }, 638 | "node_modules/eslint-utils": { 639 | "version": "3.0.0", 640 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 641 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 642 | "dev": true, 643 | "dependencies": { 644 | "eslint-visitor-keys": "^2.0.0" 645 | }, 646 | "engines": { 647 | "node": "^10.0.0 || ^12.0.0 || >= 14.0.0" 648 | }, 649 | "funding": { 650 | "url": "https://github.com/sponsors/mysticatea" 651 | }, 652 | "peerDependencies": { 653 | "eslint": ">=5" 654 | } 655 | }, 656 | "node_modules/eslint-utils/node_modules/eslint-visitor-keys": { 657 | "version": "2.1.0", 658 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 659 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 660 | "dev": true, 661 | "engines": { 662 | "node": ">=10" 663 | } 664 | }, 665 | "node_modules/eslint-visitor-keys": { 666 | "version": "3.3.0", 667 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz", 668 | "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==", 669 | "dev": true, 670 | "engines": { 671 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 672 | } 673 | }, 674 | "node_modules/espree": { 675 | "version": "9.4.1", 676 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.4.1.tgz", 677 | "integrity": "sha512-XwctdmTO6SIvCzd9810yyNzIrOrqNYV9Koizx4C/mRhf9uq0o4yHoCEU/670pOxOL/MSraektvSAji79kX90Vg==", 678 | "dev": true, 679 | "dependencies": { 680 | "acorn": "^8.8.0", 681 | "acorn-jsx": "^5.3.2", 682 | "eslint-visitor-keys": "^3.3.0" 683 | }, 684 | "engines": { 685 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 686 | }, 687 | "funding": { 688 | "url": "https://opencollective.com/eslint" 689 | } 690 | }, 691 | "node_modules/esquery": { 692 | "version": "1.4.0", 693 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 694 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 695 | "dev": true, 696 | "dependencies": { 697 | "estraverse": "^5.1.0" 698 | }, 699 | "engines": { 700 | "node": ">=0.10" 701 | } 702 | }, 703 | "node_modules/esrecurse": { 704 | "version": "4.3.0", 705 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 706 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 707 | "dev": true, 708 | "dependencies": { 709 | "estraverse": "^5.2.0" 710 | }, 711 | "engines": { 712 | "node": ">=4.0" 713 | } 714 | }, 715 | "node_modules/estraverse": { 716 | "version": "5.3.0", 717 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 718 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 719 | "dev": true, 720 | "engines": { 721 | "node": ">=4.0" 722 | } 723 | }, 724 | "node_modules/esutils": { 725 | "version": "2.0.3", 726 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 727 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 728 | "dev": true, 729 | "engines": { 730 | "node": ">=0.10.0" 731 | } 732 | }, 733 | "node_modules/fast-deep-equal": { 734 | "version": "3.1.3", 735 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 736 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 737 | "dev": true 738 | }, 739 | "node_modules/fast-json-stable-stringify": { 740 | "version": "2.1.0", 741 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 742 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 743 | "dev": true 744 | }, 745 | "node_modules/fast-levenshtein": { 746 | "version": "2.0.6", 747 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 748 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 749 | "dev": true 750 | }, 751 | "node_modules/fastq": { 752 | "version": "1.15.0", 753 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", 754 | "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", 755 | "dev": true, 756 | "dependencies": { 757 | "reusify": "^1.0.4" 758 | } 759 | }, 760 | "node_modules/file-entry-cache": { 761 | "version": "6.0.1", 762 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 763 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 764 | "dev": true, 765 | "dependencies": { 766 | "flat-cache": "^3.0.4" 767 | }, 768 | "engines": { 769 | "node": "^10.12.0 || >=12.0.0" 770 | } 771 | }, 772 | "node_modules/fill-range": { 773 | "version": "7.0.1", 774 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 775 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 776 | "dev": true, 777 | "dependencies": { 778 | "to-regex-range": "^5.0.1" 779 | }, 780 | "engines": { 781 | "node": ">=8" 782 | } 783 | }, 784 | "node_modules/find-up": { 785 | "version": "5.0.0", 786 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 787 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 788 | "dev": true, 789 | "dependencies": { 790 | "locate-path": "^6.0.0", 791 | "path-exists": "^4.0.0" 792 | }, 793 | "engines": { 794 | "node": ">=10" 795 | }, 796 | "funding": { 797 | "url": "https://github.com/sponsors/sindresorhus" 798 | } 799 | }, 800 | "node_modules/flat": { 801 | "version": "5.0.2", 802 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 803 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 804 | "dev": true, 805 | "bin": { 806 | "flat": "cli.js" 807 | } 808 | }, 809 | "node_modules/flat-cache": { 810 | "version": "3.0.4", 811 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 812 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 813 | "dev": true, 814 | "dependencies": { 815 | "flatted": "^3.1.0", 816 | "rimraf": "^3.0.2" 817 | }, 818 | "engines": { 819 | "node": "^10.12.0 || >=12.0.0" 820 | } 821 | }, 822 | "node_modules/flatted": { 823 | "version": "3.2.7", 824 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.7.tgz", 825 | "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==", 826 | "dev": true 827 | }, 828 | "node_modules/fs.realpath": { 829 | "version": "1.0.0", 830 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 831 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 832 | "dev": true 833 | }, 834 | "node_modules/fsevents": { 835 | "version": "2.3.2", 836 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 837 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 838 | "dev": true, 839 | "hasInstallScript": true, 840 | "optional": true, 841 | "os": [ 842 | "darwin" 843 | ], 844 | "engines": { 845 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 846 | } 847 | }, 848 | "node_modules/get-caller-file": { 849 | "version": "2.0.5", 850 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 851 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 852 | "dev": true, 853 | "engines": { 854 | "node": "6.* || 8.* || >= 10.*" 855 | } 856 | }, 857 | "node_modules/glob": { 858 | "version": "7.2.0", 859 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 860 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 861 | "dev": true, 862 | "dependencies": { 863 | "fs.realpath": "^1.0.0", 864 | "inflight": "^1.0.4", 865 | "inherits": "2", 866 | "minimatch": "^3.0.4", 867 | "once": "^1.3.0", 868 | "path-is-absolute": "^1.0.0" 869 | }, 870 | "engines": { 871 | "node": "*" 872 | }, 873 | "funding": { 874 | "url": "https://github.com/sponsors/isaacs" 875 | } 876 | }, 877 | "node_modules/glob-parent": { 878 | "version": "6.0.2", 879 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 880 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 881 | "dev": true, 882 | "dependencies": { 883 | "is-glob": "^4.0.3" 884 | }, 885 | "engines": { 886 | "node": ">=10.13.0" 887 | } 888 | }, 889 | "node_modules/globals": { 890 | "version": "13.19.0", 891 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.19.0.tgz", 892 | "integrity": "sha512-dkQ957uSRWHw7CFXLUtUHQI3g3aWApYhfNR2O6jn/907riyTYKVBmxYVROkBcY614FSSeSJh7Xm7SrUWCxvJMQ==", 893 | "dev": true, 894 | "dependencies": { 895 | "type-fest": "^0.20.2" 896 | }, 897 | "engines": { 898 | "node": ">=8" 899 | }, 900 | "funding": { 901 | "url": "https://github.com/sponsors/sindresorhus" 902 | } 903 | }, 904 | "node_modules/grapheme-splitter": { 905 | "version": "1.0.4", 906 | "resolved": "https://registry.npmjs.org/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz", 907 | "integrity": "sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==", 908 | "dev": true 909 | }, 910 | "node_modules/has-flag": { 911 | "version": "4.0.0", 912 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 913 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 914 | "dev": true, 915 | "engines": { 916 | "node": ">=8" 917 | } 918 | }, 919 | "node_modules/he": { 920 | "version": "1.2.0", 921 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 922 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 923 | "dev": true, 924 | "bin": { 925 | "he": "bin/he" 926 | } 927 | }, 928 | "node_modules/husky": { 929 | "version": "8.0.3", 930 | "resolved": "https://registry.npmjs.org/husky/-/husky-8.0.3.tgz", 931 | "integrity": "sha512-+dQSyqPh4x1hlO1swXBiNb2HzTDN1I2IGLQx1GrBuiqFJfoMrnZWwVmatvSiO+Iz8fBUnf+lekwNo4c2LlXItg==", 932 | "dev": true, 933 | "bin": { 934 | "husky": "lib/bin.js" 935 | }, 936 | "engines": { 937 | "node": ">=14" 938 | }, 939 | "funding": { 940 | "url": "https://github.com/sponsors/typicode" 941 | } 942 | }, 943 | "node_modules/ignore": { 944 | "version": "5.2.4", 945 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", 946 | "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", 947 | "dev": true, 948 | "engines": { 949 | "node": ">= 4" 950 | } 951 | }, 952 | "node_modules/import-fresh": { 953 | "version": "3.3.0", 954 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 955 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 956 | "dev": true, 957 | "dependencies": { 958 | "parent-module": "^1.0.0", 959 | "resolve-from": "^4.0.0" 960 | }, 961 | "engines": { 962 | "node": ">=6" 963 | }, 964 | "funding": { 965 | "url": "https://github.com/sponsors/sindresorhus" 966 | } 967 | }, 968 | "node_modules/imurmurhash": { 969 | "version": "0.1.4", 970 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 971 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 972 | "dev": true, 973 | "engines": { 974 | "node": ">=0.8.19" 975 | } 976 | }, 977 | "node_modules/inflight": { 978 | "version": "1.0.6", 979 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 980 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 981 | "dev": true, 982 | "dependencies": { 983 | "once": "^1.3.0", 984 | "wrappy": "1" 985 | } 986 | }, 987 | "node_modules/inherits": { 988 | "version": "2.0.4", 989 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 990 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 991 | "dev": true 992 | }, 993 | "node_modules/is-binary-path": { 994 | "version": "2.1.0", 995 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 996 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 997 | "dev": true, 998 | "dependencies": { 999 | "binary-extensions": "^2.0.0" 1000 | }, 1001 | "engines": { 1002 | "node": ">=8" 1003 | } 1004 | }, 1005 | "node_modules/is-extglob": { 1006 | "version": "2.1.1", 1007 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1008 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1009 | "dev": true, 1010 | "engines": { 1011 | "node": ">=0.10.0" 1012 | } 1013 | }, 1014 | "node_modules/is-fullwidth-code-point": { 1015 | "version": "3.0.0", 1016 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1017 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1018 | "dev": true, 1019 | "engines": { 1020 | "node": ">=8" 1021 | } 1022 | }, 1023 | "node_modules/is-glob": { 1024 | "version": "4.0.3", 1025 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1026 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1027 | "dev": true, 1028 | "dependencies": { 1029 | "is-extglob": "^2.1.1" 1030 | }, 1031 | "engines": { 1032 | "node": ">=0.10.0" 1033 | } 1034 | }, 1035 | "node_modules/is-number": { 1036 | "version": "7.0.0", 1037 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1038 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1039 | "dev": true, 1040 | "engines": { 1041 | "node": ">=0.12.0" 1042 | } 1043 | }, 1044 | "node_modules/is-path-inside": { 1045 | "version": "3.0.3", 1046 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 1047 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 1048 | "dev": true, 1049 | "engines": { 1050 | "node": ">=8" 1051 | } 1052 | }, 1053 | "node_modules/is-plain-obj": { 1054 | "version": "2.1.0", 1055 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 1056 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 1057 | "dev": true, 1058 | "engines": { 1059 | "node": ">=8" 1060 | } 1061 | }, 1062 | "node_modules/is-unicode-supported": { 1063 | "version": "0.1.0", 1064 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 1065 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 1066 | "dev": true, 1067 | "engines": { 1068 | "node": ">=10" 1069 | }, 1070 | "funding": { 1071 | "url": "https://github.com/sponsors/sindresorhus" 1072 | } 1073 | }, 1074 | "node_modules/isexe": { 1075 | "version": "2.0.0", 1076 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1077 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1078 | "dev": true 1079 | }, 1080 | "node_modules/js-sdsl": { 1081 | "version": "4.2.0", 1082 | "resolved": "https://registry.npmjs.org/js-sdsl/-/js-sdsl-4.2.0.tgz", 1083 | "integrity": "sha512-dyBIzQBDkCqCu+0upx25Y2jGdbTGxE9fshMsCdK0ViOongpV+n5tXRcZY9v7CaVQ79AGS9KA1KHtojxiM7aXSQ==", 1084 | "dev": true, 1085 | "funding": { 1086 | "type": "opencollective", 1087 | "url": "https://opencollective.com/js-sdsl" 1088 | } 1089 | }, 1090 | "node_modules/js-tokens": { 1091 | "version": "4.0.0", 1092 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1093 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1094 | "dev": true 1095 | }, 1096 | "node_modules/js-yaml": { 1097 | "version": "4.1.0", 1098 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1099 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1100 | "dev": true, 1101 | "dependencies": { 1102 | "argparse": "^2.0.1" 1103 | }, 1104 | "bin": { 1105 | "js-yaml": "bin/js-yaml.js" 1106 | } 1107 | }, 1108 | "node_modules/json-schema-traverse": { 1109 | "version": "0.4.1", 1110 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1111 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1112 | "dev": true 1113 | }, 1114 | "node_modules/json-stable-stringify-without-jsonify": { 1115 | "version": "1.0.1", 1116 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1117 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 1118 | "dev": true 1119 | }, 1120 | "node_modules/levn": { 1121 | "version": "0.4.1", 1122 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1123 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1124 | "dev": true, 1125 | "dependencies": { 1126 | "prelude-ls": "^1.2.1", 1127 | "type-check": "~0.4.0" 1128 | }, 1129 | "engines": { 1130 | "node": ">= 0.8.0" 1131 | } 1132 | }, 1133 | "node_modules/locate-path": { 1134 | "version": "6.0.0", 1135 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1136 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1137 | "dev": true, 1138 | "dependencies": { 1139 | "p-locate": "^5.0.0" 1140 | }, 1141 | "engines": { 1142 | "node": ">=10" 1143 | }, 1144 | "funding": { 1145 | "url": "https://github.com/sponsors/sindresorhus" 1146 | } 1147 | }, 1148 | "node_modules/lodash.merge": { 1149 | "version": "4.6.2", 1150 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1151 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1152 | "dev": true 1153 | }, 1154 | "node_modules/log-symbols": { 1155 | "version": "4.1.0", 1156 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 1157 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 1158 | "dev": true, 1159 | "dependencies": { 1160 | "chalk": "^4.1.0", 1161 | "is-unicode-supported": "^0.1.0" 1162 | }, 1163 | "engines": { 1164 | "node": ">=10" 1165 | }, 1166 | "funding": { 1167 | "url": "https://github.com/sponsors/sindresorhus" 1168 | } 1169 | }, 1170 | "node_modules/minimatch": { 1171 | "version": "3.1.2", 1172 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1173 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1174 | "dev": true, 1175 | "dependencies": { 1176 | "brace-expansion": "^1.1.7" 1177 | }, 1178 | "engines": { 1179 | "node": "*" 1180 | } 1181 | }, 1182 | "node_modules/mocha": { 1183 | "version": "10.2.0", 1184 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.2.0.tgz", 1185 | "integrity": "sha512-IDY7fl/BecMwFHzoqF2sg/SHHANeBoMMXFlS9r0OXKDssYE1M5O43wUY/9BVPeIvfH2zmEbBfseqN9gBQZzXkg==", 1186 | "dev": true, 1187 | "dependencies": { 1188 | "ansi-colors": "4.1.1", 1189 | "browser-stdout": "1.3.1", 1190 | "chokidar": "3.5.3", 1191 | "debug": "4.3.4", 1192 | "diff": "5.0.0", 1193 | "escape-string-regexp": "4.0.0", 1194 | "find-up": "5.0.0", 1195 | "glob": "7.2.0", 1196 | "he": "1.2.0", 1197 | "js-yaml": "4.1.0", 1198 | "log-symbols": "4.1.0", 1199 | "minimatch": "5.0.1", 1200 | "ms": "2.1.3", 1201 | "nanoid": "3.3.3", 1202 | "serialize-javascript": "6.0.0", 1203 | "strip-json-comments": "3.1.1", 1204 | "supports-color": "8.1.1", 1205 | "workerpool": "6.2.1", 1206 | "yargs": "16.2.0", 1207 | "yargs-parser": "20.2.4", 1208 | "yargs-unparser": "2.0.0" 1209 | }, 1210 | "bin": { 1211 | "_mocha": "bin/_mocha", 1212 | "mocha": "bin/mocha.js" 1213 | }, 1214 | "engines": { 1215 | "node": ">= 14.0.0" 1216 | }, 1217 | "funding": { 1218 | "type": "opencollective", 1219 | "url": "https://opencollective.com/mochajs" 1220 | } 1221 | }, 1222 | "node_modules/mocha/node_modules/brace-expansion": { 1223 | "version": "2.0.1", 1224 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1225 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1226 | "dev": true, 1227 | "dependencies": { 1228 | "balanced-match": "^1.0.0" 1229 | } 1230 | }, 1231 | "node_modules/mocha/node_modules/minimatch": { 1232 | "version": "5.0.1", 1233 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.1.tgz", 1234 | "integrity": "sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g==", 1235 | "dev": true, 1236 | "dependencies": { 1237 | "brace-expansion": "^2.0.1" 1238 | }, 1239 | "engines": { 1240 | "node": ">=10" 1241 | } 1242 | }, 1243 | "node_modules/mocha/node_modules/ms": { 1244 | "version": "2.1.3", 1245 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1246 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1247 | "dev": true 1248 | }, 1249 | "node_modules/mocha/node_modules/supports-color": { 1250 | "version": "8.1.1", 1251 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1252 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1253 | "dev": true, 1254 | "dependencies": { 1255 | "has-flag": "^4.0.0" 1256 | }, 1257 | "engines": { 1258 | "node": ">=10" 1259 | }, 1260 | "funding": { 1261 | "url": "https://github.com/chalk/supports-color?sponsor=1" 1262 | } 1263 | }, 1264 | "node_modules/ms": { 1265 | "version": "2.1.2", 1266 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1267 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1268 | "dev": true 1269 | }, 1270 | "node_modules/nanoid": { 1271 | "version": "3.3.3", 1272 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.3.tgz", 1273 | "integrity": "sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w==", 1274 | "dev": true, 1275 | "bin": { 1276 | "nanoid": "bin/nanoid.cjs" 1277 | }, 1278 | "engines": { 1279 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1280 | } 1281 | }, 1282 | "node_modules/natural-compare": { 1283 | "version": "1.4.0", 1284 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1285 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 1286 | "dev": true 1287 | }, 1288 | "node_modules/normalize-path": { 1289 | "version": "3.0.0", 1290 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1291 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1292 | "dev": true, 1293 | "engines": { 1294 | "node": ">=0.10.0" 1295 | } 1296 | }, 1297 | "node_modules/once": { 1298 | "version": "1.4.0", 1299 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1300 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1301 | "dev": true, 1302 | "dependencies": { 1303 | "wrappy": "1" 1304 | } 1305 | }, 1306 | "node_modules/optionator": { 1307 | "version": "0.9.1", 1308 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1309 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1310 | "dev": true, 1311 | "dependencies": { 1312 | "deep-is": "^0.1.3", 1313 | "fast-levenshtein": "^2.0.6", 1314 | "levn": "^0.4.1", 1315 | "prelude-ls": "^1.2.1", 1316 | "type-check": "^0.4.0", 1317 | "word-wrap": "^1.2.3" 1318 | }, 1319 | "engines": { 1320 | "node": ">= 0.8.0" 1321 | } 1322 | }, 1323 | "node_modules/p-limit": { 1324 | "version": "3.1.0", 1325 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1326 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1327 | "dev": true, 1328 | "dependencies": { 1329 | "yocto-queue": "^0.1.0" 1330 | }, 1331 | "engines": { 1332 | "node": ">=10" 1333 | }, 1334 | "funding": { 1335 | "url": "https://github.com/sponsors/sindresorhus" 1336 | } 1337 | }, 1338 | "node_modules/p-locate": { 1339 | "version": "5.0.0", 1340 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1341 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1342 | "dev": true, 1343 | "dependencies": { 1344 | "p-limit": "^3.0.2" 1345 | }, 1346 | "engines": { 1347 | "node": ">=10" 1348 | }, 1349 | "funding": { 1350 | "url": "https://github.com/sponsors/sindresorhus" 1351 | } 1352 | }, 1353 | "node_modules/parent-module": { 1354 | "version": "1.0.1", 1355 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1356 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1357 | "dev": true, 1358 | "dependencies": { 1359 | "callsites": "^3.0.0" 1360 | }, 1361 | "engines": { 1362 | "node": ">=6" 1363 | } 1364 | }, 1365 | "node_modules/path-exists": { 1366 | "version": "4.0.0", 1367 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1368 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1369 | "dev": true, 1370 | "engines": { 1371 | "node": ">=8" 1372 | } 1373 | }, 1374 | "node_modules/path-is-absolute": { 1375 | "version": "1.0.1", 1376 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1377 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1378 | "dev": true, 1379 | "engines": { 1380 | "node": ">=0.10.0" 1381 | } 1382 | }, 1383 | "node_modules/path-key": { 1384 | "version": "3.1.1", 1385 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1386 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1387 | "dev": true, 1388 | "engines": { 1389 | "node": ">=8" 1390 | } 1391 | }, 1392 | "node_modules/picomatch": { 1393 | "version": "2.3.1", 1394 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1395 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1396 | "dev": true, 1397 | "engines": { 1398 | "node": ">=8.6" 1399 | }, 1400 | "funding": { 1401 | "url": "https://github.com/sponsors/jonschlinkert" 1402 | } 1403 | }, 1404 | "node_modules/pinst": { 1405 | "version": "3.0.0", 1406 | "resolved": "https://registry.npmjs.org/pinst/-/pinst-3.0.0.tgz", 1407 | "integrity": "sha512-cengSmBxtCyaJqtRSvJorIIZXMXg+lJ3sIljGmtBGUVonMnMsVJbnzl6jGN1HkOWwxNuJynCJ2hXxxqCQrFDdw==", 1408 | "dev": true, 1409 | "hasInstallScript": true, 1410 | "bin": { 1411 | "pinst": "bin.js" 1412 | }, 1413 | "engines": { 1414 | "node": ">=12.0.0" 1415 | } 1416 | }, 1417 | "node_modules/prelude-ls": { 1418 | "version": "1.2.1", 1419 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1420 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1421 | "dev": true, 1422 | "engines": { 1423 | "node": ">= 0.8.0" 1424 | } 1425 | }, 1426 | "node_modules/punycode": { 1427 | "version": "2.1.1", 1428 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1429 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1430 | "dev": true, 1431 | "engines": { 1432 | "node": ">=6" 1433 | } 1434 | }, 1435 | "node_modules/queue-microtask": { 1436 | "version": "1.2.3", 1437 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 1438 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 1439 | "dev": true, 1440 | "funding": [ 1441 | { 1442 | "type": "github", 1443 | "url": "https://github.com/sponsors/feross" 1444 | }, 1445 | { 1446 | "type": "patreon", 1447 | "url": "https://www.patreon.com/feross" 1448 | }, 1449 | { 1450 | "type": "consulting", 1451 | "url": "https://feross.org/support" 1452 | } 1453 | ] 1454 | }, 1455 | "node_modules/randombytes": { 1456 | "version": "2.1.0", 1457 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1458 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1459 | "dev": true, 1460 | "dependencies": { 1461 | "safe-buffer": "^5.1.0" 1462 | } 1463 | }, 1464 | "node_modules/readdirp": { 1465 | "version": "3.6.0", 1466 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1467 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1468 | "dev": true, 1469 | "dependencies": { 1470 | "picomatch": "^2.2.1" 1471 | }, 1472 | "engines": { 1473 | "node": ">=8.10.0" 1474 | } 1475 | }, 1476 | "node_modules/regexpp": { 1477 | "version": "3.2.0", 1478 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 1479 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 1480 | "dev": true, 1481 | "engines": { 1482 | "node": ">=8" 1483 | }, 1484 | "funding": { 1485 | "url": "https://github.com/sponsors/mysticatea" 1486 | } 1487 | }, 1488 | "node_modules/require-directory": { 1489 | "version": "2.1.1", 1490 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1491 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 1492 | "dev": true, 1493 | "engines": { 1494 | "node": ">=0.10.0" 1495 | } 1496 | }, 1497 | "node_modules/resolve-from": { 1498 | "version": "4.0.0", 1499 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1500 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1501 | "dev": true, 1502 | "engines": { 1503 | "node": ">=4" 1504 | } 1505 | }, 1506 | "node_modules/reusify": { 1507 | "version": "1.0.4", 1508 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1509 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 1510 | "dev": true, 1511 | "engines": { 1512 | "iojs": ">=1.0.0", 1513 | "node": ">=0.10.0" 1514 | } 1515 | }, 1516 | "node_modules/rimraf": { 1517 | "version": "3.0.2", 1518 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1519 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1520 | "dev": true, 1521 | "dependencies": { 1522 | "glob": "^7.1.3" 1523 | }, 1524 | "bin": { 1525 | "rimraf": "bin.js" 1526 | }, 1527 | "funding": { 1528 | "url": "https://github.com/sponsors/isaacs" 1529 | } 1530 | }, 1531 | "node_modules/run-parallel": { 1532 | "version": "1.2.0", 1533 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 1534 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 1535 | "dev": true, 1536 | "funding": [ 1537 | { 1538 | "type": "github", 1539 | "url": "https://github.com/sponsors/feross" 1540 | }, 1541 | { 1542 | "type": "patreon", 1543 | "url": "https://www.patreon.com/feross" 1544 | }, 1545 | { 1546 | "type": "consulting", 1547 | "url": "https://feross.org/support" 1548 | } 1549 | ], 1550 | "dependencies": { 1551 | "queue-microtask": "^1.2.2" 1552 | } 1553 | }, 1554 | "node_modules/safe-buffer": { 1555 | "version": "5.2.1", 1556 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1557 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1558 | "dev": true, 1559 | "funding": [ 1560 | { 1561 | "type": "github", 1562 | "url": "https://github.com/sponsors/feross" 1563 | }, 1564 | { 1565 | "type": "patreon", 1566 | "url": "https://www.patreon.com/feross" 1567 | }, 1568 | { 1569 | "type": "consulting", 1570 | "url": "https://feross.org/support" 1571 | } 1572 | ] 1573 | }, 1574 | "node_modules/serialize-javascript": { 1575 | "version": "6.0.0", 1576 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 1577 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 1578 | "dev": true, 1579 | "dependencies": { 1580 | "randombytes": "^2.1.0" 1581 | } 1582 | }, 1583 | "node_modules/shebang-command": { 1584 | "version": "2.0.0", 1585 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1586 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1587 | "dev": true, 1588 | "dependencies": { 1589 | "shebang-regex": "^3.0.0" 1590 | }, 1591 | "engines": { 1592 | "node": ">=8" 1593 | } 1594 | }, 1595 | "node_modules/shebang-regex": { 1596 | "version": "3.0.0", 1597 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1598 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1599 | "dev": true, 1600 | "engines": { 1601 | "node": ">=8" 1602 | } 1603 | }, 1604 | "node_modules/string-width": { 1605 | "version": "4.2.3", 1606 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1607 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1608 | "dev": true, 1609 | "dependencies": { 1610 | "emoji-regex": "^8.0.0", 1611 | "is-fullwidth-code-point": "^3.0.0", 1612 | "strip-ansi": "^6.0.1" 1613 | }, 1614 | "engines": { 1615 | "node": ">=8" 1616 | } 1617 | }, 1618 | "node_modules/strip-ansi": { 1619 | "version": "6.0.1", 1620 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1621 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1622 | "dev": true, 1623 | "dependencies": { 1624 | "ansi-regex": "^5.0.1" 1625 | }, 1626 | "engines": { 1627 | "node": ">=8" 1628 | } 1629 | }, 1630 | "node_modules/strip-json-comments": { 1631 | "version": "3.1.1", 1632 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1633 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1634 | "dev": true, 1635 | "engines": { 1636 | "node": ">=8" 1637 | }, 1638 | "funding": { 1639 | "url": "https://github.com/sponsors/sindresorhus" 1640 | } 1641 | }, 1642 | "node_modules/supports-color": { 1643 | "version": "7.2.0", 1644 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1645 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1646 | "dev": true, 1647 | "dependencies": { 1648 | "has-flag": "^4.0.0" 1649 | }, 1650 | "engines": { 1651 | "node": ">=8" 1652 | } 1653 | }, 1654 | "node_modules/text-table": { 1655 | "version": "0.2.0", 1656 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1657 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 1658 | "dev": true 1659 | }, 1660 | "node_modules/to-regex-range": { 1661 | "version": "5.0.1", 1662 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1663 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1664 | "dev": true, 1665 | "dependencies": { 1666 | "is-number": "^7.0.0" 1667 | }, 1668 | "engines": { 1669 | "node": ">=8.0" 1670 | } 1671 | }, 1672 | "node_modules/type-check": { 1673 | "version": "0.4.0", 1674 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1675 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1676 | "dev": true, 1677 | "dependencies": { 1678 | "prelude-ls": "^1.2.1" 1679 | }, 1680 | "engines": { 1681 | "node": ">= 0.8.0" 1682 | } 1683 | }, 1684 | "node_modules/type-fest": { 1685 | "version": "0.20.2", 1686 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1687 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1688 | "dev": true, 1689 | "engines": { 1690 | "node": ">=10" 1691 | }, 1692 | "funding": { 1693 | "url": "https://github.com/sponsors/sindresorhus" 1694 | } 1695 | }, 1696 | "node_modules/uri-js": { 1697 | "version": "4.4.1", 1698 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1699 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1700 | "dev": true, 1701 | "dependencies": { 1702 | "punycode": "^2.1.0" 1703 | } 1704 | }, 1705 | "node_modules/which": { 1706 | "version": "2.0.2", 1707 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1708 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1709 | "dev": true, 1710 | "dependencies": { 1711 | "isexe": "^2.0.0" 1712 | }, 1713 | "bin": { 1714 | "node-which": "bin/node-which" 1715 | }, 1716 | "engines": { 1717 | "node": ">= 8" 1718 | } 1719 | }, 1720 | "node_modules/word-wrap": { 1721 | "version": "1.2.3", 1722 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1723 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1724 | "dev": true, 1725 | "engines": { 1726 | "node": ">=0.10.0" 1727 | } 1728 | }, 1729 | "node_modules/workerpool": { 1730 | "version": "6.2.1", 1731 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.1.tgz", 1732 | "integrity": "sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw==", 1733 | "dev": true 1734 | }, 1735 | "node_modules/wrap-ansi": { 1736 | "version": "7.0.0", 1737 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1738 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1739 | "dev": true, 1740 | "dependencies": { 1741 | "ansi-styles": "^4.0.0", 1742 | "string-width": "^4.1.0", 1743 | "strip-ansi": "^6.0.0" 1744 | }, 1745 | "engines": { 1746 | "node": ">=10" 1747 | }, 1748 | "funding": { 1749 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 1750 | } 1751 | }, 1752 | "node_modules/wrappy": { 1753 | "version": "1.0.2", 1754 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1755 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 1756 | "dev": true 1757 | }, 1758 | "node_modules/y18n": { 1759 | "version": "5.0.8", 1760 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1761 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1762 | "dev": true, 1763 | "engines": { 1764 | "node": ">=10" 1765 | } 1766 | }, 1767 | "node_modules/yargs": { 1768 | "version": "16.2.0", 1769 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 1770 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 1771 | "dev": true, 1772 | "dependencies": { 1773 | "cliui": "^7.0.2", 1774 | "escalade": "^3.1.1", 1775 | "get-caller-file": "^2.0.5", 1776 | "require-directory": "^2.1.1", 1777 | "string-width": "^4.2.0", 1778 | "y18n": "^5.0.5", 1779 | "yargs-parser": "^20.2.2" 1780 | }, 1781 | "engines": { 1782 | "node": ">=10" 1783 | } 1784 | }, 1785 | "node_modules/yargs-parser": { 1786 | "version": "20.2.4", 1787 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 1788 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 1789 | "dev": true, 1790 | "engines": { 1791 | "node": ">=10" 1792 | } 1793 | }, 1794 | "node_modules/yargs-unparser": { 1795 | "version": "2.0.0", 1796 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 1797 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 1798 | "dev": true, 1799 | "dependencies": { 1800 | "camelcase": "^6.0.0", 1801 | "decamelize": "^4.0.0", 1802 | "flat": "^5.0.2", 1803 | "is-plain-obj": "^2.1.0" 1804 | }, 1805 | "engines": { 1806 | "node": ">=10" 1807 | } 1808 | }, 1809 | "node_modules/yocto-queue": { 1810 | "version": "0.1.0", 1811 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1812 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1813 | "dev": true, 1814 | "engines": { 1815 | "node": ">=10" 1816 | }, 1817 | "funding": { 1818 | "url": "https://github.com/sponsors/sindresorhus" 1819 | } 1820 | } 1821 | }, 1822 | "dependencies": { 1823 | "@babel/code-frame": { 1824 | "version": "7.12.11", 1825 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 1826 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 1827 | "dev": true, 1828 | "requires": { 1829 | "@babel/highlight": "^7.10.4" 1830 | } 1831 | }, 1832 | "@babel/helper-validator-identifier": { 1833 | "version": "7.19.1", 1834 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", 1835 | "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==", 1836 | "dev": true 1837 | }, 1838 | "@babel/highlight": { 1839 | "version": "7.18.6", 1840 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", 1841 | "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", 1842 | "dev": true, 1843 | "requires": { 1844 | "@babel/helper-validator-identifier": "^7.18.6", 1845 | "chalk": "^2.0.0", 1846 | "js-tokens": "^4.0.0" 1847 | }, 1848 | "dependencies": { 1849 | "ansi-styles": { 1850 | "version": "3.2.1", 1851 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1852 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1853 | "dev": true, 1854 | "requires": { 1855 | "color-convert": "^1.9.0" 1856 | } 1857 | }, 1858 | "chalk": { 1859 | "version": "2.4.2", 1860 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1861 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1862 | "dev": true, 1863 | "requires": { 1864 | "ansi-styles": "^3.2.1", 1865 | "escape-string-regexp": "^1.0.5", 1866 | "supports-color": "^5.3.0" 1867 | } 1868 | }, 1869 | "color-convert": { 1870 | "version": "1.9.3", 1871 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1872 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1873 | "dev": true, 1874 | "requires": { 1875 | "color-name": "1.1.3" 1876 | } 1877 | }, 1878 | "color-name": { 1879 | "version": "1.1.3", 1880 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1881 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 1882 | "dev": true 1883 | }, 1884 | "escape-string-regexp": { 1885 | "version": "1.0.5", 1886 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1887 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 1888 | "dev": true 1889 | }, 1890 | "has-flag": { 1891 | "version": "3.0.0", 1892 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1893 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 1894 | "dev": true 1895 | }, 1896 | "supports-color": { 1897 | "version": "5.5.0", 1898 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1899 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1900 | "dev": true, 1901 | "requires": { 1902 | "has-flag": "^3.0.0" 1903 | } 1904 | } 1905 | } 1906 | }, 1907 | "@eslint/eslintrc": { 1908 | "version": "1.4.1", 1909 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.4.1.tgz", 1910 | "integrity": "sha512-XXrH9Uarn0stsyldqDYq8r++mROmWRI1xKMXa640Bb//SY1+ECYX6VzT6Lcx5frD0V30XieqJ0oX9I2Xj5aoMA==", 1911 | "dev": true, 1912 | "requires": { 1913 | "ajv": "^6.12.4", 1914 | "debug": "^4.3.2", 1915 | "espree": "^9.4.0", 1916 | "globals": "^13.19.0", 1917 | "ignore": "^5.2.0", 1918 | "import-fresh": "^3.2.1", 1919 | "js-yaml": "^4.1.0", 1920 | "minimatch": "^3.1.2", 1921 | "strip-json-comments": "^3.1.1" 1922 | } 1923 | }, 1924 | "@humanwhocodes/config-array": { 1925 | "version": "0.11.8", 1926 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.8.tgz", 1927 | "integrity": "sha512-UybHIJzJnR5Qc/MsD9Kr+RpO2h+/P1GhOwdiLPXK5TWk5sgTdu88bTD9UP+CKbPPh5Rni1u0GjAdYQLemG8g+g==", 1928 | "dev": true, 1929 | "requires": { 1930 | "@humanwhocodes/object-schema": "^1.2.1", 1931 | "debug": "^4.1.1", 1932 | "minimatch": "^3.0.5" 1933 | } 1934 | }, 1935 | "@humanwhocodes/module-importer": { 1936 | "version": "1.0.1", 1937 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 1938 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 1939 | "dev": true 1940 | }, 1941 | "@humanwhocodes/object-schema": { 1942 | "version": "1.2.1", 1943 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 1944 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 1945 | "dev": true 1946 | }, 1947 | "@nodelib/fs.scandir": { 1948 | "version": "2.1.5", 1949 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 1950 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 1951 | "dev": true, 1952 | "requires": { 1953 | "@nodelib/fs.stat": "2.0.5", 1954 | "run-parallel": "^1.1.9" 1955 | } 1956 | }, 1957 | "@nodelib/fs.stat": { 1958 | "version": "2.0.5", 1959 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 1960 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 1961 | "dev": true 1962 | }, 1963 | "@nodelib/fs.walk": { 1964 | "version": "1.2.8", 1965 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 1966 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 1967 | "dev": true, 1968 | "requires": { 1969 | "@nodelib/fs.scandir": "2.1.5", 1970 | "fastq": "^1.6.0" 1971 | } 1972 | }, 1973 | "acorn": { 1974 | "version": "8.8.1", 1975 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.1.tgz", 1976 | "integrity": "sha512-7zFpHzhnqYKrkYdUjF1HI1bzd0VygEGX8lFk4k5zVMqHEoES+P+7TKI+EvLO9WVMJ8eekdO0aDEK044xTXwPPA==", 1977 | "dev": true 1978 | }, 1979 | "acorn-jsx": { 1980 | "version": "5.3.2", 1981 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 1982 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 1983 | "dev": true, 1984 | "requires": {} 1985 | }, 1986 | "ajv": { 1987 | "version": "6.12.6", 1988 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 1989 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 1990 | "dev": true, 1991 | "requires": { 1992 | "fast-deep-equal": "^3.1.1", 1993 | "fast-json-stable-stringify": "^2.0.0", 1994 | "json-schema-traverse": "^0.4.1", 1995 | "uri-js": "^4.2.2" 1996 | } 1997 | }, 1998 | "ansi-colors": { 1999 | "version": "4.1.1", 2000 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 2001 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 2002 | "dev": true 2003 | }, 2004 | "ansi-regex": { 2005 | "version": "5.0.1", 2006 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2007 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2008 | "dev": true 2009 | }, 2010 | "ansi-styles": { 2011 | "version": "4.3.0", 2012 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2013 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2014 | "dev": true, 2015 | "requires": { 2016 | "color-convert": "^2.0.1" 2017 | } 2018 | }, 2019 | "anymatch": { 2020 | "version": "3.1.3", 2021 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 2022 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 2023 | "dev": true, 2024 | "requires": { 2025 | "normalize-path": "^3.0.0", 2026 | "picomatch": "^2.0.4" 2027 | } 2028 | }, 2029 | "argparse": { 2030 | "version": "2.0.1", 2031 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 2032 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 2033 | "dev": true 2034 | }, 2035 | "balanced-match": { 2036 | "version": "1.0.2", 2037 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2038 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 2039 | "dev": true 2040 | }, 2041 | "binary-extensions": { 2042 | "version": "2.2.0", 2043 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 2044 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 2045 | "dev": true 2046 | }, 2047 | "brace-expansion": { 2048 | "version": "1.1.11", 2049 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2050 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2051 | "dev": true, 2052 | "requires": { 2053 | "balanced-match": "^1.0.0", 2054 | "concat-map": "0.0.1" 2055 | } 2056 | }, 2057 | "braces": { 2058 | "version": "3.0.2", 2059 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2060 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2061 | "dev": true, 2062 | "requires": { 2063 | "fill-range": "^7.0.1" 2064 | } 2065 | }, 2066 | "browser-stdout": { 2067 | "version": "1.3.1", 2068 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 2069 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 2070 | "dev": true 2071 | }, 2072 | "callsites": { 2073 | "version": "3.1.0", 2074 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 2075 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 2076 | "dev": true 2077 | }, 2078 | "camelcase": { 2079 | "version": "6.3.0", 2080 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 2081 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 2082 | "dev": true 2083 | }, 2084 | "chalk": { 2085 | "version": "4.1.2", 2086 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2087 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2088 | "dev": true, 2089 | "requires": { 2090 | "ansi-styles": "^4.1.0", 2091 | "supports-color": "^7.1.0" 2092 | } 2093 | }, 2094 | "chokidar": { 2095 | "version": "3.5.3", 2096 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 2097 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 2098 | "dev": true, 2099 | "requires": { 2100 | "anymatch": "~3.1.2", 2101 | "braces": "~3.0.2", 2102 | "fsevents": "~2.3.2", 2103 | "glob-parent": "~5.1.2", 2104 | "is-binary-path": "~2.1.0", 2105 | "is-glob": "~4.0.1", 2106 | "normalize-path": "~3.0.0", 2107 | "readdirp": "~3.6.0" 2108 | }, 2109 | "dependencies": { 2110 | "glob-parent": { 2111 | "version": "5.1.2", 2112 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2113 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2114 | "dev": true, 2115 | "requires": { 2116 | "is-glob": "^4.0.1" 2117 | } 2118 | } 2119 | } 2120 | }, 2121 | "cliui": { 2122 | "version": "7.0.4", 2123 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 2124 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 2125 | "dev": true, 2126 | "requires": { 2127 | "string-width": "^4.2.0", 2128 | "strip-ansi": "^6.0.0", 2129 | "wrap-ansi": "^7.0.0" 2130 | } 2131 | }, 2132 | "color-convert": { 2133 | "version": "2.0.1", 2134 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2135 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2136 | "dev": true, 2137 | "requires": { 2138 | "color-name": "~1.1.4" 2139 | } 2140 | }, 2141 | "color-name": { 2142 | "version": "1.1.4", 2143 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2144 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2145 | "dev": true 2146 | }, 2147 | "concat-map": { 2148 | "version": "0.0.1", 2149 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2150 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 2151 | "dev": true 2152 | }, 2153 | "cross-spawn": { 2154 | "version": "7.0.3", 2155 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2156 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2157 | "dev": true, 2158 | "requires": { 2159 | "path-key": "^3.1.0", 2160 | "shebang-command": "^2.0.0", 2161 | "which": "^2.0.1" 2162 | } 2163 | }, 2164 | "debug": { 2165 | "version": "4.3.4", 2166 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2167 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2168 | "dev": true, 2169 | "requires": { 2170 | "ms": "2.1.2" 2171 | } 2172 | }, 2173 | "decamelize": { 2174 | "version": "4.0.0", 2175 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 2176 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 2177 | "dev": true 2178 | }, 2179 | "deep-is": { 2180 | "version": "0.1.4", 2181 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 2182 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 2183 | "dev": true 2184 | }, 2185 | "diff": { 2186 | "version": "5.0.0", 2187 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 2188 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 2189 | "dev": true 2190 | }, 2191 | "doctrine": { 2192 | "version": "3.0.0", 2193 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 2194 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 2195 | "dev": true, 2196 | "requires": { 2197 | "esutils": "^2.0.2" 2198 | } 2199 | }, 2200 | "emoji-regex": { 2201 | "version": "8.0.0", 2202 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2203 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2204 | "dev": true 2205 | }, 2206 | "escalade": { 2207 | "version": "3.1.1", 2208 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 2209 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 2210 | "dev": true 2211 | }, 2212 | "escape-string-regexp": { 2213 | "version": "4.0.0", 2214 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2215 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2216 | "dev": true 2217 | }, 2218 | "eslint": { 2219 | "version": "8.31.0", 2220 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.31.0.tgz", 2221 | "integrity": "sha512-0tQQEVdmPZ1UtUKXjX7EMm9BlgJ08G90IhWh0PKDCb3ZLsgAOHI8fYSIzYVZej92zsgq+ft0FGsxhJ3xo2tbuA==", 2222 | "dev": true, 2223 | "requires": { 2224 | "@eslint/eslintrc": "^1.4.1", 2225 | "@humanwhocodes/config-array": "^0.11.8", 2226 | "@humanwhocodes/module-importer": "^1.0.1", 2227 | "@nodelib/fs.walk": "^1.2.8", 2228 | "ajv": "^6.10.0", 2229 | "chalk": "^4.0.0", 2230 | "cross-spawn": "^7.0.2", 2231 | "debug": "^4.3.2", 2232 | "doctrine": "^3.0.0", 2233 | "escape-string-regexp": "^4.0.0", 2234 | "eslint-scope": "^7.1.1", 2235 | "eslint-utils": "^3.0.0", 2236 | "eslint-visitor-keys": "^3.3.0", 2237 | "espree": "^9.4.0", 2238 | "esquery": "^1.4.0", 2239 | "esutils": "^2.0.2", 2240 | "fast-deep-equal": "^3.1.3", 2241 | "file-entry-cache": "^6.0.1", 2242 | "find-up": "^5.0.0", 2243 | "glob-parent": "^6.0.2", 2244 | "globals": "^13.19.0", 2245 | "grapheme-splitter": "^1.0.4", 2246 | "ignore": "^5.2.0", 2247 | "import-fresh": "^3.0.0", 2248 | "imurmurhash": "^0.1.4", 2249 | "is-glob": "^4.0.0", 2250 | "is-path-inside": "^3.0.3", 2251 | "js-sdsl": "^4.1.4", 2252 | "js-yaml": "^4.1.0", 2253 | "json-stable-stringify-without-jsonify": "^1.0.1", 2254 | "levn": "^0.4.1", 2255 | "lodash.merge": "^4.6.2", 2256 | "minimatch": "^3.1.2", 2257 | "natural-compare": "^1.4.0", 2258 | "optionator": "^0.9.1", 2259 | "regexpp": "^3.2.0", 2260 | "strip-ansi": "^6.0.1", 2261 | "strip-json-comments": "^3.1.0", 2262 | "text-table": "^0.2.0" 2263 | } 2264 | }, 2265 | "eslint-formatter-codeframe": { 2266 | "version": "7.32.1", 2267 | "resolved": "https://registry.npmjs.org/eslint-formatter-codeframe/-/eslint-formatter-codeframe-7.32.1.tgz", 2268 | "integrity": "sha512-DK/3Q3+zVKq/7PdSYiCxPrsDF8H/TRMK5n8Hziwr4IMkMy+XiKSwbpj25AdajS63I/B61Snetq4uVvX9fOLyAg==", 2269 | "dev": true, 2270 | "requires": { 2271 | "@babel/code-frame": "7.12.11", 2272 | "chalk": "^4.0.0" 2273 | } 2274 | }, 2275 | "eslint-scope": { 2276 | "version": "7.1.1", 2277 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.1.tgz", 2278 | "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==", 2279 | "dev": true, 2280 | "requires": { 2281 | "esrecurse": "^4.3.0", 2282 | "estraverse": "^5.2.0" 2283 | } 2284 | }, 2285 | "eslint-utils": { 2286 | "version": "3.0.0", 2287 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 2288 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 2289 | "dev": true, 2290 | "requires": { 2291 | "eslint-visitor-keys": "^2.0.0" 2292 | }, 2293 | "dependencies": { 2294 | "eslint-visitor-keys": { 2295 | "version": "2.1.0", 2296 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 2297 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 2298 | "dev": true 2299 | } 2300 | } 2301 | }, 2302 | "eslint-visitor-keys": { 2303 | "version": "3.3.0", 2304 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz", 2305 | "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==", 2306 | "dev": true 2307 | }, 2308 | "espree": { 2309 | "version": "9.4.1", 2310 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.4.1.tgz", 2311 | "integrity": "sha512-XwctdmTO6SIvCzd9810yyNzIrOrqNYV9Koizx4C/mRhf9uq0o4yHoCEU/670pOxOL/MSraektvSAji79kX90Vg==", 2312 | "dev": true, 2313 | "requires": { 2314 | "acorn": "^8.8.0", 2315 | "acorn-jsx": "^5.3.2", 2316 | "eslint-visitor-keys": "^3.3.0" 2317 | } 2318 | }, 2319 | "esquery": { 2320 | "version": "1.4.0", 2321 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 2322 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 2323 | "dev": true, 2324 | "requires": { 2325 | "estraverse": "^5.1.0" 2326 | } 2327 | }, 2328 | "esrecurse": { 2329 | "version": "4.3.0", 2330 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2331 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2332 | "dev": true, 2333 | "requires": { 2334 | "estraverse": "^5.2.0" 2335 | } 2336 | }, 2337 | "estraverse": { 2338 | "version": "5.3.0", 2339 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2340 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 2341 | "dev": true 2342 | }, 2343 | "esutils": { 2344 | "version": "2.0.3", 2345 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2346 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2347 | "dev": true 2348 | }, 2349 | "fast-deep-equal": { 2350 | "version": "3.1.3", 2351 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2352 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2353 | "dev": true 2354 | }, 2355 | "fast-json-stable-stringify": { 2356 | "version": "2.1.0", 2357 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2358 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2359 | "dev": true 2360 | }, 2361 | "fast-levenshtein": { 2362 | "version": "2.0.6", 2363 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2364 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 2365 | "dev": true 2366 | }, 2367 | "fastq": { 2368 | "version": "1.15.0", 2369 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", 2370 | "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", 2371 | "dev": true, 2372 | "requires": { 2373 | "reusify": "^1.0.4" 2374 | } 2375 | }, 2376 | "file-entry-cache": { 2377 | "version": "6.0.1", 2378 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 2379 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 2380 | "dev": true, 2381 | "requires": { 2382 | "flat-cache": "^3.0.4" 2383 | } 2384 | }, 2385 | "fill-range": { 2386 | "version": "7.0.1", 2387 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2388 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2389 | "dev": true, 2390 | "requires": { 2391 | "to-regex-range": "^5.0.1" 2392 | } 2393 | }, 2394 | "find-up": { 2395 | "version": "5.0.0", 2396 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2397 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2398 | "dev": true, 2399 | "requires": { 2400 | "locate-path": "^6.0.0", 2401 | "path-exists": "^4.0.0" 2402 | } 2403 | }, 2404 | "flat": { 2405 | "version": "5.0.2", 2406 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 2407 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 2408 | "dev": true 2409 | }, 2410 | "flat-cache": { 2411 | "version": "3.0.4", 2412 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 2413 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 2414 | "dev": true, 2415 | "requires": { 2416 | "flatted": "^3.1.0", 2417 | "rimraf": "^3.0.2" 2418 | } 2419 | }, 2420 | "flatted": { 2421 | "version": "3.2.7", 2422 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.7.tgz", 2423 | "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==", 2424 | "dev": true 2425 | }, 2426 | "fs.realpath": { 2427 | "version": "1.0.0", 2428 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2429 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 2430 | "dev": true 2431 | }, 2432 | "fsevents": { 2433 | "version": "2.3.2", 2434 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2435 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2436 | "dev": true, 2437 | "optional": true 2438 | }, 2439 | "get-caller-file": { 2440 | "version": "2.0.5", 2441 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2442 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 2443 | "dev": true 2444 | }, 2445 | "glob": { 2446 | "version": "7.2.0", 2447 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 2448 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 2449 | "dev": true, 2450 | "requires": { 2451 | "fs.realpath": "^1.0.0", 2452 | "inflight": "^1.0.4", 2453 | "inherits": "2", 2454 | "minimatch": "^3.0.4", 2455 | "once": "^1.3.0", 2456 | "path-is-absolute": "^1.0.0" 2457 | } 2458 | }, 2459 | "glob-parent": { 2460 | "version": "6.0.2", 2461 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2462 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2463 | "dev": true, 2464 | "requires": { 2465 | "is-glob": "^4.0.3" 2466 | } 2467 | }, 2468 | "globals": { 2469 | "version": "13.19.0", 2470 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.19.0.tgz", 2471 | "integrity": "sha512-dkQ957uSRWHw7CFXLUtUHQI3g3aWApYhfNR2O6jn/907riyTYKVBmxYVROkBcY614FSSeSJh7Xm7SrUWCxvJMQ==", 2472 | "dev": true, 2473 | "requires": { 2474 | "type-fest": "^0.20.2" 2475 | } 2476 | }, 2477 | "grapheme-splitter": { 2478 | "version": "1.0.4", 2479 | "resolved": "https://registry.npmjs.org/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz", 2480 | "integrity": "sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==", 2481 | "dev": true 2482 | }, 2483 | "has-flag": { 2484 | "version": "4.0.0", 2485 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2486 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2487 | "dev": true 2488 | }, 2489 | "he": { 2490 | "version": "1.2.0", 2491 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 2492 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 2493 | "dev": true 2494 | }, 2495 | "husky": { 2496 | "version": "8.0.3", 2497 | "resolved": "https://registry.npmjs.org/husky/-/husky-8.0.3.tgz", 2498 | "integrity": "sha512-+dQSyqPh4x1hlO1swXBiNb2HzTDN1I2IGLQx1GrBuiqFJfoMrnZWwVmatvSiO+Iz8fBUnf+lekwNo4c2LlXItg==", 2499 | "dev": true 2500 | }, 2501 | "ignore": { 2502 | "version": "5.2.4", 2503 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", 2504 | "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", 2505 | "dev": true 2506 | }, 2507 | "import-fresh": { 2508 | "version": "3.3.0", 2509 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2510 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2511 | "dev": true, 2512 | "requires": { 2513 | "parent-module": "^1.0.0", 2514 | "resolve-from": "^4.0.0" 2515 | } 2516 | }, 2517 | "imurmurhash": { 2518 | "version": "0.1.4", 2519 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2520 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 2521 | "dev": true 2522 | }, 2523 | "inflight": { 2524 | "version": "1.0.6", 2525 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2526 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2527 | "dev": true, 2528 | "requires": { 2529 | "once": "^1.3.0", 2530 | "wrappy": "1" 2531 | } 2532 | }, 2533 | "inherits": { 2534 | "version": "2.0.4", 2535 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2536 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2537 | "dev": true 2538 | }, 2539 | "is-binary-path": { 2540 | "version": "2.1.0", 2541 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2542 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2543 | "dev": true, 2544 | "requires": { 2545 | "binary-extensions": "^2.0.0" 2546 | } 2547 | }, 2548 | "is-extglob": { 2549 | "version": "2.1.1", 2550 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2551 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2552 | "dev": true 2553 | }, 2554 | "is-fullwidth-code-point": { 2555 | "version": "3.0.0", 2556 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2557 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2558 | "dev": true 2559 | }, 2560 | "is-glob": { 2561 | "version": "4.0.3", 2562 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2563 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2564 | "dev": true, 2565 | "requires": { 2566 | "is-extglob": "^2.1.1" 2567 | } 2568 | }, 2569 | "is-number": { 2570 | "version": "7.0.0", 2571 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2572 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2573 | "dev": true 2574 | }, 2575 | "is-path-inside": { 2576 | "version": "3.0.3", 2577 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 2578 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 2579 | "dev": true 2580 | }, 2581 | "is-plain-obj": { 2582 | "version": "2.1.0", 2583 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 2584 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 2585 | "dev": true 2586 | }, 2587 | "is-unicode-supported": { 2588 | "version": "0.1.0", 2589 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 2590 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 2591 | "dev": true 2592 | }, 2593 | "isexe": { 2594 | "version": "2.0.0", 2595 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2596 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2597 | "dev": true 2598 | }, 2599 | "js-sdsl": { 2600 | "version": "4.2.0", 2601 | "resolved": "https://registry.npmjs.org/js-sdsl/-/js-sdsl-4.2.0.tgz", 2602 | "integrity": "sha512-dyBIzQBDkCqCu+0upx25Y2jGdbTGxE9fshMsCdK0ViOongpV+n5tXRcZY9v7CaVQ79AGS9KA1KHtojxiM7aXSQ==", 2603 | "dev": true 2604 | }, 2605 | "js-tokens": { 2606 | "version": "4.0.0", 2607 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2608 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 2609 | "dev": true 2610 | }, 2611 | "js-yaml": { 2612 | "version": "4.1.0", 2613 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2614 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2615 | "dev": true, 2616 | "requires": { 2617 | "argparse": "^2.0.1" 2618 | } 2619 | }, 2620 | "json-schema-traverse": { 2621 | "version": "0.4.1", 2622 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2623 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2624 | "dev": true 2625 | }, 2626 | "json-stable-stringify-without-jsonify": { 2627 | "version": "1.0.1", 2628 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2629 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 2630 | "dev": true 2631 | }, 2632 | "levn": { 2633 | "version": "0.4.1", 2634 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2635 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2636 | "dev": true, 2637 | "requires": { 2638 | "prelude-ls": "^1.2.1", 2639 | "type-check": "~0.4.0" 2640 | } 2641 | }, 2642 | "locate-path": { 2643 | "version": "6.0.0", 2644 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2645 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2646 | "dev": true, 2647 | "requires": { 2648 | "p-locate": "^5.0.0" 2649 | } 2650 | }, 2651 | "lodash.merge": { 2652 | "version": "4.6.2", 2653 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2654 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2655 | "dev": true 2656 | }, 2657 | "log-symbols": { 2658 | "version": "4.1.0", 2659 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 2660 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 2661 | "dev": true, 2662 | "requires": { 2663 | "chalk": "^4.1.0", 2664 | "is-unicode-supported": "^0.1.0" 2665 | } 2666 | }, 2667 | "minimatch": { 2668 | "version": "3.1.2", 2669 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2670 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2671 | "dev": true, 2672 | "requires": { 2673 | "brace-expansion": "^1.1.7" 2674 | } 2675 | }, 2676 | "mocha": { 2677 | "version": "10.2.0", 2678 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.2.0.tgz", 2679 | "integrity": "sha512-IDY7fl/BecMwFHzoqF2sg/SHHANeBoMMXFlS9r0OXKDssYE1M5O43wUY/9BVPeIvfH2zmEbBfseqN9gBQZzXkg==", 2680 | "dev": true, 2681 | "requires": { 2682 | "ansi-colors": "4.1.1", 2683 | "browser-stdout": "1.3.1", 2684 | "chokidar": "3.5.3", 2685 | "debug": "4.3.4", 2686 | "diff": "5.0.0", 2687 | "escape-string-regexp": "4.0.0", 2688 | "find-up": "5.0.0", 2689 | "glob": "7.2.0", 2690 | "he": "1.2.0", 2691 | "js-yaml": "4.1.0", 2692 | "log-symbols": "4.1.0", 2693 | "minimatch": "5.0.1", 2694 | "ms": "2.1.3", 2695 | "nanoid": "3.3.3", 2696 | "serialize-javascript": "6.0.0", 2697 | "strip-json-comments": "3.1.1", 2698 | "supports-color": "8.1.1", 2699 | "workerpool": "6.2.1", 2700 | "yargs": "16.2.0", 2701 | "yargs-parser": "20.2.4", 2702 | "yargs-unparser": "2.0.0" 2703 | }, 2704 | "dependencies": { 2705 | "brace-expansion": { 2706 | "version": "2.0.1", 2707 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 2708 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 2709 | "dev": true, 2710 | "requires": { 2711 | "balanced-match": "^1.0.0" 2712 | } 2713 | }, 2714 | "minimatch": { 2715 | "version": "5.0.1", 2716 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.1.tgz", 2717 | "integrity": "sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g==", 2718 | "dev": true, 2719 | "requires": { 2720 | "brace-expansion": "^2.0.1" 2721 | } 2722 | }, 2723 | "ms": { 2724 | "version": "2.1.3", 2725 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2726 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2727 | "dev": true 2728 | }, 2729 | "supports-color": { 2730 | "version": "8.1.1", 2731 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 2732 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 2733 | "dev": true, 2734 | "requires": { 2735 | "has-flag": "^4.0.0" 2736 | } 2737 | } 2738 | } 2739 | }, 2740 | "ms": { 2741 | "version": "2.1.2", 2742 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2743 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2744 | "dev": true 2745 | }, 2746 | "nanoid": { 2747 | "version": "3.3.3", 2748 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.3.tgz", 2749 | "integrity": "sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w==", 2750 | "dev": true 2751 | }, 2752 | "natural-compare": { 2753 | "version": "1.4.0", 2754 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2755 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 2756 | "dev": true 2757 | }, 2758 | "normalize-path": { 2759 | "version": "3.0.0", 2760 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2761 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2762 | "dev": true 2763 | }, 2764 | "once": { 2765 | "version": "1.4.0", 2766 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2767 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2768 | "dev": true, 2769 | "requires": { 2770 | "wrappy": "1" 2771 | } 2772 | }, 2773 | "optionator": { 2774 | "version": "0.9.1", 2775 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 2776 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 2777 | "dev": true, 2778 | "requires": { 2779 | "deep-is": "^0.1.3", 2780 | "fast-levenshtein": "^2.0.6", 2781 | "levn": "^0.4.1", 2782 | "prelude-ls": "^1.2.1", 2783 | "type-check": "^0.4.0", 2784 | "word-wrap": "^1.2.3" 2785 | } 2786 | }, 2787 | "p-limit": { 2788 | "version": "3.1.0", 2789 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2790 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2791 | "dev": true, 2792 | "requires": { 2793 | "yocto-queue": "^0.1.0" 2794 | } 2795 | }, 2796 | "p-locate": { 2797 | "version": "5.0.0", 2798 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2799 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2800 | "dev": true, 2801 | "requires": { 2802 | "p-limit": "^3.0.2" 2803 | } 2804 | }, 2805 | "parent-module": { 2806 | "version": "1.0.1", 2807 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2808 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2809 | "dev": true, 2810 | "requires": { 2811 | "callsites": "^3.0.0" 2812 | } 2813 | }, 2814 | "path-exists": { 2815 | "version": "4.0.0", 2816 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2817 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2818 | "dev": true 2819 | }, 2820 | "path-is-absolute": { 2821 | "version": "1.0.1", 2822 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2823 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 2824 | "dev": true 2825 | }, 2826 | "path-key": { 2827 | "version": "3.1.1", 2828 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2829 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2830 | "dev": true 2831 | }, 2832 | "picomatch": { 2833 | "version": "2.3.1", 2834 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2835 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2836 | "dev": true 2837 | }, 2838 | "pinst": { 2839 | "version": "3.0.0", 2840 | "resolved": "https://registry.npmjs.org/pinst/-/pinst-3.0.0.tgz", 2841 | "integrity": "sha512-cengSmBxtCyaJqtRSvJorIIZXMXg+lJ3sIljGmtBGUVonMnMsVJbnzl6jGN1HkOWwxNuJynCJ2hXxxqCQrFDdw==", 2842 | "dev": true 2843 | }, 2844 | "prelude-ls": { 2845 | "version": "1.2.1", 2846 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2847 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2848 | "dev": true 2849 | }, 2850 | "punycode": { 2851 | "version": "2.1.1", 2852 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2853 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2854 | "dev": true 2855 | }, 2856 | "queue-microtask": { 2857 | "version": "1.2.3", 2858 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2859 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2860 | "dev": true 2861 | }, 2862 | "randombytes": { 2863 | "version": "2.1.0", 2864 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 2865 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 2866 | "dev": true, 2867 | "requires": { 2868 | "safe-buffer": "^5.1.0" 2869 | } 2870 | }, 2871 | "readdirp": { 2872 | "version": "3.6.0", 2873 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2874 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2875 | "dev": true, 2876 | "requires": { 2877 | "picomatch": "^2.2.1" 2878 | } 2879 | }, 2880 | "regexpp": { 2881 | "version": "3.2.0", 2882 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 2883 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 2884 | "dev": true 2885 | }, 2886 | "require-directory": { 2887 | "version": "2.1.1", 2888 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2889 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 2890 | "dev": true 2891 | }, 2892 | "resolve-from": { 2893 | "version": "4.0.0", 2894 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2895 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2896 | "dev": true 2897 | }, 2898 | "reusify": { 2899 | "version": "1.0.4", 2900 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2901 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2902 | "dev": true 2903 | }, 2904 | "rimraf": { 2905 | "version": "3.0.2", 2906 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2907 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2908 | "dev": true, 2909 | "requires": { 2910 | "glob": "^7.1.3" 2911 | } 2912 | }, 2913 | "run-parallel": { 2914 | "version": "1.2.0", 2915 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2916 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2917 | "dev": true, 2918 | "requires": { 2919 | "queue-microtask": "^1.2.2" 2920 | } 2921 | }, 2922 | "safe-buffer": { 2923 | "version": "5.2.1", 2924 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2925 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 2926 | "dev": true 2927 | }, 2928 | "serialize-javascript": { 2929 | "version": "6.0.0", 2930 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 2931 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 2932 | "dev": true, 2933 | "requires": { 2934 | "randombytes": "^2.1.0" 2935 | } 2936 | }, 2937 | "shebang-command": { 2938 | "version": "2.0.0", 2939 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2940 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2941 | "dev": true, 2942 | "requires": { 2943 | "shebang-regex": "^3.0.0" 2944 | } 2945 | }, 2946 | "shebang-regex": { 2947 | "version": "3.0.0", 2948 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2949 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2950 | "dev": true 2951 | }, 2952 | "string-width": { 2953 | "version": "4.2.3", 2954 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2955 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2956 | "dev": true, 2957 | "requires": { 2958 | "emoji-regex": "^8.0.0", 2959 | "is-fullwidth-code-point": "^3.0.0", 2960 | "strip-ansi": "^6.0.1" 2961 | } 2962 | }, 2963 | "strip-ansi": { 2964 | "version": "6.0.1", 2965 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2966 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2967 | "dev": true, 2968 | "requires": { 2969 | "ansi-regex": "^5.0.1" 2970 | } 2971 | }, 2972 | "strip-json-comments": { 2973 | "version": "3.1.1", 2974 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2975 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2976 | "dev": true 2977 | }, 2978 | "supports-color": { 2979 | "version": "7.2.0", 2980 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2981 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2982 | "dev": true, 2983 | "requires": { 2984 | "has-flag": "^4.0.0" 2985 | } 2986 | }, 2987 | "text-table": { 2988 | "version": "0.2.0", 2989 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2990 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 2991 | "dev": true 2992 | }, 2993 | "to-regex-range": { 2994 | "version": "5.0.1", 2995 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2996 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2997 | "dev": true, 2998 | "requires": { 2999 | "is-number": "^7.0.0" 3000 | } 3001 | }, 3002 | "type-check": { 3003 | "version": "0.4.0", 3004 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3005 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3006 | "dev": true, 3007 | "requires": { 3008 | "prelude-ls": "^1.2.1" 3009 | } 3010 | }, 3011 | "type-fest": { 3012 | "version": "0.20.2", 3013 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3014 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3015 | "dev": true 3016 | }, 3017 | "uri-js": { 3018 | "version": "4.4.1", 3019 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3020 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3021 | "dev": true, 3022 | "requires": { 3023 | "punycode": "^2.1.0" 3024 | } 3025 | }, 3026 | "which": { 3027 | "version": "2.0.2", 3028 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3029 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3030 | "dev": true, 3031 | "requires": { 3032 | "isexe": "^2.0.0" 3033 | } 3034 | }, 3035 | "word-wrap": { 3036 | "version": "1.2.3", 3037 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 3038 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 3039 | "dev": true 3040 | }, 3041 | "workerpool": { 3042 | "version": "6.2.1", 3043 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.1.tgz", 3044 | "integrity": "sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw==", 3045 | "dev": true 3046 | }, 3047 | "wrap-ansi": { 3048 | "version": "7.0.0", 3049 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3050 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3051 | "dev": true, 3052 | "requires": { 3053 | "ansi-styles": "^4.0.0", 3054 | "string-width": "^4.1.0", 3055 | "strip-ansi": "^6.0.0" 3056 | } 3057 | }, 3058 | "wrappy": { 3059 | "version": "1.0.2", 3060 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3061 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3062 | "dev": true 3063 | }, 3064 | "y18n": { 3065 | "version": "5.0.8", 3066 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3067 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3068 | "dev": true 3069 | }, 3070 | "yargs": { 3071 | "version": "16.2.0", 3072 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3073 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3074 | "dev": true, 3075 | "requires": { 3076 | "cliui": "^7.0.2", 3077 | "escalade": "^3.1.1", 3078 | "get-caller-file": "^2.0.5", 3079 | "require-directory": "^2.1.1", 3080 | "string-width": "^4.2.0", 3081 | "y18n": "^5.0.5", 3082 | "yargs-parser": "^20.2.2" 3083 | } 3084 | }, 3085 | "yargs-parser": { 3086 | "version": "20.2.4", 3087 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 3088 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 3089 | "dev": true 3090 | }, 3091 | "yargs-unparser": { 3092 | "version": "2.0.0", 3093 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 3094 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 3095 | "dev": true, 3096 | "requires": { 3097 | "camelcase": "^6.0.0", 3098 | "decamelize": "^4.0.0", 3099 | "flat": "^5.0.2", 3100 | "is-plain-obj": "^2.1.0" 3101 | } 3102 | }, 3103 | "yocto-queue": { 3104 | "version": "0.1.0", 3105 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3106 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3107 | "dev": true 3108 | } 3109 | } 3110 | } 3111 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "csv-reader", 3 | "version": "1.0.12", 4 | "description": "A CSV stream reader, with many many features, and ability to work with the largest datasets", 5 | "main": "index.js", 6 | "types": "index.d.ts", 7 | "scripts": { 8 | "lint": "eslint -f codeframe ./", 9 | "lint-fix": "eslint -f codeframe --fix ./", 10 | "test": "npm run lint && mocha ./tests/**/*test.js", 11 | "prepublishOnly": "pinst --disable", 12 | "postpublish": "pinst --enable" 13 | }, 14 | "repository": { 15 | "type": "git", 16 | "url": "https://github.com/danielgindi/node-csv-reader" 17 | }, 18 | "engines": { 19 | "node": ">=8.0.0" 20 | }, 21 | "keywords": [ 22 | "node.js", 23 | "csv", 24 | "reader", 25 | "parser", 26 | "stream", 27 | "fast" 28 | ], 29 | "author": "Daniel Cohen Gindi (https://github.com/danielgindi)", 30 | "license": "MIT", 31 | "bugs": { 32 | "url": "https://github.com/danielgindi/node-csv-reader/issues" 33 | }, 34 | "homepage": "https://github.com/danielgindi/node-csv-reader", 35 | "dependencies": {}, 36 | "devDependencies": { 37 | "eslint": "^8.29.0", 38 | "eslint-formatter-codeframe": "^7.32.1", 39 | "husky": "^8.0.2", 40 | "mocha": "^10.0.0", 41 | "pinst": "^3.0.0" 42 | } 43 | } 44 | -------------------------------------------------------------------------------- /tests/basic.test.js: -------------------------------------------------------------------------------- 1 | const assert = require('assert'); 2 | const Fs = require('fs'); 3 | const Path = require('path'); 4 | const CsvReadableStream = require('../index.js'); 5 | 6 | describe('End to end', async () => { 7 | 8 | it(`Test basic csv read with skipping header`, async () => { 9 | let [header, output] = await new Promise((resolve, reject) => { 10 | let inputStream = Fs.createReadStream(Path.join(__dirname, 'test-header.csv'), 'utf8'); 11 | let header = null; 12 | let output = []; 13 | 14 | inputStream 15 | .pipe(new CsvReadableStream({ 16 | parseNumbers: true, 17 | parseBooleans: true, 18 | trim: true, 19 | skipHeader: true, 20 | })) 21 | .on('header', row => { 22 | header = row; 23 | }) 24 | .on('data', row => { 25 | output.push(row); 26 | }) 27 | .on('end', () => { 28 | resolve([header, output]); 29 | }) 30 | .on('error', err => { 31 | reject(err); 32 | }); 33 | }); 34 | 35 | assert.deepEqual(header, [ 36 | 'NAME', 'AGE', 'ALIVE', 37 | ]); 38 | 39 | assert.deepEqual(output, [ 40 | ['John Smith', 50, false], 41 | ['Jane Doe', 25, true], 42 | ]); 43 | }); 44 | 45 | it(`Test basic csv read with skipLines=1`, async () => { 46 | let [header, output] = await new Promise((resolve, reject) => { 47 | let inputStream = Fs.createReadStream(Path.join(__dirname, 'test-header.csv'), 'utf8'); 48 | let header = null; 49 | let output = []; 50 | 51 | inputStream 52 | .pipe(new CsvReadableStream({ 53 | parseNumbers: true, 54 | parseBooleans: true, 55 | trim: true, 56 | skipLines: 1, 57 | })) 58 | .on('header', row => { 59 | header = row; 60 | }) 61 | .on('data', row => { 62 | output.push(row); 63 | }) 64 | .on('end', () => { 65 | resolve([header, output]); 66 | }) 67 | .on('error', err => { 68 | reject(err); 69 | }); 70 | }); 71 | 72 | assert.deepEqual(header, [ 73 | 'NAME', 'AGE', 'ALIVE', 74 | ]); 75 | 76 | assert.deepEqual(output, [ 77 | ['John Smith', 50, false], 78 | ['Jane Doe', 25, true], 79 | ]); 80 | }); 81 | 82 | it(`Test basic csv read with skipLines=2`, async () => { 83 | let [header, output] = await new Promise((resolve, reject) => { 84 | let inputStream = Fs.createReadStream(Path.join(__dirname, 'test-header.csv'), 'utf8'); 85 | let header = null; 86 | let output = []; 87 | 88 | inputStream 89 | .pipe(new CsvReadableStream({ 90 | parseNumbers: true, 91 | parseBooleans: true, 92 | trim: true, 93 | skipLines: 2, 94 | })) 95 | .on('header', row => { 96 | header = row; 97 | }) 98 | .on('data', row => { 99 | output.push(row); 100 | }) 101 | .on('end', () => { 102 | resolve([header, output]); 103 | }) 104 | .on('error', err => { 105 | reject(err); 106 | }); 107 | }); 108 | 109 | assert.deepEqual(header, [ 110 | 'NAME', 'AGE', 'ALIVE', 111 | ]); 112 | 113 | assert.deepEqual(output, [ 114 | ['Jane Doe', 25, true], 115 | ]); 116 | }); 117 | 118 | it(`Test basic csv read with object mapped rows`, async () => { 119 | let [header, output] = await new Promise((resolve, reject) => { 120 | let inputStream = Fs.createReadStream(Path.join(__dirname, 'test-header.csv'), 'utf8'); 121 | let header = null; 122 | let output = []; 123 | 124 | inputStream 125 | .pipe(new CsvReadableStream({ 126 | parseNumbers: true, 127 | parseBooleans: true, 128 | trim: true, 129 | asObject: true, 130 | })) 131 | .on('header', row => { 132 | header = row; 133 | }) 134 | .on('data', row => { 135 | output.push(row); 136 | }) 137 | .on('end', () => { 138 | resolve([header, output]); 139 | }) 140 | .on('error', err => { 141 | reject(err); 142 | }); 143 | }); 144 | 145 | assert.deepEqual(header, [ 146 | 'NAME', 'AGE', 'ALIVE', 147 | ]); 148 | 149 | assert.deepEqual(output, [ 150 | { NAME: 'John Smith', AGE: 50, ALIVE: false }, 151 | { NAME: 'Jane Doe', AGE: 25, ALIVE: true }, 152 | ]); 153 | }); 154 | 155 | it(`Test basic csv read with quoted values`, async () => { 156 | let [header, output] = await new Promise((resolve, reject) => { 157 | let inputStream = Fs.createReadStream(Path.join(__dirname, 'test-quoted.csv'), 'utf8'); 158 | let header = null; 159 | let output = []; 160 | 161 | inputStream 162 | .pipe(new CsvReadableStream({ 163 | parseNumbers: true, 164 | parseBooleans: true, 165 | trim: true, 166 | asObject: true, 167 | })) 168 | .on('header', row => { 169 | header = row; 170 | }) 171 | .on('data', row => { 172 | output.push(row); 173 | }) 174 | .on('end', () => { 175 | resolve([header, output]); 176 | }) 177 | .on('error', err => { 178 | reject(err); 179 | }); 180 | }); 181 | 182 | assert.deepEqual(header, [ 183 | 'NAME', 'AGE', 'ALIVE', 184 | ]); 185 | 186 | assert.deepEqual(output, [ 187 | { NAME: 'John Smith', AGE: 50, ALIVE: false }, 188 | { NAME: 'Jane, Doe', AGE: 25, ALIVE: true }, 189 | ]); 190 | }); 191 | 192 | it(`Test basic csv read with parsed numbers and booleans`, async () => { 193 | let output = await new Promise((resolve, reject) => { 194 | let inputStream = Fs.createReadStream(Path.join(__dirname, 'test-auto-parse.csv'), 'utf8'); 195 | let output = []; 196 | 197 | inputStream 198 | .pipe(new CsvReadableStream({ 199 | parseNumbers: true, 200 | parseBooleans: true, 201 | trim: true, 202 | asObject: false, 203 | skipLines: 1, 204 | })) 205 | .on('data', row => { 206 | output.push(row[0]); 207 | }) 208 | .on('end', () => { 209 | resolve(output); 210 | }) 211 | .on('error', err => { 212 | reject(err); 213 | }); 214 | }); 215 | 216 | assert.deepStrictEqual(output, [ 217 | 0, 123, 123, -123, 218 | NaN, -NaN, 219 | Infinity, -Infinity, 220 | 2.343240e+6, -2.343240e+6, // eslint-disable-line no-loss-of-precision 221 | true, false, 222 | ]); 223 | }); 224 | 225 | it(`Test basic csv error emit`, async () => { 226 | 227 | await assert.rejects(new Promise((resolve, reject) => { 228 | let inputStream = Fs.createReadStream(Path.join(__dirname, 'test-auto-parse.csv'), 'utf8'); 229 | let output = []; 230 | 231 | inputStream 232 | .pipe(new CsvReadableStream({ 233 | parseNumbers: true, 234 | parseBooleans: true, 235 | trim: true, 236 | asObject: false, 237 | skipLines: 1, 238 | })) 239 | .on('data', () => { 240 | throw new Error('Error while reading data'); 241 | }) 242 | .on('end', () => { 243 | resolve(output); 244 | }) 245 | .on('error', err => { 246 | reject(err); 247 | }); 248 | }), (err) => { 249 | assert.deepStrictEqual(err.message, 'Error while reading data'); 250 | return true; 251 | }); 252 | }); 253 | }); 254 | -------------------------------------------------------------------------------- /tests/header.test.js: -------------------------------------------------------------------------------- 1 | const assert = require("assert"); 2 | const Fs = require("fs"); 3 | const Path = require("path"); 4 | const CsvReadableStream = require("../index.js"); 5 | 6 | describe("Header Processing", async () => { 7 | it(`Test setting header line`, async () => { 8 | let [header, output] = await new Promise((resolve, reject) => { 9 | let inputStream = Fs.createReadStream( 10 | Path.join(__dirname, "test-header-after-preamble.csv"), 11 | "utf8", 12 | ); 13 | let header = null; 14 | let output = []; 15 | 16 | inputStream 17 | .pipe( 18 | new CsvReadableStream({ 19 | headerLine: 4, 20 | }), 21 | ) 22 | .on("header", (row) => { 23 | header = row; 24 | }) 25 | .on("data", (row) => { 26 | output.push(row); 27 | }) 28 | .on("end", () => { 29 | resolve([header, output]); 30 | }) 31 | .on("error", (err) => { 32 | reject(err); 33 | }); 34 | }); 35 | 36 | assert.deepEqual(header, ["NAME", "AGE", "ALIVE"]); 37 | 38 | assert.deepEqual(output, [ 39 | ["John Smith", "50", "false"], 40 | ["Jane Doe", "25", "true"], 41 | ]); 42 | }); 43 | 44 | it(`Test setting header line and skip a line`, async () => { 45 | let [header, output] = await new Promise((resolve, reject) => { 46 | let inputStream = Fs.createReadStream( 47 | Path.join(__dirname, "test-header-after-preamble.csv"), 48 | "utf8", 49 | ); 50 | let header = null; 51 | let output = []; 52 | 53 | inputStream 54 | .pipe( 55 | new CsvReadableStream({ 56 | headerLine: 4, 57 | skipLines: 1, 58 | }), 59 | ) 60 | .on("header", (row) => { 61 | header = row; 62 | }) 63 | .on("data", (row) => { 64 | output.push(row); 65 | }) 66 | .on("end", () => { 67 | resolve([header, output]); 68 | }) 69 | .on("error", (err) => { 70 | reject(err); 71 | }); 72 | }); 73 | 74 | assert.deepEqual(header, ["NAME", "AGE", "ALIVE"]); 75 | 76 | assert.deepEqual(output, [ 77 | ["Jane Doe", "25", "true"], 78 | ]); 79 | }); 80 | 81 | it(`Test setting header line with object mapped rows`, async () => { 82 | let [header, output] = await new Promise((resolve, reject) => { 83 | let inputStream = Fs.createReadStream(Path.join(__dirname, 'test-header-after-preamble.csv'), 'utf8'); 84 | let header = null; 85 | let output = []; 86 | 87 | inputStream 88 | .pipe(new CsvReadableStream({ 89 | parseNumbers: true, 90 | parseBooleans: true, 91 | trim: true, 92 | asObject: true, 93 | headerLine: 4, 94 | })) 95 | .on('header', row => { 96 | header = row; 97 | }) 98 | .on('data', row => { 99 | output.push(row); 100 | }) 101 | .on('end', () => { 102 | resolve([header, output]); 103 | }) 104 | .on('error', err => { 105 | reject(err); 106 | }); 107 | }); 108 | 109 | assert.deepEqual(header, [ 110 | 'NAME', 'AGE', 'ALIVE', 111 | ]); 112 | 113 | assert.deepEqual(output, [ 114 | { NAME: 'John Smith', AGE: 50, ALIVE: false }, 115 | { NAME: 'Jane Doe', AGE: 25, ALIVE: true }, 116 | ]); 117 | }); 118 | 119 | 120 | }); 121 | -------------------------------------------------------------------------------- /tests/test-auto-parse.csv: -------------------------------------------------------------------------------- 1 | VALUE 2 | 0 3 | 123 4 | 123 5 | -123 6 | NaN 7 | -NaN 8 | Infinity 9 | -Infinity 10 | 2.343240e+6 11 | -2.343240e+6 12 | true 13 | false -------------------------------------------------------------------------------- /tests/test-header-after-preamble.csv: -------------------------------------------------------------------------------- 1 | Some lines before the data,, 2 | ,, 3 | ,, 4 | NAME,AGE,ALIVE 5 | John Smith,50,false 6 | Jane Doe,25,true 7 | -------------------------------------------------------------------------------- /tests/test-header.csv: -------------------------------------------------------------------------------- 1 | NAME,AGE,ALIVE 2 | John Smith,50,false 3 | Jane Doe,25,true 4 | -------------------------------------------------------------------------------- /tests/test-quoted.csv: -------------------------------------------------------------------------------- 1 | NAME,AGE,ALIVE 2 | "John Smith",50,false 3 | "Jane, Doe",25,true 4 | --------------------------------------------------------------------------------