├── .eslintrc.js ├── .gitattributes ├── .github └── workflows │ └── CI.yaml ├── .gitignore ├── .vscode ├── extensions.json ├── launch.json ├── settings.json └── tasks.json ├── .vscodeignore ├── CHANGELOG.md ├── README.md ├── cmds ├── build.sh ├── ci.sh └── test.sh ├── package-lock.json ├── package.json ├── src ├── configResolver.ts ├── extension.ts ├── main.ts └── test │ ├── runTest.ts │ └── suite │ ├── fixImports.test.ts │ ├── index.ts │ ├── relativize.unix.test.ts │ └── relativize.windows.test.ts ├── tsconfig.json └── tslint.json /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | 'env': { 3 | 'es6': true, 4 | 'node': true, 5 | }, 6 | 'extends': [ 7 | 'eslint:recommended', 8 | 'plugin:@typescript-eslint/eslint-recommended', 9 | 'plugin:@typescript-eslint/recommended', 10 | ], 11 | 'globals': { 12 | 'Atomics': 'readonly', 13 | 'SharedArrayBuffer': 'readonly', 14 | }, 15 | 'parser': '@typescript-eslint/parser', 16 | 'parserOptions': { 17 | 'ecmaVersion': 11, 18 | 'sourceType': 'module', 19 | }, 20 | 'plugins': [ 21 | '@typescript-eslint', 22 | ], 23 | 'rules': { 24 | 'indent': [ 25 | 'error', 26 | 4, 27 | ], 28 | 'linebreak-style': [ 29 | 'error', 30 | 'unix', 31 | ], 32 | 'quotes': [ 33 | 'error', 34 | 'single', 35 | ], 36 | 'semi': [ 37 | 'error', 38 | 'always', 39 | ], 40 | 'comma-dangle': ['error', 'always-multiline'], 41 | }, 42 | }; 43 | -------------------------------------------------------------------------------- /.gitattributes: -------------------------------------------------------------------------------- 1 | # Set default behavior to automatically normalize line endings. 2 | * text=auto 3 | 4 | -------------------------------------------------------------------------------- /.github/workflows/CI.yaml: -------------------------------------------------------------------------------- 1 | name: CI 2 | 3 | on: push 4 | 5 | jobs: 6 | build: 7 | strategy: 8 | matrix: 9 | os: [macos-latest, ubuntu-latest, windows-latest] 10 | runs-on: ${{ matrix.os }} 11 | 12 | steps: 13 | - uses: actions/checkout@v1 14 | - name: Using Node 14.3.0 15 | uses: actions/setup-node@v1 16 | with: 17 | node-version: 14.3.0 18 | - run: npm install 19 | - name: Run Tests 20 | uses: GabrielBB/xvfb-action@v1.2 21 | with: 22 | run: ./cmds/ci.sh -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | out 2 | node_modules 3 | .vscode-test/ 4 | *.vsix 5 | -------------------------------------------------------------------------------- /.vscode/extensions.json: -------------------------------------------------------------------------------- 1 | { 2 | // See http://go.microsoft.com/fwlink/?LinkId=827846 3 | // for the documentation about the extensions.json format 4 | "recommendations": [ 5 | "eg2.tslint" 6 | ] 7 | } -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | // A launch configuration that compiles the extension and then opens it inside a new window 2 | // Use IntelliSense to learn about possible attributes. 3 | // Hover to view descriptions of existing attributes. 4 | // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 5 | { 6 | "version": "0.2.0", 7 | "configurations": [ 8 | { 9 | "name": "Extension", 10 | "type": "extensionHost", 11 | "request": "launch", 12 | "runtimeExecutable": "${execPath}", 13 | "args": [ 14 | "--extensionDevelopmentPath=${workspaceFolder}" 15 | ], 16 | "outFiles": [ 17 | "${workspaceFolder}/out/**/*.js" 18 | ], 19 | "preLaunchTask": "npm: watch" 20 | }, 21 | { 22 | "name": "Extension Tests", 23 | "type": "extensionHost", 24 | "request": "launch", 25 | "runtimeExecutable": "${execPath}", 26 | "args": [ 27 | "--extensionDevelopmentPath=${workspaceFolder}", 28 | "--extensionTestsPath=${workspaceFolder}/out/test" 29 | ], 30 | "outFiles": [ 31 | "${workspaceFolder}/out/test/**/*.js" 32 | ], 33 | "preLaunchTask": "npm: watch" 34 | } 35 | ] 36 | } 37 | -------------------------------------------------------------------------------- /.vscode/settings.json: -------------------------------------------------------------------------------- 1 | // Place your settings in this file to overwrite default and user settings. 2 | { 3 | "files.exclude": { 4 | "out": false // set this to true to hide the "out" folder with the compiled JS files 5 | }, 6 | "search.exclude": { 7 | "out": true // set this to false to include "out" folder in search results 8 | }, 9 | // Turn off tsc task auto detection since we have the necessary tasks as npm scripts 10 | "typescript.tsc.autoDetect": "off", 11 | "spellright.language": [], 12 | "spellright.documentTypes": [ 13 | "latex", 14 | "plaintext" 15 | ] 16 | } -------------------------------------------------------------------------------- /.vscode/tasks.json: -------------------------------------------------------------------------------- 1 | // See https://go.microsoft.com/fwlink/?LinkId=733558 2 | // for the documentation about the tasks.json format 3 | { 4 | "version": "2.0.0", 5 | "tasks": [ 6 | { 7 | "type": "npm", 8 | "script": "watch", 9 | "problemMatcher": "$tsc-watch", 10 | "isBackground": true, 11 | "presentation": { 12 | "reveal": "never" 13 | }, 14 | "group": { 15 | "kind": "build", 16 | "isDefault": true 17 | } 18 | } 19 | ] 20 | } -------------------------------------------------------------------------------- /.vscodeignore: -------------------------------------------------------------------------------- 1 | .vscode/** 2 | .vscode-test/** 3 | out/test/** 4 | out/**/*.map 5 | src/** 6 | .gitignore 7 | tsconfig.json 8 | vsc-extension-quickstart.md 9 | tslint.json -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Change Log 2 | 3 | ## [0.3.1] - 2020-10-11 4 | - Add config options for now showing messages and running on save 5 | - Standardizing `./` for relative imports 6 | 7 | ## [0.3.0] - 2020-09-20 8 | - Add the option to fix all imports 9 | 10 | ## [0.1.6] - 2019-12-24 11 | - Allows for folders with multiple projects (thanks, @shroudedcode) 12 | 13 | ## [0.1.5] - 2019-10-27 14 | - Refactored code to make 100% of the logic testable and decoupled with vscode code (main.ts file vs extension.ts file) 15 | - Added support for import aliases (as, show, hide) 16 | 17 | ## [0.1.4] - 2019-10-27 18 | - Allows this to work on both unix and windows systems (thanks, @ElZombieIsra) 19 | - Updating dependencies 20 | 21 | ## [0.1.3] - 2019-08-11 22 | - Allowed for fixing imports in multi-project workspaces (thanks, @shyndman) 23 | - Updating dependencies 24 | 25 | ## [0.1.2] - 2019-02-12 26 | - Better error messages. 27 | 28 | ## [0.1.1] - 2019-02-11 29 | - Fix regex, also update deps. 30 | 31 | ## [0.1.0] - 2018-07-12 32 | - Fix for files directly in the lib/ folder. 33 | 34 | ## [0.0.1] - 2018-07-02 35 | - Initial release, "Fix Imports" feature. 36 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # dart-import 2 | 3 | [![CI Status](https://raster.shields.io/github/workflow/status/luanpotter/vscode-dart-import/CI/master)](https://github.com/luanpotter/vscode-dart-import/actions?query=workflow%3ACI) 4 | [![Latest Release](https://raster.shields.io/github/v/release/luanpotter/vscode-dart-import)](https://github.com/luanpotter/vscode-dart-import/releases) 5 | 6 | A simple plugin for VSCode to change all Dart/Flutter imports to relative format. 7 | 8 | Find it on the [VSCode Marketplace](https://marketplace.visualstudio.com/items?itemName=luanpotter.dart-import). 9 | 10 | ## Features 11 | 12 | Run the command "Fix Imports" from the Command Palette; all imports from your own package will become relative. Also, the "Organize Import" command will be called. 13 | 14 | The only command added (so far) is "dart-import.fix"; you can bind it as desired. 15 | 16 | ## Contribute 17 | 18 | Any help is appreciated! Comment, suggestions, issues, PR's! Give us a star to help! 19 | 20 | ## Setup 21 | 22 | This is a regular vscode extension setup. You can use the scripts in the `package.json` file to test. 23 | 24 | To setup, run `npm i` to download dependencies. 25 | 26 | Then, you can run `npm test` to run the tests, make sure they are passing. 27 | 28 | To test in your machine, run `npm run package` to create a new VSIX file, and then use vscode's built in command `Extensions: Install from VSIX...` (from command palette) to load your version. 29 | 30 | In order to deploy, run `npm run deploy`. If your PAT token is expired, go to [this page](https://your_username.visualstudio.com/_usersSettings/tokens) to get a new one. 31 | -------------------------------------------------------------------------------- /cmds/build.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash -e 2 | 3 | rm -rf out *.vsix 4 | 5 | npm run compile 6 | -------------------------------------------------------------------------------- /cmds/ci.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash -e 2 | 3 | npm run lint 4 | ./cmds/build.sh 5 | npm run test 6 | -------------------------------------------------------------------------------- /cmds/test.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash -e 2 | 3 | ./cmds/build.sh 4 | npm run test 5 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "dart-import", 3 | "version": "0.3.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.5.5", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.5.5.tgz", 10 | "integrity": "sha512-27d4lZoomVyo51VegxI20xZPuSHusqbQag/ztrBC7wegWoQ1nLREPVSKSW8byhTlzTKyNE4ifaTA6lCp7JjpFw==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.0.0" 14 | } 15 | }, 16 | "@babel/highlight": { 17 | "version": "7.5.0", 18 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.5.0.tgz", 19 | "integrity": "sha512-7dV4eu9gBxoM0dAnj/BCFDW9LFU0zvTrkq0ugM7pnHEgguOEeOz1so2ZghEdzviYzQEED0r4EAgpsBChKy1TRQ==", 20 | "dev": true, 21 | "requires": { 22 | "chalk": "^2.0.0", 23 | "esutils": "^2.0.2", 24 | "js-tokens": "^4.0.0" 25 | } 26 | }, 27 | "@types/color-name": { 28 | "version": "1.1.1", 29 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 30 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 31 | "dev": true 32 | }, 33 | "@types/eslint-visitor-keys": { 34 | "version": "1.0.0", 35 | "resolved": "https://registry.npmjs.org/@types/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 36 | "integrity": "sha512-OCutwjDZ4aFS6PB1UZ988C4YgwlBHJd6wCeQqaLdmadZ/7e+w79+hbMUFC1QXDNCmdyoRfAFdm0RypzwR+Qpag==", 37 | "dev": true 38 | }, 39 | "@types/events": { 40 | "version": "3.0.0", 41 | "resolved": "https://registry.npmjs.org/@types/events/-/events-3.0.0.tgz", 42 | "integrity": "sha512-EaObqwIvayI5a8dCzhFrjKzVwKLxjoG9T6Ppd5CEo07LRKfQ8Yokw54r5+Wq7FaBQ+yXRvQAYPrHwya1/UFt9g==", 43 | "dev": true 44 | }, 45 | "@types/glob": { 46 | "version": "7.1.1", 47 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.1.1.tgz", 48 | "integrity": "sha512-1Bh06cbWJUHMC97acuD6UMG29nMt0Aqz1vF3guLfG+kHHJhy3AyohZFFxYk2f7Q1SQIrNwvncxAE0N/9s70F2w==", 49 | "dev": true, 50 | "requires": { 51 | "@types/events": "*", 52 | "@types/minimatch": "*", 53 | "@types/node": "*" 54 | } 55 | }, 56 | "@types/json-schema": { 57 | "version": "7.0.4", 58 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.4.tgz", 59 | "integrity": "sha512-8+KAKzEvSUdeo+kmqnKrqgeE+LcA0tjYWFY7RPProVYwnqDjukzO+3b6dLD56rYX5TdWejnEOLJYOIeh4CXKuA==", 60 | "dev": true 61 | }, 62 | "@types/minimatch": { 63 | "version": "3.0.3", 64 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz", 65 | "integrity": "sha512-tHq6qdbT9U1IRSGf14CL0pUlULksvY9OZ+5eEgl1N7t+OA3tGvNpxJCzuKQlsNgCVwbAs670L1vcVQi8j9HjnA==", 66 | "dev": true 67 | }, 68 | "@types/mocha": { 69 | "version": "7.0.2", 70 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-7.0.2.tgz", 71 | "integrity": "sha512-ZvO2tAcjmMi8V/5Z3JsyofMe3hasRcaw88cto5etSVMwVQfeivGAlEYmaQgceUSVYFofVjT+ioHsATjdWcFt1w==", 72 | "dev": true 73 | }, 74 | "@types/node": { 75 | "version": "14.0.6", 76 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.0.6.tgz", 77 | "integrity": "sha512-FbNmu4F67d3oZMWBV6Y4MaPER+0EpE9eIYf2yaHhCWovc1dlXCZkqGX4NLHfVVr6umt20TNBdRzrNJIzIKfdbw==", 78 | "dev": true 79 | }, 80 | "@types/vscode": { 81 | "version": "1.45.1", 82 | "resolved": "https://registry.npmjs.org/@types/vscode/-/vscode-1.45.1.tgz", 83 | "integrity": "sha512-0NO9qrrEJBO8FsqHCrFMgR2suKnwCsKBWvRSb2OzH5gs4i3QO5AhEMQYrSzDbU/wLPt7N617/rN9lPY213gmwg==", 84 | "dev": true 85 | }, 86 | "@typescript-eslint/eslint-plugin": { 87 | "version": "3.0.2", 88 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-3.0.2.tgz", 89 | "integrity": "sha512-ER3bSS/A/pKQT/hjMGCK8UQzlL0yLjuCZ/G8CDFJFVTfl3X65fvq2lNYqOG8JPTfrPa2RULCdwfOyFjZEMNExQ==", 90 | "dev": true, 91 | "requires": { 92 | "@typescript-eslint/experimental-utils": "3.0.2", 93 | "functional-red-black-tree": "^1.0.1", 94 | "regexpp": "^3.0.0", 95 | "semver": "^7.3.2", 96 | "tsutils": "^3.17.1" 97 | }, 98 | "dependencies": { 99 | "semver": { 100 | "version": "7.3.2", 101 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 102 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 103 | "dev": true 104 | } 105 | } 106 | }, 107 | "@typescript-eslint/experimental-utils": { 108 | "version": "3.0.2", 109 | "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-3.0.2.tgz", 110 | "integrity": "sha512-4Wc4EczvoY183SSEnKgqAfkj1eLtRgBQ04AAeG+m4RhTVyaazxc1uI8IHf0qLmu7xXe9j1nn+UoDJjbmGmuqXQ==", 111 | "dev": true, 112 | "requires": { 113 | "@types/json-schema": "^7.0.3", 114 | "@typescript-eslint/typescript-estree": "3.0.2", 115 | "eslint-scope": "^5.0.0", 116 | "eslint-utils": "^2.0.0" 117 | } 118 | }, 119 | "@typescript-eslint/parser": { 120 | "version": "3.0.2", 121 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-3.0.2.tgz", 122 | "integrity": "sha512-80Z7s83e8QXHNUspqVlWwb4t5gdz/1bBBmafElbK1wwAwiD/yvJsFyHRxlEpNrt4rdK6eB3p+2WEFkEDHAKk9w==", 123 | "dev": true, 124 | "requires": { 125 | "@types/eslint-visitor-keys": "^1.0.0", 126 | "@typescript-eslint/experimental-utils": "3.0.2", 127 | "@typescript-eslint/typescript-estree": "3.0.2", 128 | "eslint-visitor-keys": "^1.1.0" 129 | } 130 | }, 131 | "@typescript-eslint/typescript-estree": { 132 | "version": "3.0.2", 133 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-3.0.2.tgz", 134 | "integrity": "sha512-cs84mxgC9zQ6viV8MEcigfIKQmKtBkZNDYf8Gru2M+MhnA6z9q0NFMZm2IEzKqAwN8lY5mFVd1Z8DiHj6zQ3Tw==", 135 | "dev": true, 136 | "requires": { 137 | "debug": "^4.1.1", 138 | "eslint-visitor-keys": "^1.1.0", 139 | "glob": "^7.1.6", 140 | "is-glob": "^4.0.1", 141 | "lodash": "^4.17.15", 142 | "semver": "^7.3.2", 143 | "tsutils": "^3.17.1" 144 | }, 145 | "dependencies": { 146 | "debug": { 147 | "version": "4.1.1", 148 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 149 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 150 | "dev": true, 151 | "requires": { 152 | "ms": "^2.1.1" 153 | } 154 | }, 155 | "glob": { 156 | "version": "7.1.6", 157 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 158 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 159 | "dev": true, 160 | "requires": { 161 | "fs.realpath": "^1.0.0", 162 | "inflight": "^1.0.4", 163 | "inherits": "2", 164 | "minimatch": "^3.0.4", 165 | "once": "^1.3.0", 166 | "path-is-absolute": "^1.0.0" 167 | } 168 | }, 169 | "ms": { 170 | "version": "2.1.2", 171 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 172 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 173 | "dev": true 174 | }, 175 | "semver": { 176 | "version": "7.3.2", 177 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 178 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 179 | "dev": true 180 | } 181 | } 182 | }, 183 | "acorn": { 184 | "version": "7.2.0", 185 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.2.0.tgz", 186 | "integrity": "sha512-apwXVmYVpQ34m/i71vrApRrRKCWQnZZF1+npOD0WV5xZFfwWOmKGQ2RWlfdy9vWITsenisM8M0Qeq8agcFHNiQ==", 187 | "dev": true 188 | }, 189 | "acorn-jsx": { 190 | "version": "5.2.0", 191 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.2.0.tgz", 192 | "integrity": "sha512-HiUX/+K2YpkpJ+SzBffkM/AQ2YE03S0U1kjTLVpoJdhZMOWy8qvXVN9JdLqv2QsaQ6MPYQIuNmwD8zOiYUofLQ==", 193 | "dev": true 194 | }, 195 | "agent-base": { 196 | "version": "4.3.0", 197 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-4.3.0.tgz", 198 | "integrity": "sha512-salcGninV0nPrwpGNn4VTXBb1SOuXQBiqbrNXoeizJsHrsL6ERFM2Ne3JUSBWRE6aeNJI2ROP/WEEIDUiDe3cg==", 199 | "dev": true, 200 | "requires": { 201 | "es6-promisify": "^5.0.0" 202 | } 203 | }, 204 | "ajv": { 205 | "version": "6.10.2", 206 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", 207 | "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", 208 | "dev": true, 209 | "requires": { 210 | "fast-deep-equal": "^2.0.1", 211 | "fast-json-stable-stringify": "^2.0.0", 212 | "json-schema-traverse": "^0.4.1", 213 | "uri-js": "^4.2.2" 214 | } 215 | }, 216 | "ansi-colors": { 217 | "version": "3.2.3", 218 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.3.tgz", 219 | "integrity": "sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw==", 220 | "dev": true 221 | }, 222 | "ansi-escapes": { 223 | "version": "4.3.1", 224 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.1.tgz", 225 | "integrity": "sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA==", 226 | "dev": true, 227 | "requires": { 228 | "type-fest": "^0.11.0" 229 | }, 230 | "dependencies": { 231 | "type-fest": { 232 | "version": "0.11.0", 233 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.11.0.tgz", 234 | "integrity": "sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ==", 235 | "dev": true 236 | } 237 | } 238 | }, 239 | "ansi-regex": { 240 | "version": "5.0.0", 241 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 242 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 243 | "dev": true 244 | }, 245 | "ansi-styles": { 246 | "version": "3.2.1", 247 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 248 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 249 | "dev": true, 250 | "requires": { 251 | "color-convert": "^1.9.0" 252 | } 253 | }, 254 | "anymatch": { 255 | "version": "3.1.1", 256 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", 257 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", 258 | "dev": true, 259 | "requires": { 260 | "normalize-path": "^3.0.0", 261 | "picomatch": "^2.0.4" 262 | } 263 | }, 264 | "argparse": { 265 | "version": "1.0.10", 266 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 267 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 268 | "dev": true, 269 | "requires": { 270 | "sprintf-js": "~1.0.2" 271 | } 272 | }, 273 | "astral-regex": { 274 | "version": "1.0.0", 275 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 276 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 277 | "dev": true 278 | }, 279 | "azure-devops-node-api": { 280 | "version": "7.2.0", 281 | "resolved": "https://registry.npmjs.org/azure-devops-node-api/-/azure-devops-node-api-7.2.0.tgz", 282 | "integrity": "sha512-pMfGJ6gAQ7LRKTHgiRF+8iaUUeGAI0c8puLaqHLc7B8AR7W6GJLozK9RFeUHFjEGybC9/EB3r67WPd7e46zQ8w==", 283 | "dev": true, 284 | "requires": { 285 | "os": "0.1.1", 286 | "tunnel": "0.0.4", 287 | "typed-rest-client": "1.2.0", 288 | "underscore": "1.8.3" 289 | } 290 | }, 291 | "balanced-match": { 292 | "version": "1.0.0", 293 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 294 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 295 | "dev": true 296 | }, 297 | "binary-extensions": { 298 | "version": "2.0.0", 299 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.0.0.tgz", 300 | "integrity": "sha512-Phlt0plgpIIBOGTT/ehfFnbNlfsDEiqmzE2KRXoX1bLIlir4X/MR+zSyBEkL05ffWgnRSf/DXv+WrUAVr93/ow==", 301 | "dev": true 302 | }, 303 | "boolbase": { 304 | "version": "1.0.0", 305 | "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", 306 | "integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=", 307 | "dev": true 308 | }, 309 | "brace-expansion": { 310 | "version": "1.1.11", 311 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 312 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 313 | "dev": true, 314 | "requires": { 315 | "balanced-match": "^1.0.0", 316 | "concat-map": "0.0.1" 317 | } 318 | }, 319 | "braces": { 320 | "version": "3.0.2", 321 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 322 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 323 | "dev": true, 324 | "requires": { 325 | "fill-range": "^7.0.1" 326 | } 327 | }, 328 | "browser-stdout": { 329 | "version": "1.3.1", 330 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 331 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 332 | "dev": true 333 | }, 334 | "buffer-crc32": { 335 | "version": "0.2.13", 336 | "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", 337 | "integrity": "sha1-DTM+PwDqxQqhRUq9MO+MKl2ackI=", 338 | "dev": true 339 | }, 340 | "callsites": { 341 | "version": "3.1.0", 342 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 343 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 344 | "dev": true 345 | }, 346 | "camelcase": { 347 | "version": "5.3.1", 348 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 349 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 350 | "dev": true 351 | }, 352 | "chalk": { 353 | "version": "2.4.2", 354 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 355 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 356 | "dev": true, 357 | "requires": { 358 | "ansi-styles": "^3.2.1", 359 | "escape-string-regexp": "^1.0.5", 360 | "supports-color": "^5.3.0" 361 | } 362 | }, 363 | "chardet": { 364 | "version": "0.7.0", 365 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 366 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 367 | "dev": true 368 | }, 369 | "cheerio": { 370 | "version": "1.0.0-rc.3", 371 | "resolved": "https://registry.npmjs.org/cheerio/-/cheerio-1.0.0-rc.3.tgz", 372 | "integrity": "sha512-0td5ijfUPuubwLUu0OBoe98gZj8C/AA+RW3v67GPlGOrvxWjZmBXiBCRU+I8VEiNyJzjth40POfHiz2RB3gImA==", 373 | "dev": true, 374 | "requires": { 375 | "css-select": "~1.2.0", 376 | "dom-serializer": "~0.1.1", 377 | "entities": "~1.1.1", 378 | "htmlparser2": "^3.9.1", 379 | "lodash": "^4.15.0", 380 | "parse5": "^3.0.1" 381 | } 382 | }, 383 | "chokidar": { 384 | "version": "3.3.0", 385 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.3.0.tgz", 386 | "integrity": "sha512-dGmKLDdT3Gdl7fBUe8XK+gAtGmzy5Fn0XkkWQuYxGIgWVPPse2CxFA5mtrlD0TOHaHjEUqkWNyP1XdHoJES/4A==", 387 | "dev": true, 388 | "requires": { 389 | "anymatch": "~3.1.1", 390 | "braces": "~3.0.2", 391 | "fsevents": "~2.1.1", 392 | "glob-parent": "~5.1.0", 393 | "is-binary-path": "~2.1.0", 394 | "is-glob": "~4.0.1", 395 | "normalize-path": "~3.0.0", 396 | "readdirp": "~3.2.0" 397 | } 398 | }, 399 | "cli-cursor": { 400 | "version": "3.1.0", 401 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 402 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 403 | "dev": true, 404 | "requires": { 405 | "restore-cursor": "^3.1.0" 406 | } 407 | }, 408 | "cli-width": { 409 | "version": "2.2.1", 410 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.1.tgz", 411 | "integrity": "sha512-GRMWDxpOB6Dgk2E5Uo+3eEBvtOOlimMmpbFiKuLFnQzYDavtLFY3K5ona41jgN/WdRZtG7utuVSVTL4HbZHGkw==", 412 | "dev": true 413 | }, 414 | "cliui": { 415 | "version": "5.0.0", 416 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 417 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 418 | "dev": true, 419 | "requires": { 420 | "string-width": "^3.1.0", 421 | "strip-ansi": "^5.2.0", 422 | "wrap-ansi": "^5.1.0" 423 | }, 424 | "dependencies": { 425 | "ansi-regex": { 426 | "version": "4.1.0", 427 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 428 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 429 | "dev": true 430 | }, 431 | "emoji-regex": { 432 | "version": "7.0.3", 433 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 434 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 435 | "dev": true 436 | }, 437 | "is-fullwidth-code-point": { 438 | "version": "2.0.0", 439 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 440 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 441 | "dev": true 442 | }, 443 | "string-width": { 444 | "version": "3.1.0", 445 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 446 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 447 | "dev": true, 448 | "requires": { 449 | "emoji-regex": "^7.0.1", 450 | "is-fullwidth-code-point": "^2.0.0", 451 | "strip-ansi": "^5.1.0" 452 | } 453 | }, 454 | "strip-ansi": { 455 | "version": "5.2.0", 456 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 457 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 458 | "dev": true, 459 | "requires": { 460 | "ansi-regex": "^4.1.0" 461 | } 462 | } 463 | } 464 | }, 465 | "color-convert": { 466 | "version": "1.9.3", 467 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 468 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 469 | "dev": true, 470 | "requires": { 471 | "color-name": "1.1.3" 472 | } 473 | }, 474 | "color-name": { 475 | "version": "1.1.3", 476 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 477 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 478 | "dev": true 479 | }, 480 | "commander": { 481 | "version": "6.1.0", 482 | "resolved": "https://registry.npmjs.org/commander/-/commander-6.1.0.tgz", 483 | "integrity": "sha512-wl7PNrYWd2y5mp1OK/LhTlv8Ff4kQJQRXXAvF+uU/TPNiVJUxZLRYGj/B0y/lPGAVcSbJqH2Za/cvHmrPMC8mA==", 484 | "dev": true 485 | }, 486 | "concat-map": { 487 | "version": "0.0.1", 488 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 489 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 490 | "dev": true 491 | }, 492 | "cross-spawn": { 493 | "version": "7.0.3", 494 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 495 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 496 | "dev": true, 497 | "requires": { 498 | "path-key": "^3.1.0", 499 | "shebang-command": "^2.0.0", 500 | "which": "^2.0.1" 501 | } 502 | }, 503 | "css-select": { 504 | "version": "1.2.0", 505 | "resolved": "https://registry.npmjs.org/css-select/-/css-select-1.2.0.tgz", 506 | "integrity": "sha1-KzoRBTnFNV8c2NMUYj6HCxIeyFg=", 507 | "dev": true, 508 | "requires": { 509 | "boolbase": "~1.0.0", 510 | "css-what": "2.1", 511 | "domutils": "1.5.1", 512 | "nth-check": "~1.0.1" 513 | } 514 | }, 515 | "css-what": { 516 | "version": "2.1.3", 517 | "resolved": "https://registry.npmjs.org/css-what/-/css-what-2.1.3.tgz", 518 | "integrity": "sha512-a+EPoD+uZiNfh+5fxw2nO9QwFa6nJe2Or35fGY6Ipw1R3R4AGz1d1TEZrCegvw2YTmZ0jXirGYlzxxpYSHwpEg==", 519 | "dev": true 520 | }, 521 | "debug": { 522 | "version": "3.1.0", 523 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 524 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 525 | "dev": true, 526 | "requires": { 527 | "ms": "2.0.0" 528 | } 529 | }, 530 | "decamelize": { 531 | "version": "1.2.0", 532 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 533 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 534 | "dev": true 535 | }, 536 | "deep-is": { 537 | "version": "0.1.3", 538 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 539 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 540 | "dev": true 541 | }, 542 | "define-properties": { 543 | "version": "1.1.3", 544 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 545 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 546 | "dev": true, 547 | "requires": { 548 | "object-keys": "^1.0.12" 549 | } 550 | }, 551 | "denodeify": { 552 | "version": "1.2.1", 553 | "resolved": "https://registry.npmjs.org/denodeify/-/denodeify-1.2.1.tgz", 554 | "integrity": "sha1-OjYof1A05pnnV3kBBSwubJQlFjE=", 555 | "dev": true 556 | }, 557 | "diff": { 558 | "version": "3.5.0", 559 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 560 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 561 | "dev": true 562 | }, 563 | "doctrine": { 564 | "version": "3.0.0", 565 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 566 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 567 | "dev": true, 568 | "requires": { 569 | "esutils": "^2.0.2" 570 | } 571 | }, 572 | "dom-serializer": { 573 | "version": "0.1.1", 574 | "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.1.1.tgz", 575 | "integrity": "sha512-l0IU0pPzLWSHBcieZbpOKgkIn3ts3vAh7ZuFyXNwJxJXk/c4Gwj9xaTJwIDVQCXawWD0qb3IzMGH5rglQaO0XA==", 576 | "dev": true, 577 | "requires": { 578 | "domelementtype": "^1.3.0", 579 | "entities": "^1.1.1" 580 | } 581 | }, 582 | "domelementtype": { 583 | "version": "1.3.1", 584 | "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz", 585 | "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==", 586 | "dev": true 587 | }, 588 | "domhandler": { 589 | "version": "2.4.2", 590 | "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.4.2.tgz", 591 | "integrity": "sha512-JiK04h0Ht5u/80fdLMCEmV4zkNh2BcoMFBmZ/91WtYZ8qVXSKjiw7fXMgFPnHcSZgOo3XdinHvmnDUeMf5R4wA==", 592 | "dev": true, 593 | "requires": { 594 | "domelementtype": "1" 595 | } 596 | }, 597 | "domutils": { 598 | "version": "1.5.1", 599 | "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.5.1.tgz", 600 | "integrity": "sha1-3NhIiib1Y9YQeeSMn3t+Mjc2gs8=", 601 | "dev": true, 602 | "requires": { 603 | "dom-serializer": "0", 604 | "domelementtype": "1" 605 | } 606 | }, 607 | "emoji-regex": { 608 | "version": "8.0.0", 609 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 610 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 611 | "dev": true 612 | }, 613 | "entities": { 614 | "version": "1.1.2", 615 | "resolved": "https://registry.npmjs.org/entities/-/entities-1.1.2.tgz", 616 | "integrity": "sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w==", 617 | "dev": true 618 | }, 619 | "es-abstract": { 620 | "version": "1.17.5", 621 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.5.tgz", 622 | "integrity": "sha512-BR9auzDbySxOcfog0tLECW8l28eRGpDpU3Dm3Hp4q/N+VtLTmyj4EUN088XZWQDW/hzj6sYRDXeOFsaAODKvpg==", 623 | "dev": true, 624 | "requires": { 625 | "es-to-primitive": "^1.2.1", 626 | "function-bind": "^1.1.1", 627 | "has": "^1.0.3", 628 | "has-symbols": "^1.0.1", 629 | "is-callable": "^1.1.5", 630 | "is-regex": "^1.0.5", 631 | "object-inspect": "^1.7.0", 632 | "object-keys": "^1.1.1", 633 | "object.assign": "^4.1.0", 634 | "string.prototype.trimleft": "^2.1.1", 635 | "string.prototype.trimright": "^2.1.1" 636 | } 637 | }, 638 | "es-to-primitive": { 639 | "version": "1.2.1", 640 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 641 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 642 | "dev": true, 643 | "requires": { 644 | "is-callable": "^1.1.4", 645 | "is-date-object": "^1.0.1", 646 | "is-symbol": "^1.0.2" 647 | } 648 | }, 649 | "es6-promise": { 650 | "version": "4.2.8", 651 | "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.8.tgz", 652 | "integrity": "sha512-HJDGx5daxeIvxdBxvG2cb9g4tEvwIk3i8+nhX0yGrYmZUzbkdg8QbDevheDB8gd0//uPj4c1EQua8Q+MViT0/w==", 653 | "dev": true 654 | }, 655 | "es6-promisify": { 656 | "version": "5.0.0", 657 | "resolved": "https://registry.npmjs.org/es6-promisify/-/es6-promisify-5.0.0.tgz", 658 | "integrity": "sha1-UQnWLz5W6pZ8S2NQWu8IKRyKUgM=", 659 | "dev": true, 660 | "requires": { 661 | "es6-promise": "^4.0.3" 662 | } 663 | }, 664 | "escape-string-regexp": { 665 | "version": "1.0.5", 666 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 667 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 668 | "dev": true 669 | }, 670 | "eslint": { 671 | "version": "7.1.0", 672 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.1.0.tgz", 673 | "integrity": "sha512-DfS3b8iHMK5z/YLSme8K5cge168I8j8o1uiVmFCgnnjxZQbCGyraF8bMl7Ju4yfBmCuxD7shOF7eqGkcuIHfsA==", 674 | "dev": true, 675 | "requires": { 676 | "@babel/code-frame": "^7.0.0", 677 | "ajv": "^6.10.0", 678 | "chalk": "^4.0.0", 679 | "cross-spawn": "^7.0.2", 680 | "debug": "^4.0.1", 681 | "doctrine": "^3.0.0", 682 | "eslint-scope": "^5.0.0", 683 | "eslint-utils": "^2.0.0", 684 | "eslint-visitor-keys": "^1.1.0", 685 | "espree": "^7.0.0", 686 | "esquery": "^1.2.0", 687 | "esutils": "^2.0.2", 688 | "file-entry-cache": "^5.0.1", 689 | "functional-red-black-tree": "^1.0.1", 690 | "glob-parent": "^5.0.0", 691 | "globals": "^12.1.0", 692 | "ignore": "^4.0.6", 693 | "import-fresh": "^3.0.0", 694 | "imurmurhash": "^0.1.4", 695 | "inquirer": "^7.0.0", 696 | "is-glob": "^4.0.0", 697 | "js-yaml": "^3.13.1", 698 | "json-stable-stringify-without-jsonify": "^1.0.1", 699 | "levn": "^0.4.1", 700 | "lodash": "^4.17.14", 701 | "minimatch": "^3.0.4", 702 | "natural-compare": "^1.4.0", 703 | "optionator": "^0.9.1", 704 | "progress": "^2.0.0", 705 | "regexpp": "^3.1.0", 706 | "semver": "^7.2.1", 707 | "strip-ansi": "^6.0.0", 708 | "strip-json-comments": "^3.1.0", 709 | "table": "^5.2.3", 710 | "text-table": "^0.2.0", 711 | "v8-compile-cache": "^2.0.3" 712 | }, 713 | "dependencies": { 714 | "ansi-styles": { 715 | "version": "4.2.1", 716 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 717 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 718 | "dev": true, 719 | "requires": { 720 | "@types/color-name": "^1.1.1", 721 | "color-convert": "^2.0.1" 722 | } 723 | }, 724 | "chalk": { 725 | "version": "4.0.0", 726 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.0.0.tgz", 727 | "integrity": "sha512-N9oWFcegS0sFr9oh1oz2d7Npos6vNoWW9HvtCg5N1KRFpUhaAhvTv5Y58g880fZaEYSNm3qDz8SU1UrGvp+n7A==", 728 | "dev": true, 729 | "requires": { 730 | "ansi-styles": "^4.1.0", 731 | "supports-color": "^7.1.0" 732 | } 733 | }, 734 | "color-convert": { 735 | "version": "2.0.1", 736 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 737 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 738 | "dev": true, 739 | "requires": { 740 | "color-name": "~1.1.4" 741 | } 742 | }, 743 | "color-name": { 744 | "version": "1.1.4", 745 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 746 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 747 | "dev": true 748 | }, 749 | "debug": { 750 | "version": "4.1.1", 751 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 752 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 753 | "dev": true, 754 | "requires": { 755 | "ms": "^2.1.1" 756 | } 757 | }, 758 | "has-flag": { 759 | "version": "4.0.0", 760 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 761 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 762 | "dev": true 763 | }, 764 | "ms": { 765 | "version": "2.1.2", 766 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 767 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 768 | "dev": true 769 | }, 770 | "semver": { 771 | "version": "7.3.2", 772 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 773 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 774 | "dev": true 775 | }, 776 | "supports-color": { 777 | "version": "7.1.0", 778 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 779 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 780 | "dev": true, 781 | "requires": { 782 | "has-flag": "^4.0.0" 783 | } 784 | } 785 | } 786 | }, 787 | "eslint-scope": { 788 | "version": "5.0.0", 789 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.0.0.tgz", 790 | "integrity": "sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw==", 791 | "dev": true, 792 | "requires": { 793 | "esrecurse": "^4.1.0", 794 | "estraverse": "^4.1.1" 795 | } 796 | }, 797 | "eslint-utils": { 798 | "version": "2.0.0", 799 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.0.0.tgz", 800 | "integrity": "sha512-0HCPuJv+7Wv1bACm8y5/ECVfYdfsAm9xmVb7saeFlxjPYALefjhbYoCkBjPdPzGH8wWyTpAez82Fh3VKYEZ8OA==", 801 | "dev": true, 802 | "requires": { 803 | "eslint-visitor-keys": "^1.1.0" 804 | } 805 | }, 806 | "eslint-visitor-keys": { 807 | "version": "1.1.0", 808 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", 809 | "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==", 810 | "dev": true 811 | }, 812 | "espree": { 813 | "version": "7.0.0", 814 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.0.0.tgz", 815 | "integrity": "sha512-/r2XEx5Mw4pgKdyb7GNLQNsu++asx/dltf/CI8RFi9oGHxmQFgvLbc5Op4U6i8Oaj+kdslhJtVlEZeAqH5qOTw==", 816 | "dev": true, 817 | "requires": { 818 | "acorn": "^7.1.1", 819 | "acorn-jsx": "^5.2.0", 820 | "eslint-visitor-keys": "^1.1.0" 821 | } 822 | }, 823 | "esprima": { 824 | "version": "4.0.1", 825 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 826 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 827 | "dev": true 828 | }, 829 | "esquery": { 830 | "version": "1.3.1", 831 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 832 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 833 | "dev": true, 834 | "requires": { 835 | "estraverse": "^5.1.0" 836 | }, 837 | "dependencies": { 838 | "estraverse": { 839 | "version": "5.1.0", 840 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.1.0.tgz", 841 | "integrity": "sha512-FyohXK+R0vE+y1nHLoBM7ZTyqRpqAlhdZHCWIWEviFLiGB8b04H6bQs8G+XTthacvT8VuwvteiP7RJSxMs8UEw==", 842 | "dev": true 843 | } 844 | } 845 | }, 846 | "esrecurse": { 847 | "version": "4.2.1", 848 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 849 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 850 | "dev": true, 851 | "requires": { 852 | "estraverse": "^4.1.0" 853 | } 854 | }, 855 | "estraverse": { 856 | "version": "4.3.0", 857 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 858 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 859 | "dev": true 860 | }, 861 | "esutils": { 862 | "version": "2.0.3", 863 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 864 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 865 | "dev": true 866 | }, 867 | "external-editor": { 868 | "version": "3.1.0", 869 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 870 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 871 | "dev": true, 872 | "requires": { 873 | "chardet": "^0.7.0", 874 | "iconv-lite": "^0.4.24", 875 | "tmp": "^0.0.33" 876 | }, 877 | "dependencies": { 878 | "tmp": { 879 | "version": "0.0.33", 880 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 881 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 882 | "dev": true, 883 | "requires": { 884 | "os-tmpdir": "~1.0.2" 885 | } 886 | } 887 | } 888 | }, 889 | "fast-deep-equal": { 890 | "version": "2.0.1", 891 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 892 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 893 | "dev": true 894 | }, 895 | "fast-json-stable-stringify": { 896 | "version": "2.0.0", 897 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 898 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 899 | "dev": true 900 | }, 901 | "fast-levenshtein": { 902 | "version": "2.0.6", 903 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 904 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 905 | "dev": true 906 | }, 907 | "fd-slicer": { 908 | "version": "1.1.0", 909 | "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", 910 | "integrity": "sha1-JcfInLH5B3+IkbvmHY85Dq4lbx4=", 911 | "dev": true, 912 | "requires": { 913 | "pend": "~1.2.0" 914 | } 915 | }, 916 | "figures": { 917 | "version": "3.2.0", 918 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", 919 | "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", 920 | "dev": true, 921 | "requires": { 922 | "escape-string-regexp": "^1.0.5" 923 | } 924 | }, 925 | "file-entry-cache": { 926 | "version": "5.0.1", 927 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 928 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 929 | "dev": true, 930 | "requires": { 931 | "flat-cache": "^2.0.1" 932 | } 933 | }, 934 | "fill-range": { 935 | "version": "7.0.1", 936 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 937 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 938 | "dev": true, 939 | "requires": { 940 | "to-regex-range": "^5.0.1" 941 | } 942 | }, 943 | "find-up": { 944 | "version": "3.0.0", 945 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 946 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 947 | "dev": true, 948 | "requires": { 949 | "locate-path": "^3.0.0" 950 | } 951 | }, 952 | "flat": { 953 | "version": "4.1.0", 954 | "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", 955 | "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", 956 | "dev": true, 957 | "requires": { 958 | "is-buffer": "~2.0.3" 959 | } 960 | }, 961 | "flat-cache": { 962 | "version": "2.0.1", 963 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 964 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 965 | "dev": true, 966 | "requires": { 967 | "flatted": "^2.0.0", 968 | "rimraf": "2.6.3", 969 | "write": "1.0.3" 970 | } 971 | }, 972 | "flatted": { 973 | "version": "2.0.2", 974 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz", 975 | "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==", 976 | "dev": true 977 | }, 978 | "fs.realpath": { 979 | "version": "1.0.0", 980 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 981 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 982 | "dev": true 983 | }, 984 | "fsevents": { 985 | "version": "2.1.3", 986 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz", 987 | "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==", 988 | "dev": true, 989 | "optional": true 990 | }, 991 | "function-bind": { 992 | "version": "1.1.1", 993 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 994 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 995 | "dev": true 996 | }, 997 | "functional-red-black-tree": { 998 | "version": "1.0.1", 999 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1000 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1001 | "dev": true 1002 | }, 1003 | "get-caller-file": { 1004 | "version": "2.0.5", 1005 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1006 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1007 | "dev": true 1008 | }, 1009 | "glob": { 1010 | "version": "7.1.6", 1011 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1012 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1013 | "dev": true, 1014 | "requires": { 1015 | "fs.realpath": "^1.0.0", 1016 | "inflight": "^1.0.4", 1017 | "inherits": "2", 1018 | "minimatch": "^3.0.4", 1019 | "once": "^1.3.0", 1020 | "path-is-absolute": "^1.0.0" 1021 | } 1022 | }, 1023 | "glob-parent": { 1024 | "version": "5.1.1", 1025 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 1026 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 1027 | "dev": true, 1028 | "requires": { 1029 | "is-glob": "^4.0.1" 1030 | } 1031 | }, 1032 | "globals": { 1033 | "version": "12.4.0", 1034 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 1035 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 1036 | "dev": true, 1037 | "requires": { 1038 | "type-fest": "^0.8.1" 1039 | } 1040 | }, 1041 | "growl": { 1042 | "version": "1.10.5", 1043 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 1044 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 1045 | "dev": true 1046 | }, 1047 | "has": { 1048 | "version": "1.0.3", 1049 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1050 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1051 | "dev": true, 1052 | "requires": { 1053 | "function-bind": "^1.1.1" 1054 | } 1055 | }, 1056 | "has-flag": { 1057 | "version": "3.0.0", 1058 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1059 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1060 | "dev": true 1061 | }, 1062 | "has-symbols": { 1063 | "version": "1.0.1", 1064 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 1065 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 1066 | "dev": true 1067 | }, 1068 | "he": { 1069 | "version": "1.2.0", 1070 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1071 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1072 | "dev": true 1073 | }, 1074 | "htmlparser2": { 1075 | "version": "3.10.1", 1076 | "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.10.1.tgz", 1077 | "integrity": "sha512-IgieNijUMbkDovyoKObU1DUhm1iwNYE/fuifEoEHfd1oZKZDaONBSkal7Y01shxsM49R4XaMdGez3WnF9UfiCQ==", 1078 | "dev": true, 1079 | "requires": { 1080 | "domelementtype": "^1.3.1", 1081 | "domhandler": "^2.3.0", 1082 | "domutils": "^1.5.1", 1083 | "entities": "^1.1.1", 1084 | "inherits": "^2.0.1", 1085 | "readable-stream": "^3.1.1" 1086 | } 1087 | }, 1088 | "http-proxy-agent": { 1089 | "version": "2.1.0", 1090 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-2.1.0.tgz", 1091 | "integrity": "sha512-qwHbBLV7WviBl0rQsOzH6o5lwyOIvwp/BdFnvVxXORldu5TmjFfjzBcWUWS5kWAZhmv+JtiDhSuQCp4sBfbIgg==", 1092 | "dev": true, 1093 | "requires": { 1094 | "agent-base": "4", 1095 | "debug": "3.1.0" 1096 | } 1097 | }, 1098 | "https-proxy-agent": { 1099 | "version": "2.2.4", 1100 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-2.2.4.tgz", 1101 | "integrity": "sha512-OmvfoQ53WLjtA9HeYP9RNrWMJzzAz1JGaSFr1nijg0PVR1JaD/xbJq1mdEIIlxGpXp9eSe/O2LgU9DJmTPd0Eg==", 1102 | "dev": true, 1103 | "requires": { 1104 | "agent-base": "^4.3.0", 1105 | "debug": "^3.1.0" 1106 | } 1107 | }, 1108 | "iconv-lite": { 1109 | "version": "0.4.24", 1110 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1111 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1112 | "dev": true, 1113 | "requires": { 1114 | "safer-buffer": ">= 2.1.2 < 3" 1115 | } 1116 | }, 1117 | "ignore": { 1118 | "version": "4.0.6", 1119 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1120 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1121 | "dev": true 1122 | }, 1123 | "import-fresh": { 1124 | "version": "3.2.1", 1125 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 1126 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 1127 | "dev": true, 1128 | "requires": { 1129 | "parent-module": "^1.0.0", 1130 | "resolve-from": "^4.0.0" 1131 | } 1132 | }, 1133 | "imurmurhash": { 1134 | "version": "0.1.4", 1135 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1136 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1137 | "dev": true 1138 | }, 1139 | "inflight": { 1140 | "version": "1.0.6", 1141 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1142 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1143 | "dev": true, 1144 | "requires": { 1145 | "once": "^1.3.0", 1146 | "wrappy": "1" 1147 | } 1148 | }, 1149 | "inherits": { 1150 | "version": "2.0.4", 1151 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1152 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1153 | "dev": true 1154 | }, 1155 | "inquirer": { 1156 | "version": "7.1.0", 1157 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.1.0.tgz", 1158 | "integrity": "sha512-5fJMWEmikSYu0nv/flMc475MhGbB7TSPd/2IpFV4I4rMklboCH2rQjYY5kKiYGHqUF9gvaambupcJFFG9dvReg==", 1159 | "dev": true, 1160 | "requires": { 1161 | "ansi-escapes": "^4.2.1", 1162 | "chalk": "^3.0.0", 1163 | "cli-cursor": "^3.1.0", 1164 | "cli-width": "^2.0.0", 1165 | "external-editor": "^3.0.3", 1166 | "figures": "^3.0.0", 1167 | "lodash": "^4.17.15", 1168 | "mute-stream": "0.0.8", 1169 | "run-async": "^2.4.0", 1170 | "rxjs": "^6.5.3", 1171 | "string-width": "^4.1.0", 1172 | "strip-ansi": "^6.0.0", 1173 | "through": "^2.3.6" 1174 | }, 1175 | "dependencies": { 1176 | "ansi-styles": { 1177 | "version": "4.2.1", 1178 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 1179 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 1180 | "dev": true, 1181 | "requires": { 1182 | "@types/color-name": "^1.1.1", 1183 | "color-convert": "^2.0.1" 1184 | } 1185 | }, 1186 | "chalk": { 1187 | "version": "3.0.0", 1188 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", 1189 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", 1190 | "dev": true, 1191 | "requires": { 1192 | "ansi-styles": "^4.1.0", 1193 | "supports-color": "^7.1.0" 1194 | } 1195 | }, 1196 | "color-convert": { 1197 | "version": "2.0.1", 1198 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1199 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1200 | "dev": true, 1201 | "requires": { 1202 | "color-name": "~1.1.4" 1203 | } 1204 | }, 1205 | "color-name": { 1206 | "version": "1.1.4", 1207 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1208 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1209 | "dev": true 1210 | }, 1211 | "has-flag": { 1212 | "version": "4.0.0", 1213 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1214 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1215 | "dev": true 1216 | }, 1217 | "supports-color": { 1218 | "version": "7.1.0", 1219 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 1220 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 1221 | "dev": true, 1222 | "requires": { 1223 | "has-flag": "^4.0.0" 1224 | } 1225 | } 1226 | } 1227 | }, 1228 | "is-binary-path": { 1229 | "version": "2.1.0", 1230 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1231 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1232 | "dev": true, 1233 | "requires": { 1234 | "binary-extensions": "^2.0.0" 1235 | } 1236 | }, 1237 | "is-buffer": { 1238 | "version": "2.0.4", 1239 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.4.tgz", 1240 | "integrity": "sha512-Kq1rokWXOPXWuaMAqZiJW4XxsmD9zGx9q4aePabbn3qCRGedtH7Cm+zV8WETitMfu1wdh+Rvd6w5egwSngUX2A==", 1241 | "dev": true 1242 | }, 1243 | "is-callable": { 1244 | "version": "1.1.5", 1245 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.5.tgz", 1246 | "integrity": "sha512-ESKv5sMCJB2jnHTWZ3O5itG+O128Hsus4K4Qh1h2/cgn2vbgnLSVqfV46AeJA9D5EeeLa9w81KUXMtn34zhX+Q==", 1247 | "dev": true 1248 | }, 1249 | "is-date-object": { 1250 | "version": "1.0.2", 1251 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 1252 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==", 1253 | "dev": true 1254 | }, 1255 | "is-extglob": { 1256 | "version": "2.1.1", 1257 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1258 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1259 | "dev": true 1260 | }, 1261 | "is-fullwidth-code-point": { 1262 | "version": "3.0.0", 1263 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1264 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1265 | "dev": true 1266 | }, 1267 | "is-glob": { 1268 | "version": "4.0.1", 1269 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1270 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1271 | "dev": true, 1272 | "requires": { 1273 | "is-extglob": "^2.1.1" 1274 | } 1275 | }, 1276 | "is-number": { 1277 | "version": "7.0.0", 1278 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1279 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1280 | "dev": true 1281 | }, 1282 | "is-regex": { 1283 | "version": "1.0.5", 1284 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.5.tgz", 1285 | "integrity": "sha512-vlKW17SNq44owv5AQR3Cq0bQPEb8+kF3UKZ2fiZNOWtztYE5i0CzCZxFDwO58qAOWtxdBRVO/V5Qin1wjCqFYQ==", 1286 | "dev": true, 1287 | "requires": { 1288 | "has": "^1.0.3" 1289 | } 1290 | }, 1291 | "is-symbol": { 1292 | "version": "1.0.3", 1293 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 1294 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 1295 | "dev": true, 1296 | "requires": { 1297 | "has-symbols": "^1.0.1" 1298 | } 1299 | }, 1300 | "isexe": { 1301 | "version": "2.0.0", 1302 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1303 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1304 | "dev": true 1305 | }, 1306 | "js-tokens": { 1307 | "version": "4.0.0", 1308 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1309 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1310 | "dev": true 1311 | }, 1312 | "js-yaml": { 1313 | "version": "3.13.1", 1314 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1315 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1316 | "dev": true, 1317 | "requires": { 1318 | "argparse": "^1.0.7", 1319 | "esprima": "^4.0.0" 1320 | } 1321 | }, 1322 | "json-schema-traverse": { 1323 | "version": "0.4.1", 1324 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1325 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1326 | "dev": true 1327 | }, 1328 | "json-stable-stringify-without-jsonify": { 1329 | "version": "1.0.1", 1330 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1331 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1332 | "dev": true 1333 | }, 1334 | "leven": { 1335 | "version": "3.1.0", 1336 | "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", 1337 | "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", 1338 | "dev": true 1339 | }, 1340 | "levn": { 1341 | "version": "0.4.1", 1342 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1343 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1344 | "dev": true, 1345 | "requires": { 1346 | "prelude-ls": "^1.2.1", 1347 | "type-check": "~0.4.0" 1348 | } 1349 | }, 1350 | "linkify-it": { 1351 | "version": "2.2.0", 1352 | "resolved": "https://registry.npmjs.org/linkify-it/-/linkify-it-2.2.0.tgz", 1353 | "integrity": "sha512-GnAl/knGn+i1U/wjBz3akz2stz+HrHLsxMwHQGofCDfPvlf+gDKN58UtfmUquTY4/MXeE2x7k19KQmeoZi94Iw==", 1354 | "dev": true, 1355 | "requires": { 1356 | "uc.micro": "^1.0.1" 1357 | } 1358 | }, 1359 | "locate-path": { 1360 | "version": "3.0.0", 1361 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1362 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1363 | "dev": true, 1364 | "requires": { 1365 | "p-locate": "^3.0.0", 1366 | "path-exists": "^3.0.0" 1367 | } 1368 | }, 1369 | "lodash": { 1370 | "version": "4.17.19", 1371 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.19.tgz", 1372 | "integrity": "sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ==", 1373 | "dev": true 1374 | }, 1375 | "log-symbols": { 1376 | "version": "3.0.0", 1377 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-3.0.0.tgz", 1378 | "integrity": "sha512-dSkNGuI7iG3mfvDzUuYZyvk5dD9ocYCYzNU6CYDE6+Xqd+gwme6Z00NS3dUh8mq/73HaEtT7m6W+yUPtU6BZnQ==", 1379 | "dev": true, 1380 | "requires": { 1381 | "chalk": "^2.4.2" 1382 | } 1383 | }, 1384 | "markdown-it": { 1385 | "version": "10.0.0", 1386 | "resolved": "https://registry.npmjs.org/markdown-it/-/markdown-it-10.0.0.tgz", 1387 | "integrity": "sha512-YWOP1j7UbDNz+TumYP1kpwnP0aEa711cJjrAQrzd0UXlbJfc5aAq0F/PZHjiioqDC1NKgvIMX+o+9Bk7yuM2dg==", 1388 | "dev": true, 1389 | "requires": { 1390 | "argparse": "^1.0.7", 1391 | "entities": "~2.0.0", 1392 | "linkify-it": "^2.0.0", 1393 | "mdurl": "^1.0.1", 1394 | "uc.micro": "^1.0.5" 1395 | }, 1396 | "dependencies": { 1397 | "entities": { 1398 | "version": "2.0.3", 1399 | "resolved": "https://registry.npmjs.org/entities/-/entities-2.0.3.tgz", 1400 | "integrity": "sha512-MyoZ0jgnLvB2X3Lg5HqpFmn1kybDiIfEQmKzTb5apr51Rb+T3KdmMiqa70T+bhGnyv7bQ6WMj2QMHpGMmlrUYQ==", 1401 | "dev": true 1402 | } 1403 | } 1404 | }, 1405 | "mdurl": { 1406 | "version": "1.0.1", 1407 | "resolved": "https://registry.npmjs.org/mdurl/-/mdurl-1.0.1.tgz", 1408 | "integrity": "sha1-/oWy7HWlkDfyrf7BAP1sYBdhFS4=", 1409 | "dev": true 1410 | }, 1411 | "mime": { 1412 | "version": "1.6.0", 1413 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1414 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 1415 | "dev": true 1416 | }, 1417 | "mimic-fn": { 1418 | "version": "2.1.0", 1419 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1420 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1421 | "dev": true 1422 | }, 1423 | "minimatch": { 1424 | "version": "3.0.4", 1425 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1426 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1427 | "dev": true, 1428 | "requires": { 1429 | "brace-expansion": "^1.1.7" 1430 | } 1431 | }, 1432 | "mkdirp": { 1433 | "version": "0.5.5", 1434 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1435 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1436 | "dev": true, 1437 | "requires": { 1438 | "minimist": "^1.2.5" 1439 | }, 1440 | "dependencies": { 1441 | "minimist": { 1442 | "version": "1.2.5", 1443 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1444 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1445 | "dev": true 1446 | } 1447 | } 1448 | }, 1449 | "mocha": { 1450 | "version": "7.2.0", 1451 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-7.2.0.tgz", 1452 | "integrity": "sha512-O9CIypScywTVpNaRrCAgoUnJgozpIofjKUYmJhiCIJMiuYnLI6otcb1/kpW9/n/tJODHGZ7i8aLQoDVsMtOKQQ==", 1453 | "dev": true, 1454 | "requires": { 1455 | "ansi-colors": "3.2.3", 1456 | "browser-stdout": "1.3.1", 1457 | "chokidar": "3.3.0", 1458 | "debug": "3.2.6", 1459 | "diff": "3.5.0", 1460 | "escape-string-regexp": "1.0.5", 1461 | "find-up": "3.0.0", 1462 | "glob": "7.1.3", 1463 | "growl": "1.10.5", 1464 | "he": "1.2.0", 1465 | "js-yaml": "3.13.1", 1466 | "log-symbols": "3.0.0", 1467 | "minimatch": "3.0.4", 1468 | "mkdirp": "0.5.5", 1469 | "ms": "2.1.1", 1470 | "node-environment-flags": "1.0.6", 1471 | "object.assign": "4.1.0", 1472 | "strip-json-comments": "2.0.1", 1473 | "supports-color": "6.0.0", 1474 | "which": "1.3.1", 1475 | "wide-align": "1.1.3", 1476 | "yargs": "13.3.2", 1477 | "yargs-parser": "13.1.2", 1478 | "yargs-unparser": "1.6.0" 1479 | }, 1480 | "dependencies": { 1481 | "debug": { 1482 | "version": "3.2.6", 1483 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 1484 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 1485 | "dev": true, 1486 | "requires": { 1487 | "ms": "^2.1.1" 1488 | } 1489 | }, 1490 | "glob": { 1491 | "version": "7.1.3", 1492 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 1493 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 1494 | "dev": true, 1495 | "requires": { 1496 | "fs.realpath": "^1.0.0", 1497 | "inflight": "^1.0.4", 1498 | "inherits": "2", 1499 | "minimatch": "^3.0.4", 1500 | "once": "^1.3.0", 1501 | "path-is-absolute": "^1.0.0" 1502 | } 1503 | }, 1504 | "ms": { 1505 | "version": "2.1.1", 1506 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1507 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 1508 | "dev": true 1509 | }, 1510 | "strip-json-comments": { 1511 | "version": "2.0.1", 1512 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1513 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1514 | "dev": true 1515 | }, 1516 | "supports-color": { 1517 | "version": "6.0.0", 1518 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.0.0.tgz", 1519 | "integrity": "sha512-on9Kwidc1IUQo+bQdhi8+Tijpo0e1SS6RoGo2guUwn5vdaxw8RXOF9Vb2ws+ihWOmh4JnCJOvaziZWP1VABaLg==", 1520 | "dev": true, 1521 | "requires": { 1522 | "has-flag": "^3.0.0" 1523 | } 1524 | }, 1525 | "which": { 1526 | "version": "1.3.1", 1527 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1528 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1529 | "dev": true, 1530 | "requires": { 1531 | "isexe": "^2.0.0" 1532 | } 1533 | } 1534 | } 1535 | }, 1536 | "ms": { 1537 | "version": "2.0.0", 1538 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1539 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1540 | "dev": true 1541 | }, 1542 | "mute-stream": { 1543 | "version": "0.0.8", 1544 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 1545 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 1546 | "dev": true 1547 | }, 1548 | "natural-compare": { 1549 | "version": "1.4.0", 1550 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1551 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1552 | "dev": true 1553 | }, 1554 | "node-environment-flags": { 1555 | "version": "1.0.6", 1556 | "resolved": "https://registry.npmjs.org/node-environment-flags/-/node-environment-flags-1.0.6.tgz", 1557 | "integrity": "sha512-5Evy2epuL+6TM0lCQGpFIj6KwiEsGh1SrHUhTbNX+sLbBtjidPZFAnVK9y5yU1+h//RitLbRHTIMyxQPtxMdHw==", 1558 | "dev": true, 1559 | "requires": { 1560 | "object.getownpropertydescriptors": "^2.0.3", 1561 | "semver": "^5.7.0" 1562 | } 1563 | }, 1564 | "normalize-path": { 1565 | "version": "3.0.0", 1566 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1567 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1568 | "dev": true 1569 | }, 1570 | "nth-check": { 1571 | "version": "1.0.2", 1572 | "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-1.0.2.tgz", 1573 | "integrity": "sha512-WeBOdju8SnzPN5vTUJYxYUxLeXpCaVP5i5e0LF8fg7WORF2Wd7wFX/pk0tYZk7s8T+J7VLy0Da6J1+wCT0AtHg==", 1574 | "dev": true, 1575 | "requires": { 1576 | "boolbase": "~1.0.0" 1577 | } 1578 | }, 1579 | "object-inspect": { 1580 | "version": "1.7.0", 1581 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.7.0.tgz", 1582 | "integrity": "sha512-a7pEHdh1xKIAgTySUGgLMx/xwDZskN1Ud6egYYN3EdRW4ZMPNEDUTF+hwy2LUC+Bl+SyLXANnwz/jyh/qutKUw==", 1583 | "dev": true 1584 | }, 1585 | "object-keys": { 1586 | "version": "1.1.1", 1587 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1588 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1589 | "dev": true 1590 | }, 1591 | "object.assign": { 1592 | "version": "4.1.0", 1593 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1594 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1595 | "dev": true, 1596 | "requires": { 1597 | "define-properties": "^1.1.2", 1598 | "function-bind": "^1.1.1", 1599 | "has-symbols": "^1.0.0", 1600 | "object-keys": "^1.0.11" 1601 | } 1602 | }, 1603 | "object.getownpropertydescriptors": { 1604 | "version": "2.1.0", 1605 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.0.tgz", 1606 | "integrity": "sha512-Z53Oah9A3TdLoblT7VKJaTDdXdT+lQO+cNpKVnya5JDe9uLvzu1YyY1yFDFrcxrlRgWrEFH0jJtD/IbuwjcEVg==", 1607 | "dev": true, 1608 | "requires": { 1609 | "define-properties": "^1.1.3", 1610 | "es-abstract": "^1.17.0-next.1" 1611 | } 1612 | }, 1613 | "once": { 1614 | "version": "1.4.0", 1615 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1616 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1617 | "dev": true, 1618 | "requires": { 1619 | "wrappy": "1" 1620 | } 1621 | }, 1622 | "onetime": { 1623 | "version": "5.1.0", 1624 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 1625 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 1626 | "dev": true, 1627 | "requires": { 1628 | "mimic-fn": "^2.1.0" 1629 | } 1630 | }, 1631 | "optionator": { 1632 | "version": "0.9.1", 1633 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1634 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1635 | "dev": true, 1636 | "requires": { 1637 | "deep-is": "^0.1.3", 1638 | "fast-levenshtein": "^2.0.6", 1639 | "levn": "^0.4.1", 1640 | "prelude-ls": "^1.2.1", 1641 | "type-check": "^0.4.0", 1642 | "word-wrap": "^1.2.3" 1643 | } 1644 | }, 1645 | "os": { 1646 | "version": "0.1.1", 1647 | "resolved": "https://registry.npmjs.org/os/-/os-0.1.1.tgz", 1648 | "integrity": "sha1-IIhF6J4ZOtTZcUdLk5R3NqVtE/M=", 1649 | "dev": true 1650 | }, 1651 | "os-homedir": { 1652 | "version": "1.0.2", 1653 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1654 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", 1655 | "dev": true 1656 | }, 1657 | "os-tmpdir": { 1658 | "version": "1.0.2", 1659 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1660 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1661 | "dev": true 1662 | }, 1663 | "osenv": { 1664 | "version": "0.1.5", 1665 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", 1666 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", 1667 | "dev": true, 1668 | "requires": { 1669 | "os-homedir": "^1.0.0", 1670 | "os-tmpdir": "^1.0.0" 1671 | } 1672 | }, 1673 | "p-limit": { 1674 | "version": "2.3.0", 1675 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 1676 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 1677 | "dev": true, 1678 | "requires": { 1679 | "p-try": "^2.0.0" 1680 | } 1681 | }, 1682 | "p-locate": { 1683 | "version": "3.0.0", 1684 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 1685 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 1686 | "dev": true, 1687 | "requires": { 1688 | "p-limit": "^2.0.0" 1689 | } 1690 | }, 1691 | "p-try": { 1692 | "version": "2.2.0", 1693 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1694 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1695 | "dev": true 1696 | }, 1697 | "parent-module": { 1698 | "version": "1.0.1", 1699 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1700 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1701 | "dev": true, 1702 | "requires": { 1703 | "callsites": "^3.0.0" 1704 | } 1705 | }, 1706 | "parse-semver": { 1707 | "version": "1.1.1", 1708 | "resolved": "https://registry.npmjs.org/parse-semver/-/parse-semver-1.1.1.tgz", 1709 | "integrity": "sha1-mkr9bfBj3Egm+T+6SpnPIj9mbLg=", 1710 | "dev": true, 1711 | "requires": { 1712 | "semver": "^5.1.0" 1713 | } 1714 | }, 1715 | "parse5": { 1716 | "version": "3.0.3", 1717 | "resolved": "https://registry.npmjs.org/parse5/-/parse5-3.0.3.tgz", 1718 | "integrity": "sha512-rgO9Zg5LLLkfJF9E6CCmXlSE4UVceloys8JrFqCcHloC3usd/kJCyPDwH2SOlzix2j3xaP9sUX3e8+kvkuleAA==", 1719 | "dev": true, 1720 | "requires": { 1721 | "@types/node": "*" 1722 | } 1723 | }, 1724 | "path-exists": { 1725 | "version": "3.0.0", 1726 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1727 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1728 | "dev": true 1729 | }, 1730 | "path-is-absolute": { 1731 | "version": "1.0.1", 1732 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1733 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1734 | "dev": true 1735 | }, 1736 | "path-key": { 1737 | "version": "3.1.1", 1738 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1739 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1740 | "dev": true 1741 | }, 1742 | "pend": { 1743 | "version": "1.2.0", 1744 | "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", 1745 | "integrity": "sha1-elfrVQpng/kRUzH89GY9XI4AelA=", 1746 | "dev": true 1747 | }, 1748 | "picomatch": { 1749 | "version": "2.2.2", 1750 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 1751 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 1752 | "dev": true 1753 | }, 1754 | "prelude-ls": { 1755 | "version": "1.2.1", 1756 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1757 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1758 | "dev": true 1759 | }, 1760 | "progress": { 1761 | "version": "2.0.3", 1762 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1763 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1764 | "dev": true 1765 | }, 1766 | "punycode": { 1767 | "version": "2.1.1", 1768 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1769 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1770 | "dev": true 1771 | }, 1772 | "read": { 1773 | "version": "1.0.7", 1774 | "resolved": "https://registry.npmjs.org/read/-/read-1.0.7.tgz", 1775 | "integrity": "sha1-s9oZvQUkMal2cdRKQmNK33ELQMQ=", 1776 | "dev": true, 1777 | "requires": { 1778 | "mute-stream": "~0.0.4" 1779 | } 1780 | }, 1781 | "readable-stream": { 1782 | "version": "3.6.0", 1783 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 1784 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 1785 | "dev": true, 1786 | "requires": { 1787 | "inherits": "^2.0.3", 1788 | "string_decoder": "^1.1.1", 1789 | "util-deprecate": "^1.0.1" 1790 | } 1791 | }, 1792 | "readdirp": { 1793 | "version": "3.2.0", 1794 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.2.0.tgz", 1795 | "integrity": "sha512-crk4Qu3pmXwgxdSgGhgA/eXiJAPQiX4GMOZZMXnqKxHX7TaoL+3gQVo/WeuAiogr07DpnfjIMpXXa+PAIvwPGQ==", 1796 | "dev": true, 1797 | "requires": { 1798 | "picomatch": "^2.0.4" 1799 | } 1800 | }, 1801 | "regexpp": { 1802 | "version": "3.1.0", 1803 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 1804 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 1805 | "dev": true 1806 | }, 1807 | "require-directory": { 1808 | "version": "2.1.1", 1809 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1810 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1811 | "dev": true 1812 | }, 1813 | "require-main-filename": { 1814 | "version": "2.0.0", 1815 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 1816 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 1817 | "dev": true 1818 | }, 1819 | "resolve-from": { 1820 | "version": "4.0.0", 1821 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1822 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1823 | "dev": true 1824 | }, 1825 | "restore-cursor": { 1826 | "version": "3.1.0", 1827 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 1828 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 1829 | "dev": true, 1830 | "requires": { 1831 | "onetime": "^5.1.0", 1832 | "signal-exit": "^3.0.2" 1833 | } 1834 | }, 1835 | "rimraf": { 1836 | "version": "2.6.3", 1837 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1838 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1839 | "dev": true, 1840 | "requires": { 1841 | "glob": "^7.1.3" 1842 | } 1843 | }, 1844 | "run-async": { 1845 | "version": "2.4.1", 1846 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.1.tgz", 1847 | "integrity": "sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==", 1848 | "dev": true 1849 | }, 1850 | "rxjs": { 1851 | "version": "6.5.5", 1852 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.5.tgz", 1853 | "integrity": "sha512-WfQI+1gohdf0Dai/Bbmk5L5ItH5tYqm3ki2c5GdWhKjalzjg93N3avFjVStyZZz+A2Em+ZxKH5bNghw9UeylGQ==", 1854 | "dev": true, 1855 | "requires": { 1856 | "tslib": "^1.9.0" 1857 | } 1858 | }, 1859 | "safe-buffer": { 1860 | "version": "5.2.1", 1861 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1862 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1863 | "dev": true 1864 | }, 1865 | "safer-buffer": { 1866 | "version": "2.1.2", 1867 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1868 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1869 | "dev": true 1870 | }, 1871 | "semver": { 1872 | "version": "5.7.1", 1873 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1874 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1875 | "dev": true 1876 | }, 1877 | "set-blocking": { 1878 | "version": "2.0.0", 1879 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1880 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 1881 | "dev": true 1882 | }, 1883 | "shebang-command": { 1884 | "version": "2.0.0", 1885 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1886 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1887 | "dev": true, 1888 | "requires": { 1889 | "shebang-regex": "^3.0.0" 1890 | } 1891 | }, 1892 | "shebang-regex": { 1893 | "version": "3.0.0", 1894 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1895 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1896 | "dev": true 1897 | }, 1898 | "signal-exit": { 1899 | "version": "3.0.3", 1900 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 1901 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 1902 | "dev": true 1903 | }, 1904 | "slice-ansi": { 1905 | "version": "2.1.0", 1906 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 1907 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 1908 | "dev": true, 1909 | "requires": { 1910 | "ansi-styles": "^3.2.0", 1911 | "astral-regex": "^1.0.0", 1912 | "is-fullwidth-code-point": "^2.0.0" 1913 | }, 1914 | "dependencies": { 1915 | "is-fullwidth-code-point": { 1916 | "version": "2.0.0", 1917 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1918 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1919 | "dev": true 1920 | } 1921 | } 1922 | }, 1923 | "sprintf-js": { 1924 | "version": "1.0.3", 1925 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1926 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1927 | "dev": true 1928 | }, 1929 | "string-width": { 1930 | "version": "4.2.0", 1931 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 1932 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 1933 | "dev": true, 1934 | "requires": { 1935 | "emoji-regex": "^8.0.0", 1936 | "is-fullwidth-code-point": "^3.0.0", 1937 | "strip-ansi": "^6.0.0" 1938 | } 1939 | }, 1940 | "string.prototype.trimend": { 1941 | "version": "1.0.1", 1942 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz", 1943 | "integrity": "sha512-LRPxFUaTtpqYsTeNKaFOw3R4bxIzWOnbQ837QfBylo8jIxtcbK/A/sMV7Q+OAV/vWo+7s25pOE10KYSjaSO06g==", 1944 | "dev": true, 1945 | "requires": { 1946 | "define-properties": "^1.1.3", 1947 | "es-abstract": "^1.17.5" 1948 | } 1949 | }, 1950 | "string.prototype.trimleft": { 1951 | "version": "2.1.2", 1952 | "resolved": "https://registry.npmjs.org/string.prototype.trimleft/-/string.prototype.trimleft-2.1.2.tgz", 1953 | "integrity": "sha512-gCA0tza1JBvqr3bfAIFJGqfdRTyPae82+KTnm3coDXkZN9wnuW3HjGgN386D7hfv5CHQYCI022/rJPVlqXyHSw==", 1954 | "dev": true, 1955 | "requires": { 1956 | "define-properties": "^1.1.3", 1957 | "es-abstract": "^1.17.5", 1958 | "string.prototype.trimstart": "^1.0.0" 1959 | } 1960 | }, 1961 | "string.prototype.trimright": { 1962 | "version": "2.1.2", 1963 | "resolved": "https://registry.npmjs.org/string.prototype.trimright/-/string.prototype.trimright-2.1.2.tgz", 1964 | "integrity": "sha512-ZNRQ7sY3KroTaYjRS6EbNiiHrOkjihL9aQE/8gfQ4DtAC/aEBRHFJa44OmoWxGGqXuJlfKkZW4WcXErGr+9ZFg==", 1965 | "dev": true, 1966 | "requires": { 1967 | "define-properties": "^1.1.3", 1968 | "es-abstract": "^1.17.5", 1969 | "string.prototype.trimend": "^1.0.0" 1970 | } 1971 | }, 1972 | "string.prototype.trimstart": { 1973 | "version": "1.0.1", 1974 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz", 1975 | "integrity": "sha512-XxZn+QpvrBI1FOcg6dIpxUPgWCPuNXvMD72aaRaUQv1eD4e/Qy8i/hFTe0BUmD60p/QA6bh1avmuPTfNjqVWRw==", 1976 | "dev": true, 1977 | "requires": { 1978 | "define-properties": "^1.1.3", 1979 | "es-abstract": "^1.17.5" 1980 | } 1981 | }, 1982 | "string_decoder": { 1983 | "version": "1.3.0", 1984 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 1985 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 1986 | "dev": true, 1987 | "requires": { 1988 | "safe-buffer": "~5.2.0" 1989 | } 1990 | }, 1991 | "strip-ansi": { 1992 | "version": "6.0.0", 1993 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1994 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1995 | "dev": true, 1996 | "requires": { 1997 | "ansi-regex": "^5.0.0" 1998 | } 1999 | }, 2000 | "strip-json-comments": { 2001 | "version": "3.1.0", 2002 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.0.tgz", 2003 | "integrity": "sha512-e6/d0eBu7gHtdCqFt0xJr642LdToM5/cN4Qb9DbHjVx1CP5RyeM+zH7pbecEmDv/lBqb0QH+6Uqq75rxFPkM0w==", 2004 | "dev": true 2005 | }, 2006 | "supports-color": { 2007 | "version": "5.5.0", 2008 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2009 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2010 | "dev": true, 2011 | "requires": { 2012 | "has-flag": "^3.0.0" 2013 | } 2014 | }, 2015 | "table": { 2016 | "version": "5.4.6", 2017 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 2018 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 2019 | "dev": true, 2020 | "requires": { 2021 | "ajv": "^6.10.2", 2022 | "lodash": "^4.17.14", 2023 | "slice-ansi": "^2.1.0", 2024 | "string-width": "^3.0.0" 2025 | }, 2026 | "dependencies": { 2027 | "ansi-regex": { 2028 | "version": "4.1.0", 2029 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2030 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2031 | "dev": true 2032 | }, 2033 | "emoji-regex": { 2034 | "version": "7.0.3", 2035 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 2036 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 2037 | "dev": true 2038 | }, 2039 | "is-fullwidth-code-point": { 2040 | "version": "2.0.0", 2041 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2042 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2043 | "dev": true 2044 | }, 2045 | "string-width": { 2046 | "version": "3.1.0", 2047 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2048 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2049 | "dev": true, 2050 | "requires": { 2051 | "emoji-regex": "^7.0.1", 2052 | "is-fullwidth-code-point": "^2.0.0", 2053 | "strip-ansi": "^5.1.0" 2054 | } 2055 | }, 2056 | "strip-ansi": { 2057 | "version": "5.2.0", 2058 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2059 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2060 | "dev": true, 2061 | "requires": { 2062 | "ansi-regex": "^4.1.0" 2063 | } 2064 | } 2065 | } 2066 | }, 2067 | "text-table": { 2068 | "version": "0.2.0", 2069 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2070 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2071 | "dev": true 2072 | }, 2073 | "through": { 2074 | "version": "2.3.8", 2075 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2076 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2077 | "dev": true 2078 | }, 2079 | "tmp": { 2080 | "version": "0.0.29", 2081 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.29.tgz", 2082 | "integrity": "sha1-8lEl/w3Z2jzLDC3Tce4SiLuRKMA=", 2083 | "dev": true, 2084 | "requires": { 2085 | "os-tmpdir": "~1.0.1" 2086 | } 2087 | }, 2088 | "to-regex-range": { 2089 | "version": "5.0.1", 2090 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2091 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2092 | "dev": true, 2093 | "requires": { 2094 | "is-number": "^7.0.0" 2095 | } 2096 | }, 2097 | "tsc": { 2098 | "version": "1.20150623.0", 2099 | "resolved": "https://registry.npmjs.org/tsc/-/tsc-1.20150623.0.tgz", 2100 | "integrity": "sha1-Trw8d04WkUjLx2inNCUz8ILHpuU=", 2101 | "dev": true 2102 | }, 2103 | "tslib": { 2104 | "version": "1.10.0", 2105 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", 2106 | "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==", 2107 | "dev": true 2108 | }, 2109 | "tsutils": { 2110 | "version": "3.17.1", 2111 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.17.1.tgz", 2112 | "integrity": "sha512-kzeQ5B8H3w60nFY2g8cJIuH7JDpsALXySGtwGJ0p2LSjLgay3NdIpqq5SoOBe46bKDW2iq25irHCr8wjomUS2g==", 2113 | "dev": true, 2114 | "requires": { 2115 | "tslib": "^1.8.1" 2116 | } 2117 | }, 2118 | "tunnel": { 2119 | "version": "0.0.4", 2120 | "resolved": "https://registry.npmjs.org/tunnel/-/tunnel-0.0.4.tgz", 2121 | "integrity": "sha1-LTeFoVjBdMmhbcLARuxfxfF0IhM=", 2122 | "dev": true 2123 | }, 2124 | "type-check": { 2125 | "version": "0.4.0", 2126 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2127 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2128 | "dev": true, 2129 | "requires": { 2130 | "prelude-ls": "^1.2.1" 2131 | } 2132 | }, 2133 | "type-fest": { 2134 | "version": "0.8.1", 2135 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 2136 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 2137 | "dev": true 2138 | }, 2139 | "typed-rest-client": { 2140 | "version": "1.2.0", 2141 | "resolved": "https://registry.npmjs.org/typed-rest-client/-/typed-rest-client-1.2.0.tgz", 2142 | "integrity": "sha512-FrUshzZ1yxH8YwGR29PWWnfksLEILbWJydU7zfIRkyH7kAEzB62uMAl2WY6EyolWpLpVHeJGgQm45/MaruaHpw==", 2143 | "dev": true, 2144 | "requires": { 2145 | "tunnel": "0.0.4", 2146 | "underscore": "1.8.3" 2147 | } 2148 | }, 2149 | "typescript": { 2150 | "version": "3.9.3", 2151 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.9.3.tgz", 2152 | "integrity": "sha512-D/wqnB2xzNFIcoBG9FG8cXRDjiqSTbG2wd8DMZeQyJlP1vfTkIxH4GKveWaEBYySKIg+USu+E+EDIR47SqnaMQ==", 2153 | "dev": true 2154 | }, 2155 | "uc.micro": { 2156 | "version": "1.0.6", 2157 | "resolved": "https://registry.npmjs.org/uc.micro/-/uc.micro-1.0.6.tgz", 2158 | "integrity": "sha512-8Y75pvTYkLJW2hWQHXxoqRgV7qb9B+9vFEtidML+7koHUFapnVJAZ6cKs+Qjz5Aw3aZWHMC6u0wJE3At+nSGwA==", 2159 | "dev": true 2160 | }, 2161 | "underscore": { 2162 | "version": "1.8.3", 2163 | "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.8.3.tgz", 2164 | "integrity": "sha1-Tz+1OxBuYJf8+ctBCfKl6b36UCI=", 2165 | "dev": true 2166 | }, 2167 | "uri-js": { 2168 | "version": "4.2.2", 2169 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2170 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2171 | "dev": true, 2172 | "requires": { 2173 | "punycode": "^2.1.0" 2174 | } 2175 | }, 2176 | "url-join": { 2177 | "version": "1.1.0", 2178 | "resolved": "https://registry.npmjs.org/url-join/-/url-join-1.1.0.tgz", 2179 | "integrity": "sha1-dBxsL0WWxIMNZxhGCSDQySIC3Hg=", 2180 | "dev": true 2181 | }, 2182 | "util-deprecate": { 2183 | "version": "1.0.2", 2184 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2185 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2186 | "dev": true 2187 | }, 2188 | "v8-compile-cache": { 2189 | "version": "2.1.0", 2190 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.0.tgz", 2191 | "integrity": "sha512-usZBT3PW+LOjM25wbqIlZwPeJV+3OSz3M1k1Ws8snlW39dZyYL9lOGC5FgPVHfk0jKmjiDV8Z0mIbVQPiwFs7g==", 2192 | "dev": true 2193 | }, 2194 | "vsce": { 2195 | "version": "1.81.1", 2196 | "resolved": "https://registry.npmjs.org/vsce/-/vsce-1.81.1.tgz", 2197 | "integrity": "sha512-1yWAYRxTx/PKSFZnuELe7GPyIo70H/XKJqf6wGikofUK3f3TCNGI6F9xkTQFvXKNe0AygUuxN7kITyPIQGMP+w==", 2198 | "dev": true, 2199 | "requires": { 2200 | "azure-devops-node-api": "^7.2.0", 2201 | "chalk": "^2.4.2", 2202 | "cheerio": "^1.0.0-rc.1", 2203 | "commander": "^6.1.0", 2204 | "denodeify": "^1.2.1", 2205 | "glob": "^7.0.6", 2206 | "leven": "^3.1.0", 2207 | "lodash": "^4.17.15", 2208 | "markdown-it": "^10.0.0", 2209 | "mime": "^1.3.4", 2210 | "minimatch": "^3.0.3", 2211 | "osenv": "^0.1.3", 2212 | "parse-semver": "^1.1.1", 2213 | "read": "^1.0.7", 2214 | "semver": "^5.1.0", 2215 | "tmp": "0.0.29", 2216 | "typed-rest-client": "1.2.0", 2217 | "url-join": "^1.1.0", 2218 | "yauzl": "^2.3.1", 2219 | "yazl": "^2.2.2" 2220 | } 2221 | }, 2222 | "vscode-test": { 2223 | "version": "1.4.0", 2224 | "resolved": "https://registry.npmjs.org/vscode-test/-/vscode-test-1.4.0.tgz", 2225 | "integrity": "sha512-Jt7HNGvSE0+++Tvtq5wc4hiXLIr2OjDShz/gbAfM/mahQpy4rKBnmOK33D+MR67ATWviQhl+vpmU3p/qwSH/Pg==", 2226 | "dev": true, 2227 | "requires": { 2228 | "http-proxy-agent": "^2.1.0", 2229 | "https-proxy-agent": "^2.2.4", 2230 | "rimraf": "^2.6.3" 2231 | } 2232 | }, 2233 | "which": { 2234 | "version": "2.0.2", 2235 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2236 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2237 | "dev": true, 2238 | "requires": { 2239 | "isexe": "^2.0.0" 2240 | } 2241 | }, 2242 | "which-module": { 2243 | "version": "2.0.0", 2244 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 2245 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 2246 | "dev": true 2247 | }, 2248 | "wide-align": { 2249 | "version": "1.1.3", 2250 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 2251 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 2252 | "dev": true, 2253 | "requires": { 2254 | "string-width": "^1.0.2 || 2" 2255 | }, 2256 | "dependencies": { 2257 | "ansi-regex": { 2258 | "version": "3.0.0", 2259 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 2260 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 2261 | "dev": true 2262 | }, 2263 | "is-fullwidth-code-point": { 2264 | "version": "2.0.0", 2265 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2266 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2267 | "dev": true 2268 | }, 2269 | "string-width": { 2270 | "version": "2.1.1", 2271 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2272 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2273 | "dev": true, 2274 | "requires": { 2275 | "is-fullwidth-code-point": "^2.0.0", 2276 | "strip-ansi": "^4.0.0" 2277 | } 2278 | }, 2279 | "strip-ansi": { 2280 | "version": "4.0.0", 2281 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2282 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2283 | "dev": true, 2284 | "requires": { 2285 | "ansi-regex": "^3.0.0" 2286 | } 2287 | } 2288 | } 2289 | }, 2290 | "word-wrap": { 2291 | "version": "1.2.3", 2292 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2293 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2294 | "dev": true 2295 | }, 2296 | "wrap-ansi": { 2297 | "version": "5.1.0", 2298 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 2299 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 2300 | "dev": true, 2301 | "requires": { 2302 | "ansi-styles": "^3.2.0", 2303 | "string-width": "^3.0.0", 2304 | "strip-ansi": "^5.0.0" 2305 | }, 2306 | "dependencies": { 2307 | "ansi-regex": { 2308 | "version": "4.1.0", 2309 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2310 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2311 | "dev": true 2312 | }, 2313 | "emoji-regex": { 2314 | "version": "7.0.3", 2315 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 2316 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 2317 | "dev": true 2318 | }, 2319 | "is-fullwidth-code-point": { 2320 | "version": "2.0.0", 2321 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2322 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2323 | "dev": true 2324 | }, 2325 | "string-width": { 2326 | "version": "3.1.0", 2327 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2328 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2329 | "dev": true, 2330 | "requires": { 2331 | "emoji-regex": "^7.0.1", 2332 | "is-fullwidth-code-point": "^2.0.0", 2333 | "strip-ansi": "^5.1.0" 2334 | } 2335 | }, 2336 | "strip-ansi": { 2337 | "version": "5.2.0", 2338 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2339 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2340 | "dev": true, 2341 | "requires": { 2342 | "ansi-regex": "^4.1.0" 2343 | } 2344 | } 2345 | } 2346 | }, 2347 | "wrappy": { 2348 | "version": "1.0.2", 2349 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2350 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2351 | "dev": true 2352 | }, 2353 | "write": { 2354 | "version": "1.0.3", 2355 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 2356 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 2357 | "dev": true, 2358 | "requires": { 2359 | "mkdirp": "^0.5.1" 2360 | } 2361 | }, 2362 | "y18n": { 2363 | "version": "4.0.1", 2364 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.1.tgz", 2365 | "integrity": "sha512-wNcy4NvjMYL8gogWWYAO7ZFWFfHcbdbE57tZO8e4cbpj8tfUcwrwqSl3ad8HxpYWCdXcJUCeKKZS62Av1affwQ==", 2366 | "dev": true 2367 | }, 2368 | "yargs": { 2369 | "version": "13.3.2", 2370 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz", 2371 | "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==", 2372 | "dev": true, 2373 | "requires": { 2374 | "cliui": "^5.0.0", 2375 | "find-up": "^3.0.0", 2376 | "get-caller-file": "^2.0.1", 2377 | "require-directory": "^2.1.1", 2378 | "require-main-filename": "^2.0.0", 2379 | "set-blocking": "^2.0.0", 2380 | "string-width": "^3.0.0", 2381 | "which-module": "^2.0.0", 2382 | "y18n": "^4.0.0", 2383 | "yargs-parser": "^13.1.2" 2384 | }, 2385 | "dependencies": { 2386 | "ansi-regex": { 2387 | "version": "4.1.0", 2388 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2389 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2390 | "dev": true 2391 | }, 2392 | "emoji-regex": { 2393 | "version": "7.0.3", 2394 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 2395 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 2396 | "dev": true 2397 | }, 2398 | "is-fullwidth-code-point": { 2399 | "version": "2.0.0", 2400 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2401 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2402 | "dev": true 2403 | }, 2404 | "string-width": { 2405 | "version": "3.1.0", 2406 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2407 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2408 | "dev": true, 2409 | "requires": { 2410 | "emoji-regex": "^7.0.1", 2411 | "is-fullwidth-code-point": "^2.0.0", 2412 | "strip-ansi": "^5.1.0" 2413 | } 2414 | }, 2415 | "strip-ansi": { 2416 | "version": "5.2.0", 2417 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2418 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2419 | "dev": true, 2420 | "requires": { 2421 | "ansi-regex": "^4.1.0" 2422 | } 2423 | } 2424 | } 2425 | }, 2426 | "yargs-parser": { 2427 | "version": "13.1.2", 2428 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz", 2429 | "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==", 2430 | "dev": true, 2431 | "requires": { 2432 | "camelcase": "^5.0.0", 2433 | "decamelize": "^1.2.0" 2434 | } 2435 | }, 2436 | "yargs-unparser": { 2437 | "version": "1.6.0", 2438 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.6.0.tgz", 2439 | "integrity": "sha512-W9tKgmSn0DpSatfri0nx52Joq5hVXgeLiqR/5G0sZNDoLZFOr/xjBUDcShCOGNsBnEMNo1KAMBkTej1Hm62HTw==", 2440 | "dev": true, 2441 | "requires": { 2442 | "flat": "^4.1.0", 2443 | "lodash": "^4.17.15", 2444 | "yargs": "^13.3.0" 2445 | } 2446 | }, 2447 | "yauzl": { 2448 | "version": "2.10.0", 2449 | "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz", 2450 | "integrity": "sha1-x+sXyT4RLLEIb6bY5R+wZnt5pfk=", 2451 | "dev": true, 2452 | "requires": { 2453 | "buffer-crc32": "~0.2.3", 2454 | "fd-slicer": "~1.1.0" 2455 | } 2456 | }, 2457 | "yazl": { 2458 | "version": "2.5.1", 2459 | "resolved": "https://registry.npmjs.org/yazl/-/yazl-2.5.1.tgz", 2460 | "integrity": "sha512-phENi2PLiHnHb6QBVot+dJnaAZ0xosj7p3fWl+znIjBDlnMI2PsZCJZ306BPTFOaHf5qdDEI8x5qFrSOBN5vrw==", 2461 | "dev": true, 2462 | "requires": { 2463 | "buffer-crc32": "~0.2.3" 2464 | } 2465 | } 2466 | } 2467 | } 2468 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "dart-import", 3 | "displayName": "dart-import", 4 | "description": "Fix Dart/Flutter's imports", 5 | "version": "0.3.1", 6 | "publisher": "luanpotter", 7 | "repository": "https://github.com/luanpotter/vscode-dart-import", 8 | "engines": { 9 | "vscode": "^1.45.1" 10 | }, 11 | "categories": [ 12 | "Other" 13 | ], 14 | "activationEvents": [ 15 | "onCommand:dart-import.fix", 16 | "onCommand:dart-import.fix-all" 17 | ], 18 | "main": "./out/extension", 19 | "contributes": { 20 | "languages": [ 21 | { 22 | "id": "dart", 23 | "extensions": [ 24 | ".dart" 25 | ], 26 | "aliases": [ 27 | "Dart", 28 | "dart" 29 | ] 30 | } 31 | ], 32 | "configuration": { 33 | "title": "Dart Import configuration", 34 | "properties": { 35 | "dartImport.showErrorMessages": { 36 | "type": "boolean", 37 | "description": "Whether you want to see errors after dart-import task failure", 38 | "default": true 39 | }, 40 | "dartImport.showInfoMessages": { 41 | "type": "boolean", 42 | "description": "Whether you want to see notification after dart-import task completion", 43 | "default": true 44 | }, 45 | "dartImport.excludeGeneratedFiles": { 46 | "type": "array", 47 | "items": { 48 | "type": "string" 49 | }, 50 | "description": "A list of generated file extensions to exclude", 51 | "default": [ 52 | "g.dart", 53 | "config.dart", 54 | "freezed.dart" 55 | ] 56 | }, 57 | "dartImport.fixOnSave": { 58 | "type": "boolean", 59 | "description": "Auto fix dart imports on file save", 60 | "default": false 61 | } 62 | } 63 | }, 64 | "commands": [ 65 | { 66 | "command": "dart-import.fix", 67 | "title": "Fix Imports" 68 | }, 69 | { 70 | "command": "dart-import.fix-all", 71 | "title": "Fix All Imports" 72 | } 73 | ] 74 | }, 75 | "scripts": { 76 | "vscode:prepublish": "npm run compile", 77 | "compile": "tsc -p ./", 78 | "package": "vsce package", 79 | "publish": "vsce publish", 80 | "lint": "eslint . --ext .ts,.tsx", 81 | "watch": "tsc -watch -p ./", 82 | "pretest": "npm run compile", 83 | "test": "node ./out/test/runTest.js" 84 | }, 85 | "devDependencies": { 86 | "@types/glob": "^7.1.1", 87 | "@types/mocha": "^7.0.2", 88 | "@types/node": "^14.0.6", 89 | "@types/vscode": "^1.45.1", 90 | "@typescript-eslint/eslint-plugin": "^3.0.2", 91 | "@typescript-eslint/parser": "^3.0.2", 92 | "eslint": "^7.1.0", 93 | "glob": "^7.1.6", 94 | "mocha": "^7.2.0", 95 | "tsc": "^1.20150623.0", 96 | "typescript": "^3.9.3", 97 | "vsce": "^1.81.1", 98 | "vscode-test": "^1.4.0" 99 | } 100 | } 101 | -------------------------------------------------------------------------------- /src/configResolver.ts: -------------------------------------------------------------------------------- 1 | import * as vscode from 'vscode'; 2 | 3 | export class ConfigResolver { 4 | private _showInfoMessages: boolean; 5 | private _showErrorMessages: boolean; 6 | private _excludeGeneratedFiles: Array; 7 | private _fixOnSave: boolean; 8 | 9 | constructor() { 10 | const config = vscode.workspace.getConfiguration( 11 | 'dartImport', 12 | ) as vscode.WorkspaceConfiguration; 13 | 14 | this._showInfoMessages = !!config.get('showInfoMessages'); 15 | this._showErrorMessages = !!config.get('showErrorMessages'); 16 | this._excludeGeneratedFiles = config.get('excludeGeneratedFiles') || []; 17 | this._fixOnSave = !!config.get('fixOnSave'); 18 | } 19 | 20 | public get showErrorMessages() : boolean { 21 | return this._showErrorMessages; 22 | } 23 | 24 | public get showInfoMessages() : boolean { 25 | return this._showInfoMessages; 26 | } 27 | 28 | public get excludeGeneratedFiles() : Array { 29 | return this._excludeGeneratedFiles; 30 | } 31 | 32 | public get fixOnSave() : boolean { 33 | return this._fixOnSave; 34 | } 35 | } 36 | -------------------------------------------------------------------------------- /src/extension.ts: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | import * as vscode from 'vscode'; 4 | import * as path from 'path'; 5 | import { PackageInfo, EditorAccess, fixImports } from './main'; 6 | import { ConfigResolver } from './configResolver'; 7 | 8 | let configResolver = new ConfigResolver(); 9 | 10 | const showErrorMessage = (message: string) => { 11 | if (configResolver.showErrorMessages) { 12 | vscode.window.showErrorMessage(message); 13 | } 14 | }; 15 | 16 | const showInfoMessage = (message: string) => { 17 | if (configResolver.showInfoMessages) { 18 | vscode.window.showInformationMessage(message); 19 | } 20 | }; 21 | 22 | /** 23 | * Returns the set of `pubspec.yaml` files that sit above `activeFileUri` in its 24 | * directory ancestry. 25 | */ 26 | const findPubspec = async (activeFileUri: vscode.Uri) => { 27 | const allPubspecUris = await vscode.workspace.findFiles('**/pubspec.yaml'); 28 | return allPubspecUris.filter((pubspecUri) => { 29 | const packageRootUri = pubspecUri.with({ 30 | path: path.dirname(pubspecUri.path), 31 | }) + '/'; 32 | 33 | // Containment check 34 | return activeFileUri.toString().startsWith(packageRootUri.toString()); 35 | }); 36 | }; 37 | 38 | const fetchPackageInfoFor = async (activeDocumentUri: vscode.Uri): Promise => { 39 | const pubspecUris = await findPubspec(activeDocumentUri); 40 | if (pubspecUris.length !== 1) { 41 | showErrorMessage( 42 | `Expected to find a single pubspec.yaml file above ${activeDocumentUri}, ${pubspecUris.length} found.`, 43 | ); 44 | return null; 45 | } 46 | 47 | const pubspec: vscode.TextDocument = await vscode.workspace.openTextDocument(pubspecUris[0]); 48 | const projectRoot = path.dirname(pubspec.fileName); 49 | const possibleNameLines = pubspec.getText().split('\n').filter((line: string) => line.match(/^name:/)); 50 | if (possibleNameLines.length !== 1) { 51 | showErrorMessage( 52 | `Expected to find a single line starting with 'name:' on pubspec.yaml file, ${possibleNameLines.length} found.`, 53 | ); 54 | return null; 55 | } 56 | const nameLine = possibleNameLines[0]; 57 | const packageNameMatch = /^name:\s*(.*)$/mg.exec(nameLine); 58 | if (!packageNameMatch) { 59 | showErrorMessage( 60 | `Expected line 'name:' on pubspec.yaml to match regex, but it didn't (line: ${nameLine}).`, 61 | ); 62 | return null; 63 | } 64 | return { 65 | projectRoot: projectRoot, 66 | projectName: packageNameMatch[1].trim(), 67 | }; 68 | }; 69 | 70 | const runFixImportTask = async (rawEditor: vscode.TextEditor) => { 71 | const packageInfo = await fetchPackageInfoFor(rawEditor.document.uri); 72 | if (!packageInfo) { 73 | showErrorMessage( 74 | 'Failed to initialize extension. Is this a valid Dart/Flutter project?', 75 | ); 76 | return; 77 | } 78 | 79 | const editor = new VSCodeEditorAccess(rawEditor); 80 | try { 81 | const count = await fixImports(editor, packageInfo, path.sep); 82 | vscode.commands.executeCommand('editor.action.organizeImports'); 83 | showInfoMessage( 84 | (count === 0 ? 'No lines changed.' : `${count} imports fixed.`) + 85 | ' All imports sorted.', 86 | ); 87 | } catch (ex) { 88 | if (ex instanceof Error) { 89 | showErrorMessage(ex.message); 90 | } else { 91 | throw ex; 92 | } 93 | } 94 | }; 95 | 96 | class VSCodeEditorAccess implements EditorAccess { 97 | editor: vscode.TextEditor; 98 | 99 | constructor(editor: vscode.TextEditor) { 100 | this.editor = editor; 101 | } 102 | 103 | getFileName(): string { 104 | return this.editor.document.fileName; 105 | } 106 | 107 | getLineAt(idx: number): string { 108 | return this.editor.document.lineAt(idx).text; 109 | } 110 | 111 | getLineCount(): number { 112 | return this.editor.document.lineCount; 113 | } 114 | 115 | replaceLineAt(idx: number, newLine: string): Thenable { 116 | return this.editor.edit((builder) => { 117 | const line = this.getLineAt(idx); 118 | const start = new vscode.Position(idx, 0); 119 | const end = new vscode.Position(idx, line.length); 120 | builder.replace(new vscode.Range(start, end), newLine); 121 | }); 122 | } 123 | } 124 | 125 | export async function activate(context: vscode.ExtensionContext): Promise { 126 | const configChanges = vscode.workspace.onDidChangeConfiguration((e) => { 127 | if (e.affectsConfiguration('dartImport')) { 128 | configResolver = new ConfigResolver(); 129 | } 130 | }); 131 | 132 | const documentSave = vscode.workspace.onDidSaveTextDocument( 133 | async (e: vscode.TextDocument) => { 134 | if (!configResolver.fixOnSave) { 135 | return; 136 | } 137 | const rawEditor = await vscode.window.showTextDocument(e); 138 | 139 | runFixImportTask(rawEditor); 140 | }, 141 | ); 142 | 143 | const cmd = vscode.commands.registerCommand('dart-import.fix', async () => { 144 | const rawEditor = vscode.window.activeTextEditor; 145 | if (!rawEditor) { 146 | return; // No open text editor 147 | } 148 | 149 | runFixImportTask(rawEditor); 150 | }); 151 | const cmdAll = vscode.commands.registerCommand('dart-import.fix-all', async () => { 152 | const excludeExt = configResolver.excludeGeneratedFiles; 153 | const excludeFiles = excludeExt ? `lib/**/*.{${excludeExt}}` : null; 154 | const filesUris = await vscode.workspace.findFiles('lib/**/**.dart', excludeFiles); 155 | 156 | if (filesUris.length === 0) { 157 | showInfoMessage('No dart files were found'); 158 | return; 159 | } 160 | const packageInfo = await fetchPackageInfoFor(filesUris[0]); 161 | 162 | if (!packageInfo) { 163 | showErrorMessage( 164 | 'Failed to initialize extension. Is this a valid Dart/Flutter project?', 165 | ); 166 | return; 167 | } 168 | 169 | let totalCount = 0; 170 | for await (const uri of filesUris) { 171 | const document = await vscode.workspace.openTextDocument(uri); 172 | const rawEditor = await vscode.window.showTextDocument(document); 173 | const editor = new VSCodeEditorAccess(rawEditor); 174 | try { 175 | const count = await fixImports(editor, packageInfo, path.sep); 176 | vscode.commands.executeCommand('editor.action.organizeImports'); 177 | totalCount += count; 178 | } catch (ex) { 179 | if (ex instanceof Error) { 180 | showErrorMessage(ex.message); 181 | } else { 182 | throw ex; 183 | } 184 | } 185 | } 186 | showInfoMessage( 187 | totalCount === 0 188 | ? 'Done. No lines changed' 189 | : `All done. ${totalCount} lines changed.`, 190 | ); 191 | }); 192 | context.subscriptions.push(cmd, cmdAll, configChanges, documentSave); 193 | } 194 | -------------------------------------------------------------------------------- /src/main.ts: -------------------------------------------------------------------------------- 1 | interface PackageInfo { 2 | projectRoot: string; 3 | projectName: string; 4 | } 5 | 6 | const relativize = (filePath: string, importPath: string, pathSep: string) => { 7 | const dartSep = '/'; // dart uses this separator for imports no matter the platform 8 | const pathSplit = (path: string, sep: string) => path.length === 0 ? [] : path.split(sep); 9 | const fileBits = pathSplit(filePath, pathSep); 10 | const importBits = pathSplit(importPath, dartSep); 11 | let dotdotAmount = 0, startIdx; 12 | for (startIdx = 0; startIdx < fileBits.length; startIdx++) { 13 | if (fileBits[startIdx] === importBits[startIdx]) { 14 | continue; 15 | } 16 | dotdotAmount = fileBits.length - startIdx; 17 | break; 18 | } 19 | const relativeBits = new Array(dotdotAmount).fill('..').concat(importBits.slice(startIdx)); 20 | return relativeBits.join(dartSep); 21 | }; 22 | 23 | interface EditorAccess { 24 | getFileName(): string; 25 | getLineAt(idx: number): string; 26 | getLineCount(): number; 27 | replaceLineAt(idx: number, newLine: string): Thenable; 28 | } 29 | 30 | const fixImports = async (editor: EditorAccess, packageInfo: PackageInfo, pathSep: string): Promise => { 31 | const currentPath = editor.getFileName().replace(/(\/|\\)[^/\\]*.dart$/, ''); 32 | const libFolder = `${packageInfo.projectRoot}${pathSep}lib`; 33 | if (!currentPath.startsWith(libFolder)) { 34 | const l1 = 'Current file is not on project root or not on lib folder? File must be on $root/lib.'; 35 | const l2 = `Your current file path is: '${currentPath}' and the lib folder according to the pubspec.yaml file is '${libFolder}'.`; 36 | throw Error(`${l1}\n${l2}`); 37 | } 38 | const relativePath = currentPath.substring(libFolder.length + 1); 39 | const lineCount = editor.getLineCount(); 40 | let count = 0; 41 | for (let currentLine = 0; currentLine < lineCount; currentLine++) { 42 | const line: string = editor.getLineAt(currentLine); 43 | if (line.trim().length === 0) { 44 | continue; 45 | } 46 | const content = line.trim(); 47 | if (!content.startsWith('import ')) { 48 | break; 49 | } 50 | const packageNameRegex = new RegExp(`^\\s*import\\s*(['"])package:${packageInfo.projectName}/([^'"]*)['"]([^;]*);\\s*$`); 51 | const packageNameExec = packageNameRegex.exec(content); 52 | if (packageNameExec) { 53 | const quote = packageNameExec[1]; 54 | const importPath = packageNameExec[2]; 55 | const ending = packageNameExec[3]; 56 | const relativeImport = relativize(relativePath, importPath, pathSep); 57 | const newContent = `import ${quote}${relativeImport}${quote}${ending};`; 58 | await editor.replaceLineAt(currentLine, newContent); 59 | count++; 60 | } else { 61 | const standardPrefixRegex = new RegExp('^\\s*import\\s*([\'"])\\./(.*)$'); 62 | const standardPrefixExec = standardPrefixRegex.exec(content); 63 | if (standardPrefixExec) { 64 | const quote = standardPrefixExec[1]; 65 | const end = standardPrefixExec[2]; 66 | const newContent = `import ${quote}${end}`; 67 | await editor.replaceLineAt(currentLine, newContent); 68 | count++; 69 | } 70 | } 71 | } 72 | return count; 73 | }; 74 | 75 | export { PackageInfo, relativize, EditorAccess, fixImports }; -------------------------------------------------------------------------------- /src/test/runTest.ts: -------------------------------------------------------------------------------- 1 | import * as path from 'path'; 2 | 3 | import { runTests } from 'vscode-test'; 4 | 5 | async function main() { 6 | try { 7 | // The folder containing the Extension Manifest package.json 8 | // Passed to `--extensionDevelopmentPath` 9 | const extensionDevelopmentPath = path.resolve(__dirname, '../../../'); 10 | 11 | // The path to the extension test runner script 12 | // Passed to --extensionTestsPath 13 | const extensionTestsPath = path.resolve(__dirname, './suite/index'); 14 | 15 | // Download VS Code, unzip it and run the integration test 16 | await runTests({ extensionDevelopmentPath, extensionTestsPath }); 17 | } catch (err) { 18 | console.error(err); 19 | console.error('Failed to run tests'); 20 | process.exit(1); 21 | } 22 | } 23 | 24 | main(); -------------------------------------------------------------------------------- /src/test/suite/fixImports.test.ts: -------------------------------------------------------------------------------- 1 | import * as assert from 'assert'; 2 | import { fixImports, EditorAccess, PackageInfo } from '../../main'; 3 | 4 | class FakeEditor implements EditorAccess { 5 | fileName: string; 6 | lines: string[]; 7 | 8 | constructor(fileName: string, lines: string[]) { 9 | this.fileName = fileName; 10 | this.lines = lines; 11 | } 12 | 13 | getFileName(): string { 14 | return this.fileName; 15 | } 16 | 17 | getLineCount(): number { 18 | return this.lines.length; 19 | } 20 | 21 | getLineAt(idx: number): string { 22 | return this.lines[idx]; 23 | } 24 | 25 | replaceLineAt(idx: number, newLine: string): Thenable { 26 | this.lines[idx] = newLine; 27 | return Promise.resolve(true); 28 | } 29 | } 30 | 31 | suite('#fixImports test', () => { 32 | test('replace a couple of wrong imports, keep the rest', async () => { 33 | const pathSep = '/'; 34 | const editor: EditorAccess = new FakeEditor('root/lib/foo/1.dart', [ 35 | '', 36 | 'import "package:this_package/foo/2.dart";', 37 | 'import "package:other_package/foo/1.dart";', 38 | '', 39 | 'import "package:this_package/bar/1.dart";', 40 | 'import "package:other_package/sam.dart";', 41 | ]); 42 | const packageInfo: PackageInfo = { 43 | projectRoot: 'root', 44 | projectName: 'this_package', 45 | }; 46 | const result: number = await fixImports(editor, packageInfo, pathSep); 47 | assert.equal(2, result); 48 | assert.equal('import "2.dart";', editor.getLineAt(1)); 49 | assert.equal('import "package:other_package/foo/1.dart";', editor.getLineAt(2)); 50 | assert.equal('import "../bar/1.dart";', editor.getLineAt(4)); 51 | assert.equal('import "package:other_package/sam.dart";', editor.getLineAt(5)); 52 | }); 53 | 54 | test('allow for use of as, show, and hide', async () => { 55 | const editor: EditorAccess = new FakeEditor('/lib/foo/1.dart', [ 56 | 'import "package:p/foo/2.dart" as Foo;', 57 | 'import "package:p/foo/2.dart" show Foo;', 58 | 'import "package:p/foo/2.dart" hide Foo;', 59 | ]); 60 | const packageInfo: PackageInfo = { projectRoot: '', projectName: 'p' }; 61 | const result: number = await fixImports(editor, packageInfo, '/'); 62 | assert.equal(3, result); 63 | assert.equal('import "2.dart" as Foo;', editor.getLineAt(0)); 64 | assert.equal('import "2.dart" show Foo;', editor.getLineAt(1)); 65 | assert.equal('import "2.dart" hide Foo;', editor.getLineAt(2)); 66 | }); 67 | 68 | test('standardize relative imports', async () => { 69 | const editor: EditorAccess = new FakeEditor('/lib/foo/1.dart', [ 70 | 'import "no_dot.dart";', 71 | 'import "./with_dot.dart" show Foo;', 72 | 'import "../parent.dart";', 73 | ]); 74 | const packageInfo: PackageInfo = { projectRoot: '', projectName: 'p' }; 75 | const result: number = await fixImports(editor, packageInfo, '/'); 76 | assert.equal(1, result); 77 | assert.equal('import "no_dot.dart";', editor.getLineAt(0)); 78 | assert.equal('import "with_dot.dart" show Foo;', editor.getLineAt(1)); 79 | assert.equal('import "../parent.dart";', editor.getLineAt(2)); 80 | }); 81 | }); -------------------------------------------------------------------------------- /src/test/suite/index.ts: -------------------------------------------------------------------------------- 1 | import * as path from 'path'; 2 | import * as Mocha from 'mocha'; 3 | import * as glob from 'glob'; 4 | 5 | export function run(): Promise { 6 | // Create the mocha test 7 | const mocha = new Mocha({ 8 | ui: 'tdd', 9 | }); 10 | mocha.useColors(true); 11 | 12 | const testsRoot = path.resolve(__dirname, '..'); 13 | 14 | return new Promise((c, e) => { 15 | glob('**/**.test.js', { cwd: testsRoot }, (err: Error | null, files: string[]) => { 16 | if (err) { 17 | return e(err); 18 | } 19 | 20 | // Add files to the test suite 21 | files.forEach((f: string) => mocha.addFile(path.resolve(testsRoot, f))); 22 | 23 | try { 24 | // Run the mocha test 25 | mocha.run(failures => { 26 | if (failures > 0) { 27 | e(new Error(`${failures} tests failed.`)); 28 | } else { 29 | c(); 30 | } 31 | }); 32 | } catch (err) { 33 | console.error(err); 34 | e(err); 35 | } 36 | }); 37 | }); 38 | } -------------------------------------------------------------------------------- /src/test/suite/relativize.unix.test.ts: -------------------------------------------------------------------------------- 1 | import * as assert from 'assert'; 2 | import { relativize } from '../../main'; 3 | 4 | suite('#relativize unix test', () => { 5 | test('Root file path', () => { 6 | const filePath = ''; 7 | const importPath = 'foo/bar.dart'; 8 | const result = relativize(filePath, importPath, '/'); 9 | assert.equal('foo/bar.dart', result); 10 | }); 11 | 12 | test('Shared root', () => { 13 | const filePath = 'foo'; 14 | const importPath = 'foo/bar.dart'; 15 | const result = relativize(filePath, importPath, '/'); 16 | assert.equal('bar.dart', result); 17 | }); 18 | 19 | test('One up', () => { 20 | const filePath = 'foo'; 21 | const importPath = 'bar.dart'; 22 | const result = relativize(filePath, importPath, '/'); 23 | assert.equal('../bar.dart', result); 24 | }); 25 | 26 | test('Some up', () => { 27 | const filePath = 'foo/bar/john/carl'; 28 | const importPath = 'foo/bar/sam/tom.dart'; 29 | const result = relativize(filePath, importPath, '/'); 30 | assert.equal('../../sam/tom.dart', result); 31 | }); 32 | }); -------------------------------------------------------------------------------- /src/test/suite/relativize.windows.test.ts: -------------------------------------------------------------------------------- 1 | import * as assert from 'assert'; 2 | import { relativize } from '../../main'; 3 | 4 | suite('#relativize windows test', () => { 5 | test('Root file path', () => { 6 | const filePath = ''; 7 | const importPath = 'foo/bar.dart'; 8 | const result = relativize(filePath, importPath, '\\'); 9 | assert.equal('foo/bar.dart', result); 10 | }); 11 | 12 | test('Shared root', () => { 13 | const filePath = 'foo'; 14 | const importPath = 'foo/bar.dart'; 15 | const result = relativize(filePath, importPath, '\\'); 16 | assert.equal('bar.dart', result); 17 | }); 18 | 19 | test('One up', () => { 20 | const filePath = 'foo'; 21 | const importPath = 'bar.dart'; 22 | const result = relativize(filePath, importPath, '\\'); 23 | assert.equal('../bar.dart', result); 24 | }); 25 | 26 | test('Some up', () => { 27 | const filePath = 'foo\\bar\\john\\carl'; 28 | const importPath = 'foo/bar/sam/tom.dart'; 29 | const result = relativize(filePath, importPath, '\\'); 30 | assert.equal('../../sam/tom.dart', result); 31 | }); 32 | }); -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "target": "es6", 5 | "outDir": "out", 6 | "lib": [ 7 | "es6" 8 | ], 9 | "sourceMap": true, 10 | "rootDir": "src", 11 | /* Strict Type-Checking Option */ 12 | "strict": true, /* enable all strict type-checking options */ 13 | /* Additional Checks */ 14 | "noUnusedLocals": true /* Report errors on unused locals. */ 15 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ 16 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ 17 | // "noUnusedParameters": true, /* Report errors on unused parameters. */ 18 | }, 19 | "exclude": [ 20 | "node_modules", 21 | ".vscode-test" 22 | ] 23 | } -------------------------------------------------------------------------------- /tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "rules": { 3 | "no-string-throw": true, 4 | "no-unused-expression": true, 5 | "no-duplicate-variable": true, 6 | "curly": true, 7 | "class-name": true, 8 | "semicolon": [ 9 | true, 10 | "always" 11 | ], 12 | "triple-equals": true 13 | }, 14 | "defaultSeverity": "warning" 15 | } --------------------------------------------------------------------------------