├── .gitignore ├── .nvmrc ├── .vscode ├── launch.json ├── settings.json └── tasks.json ├── .vscodeignore ├── CHANGELOG.md ├── LICENSE ├── README.md ├── data ├── classes.json └── defines.json ├── images ├── autocomplete.gif └── tooltips.gif ├── package-lock.json ├── package.json ├── scraper ├── classes.ts ├── config.ts ├── defines.ts ├── index.ts └── utils.ts ├── src ├── FactorioApiData.ts ├── FactorioAutocomplete.ts ├── FactorioHover.ts ├── extension.ts ├── types.d.ts └── utils.ts ├── test ├── extension.test.ts └── index.ts └── tsconfig.json /.gitignore: -------------------------------------------------------------------------------- 1 | out 2 | node_modules 3 | 4 | .vscode-test -------------------------------------------------------------------------------- /.nvmrc: -------------------------------------------------------------------------------- 1 | 8.16.0 2 | -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | // A launch configuration that compiles the extension and then opens it inside a new window 2 | { 3 | "version": "0.1.0", 4 | "configurations": [ 5 | 6 | { 7 | "name": "Launch Extension", 8 | "type": "extensionHost", 9 | "request": "launch", 10 | "runtimeExecutable": "${execPath}", 11 | "args": ["--extensionDevelopmentPath=${workspaceRoot}" ], 12 | "stopOnEntry": false, 13 | "sourceMaps": true, 14 | "outFiles": [ "${workspaceRoot}/out/src/**/*.js" ], 15 | "preLaunchTask": "npm" 16 | }, 17 | { 18 | "name": "Launch Tests", 19 | "type": "extensionHost", 20 | "request": "launch", 21 | "runtimeExecutable": "${execPath}", 22 | "args": ["--extensionDevelopmentPath=${workspaceRoot}", "--extensionTestsPath=${workspaceRoot}/out/test" ], 23 | "stopOnEntry": false, 24 | "sourceMaps": true, 25 | "outFiles": [ "${workspaceRoot}/out/test/**/*.js" ], 26 | "preLaunchTask": "npm" 27 | }, 28 | { 29 | "type": "node", 30 | "request": "launch", 31 | "name": "Launch scraper", 32 | "program": "${workspaceRoot}/node_modules/ts-node/dist/_bin.js", 33 | "args": ["scraper/index.ts"], 34 | "cwd": "${workspaceRoot}", 35 | "protocol": "inspector" 36 | }, 37 | { 38 | "name": "Current TS File", 39 | "type": "node", 40 | "request": "launch", 41 | "program": "${workspaceRoot}/node_modules/ts-node/dist/_bin.js", 42 | "args": ["${relativeFile}"], 43 | "cwd": "${workspaceRoot}", 44 | "protocol": "inspector" 45 | } 46 | ] 47 | } 48 | -------------------------------------------------------------------------------- /.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 | } -------------------------------------------------------------------------------- /.vscode/tasks.json: -------------------------------------------------------------------------------- 1 | // Available variables which can be used inside of strings. 2 | // ${workspaceRoot}: the root folder of the team 3 | // ${file}: the current opened file 4 | // ${fileBasename}: the current opened file's basename 5 | // ${fileDirname}: the current opened file's dirname 6 | // ${fileExtname}: the current opened file's extension 7 | // ${cwd}: the current working directory of the spawned process 8 | 9 | // A task runner that calls a custom npm script that compiles the extension. 10 | { 11 | "version": "0.1.0", 12 | 13 | // we want to run npm 14 | "command": "npm", 15 | 16 | // the command is a shell script 17 | "isShellCommand": true, 18 | 19 | // show the output window only if unrecognized errors occur. 20 | "showOutput": "silent", 21 | 22 | // we run the custom script "compile" as defined in package.json 23 | "args": ["run", "compile", "--loglevel", "silent"], 24 | 25 | // The tsc compiler is started in watching mode 26 | "isBackground": true, 27 | 28 | // use the standard tsc in watch mode problem matcher to find compile problems in the output. 29 | "problemMatcher": "$tsc-watch" 30 | } -------------------------------------------------------------------------------- /.vscodeignore: -------------------------------------------------------------------------------- 1 | .vscode/** 2 | .vscode-test/** 3 | out/test/** 4 | test/** 5 | src/** 6 | scraper/** 7 | **/*.map 8 | .gitignore 9 | tsconfig.json 10 | vsc-extension-quickstart.md 11 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Changelog 2 | 3 | ## 0.7.0 - 2019-06-01 4 | - Update to Factorio 0.17.45 5 | 6 | ## 0.6.0 - 2018-08-11 7 | - Update to Factorio 0.16.51 8 | - Autocomplete items now properly render markdown strings thanks to VS Codes addition of `MarkdownString` class 9 | 10 | ## 0.5.0 - 2017-07-31 11 | - Update to Factorio 0.15.31 12 | 13 | ## 0.4.0 - 2017-06-04 14 | - Class inheritance is now considered, meaning classes now also suggest properties of their parent classes (e.g. LuaEntity now properly displays properties inherited from LuaControl) 15 | - Tooltips are now rendered as markdown, including links to the official documentation 16 | - Added support for all LuaControlBehavior classes 17 | - Issue: vscode autocomplete items unfortunately don't support markdown strings, and so the raw markdown string will be displayed. 18 | 19 | ## 0.3.2 - 2017-05-05 20 | - Fixed data file loading issue 21 | 22 | ## 0.3.1 - 2017-05-04 23 | - Tried to fix data file loading issue 24 | 25 | ## 0.3.0 - 2017-05-04 26 | - Added mouse hover tooltips 27 | - Added events documentation 28 | - Fixed wrong type lookup in some cases 29 | 30 | ## 0.2.0 - 2017-05-01 31 | - Added autocomplete for [defines](http://lua-api.factorio.com/latest/defines.html) 32 | - Prettier type documentation with the help of [html-to-text](https://github.com/werk85/node-html-to-text) 33 | 34 | ## 0.1.1 - 2017-04-30 35 | - Added license and repository 36 | 37 | ## 0.1.0 - 2017-04-30 38 | - Initial release -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2017 Simon Vizzini 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Factorio API autocomplete extension 2 | 3 | ## Features 4 | 5 | - Autocomplete of all Lua classes and globals 6 | 7 | ![autocomplete](images/autocomplete.gif) 8 | 9 | - Mouse hover tooltips, with links to the official documentation at http://lua-api.factorio.com 10 | 11 | ![tooltips](images/tooltips.gif) 12 | 13 | ## Dev Requirements 14 | 15 | Using nvm you can get the correct node version to run the scraper: `nvm use`. 16 | 17 | After this install the necessary modules with `npm install`. 18 | 19 | ## Update data 20 | 21 | Run the scrapper to pull the latest data from the Factorio API documentation: `npx ts-node scraper/index.ts` 22 | 23 | ## Todo 24 | 25 | #### Features 26 | - Better support for functions that take tables as argument 27 | - Function signature hints (**registerSignatureHelpProvider**) 28 | 29 | #### Technical tasks 30 | - Instead of storing inherited properties in the data file, they should maybe get looked up during runtime 31 | - Unit tests 32 | 33 | ## [Changelog](CHANGELOG.md) 34 | -------------------------------------------------------------------------------- /images/autocomplete.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/simonvizzini/vscode-factorio-lua-api-autocomplete/449be19527176f4236b3667dc5994b1a3ad00ef9/images/autocomplete.gif -------------------------------------------------------------------------------- /images/tooltips.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/simonvizzini/vscode-factorio-lua-api-autocomplete/449be19527176f4236b3667dc5994b1a3ad00ef9/images/tooltips.gif -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "factorio-lua-api-autocomplete", 3 | "version": "0.7.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@types/lodash": { 8 | "version": "4.14.134", 9 | "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.134.tgz", 10 | "integrity": "sha512-2/O0khFUCFeDlbi7sZ7ZFRCcT812fAeOLm7Ev4KbwASkZ575TDrDcY7YyaoHdTOzKcNbfiwLYZqPmoC4wadrsw==", 11 | "dev": true 12 | }, 13 | "@types/mocha": { 14 | "version": "5.2.7", 15 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-5.2.7.tgz", 16 | "integrity": "sha512-NYrtPht0wGzhwe9+/idPaBB+TqkY9AhTvOLMkThm0IoEfLaiVQZwBwyJ5puCkO3AUCWrmcoePjp2mbFocKy4SQ==", 17 | "dev": true 18 | }, 19 | "@types/node": { 20 | "version": "12.0.7", 21 | "resolved": "https://registry.npmjs.org/@types/node/-/node-12.0.7.tgz", 22 | "integrity": "sha512-1YKeT4JitGgE4SOzyB9eMwO0nGVNkNEsm9qlIt1Lqm/tG2QEiSMTD4kS3aO6L+w5SClLVxALmIBESK6Mk5wX0A==", 23 | "dev": true 24 | }, 25 | "abbrev": { 26 | "version": "1.1.1", 27 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 28 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 29 | "dev": true 30 | }, 31 | "agent-base": { 32 | "version": "4.3.0", 33 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-4.3.0.tgz", 34 | "integrity": "sha512-salcGninV0nPrwpGNn4VTXBb1SOuXQBiqbrNXoeizJsHrsL6ERFM2Ne3JUSBWRE6aeNJI2ROP/WEEIDUiDe3cg==", 35 | "dev": true, 36 | "requires": { 37 | "es6-promisify": "^5.0.0" 38 | } 39 | }, 40 | "ajv": { 41 | "version": "6.10.0", 42 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.0.tgz", 43 | "integrity": "sha512-nffhOpkymDECQyR0mnsUtoCE8RlX38G0rYP+wgLWFyZuUyuuojSSvi/+euOiQBIn63whYwYVIIH1TvE3tu4OEg==", 44 | "dev": true, 45 | "requires": { 46 | "fast-deep-equal": "^2.0.1", 47 | "fast-json-stable-stringify": "^2.0.0", 48 | "json-schema-traverse": "^0.4.1", 49 | "uri-js": "^4.2.2" 50 | } 51 | }, 52 | "ansi-colors": { 53 | "version": "3.2.3", 54 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.3.tgz", 55 | "integrity": "sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw==", 56 | "dev": true 57 | }, 58 | "ansi-regex": { 59 | "version": "3.0.0", 60 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 61 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 62 | "dev": true 63 | }, 64 | "ansi-styles": { 65 | "version": "3.2.1", 66 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 67 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 68 | "dev": true, 69 | "requires": { 70 | "color-convert": "^1.9.0" 71 | } 72 | }, 73 | "aproba": { 74 | "version": "1.2.0", 75 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 76 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==", 77 | "dev": true 78 | }, 79 | "are-we-there-yet": { 80 | "version": "1.1.5", 81 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", 82 | "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", 83 | "dev": true, 84 | "requires": { 85 | "delegates": "^1.0.0", 86 | "readable-stream": "^2.0.6" 87 | }, 88 | "dependencies": { 89 | "readable-stream": { 90 | "version": "2.3.6", 91 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 92 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 93 | "dev": true, 94 | "requires": { 95 | "core-util-is": "~1.0.0", 96 | "inherits": "~2.0.3", 97 | "isarray": "~1.0.0", 98 | "process-nextick-args": "~2.0.0", 99 | "safe-buffer": "~5.1.1", 100 | "string_decoder": "~1.1.1", 101 | "util-deprecate": "~1.0.1" 102 | } 103 | }, 104 | "string_decoder": { 105 | "version": "1.1.1", 106 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 107 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 108 | "dev": true, 109 | "requires": { 110 | "safe-buffer": "~5.1.0" 111 | } 112 | } 113 | } 114 | }, 115 | "arg": { 116 | "version": "4.1.0", 117 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.0.tgz", 118 | "integrity": "sha512-ZWc51jO3qegGkVh8Hwpv636EkbesNV5ZNQPCtRa+0qytRYPEs9IYT9qITY9buezqUH5uqyzlWLcufrzU2rffdg==", 119 | "dev": true 120 | }, 121 | "argparse": { 122 | "version": "1.0.10", 123 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 124 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 125 | "dev": true, 126 | "requires": { 127 | "sprintf-js": "~1.0.2" 128 | } 129 | }, 130 | "asn1": { 131 | "version": "0.2.4", 132 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 133 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 134 | "dev": true, 135 | "requires": { 136 | "safer-buffer": "~2.1.0" 137 | } 138 | }, 139 | "assert-plus": { 140 | "version": "1.0.0", 141 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 142 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 143 | "dev": true 144 | }, 145 | "asynckit": { 146 | "version": "0.4.0", 147 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 148 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 149 | "dev": true 150 | }, 151 | "aws-sign2": { 152 | "version": "0.7.0", 153 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 154 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 155 | "dev": true 156 | }, 157 | "aws4": { 158 | "version": "1.8.0", 159 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.8.0.tgz", 160 | "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==", 161 | "dev": true 162 | }, 163 | "balanced-match": { 164 | "version": "1.0.0", 165 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 166 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 167 | "dev": true 168 | }, 169 | "bcrypt-pbkdf": { 170 | "version": "1.0.2", 171 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 172 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 173 | "dev": true, 174 | "requires": { 175 | "tweetnacl": "^0.14.3" 176 | } 177 | }, 178 | "bindings": { 179 | "version": "1.3.1", 180 | "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.3.1.tgz", 181 | "integrity": "sha512-i47mqjF9UbjxJhxGf+pZ6kSxrnI3wBLlnGI2ArWJ4r0VrvDS7ZYXkprq/pLaBWYq4GM0r4zdHY+NNRqEMU7uew==", 182 | "dev": true 183 | }, 184 | "brace-expansion": { 185 | "version": "1.1.11", 186 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 187 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 188 | "dev": true, 189 | "requires": { 190 | "balanced-match": "^1.0.0", 191 | "concat-map": "0.0.1" 192 | } 193 | }, 194 | "browser-stdout": { 195 | "version": "1.3.1", 196 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 197 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 198 | "dev": true 199 | }, 200 | "buffer-from": { 201 | "version": "1.1.1", 202 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 203 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 204 | "dev": true 205 | }, 206 | "camelcase": { 207 | "version": "5.3.1", 208 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 209 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 210 | "dev": true 211 | }, 212 | "caseless": { 213 | "version": "0.12.0", 214 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 215 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", 216 | "dev": true 217 | }, 218 | "chalk": { 219 | "version": "2.4.2", 220 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 221 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 222 | "dev": true, 223 | "requires": { 224 | "ansi-styles": "^3.2.1", 225 | "escape-string-regexp": "^1.0.5", 226 | "supports-color": "^5.3.0" 227 | }, 228 | "dependencies": { 229 | "supports-color": { 230 | "version": "5.5.0", 231 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 232 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 233 | "dev": true, 234 | "requires": { 235 | "has-flag": "^3.0.0" 236 | } 237 | } 238 | } 239 | }, 240 | "chownr": { 241 | "version": "1.1.1", 242 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.1.tgz", 243 | "integrity": "sha512-j38EvO5+LHX84jlo6h4UzmOwi0UgW61WRyPtJz4qaadK5eY3BTS5TY/S1Stc3Uk2lIM6TPevAlULiEJwie860g==", 244 | "dev": true 245 | }, 246 | "cliui": { 247 | "version": "4.1.0", 248 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz", 249 | "integrity": "sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ==", 250 | "dev": true, 251 | "requires": { 252 | "string-width": "^2.1.1", 253 | "strip-ansi": "^4.0.0", 254 | "wrap-ansi": "^2.0.0" 255 | } 256 | }, 257 | "code-point-at": { 258 | "version": "1.1.0", 259 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 260 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", 261 | "dev": true 262 | }, 263 | "color-convert": { 264 | "version": "1.9.3", 265 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 266 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 267 | "dev": true, 268 | "requires": { 269 | "color-name": "1.1.3" 270 | } 271 | }, 272 | "color-name": { 273 | "version": "1.1.3", 274 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 275 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 276 | "dev": true 277 | }, 278 | "combined-stream": { 279 | "version": "1.0.8", 280 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 281 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 282 | "dev": true, 283 | "requires": { 284 | "delayed-stream": "~1.0.0" 285 | } 286 | }, 287 | "commander": { 288 | "version": "2.11.0", 289 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.11.0.tgz", 290 | "integrity": "sha512-b0553uYA5YAEGgyYIGYROzKQ7X5RAqedkfjiZxwi0kL1g3bOaBNNZfYkzt/CL0umgD5wc9Jec2FbB98CjkMRvQ==", 291 | "dev": true 292 | }, 293 | "concat-map": { 294 | "version": "0.0.1", 295 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 296 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 297 | "dev": true 298 | }, 299 | "console-control-strings": { 300 | "version": "1.1.0", 301 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 302 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=", 303 | "dev": true 304 | }, 305 | "core-util-is": { 306 | "version": "1.0.2", 307 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 308 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 309 | "dev": true 310 | }, 311 | "cross-spawn": { 312 | "version": "6.0.5", 313 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 314 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 315 | "dev": true, 316 | "requires": { 317 | "nice-try": "^1.0.4", 318 | "path-key": "^2.0.1", 319 | "semver": "^5.5.0", 320 | "shebang-command": "^1.2.0", 321 | "which": "^1.2.9" 322 | } 323 | }, 324 | "css2xpath": { 325 | "version": "0.0.1", 326 | "resolved": "https://registry.npmjs.org/css2xpath/-/css2xpath-0.0.1.tgz", 327 | "integrity": "sha1-8QUC1kkzDWz/toK7IbO7VFVDw2U=", 328 | "dev": true 329 | }, 330 | "dashdash": { 331 | "version": "1.14.1", 332 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 333 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 334 | "dev": true, 335 | "requires": { 336 | "assert-plus": "^1.0.0" 337 | } 338 | }, 339 | "debug": { 340 | "version": "3.2.6", 341 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 342 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 343 | "dev": true, 344 | "requires": { 345 | "ms": "^2.1.1" 346 | } 347 | }, 348 | "decamelize": { 349 | "version": "1.2.0", 350 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 351 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 352 | "dev": true 353 | }, 354 | "deep-extend": { 355 | "version": "0.6.0", 356 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 357 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 358 | "dev": true 359 | }, 360 | "define-properties": { 361 | "version": "1.1.3", 362 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 363 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 364 | "dev": true, 365 | "requires": { 366 | "object-keys": "^1.0.12" 367 | } 368 | }, 369 | "delayed-stream": { 370 | "version": "1.0.0", 371 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 372 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 373 | "dev": true 374 | }, 375 | "delegates": { 376 | "version": "1.0.0", 377 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 378 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=", 379 | "dev": true 380 | }, 381 | "detect-libc": { 382 | "version": "1.0.3", 383 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz", 384 | "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=", 385 | "dev": true 386 | }, 387 | "diff": { 388 | "version": "3.5.0", 389 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 390 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 391 | "dev": true 392 | }, 393 | "dom-serializer": { 394 | "version": "0.1.1", 395 | "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.1.1.tgz", 396 | "integrity": "sha512-l0IU0pPzLWSHBcieZbpOKgkIn3ts3vAh7ZuFyXNwJxJXk/c4Gwj9xaTJwIDVQCXawWD0qb3IzMGH5rglQaO0XA==", 397 | "dev": true, 398 | "requires": { 399 | "domelementtype": "^1.3.0", 400 | "entities": "^1.1.1" 401 | } 402 | }, 403 | "domelementtype": { 404 | "version": "1.3.1", 405 | "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz", 406 | "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==", 407 | "dev": true 408 | }, 409 | "domhandler": { 410 | "version": "2.4.2", 411 | "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.4.2.tgz", 412 | "integrity": "sha512-JiK04h0Ht5u/80fdLMCEmV4zkNh2BcoMFBmZ/91WtYZ8qVXSKjiw7fXMgFPnHcSZgOo3XdinHvmnDUeMf5R4wA==", 413 | "dev": true, 414 | "requires": { 415 | "domelementtype": "1" 416 | } 417 | }, 418 | "domutils": { 419 | "version": "1.7.0", 420 | "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.7.0.tgz", 421 | "integrity": "sha512-Lgd2XcJ/NjEw+7tFvfKxOzCYKZsdct5lczQ2ZaQY8Djz7pfAD3Gbp8ySJWtreII/vDlMVmxwa6pHmdxIYgttDg==", 422 | "dev": true, 423 | "requires": { 424 | "dom-serializer": "0", 425 | "domelementtype": "1" 426 | } 427 | }, 428 | "ecc-jsbn": { 429 | "version": "0.1.2", 430 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 431 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 432 | "dev": true, 433 | "requires": { 434 | "jsbn": "~0.1.0", 435 | "safer-buffer": "^2.1.0" 436 | } 437 | }, 438 | "emoji-regex": { 439 | "version": "7.0.3", 440 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 441 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 442 | "dev": true 443 | }, 444 | "end-of-stream": { 445 | "version": "1.4.1", 446 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz", 447 | "integrity": "sha512-1MkrZNvWTKCaigbn+W15elq2BB/L22nqrSY5DKlo3X6+vclJm8Bb5djXJBmEX6fS3+zCh/F4VBK5Z2KxJt4s2Q==", 448 | "dev": true, 449 | "requires": { 450 | "once": "^1.4.0" 451 | } 452 | }, 453 | "entities": { 454 | "version": "1.1.2", 455 | "resolved": "https://registry.npmjs.org/entities/-/entities-1.1.2.tgz", 456 | "integrity": "sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w==", 457 | "dev": true 458 | }, 459 | "es-abstract": { 460 | "version": "1.13.0", 461 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", 462 | "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", 463 | "dev": true, 464 | "requires": { 465 | "es-to-primitive": "^1.2.0", 466 | "function-bind": "^1.1.1", 467 | "has": "^1.0.3", 468 | "is-callable": "^1.1.4", 469 | "is-regex": "^1.0.4", 470 | "object-keys": "^1.0.12" 471 | } 472 | }, 473 | "es-to-primitive": { 474 | "version": "1.2.0", 475 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 476 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 477 | "dev": true, 478 | "requires": { 479 | "is-callable": "^1.1.4", 480 | "is-date-object": "^1.0.1", 481 | "is-symbol": "^1.0.2" 482 | } 483 | }, 484 | "es6-promise": { 485 | "version": "4.2.8", 486 | "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.8.tgz", 487 | "integrity": "sha512-HJDGx5daxeIvxdBxvG2cb9g4tEvwIk3i8+nhX0yGrYmZUzbkdg8QbDevheDB8gd0//uPj4c1EQua8Q+MViT0/w==", 488 | "dev": true 489 | }, 490 | "es6-promisify": { 491 | "version": "5.0.0", 492 | "resolved": "https://registry.npmjs.org/es6-promisify/-/es6-promisify-5.0.0.tgz", 493 | "integrity": "sha1-UQnWLz5W6pZ8S2NQWu8IKRyKUgM=", 494 | "dev": true, 495 | "requires": { 496 | "es6-promise": "^4.0.3" 497 | } 498 | }, 499 | "escape-string-regexp": { 500 | "version": "1.0.5", 501 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 502 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 503 | "dev": true 504 | }, 505 | "esprima": { 506 | "version": "4.0.1", 507 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 508 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 509 | "dev": true 510 | }, 511 | "execa": { 512 | "version": "1.0.0", 513 | "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", 514 | "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", 515 | "dev": true, 516 | "requires": { 517 | "cross-spawn": "^6.0.0", 518 | "get-stream": "^4.0.0", 519 | "is-stream": "^1.1.0", 520 | "npm-run-path": "^2.0.0", 521 | "p-finally": "^1.0.0", 522 | "signal-exit": "^3.0.0", 523 | "strip-eof": "^1.0.0" 524 | } 525 | }, 526 | "extend": { 527 | "version": "3.0.2", 528 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 529 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 530 | "dev": true 531 | }, 532 | "extsprintf": { 533 | "version": "1.3.0", 534 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 535 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 536 | "dev": true 537 | }, 538 | "fast-deep-equal": { 539 | "version": "2.0.1", 540 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 541 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 542 | "dev": true 543 | }, 544 | "fast-json-stable-stringify": { 545 | "version": "2.0.0", 546 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 547 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 548 | "dev": true 549 | }, 550 | "find-up": { 551 | "version": "3.0.0", 552 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 553 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 554 | "dev": true, 555 | "requires": { 556 | "locate-path": "^3.0.0" 557 | } 558 | }, 559 | "flat": { 560 | "version": "4.1.0", 561 | "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", 562 | "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", 563 | "dev": true, 564 | "requires": { 565 | "is-buffer": "~2.0.3" 566 | } 567 | }, 568 | "forever-agent": { 569 | "version": "0.6.1", 570 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 571 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 572 | "dev": true 573 | }, 574 | "form-data": { 575 | "version": "2.3.3", 576 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 577 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 578 | "dev": true, 579 | "requires": { 580 | "asynckit": "^0.4.0", 581 | "combined-stream": "^1.0.6", 582 | "mime-types": "^2.1.12" 583 | } 584 | }, 585 | "fs-minipass": { 586 | "version": "1.2.6", 587 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.6.tgz", 588 | "integrity": "sha512-crhvyXcMejjv3Z5d2Fa9sf5xLYVCF5O1c71QxbVnbLsmYMBEvDAftewesN/HhY03YRoA7zOMxjNGrF5svGaaeQ==", 589 | "dev": true, 590 | "requires": { 591 | "minipass": "^2.2.1" 592 | } 593 | }, 594 | "fs.realpath": { 595 | "version": "1.0.0", 596 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 597 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 598 | "dev": true 599 | }, 600 | "function-bind": { 601 | "version": "1.1.1", 602 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 603 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 604 | "dev": true 605 | }, 606 | "gauge": { 607 | "version": "2.7.4", 608 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 609 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 610 | "dev": true, 611 | "requires": { 612 | "aproba": "^1.0.3", 613 | "console-control-strings": "^1.0.0", 614 | "has-unicode": "^2.0.0", 615 | "object-assign": "^4.1.0", 616 | "signal-exit": "^3.0.0", 617 | "string-width": "^1.0.1", 618 | "strip-ansi": "^3.0.1", 619 | "wide-align": "^1.1.0" 620 | }, 621 | "dependencies": { 622 | "ansi-regex": { 623 | "version": "2.1.1", 624 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 625 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 626 | "dev": true 627 | }, 628 | "is-fullwidth-code-point": { 629 | "version": "1.0.0", 630 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 631 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 632 | "dev": true, 633 | "requires": { 634 | "number-is-nan": "^1.0.0" 635 | } 636 | }, 637 | "string-width": { 638 | "version": "1.0.2", 639 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 640 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 641 | "dev": true, 642 | "requires": { 643 | "code-point-at": "^1.0.0", 644 | "is-fullwidth-code-point": "^1.0.0", 645 | "strip-ansi": "^3.0.0" 646 | } 647 | }, 648 | "strip-ansi": { 649 | "version": "3.0.1", 650 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 651 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 652 | "dev": true, 653 | "requires": { 654 | "ansi-regex": "^2.0.0" 655 | } 656 | } 657 | } 658 | }, 659 | "get-caller-file": { 660 | "version": "2.0.5", 661 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 662 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 663 | "dev": true 664 | }, 665 | "get-stream": { 666 | "version": "4.1.0", 667 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 668 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 669 | "dev": true, 670 | "requires": { 671 | "pump": "^3.0.0" 672 | } 673 | }, 674 | "getpass": { 675 | "version": "0.1.7", 676 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 677 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 678 | "dev": true, 679 | "requires": { 680 | "assert-plus": "^1.0.0" 681 | } 682 | }, 683 | "glob": { 684 | "version": "7.1.3", 685 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 686 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 687 | "dev": true, 688 | "requires": { 689 | "fs.realpath": "^1.0.0", 690 | "inflight": "^1.0.4", 691 | "inherits": "2", 692 | "minimatch": "^3.0.4", 693 | "once": "^1.3.0", 694 | "path-is-absolute": "^1.0.0" 695 | } 696 | }, 697 | "growl": { 698 | "version": "1.10.5", 699 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 700 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 701 | "dev": true 702 | }, 703 | "har-schema": { 704 | "version": "2.0.0", 705 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 706 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 707 | "dev": true 708 | }, 709 | "har-validator": { 710 | "version": "5.1.3", 711 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", 712 | "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", 713 | "dev": true, 714 | "requires": { 715 | "ajv": "^6.5.5", 716 | "har-schema": "^2.0.0" 717 | } 718 | }, 719 | "has": { 720 | "version": "1.0.3", 721 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 722 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 723 | "dev": true, 724 | "requires": { 725 | "function-bind": "^1.1.1" 726 | } 727 | }, 728 | "has-flag": { 729 | "version": "3.0.0", 730 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 731 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 732 | "dev": true 733 | }, 734 | "has-symbols": { 735 | "version": "1.0.0", 736 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 737 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 738 | "dev": true 739 | }, 740 | "has-unicode": { 741 | "version": "2.0.1", 742 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 743 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=", 744 | "dev": true 745 | }, 746 | "he": { 747 | "version": "1.2.0", 748 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 749 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 750 | "dev": true 751 | }, 752 | "html-to-text": { 753 | "version": "5.1.1", 754 | "resolved": "https://registry.npmjs.org/html-to-text/-/html-to-text-5.1.1.tgz", 755 | "integrity": "sha512-Bci6bD/JIfZSvG4s0gW/9mMKwBRoe/1RWLxUME/d6WUSZCdY7T60bssf/jFf7EYXRyqU4P5xdClVqiYU0/ypdA==", 756 | "dev": true, 757 | "requires": { 758 | "he": "^1.2.0", 759 | "htmlparser2": "^3.10.1", 760 | "lodash": "^4.17.11", 761 | "minimist": "^1.2.0" 762 | } 763 | }, 764 | "htmlparser2": { 765 | "version": "3.10.1", 766 | "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.10.1.tgz", 767 | "integrity": "sha512-IgieNijUMbkDovyoKObU1DUhm1iwNYE/fuifEoEHfd1oZKZDaONBSkal7Y01shxsM49R4XaMdGez3WnF9UfiCQ==", 768 | "dev": true, 769 | "requires": { 770 | "domelementtype": "^1.3.1", 771 | "domhandler": "^2.3.0", 772 | "domutils": "^1.5.1", 773 | "entities": "^1.1.1", 774 | "inherits": "^2.0.1", 775 | "readable-stream": "^3.1.1" 776 | } 777 | }, 778 | "http-proxy-agent": { 779 | "version": "2.1.0", 780 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-2.1.0.tgz", 781 | "integrity": "sha512-qwHbBLV7WviBl0rQsOzH6o5lwyOIvwp/BdFnvVxXORldu5TmjFfjzBcWUWS5kWAZhmv+JtiDhSuQCp4sBfbIgg==", 782 | "dev": true, 783 | "requires": { 784 | "agent-base": "4", 785 | "debug": "3.1.0" 786 | }, 787 | "dependencies": { 788 | "debug": { 789 | "version": "3.1.0", 790 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 791 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 792 | "dev": true, 793 | "requires": { 794 | "ms": "2.0.0" 795 | } 796 | }, 797 | "ms": { 798 | "version": "2.0.0", 799 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 800 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 801 | "dev": true 802 | } 803 | } 804 | }, 805 | "http-signature": { 806 | "version": "1.2.0", 807 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 808 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 809 | "dev": true, 810 | "requires": { 811 | "assert-plus": "^1.0.0", 812 | "jsprim": "^1.2.2", 813 | "sshpk": "^1.7.0" 814 | } 815 | }, 816 | "https-proxy-agent": { 817 | "version": "2.2.1", 818 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-2.2.1.tgz", 819 | "integrity": "sha512-HPCTS1LW51bcyMYbxUIOO4HEOlQ1/1qRaFWcyxvwaqUS9TY88aoEuHUY33kuAh1YhVVaDQhLZsnPd+XNARWZlQ==", 820 | "dev": true, 821 | "requires": { 822 | "agent-base": "^4.1.0", 823 | "debug": "^3.1.0" 824 | } 825 | }, 826 | "iconv-lite": { 827 | "version": "0.4.24", 828 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 829 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 830 | "dev": true, 831 | "requires": { 832 | "safer-buffer": ">= 2.1.2 < 3" 833 | } 834 | }, 835 | "ignore-walk": { 836 | "version": "3.0.1", 837 | "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.1.tgz", 838 | "integrity": "sha512-DTVlMx3IYPe0/JJcYP7Gxg7ttZZu3IInhuEhbchuqneY9wWe5Ojy2mXLBaQFUQmo0AW2r3qG7m1mg86js+gnlQ==", 839 | "dev": true, 840 | "requires": { 841 | "minimatch": "^3.0.4" 842 | } 843 | }, 844 | "inflight": { 845 | "version": "1.0.6", 846 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 847 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 848 | "dev": true, 849 | "requires": { 850 | "once": "^1.3.0", 851 | "wrappy": "1" 852 | } 853 | }, 854 | "inherits": { 855 | "version": "2.0.3", 856 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 857 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 858 | "dev": true 859 | }, 860 | "ini": { 861 | "version": "1.3.5", 862 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 863 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", 864 | "dev": true 865 | }, 866 | "invert-kv": { 867 | "version": "2.0.0", 868 | "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-2.0.0.tgz", 869 | "integrity": "sha512-wPVv/y/QQ/Uiirj/vh3oP+1Ww+AWehmi1g5fFWGPF6IpCBCDVrhgHRMvrLfdYcwDh3QJbGXDW4JAuzxElLSqKA==", 870 | "dev": true 871 | }, 872 | "is-buffer": { 873 | "version": "2.0.3", 874 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.3.tgz", 875 | "integrity": "sha512-U15Q7MXTuZlrbymiz95PJpZxu8IlipAp4dtS3wOdgPXx3mqBnslrWU14kxfHB+Py/+2PVKSr37dMAgM2A4uArw==", 876 | "dev": true 877 | }, 878 | "is-callable": { 879 | "version": "1.1.4", 880 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 881 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 882 | "dev": true 883 | }, 884 | "is-date-object": { 885 | "version": "1.0.1", 886 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 887 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 888 | "dev": true 889 | }, 890 | "is-fullwidth-code-point": { 891 | "version": "2.0.0", 892 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 893 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 894 | "dev": true 895 | }, 896 | "is-regex": { 897 | "version": "1.0.4", 898 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 899 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 900 | "dev": true, 901 | "requires": { 902 | "has": "^1.0.1" 903 | } 904 | }, 905 | "is-stream": { 906 | "version": "1.1.0", 907 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 908 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", 909 | "dev": true 910 | }, 911 | "is-symbol": { 912 | "version": "1.0.2", 913 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 914 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 915 | "dev": true, 916 | "requires": { 917 | "has-symbols": "^1.0.0" 918 | } 919 | }, 920 | "is-typedarray": { 921 | "version": "1.0.0", 922 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 923 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 924 | "dev": true 925 | }, 926 | "isarray": { 927 | "version": "1.0.0", 928 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 929 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 930 | "dev": true 931 | }, 932 | "isexe": { 933 | "version": "2.0.0", 934 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 935 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 936 | "dev": true 937 | }, 938 | "isstream": { 939 | "version": "0.1.2", 940 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 941 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", 942 | "dev": true 943 | }, 944 | "js-yaml": { 945 | "version": "3.13.1", 946 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 947 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 948 | "dev": true, 949 | "requires": { 950 | "argparse": "^1.0.7", 951 | "esprima": "^4.0.0" 952 | } 953 | }, 954 | "jsbn": { 955 | "version": "0.1.1", 956 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 957 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 958 | "dev": true 959 | }, 960 | "json-schema": { 961 | "version": "0.2.3", 962 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 963 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", 964 | "dev": true 965 | }, 966 | "json-schema-traverse": { 967 | "version": "0.4.1", 968 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 969 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 970 | "dev": true 971 | }, 972 | "json-stringify-safe": { 973 | "version": "5.0.1", 974 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 975 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", 976 | "dev": true 977 | }, 978 | "jsprim": { 979 | "version": "1.4.1", 980 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 981 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 982 | "dev": true, 983 | "requires": { 984 | "assert-plus": "1.0.0", 985 | "extsprintf": "1.3.0", 986 | "json-schema": "0.2.3", 987 | "verror": "1.10.0" 988 | } 989 | }, 990 | "lcid": { 991 | "version": "2.0.0", 992 | "resolved": "https://registry.npmjs.org/lcid/-/lcid-2.0.0.tgz", 993 | "integrity": "sha512-avPEb8P8EGnwXKClwsNUgryVjllcRqtMYa49NTsbQagYuT1DcXnl1915oxWjoyGrXR6zH/Y0Zc96xWsPcoDKeA==", 994 | "dev": true, 995 | "requires": { 996 | "invert-kv": "^2.0.0" 997 | } 998 | }, 999 | "libxmljs": { 1000 | "version": "0.19.5", 1001 | "resolved": "https://registry.npmjs.org/libxmljs/-/libxmljs-0.19.5.tgz", 1002 | "integrity": "sha512-mKlafbSIsgZCXcha6loyMN/Q1kcbNJ5N3VC/rS0vrJXdI99TzEI2i2rPp10HN/B70vSPh6bq6nHhoCT19eGtTw==", 1003 | "dev": true, 1004 | "requires": { 1005 | "bindings": "~1.3.0", 1006 | "nan": "~2.10.0", 1007 | "node-pre-gyp": "~0.11.0" 1008 | } 1009 | }, 1010 | "libxmljs-dom": { 1011 | "version": "0.0.17", 1012 | "resolved": "https://registry.npmjs.org/libxmljs-dom/-/libxmljs-dom-0.0.17.tgz", 1013 | "integrity": "sha512-4+ySRJ53vvOExM1IQneP+pKiy4r0lFCSm2RhZA1Tur3xqu6DGMoL7+cAFNCI1qyEYP/otq16Ku98U7Izi53PNw==", 1014 | "dev": true, 1015 | "requires": { 1016 | "css2xpath": "0.0.1", 1017 | "libxmljs": "^0.19.5", 1018 | "needle": ">=0.9.2" 1019 | } 1020 | }, 1021 | "locate-path": { 1022 | "version": "3.0.0", 1023 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1024 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1025 | "dev": true, 1026 | "requires": { 1027 | "p-locate": "^3.0.0", 1028 | "path-exists": "^3.0.0" 1029 | } 1030 | }, 1031 | "lodash": { 1032 | "version": "4.17.11", 1033 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 1034 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" 1035 | }, 1036 | "log-symbols": { 1037 | "version": "2.2.0", 1038 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-2.2.0.tgz", 1039 | "integrity": "sha512-VeIAFslyIerEJLXHziedo2basKbMKtTw3vfn5IzG0XTjhAVEJyNHnL2p7vc+wBDSdQuUpNw3M2u6xb9QsAY5Eg==", 1040 | "dev": true, 1041 | "requires": { 1042 | "chalk": "^2.0.1" 1043 | } 1044 | }, 1045 | "make-error": { 1046 | "version": "1.3.5", 1047 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.5.tgz", 1048 | "integrity": "sha512-c3sIjNUow0+8swNwVpqoH4YCShKNFkMaw6oH1mNS2haDZQqkeZFlHS3dhoeEbKKmJB4vXpJucU6oH75aDYeE9g==", 1049 | "dev": true 1050 | }, 1051 | "map-age-cleaner": { 1052 | "version": "0.1.3", 1053 | "resolved": "https://registry.npmjs.org/map-age-cleaner/-/map-age-cleaner-0.1.3.tgz", 1054 | "integrity": "sha512-bJzx6nMoP6PDLPBFmg7+xRKeFZvFboMrGlxmNj9ClvX53KrmvM5bXFXEWjbz4cz1AFn+jWJ9z/DJSz7hrs0w3w==", 1055 | "dev": true, 1056 | "requires": { 1057 | "p-defer": "^1.0.0" 1058 | } 1059 | }, 1060 | "mem": { 1061 | "version": "4.3.0", 1062 | "resolved": "https://registry.npmjs.org/mem/-/mem-4.3.0.tgz", 1063 | "integrity": "sha512-qX2bG48pTqYRVmDB37rn/6PT7LcR8T7oAX3bf99u1Tt1nzxYfxkgqDwUwolPlXweM0XzBOBFzSx4kfp7KP1s/w==", 1064 | "dev": true, 1065 | "requires": { 1066 | "map-age-cleaner": "^0.1.1", 1067 | "mimic-fn": "^2.0.0", 1068 | "p-is-promise": "^2.0.0" 1069 | } 1070 | }, 1071 | "mime-db": { 1072 | "version": "1.40.0", 1073 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", 1074 | "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==", 1075 | "dev": true 1076 | }, 1077 | "mime-types": { 1078 | "version": "2.1.24", 1079 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", 1080 | "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", 1081 | "dev": true, 1082 | "requires": { 1083 | "mime-db": "1.40.0" 1084 | } 1085 | }, 1086 | "mimic-fn": { 1087 | "version": "2.1.0", 1088 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1089 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1090 | "dev": true 1091 | }, 1092 | "minimatch": { 1093 | "version": "3.0.4", 1094 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1095 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1096 | "dev": true, 1097 | "requires": { 1098 | "brace-expansion": "^1.1.7" 1099 | } 1100 | }, 1101 | "minimist": { 1102 | "version": "1.2.0", 1103 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1104 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 1105 | "dev": true 1106 | }, 1107 | "minipass": { 1108 | "version": "2.3.5", 1109 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.3.5.tgz", 1110 | "integrity": "sha512-Gi1W4k059gyRbyVUZQ4mEqLm0YIUiGYfvxhF6SIlk3ui1WVxMTGfGdQ2SInh3PDrRTVvPKgULkpJtT4RH10+VA==", 1111 | "dev": true, 1112 | "requires": { 1113 | "safe-buffer": "^5.1.2", 1114 | "yallist": "^3.0.0" 1115 | } 1116 | }, 1117 | "minizlib": { 1118 | "version": "1.2.1", 1119 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.2.1.tgz", 1120 | "integrity": "sha512-7+4oTUOWKg7AuL3vloEWekXY2/D20cevzsrNT2kGWm+39J9hGTCBv8VI5Pm5lXZ/o3/mdR4f8rflAPhnQb8mPA==", 1121 | "dev": true, 1122 | "requires": { 1123 | "minipass": "^2.2.1" 1124 | } 1125 | }, 1126 | "mkdirp": { 1127 | "version": "0.5.1", 1128 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1129 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1130 | "dev": true, 1131 | "requires": { 1132 | "minimist": "0.0.8" 1133 | }, 1134 | "dependencies": { 1135 | "minimist": { 1136 | "version": "0.0.8", 1137 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1138 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1139 | "dev": true 1140 | } 1141 | } 1142 | }, 1143 | "mocha": { 1144 | "version": "6.1.4", 1145 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-6.1.4.tgz", 1146 | "integrity": "sha512-PN8CIy4RXsIoxoFJzS4QNnCH4psUCPWc4/rPrst/ecSJJbLBkubMiyGCP2Kj/9YnWbotFqAoeXyXMucj7gwCFg==", 1147 | "dev": true, 1148 | "requires": { 1149 | "ansi-colors": "3.2.3", 1150 | "browser-stdout": "1.3.1", 1151 | "debug": "3.2.6", 1152 | "diff": "3.5.0", 1153 | "escape-string-regexp": "1.0.5", 1154 | "find-up": "3.0.0", 1155 | "glob": "7.1.3", 1156 | "growl": "1.10.5", 1157 | "he": "1.2.0", 1158 | "js-yaml": "3.13.1", 1159 | "log-symbols": "2.2.0", 1160 | "minimatch": "3.0.4", 1161 | "mkdirp": "0.5.1", 1162 | "ms": "2.1.1", 1163 | "node-environment-flags": "1.0.5", 1164 | "object.assign": "4.1.0", 1165 | "strip-json-comments": "2.0.1", 1166 | "supports-color": "6.0.0", 1167 | "which": "1.3.1", 1168 | "wide-align": "1.1.3", 1169 | "yargs": "13.2.2", 1170 | "yargs-parser": "13.0.0", 1171 | "yargs-unparser": "1.5.0" 1172 | } 1173 | }, 1174 | "ms": { 1175 | "version": "2.1.1", 1176 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1177 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 1178 | "dev": true 1179 | }, 1180 | "nan": { 1181 | "version": "2.10.0", 1182 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.10.0.tgz", 1183 | "integrity": "sha512-bAdJv7fBLhWC+/Bls0Oza+mvTaNQtP+1RyhhhvD95pgUJz6XM5IzgmxOkItJ9tkoCiplvAnXI1tNmmUD/eScyA==", 1184 | "dev": true 1185 | }, 1186 | "needle": { 1187 | "version": "1.6.0", 1188 | "resolved": "https://registry.npmjs.org/needle/-/needle-1.6.0.tgz", 1189 | "integrity": "sha1-9SpYWJchIWGOAC+OY4TK2sItYk8=", 1190 | "dev": true, 1191 | "requires": { 1192 | "debug": "^2.1.2", 1193 | "iconv-lite": "^0.4.4" 1194 | }, 1195 | "dependencies": { 1196 | "debug": { 1197 | "version": "2.6.9", 1198 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1199 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1200 | "dev": true, 1201 | "requires": { 1202 | "ms": "2.0.0" 1203 | } 1204 | }, 1205 | "ms": { 1206 | "version": "2.0.0", 1207 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1208 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1209 | "dev": true 1210 | } 1211 | } 1212 | }, 1213 | "nice-try": { 1214 | "version": "1.0.5", 1215 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1216 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1217 | "dev": true 1218 | }, 1219 | "node-environment-flags": { 1220 | "version": "1.0.5", 1221 | "resolved": "https://registry.npmjs.org/node-environment-flags/-/node-environment-flags-1.0.5.tgz", 1222 | "integrity": "sha512-VNYPRfGfmZLx0Ye20jWzHUjyTW/c+6Wq+iLhDzUI4XmhrDd9l/FozXV3F2xOaXjvp0co0+v1YSR3CMP6g+VvLQ==", 1223 | "dev": true, 1224 | "requires": { 1225 | "object.getownpropertydescriptors": "^2.0.3", 1226 | "semver": "^5.7.0" 1227 | } 1228 | }, 1229 | "node-pre-gyp": { 1230 | "version": "0.11.0", 1231 | "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.11.0.tgz", 1232 | "integrity": "sha512-TwWAOZb0j7e9eGaf9esRx3ZcLaE5tQ2lvYy1pb5IAaG1a2e2Kv5Lms1Y4hpj+ciXJRofIxxlt5haeQ/2ANeE0Q==", 1233 | "dev": true, 1234 | "requires": { 1235 | "detect-libc": "^1.0.2", 1236 | "mkdirp": "^0.5.1", 1237 | "needle": "^2.2.1", 1238 | "nopt": "^4.0.1", 1239 | "npm-packlist": "^1.1.6", 1240 | "npmlog": "^4.0.2", 1241 | "rc": "^1.2.7", 1242 | "rimraf": "^2.6.1", 1243 | "semver": "^5.3.0", 1244 | "tar": "^4" 1245 | }, 1246 | "dependencies": { 1247 | "needle": { 1248 | "version": "2.4.0", 1249 | "resolved": "https://registry.npmjs.org/needle/-/needle-2.4.0.tgz", 1250 | "integrity": "sha512-4Hnwzr3mi5L97hMYeNl8wRW/Onhy4nUKR/lVemJ8gJedxxUyBLm9kkrDColJvoSfwi0jCNhD+xCdOtiGDQiRZg==", 1251 | "dev": true, 1252 | "requires": { 1253 | "debug": "^3.2.6", 1254 | "iconv-lite": "^0.4.4", 1255 | "sax": "^1.2.4" 1256 | } 1257 | } 1258 | } 1259 | }, 1260 | "nopt": { 1261 | "version": "4.0.1", 1262 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.1.tgz", 1263 | "integrity": "sha1-0NRoWv1UFRk8jHUFYC0NF81kR00=", 1264 | "dev": true, 1265 | "requires": { 1266 | "abbrev": "1", 1267 | "osenv": "^0.1.4" 1268 | } 1269 | }, 1270 | "npm-bundled": { 1271 | "version": "1.0.6", 1272 | "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.0.6.tgz", 1273 | "integrity": "sha512-8/JCaftHwbd//k6y2rEWp6k1wxVfpFzB6t1p825+cUb7Ym2XQfhwIC5KwhrvzZRJu+LtDE585zVaS32+CGtf0g==", 1274 | "dev": true 1275 | }, 1276 | "npm-packlist": { 1277 | "version": "1.4.1", 1278 | "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.4.1.tgz", 1279 | "integrity": "sha512-+TcdO7HJJ8peiiYhvPxsEDhF3PJFGUGRcFsGve3vxvxdcpO2Z4Z7rkosRM0kWj6LfbK/P0gu3dzk5RU1ffvFcw==", 1280 | "dev": true, 1281 | "requires": { 1282 | "ignore-walk": "^3.0.1", 1283 | "npm-bundled": "^1.0.1" 1284 | } 1285 | }, 1286 | "npm-run-path": { 1287 | "version": "2.0.2", 1288 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 1289 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 1290 | "dev": true, 1291 | "requires": { 1292 | "path-key": "^2.0.0" 1293 | } 1294 | }, 1295 | "npmlog": { 1296 | "version": "4.1.2", 1297 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 1298 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 1299 | "dev": true, 1300 | "requires": { 1301 | "are-we-there-yet": "~1.1.2", 1302 | "console-control-strings": "~1.1.0", 1303 | "gauge": "~2.7.3", 1304 | "set-blocking": "~2.0.0" 1305 | } 1306 | }, 1307 | "number-is-nan": { 1308 | "version": "1.0.1", 1309 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1310 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", 1311 | "dev": true 1312 | }, 1313 | "oauth-sign": { 1314 | "version": "0.9.0", 1315 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 1316 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", 1317 | "dev": true 1318 | }, 1319 | "object-assign": { 1320 | "version": "4.1.1", 1321 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1322 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1323 | "dev": true 1324 | }, 1325 | "object-keys": { 1326 | "version": "1.1.1", 1327 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1328 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1329 | "dev": true 1330 | }, 1331 | "object.assign": { 1332 | "version": "4.1.0", 1333 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1334 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1335 | "dev": true, 1336 | "requires": { 1337 | "define-properties": "^1.1.2", 1338 | "function-bind": "^1.1.1", 1339 | "has-symbols": "^1.0.0", 1340 | "object-keys": "^1.0.11" 1341 | } 1342 | }, 1343 | "object.getownpropertydescriptors": { 1344 | "version": "2.0.3", 1345 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.0.3.tgz", 1346 | "integrity": "sha1-h1jIRvW0B62rDyNuCYbxSwUcqhY=", 1347 | "dev": true, 1348 | "requires": { 1349 | "define-properties": "^1.1.2", 1350 | "es-abstract": "^1.5.1" 1351 | } 1352 | }, 1353 | "once": { 1354 | "version": "1.4.0", 1355 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1356 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1357 | "dev": true, 1358 | "requires": { 1359 | "wrappy": "1" 1360 | } 1361 | }, 1362 | "os-homedir": { 1363 | "version": "1.0.2", 1364 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1365 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", 1366 | "dev": true 1367 | }, 1368 | "os-locale": { 1369 | "version": "3.1.0", 1370 | "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-3.1.0.tgz", 1371 | "integrity": "sha512-Z8l3R4wYWM40/52Z+S265okfFj8Kt2cC2MKY+xNi3kFs+XGI7WXu/I309QQQYbRW4ijiZ+yxs9pqEhJh0DqW3Q==", 1372 | "dev": true, 1373 | "requires": { 1374 | "execa": "^1.0.0", 1375 | "lcid": "^2.0.0", 1376 | "mem": "^4.0.0" 1377 | } 1378 | }, 1379 | "os-tmpdir": { 1380 | "version": "1.0.2", 1381 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1382 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1383 | "dev": true 1384 | }, 1385 | "osenv": { 1386 | "version": "0.1.5", 1387 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", 1388 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", 1389 | "dev": true, 1390 | "requires": { 1391 | "os-homedir": "^1.0.0", 1392 | "os-tmpdir": "^1.0.0" 1393 | } 1394 | }, 1395 | "osmosis": { 1396 | "version": "1.1.10", 1397 | "resolved": "https://registry.npmjs.org/osmosis/-/osmosis-1.1.10.tgz", 1398 | "integrity": "sha512-FHY+rGQvwOJxBMkuVGI4PQi0jRwmd8+BDFgYpQeX4xNQGwNcFkBvzhGWf1t4kekcFyUN7nMY1ExczzZndPbjzw==", 1399 | "dev": true, 1400 | "requires": { 1401 | "libxmljs-dom": "~0.0.17", 1402 | "needle": "^1.6.0" 1403 | } 1404 | }, 1405 | "p-defer": { 1406 | "version": "1.0.0", 1407 | "resolved": "https://registry.npmjs.org/p-defer/-/p-defer-1.0.0.tgz", 1408 | "integrity": "sha1-n26xgvbJqozXQwBKfU+WsZaw+ww=", 1409 | "dev": true 1410 | }, 1411 | "p-finally": { 1412 | "version": "1.0.0", 1413 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 1414 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=", 1415 | "dev": true 1416 | }, 1417 | "p-is-promise": { 1418 | "version": "2.1.0", 1419 | "resolved": "https://registry.npmjs.org/p-is-promise/-/p-is-promise-2.1.0.tgz", 1420 | "integrity": "sha512-Y3W0wlRPK8ZMRbNq97l4M5otioeA5lm1z7bkNkxCka8HSPjR0xRWmpCmc9utiaLP9Jb1eD8BgeIxTW4AIF45Pg==", 1421 | "dev": true 1422 | }, 1423 | "p-limit": { 1424 | "version": "2.2.0", 1425 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.0.tgz", 1426 | "integrity": "sha512-pZbTJpoUsCzV48Mc9Nh51VbwO0X9cuPFE8gYwx9BTCt9SF8/b7Zljd2fVgOxhIF/HDTKgpVzs+GPhyKfjLLFRQ==", 1427 | "dev": true, 1428 | "requires": { 1429 | "p-try": "^2.0.0" 1430 | } 1431 | }, 1432 | "p-locate": { 1433 | "version": "3.0.0", 1434 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 1435 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 1436 | "dev": true, 1437 | "requires": { 1438 | "p-limit": "^2.0.0" 1439 | } 1440 | }, 1441 | "p-try": { 1442 | "version": "2.2.0", 1443 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1444 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1445 | "dev": true 1446 | }, 1447 | "path-exists": { 1448 | "version": "3.0.0", 1449 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1450 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1451 | "dev": true 1452 | }, 1453 | "path-is-absolute": { 1454 | "version": "1.0.1", 1455 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1456 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1457 | "dev": true 1458 | }, 1459 | "path-key": { 1460 | "version": "2.0.1", 1461 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1462 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1463 | "dev": true 1464 | }, 1465 | "performance-now": { 1466 | "version": "2.1.0", 1467 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 1468 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", 1469 | "dev": true 1470 | }, 1471 | "process-nextick-args": { 1472 | "version": "2.0.0", 1473 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 1474 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", 1475 | "dev": true 1476 | }, 1477 | "psl": { 1478 | "version": "1.1.32", 1479 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.1.32.tgz", 1480 | "integrity": "sha512-MHACAkHpihU/REGGPLj4sEfc/XKW2bheigvHO1dUqjaKigMp1C8+WLQYRGgeKFMsw5PMfegZcaN8IDXK/cD0+g==", 1481 | "dev": true 1482 | }, 1483 | "pump": { 1484 | "version": "3.0.0", 1485 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1486 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1487 | "dev": true, 1488 | "requires": { 1489 | "end-of-stream": "^1.1.0", 1490 | "once": "^1.3.1" 1491 | } 1492 | }, 1493 | "punycode": { 1494 | "version": "2.1.1", 1495 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1496 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1497 | "dev": true 1498 | }, 1499 | "qs": { 1500 | "version": "6.5.2", 1501 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 1502 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", 1503 | "dev": true 1504 | }, 1505 | "querystringify": { 1506 | "version": "2.1.1", 1507 | "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.1.1.tgz", 1508 | "integrity": "sha512-w7fLxIRCRT7U8Qu53jQnJyPkYZIaR4n5151KMfcJlO/A9397Wxb1amJvROTK6TOnp7PfoAmg/qXiNHI+08jRfA==", 1509 | "dev": true 1510 | }, 1511 | "rc": { 1512 | "version": "1.2.8", 1513 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1514 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1515 | "dev": true, 1516 | "requires": { 1517 | "deep-extend": "^0.6.0", 1518 | "ini": "~1.3.0", 1519 | "minimist": "^1.2.0", 1520 | "strip-json-comments": "~2.0.1" 1521 | } 1522 | }, 1523 | "readable-stream": { 1524 | "version": "3.4.0", 1525 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.4.0.tgz", 1526 | "integrity": "sha512-jItXPLmrSR8jmTRmRWJXCnGJsfy85mB3Wd/uINMXA65yrnFo0cPClFIUWzo2najVNSl+mx7/4W8ttlLWJe99pQ==", 1527 | "dev": true, 1528 | "requires": { 1529 | "inherits": "^2.0.3", 1530 | "string_decoder": "^1.1.1", 1531 | "util-deprecate": "^1.0.1" 1532 | } 1533 | }, 1534 | "request": { 1535 | "version": "2.88.0", 1536 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", 1537 | "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", 1538 | "dev": true, 1539 | "requires": { 1540 | "aws-sign2": "~0.7.0", 1541 | "aws4": "^1.8.0", 1542 | "caseless": "~0.12.0", 1543 | "combined-stream": "~1.0.6", 1544 | "extend": "~3.0.2", 1545 | "forever-agent": "~0.6.1", 1546 | "form-data": "~2.3.2", 1547 | "har-validator": "~5.1.0", 1548 | "http-signature": "~1.2.0", 1549 | "is-typedarray": "~1.0.0", 1550 | "isstream": "~0.1.2", 1551 | "json-stringify-safe": "~5.0.1", 1552 | "mime-types": "~2.1.19", 1553 | "oauth-sign": "~0.9.0", 1554 | "performance-now": "^2.1.0", 1555 | "qs": "~6.5.2", 1556 | "safe-buffer": "^5.1.2", 1557 | "tough-cookie": "~2.4.3", 1558 | "tunnel-agent": "^0.6.0", 1559 | "uuid": "^3.3.2" 1560 | } 1561 | }, 1562 | "require-directory": { 1563 | "version": "2.1.1", 1564 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1565 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1566 | "dev": true 1567 | }, 1568 | "require-main-filename": { 1569 | "version": "2.0.0", 1570 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 1571 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 1572 | "dev": true 1573 | }, 1574 | "requires-port": { 1575 | "version": "1.0.0", 1576 | "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", 1577 | "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=", 1578 | "dev": true 1579 | }, 1580 | "rimraf": { 1581 | "version": "2.6.3", 1582 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1583 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1584 | "dev": true, 1585 | "requires": { 1586 | "glob": "^7.1.3" 1587 | } 1588 | }, 1589 | "safe-buffer": { 1590 | "version": "5.1.2", 1591 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1592 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1593 | "dev": true 1594 | }, 1595 | "safer-buffer": { 1596 | "version": "2.1.2", 1597 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1598 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1599 | "dev": true 1600 | }, 1601 | "sax": { 1602 | "version": "1.2.4", 1603 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 1604 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==", 1605 | "dev": true 1606 | }, 1607 | "semver": { 1608 | "version": "5.7.0", 1609 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz", 1610 | "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==", 1611 | "dev": true 1612 | }, 1613 | "set-blocking": { 1614 | "version": "2.0.0", 1615 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1616 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 1617 | "dev": true 1618 | }, 1619 | "shebang-command": { 1620 | "version": "1.2.0", 1621 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1622 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1623 | "dev": true, 1624 | "requires": { 1625 | "shebang-regex": "^1.0.0" 1626 | } 1627 | }, 1628 | "shebang-regex": { 1629 | "version": "1.0.0", 1630 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1631 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1632 | "dev": true 1633 | }, 1634 | "signal-exit": { 1635 | "version": "3.0.2", 1636 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1637 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 1638 | "dev": true 1639 | }, 1640 | "source-map": { 1641 | "version": "0.6.1", 1642 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1643 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1644 | "dev": true 1645 | }, 1646 | "source-map-support": { 1647 | "version": "0.5.12", 1648 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.12.tgz", 1649 | "integrity": "sha512-4h2Pbvyy15EE02G+JOZpUCmqWJuqrs+sEkzewTm++BPi7Hvn/HwcqLAcNxYAyI0x13CpPPn+kMjl+hplXMHITQ==", 1650 | "dev": true, 1651 | "requires": { 1652 | "buffer-from": "^1.0.0", 1653 | "source-map": "^0.6.0" 1654 | } 1655 | }, 1656 | "sprintf-js": { 1657 | "version": "1.0.3", 1658 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1659 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1660 | "dev": true 1661 | }, 1662 | "sshpk": { 1663 | "version": "1.16.1", 1664 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", 1665 | "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", 1666 | "dev": true, 1667 | "requires": { 1668 | "asn1": "~0.2.3", 1669 | "assert-plus": "^1.0.0", 1670 | "bcrypt-pbkdf": "^1.0.0", 1671 | "dashdash": "^1.12.0", 1672 | "ecc-jsbn": "~0.1.1", 1673 | "getpass": "^0.1.1", 1674 | "jsbn": "~0.1.0", 1675 | "safer-buffer": "^2.0.2", 1676 | "tweetnacl": "~0.14.0" 1677 | } 1678 | }, 1679 | "string-width": { 1680 | "version": "2.1.1", 1681 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1682 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1683 | "dev": true, 1684 | "requires": { 1685 | "is-fullwidth-code-point": "^2.0.0", 1686 | "strip-ansi": "^4.0.0" 1687 | } 1688 | }, 1689 | "string_decoder": { 1690 | "version": "1.2.0", 1691 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.2.0.tgz", 1692 | "integrity": "sha512-6YqyX6ZWEYguAxgZzHGL7SsCeGx3V2TtOTqZz1xSTSWnqsbWwbptafNyvf/ACquZUXV3DANr5BDIwNYe1mN42w==", 1693 | "dev": true, 1694 | "requires": { 1695 | "safe-buffer": "~5.1.0" 1696 | } 1697 | }, 1698 | "strip-ansi": { 1699 | "version": "4.0.0", 1700 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1701 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1702 | "dev": true, 1703 | "requires": { 1704 | "ansi-regex": "^3.0.0" 1705 | } 1706 | }, 1707 | "strip-eof": { 1708 | "version": "1.0.0", 1709 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 1710 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", 1711 | "dev": true 1712 | }, 1713 | "strip-json-comments": { 1714 | "version": "2.0.1", 1715 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1716 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1717 | "dev": true 1718 | }, 1719 | "supports-color": { 1720 | "version": "6.0.0", 1721 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.0.0.tgz", 1722 | "integrity": "sha512-on9Kwidc1IUQo+bQdhi8+Tijpo0e1SS6RoGo2guUwn5vdaxw8RXOF9Vb2ws+ihWOmh4JnCJOvaziZWP1VABaLg==", 1723 | "dev": true, 1724 | "requires": { 1725 | "has-flag": "^3.0.0" 1726 | } 1727 | }, 1728 | "tar": { 1729 | "version": "4.4.10", 1730 | "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.10.tgz", 1731 | "integrity": "sha512-g2SVs5QIxvo6OLp0GudTqEf05maawKUxXru104iaayWA09551tFCTI8f1Asb4lPfkBr91k07iL4c11XO3/b0tA==", 1732 | "dev": true, 1733 | "requires": { 1734 | "chownr": "^1.1.1", 1735 | "fs-minipass": "^1.2.5", 1736 | "minipass": "^2.3.5", 1737 | "minizlib": "^1.2.1", 1738 | "mkdirp": "^0.5.0", 1739 | "safe-buffer": "^5.1.2", 1740 | "yallist": "^3.0.3" 1741 | } 1742 | }, 1743 | "tough-cookie": { 1744 | "version": "2.4.3", 1745 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", 1746 | "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", 1747 | "dev": true, 1748 | "requires": { 1749 | "psl": "^1.1.24", 1750 | "punycode": "^1.4.1" 1751 | }, 1752 | "dependencies": { 1753 | "punycode": { 1754 | "version": "1.4.1", 1755 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 1756 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", 1757 | "dev": true 1758 | } 1759 | } 1760 | }, 1761 | "ts-node": { 1762 | "version": "8.2.0", 1763 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-8.2.0.tgz", 1764 | "integrity": "sha512-m8XQwUurkbYqXrKqr3WHCW310utRNvV5OnRVeISeea7LoCWVcdfeB/Ntl8JYWFh+WRoUAdBgESrzKochQt7sMw==", 1765 | "dev": true, 1766 | "requires": { 1767 | "arg": "^4.1.0", 1768 | "diff": "^4.0.1", 1769 | "make-error": "^1.1.1", 1770 | "source-map-support": "^0.5.6", 1771 | "yn": "^3.0.0" 1772 | }, 1773 | "dependencies": { 1774 | "diff": { 1775 | "version": "4.0.1", 1776 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.1.tgz", 1777 | "integrity": "sha512-s2+XdvhPCOF01LRQBC8hf4vhbVmI2CGS5aZnxLJlT5FtdhPCDFq80q++zK2KlrVorVDdL5BOGZ/VfLrVtYNF+Q==", 1778 | "dev": true 1779 | } 1780 | } 1781 | }, 1782 | "tunnel-agent": { 1783 | "version": "0.6.0", 1784 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 1785 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 1786 | "dev": true, 1787 | "requires": { 1788 | "safe-buffer": "^5.0.1" 1789 | } 1790 | }, 1791 | "tweetnacl": { 1792 | "version": "0.14.5", 1793 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 1794 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 1795 | "dev": true 1796 | }, 1797 | "typescript": { 1798 | "version": "3.5.1", 1799 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.5.1.tgz", 1800 | "integrity": "sha512-64HkdiRv1yYZsSe4xC1WVgamNigVYjlssIoaH2HcZF0+ijsk5YK2g0G34w9wJkze8+5ow4STd22AynfO6ZYYLw==", 1801 | "dev": true 1802 | }, 1803 | "uri-js": { 1804 | "version": "4.2.2", 1805 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1806 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1807 | "dev": true, 1808 | "requires": { 1809 | "punycode": "^2.1.0" 1810 | } 1811 | }, 1812 | "url-parse": { 1813 | "version": "1.4.7", 1814 | "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.4.7.tgz", 1815 | "integrity": "sha512-d3uaVyzDB9tQoSXFvuSUNFibTd9zxd2bkVrDRvF5TmvWWQwqE4lgYJ5m+x1DbecWkw+LK4RNl2CU1hHuOKPVlg==", 1816 | "dev": true, 1817 | "requires": { 1818 | "querystringify": "^2.1.1", 1819 | "requires-port": "^1.0.0" 1820 | } 1821 | }, 1822 | "util-deprecate": { 1823 | "version": "1.0.2", 1824 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1825 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 1826 | "dev": true 1827 | }, 1828 | "uuid": { 1829 | "version": "3.3.2", 1830 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 1831 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==", 1832 | "dev": true 1833 | }, 1834 | "verror": { 1835 | "version": "1.10.0", 1836 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 1837 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 1838 | "dev": true, 1839 | "requires": { 1840 | "assert-plus": "^1.0.0", 1841 | "core-util-is": "1.0.2", 1842 | "extsprintf": "^1.2.0" 1843 | } 1844 | }, 1845 | "vscode": { 1846 | "version": "1.1.34", 1847 | "resolved": "https://registry.npmjs.org/vscode/-/vscode-1.1.34.tgz", 1848 | "integrity": "sha512-GuT3tCT2N5Qp26VG4C+iGmWMgg/MuqtY5G5TSOT3U/X6pgjM9LFulJEeqpyf6gdzpI4VyU3ZN/lWPo54UFPuQg==", 1849 | "dev": true, 1850 | "requires": { 1851 | "glob": "^7.1.2", 1852 | "mocha": "^4.0.1", 1853 | "request": "^2.88.0", 1854 | "semver": "^5.4.1", 1855 | "source-map-support": "^0.5.0", 1856 | "url-parse": "^1.4.4", 1857 | "vscode-test": "^0.4.1" 1858 | }, 1859 | "dependencies": { 1860 | "browser-stdout": { 1861 | "version": "1.3.0", 1862 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.0.tgz", 1863 | "integrity": "sha1-81HTKWnTL6XXpVZxVCY9korjvR8=", 1864 | "dev": true 1865 | }, 1866 | "debug": { 1867 | "version": "3.1.0", 1868 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1869 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1870 | "dev": true, 1871 | "requires": { 1872 | "ms": "2.0.0" 1873 | } 1874 | }, 1875 | "diff": { 1876 | "version": "3.3.1", 1877 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.3.1.tgz", 1878 | "integrity": "sha512-MKPHZDMB0o6yHyDryUOScqZibp914ksXwAMYMTHj6KO8UeKsRYNJD3oNCKjTqZon+V488P7N/HzXF8t7ZR95ww==", 1879 | "dev": true 1880 | }, 1881 | "growl": { 1882 | "version": "1.10.3", 1883 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.3.tgz", 1884 | "integrity": "sha512-hKlsbA5Vu3xsh1Cg3J7jSmX/WaW6A5oBeqzM88oNbCRQFz+zUaXm6yxS4RVytp1scBoJzSYl4YAEOQIt6O8V1Q==", 1885 | "dev": true 1886 | }, 1887 | "has-flag": { 1888 | "version": "2.0.0", 1889 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz", 1890 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=", 1891 | "dev": true 1892 | }, 1893 | "he": { 1894 | "version": "1.1.1", 1895 | "resolved": "https://registry.npmjs.org/he/-/he-1.1.1.tgz", 1896 | "integrity": "sha1-k0EP0hsAlzUVH4howvJx80J+I/0=", 1897 | "dev": true 1898 | }, 1899 | "mocha": { 1900 | "version": "4.1.0", 1901 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-4.1.0.tgz", 1902 | "integrity": "sha512-0RVnjg1HJsXY2YFDoTNzcc1NKhYuXKRrBAG2gDygmJJA136Cs2QlRliZG1mA0ap7cuaT30mw16luAeln+4RiNA==", 1903 | "dev": true, 1904 | "requires": { 1905 | "browser-stdout": "1.3.0", 1906 | "commander": "2.11.0", 1907 | "debug": "3.1.0", 1908 | "diff": "3.3.1", 1909 | "escape-string-regexp": "1.0.5", 1910 | "glob": "7.1.2", 1911 | "growl": "1.10.3", 1912 | "he": "1.1.1", 1913 | "mkdirp": "0.5.1", 1914 | "supports-color": "4.4.0" 1915 | }, 1916 | "dependencies": { 1917 | "glob": { 1918 | "version": "7.1.2", 1919 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 1920 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 1921 | "dev": true, 1922 | "requires": { 1923 | "fs.realpath": "^1.0.0", 1924 | "inflight": "^1.0.4", 1925 | "inherits": "2", 1926 | "minimatch": "^3.0.4", 1927 | "once": "^1.3.0", 1928 | "path-is-absolute": "^1.0.0" 1929 | } 1930 | } 1931 | } 1932 | }, 1933 | "ms": { 1934 | "version": "2.0.0", 1935 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1936 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1937 | "dev": true 1938 | }, 1939 | "supports-color": { 1940 | "version": "4.4.0", 1941 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.4.0.tgz", 1942 | "integrity": "sha512-rKC3+DyXWgK0ZLKwmRsrkyHVZAjNkfzeehuFWdGGcqGDTZFH73+RH6S/RDAAxl9GusSjZSUWYLmT9N5pzXFOXQ==", 1943 | "dev": true, 1944 | "requires": { 1945 | "has-flag": "^2.0.0" 1946 | } 1947 | } 1948 | } 1949 | }, 1950 | "vscode-test": { 1951 | "version": "0.4.3", 1952 | "resolved": "https://registry.npmjs.org/vscode-test/-/vscode-test-0.4.3.tgz", 1953 | "integrity": "sha512-EkMGqBSefZH2MgW65nY05rdRSko15uvzq4VAPM5jVmwYuFQKE7eikKXNJDRxL+OITXHB6pI+a3XqqD32Y3KC5w==", 1954 | "dev": true, 1955 | "requires": { 1956 | "http-proxy-agent": "^2.1.0", 1957 | "https-proxy-agent": "^2.2.1" 1958 | } 1959 | }, 1960 | "which": { 1961 | "version": "1.3.1", 1962 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1963 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1964 | "dev": true, 1965 | "requires": { 1966 | "isexe": "^2.0.0" 1967 | } 1968 | }, 1969 | "which-module": { 1970 | "version": "2.0.0", 1971 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 1972 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 1973 | "dev": true 1974 | }, 1975 | "wide-align": { 1976 | "version": "1.1.3", 1977 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1978 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1979 | "dev": true, 1980 | "requires": { 1981 | "string-width": "^1.0.2 || 2" 1982 | } 1983 | }, 1984 | "wrap-ansi": { 1985 | "version": "2.1.0", 1986 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", 1987 | "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", 1988 | "dev": true, 1989 | "requires": { 1990 | "string-width": "^1.0.1", 1991 | "strip-ansi": "^3.0.1" 1992 | }, 1993 | "dependencies": { 1994 | "ansi-regex": { 1995 | "version": "2.1.1", 1996 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 1997 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 1998 | "dev": true 1999 | }, 2000 | "is-fullwidth-code-point": { 2001 | "version": "1.0.0", 2002 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 2003 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 2004 | "dev": true, 2005 | "requires": { 2006 | "number-is-nan": "^1.0.0" 2007 | } 2008 | }, 2009 | "string-width": { 2010 | "version": "1.0.2", 2011 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 2012 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 2013 | "dev": true, 2014 | "requires": { 2015 | "code-point-at": "^1.0.0", 2016 | "is-fullwidth-code-point": "^1.0.0", 2017 | "strip-ansi": "^3.0.0" 2018 | } 2019 | }, 2020 | "strip-ansi": { 2021 | "version": "3.0.1", 2022 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 2023 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 2024 | "dev": true, 2025 | "requires": { 2026 | "ansi-regex": "^2.0.0" 2027 | } 2028 | } 2029 | } 2030 | }, 2031 | "wrappy": { 2032 | "version": "1.0.2", 2033 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2034 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2035 | "dev": true 2036 | }, 2037 | "y18n": { 2038 | "version": "4.0.0", 2039 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", 2040 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", 2041 | "dev": true 2042 | }, 2043 | "yallist": { 2044 | "version": "3.0.3", 2045 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.0.3.tgz", 2046 | "integrity": "sha512-S+Zk8DEWE6oKpV+vI3qWkaK+jSbIK86pCwe2IF/xwIpQ8jEuxpw9NyaGjmp9+BoJv5FV2piqCDcoCtStppiq2A==", 2047 | "dev": true 2048 | }, 2049 | "yargs": { 2050 | "version": "13.2.2", 2051 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.2.2.tgz", 2052 | "integrity": "sha512-WyEoxgyTD3w5XRpAQNYUB9ycVH/PQrToaTXdYXRdOXvEy1l19br+VJsc0vcO8PTGg5ro/l/GY7F/JMEBmI0BxA==", 2053 | "dev": true, 2054 | "requires": { 2055 | "cliui": "^4.0.0", 2056 | "find-up": "^3.0.0", 2057 | "get-caller-file": "^2.0.1", 2058 | "os-locale": "^3.1.0", 2059 | "require-directory": "^2.1.1", 2060 | "require-main-filename": "^2.0.0", 2061 | "set-blocking": "^2.0.0", 2062 | "string-width": "^3.0.0", 2063 | "which-module": "^2.0.0", 2064 | "y18n": "^4.0.0", 2065 | "yargs-parser": "^13.0.0" 2066 | }, 2067 | "dependencies": { 2068 | "ansi-regex": { 2069 | "version": "4.1.0", 2070 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2071 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2072 | "dev": true 2073 | }, 2074 | "string-width": { 2075 | "version": "3.1.0", 2076 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2077 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2078 | "dev": true, 2079 | "requires": { 2080 | "emoji-regex": "^7.0.1", 2081 | "is-fullwidth-code-point": "^2.0.0", 2082 | "strip-ansi": "^5.1.0" 2083 | } 2084 | }, 2085 | "strip-ansi": { 2086 | "version": "5.2.0", 2087 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2088 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2089 | "dev": true, 2090 | "requires": { 2091 | "ansi-regex": "^4.1.0" 2092 | } 2093 | } 2094 | } 2095 | }, 2096 | "yargs-parser": { 2097 | "version": "13.0.0", 2098 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.0.0.tgz", 2099 | "integrity": "sha512-w2LXjoL8oRdRQN+hOyppuXs+V/fVAYtpcrRxZuF7Kt/Oc+Jr2uAcVntaUTNT6w5ihoWfFDpNY8CPx1QskxZ/pw==", 2100 | "dev": true, 2101 | "requires": { 2102 | "camelcase": "^5.0.0", 2103 | "decamelize": "^1.2.0" 2104 | } 2105 | }, 2106 | "yargs-unparser": { 2107 | "version": "1.5.0", 2108 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.5.0.tgz", 2109 | "integrity": "sha512-HK25qidFTCVuj/D1VfNiEndpLIeJN78aqgR23nL3y4N0U/91cOAzqfHlF8n2BvoNDcZmJKin3ddNSvOxSr8flw==", 2110 | "dev": true, 2111 | "requires": { 2112 | "flat": "^4.1.0", 2113 | "lodash": "^4.17.11", 2114 | "yargs": "^12.0.5" 2115 | }, 2116 | "dependencies": { 2117 | "get-caller-file": { 2118 | "version": "1.0.3", 2119 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz", 2120 | "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==", 2121 | "dev": true 2122 | }, 2123 | "require-main-filename": { 2124 | "version": "1.0.1", 2125 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", 2126 | "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=", 2127 | "dev": true 2128 | }, 2129 | "yargs": { 2130 | "version": "12.0.5", 2131 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-12.0.5.tgz", 2132 | "integrity": "sha512-Lhz8TLaYnxq/2ObqHDql8dX8CJi97oHxrjUcYtzKbbykPtVW9WB+poxI+NM2UIzsMgNCZTIf0AQwsjK5yMAqZw==", 2133 | "dev": true, 2134 | "requires": { 2135 | "cliui": "^4.0.0", 2136 | "decamelize": "^1.2.0", 2137 | "find-up": "^3.0.0", 2138 | "get-caller-file": "^1.0.1", 2139 | "os-locale": "^3.0.0", 2140 | "require-directory": "^2.1.1", 2141 | "require-main-filename": "^1.0.1", 2142 | "set-blocking": "^2.0.0", 2143 | "string-width": "^2.0.0", 2144 | "which-module": "^2.0.0", 2145 | "y18n": "^3.2.1 || ^4.0.0", 2146 | "yargs-parser": "^11.1.1" 2147 | } 2148 | }, 2149 | "yargs-parser": { 2150 | "version": "11.1.1", 2151 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-11.1.1.tgz", 2152 | "integrity": "sha512-C6kB/WJDiaxONLJQnF8ccx9SEeoTTLek8RVbaOIsrAUS8VrBEXfmeSnCZxygc+XC2sNMBIwOOnfcxiynjHsVSQ==", 2153 | "dev": true, 2154 | "requires": { 2155 | "camelcase": "^5.0.0", 2156 | "decamelize": "^1.2.0" 2157 | } 2158 | } 2159 | } 2160 | }, 2161 | "yn": { 2162 | "version": "3.1.0", 2163 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.0.tgz", 2164 | "integrity": "sha512-kKfnnYkbTfrAdd0xICNFw7Atm8nKpLcLv9AZGEt+kczL/WQVai4e2V6ZN8U/O+iI6WrNuJjNNOyu4zfhl9D3Hg==", 2165 | "dev": true 2166 | } 2167 | } 2168 | } 2169 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "factorio-lua-api-autocomplete", 3 | "displayName": "Factorio Lua API autocomplete", 4 | "description": "Autocompletion for the Factorio Lua API", 5 | "version": "0.7.0", 6 | "publisher": "svizzini", 7 | "repository": { 8 | "type": "git", 9 | "url": "https://github.com/simonvizzini/vscode-factorio-lua-api-autocomplete.git" 10 | }, 11 | "private": true, 12 | "license": "MIT", 13 | "engines": { 14 | "vscode": "^1.20.0" 15 | }, 16 | "categories": [ 17 | "Other", 18 | "Programming Languages" 19 | ], 20 | "activationEvents": [ 21 | "onLanguage:lua" 22 | ], 23 | "main": "./out/src/extension", 24 | "contributes": { 25 | "languages": [ 26 | { 27 | "id": "lua", 28 | "extensions": [ 29 | ".lua" 30 | ], 31 | "aliases": [ 32 | "lua" 33 | ] 34 | } 35 | ] 36 | }, 37 | "scripts": { 38 | "vscode:prepublish": "tsc -p ./", 39 | "compile": "tsc -watch -p ./", 40 | "postinstall": "node ./node_modules/vscode/bin/install", 41 | "test": "node ./node_modules/vscode/bin/test" 42 | }, 43 | "dependencies": { 44 | "lodash": "^4.17.11" 45 | }, 46 | "devDependencies": { 47 | "@types/lodash": "^4.14.134", 48 | "@types/mocha": "^5.2.7", 49 | "@types/node": "^12.0.7", 50 | "html-to-text": "^5.1.1", 51 | "mocha": "^6.1.4", 52 | "osmosis": "^1.1.10", 53 | "ts-node": "^8.2.0", 54 | "typescript": "^3.5.1", 55 | "vscode": "^1.1.34" 56 | } 57 | } 58 | -------------------------------------------------------------------------------- /scraper/classes.ts: -------------------------------------------------------------------------------- 1 | import * as osmosis from "osmosis" 2 | import * as fs from "fs" 3 | import * as htmlToText from "html-to-text" 4 | import * as _ from "lodash" 5 | 6 | import { splitFnRegex, arrayToObject, parseHtml } from "./utils" 7 | import config from "./config" 8 | 9 | const { keys } = Object 10 | const { isArray } = Array 11 | 12 | const URL = config.baseUrl + "/Classes.html" 13 | 14 | export const scrape = () => { 15 | let classes: FactorioTypeMap = {} 16 | 17 | return new Promise((resolve, reject) => { 18 | osmosis 19 | .get(URL) 20 | .find("body > div.brief-listing > div.brief-listing") 21 | .set({ 22 | name: "span.type-name > a", 23 | type: "span.type-name > a", 24 | inherits: ["div:contains('Inherited from')"] 25 | }) 26 | .then((context, data, next) => { 27 | console.log("current: ", data.name) 28 | classes[data.name] = data 29 | next(context, {}) 30 | }) 31 | .fail("a:nth-child(2):contains('ControlBehavior')") 32 | .select("span.type-name > a") 33 | .follow("@href") 34 | .find("body > div.brief-listing > div.brief-listing") 35 | .set({ 36 | name: "span.type-name", 37 | properties: [ 38 | osmosis 39 | .find("table.brief-members > tr") 40 | .set({ 41 | name: "span.element-name > a", 42 | type: "span.param-type > a", 43 | mode: "span.attribute-mode", 44 | doc: "td.description:not(:empty)" 45 | }) 46 | ] 47 | }) 48 | .then((document, data, next) => { 49 | _.merge(classes[data.name], data) 50 | next(document.querySelector("#" + data.name), {}) 51 | }) 52 | .set({ 53 | name: "node() !> div@id", // gets the id of parent div.element (!> is parent) 54 | doc: "p:first", 55 | properties: [ 56 | osmosis 57 | .find("div.element") 58 | .set({ 59 | name: "span.element-name", 60 | type: "span.param-type:first", 61 | returns: "span.return-type > span.param-type", 62 | args: [ 63 | osmosis 64 | .find("div.element-content .detail-header:contains(Parameters) + .detail-content > div") 65 | .set({ 66 | name: "span.param-name", 67 | // TODO: Missing types. e.g. LuaCircuitNetwork.get_signal(SignalID) 68 | type: "span.param-type:first" 69 | }) 70 | .set("doc", (context) => { 71 | return parseHtml(context.innerHTML) 72 | }) 73 | ] 74 | }) 75 | .select("div.element-content") 76 | .set("doc", (context) => { 77 | return parseHtml(context.innerHTML) 78 | }) 79 | ] 80 | }) 81 | .then((context, data, next) => { 82 | const notString = (obj) => !_.isEmpty(obj) && typeof obj !== "string" 83 | 84 | data.properties = data.properties.filter(notString) 85 | 86 | data.properties.forEach((prop) => { 87 | if (_.isEmpty(prop.doc)) { 88 | delete prop.doc 89 | } 90 | 91 | // Check if this is a function 92 | if (splitFnRegex.test(prop.name)) { 93 | let [__, fnName] = prop.name.match(splitFnRegex) 94 | prop.name = fnName 95 | prop.type = "function" 96 | } 97 | 98 | if (!_.isArray(prop.args)) { 99 | prop.args = [prop.args] 100 | } 101 | 102 | prop.args = _(prop.args) 103 | .filter(notString) 104 | .each((arg) => { 105 | if (!arg.type) { 106 | arg.type = arg.name 107 | } 108 | }) 109 | 110 | if (prop.args.length === 0) { 111 | delete prop.args 112 | } 113 | }) 114 | 115 | _.merge(classes[data.name], data) 116 | 117 | next(context, {}) 118 | }) 119 | .log((msg) => { 120 | if (/follow|find/.test(msg)) return 121 | console.log(msg) 122 | }) 123 | .error(console.log) 124 | //.debug(console.log) 125 | .done(() => { 126 | _.forOwn(classes, (type, key) => { 127 | _.forEach(type.properties, (prop: FactorioType) => { 128 | if (prop.args) { 129 | prop.args = arrayToObject(prop.args as any) 130 | } 131 | }) 132 | 133 | if (type.inherits.length) { 134 | handleInheritance(type, classes) 135 | } 136 | 137 | type.properties = arrayToObject(type.properties as any) 138 | 139 | // comment for debugging 140 | // delete type.inherits 141 | }) 142 | 143 | // Sort classes by key 144 | classes = _(classes).toPairs().sortBy(0).fromPairs().value() 145 | console.log(`done: ${Object.keys(classes).length} classes`) 146 | resolve(classes) 147 | }) 148 | }) 149 | } 150 | 151 | const handleInheritance = (type, typeMap) => { 152 | // Merge properties from parent classes 153 | type.inherits.reduce((type, inheritStr: string) => { 154 | let [__, fromStr, propsStr] = inheritStr.match(/Inherited from (\w+): (.*)/) 155 | const from = typeMap[fromStr] 156 | 157 | if (!from) { 158 | console.error(`${type.name} inherits from ${from}, but ${from} doesn't exit!`) 159 | return type 160 | } 161 | 162 | let propsStrArr = propsStr.split(", ") 163 | 164 | propsStrArr.forEach((propStr) => { 165 | let fromProp = from.properties[propStr] 166 | 167 | if (!fromProp) { 168 | console.error(`${from.name} has no property ${propStr}`) 169 | return 170 | } 171 | 172 | type.properties.push(fromProp) 173 | }) 174 | 175 | return type 176 | }, type) 177 | } 178 | -------------------------------------------------------------------------------- /scraper/config.ts: -------------------------------------------------------------------------------- 1 | export default { 2 | baseUrl: "https://lua-api.factorio.com/latest/", 3 | htmlToText: { 4 | ignoreHref: true, 5 | wordwrap: 500 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /scraper/defines.ts: -------------------------------------------------------------------------------- 1 | import * as osmosis from "osmosis" 2 | import * as fs from "fs" 3 | import * as htmlToText from "html-to-text" 4 | import * as _ from "lodash" 5 | 6 | import { getRegexMatches, parseHtml } from "./utils" 7 | import config from "./config" 8 | const { keys, assign } = Object 9 | 10 | const DEFINES_URL = config.baseUrl + "/defines.html" 11 | const EVENTS_URL = config.baseUrl + "/events.html" 12 | 13 | export const scrape = () => { 14 | const definesPromise = new Promise((resolve, reject) => { 15 | const defines: FactorioTypeMap = {} 16 | 17 | osmosis 18 | .get(DEFINES_URL) 19 | .find("div.element table.brief-members tr") 20 | .set("name", "td.header") 21 | .select("td.description") 22 | .set("doc", (context) => { 23 | let { innerHTML } = context 24 | if (!innerHTML || innerHTML.trim() === "") return 25 | return htmlToText.fromString(innerHTML, config.htmlToText) 26 | }) 27 | .data((defineData: FactorioType, next) => { 28 | let words = defineData.name.split(".") 29 | words.shift() // remove "defines" word 30 | 31 | const tree: FactorioTypeMap = {} 32 | let define = words.reduce((result: FactorioType | FactorioTypeMap, word, i) => { 33 | let notLast = i < (words.length - 1) 34 | let curr: FactorioType = { type: "define" } 35 | result[word] = curr 36 | 37 | if (notLast) { 38 | if (!curr.properties) { 39 | curr.properties = {} 40 | } 41 | return result[word].properties 42 | } 43 | return curr 44 | }, tree) 45 | 46 | _.merge(define, defineData) 47 | _.merge(defines, tree) 48 | }) 49 | .done(() => { 50 | console.log(`done: ${keys(defines).length} defines parsed`) 51 | resolve(defines) 52 | }) 53 | }) 54 | 55 | const eventsPromise = new Promise((resolve, reject) => { 56 | let events: FactorioType[] = [] 57 | 58 | osmosis 59 | .get(EVENTS_URL) 60 | .find("div.element") 61 | .set("name", "div.element-header") 62 | .select("div.element-content") 63 | .set("doc", (context) => { 64 | return parseHtml(context.innerHTML) 65 | }) 66 | .data((data) => { 67 | data.type = "event" 68 | events.push(data) 69 | }) 70 | .log(console.log) 71 | .error(console.log) 72 | //.debug(console.log) 73 | .done(() => { 74 | console.log(`done: ${keys(events).length} events parsed`) 75 | resolve(events) 76 | }) 77 | }) 78 | 79 | return new Promise((resolve, reject) => { 80 | Promise 81 | .all([definesPromise, eventsPromise]) 82 | .then(([defines, events]) => { 83 | // First event is the parent of all events 84 | const parentEvent = events.shift() 85 | events.forEach(event => { 86 | event = _.merge({}, parentEvent, event) 87 | if (defines.events.properties[event.name]) { 88 | defines.events.properties[event.name] = event 89 | } 90 | }) 91 | 92 | resolve(defines) 93 | }) 94 | }) 95 | } 96 | -------------------------------------------------------------------------------- /scraper/index.ts: -------------------------------------------------------------------------------- 1 | const utils = require("./utils") 2 | const classesScraper = require("./classes") 3 | const definesScraper = require("./defines") 4 | 5 | Promise.all([ 6 | classesScraper.scrape(), 7 | definesScraper.scrape() 8 | ]) 9 | .then(([ classes, defines ]) => { 10 | return Promise.all([ 11 | utils.writeJson("./data/classes.json", classes), 12 | utils.writeJson("./data/defines.json", defines) 13 | ]) 14 | .then(() => { 15 | console.log("all done, exiting now") 16 | process.exit(0) 17 | }) 18 | }) 19 | .catch((err) => { 20 | console.log("error, exiting now: ", err) 21 | process.exit(1) 22 | }) 23 | -------------------------------------------------------------------------------- /scraper/utils.ts: -------------------------------------------------------------------------------- 1 | import * as fs from "fs" 2 | 3 | /** 4 | * Extracts a function from a string and splits it into two parts: 5 | * - function name 6 | * - parameters 7 | * 8 | * Example: 9 | * 10 | * "set_tiles(tiles, correct_tiles)".match(...) 11 | * => [__, "set_tiles", "tiles, correct_tiles"] 12 | */ 13 | export const splitFnRegex = /(\S+)(?:\(|\{)(.*)(?:\}|\))/ 14 | 15 | export const wordsRegex = /([\w\[\]]+\.[\w\[\]\.]+)+/g 16 | 17 | export const writeJson = (fileName, obj) => { 18 | return new Promise((resolve, reject) => { 19 | fs.writeFile(fileName, JSON.stringify(obj, null, 2), "utf8", err => { 20 | if (err) return reject(err) 21 | console.log(`writeJson: "${fileName}" success`) 22 | resolve() 23 | }) 24 | }) 25 | } 26 | 27 | export const arrayToObject = (array: any[]) => { 28 | return array 29 | .sort((a, b) => a.name.localeCompare(b.name)) 30 | .reduce((obj, item) => { 31 | let { name } = item 32 | // if it's a function, get rid of the params (??? check again later, needs improvements) 33 | if (exports.splitFnRegex.test(name)) { 34 | name = item.name.match(exports.splitFnRegex)[1] 35 | } 36 | obj[name] = item 37 | return obj 38 | }, {}) 39 | } 40 | 41 | export const getRegexMatches = (regex, str) => { 42 | let match = null, matches = [] 43 | while ((match = regex.exec(str)) !== null) { 44 | matches.push(match[0]) 45 | } 46 | return matches 47 | } 48 | 49 | export const getLastMatch = (regex, str) => { 50 | return getRegexMatches(regex, str).slice(-1).pop() 51 | } 52 | 53 | // /<\/?(tag)[^><]*>/g 54 | const tagsRegex = (tag) => new RegExp("<\\/?(" + tag + ")[^><]*>", "g") 55 | const latestUrl = "http://lua-api.factorio.com/latest/" 56 | 57 | // This whole function is complete bullshit, but it works much better than htmlToText or pandoc. 58 | // Very fragile, much regex. I pray I won't have to touch this anytime soon again. 59 | // At least some unit tests would be good though... 60 | export const parseHtml = (htmlStr) => { 61 | return htmlStr 62 | .replace(tagsRegex("span|ul|p"), "") 63 | .replace(tagsRegex("div|br|li"), "\n\n") 64 | // .replace(tagsRegex("li"), "\n\n") 65 | .replace(tagsRegex("strong"), "**") 66 | .replace(tagsRegex("em"), "_") 67 | .replace(tagsRegex("code"), "````\n") 68 | // Make some markdown links 69 | .replace(/([\w\s\.:]*)<\/a>/g, "[$2]("+latestUrl+"$1)") 70 | 71 | // And now let's try to clean up all those broken newlines and whitespaces... 72 | // Very fun 73 | // Replace multiple whitespaces with one 74 | .replace(/[ ]+/g, " ") 75 | // Prepend two spaces before single line breaks (so markdown renders a single line break correctly) 76 | .replace(/[^`].(\n)./g, " \n") 77 | // Replace multiple newlines with a single markdown-style newline 78 | .replace(/\n\s*\n/g, " \n") 79 | // Remove spaces after new lines (affects some code blocks) 80 | .replace(/\n /g, "\n") 81 | // Replace unnecessary new lines between words 82 | .replace(/\w\n\w/g, "") 83 | 84 | // Wrap some stuff with newlines for a nicer look 85 | .replace(/\n*(Parameters)[\n\s]*/g, "\n\n**$1** \n") 86 | .replace(/\n*(Return value)[\n\s]*/g, "\n\n**$1** \n") 87 | .replace(/\n*(Example)[\n\s]/g, "\n\n**$1** ") 88 | .replace(/\n*(Contains)[\n\s]/g, "\n\n**$1** ") 89 | .replace(/\n*(\*\*Note:)/g, "\n\n$1") 90 | 91 | // Replace newlines at the beginning 92 | .replace(/^[\s\n]+/, "") 93 | // Replace newlines at the end 94 | .replace(/[\s\n]+$/, "") 95 | } 96 | -------------------------------------------------------------------------------- /src/FactorioApiData.ts: -------------------------------------------------------------------------------- 1 | import * as fs from"fs" 2 | import * as _ from "lodash" 3 | 4 | const brackets = /\[.*\]/g 5 | 6 | const additionalTriggers = { 7 | game: "LuaGameScript", 8 | script: "LuaBootstrap", 9 | remote: "LuaRemote", 10 | commands: "LuaCommandProcessor", 11 | player: "LuaPlayer", 12 | entity: "LuaEntity", 13 | inventory: "LuaInventory", 14 | gui: "LuaGui", 15 | force: "LuaForce", 16 | style: "LuaStyle", 17 | tile: "LuaTile", 18 | } 19 | 20 | export default class FactorioApiData { 21 | 22 | private classes: FactorioTypeMap 23 | private defines: FactorioTypeMap 24 | 25 | constructor(private dataPath: string) { 26 | this.loadData(dataPath) 27 | } 28 | 29 | public findType(words: string[]): FactorioType { 30 | if (words.length === 0) { 31 | return { properties: this.classes } 32 | } 33 | 34 | // Clean up path by removing array/dict access brackets (players[0] => players) 35 | words = words.map(p => p.replace(brackets, "")) 36 | 37 | let type = this.classes[words.shift()] 38 | 39 | if (!type) { 40 | return null 41 | } 42 | 43 | if (!type.properties || words.length === 0) { 44 | return type 45 | } 46 | 47 | let props = type.properties 48 | 49 | for (let i = 0; i < words.length; i++) { 50 | type = props[words[i]] 51 | 52 | // Not found 53 | if (!type) return null 54 | 55 | // First try traverse it's own properties 56 | if (type.properties) { 57 | props = type.properties 58 | continue 59 | } 60 | 61 | // Then the complete type list 62 | let parentType = type.type 63 | 64 | // Special handling for defines 65 | if (/defines/.test(parentType)) { 66 | let [__, defineName] = parentType.split(".") 67 | //let define = this.defines[defineName] 68 | return _.get(this.defines, [defineName, "properties"]) 69 | // return defineName && this.defines[defineName] || null 70 | } 71 | 72 | type = this.classes[parentType] 73 | 74 | if (type && type.properties) { 75 | props = type.properties 76 | continue 77 | } 78 | } 79 | 80 | return type 81 | } 82 | 83 | private loadData(dataPath: string) { 84 | const classes = this.loadDataFile(dataPath + "/classes.json") 85 | const defines = this.loadDataFile(dataPath + "/defines.json") 86 | 87 | // Add some additional autocomplete triggers (when typing on blank line or pressing ctrl-space) 88 | Object.keys(additionalTriggers).forEach(trigger => { 89 | let luaType = additionalTriggers[trigger] 90 | if (luaType in classes) { 91 | classes[trigger] = classes[luaType] 92 | } 93 | }) 94 | 95 | // LuaPlayer and LuaEntity inherit from LuaControl 96 | // Instead of doing this manually it would be best to adjust the scraper to read the "extends" keyword 97 | // in the docs and do this automatically. 98 | // Object.assign(classes.LuaPlayer.properties, classes.LuaControl.properties) 99 | // Object.assign(classes.LuaEntity.properties, classes.LuaControl.properties) 100 | 101 | this.classes = classes 102 | this.defines = defines 103 | // todo: revisit this 104 | this.classes.defines = { 105 | type: "define", 106 | properties: defines 107 | } 108 | } 109 | 110 | private loadDataFile(fileName: string): FactorioTypeMap { 111 | const jsonStr = fs.readFileSync(fileName, "utf8") 112 | const data = JSON.parse(jsonStr) 113 | return data 114 | } 115 | } 116 | -------------------------------------------------------------------------------- /src/FactorioAutocomplete.ts: -------------------------------------------------------------------------------- 1 | "use strict" 2 | 3 | import vscode = require('vscode') 4 | import FactorioApiData from "./FactorioApiData" 5 | import { getLastMatch, keys, assign } from "./utils" 6 | 7 | const wordsRegex = /([\w\[\]]+\.[\w\[\]\.]*)/g 8 | 9 | export class FactorioAutocomplete implements vscode.CompletionItemProvider { 10 | constructor(private apiData: FactorioApiData) { } 11 | 12 | public provideCompletionItems(document: vscode.TextDocument, position: vscode.Position, token: vscode.CancellationToken): Thenable { 13 | return new Promise((resolve, reject) => { 14 | let lineText = document.lineAt(position.line).text 15 | let lineTillCurrentPosition = lineText.substr(0, position.character) 16 | 17 | let match = getLastMatch(wordsRegex, lineTillCurrentPosition) 18 | let line = match ? match[1] : "" 19 | 20 | let words = line.split(".") 21 | words.pop() 22 | 23 | let type = this.apiData.findType(words) 24 | 25 | if (!type || !type.properties) { 26 | return reject() 27 | } 28 | 29 | let suggestions = this.toCompletionItems(type.properties) 30 | return resolve(suggestions) 31 | }) 32 | } 33 | 34 | private toCompletionItems(types: FactorioTypeMap): vscode.CompletionItem[] { 35 | return keys(types).map(key => this.toCompletionItem(types[key], key)) 36 | } 37 | 38 | private toCompletionItem(type: FactorioType, key: string): vscode.CompletionItem { 39 | const { doc, name, mode } = type 40 | 41 | let completionItem = assign(new vscode.CompletionItem(key), { 42 | detail: type.type, 43 | documentation: new vscode.MarkdownString([doc, mode].filter(Boolean).join("\n\n")), 44 | kind: vscode.CompletionItemKind.Property 45 | }) 46 | 47 | if (type.type === "function") { 48 | assign(completionItem, { 49 | detail: name, 50 | kind: vscode.CompletionItemKind.Function 51 | }) 52 | } else if (type.type === "define") { 53 | assign(completionItem, { 54 | kind: vscode.CompletionItemKind.Constant 55 | }) 56 | } 57 | 58 | return completionItem 59 | } 60 | } 61 | -------------------------------------------------------------------------------- /src/FactorioHover.ts: -------------------------------------------------------------------------------- 1 | "use strict" 2 | 3 | import vscode = require('vscode') 4 | import FactorioApiData from "./FactorioApiData" 5 | import { getLastMatch } from "./utils" 6 | 7 | const { isArray } = Array 8 | const { assign, keys } = Object 9 | 10 | const wordsRegex = /([\w\[\]]+\.*[\w\[\]\.]*)/g 11 | 12 | export class FactorioHover implements vscode.HoverProvider { 13 | constructor(private apiData: FactorioApiData) { } 14 | 15 | provideHover(document: vscode.TextDocument, position: vscode.Position, token: vscode.CancellationToken): vscode.ProviderResult { 16 | return new Promise((resolve, reject) => { 17 | let lineText = document.lineAt(position.line).text 18 | let wordRange = document.getWordRangeAtPosition(position) 19 | 20 | if (!wordRange) return reject() 21 | 22 | let lineTillCurrentWord = lineText.substr(0, wordRange.end.character) 23 | let match = getLastMatch(wordsRegex, lineTillCurrentWord) 24 | let wordsStr = match ? match[1] : null 25 | 26 | if (!wordsStr) return reject() 27 | 28 | let words = wordsStr.split(".") 29 | let word = words.pop() 30 | let type = this.apiData.findType(words) 31 | 32 | if (!type) return reject() 33 | 34 | let target 35 | 36 | if (type.properties && type.properties[word]) { 37 | target = type.properties[word] 38 | } else if (type[word]) { 39 | target = type[word] 40 | } else if (!target || (!target.type && !target.name)) { 41 | return reject() 42 | } 43 | 44 | let content = `_${target.type}_` 45 | 46 | if (target.name && target.name !== target.type) { 47 | content = `**${target.name}**` + ": " + content 48 | } 49 | 50 | if (target.doc) { 51 | content += "\n\n" + target.doc 52 | } 53 | 54 | resolve(new vscode.Hover(content, wordRange)) 55 | }) 56 | } 57 | } 58 | -------------------------------------------------------------------------------- /src/extension.ts: -------------------------------------------------------------------------------- 1 | "use strict" 2 | 3 | import vscode = require("vscode") 4 | import FactorioApiData from "./FactorioApiData" 5 | import { FactorioAutocomplete } from "./FactorioAutocomplete" 6 | import { FactorioHover } from "./FactorioHover" 7 | 8 | const LUA_MODE = { language: "lua", scheme: "file" } 9 | 10 | export function activate(context: vscode.ExtensionContext) { 11 | let dataPath = context.asAbsolutePath("./data") 12 | const factorioApiData = new FactorioApiData(dataPath) 13 | 14 | context.subscriptions.push( 15 | vscode.languages.registerCompletionItemProvider( 16 | LUA_MODE, 17 | new FactorioAutocomplete(factorioApiData), 18 | '.' 19 | ) 20 | ) 21 | 22 | context.subscriptions.push( 23 | vscode.languages.registerHoverProvider( 24 | LUA_MODE, 25 | new FactorioHover(factorioApiData) 26 | ) 27 | ) 28 | } 29 | 30 | // this method is called when your extension is deactivated 31 | export function deactivate() { 32 | } -------------------------------------------------------------------------------- /src/types.d.ts: -------------------------------------------------------------------------------- 1 | interface FactorioTypeMap { 2 | [prop: string]: FactorioType 3 | } 4 | 5 | interface FactorioType { 6 | type?: string 7 | name?: string 8 | doc?: string 9 | mode?: string 10 | properties?: FactorioTypeMap 11 | args?: FactorioTypeMap 12 | returns?: string 13 | inherits?: string[] 14 | } 15 | -------------------------------------------------------------------------------- /src/utils.ts: -------------------------------------------------------------------------------- 1 | export const { isArray } = Array 2 | export const { assign, keys } = Object 3 | 4 | export const getMatches = (regex: RegExp, str: string) : string[] => { 5 | let match = null, matches = [] 6 | while ((match = regex.exec(str)) !== null) { 7 | matches.push(match) 8 | } 9 | return matches 10 | } 11 | 12 | export const getLastMatch = (regex: RegExp, str: string) : string => { 13 | return getMatches(regex, str).slice(-1).pop() 14 | } 15 | 16 | export const each = (data: any[] | {}, callback: (value: any, key: string | number) => any) =>{ 17 | isArray(data) ? 18 | data.forEach(callback) : 19 | keys(data).forEach(k => callback(data[k], k)) 20 | } 21 | 22 | export const reduce = (data: any[] | {}, callback: (prev: any, curr: any, key: string | number) => any, initial?: any): any => { 23 | return isArray(data) ? 24 | data.reduce(callback, initial) : 25 | keys(data).reduce((prev, key) => callback(prev, data[key], key), initial) 26 | } 27 | -------------------------------------------------------------------------------- /test/extension.test.ts: -------------------------------------------------------------------------------- 1 | // 2 | // Note: This example test is leveraging the Mocha test framework. 3 | // Please refer to their documentation on https://mochajs.org/ for help. 4 | // 5 | 6 | // The module 'assert' provides assertion methods from node 7 | import * as assert from 'assert'; 8 | 9 | // You can import and use all API from the 'vscode' module 10 | // as well as import your extension to test it 11 | import * as vscode from 'vscode'; 12 | import * as myExtension from '../src/extension'; 13 | 14 | // Defines a Mocha test suite to group tests of similar kind together 15 | suite("Extension Tests", () => { 16 | 17 | // Defines a Mocha unit test 18 | test("Something 1", () => { 19 | assert.equal(-1, [1, 2, 3].indexOf(5)); 20 | assert.equal(-1, [1, 2, 3].indexOf(0)); 21 | }); 22 | }); -------------------------------------------------------------------------------- /test/index.ts: -------------------------------------------------------------------------------- 1 | // 2 | // PLEASE DO NOT MODIFY / DELETE UNLESS YOU KNOW WHAT YOU ARE DOING 3 | // 4 | // This file is providing the test runner to use when running extension tests. 5 | // By default the test runner in use is Mocha based. 6 | // 7 | // You can provide your own test runner if you want to override it by exporting 8 | // a function run(testRoot: string, clb: (error:Error) => void) that the extension 9 | // host can call to run the tests. The test runner is expected to use console.log 10 | // to report the results back to the caller. When the tests are finished, return 11 | // a possible error to the callback or null if none. 12 | 13 | var testRunner = require('vscode/lib/testrunner'); 14 | 15 | // You can directly control Mocha options by uncommenting the following lines 16 | // See https://github.com/mochajs/mocha/wiki/Using-mocha-programmatically#set-options for more info 17 | testRunner.configure({ 18 | ui: 'tdd', // the TDD UI is being used in extension.test.ts (suite, test, etc.) 19 | useColors: true // colored output from test results 20 | }); 21 | 22 | module.exports = testRunner; -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "target": "es6", 5 | "outDir": "out", 6 | "lib": [ 7 | "es6" 8 | ], 9 | "sourceMap": true, 10 | "rootDir": ".", 11 | "allowJs": false 12 | }, 13 | "exclude": [ 14 | "node_modules", 15 | ".vscode-test" 16 | ] 17 | } --------------------------------------------------------------------------------