├── License.txt ├── README.md ├── client ├── .gitignore ├── .vscode │ ├── launch.json │ ├── settings.json │ └── tasks.json ├── .vscodeignore ├── License.txt ├── README.md ├── ThirdPartyNotices.txt ├── package-lock.json ├── package.json ├── src │ └── extension.ts ├── test │ ├── extension.test.ts │ └── index.ts └── tsconfig.json └── server ├── .gitignore ├── README.md ├── SampleServer.sln └── SampleServer ├── App.config ├── App.cs ├── Logger.cs ├── Program.cs ├── Properties └── AssemblyInfo.cs ├── SampleServer.csproj ├── TextDocumentChangedEventArgs.cs └── TextDocumentManager.cs /License.txt: -------------------------------------------------------------------------------- 1 | Copyright (c) Microsoft Corporation 2 | 3 | All rights reserved. 4 | 5 | MIT License 6 | 7 | Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files 8 | (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, 9 | publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do 10 | so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. 13 | 14 | THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 15 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE 16 | FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION 17 | WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 18 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # vscode-languageserver-csharp-example 2 | 3 | This repository contains a sample language server implemented in C# 4 | and a sample VS code extension that demonstrates an extension that runs the server. 5 | 6 | The extension observes all 'plaintext' documents (documents from all editors not associated with a language) 7 | and uses the server to provide validation and completion proposals. 8 | 9 | The code for the extension is in the 'client' folder. It uses the 'vscode-languageclient' node module to launch the language server. 10 | 11 | The language server is located in the 'server' folder. 12 | 13 | # Modification from the original 14 | Sample language server is implemented in C#. 15 | 16 | # How to run locally 17 | * `cd server` to move the server folder. 18 | * `msbuild /t:Restore SampleServer.sln` to restore nuget packages. 19 | * `msbuild SampleServer.sln` to build the server. 20 | * `cd ../client` to move the client folder. 21 | * `npm install` to initialize the extension. 22 | * open `client` folder in VS Code. 23 | * 'Ctrl+Shift+B' to build the client and watch files. 24 | * In the Debug viewlet, run 'Launch Extension' from drop-down to launch the extension and attach to the extension. 25 | * create a file `test.txt`, and type `typescript`. You should see a validation error. 26 | * to debug the server use external debugger such as Visual Studio. 27 | -------------------------------------------------------------------------------- /client/.gitignore: -------------------------------------------------------------------------------- 1 | out 2 | server 3 | node_modules -------------------------------------------------------------------------------- /client/.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 | "name": "Launch Extension", 7 | "type": "extensionHost", 8 | "request": "launch", 9 | "runtimeExecutable": "${execPath}", 10 | "args": ["--extensionDevelopmentPath=${workspaceRoot}" ], 11 | "stopOnEntry": false, 12 | "sourceMaps": true, 13 | "outFiles": [ "${workspaceRoot}/out/src/**/*.js" ], 14 | "preLaunchTask": "npm" 15 | }, 16 | { 17 | "name": "Launch Tests", 18 | "type": "extensionHost", 19 | "request": "launch", 20 | "runtimeExecutable": "${execPath}", 21 | "args": ["--extensionDevelopmentPath=${workspaceRoot}", "--extensionTestsPath=${workspaceRoot}/out/test" ], 22 | "stopOnEntry": false, 23 | "sourceMaps": true, 24 | "outFiles": [ "${workspaceRoot}/out/test/**/*.js" ], 25 | "preLaunchTask": "npm" 26 | } 27 | ] 28 | } -------------------------------------------------------------------------------- /client/.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 | "typescript.tsdk": "./node_modules/typescript/lib" // we want to use the TS server from our node_modules folder to control its version 10 | } -------------------------------------------------------------------------------- /client/.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 | "isWatching": true, 27 | 28 | // use the standard tsc in watch mode problem matcher to find compile problems in the output. 29 | "problemMatcher": "$tsc-watch" 30 | } -------------------------------------------------------------------------------- /client/.vscodeignore: -------------------------------------------------------------------------------- 1 | .vscode/** 2 | typings/** 3 | out/test/** 4 | test/** 5 | src/** 6 | **/*.map 7 | .gitignore 8 | tsconfig.json 9 | vsc-extension-quickstart.md 10 | -------------------------------------------------------------------------------- /client/License.txt: -------------------------------------------------------------------------------- 1 | Copyright (c) Microsoft Corporation 2 | 3 | All rights reserved. 4 | 5 | MIT License 6 | 7 | Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: 8 | 9 | The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. 10 | 11 | THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 12 | -------------------------------------------------------------------------------- /client/README.md: -------------------------------------------------------------------------------- 1 | # README 2 | ## This is the README for your extension "vscode" 3 | You can author your README using Visual Studio Code. Here are some useful editor keyboard shortcuts: 4 | 5 | * Split the editor (`Cmd+\` on OSX or `Ctrl+\` on Windows and Linux) 6 | * Toggle preview (`Shift+CMD+V` on OSX or `Shift+Ctrl+V` on Windows and Linux) 7 | * Press `Ctrl+Space` (Windows, Linux) or `Cmd+Space` (OSX) to see a list of Markdown snippets 8 | 9 | ### For more information 10 | * [Visual Studio Code's Markdown Support](http://code.visualstudio.com/docs/languages/markdown) 11 | * [Markdown Syntax Reference](https://help.github.com/articles/markdown-basics/) 12 | 13 | ** Enjoy!** 14 | -------------------------------------------------------------------------------- /client/ThirdPartyNotices.txt: -------------------------------------------------------------------------------- 1 | THIRD-PARTY SOFTWARE NOTICES AND INFORMATION 2 | For Microsoft vscode-languageserver-node-example 3 | 4 | This project incorporates material from the project(s) listed below (collectively, “Third Party Code”). 5 | Microsoft is not the original author of the Third Party Code. The original copyright notice and license 6 | under which Microsoft received such Third Party Code are set out below. This Third Party Code is licensed 7 | to you under their original license terms set forth below. Microsoft reserves all other rights not expressly 8 | granted, whether by implication, estoppel or otherwise. 9 | 10 | 1. DefinitelyTyped version 0.0.1 (https://github.com/borisyankov/DefinitelyTyped) 11 | 12 | This project is licensed under the MIT license. 13 | Copyrights are respective of each contributor listed at the beginning of each definition file. 14 | 15 | Permission is hereby granted, free of charge, to any person obtaining a copy 16 | of this software and associated documentation files (the "Software"), to deal 17 | in the Software without restriction, including without limitation the rights 18 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 19 | copies of the Software, and to permit persons to whom the Software is 20 | furnished to do so, subject to the following conditions: 21 | 22 | The above copyright notice and this permission notice shall be included in 23 | all copies or substantial portions of the Software. 24 | 25 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 26 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 27 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 28 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 29 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 30 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 31 | THE SOFTWARE. -------------------------------------------------------------------------------- /client/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "language-client-example", 3 | "version": "0.0.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@types/mocha": { 8 | "version": "2.2.48", 9 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-2.2.48.tgz", 10 | "integrity": "sha512-nlK/iyETgafGli8Zh9zJVCTicvU3iajSkRwOh3Hhiva598CMqNJ4NcVCGMTGKpGpTYj/9R8RLzS9NAykSSCqGw==", 11 | "dev": true 12 | }, 13 | "@types/node": { 14 | "version": "6.0.115", 15 | "resolved": "https://registry.npmjs.org/@types/node/-/node-6.0.115.tgz", 16 | "integrity": "sha512-PWA07jqflLli+PAk7VaJn0MVdTw96egk5B1FxwocV/tcc3RamNGbza1ZgS0OGUsTuAYCFCboL+IlG2bPazV2Nw==", 17 | "dev": true 18 | }, 19 | "ajv": { 20 | "version": "5.5.2", 21 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.2.tgz", 22 | "integrity": "sha1-c7Xuyj+rZT49P5Qis0GtQiBdyWU=", 23 | "dev": true, 24 | "requires": { 25 | "co": "^4.6.0", 26 | "fast-deep-equal": "^1.0.0", 27 | "fast-json-stable-stringify": "^2.0.0", 28 | "json-schema-traverse": "^0.3.0" 29 | } 30 | }, 31 | "ansi-cyan": { 32 | "version": "0.1.1", 33 | "resolved": "https://registry.npmjs.org/ansi-cyan/-/ansi-cyan-0.1.1.tgz", 34 | "integrity": "sha1-U4rlKK+JgvKK4w2G8vF0VtJgmHM=", 35 | "dev": true, 36 | "requires": { 37 | "ansi-wrap": "0.1.0" 38 | } 39 | }, 40 | "ansi-red": { 41 | "version": "0.1.1", 42 | "resolved": "https://registry.npmjs.org/ansi-red/-/ansi-red-0.1.1.tgz", 43 | "integrity": "sha1-jGOPnRCAgAo1PJwoyKgcpHBdlGw=", 44 | "dev": true, 45 | "requires": { 46 | "ansi-wrap": "0.1.0" 47 | } 48 | }, 49 | "ansi-wrap": { 50 | "version": "0.1.0", 51 | "resolved": "https://registry.npmjs.org/ansi-wrap/-/ansi-wrap-0.1.0.tgz", 52 | "integrity": "sha1-qCJQ3bABXponyoLoLqYDu/pF768=", 53 | "dev": true 54 | }, 55 | "arr-diff": { 56 | "version": "1.1.0", 57 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-1.1.0.tgz", 58 | "integrity": "sha1-aHwydYFjWI/vfeezb6vklesaOZo=", 59 | "dev": true, 60 | "requires": { 61 | "arr-flatten": "^1.0.1", 62 | "array-slice": "^0.2.3" 63 | } 64 | }, 65 | "arr-flatten": { 66 | "version": "1.1.0", 67 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 68 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", 69 | "dev": true 70 | }, 71 | "arr-union": { 72 | "version": "2.1.0", 73 | "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-2.1.0.tgz", 74 | "integrity": "sha1-IPnqtexw9cfSFbEHexw5Fh0pLH0=", 75 | "dev": true 76 | }, 77 | "array-differ": { 78 | "version": "1.0.0", 79 | "resolved": "https://registry.npmjs.org/array-differ/-/array-differ-1.0.0.tgz", 80 | "integrity": "sha1-7/UuN1gknTO+QCuLuOVkuytdQDE=", 81 | "dev": true 82 | }, 83 | "array-slice": { 84 | "version": "0.2.3", 85 | "resolved": "https://registry.npmjs.org/array-slice/-/array-slice-0.2.3.tgz", 86 | "integrity": "sha1-3Tz7gO15c6dRF82sabC5nshhhvU=", 87 | "dev": true 88 | }, 89 | "array-union": { 90 | "version": "1.0.2", 91 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", 92 | "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", 93 | "dev": true, 94 | "requires": { 95 | "array-uniq": "^1.0.1" 96 | } 97 | }, 98 | "array-uniq": { 99 | "version": "1.0.3", 100 | "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", 101 | "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", 102 | "dev": true 103 | }, 104 | "array-unique": { 105 | "version": "0.2.1", 106 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", 107 | "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", 108 | "dev": true 109 | }, 110 | "arrify": { 111 | "version": "1.0.1", 112 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 113 | "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", 114 | "dev": true 115 | }, 116 | "asn1": { 117 | "version": "0.2.4", 118 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 119 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 120 | "dev": true, 121 | "requires": { 122 | "safer-buffer": "~2.1.0" 123 | } 124 | }, 125 | "assert-plus": { 126 | "version": "1.0.0", 127 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 128 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 129 | "dev": true 130 | }, 131 | "asynckit": { 132 | "version": "0.4.0", 133 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 134 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 135 | "dev": true 136 | }, 137 | "aws-sign2": { 138 | "version": "0.7.0", 139 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 140 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 141 | "dev": true 142 | }, 143 | "aws4": { 144 | "version": "1.7.0", 145 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.7.0.tgz", 146 | "integrity": "sha512-32NDda82rhwD9/JBCCkB+MRYDp0oSvlo2IL6rQWA10PQi7tDUM3eqMSltXmY+Oyl/7N3P3qNtAlv7X0d9bI28w==", 147 | "dev": true 148 | }, 149 | "balanced-match": { 150 | "version": "1.0.0", 151 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 152 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 153 | "dev": true 154 | }, 155 | "bcrypt-pbkdf": { 156 | "version": "1.0.2", 157 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 158 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 159 | "dev": true, 160 | "optional": true, 161 | "requires": { 162 | "tweetnacl": "^0.14.3" 163 | } 164 | }, 165 | "block-stream": { 166 | "version": "0.0.9", 167 | "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz", 168 | "integrity": "sha1-E+v+d4oDIFz+A3UUgeu0szAMEmo=", 169 | "dev": true, 170 | "requires": { 171 | "inherits": "~2.0.0" 172 | } 173 | }, 174 | "brace-expansion": { 175 | "version": "1.1.11", 176 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 177 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 178 | "dev": true, 179 | "requires": { 180 | "balanced-match": "^1.0.0", 181 | "concat-map": "0.0.1" 182 | } 183 | }, 184 | "braces": { 185 | "version": "1.8.5", 186 | "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", 187 | "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", 188 | "dev": true, 189 | "requires": { 190 | "expand-range": "^1.8.1", 191 | "preserve": "^0.2.0", 192 | "repeat-element": "^1.1.2" 193 | } 194 | }, 195 | "browser-stdout": { 196 | "version": "1.3.0", 197 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.0.tgz", 198 | "integrity": "sha1-81HTKWnTL6XXpVZxVCY9korjvR8=", 199 | "dev": true 200 | }, 201 | "buffer-crc32": { 202 | "version": "0.2.13", 203 | "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", 204 | "integrity": "sha1-DTM+PwDqxQqhRUq9MO+MKl2ackI=", 205 | "dev": true 206 | }, 207 | "buffer-from": { 208 | "version": "1.1.1", 209 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 210 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 211 | "dev": true 212 | }, 213 | "caseless": { 214 | "version": "0.12.0", 215 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 216 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", 217 | "dev": true 218 | }, 219 | "clone": { 220 | "version": "0.2.0", 221 | "resolved": "https://registry.npmjs.org/clone/-/clone-0.2.0.tgz", 222 | "integrity": "sha1-xhJqkK1Pctv1rNskPMN3JP6T/B8=", 223 | "dev": true 224 | }, 225 | "clone-buffer": { 226 | "version": "1.0.0", 227 | "resolved": "https://registry.npmjs.org/clone-buffer/-/clone-buffer-1.0.0.tgz", 228 | "integrity": "sha1-4+JbIHrE5wGvch4staFnksrD3Fg=", 229 | "dev": true 230 | }, 231 | "clone-stats": { 232 | "version": "0.0.1", 233 | "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-0.0.1.tgz", 234 | "integrity": "sha1-uI+UqCzzi4eR1YBG6kAprYjKmdE=", 235 | "dev": true 236 | }, 237 | "cloneable-readable": { 238 | "version": "1.1.2", 239 | "resolved": "https://registry.npmjs.org/cloneable-readable/-/cloneable-readable-1.1.2.tgz", 240 | "integrity": "sha512-Bq6+4t+lbM8vhTs/Bef5c5AdEMtapp/iFb6+s4/Hh9MVTt8OLKH7ZOOZSCT+Ys7hsHvqv0GuMPJ1lnQJVHvxpg==", 241 | "dev": true, 242 | "requires": { 243 | "inherits": "^2.0.1", 244 | "process-nextick-args": "^2.0.0", 245 | "readable-stream": "^2.3.5" 246 | } 247 | }, 248 | "co": { 249 | "version": "4.6.0", 250 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 251 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", 252 | "dev": true 253 | }, 254 | "combined-stream": { 255 | "version": "1.0.6", 256 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.6.tgz", 257 | "integrity": "sha1-cj599ugBrFYTETp+RFqbactjKBg=", 258 | "dev": true, 259 | "requires": { 260 | "delayed-stream": "~1.0.0" 261 | } 262 | }, 263 | "commander": { 264 | "version": "2.11.0", 265 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.11.0.tgz", 266 | "integrity": "sha512-b0553uYA5YAEGgyYIGYROzKQ7X5RAqedkfjiZxwi0kL1g3bOaBNNZfYkzt/CL0umgD5wc9Jec2FbB98CjkMRvQ==", 267 | "dev": true 268 | }, 269 | "concat-map": { 270 | "version": "0.0.1", 271 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 272 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 273 | "dev": true 274 | }, 275 | "convert-source-map": { 276 | "version": "1.5.1", 277 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.5.1.tgz", 278 | "integrity": "sha1-uCeAl7m8IpNl3lxiz1/K7YtVmeU=", 279 | "dev": true 280 | }, 281 | "core-util-is": { 282 | "version": "1.0.2", 283 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 284 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 285 | "dev": true 286 | }, 287 | "dashdash": { 288 | "version": "1.14.1", 289 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 290 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 291 | "dev": true, 292 | "requires": { 293 | "assert-plus": "^1.0.0" 294 | } 295 | }, 296 | "debug": { 297 | "version": "3.1.0", 298 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 299 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 300 | "dev": true, 301 | "requires": { 302 | "ms": "2.0.0" 303 | } 304 | }, 305 | "deep-assign": { 306 | "version": "1.0.0", 307 | "resolved": "https://registry.npmjs.org/deep-assign/-/deep-assign-1.0.0.tgz", 308 | "integrity": "sha1-sJJ0O+hCfcYh6gBnzex+cN0Z83s=", 309 | "dev": true, 310 | "requires": { 311 | "is-obj": "^1.0.0" 312 | } 313 | }, 314 | "delayed-stream": { 315 | "version": "1.0.0", 316 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 317 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 318 | "dev": true 319 | }, 320 | "diff": { 321 | "version": "3.3.1", 322 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.3.1.tgz", 323 | "integrity": "sha512-MKPHZDMB0o6yHyDryUOScqZibp914ksXwAMYMTHj6KO8UeKsRYNJD3oNCKjTqZon+V488P7N/HzXF8t7ZR95ww==", 324 | "dev": true 325 | }, 326 | "duplexer": { 327 | "version": "0.1.1", 328 | "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.1.tgz", 329 | "integrity": "sha1-rOb/gIwc5mtX0ev5eXessCM0z8E=", 330 | "dev": true 331 | }, 332 | "duplexify": { 333 | "version": "3.6.0", 334 | "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.6.0.tgz", 335 | "integrity": "sha512-fO3Di4tBKJpYTFHAxTU00BcfWMY9w24r/x21a6rZRbsD/ToUgGxsMbiGRmB7uVAXeGKXD9MwiLZa5E97EVgIRQ==", 336 | "dev": true, 337 | "requires": { 338 | "end-of-stream": "^1.0.0", 339 | "inherits": "^2.0.1", 340 | "readable-stream": "^2.0.0", 341 | "stream-shift": "^1.0.0" 342 | } 343 | }, 344 | "ecc-jsbn": { 345 | "version": "0.1.2", 346 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 347 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 348 | "dev": true, 349 | "optional": true, 350 | "requires": { 351 | "jsbn": "~0.1.0", 352 | "safer-buffer": "^2.1.0" 353 | } 354 | }, 355 | "end-of-stream": { 356 | "version": "1.4.1", 357 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz", 358 | "integrity": "sha512-1MkrZNvWTKCaigbn+W15elq2BB/L22nqrSY5DKlo3X6+vclJm8Bb5djXJBmEX6fS3+zCh/F4VBK5Z2KxJt4s2Q==", 359 | "dev": true, 360 | "requires": { 361 | "once": "^1.4.0" 362 | } 363 | }, 364 | "escape-string-regexp": { 365 | "version": "1.0.5", 366 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 367 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 368 | "dev": true 369 | }, 370 | "event-stream": { 371 | "version": "3.3.4", 372 | "resolved": "http://registry.npmjs.org/event-stream/-/event-stream-3.3.4.tgz", 373 | "integrity": "sha1-SrTJoPWlTbkzi0w02Gv86PSzVXE=", 374 | "dev": true, 375 | "requires": { 376 | "duplexer": "~0.1.1", 377 | "from": "~0", 378 | "map-stream": "~0.1.0", 379 | "pause-stream": "0.0.11", 380 | "split": "0.3", 381 | "stream-combiner": "~0.0.4", 382 | "through": "~2.3.1" 383 | } 384 | }, 385 | "expand-brackets": { 386 | "version": "0.1.5", 387 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", 388 | "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", 389 | "dev": true, 390 | "requires": { 391 | "is-posix-bracket": "^0.1.0" 392 | } 393 | }, 394 | "expand-range": { 395 | "version": "1.8.2", 396 | "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz", 397 | "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", 398 | "dev": true, 399 | "requires": { 400 | "fill-range": "^2.1.0" 401 | } 402 | }, 403 | "extend": { 404 | "version": "3.0.2", 405 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 406 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 407 | "dev": true 408 | }, 409 | "extend-shallow": { 410 | "version": "1.1.4", 411 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-1.1.4.tgz", 412 | "integrity": "sha1-Gda/lN/AnXa6cR85uHLSH/TdkHE=", 413 | "dev": true, 414 | "requires": { 415 | "kind-of": "^1.1.0" 416 | } 417 | }, 418 | "extglob": { 419 | "version": "0.3.2", 420 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", 421 | "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", 422 | "dev": true, 423 | "requires": { 424 | "is-extglob": "^1.0.0" 425 | }, 426 | "dependencies": { 427 | "is-extglob": { 428 | "version": "1.0.0", 429 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 430 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 431 | "dev": true 432 | } 433 | } 434 | }, 435 | "extsprintf": { 436 | "version": "1.3.0", 437 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 438 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 439 | "dev": true 440 | }, 441 | "fast-deep-equal": { 442 | "version": "1.1.0", 443 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz", 444 | "integrity": "sha1-wFNHeBfIa1HaqFPIHgWbcz0CNhQ=", 445 | "dev": true 446 | }, 447 | "fast-json-stable-stringify": { 448 | "version": "2.0.0", 449 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 450 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 451 | "dev": true 452 | }, 453 | "fd-slicer": { 454 | "version": "1.1.0", 455 | "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", 456 | "integrity": "sha1-JcfInLH5B3+IkbvmHY85Dq4lbx4=", 457 | "dev": true, 458 | "requires": { 459 | "pend": "~1.2.0" 460 | } 461 | }, 462 | "filename-regex": { 463 | "version": "2.0.1", 464 | "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", 465 | "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=", 466 | "dev": true 467 | }, 468 | "fill-range": { 469 | "version": "2.2.4", 470 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.4.tgz", 471 | "integrity": "sha512-cnrcCbj01+j2gTG921VZPnHbjmdAf8oQV/iGeV2kZxGSyfYjjTyY79ErsK1WJWMpw6DaApEX72binqJE+/d+5Q==", 472 | "dev": true, 473 | "requires": { 474 | "is-number": "^2.1.0", 475 | "isobject": "^2.0.0", 476 | "randomatic": "^3.0.0", 477 | "repeat-element": "^1.1.2", 478 | "repeat-string": "^1.5.2" 479 | } 480 | }, 481 | "first-chunk-stream": { 482 | "version": "1.0.0", 483 | "resolved": "https://registry.npmjs.org/first-chunk-stream/-/first-chunk-stream-1.0.0.tgz", 484 | "integrity": "sha1-Wb+1DNkF9g18OUzT2ayqtOatk04=", 485 | "dev": true 486 | }, 487 | "for-in": { 488 | "version": "1.0.2", 489 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 490 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", 491 | "dev": true 492 | }, 493 | "for-own": { 494 | "version": "0.1.5", 495 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", 496 | "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", 497 | "dev": true, 498 | "requires": { 499 | "for-in": "^1.0.1" 500 | } 501 | }, 502 | "forever-agent": { 503 | "version": "0.6.1", 504 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 505 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 506 | "dev": true 507 | }, 508 | "form-data": { 509 | "version": "2.3.2", 510 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.2.tgz", 511 | "integrity": "sha1-SXBJi+YEwgwAXU9cI67NIda0kJk=", 512 | "dev": true, 513 | "requires": { 514 | "asynckit": "^0.4.0", 515 | "combined-stream": "1.0.6", 516 | "mime-types": "^2.1.12" 517 | } 518 | }, 519 | "from": { 520 | "version": "0.1.7", 521 | "resolved": "https://registry.npmjs.org/from/-/from-0.1.7.tgz", 522 | "integrity": "sha1-g8YK/Fi5xWmXAH7Rp2izqzA6RP4=", 523 | "dev": true 524 | }, 525 | "fs.realpath": { 526 | "version": "1.0.0", 527 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 528 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 529 | "dev": true 530 | }, 531 | "fstream": { 532 | "version": "1.0.11", 533 | "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz", 534 | "integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=", 535 | "dev": true, 536 | "requires": { 537 | "graceful-fs": "^4.1.2", 538 | "inherits": "~2.0.0", 539 | "mkdirp": ">=0.5 0", 540 | "rimraf": "2" 541 | } 542 | }, 543 | "getpass": { 544 | "version": "0.1.7", 545 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 546 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 547 | "dev": true, 548 | "requires": { 549 | "assert-plus": "^1.0.0" 550 | } 551 | }, 552 | "glob": { 553 | "version": "7.1.2", 554 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 555 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 556 | "dev": true, 557 | "requires": { 558 | "fs.realpath": "^1.0.0", 559 | "inflight": "^1.0.4", 560 | "inherits": "2", 561 | "minimatch": "^3.0.4", 562 | "once": "^1.3.0", 563 | "path-is-absolute": "^1.0.0" 564 | } 565 | }, 566 | "glob-base": { 567 | "version": "0.3.0", 568 | "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", 569 | "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", 570 | "dev": true, 571 | "requires": { 572 | "glob-parent": "^2.0.0", 573 | "is-glob": "^2.0.0" 574 | }, 575 | "dependencies": { 576 | "glob-parent": { 577 | "version": "2.0.0", 578 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", 579 | "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", 580 | "dev": true, 581 | "requires": { 582 | "is-glob": "^2.0.0" 583 | } 584 | }, 585 | "is-extglob": { 586 | "version": "1.0.0", 587 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 588 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 589 | "dev": true 590 | }, 591 | "is-glob": { 592 | "version": "2.0.1", 593 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 594 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 595 | "dev": true, 596 | "requires": { 597 | "is-extglob": "^1.0.0" 598 | } 599 | } 600 | } 601 | }, 602 | "glob-parent": { 603 | "version": "3.1.0", 604 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", 605 | "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", 606 | "dev": true, 607 | "requires": { 608 | "is-glob": "^3.1.0", 609 | "path-dirname": "^1.0.0" 610 | } 611 | }, 612 | "glob-stream": { 613 | "version": "5.3.5", 614 | "resolved": "https://registry.npmjs.org/glob-stream/-/glob-stream-5.3.5.tgz", 615 | "integrity": "sha1-pVZlqajM3EGRWofHAeMtTgFvrSI=", 616 | "dev": true, 617 | "requires": { 618 | "extend": "^3.0.0", 619 | "glob": "^5.0.3", 620 | "glob-parent": "^3.0.0", 621 | "micromatch": "^2.3.7", 622 | "ordered-read-streams": "^0.3.0", 623 | "through2": "^0.6.0", 624 | "to-absolute-glob": "^0.1.1", 625 | "unique-stream": "^2.0.2" 626 | }, 627 | "dependencies": { 628 | "glob": { 629 | "version": "5.0.15", 630 | "resolved": "https://registry.npmjs.org/glob/-/glob-5.0.15.tgz", 631 | "integrity": "sha1-G8k2ueAvSmA/zCIuz3Yz0wuLk7E=", 632 | "dev": true, 633 | "requires": { 634 | "inflight": "^1.0.4", 635 | "inherits": "2", 636 | "minimatch": "2 || 3", 637 | "once": "^1.3.0", 638 | "path-is-absolute": "^1.0.0" 639 | } 640 | }, 641 | "isarray": { 642 | "version": "0.0.1", 643 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 644 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 645 | "dev": true 646 | }, 647 | "readable-stream": { 648 | "version": "1.0.34", 649 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.0.34.tgz", 650 | "integrity": "sha1-Elgg40vIQtLyqq+v5MKRbuMsFXw=", 651 | "dev": true, 652 | "requires": { 653 | "core-util-is": "~1.0.0", 654 | "inherits": "~2.0.1", 655 | "isarray": "0.0.1", 656 | "string_decoder": "~0.10.x" 657 | } 658 | }, 659 | "string_decoder": { 660 | "version": "0.10.31", 661 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 662 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", 663 | "dev": true 664 | }, 665 | "through2": { 666 | "version": "0.6.5", 667 | "resolved": "https://registry.npmjs.org/through2/-/through2-0.6.5.tgz", 668 | "integrity": "sha1-QaucZ7KdVyCQcUEOHXp6lozTrUg=", 669 | "dev": true, 670 | "requires": { 671 | "readable-stream": ">=1.0.33-1 <1.1.0-0", 672 | "xtend": ">=4.0.0 <4.1.0-0" 673 | } 674 | } 675 | } 676 | }, 677 | "graceful-fs": { 678 | "version": "4.1.11", 679 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 680 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", 681 | "dev": true 682 | }, 683 | "growl": { 684 | "version": "1.10.3", 685 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.3.tgz", 686 | "integrity": "sha512-hKlsbA5Vu3xsh1Cg3J7jSmX/WaW6A5oBeqzM88oNbCRQFz+zUaXm6yxS4RVytp1scBoJzSYl4YAEOQIt6O8V1Q==", 687 | "dev": true 688 | }, 689 | "gulp-chmod": { 690 | "version": "2.0.0", 691 | "resolved": "https://registry.npmjs.org/gulp-chmod/-/gulp-chmod-2.0.0.tgz", 692 | "integrity": "sha1-AMOQuSigeZslGsz2MaoJ4BzGKZw=", 693 | "dev": true, 694 | "requires": { 695 | "deep-assign": "^1.0.0", 696 | "stat-mode": "^0.2.0", 697 | "through2": "^2.0.0" 698 | } 699 | }, 700 | "gulp-filter": { 701 | "version": "5.1.0", 702 | "resolved": "https://registry.npmjs.org/gulp-filter/-/gulp-filter-5.1.0.tgz", 703 | "integrity": "sha1-oF4Rr/sHz33PQafeHLe2OsN4PnM=", 704 | "dev": true, 705 | "requires": { 706 | "multimatch": "^2.0.0", 707 | "plugin-error": "^0.1.2", 708 | "streamfilter": "^1.0.5" 709 | } 710 | }, 711 | "gulp-gunzip": { 712 | "version": "1.0.0", 713 | "resolved": "https://registry.npmjs.org/gulp-gunzip/-/gulp-gunzip-1.0.0.tgz", 714 | "integrity": "sha1-FbdBFF6Dqcb1CIYkG1fMWHHxUak=", 715 | "dev": true, 716 | "requires": { 717 | "through2": "~0.6.5", 718 | "vinyl": "~0.4.6" 719 | }, 720 | "dependencies": { 721 | "isarray": { 722 | "version": "0.0.1", 723 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 724 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 725 | "dev": true 726 | }, 727 | "readable-stream": { 728 | "version": "1.0.34", 729 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.0.34.tgz", 730 | "integrity": "sha1-Elgg40vIQtLyqq+v5MKRbuMsFXw=", 731 | "dev": true, 732 | "requires": { 733 | "core-util-is": "~1.0.0", 734 | "inherits": "~2.0.1", 735 | "isarray": "0.0.1", 736 | "string_decoder": "~0.10.x" 737 | } 738 | }, 739 | "string_decoder": { 740 | "version": "0.10.31", 741 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 742 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", 743 | "dev": true 744 | }, 745 | "through2": { 746 | "version": "0.6.5", 747 | "resolved": "https://registry.npmjs.org/through2/-/through2-0.6.5.tgz", 748 | "integrity": "sha1-QaucZ7KdVyCQcUEOHXp6lozTrUg=", 749 | "dev": true, 750 | "requires": { 751 | "readable-stream": ">=1.0.33-1 <1.1.0-0", 752 | "xtend": ">=4.0.0 <4.1.0-0" 753 | } 754 | } 755 | } 756 | }, 757 | "gulp-remote-src-vscode": { 758 | "version": "0.5.0", 759 | "resolved": "https://registry.npmjs.org/gulp-remote-src-vscode/-/gulp-remote-src-vscode-0.5.0.tgz", 760 | "integrity": "sha512-/9vtSk9eI9DEWCqzGieglPqmx0WUQ9pwPHyHFpKmfxqdgqGJC2l0vFMdYs54hLdDsMDEZFLDL2J4ikjc4hQ5HQ==", 761 | "dev": true, 762 | "requires": { 763 | "event-stream": "^3.3.4", 764 | "node.extend": "^1.1.2", 765 | "request": "^2.79.0", 766 | "through2": "^2.0.3", 767 | "vinyl": "^2.0.1" 768 | }, 769 | "dependencies": { 770 | "clone": { 771 | "version": "2.1.2", 772 | "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.2.tgz", 773 | "integrity": "sha1-G39Ln1kfHo+DZwQBYANFoCiHQ18=", 774 | "dev": true 775 | }, 776 | "clone-stats": { 777 | "version": "1.0.0", 778 | "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-1.0.0.tgz", 779 | "integrity": "sha1-s3gt/4u1R04Yuba/D9/ngvh3doA=", 780 | "dev": true 781 | }, 782 | "vinyl": { 783 | "version": "2.2.0", 784 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-2.2.0.tgz", 785 | "integrity": "sha512-MBH+yP0kC/GQ5GwBqrTPTzEfiiLjta7hTtvQtbxBgTeSXsmKQRQecjibMbxIXzVT3Y9KJK+drOz1/k+vsu8Nkg==", 786 | "dev": true, 787 | "requires": { 788 | "clone": "^2.1.1", 789 | "clone-buffer": "^1.0.0", 790 | "clone-stats": "^1.0.0", 791 | "cloneable-readable": "^1.0.0", 792 | "remove-trailing-separator": "^1.0.1", 793 | "replace-ext": "^1.0.0" 794 | } 795 | } 796 | } 797 | }, 798 | "gulp-sourcemaps": { 799 | "version": "1.6.0", 800 | "resolved": "https://registry.npmjs.org/gulp-sourcemaps/-/gulp-sourcemaps-1.6.0.tgz", 801 | "integrity": "sha1-uG/zSdgBzrVuHZ59x7vLS33uYAw=", 802 | "dev": true, 803 | "requires": { 804 | "convert-source-map": "^1.1.1", 805 | "graceful-fs": "^4.1.2", 806 | "strip-bom": "^2.0.0", 807 | "through2": "^2.0.0", 808 | "vinyl": "^1.0.0" 809 | }, 810 | "dependencies": { 811 | "clone": { 812 | "version": "1.0.4", 813 | "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", 814 | "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", 815 | "dev": true 816 | }, 817 | "replace-ext": { 818 | "version": "0.0.1", 819 | "resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-0.0.1.tgz", 820 | "integrity": "sha1-KbvZIHinOfC8zitO5B6DeVNSKSQ=", 821 | "dev": true 822 | }, 823 | "vinyl": { 824 | "version": "1.2.0", 825 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-1.2.0.tgz", 826 | "integrity": "sha1-XIgDbPVl5d8FVYv8kR+GVt8hiIQ=", 827 | "dev": true, 828 | "requires": { 829 | "clone": "^1.0.0", 830 | "clone-stats": "^0.0.1", 831 | "replace-ext": "0.0.1" 832 | } 833 | } 834 | } 835 | }, 836 | "gulp-symdest": { 837 | "version": "1.1.0", 838 | "resolved": "https://registry.npmjs.org/gulp-symdest/-/gulp-symdest-1.1.0.tgz", 839 | "integrity": "sha1-wWUyBzLRks5W/ZQnH/oSMjS/KuA=", 840 | "dev": true, 841 | "requires": { 842 | "event-stream": "^3.3.1", 843 | "mkdirp": "^0.5.1", 844 | "queue": "^3.1.0", 845 | "vinyl-fs": "^2.4.3" 846 | } 847 | }, 848 | "gulp-untar": { 849 | "version": "0.0.7", 850 | "resolved": "https://registry.npmjs.org/gulp-untar/-/gulp-untar-0.0.7.tgz", 851 | "integrity": "sha512-0QfbCH2a1k2qkTLWPqTX+QO4qNsHn3kC546YhAP3/n0h+nvtyGITDuDrYBMDZeW4WnFijmkOvBWa5HshTic1tw==", 852 | "dev": true, 853 | "requires": { 854 | "event-stream": "~3.3.4", 855 | "streamifier": "~0.1.1", 856 | "tar": "^2.2.1", 857 | "through2": "~2.0.3", 858 | "vinyl": "^1.2.0" 859 | }, 860 | "dependencies": { 861 | "clone": { 862 | "version": "1.0.4", 863 | "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", 864 | "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", 865 | "dev": true 866 | }, 867 | "replace-ext": { 868 | "version": "0.0.1", 869 | "resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-0.0.1.tgz", 870 | "integrity": "sha1-KbvZIHinOfC8zitO5B6DeVNSKSQ=", 871 | "dev": true 872 | }, 873 | "vinyl": { 874 | "version": "1.2.0", 875 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-1.2.0.tgz", 876 | "integrity": "sha1-XIgDbPVl5d8FVYv8kR+GVt8hiIQ=", 877 | "dev": true, 878 | "requires": { 879 | "clone": "^1.0.0", 880 | "clone-stats": "^0.0.1", 881 | "replace-ext": "0.0.1" 882 | } 883 | } 884 | } 885 | }, 886 | "gulp-vinyl-zip": { 887 | "version": "2.1.0", 888 | "resolved": "https://registry.npmjs.org/gulp-vinyl-zip/-/gulp-vinyl-zip-2.1.0.tgz", 889 | "integrity": "sha1-JOQGhdwFtxSZlSRQmeBZAmO+ja0=", 890 | "dev": true, 891 | "requires": { 892 | "event-stream": "^3.3.1", 893 | "queue": "^4.2.1", 894 | "through2": "^2.0.3", 895 | "vinyl": "^2.0.2", 896 | "vinyl-fs": "^2.0.0", 897 | "yauzl": "^2.2.1", 898 | "yazl": "^2.2.1" 899 | }, 900 | "dependencies": { 901 | "clone": { 902 | "version": "2.1.2", 903 | "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.2.tgz", 904 | "integrity": "sha1-G39Ln1kfHo+DZwQBYANFoCiHQ18=", 905 | "dev": true 906 | }, 907 | "clone-stats": { 908 | "version": "1.0.0", 909 | "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-1.0.0.tgz", 910 | "integrity": "sha1-s3gt/4u1R04Yuba/D9/ngvh3doA=", 911 | "dev": true 912 | }, 913 | "queue": { 914 | "version": "4.4.2", 915 | "resolved": "https://registry.npmjs.org/queue/-/queue-4.4.2.tgz", 916 | "integrity": "sha512-fSMRXbwhMwipcDZ08enW2vl+YDmAmhcNcr43sCJL8DIg+CFOsoRLG23ctxA+fwNk1w55SePSiS7oqQQSgQoVJQ==", 917 | "dev": true, 918 | "requires": { 919 | "inherits": "~2.0.0" 920 | } 921 | }, 922 | "vinyl": { 923 | "version": "2.2.0", 924 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-2.2.0.tgz", 925 | "integrity": "sha512-MBH+yP0kC/GQ5GwBqrTPTzEfiiLjta7hTtvQtbxBgTeSXsmKQRQecjibMbxIXzVT3Y9KJK+drOz1/k+vsu8Nkg==", 926 | "dev": true, 927 | "requires": { 928 | "clone": "^2.1.1", 929 | "clone-buffer": "^1.0.0", 930 | "clone-stats": "^1.0.0", 931 | "cloneable-readable": "^1.0.0", 932 | "remove-trailing-separator": "^1.0.1", 933 | "replace-ext": "^1.0.0" 934 | } 935 | } 936 | } 937 | }, 938 | "har-schema": { 939 | "version": "2.0.0", 940 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 941 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 942 | "dev": true 943 | }, 944 | "har-validator": { 945 | "version": "5.0.3", 946 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.0.3.tgz", 947 | "integrity": "sha1-ukAsJmGU8VlW7xXg/PJCmT9qff0=", 948 | "dev": true, 949 | "requires": { 950 | "ajv": "^5.1.0", 951 | "har-schema": "^2.0.0" 952 | } 953 | }, 954 | "has-flag": { 955 | "version": "2.0.0", 956 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz", 957 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=", 958 | "dev": true 959 | }, 960 | "he": { 961 | "version": "1.1.1", 962 | "resolved": "https://registry.npmjs.org/he/-/he-1.1.1.tgz", 963 | "integrity": "sha1-k0EP0hsAlzUVH4howvJx80J+I/0=", 964 | "dev": true 965 | }, 966 | "http-signature": { 967 | "version": "1.2.0", 968 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 969 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 970 | "dev": true, 971 | "requires": { 972 | "assert-plus": "^1.0.0", 973 | "jsprim": "^1.2.2", 974 | "sshpk": "^1.7.0" 975 | } 976 | }, 977 | "inflight": { 978 | "version": "1.0.6", 979 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 980 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 981 | "dev": true, 982 | "requires": { 983 | "once": "^1.3.0", 984 | "wrappy": "1" 985 | } 986 | }, 987 | "inherits": { 988 | "version": "2.0.3", 989 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 990 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 991 | "dev": true 992 | }, 993 | "is": { 994 | "version": "3.2.1", 995 | "resolved": "https://registry.npmjs.org/is/-/is-3.2.1.tgz", 996 | "integrity": "sha1-0Kwq1V63sL7JJqUmb2xmKqqD3KU=", 997 | "dev": true 998 | }, 999 | "is-buffer": { 1000 | "version": "1.1.6", 1001 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 1002 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 1003 | "dev": true 1004 | }, 1005 | "is-dotfile": { 1006 | "version": "1.0.3", 1007 | "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", 1008 | "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=", 1009 | "dev": true 1010 | }, 1011 | "is-equal-shallow": { 1012 | "version": "0.1.3", 1013 | "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", 1014 | "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", 1015 | "dev": true, 1016 | "requires": { 1017 | "is-primitive": "^2.0.0" 1018 | } 1019 | }, 1020 | "is-extendable": { 1021 | "version": "0.1.1", 1022 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 1023 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", 1024 | "dev": true 1025 | }, 1026 | "is-extglob": { 1027 | "version": "2.1.1", 1028 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1029 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1030 | "dev": true 1031 | }, 1032 | "is-glob": { 1033 | "version": "3.1.0", 1034 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", 1035 | "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", 1036 | "dev": true, 1037 | "requires": { 1038 | "is-extglob": "^2.1.0" 1039 | } 1040 | }, 1041 | "is-number": { 1042 | "version": "2.1.0", 1043 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", 1044 | "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", 1045 | "dev": true, 1046 | "requires": { 1047 | "kind-of": "^3.0.2" 1048 | }, 1049 | "dependencies": { 1050 | "kind-of": { 1051 | "version": "3.2.2", 1052 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1053 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1054 | "dev": true, 1055 | "requires": { 1056 | "is-buffer": "^1.1.5" 1057 | } 1058 | } 1059 | } 1060 | }, 1061 | "is-obj": { 1062 | "version": "1.0.1", 1063 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", 1064 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=", 1065 | "dev": true 1066 | }, 1067 | "is-posix-bracket": { 1068 | "version": "0.1.1", 1069 | "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", 1070 | "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=", 1071 | "dev": true 1072 | }, 1073 | "is-primitive": { 1074 | "version": "2.0.0", 1075 | "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", 1076 | "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=", 1077 | "dev": true 1078 | }, 1079 | "is-stream": { 1080 | "version": "1.1.0", 1081 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 1082 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", 1083 | "dev": true 1084 | }, 1085 | "is-typedarray": { 1086 | "version": "1.0.0", 1087 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1088 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1089 | "dev": true 1090 | }, 1091 | "is-utf8": { 1092 | "version": "0.2.1", 1093 | "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", 1094 | "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=", 1095 | "dev": true 1096 | }, 1097 | "is-valid-glob": { 1098 | "version": "0.3.0", 1099 | "resolved": "https://registry.npmjs.org/is-valid-glob/-/is-valid-glob-0.3.0.tgz", 1100 | "integrity": "sha1-1LVcafUYhvm2XHDWwmItN+KfSP4=", 1101 | "dev": true 1102 | }, 1103 | "isarray": { 1104 | "version": "1.0.0", 1105 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1106 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1107 | "dev": true 1108 | }, 1109 | "isobject": { 1110 | "version": "2.1.0", 1111 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 1112 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 1113 | "dev": true, 1114 | "requires": { 1115 | "isarray": "1.0.0" 1116 | } 1117 | }, 1118 | "isstream": { 1119 | "version": "0.1.2", 1120 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 1121 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", 1122 | "dev": true 1123 | }, 1124 | "jsbn": { 1125 | "version": "0.1.1", 1126 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 1127 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 1128 | "dev": true, 1129 | "optional": true 1130 | }, 1131 | "json-schema": { 1132 | "version": "0.2.3", 1133 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 1134 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", 1135 | "dev": true 1136 | }, 1137 | "json-schema-traverse": { 1138 | "version": "0.3.1", 1139 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", 1140 | "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=", 1141 | "dev": true 1142 | }, 1143 | "json-stable-stringify": { 1144 | "version": "1.0.1", 1145 | "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", 1146 | "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", 1147 | "dev": true, 1148 | "requires": { 1149 | "jsonify": "~0.0.0" 1150 | } 1151 | }, 1152 | "json-stringify-safe": { 1153 | "version": "5.0.1", 1154 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 1155 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", 1156 | "dev": true 1157 | }, 1158 | "jsonify": { 1159 | "version": "0.0.0", 1160 | "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", 1161 | "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=", 1162 | "dev": true 1163 | }, 1164 | "jsprim": { 1165 | "version": "1.4.1", 1166 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 1167 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 1168 | "dev": true, 1169 | "requires": { 1170 | "assert-plus": "1.0.0", 1171 | "extsprintf": "1.3.0", 1172 | "json-schema": "0.2.3", 1173 | "verror": "1.10.0" 1174 | } 1175 | }, 1176 | "kind-of": { 1177 | "version": "1.1.0", 1178 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-1.1.0.tgz", 1179 | "integrity": "sha1-FAo9LUGjbS78+pN3tiwk+ElaXEQ=", 1180 | "dev": true 1181 | }, 1182 | "lazystream": { 1183 | "version": "1.0.0", 1184 | "resolved": "https://registry.npmjs.org/lazystream/-/lazystream-1.0.0.tgz", 1185 | "integrity": "sha1-9plf4PggOS9hOWvolGJAe7dxaOQ=", 1186 | "dev": true, 1187 | "requires": { 1188 | "readable-stream": "^2.0.5" 1189 | } 1190 | }, 1191 | "lodash.isequal": { 1192 | "version": "4.5.0", 1193 | "resolved": "https://registry.npmjs.org/lodash.isequal/-/lodash.isequal-4.5.0.tgz", 1194 | "integrity": "sha1-QVxEePK8wwEgwizhDtMib30+GOA=", 1195 | "dev": true 1196 | }, 1197 | "map-stream": { 1198 | "version": "0.1.0", 1199 | "resolved": "https://registry.npmjs.org/map-stream/-/map-stream-0.1.0.tgz", 1200 | "integrity": "sha1-5WqpTEyAVaFkBKBnS3jyFffI4ZQ=", 1201 | "dev": true 1202 | }, 1203 | "math-random": { 1204 | "version": "1.0.1", 1205 | "resolved": "https://registry.npmjs.org/math-random/-/math-random-1.0.1.tgz", 1206 | "integrity": "sha1-izqsWIuKZuSXXjzepn97sylgH6w=", 1207 | "dev": true 1208 | }, 1209 | "merge-stream": { 1210 | "version": "1.0.1", 1211 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-1.0.1.tgz", 1212 | "integrity": "sha1-QEEgLVCKNCugAXQAjfDCUbjBNeE=", 1213 | "dev": true, 1214 | "requires": { 1215 | "readable-stream": "^2.0.1" 1216 | } 1217 | }, 1218 | "micromatch": { 1219 | "version": "2.3.11", 1220 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", 1221 | "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", 1222 | "dev": true, 1223 | "requires": { 1224 | "arr-diff": "^2.0.0", 1225 | "array-unique": "^0.2.1", 1226 | "braces": "^1.8.2", 1227 | "expand-brackets": "^0.1.4", 1228 | "extglob": "^0.3.1", 1229 | "filename-regex": "^2.0.0", 1230 | "is-extglob": "^1.0.0", 1231 | "is-glob": "^2.0.1", 1232 | "kind-of": "^3.0.2", 1233 | "normalize-path": "^2.0.1", 1234 | "object.omit": "^2.0.0", 1235 | "parse-glob": "^3.0.4", 1236 | "regex-cache": "^0.4.2" 1237 | }, 1238 | "dependencies": { 1239 | "arr-diff": { 1240 | "version": "2.0.0", 1241 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", 1242 | "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", 1243 | "dev": true, 1244 | "requires": { 1245 | "arr-flatten": "^1.0.1" 1246 | } 1247 | }, 1248 | "is-extglob": { 1249 | "version": "1.0.0", 1250 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 1251 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 1252 | "dev": true 1253 | }, 1254 | "is-glob": { 1255 | "version": "2.0.1", 1256 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 1257 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 1258 | "dev": true, 1259 | "requires": { 1260 | "is-extglob": "^1.0.0" 1261 | } 1262 | }, 1263 | "kind-of": { 1264 | "version": "3.2.2", 1265 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1266 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1267 | "dev": true, 1268 | "requires": { 1269 | "is-buffer": "^1.1.5" 1270 | } 1271 | } 1272 | } 1273 | }, 1274 | "mime-db": { 1275 | "version": "1.35.0", 1276 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.35.0.tgz", 1277 | "integrity": "sha512-JWT/IcCTsB0Io3AhWUMjRqucrHSPsSf2xKLaRldJVULioggvkJvggZ3VXNNSRkCddE6D+BUI4HEIZIA2OjwIvg==", 1278 | "dev": true 1279 | }, 1280 | "mime-types": { 1281 | "version": "2.1.19", 1282 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.19.tgz", 1283 | "integrity": "sha512-P1tKYHVSZ6uFo26mtnve4HQFE3koh1UWVkp8YUC+ESBHe945xWSoXuHHiGarDqcEZ+whpCDnlNw5LON0kLo+sw==", 1284 | "dev": true, 1285 | "requires": { 1286 | "mime-db": "~1.35.0" 1287 | } 1288 | }, 1289 | "minimatch": { 1290 | "version": "3.0.4", 1291 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1292 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1293 | "dev": true, 1294 | "requires": { 1295 | "brace-expansion": "^1.1.7" 1296 | } 1297 | }, 1298 | "minimist": { 1299 | "version": "0.0.8", 1300 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1301 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1302 | "dev": true 1303 | }, 1304 | "mkdirp": { 1305 | "version": "0.5.1", 1306 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1307 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1308 | "dev": true, 1309 | "requires": { 1310 | "minimist": "0.0.8" 1311 | } 1312 | }, 1313 | "mocha": { 1314 | "version": "4.1.0", 1315 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-4.1.0.tgz", 1316 | "integrity": "sha512-0RVnjg1HJsXY2YFDoTNzcc1NKhYuXKRrBAG2gDygmJJA136Cs2QlRliZG1mA0ap7cuaT30mw16luAeln+4RiNA==", 1317 | "dev": true, 1318 | "requires": { 1319 | "browser-stdout": "1.3.0", 1320 | "commander": "2.11.0", 1321 | "debug": "3.1.0", 1322 | "diff": "3.3.1", 1323 | "escape-string-regexp": "1.0.5", 1324 | "glob": "7.1.2", 1325 | "growl": "1.10.3", 1326 | "he": "1.1.1", 1327 | "mkdirp": "0.5.1", 1328 | "supports-color": "4.4.0" 1329 | } 1330 | }, 1331 | "ms": { 1332 | "version": "2.0.0", 1333 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1334 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1335 | "dev": true 1336 | }, 1337 | "multimatch": { 1338 | "version": "2.1.0", 1339 | "resolved": "https://registry.npmjs.org/multimatch/-/multimatch-2.1.0.tgz", 1340 | "integrity": "sha1-nHkGoi+0wCkZ4vX3UWG0zb1LKis=", 1341 | "dev": true, 1342 | "requires": { 1343 | "array-differ": "^1.0.0", 1344 | "array-union": "^1.0.1", 1345 | "arrify": "^1.0.0", 1346 | "minimatch": "^3.0.0" 1347 | } 1348 | }, 1349 | "node.extend": { 1350 | "version": "1.1.6", 1351 | "resolved": "https://registry.npmjs.org/node.extend/-/node.extend-1.1.6.tgz", 1352 | "integrity": "sha1-p7iCyC1sk6SGOlUEvV3o7IYli5Y=", 1353 | "dev": true, 1354 | "requires": { 1355 | "is": "^3.1.0" 1356 | } 1357 | }, 1358 | "normalize-path": { 1359 | "version": "2.1.1", 1360 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 1361 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 1362 | "dev": true, 1363 | "requires": { 1364 | "remove-trailing-separator": "^1.0.1" 1365 | } 1366 | }, 1367 | "oauth-sign": { 1368 | "version": "0.8.2", 1369 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.8.2.tgz", 1370 | "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=", 1371 | "dev": true 1372 | }, 1373 | "object-assign": { 1374 | "version": "4.1.1", 1375 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1376 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1377 | "dev": true 1378 | }, 1379 | "object.omit": { 1380 | "version": "2.0.1", 1381 | "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz", 1382 | "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", 1383 | "dev": true, 1384 | "requires": { 1385 | "for-own": "^0.1.4", 1386 | "is-extendable": "^0.1.1" 1387 | } 1388 | }, 1389 | "once": { 1390 | "version": "1.4.0", 1391 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1392 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1393 | "dev": true, 1394 | "requires": { 1395 | "wrappy": "1" 1396 | } 1397 | }, 1398 | "ordered-read-streams": { 1399 | "version": "0.3.0", 1400 | "resolved": "https://registry.npmjs.org/ordered-read-streams/-/ordered-read-streams-0.3.0.tgz", 1401 | "integrity": "sha1-cTfmmzKYuzQiR6G77jiByA4v14s=", 1402 | "dev": true, 1403 | "requires": { 1404 | "is-stream": "^1.0.1", 1405 | "readable-stream": "^2.0.1" 1406 | } 1407 | }, 1408 | "parse-glob": { 1409 | "version": "3.0.4", 1410 | "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", 1411 | "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", 1412 | "dev": true, 1413 | "requires": { 1414 | "glob-base": "^0.3.0", 1415 | "is-dotfile": "^1.0.0", 1416 | "is-extglob": "^1.0.0", 1417 | "is-glob": "^2.0.0" 1418 | }, 1419 | "dependencies": { 1420 | "is-extglob": { 1421 | "version": "1.0.0", 1422 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 1423 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 1424 | "dev": true 1425 | }, 1426 | "is-glob": { 1427 | "version": "2.0.1", 1428 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 1429 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 1430 | "dev": true, 1431 | "requires": { 1432 | "is-extglob": "^1.0.0" 1433 | } 1434 | } 1435 | } 1436 | }, 1437 | "path-dirname": { 1438 | "version": "1.0.2", 1439 | "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", 1440 | "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", 1441 | "dev": true 1442 | }, 1443 | "path-is-absolute": { 1444 | "version": "1.0.1", 1445 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1446 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1447 | "dev": true 1448 | }, 1449 | "pause-stream": { 1450 | "version": "0.0.11", 1451 | "resolved": "https://registry.npmjs.org/pause-stream/-/pause-stream-0.0.11.tgz", 1452 | "integrity": "sha1-/lo0sMvOErWqaitAPuLnO2AvFEU=", 1453 | "dev": true, 1454 | "requires": { 1455 | "through": "~2.3" 1456 | } 1457 | }, 1458 | "pend": { 1459 | "version": "1.2.0", 1460 | "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", 1461 | "integrity": "sha1-elfrVQpng/kRUzH89GY9XI4AelA=", 1462 | "dev": true 1463 | }, 1464 | "performance-now": { 1465 | "version": "2.1.0", 1466 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 1467 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", 1468 | "dev": true 1469 | }, 1470 | "plugin-error": { 1471 | "version": "0.1.2", 1472 | "resolved": "https://registry.npmjs.org/plugin-error/-/plugin-error-0.1.2.tgz", 1473 | "integrity": "sha1-O5uzM1zPAPQl4HQ34ZJ2ln2kes4=", 1474 | "dev": true, 1475 | "requires": { 1476 | "ansi-cyan": "^0.1.1", 1477 | "ansi-red": "^0.1.1", 1478 | "arr-diff": "^1.0.1", 1479 | "arr-union": "^2.0.1", 1480 | "extend-shallow": "^1.1.2" 1481 | } 1482 | }, 1483 | "preserve": { 1484 | "version": "0.2.0", 1485 | "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", 1486 | "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", 1487 | "dev": true 1488 | }, 1489 | "process-nextick-args": { 1490 | "version": "2.0.0", 1491 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 1492 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", 1493 | "dev": true 1494 | }, 1495 | "punycode": { 1496 | "version": "1.4.1", 1497 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 1498 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", 1499 | "dev": true 1500 | }, 1501 | "qs": { 1502 | "version": "6.5.2", 1503 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 1504 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", 1505 | "dev": true 1506 | }, 1507 | "querystringify": { 1508 | "version": "2.0.0", 1509 | "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.0.0.tgz", 1510 | "integrity": "sha512-eTPo5t/4bgaMNZxyjWx6N2a6AuE0mq51KWvpc7nU/MAqixcI6v6KrGUKES0HaomdnolQBBXU/++X6/QQ9KL4tw==", 1511 | "dev": true 1512 | }, 1513 | "queue": { 1514 | "version": "3.1.0", 1515 | "resolved": "https://registry.npmjs.org/queue/-/queue-3.1.0.tgz", 1516 | "integrity": "sha1-bEnQHwCeIlZ4h4nyv/rGuLmZBYU=", 1517 | "dev": true, 1518 | "requires": { 1519 | "inherits": "~2.0.0" 1520 | } 1521 | }, 1522 | "randomatic": { 1523 | "version": "3.0.0", 1524 | "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-3.0.0.tgz", 1525 | "integrity": "sha512-VdxFOIEY3mNO5PtSRkkle/hPJDHvQhK21oa73K4yAc9qmp6N429gAyF1gZMOTMeS0/AYzaV/2Trcef+NaIonSA==", 1526 | "dev": true, 1527 | "requires": { 1528 | "is-number": "^4.0.0", 1529 | "kind-of": "^6.0.0", 1530 | "math-random": "^1.0.1" 1531 | }, 1532 | "dependencies": { 1533 | "is-number": { 1534 | "version": "4.0.0", 1535 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-4.0.0.tgz", 1536 | "integrity": "sha512-rSklcAIlf1OmFdyAqbnWTLVelsQ58uvZ66S/ZyawjWqIviTWCjg2PzVGw8WUA+nNuPTqb4wgA+NszrJ+08LlgQ==", 1537 | "dev": true 1538 | }, 1539 | "kind-of": { 1540 | "version": "6.0.2", 1541 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", 1542 | "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", 1543 | "dev": true 1544 | } 1545 | } 1546 | }, 1547 | "readable-stream": { 1548 | "version": "2.3.6", 1549 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 1550 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 1551 | "dev": true, 1552 | "requires": { 1553 | "core-util-is": "~1.0.0", 1554 | "inherits": "~2.0.3", 1555 | "isarray": "~1.0.0", 1556 | "process-nextick-args": "~2.0.0", 1557 | "safe-buffer": "~5.1.1", 1558 | "string_decoder": "~1.1.1", 1559 | "util-deprecate": "~1.0.1" 1560 | } 1561 | }, 1562 | "regex-cache": { 1563 | "version": "0.4.4", 1564 | "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.4.tgz", 1565 | "integrity": "sha512-nVIZwtCjkC9YgvWkpM55B5rBhBYRZhAaJbgcFYXXsHnbZ9UZI9nnVWYZpBlCqv9ho2eZryPnWrZGsOdPwVWXWQ==", 1566 | "dev": true, 1567 | "requires": { 1568 | "is-equal-shallow": "^0.1.3" 1569 | } 1570 | }, 1571 | "remove-trailing-separator": { 1572 | "version": "1.1.0", 1573 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 1574 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", 1575 | "dev": true 1576 | }, 1577 | "repeat-element": { 1578 | "version": "1.1.2", 1579 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.2.tgz", 1580 | "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=", 1581 | "dev": true 1582 | }, 1583 | "repeat-string": { 1584 | "version": "1.6.1", 1585 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 1586 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", 1587 | "dev": true 1588 | }, 1589 | "replace-ext": { 1590 | "version": "1.0.0", 1591 | "resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-1.0.0.tgz", 1592 | "integrity": "sha1-3mMSg3P8v3w8z6TeWkgMRaZ5WOs=", 1593 | "dev": true 1594 | }, 1595 | "request": { 1596 | "version": "2.87.0", 1597 | "resolved": "https://registry.npmjs.org/request/-/request-2.87.0.tgz", 1598 | "integrity": "sha512-fcogkm7Az5bsS6Sl0sibkbhcKsnyon/jV1kF3ajGmF0c8HrttdKTPRT9hieOaQHA5HEq6r8OyWOo/o781C1tNw==", 1599 | "dev": true, 1600 | "requires": { 1601 | "aws-sign2": "~0.7.0", 1602 | "aws4": "^1.6.0", 1603 | "caseless": "~0.12.0", 1604 | "combined-stream": "~1.0.5", 1605 | "extend": "~3.0.1", 1606 | "forever-agent": "~0.6.1", 1607 | "form-data": "~2.3.1", 1608 | "har-validator": "~5.0.3", 1609 | "http-signature": "~1.2.0", 1610 | "is-typedarray": "~1.0.0", 1611 | "isstream": "~0.1.2", 1612 | "json-stringify-safe": "~5.0.1", 1613 | "mime-types": "~2.1.17", 1614 | "oauth-sign": "~0.8.2", 1615 | "performance-now": "^2.1.0", 1616 | "qs": "~6.5.1", 1617 | "safe-buffer": "^5.1.1", 1618 | "tough-cookie": "~2.3.3", 1619 | "tunnel-agent": "^0.6.0", 1620 | "uuid": "^3.1.0" 1621 | } 1622 | }, 1623 | "requires-port": { 1624 | "version": "1.0.0", 1625 | "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", 1626 | "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=", 1627 | "dev": true 1628 | }, 1629 | "rimraf": { 1630 | "version": "2.6.2", 1631 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 1632 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 1633 | "dev": true, 1634 | "requires": { 1635 | "glob": "^7.0.5" 1636 | } 1637 | }, 1638 | "safe-buffer": { 1639 | "version": "5.1.2", 1640 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1641 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1642 | "dev": true 1643 | }, 1644 | "safer-buffer": { 1645 | "version": "2.1.2", 1646 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1647 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1648 | "dev": true 1649 | }, 1650 | "semver": { 1651 | "version": "5.5.0", 1652 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.0.tgz", 1653 | "integrity": "sha512-4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA==", 1654 | "dev": true 1655 | }, 1656 | "source-map": { 1657 | "version": "0.6.1", 1658 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1659 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1660 | "dev": true 1661 | }, 1662 | "source-map-support": { 1663 | "version": "0.5.6", 1664 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.6.tgz", 1665 | "integrity": "sha512-N4KXEz7jcKqPf2b2vZF11lQIz9W5ZMuUcIOGj243lduidkf2fjkVKJS9vNxVWn3u/uxX38AcE8U9nnH9FPcq+g==", 1666 | "dev": true, 1667 | "requires": { 1668 | "buffer-from": "^1.0.0", 1669 | "source-map": "^0.6.0" 1670 | } 1671 | }, 1672 | "split": { 1673 | "version": "0.3.3", 1674 | "resolved": "https://registry.npmjs.org/split/-/split-0.3.3.tgz", 1675 | "integrity": "sha1-zQ7qXmOiEd//frDwkcQTPi0N0o8=", 1676 | "dev": true, 1677 | "requires": { 1678 | "through": "2" 1679 | } 1680 | }, 1681 | "sshpk": { 1682 | "version": "1.14.2", 1683 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.14.2.tgz", 1684 | "integrity": "sha1-xvxhZIo9nE52T9P8306hBeSSupg=", 1685 | "dev": true, 1686 | "requires": { 1687 | "asn1": "~0.2.3", 1688 | "assert-plus": "^1.0.0", 1689 | "bcrypt-pbkdf": "^1.0.0", 1690 | "dashdash": "^1.12.0", 1691 | "ecc-jsbn": "~0.1.1", 1692 | "getpass": "^0.1.1", 1693 | "jsbn": "~0.1.0", 1694 | "safer-buffer": "^2.0.2", 1695 | "tweetnacl": "~0.14.0" 1696 | } 1697 | }, 1698 | "stat-mode": { 1699 | "version": "0.2.2", 1700 | "resolved": "https://registry.npmjs.org/stat-mode/-/stat-mode-0.2.2.tgz", 1701 | "integrity": "sha1-5sgLYjEj19gM8TLOU480YokHJQI=", 1702 | "dev": true 1703 | }, 1704 | "stream-combiner": { 1705 | "version": "0.0.4", 1706 | "resolved": "https://registry.npmjs.org/stream-combiner/-/stream-combiner-0.0.4.tgz", 1707 | "integrity": "sha1-TV5DPBhSYd3mI8o/RMWGvPXErRQ=", 1708 | "dev": true, 1709 | "requires": { 1710 | "duplexer": "~0.1.1" 1711 | } 1712 | }, 1713 | "stream-shift": { 1714 | "version": "1.0.0", 1715 | "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.0.tgz", 1716 | "integrity": "sha1-1cdSgl5TZ+eG944Y5EXqIjoVWVI=", 1717 | "dev": true 1718 | }, 1719 | "streamfilter": { 1720 | "version": "1.0.7", 1721 | "resolved": "https://registry.npmjs.org/streamfilter/-/streamfilter-1.0.7.tgz", 1722 | "integrity": "sha512-Gk6KZM+yNA1JpW0KzlZIhjo3EaBJDkYfXtYSbOwNIQ7Zd6006E6+sCFlW1NDvFG/vnXhKmw6TJJgiEQg/8lXfQ==", 1723 | "dev": true, 1724 | "requires": { 1725 | "readable-stream": "^2.0.2" 1726 | } 1727 | }, 1728 | "streamifier": { 1729 | "version": "0.1.1", 1730 | "resolved": "https://registry.npmjs.org/streamifier/-/streamifier-0.1.1.tgz", 1731 | "integrity": "sha1-l+mNj6TRBdYqJpHR3AfoINuN/E8=", 1732 | "dev": true 1733 | }, 1734 | "string_decoder": { 1735 | "version": "1.1.1", 1736 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1737 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1738 | "dev": true, 1739 | "requires": { 1740 | "safe-buffer": "~5.1.0" 1741 | } 1742 | }, 1743 | "strip-bom": { 1744 | "version": "2.0.0", 1745 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz", 1746 | "integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=", 1747 | "dev": true, 1748 | "requires": { 1749 | "is-utf8": "^0.2.0" 1750 | } 1751 | }, 1752 | "strip-bom-stream": { 1753 | "version": "1.0.0", 1754 | "resolved": "https://registry.npmjs.org/strip-bom-stream/-/strip-bom-stream-1.0.0.tgz", 1755 | "integrity": "sha1-5xRDmFd9Uaa+0PoZlPoF9D/ZiO4=", 1756 | "dev": true, 1757 | "requires": { 1758 | "first-chunk-stream": "^1.0.0", 1759 | "strip-bom": "^2.0.0" 1760 | } 1761 | }, 1762 | "supports-color": { 1763 | "version": "4.4.0", 1764 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.4.0.tgz", 1765 | "integrity": "sha512-rKC3+DyXWgK0ZLKwmRsrkyHVZAjNkfzeehuFWdGGcqGDTZFH73+RH6S/RDAAxl9GusSjZSUWYLmT9N5pzXFOXQ==", 1766 | "dev": true, 1767 | "requires": { 1768 | "has-flag": "^2.0.0" 1769 | } 1770 | }, 1771 | "tar": { 1772 | "version": "2.2.1", 1773 | "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.1.tgz", 1774 | "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=", 1775 | "dev": true, 1776 | "requires": { 1777 | "block-stream": "*", 1778 | "fstream": "^1.0.2", 1779 | "inherits": "2" 1780 | } 1781 | }, 1782 | "through": { 1783 | "version": "2.3.8", 1784 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1785 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1786 | "dev": true 1787 | }, 1788 | "through2": { 1789 | "version": "2.0.3", 1790 | "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.3.tgz", 1791 | "integrity": "sha1-AARWmzfHx0ujnEPzzteNGtlBQL4=", 1792 | "dev": true, 1793 | "requires": { 1794 | "readable-stream": "^2.1.5", 1795 | "xtend": "~4.0.1" 1796 | } 1797 | }, 1798 | "through2-filter": { 1799 | "version": "2.0.0", 1800 | "resolved": "https://registry.npmjs.org/through2-filter/-/through2-filter-2.0.0.tgz", 1801 | "integrity": "sha1-YLxVoNrLdghdsfna6Zq0P4PWIuw=", 1802 | "dev": true, 1803 | "requires": { 1804 | "through2": "~2.0.0", 1805 | "xtend": "~4.0.0" 1806 | } 1807 | }, 1808 | "to-absolute-glob": { 1809 | "version": "0.1.1", 1810 | "resolved": "https://registry.npmjs.org/to-absolute-glob/-/to-absolute-glob-0.1.1.tgz", 1811 | "integrity": "sha1-HN+kcqnvUMI57maZm2YsoOs5k38=", 1812 | "dev": true, 1813 | "requires": { 1814 | "extend-shallow": "^2.0.1" 1815 | }, 1816 | "dependencies": { 1817 | "extend-shallow": { 1818 | "version": "2.0.1", 1819 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 1820 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 1821 | "dev": true, 1822 | "requires": { 1823 | "is-extendable": "^0.1.0" 1824 | } 1825 | } 1826 | } 1827 | }, 1828 | "tough-cookie": { 1829 | "version": "2.3.4", 1830 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.4.tgz", 1831 | "integrity": "sha512-TZ6TTfI5NtZnuyy/Kecv+CnoROnyXn2DN97LontgQpCwsX2XyLYCC0ENhYkehSOwAp8rTQKc/NUIF7BkQ5rKLA==", 1832 | "dev": true, 1833 | "requires": { 1834 | "punycode": "^1.4.1" 1835 | } 1836 | }, 1837 | "tunnel-agent": { 1838 | "version": "0.6.0", 1839 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 1840 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 1841 | "dev": true, 1842 | "requires": { 1843 | "safe-buffer": "^5.0.1" 1844 | } 1845 | }, 1846 | "tweetnacl": { 1847 | "version": "0.14.5", 1848 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 1849 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 1850 | "dev": true, 1851 | "optional": true 1852 | }, 1853 | "typescript": { 1854 | "version": "2.9.2", 1855 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-2.9.2.tgz", 1856 | "integrity": "sha512-Gr4p6nFNaoufRIY4NMdpQRNmgxVIGMs4Fcu/ujdYk3nAZqk7supzBE9idmvfZIlH/Cuj//dvi+019qEue9lV0w==", 1857 | "dev": true 1858 | }, 1859 | "unique-stream": { 1860 | "version": "2.2.1", 1861 | "resolved": "https://registry.npmjs.org/unique-stream/-/unique-stream-2.2.1.tgz", 1862 | "integrity": "sha1-WqADz76Uxf+GbE59ZouxxNuts2k=", 1863 | "dev": true, 1864 | "requires": { 1865 | "json-stable-stringify": "^1.0.0", 1866 | "through2-filter": "^2.0.0" 1867 | } 1868 | }, 1869 | "url-parse": { 1870 | "version": "1.4.3", 1871 | "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.4.3.tgz", 1872 | "integrity": "sha512-rh+KuAW36YKo0vClhQzLLveoj8FwPJNu65xLb7Mrt+eZht0IPT0IXgSv8gcMegZ6NvjJUALf6Mf25POlMwD1Fw==", 1873 | "dev": true, 1874 | "requires": { 1875 | "querystringify": "^2.0.0", 1876 | "requires-port": "^1.0.0" 1877 | } 1878 | }, 1879 | "util-deprecate": { 1880 | "version": "1.0.2", 1881 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1882 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 1883 | "dev": true 1884 | }, 1885 | "uuid": { 1886 | "version": "3.3.2", 1887 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 1888 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==", 1889 | "dev": true 1890 | }, 1891 | "vali-date": { 1892 | "version": "1.0.0", 1893 | "resolved": "https://registry.npmjs.org/vali-date/-/vali-date-1.0.0.tgz", 1894 | "integrity": "sha1-G5BKWWCfsyjvB4E4Qgk09rhnCaY=", 1895 | "dev": true 1896 | }, 1897 | "verror": { 1898 | "version": "1.10.0", 1899 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 1900 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 1901 | "dev": true, 1902 | "requires": { 1903 | "assert-plus": "^1.0.0", 1904 | "core-util-is": "1.0.2", 1905 | "extsprintf": "^1.2.0" 1906 | } 1907 | }, 1908 | "vinyl": { 1909 | "version": "0.4.6", 1910 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-0.4.6.tgz", 1911 | "integrity": "sha1-LzVsh6VQolVGHza76ypbqL94SEc=", 1912 | "dev": true, 1913 | "requires": { 1914 | "clone": "^0.2.0", 1915 | "clone-stats": "^0.0.1" 1916 | } 1917 | }, 1918 | "vinyl-fs": { 1919 | "version": "2.4.4", 1920 | "resolved": "https://registry.npmjs.org/vinyl-fs/-/vinyl-fs-2.4.4.tgz", 1921 | "integrity": "sha1-vm/zJwy1Xf19MGNkDegfJddTIjk=", 1922 | "dev": true, 1923 | "requires": { 1924 | "duplexify": "^3.2.0", 1925 | "glob-stream": "^5.3.2", 1926 | "graceful-fs": "^4.0.0", 1927 | "gulp-sourcemaps": "1.6.0", 1928 | "is-valid-glob": "^0.3.0", 1929 | "lazystream": "^1.0.0", 1930 | "lodash.isequal": "^4.0.0", 1931 | "merge-stream": "^1.0.0", 1932 | "mkdirp": "^0.5.0", 1933 | "object-assign": "^4.0.0", 1934 | "readable-stream": "^2.0.4", 1935 | "strip-bom": "^2.0.0", 1936 | "strip-bom-stream": "^1.0.0", 1937 | "through2": "^2.0.0", 1938 | "through2-filter": "^2.0.0", 1939 | "vali-date": "^1.0.0", 1940 | "vinyl": "^1.0.0" 1941 | }, 1942 | "dependencies": { 1943 | "clone": { 1944 | "version": "1.0.4", 1945 | "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", 1946 | "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", 1947 | "dev": true 1948 | }, 1949 | "replace-ext": { 1950 | "version": "0.0.1", 1951 | "resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-0.0.1.tgz", 1952 | "integrity": "sha1-KbvZIHinOfC8zitO5B6DeVNSKSQ=", 1953 | "dev": true 1954 | }, 1955 | "vinyl": { 1956 | "version": "1.2.0", 1957 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-1.2.0.tgz", 1958 | "integrity": "sha1-XIgDbPVl5d8FVYv8kR+GVt8hiIQ=", 1959 | "dev": true, 1960 | "requires": { 1961 | "clone": "^1.0.0", 1962 | "clone-stats": "^0.0.1", 1963 | "replace-ext": "0.0.1" 1964 | } 1965 | } 1966 | } 1967 | }, 1968 | "vinyl-source-stream": { 1969 | "version": "1.1.2", 1970 | "resolved": "https://registry.npmjs.org/vinyl-source-stream/-/vinyl-source-stream-1.1.2.tgz", 1971 | "integrity": "sha1-YrU6E1YQqJbpjKlr7jqH8Aio54A=", 1972 | "dev": true, 1973 | "requires": { 1974 | "through2": "^2.0.3", 1975 | "vinyl": "^0.4.3" 1976 | } 1977 | }, 1978 | "vscode": { 1979 | "version": "1.1.18", 1980 | "resolved": "https://registry.npmjs.org/vscode/-/vscode-1.1.18.tgz", 1981 | "integrity": "sha512-SyDw4qFwZ+WthZX7RWp71PNiWLF7VhpM65j2oryY/6jtSORd8qH6J8vclwWZJ6Jvu0EH7JamO2RWNfBfsMR9Zw==", 1982 | "dev": true, 1983 | "requires": { 1984 | "glob": "^7.1.2", 1985 | "gulp-chmod": "^2.0.0", 1986 | "gulp-filter": "^5.0.1", 1987 | "gulp-gunzip": "1.0.0", 1988 | "gulp-remote-src-vscode": "^0.5.0", 1989 | "gulp-symdest": "^1.1.0", 1990 | "gulp-untar": "^0.0.7", 1991 | "gulp-vinyl-zip": "^2.1.0", 1992 | "mocha": "^4.0.1", 1993 | "request": "^2.83.0", 1994 | "semver": "^5.4.1", 1995 | "source-map-support": "^0.5.0", 1996 | "url-parse": "^1.1.9", 1997 | "vinyl-source-stream": "^1.1.0" 1998 | } 1999 | }, 2000 | "vscode-jsonrpc": { 2001 | "version": "3.6.2", 2002 | "resolved": "https://registry.npmjs.org/vscode-jsonrpc/-/vscode-jsonrpc-3.6.2.tgz", 2003 | "integrity": "sha512-T24Jb5V48e4VgYliUXMnZ379ItbrXgOimweKaJshD84z+8q7ZOZjJan0MeDe+Ugb+uqERDVV8SBmemaGMSMugA==" 2004 | }, 2005 | "vscode-languageclient": { 2006 | "version": "3.3.0", 2007 | "resolved": "https://registry.npmjs.org/vscode-languageclient/-/vscode-languageclient-3.3.0.tgz", 2008 | "integrity": "sha512-4HVt0GorAV7lJfoT2C6qh/Fug9u/HSmKUa8u+y+Pte0HqvUtOwTI8qlX1vu8vyQ5OHD8t8pJad/9yIbYntwxCw==", 2009 | "requires": { 2010 | "vscode-jsonrpc": "^3.3.0", 2011 | "vscode-languageserver-types": "^3.3.0" 2012 | } 2013 | }, 2014 | "vscode-languageserver-types": { 2015 | "version": "3.10.0", 2016 | "resolved": "https://registry.npmjs.org/vscode-languageserver-types/-/vscode-languageserver-types-3.10.0.tgz", 2017 | "integrity": "sha512-vxmCsVZGwq8X40SuLP8Ix7V0rq5V/7iQUjRVe2Oxm+TbmjxtjK4dpHHXQCUawjA4fhPA9FwjSRbDhbvQmYCfMw==" 2018 | }, 2019 | "wrappy": { 2020 | "version": "1.0.2", 2021 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2022 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2023 | "dev": true 2024 | }, 2025 | "xtend": { 2026 | "version": "4.0.1", 2027 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 2028 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=", 2029 | "dev": true 2030 | }, 2031 | "yauzl": { 2032 | "version": "2.10.0", 2033 | "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz", 2034 | "integrity": "sha1-x+sXyT4RLLEIb6bY5R+wZnt5pfk=", 2035 | "dev": true, 2036 | "requires": { 2037 | "buffer-crc32": "~0.2.3", 2038 | "fd-slicer": "~1.1.0" 2039 | } 2040 | }, 2041 | "yazl": { 2042 | "version": "2.4.3", 2043 | "resolved": "https://registry.npmjs.org/yazl/-/yazl-2.4.3.tgz", 2044 | "integrity": "sha1-7CblzIfVYBud+EMtvdPNLlFzoHE=", 2045 | "dev": true, 2046 | "requires": { 2047 | "buffer-crc32": "~0.2.3" 2048 | } 2049 | } 2050 | } 2051 | } 2052 | -------------------------------------------------------------------------------- /client/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "language-client-example", 3 | "description": "VSCode part of a language server", 4 | "author": "Microsoft Corporation", 5 | "license": "MIT", 6 | "version": "0.0.1", 7 | "publisher": "vscode", 8 | "engines": { 9 | "vscode": "^1.8.0" 10 | }, 11 | "categories": [ 12 | "Other" 13 | ], 14 | "activationEvents": [ 15 | "onLanguage:plaintext" 16 | ], 17 | "main": "./out/src/extension", 18 | "contributes": { 19 | "configuration": { 20 | "type": "object", 21 | "title": "Example configuration", 22 | "properties": { 23 | "languageServerExample.maxNumberOfProblems": { 24 | "type": "number", 25 | "default": 100, 26 | "description": "Controls the maximum number of problems produced by the server." 27 | }, 28 | "languageServerExample.trace.server": { 29 | "type": "string", 30 | "enum": [ 31 | "off", 32 | "messages", 33 | "verbose" 34 | ], 35 | "default": "off", 36 | "description": "Traces the communication between VSCode and the languageServerExample service." 37 | } 38 | } 39 | } 40 | }, 41 | "scripts": { 42 | "vscode:prepublish": "tsc -p ./", 43 | "compile": "tsc -watch -p ./", 44 | "update-vscode": "node ./node_modules/vscode/bin/install", 45 | "postinstall": "node ./node_modules/vscode/bin/install" 46 | }, 47 | "devDependencies": { 48 | "@types/mocha": "^2.2.33", 49 | "@types/node": "^6.0.52", 50 | "typescript": "^2.1.5", 51 | "vscode": "^1.1.18" 52 | }, 53 | "dependencies": { 54 | "vscode-languageclient": "~3.3.0" 55 | } 56 | } 57 | -------------------------------------------------------------------------------- /client/src/extension.ts: -------------------------------------------------------------------------------- 1 | /* -------------------------------------------------------------------------------------------- 2 | * Copyright (c) Microsoft Corporation. All rights reserved. 3 | * Licensed under the MIT License. See License.txt in the project root for license information. 4 | * ------------------------------------------------------------------------------------------ */ 5 | 'use strict'; 6 | 7 | import * as path from 'path'; 8 | import * as os from 'os'; 9 | import { workspace, ExtensionContext } from 'vscode'; 10 | 11 | import { 12 | LanguageClient, 13 | LanguageClientOptions, 14 | ServerOptions, 15 | ExecutableOptions, 16 | Executable 17 | } from 'vscode-languageclient'; 18 | 19 | let client: LanguageClient; 20 | 21 | export function activate(context: ExtensionContext) { 22 | 23 | // The server is implemented in C# 24 | let serverCommand = context.asAbsolutePath(path.join('server', 'SampleServer.exe')); 25 | let commandOptions: ExecutableOptions = { stdio: 'pipe', detached: false }; 26 | 27 | // If the extension is launched in debug mode then the debug server options are used 28 | // Otherwise the run options are used 29 | let serverOptions: ServerOptions = 30 | (os.platform() === 'win32') ? { 31 | run : { command: serverCommand, options: commandOptions }, 32 | debug: { command: serverCommand, options: commandOptions } 33 | } : { 34 | run : { command: 'mono', args: [serverCommand], options: commandOptions }, 35 | debug: { command: 'mono', args: [serverCommand], options: commandOptions } 36 | }; 37 | 38 | // Options to control the language client 39 | let clientOptions: LanguageClientOptions = { 40 | // Register the server for plain text documents 41 | documentSelector: ['plaintext'], 42 | synchronize: { 43 | // Synchronize the setting section 'languageServerExample' to the server 44 | configurationSection: 'languageServerExample', 45 | // Notify the server about file changes to '.clientrc files contain in the workspace 46 | fileEvents: workspace.createFileSystemWatcher('**/.clientrc') 47 | } 48 | }; 49 | 50 | // Create the language client and start the client. 51 | client = new LanguageClient( 52 | 'languageServerExample', 53 | 'Language Server Example', 54 | serverOptions, 55 | clientOptions 56 | ); 57 | 58 | // Start the client. This will also launch the server 59 | client.start(); 60 | } 61 | 62 | export function deactivate(): Thenable { 63 | if (!client) { 64 | return undefined; 65 | } 66 | return client.stop(); 67 | } 68 | -------------------------------------------------------------------------------- /client/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 | }); -------------------------------------------------------------------------------- /client/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; -------------------------------------------------------------------------------- /client/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es6", 4 | "module": "commonjs", 5 | "moduleResolution": "node", 6 | "outDir": "out", 7 | "lib": [ "es2016" ], 8 | "sourceMap": true 9 | }, 10 | "exclude": [ 11 | "node_modules", 12 | "server" 13 | ] 14 | } -------------------------------------------------------------------------------- /server/.gitignore: -------------------------------------------------------------------------------- 1 | ## Ignore Visual Studio temporary files, build results, and 2 | ## files generated by popular Visual Studio add-ons. 3 | ## 4 | ## Get latest from https://github.com/github/gitignore/blob/master/VisualStudio.gitignore 5 | 6 | # User-specific files 7 | *.suo 8 | *.user 9 | *.userosscache 10 | *.sln.docstates 11 | 12 | # User-specific files (MonoDevelop/Xamarin Studio) 13 | *.userprefs 14 | 15 | # Build results 16 | [Dd]ebug/ 17 | [Dd]ebugPublic/ 18 | [Rr]elease/ 19 | [Rr]eleases/ 20 | x64/ 21 | x86/ 22 | bld/ 23 | [Bb]in/ 24 | [Oo]bj/ 25 | [Ll]og/ 26 | 27 | # Visual Studio 2015 cache/options directory 28 | .vs/ 29 | # Uncomment if you have tasks that create the project's static files in wwwroot 30 | #wwwroot/ 31 | 32 | # MSTest test Results 33 | [Tt]est[Rr]esult*/ 34 | [Bb]uild[Ll]og.* 35 | 36 | # NUNIT 37 | *.VisualState.xml 38 | TestResult.xml 39 | 40 | # Build Results of an ATL Project 41 | [Dd]ebugPS/ 42 | [Rr]eleasePS/ 43 | dlldata.c 44 | 45 | # .NET Core 46 | project.lock.json 47 | project.fragment.lock.json 48 | artifacts/ 49 | **/Properties/launchSettings.json 50 | 51 | *_i.c 52 | *_p.c 53 | *_i.h 54 | *.ilk 55 | *.meta 56 | *.obj 57 | *.pch 58 | *.pdb 59 | *.pgc 60 | *.pgd 61 | *.rsp 62 | *.sbr 63 | *.tlb 64 | *.tli 65 | *.tlh 66 | *.tmp 67 | *.tmp_proj 68 | *.log 69 | *.vspscc 70 | *.vssscc 71 | .builds 72 | *.pidb 73 | *.svclog 74 | *.scc 75 | 76 | # Chutzpah Test files 77 | _Chutzpah* 78 | 79 | # Visual C++ cache files 80 | ipch/ 81 | *.aps 82 | *.ncb 83 | *.opendb 84 | *.opensdf 85 | *.sdf 86 | *.cachefile 87 | *.VC.db 88 | *.VC.VC.opendb 89 | 90 | # Visual Studio profiler 91 | *.psess 92 | *.vsp 93 | *.vspx 94 | *.sap 95 | 96 | # TFS 2012 Local Workspace 97 | $tf/ 98 | 99 | # Guidance Automation Toolkit 100 | *.gpState 101 | 102 | # ReSharper is a .NET coding add-in 103 | _ReSharper*/ 104 | *.[Rr]e[Ss]harper 105 | *.DotSettings.user 106 | 107 | # JustCode is a .NET coding add-in 108 | .JustCode 109 | 110 | # TeamCity is a build add-in 111 | _TeamCity* 112 | 113 | # DotCover is a Code Coverage Tool 114 | *.dotCover 115 | 116 | # Visual Studio code coverage results 117 | *.coverage 118 | *.coveragexml 119 | 120 | # NCrunch 121 | _NCrunch_* 122 | .*crunch*.local.xml 123 | nCrunchTemp_* 124 | 125 | # MightyMoose 126 | *.mm.* 127 | AutoTest.Net/ 128 | 129 | # Web workbench (sass) 130 | .sass-cache/ 131 | 132 | # Installshield output folder 133 | [Ee]xpress/ 134 | 135 | # DocProject is a documentation generator add-in 136 | DocProject/buildhelp/ 137 | DocProject/Help/*.HxT 138 | DocProject/Help/*.HxC 139 | DocProject/Help/*.hhc 140 | DocProject/Help/*.hhk 141 | DocProject/Help/*.hhp 142 | DocProject/Help/Html2 143 | DocProject/Help/html 144 | 145 | # Click-Once directory 146 | publish/ 147 | 148 | # Publish Web Output 149 | *.[Pp]ublish.xml 150 | *.azurePubxml 151 | # TODO: Comment the next line if you want to checkin your web deploy settings 152 | # but database connection strings (with potential passwords) will be unencrypted 153 | *.pubxml 154 | *.publishproj 155 | 156 | # Microsoft Azure Web App publish settings. Comment the next line if you want to 157 | # checkin your Azure Web App publish settings, but sensitive information contained 158 | # in these scripts will be unencrypted 159 | PublishScripts/ 160 | 161 | # NuGet Packages 162 | *.nupkg 163 | # The packages folder can be ignored because of Package Restore 164 | **/packages/* 165 | # except build/, which is used as an MSBuild target. 166 | !**/packages/build/ 167 | # Uncomment if necessary however generally it will be regenerated when needed 168 | #!**/packages/repositories.config 169 | # NuGet v3's project.json files produces more ignorable files 170 | *.nuget.props 171 | *.nuget.targets 172 | 173 | # Microsoft Azure Build Output 174 | csx/ 175 | *.build.csdef 176 | 177 | # Microsoft Azure Emulator 178 | ecf/ 179 | rcf/ 180 | 181 | # Windows Store app package directories and files 182 | AppPackages/ 183 | BundleArtifacts/ 184 | Package.StoreAssociation.xml 185 | _pkginfo.txt 186 | 187 | # Visual Studio cache files 188 | # files ending in .cache can be ignored 189 | *.[Cc]ache 190 | # but keep track of directories ending in .cache 191 | !*.[Cc]ache/ 192 | 193 | # Others 194 | ClientBin/ 195 | ~$* 196 | *~ 197 | *.dbmdl 198 | *.dbproj.schemaview 199 | *.jfm 200 | *.pfx 201 | *.publishsettings 202 | orleans.codegen.cs 203 | 204 | # Since there are multiple workflows, uncomment next line to ignore bower_components 205 | # (https://github.com/github/gitignore/pull/1529#issuecomment-104372622) 206 | #bower_components/ 207 | 208 | # RIA/Silverlight projects 209 | Generated_Code/ 210 | 211 | # Backup & report files from converting an old project file 212 | # to a newer Visual Studio version. Backup files are not needed, 213 | # because we have git ;-) 214 | _UpgradeReport_Files/ 215 | Backup*/ 216 | UpgradeLog*.XML 217 | UpgradeLog*.htm 218 | 219 | # SQL Server files 220 | *.mdf 221 | *.ldf 222 | *.ndf 223 | 224 | # Business Intelligence projects 225 | *.rdl.data 226 | *.bim.layout 227 | *.bim_*.settings 228 | 229 | # Microsoft Fakes 230 | FakesAssemblies/ 231 | 232 | # GhostDoc plugin setting file 233 | *.GhostDoc.xml 234 | 235 | # Node.js Tools for Visual Studio 236 | .ntvs_analysis.dat 237 | node_modules/ 238 | 239 | # Typescript v1 declaration files 240 | typings/ 241 | 242 | # Visual Studio 6 build log 243 | *.plg 244 | 245 | # Visual Studio 6 workspace options file 246 | *.opt 247 | 248 | # Visual Studio 6 auto-generated workspace file (contains which files were open etc.) 249 | *.vbw 250 | 251 | # Visual Studio LightSwitch build output 252 | **/*.HTMLClient/GeneratedArtifacts 253 | **/*.DesktopClient/GeneratedArtifacts 254 | **/*.DesktopClient/ModelManifest.xml 255 | **/*.Server/GeneratedArtifacts 256 | **/*.Server/ModelManifest.xml 257 | _Pvt_Extensions 258 | 259 | # Paket dependency manager 260 | .paket/paket.exe 261 | paket-files/ 262 | 263 | # FAKE - F# Make 264 | .fake/ 265 | 266 | # JetBrains Rider 267 | .idea/ 268 | *.sln.iml 269 | 270 | # CodeRush 271 | .cr/ 272 | 273 | # Python Tools for Visual Studio (PTVS) 274 | __pycache__/ 275 | *.pyc 276 | 277 | # Cake - Uncomment if you are using it 278 | # tools/** 279 | # !tools/packages.config 280 | 281 | # Telerik's JustMock configuration file 282 | *.jmconfig 283 | 284 | # BizTalk build output 285 | *.btp.cs 286 | *.btm.cs 287 | *.odx.cs 288 | *.xsd.cs 289 | -------------------------------------------------------------------------------- /server/README.md: -------------------------------------------------------------------------------- 1 | #README 2 | 3 | This is a language server sample implementation in C# -------------------------------------------------------------------------------- /server/SampleServer.sln: -------------------------------------------------------------------------------- 1 |  2 | Microsoft Visual Studio Solution File, Format Version 12.00 3 | # Visual Studio 15 4 | VisualStudioVersion = 15.0.26430.12 5 | MinimumVisualStudioVersion = 10.0.40219.1 6 | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "SampleServer", "SampleServer\SampleServer.csproj", "{EC7EAA0A-E2C3-4ECC-99C3-A9F684529D6D}" 7 | EndProject 8 | Global 9 | GlobalSection(SolutionConfigurationPlatforms) = preSolution 10 | Debug|Any CPU = Debug|Any CPU 11 | Release|Any CPU = Release|Any CPU 12 | EndGlobalSection 13 | GlobalSection(ProjectConfigurationPlatforms) = postSolution 14 | {EC7EAA0A-E2C3-4ECC-99C3-A9F684529D6D}.Debug|Any CPU.ActiveCfg = Debug|Any CPU 15 | {EC7EAA0A-E2C3-4ECC-99C3-A9F684529D6D}.Debug|Any CPU.Build.0 = Debug|Any CPU 16 | {EC7EAA0A-E2C3-4ECC-99C3-A9F684529D6D}.Release|Any CPU.ActiveCfg = Release|Any CPU 17 | {EC7EAA0A-E2C3-4ECC-99C3-A9F684529D6D}.Release|Any CPU.Build.0 = Release|Any CPU 18 | EndGlobalSection 19 | GlobalSection(SolutionProperties) = preSolution 20 | HideSolutionNode = FALSE 21 | EndGlobalSection 22 | EndGlobal 23 | -------------------------------------------------------------------------------- /server/SampleServer/App.config: -------------------------------------------------------------------------------- 1 |  2 | 3 | 4 | 5 | 6 | -------------------------------------------------------------------------------- /server/SampleServer/App.cs: -------------------------------------------------------------------------------- 1 | using LanguageServer; 2 | using LanguageServer.Client; 3 | using LanguageServer.Parameters; 4 | using LanguageServer.Parameters.General; 5 | using LanguageServer.Parameters.TextDocument; 6 | using LanguageServer.Parameters.Workspace; 7 | using System; 8 | using System.Collections.Generic; 9 | using System.IO; 10 | using System.Threading.Tasks; 11 | 12 | namespace SampleServer 13 | { 14 | public class App : ServiceConnection 15 | { 16 | private Uri _workerSpaceRoot; 17 | private int _maxNumberOfProblems = 1000; 18 | private TextDocumentManager _documents; 19 | 20 | public App(Stream input, Stream output) 21 | : base(input, output) 22 | { 23 | _documents = new TextDocumentManager(); 24 | _documents.Changed += Documents_Changed; 25 | } 26 | 27 | private void Documents_Changed(object sender, TextDocumentChangedEventArgs e) 28 | { 29 | ValidateTextDocument(e.Document); 30 | } 31 | 32 | protected override Result> Initialize(InitializeParams @params) 33 | { 34 | _workerSpaceRoot = @params.rootUri; 35 | var result = new InitializeResult 36 | { 37 | capabilities = new ServerCapabilities 38 | { 39 | textDocumentSync = TextDocumentSyncKind.Full, 40 | completionProvider = new CompletionOptions 41 | { 42 | resolveProvider = true 43 | } 44 | } 45 | }; 46 | return Result>.Success(result); 47 | } 48 | 49 | protected override void DidOpenTextDocument(DidOpenTextDocumentParams @params) 50 | { 51 | _documents.Add(@params.textDocument); 52 | Logger.Instance.Log($"{@params.textDocument.uri} opened."); 53 | } 54 | 55 | protected override void DidChangeTextDocument(DidChangeTextDocumentParams @params) 56 | { 57 | _documents.Change(@params.textDocument.uri, @params.textDocument.version, @params.contentChanges); 58 | Logger.Instance.Log($"{@params.textDocument.uri} changed."); 59 | } 60 | 61 | protected override void DidCloseTextDocument(DidCloseTextDocumentParams @params) 62 | { 63 | _documents.Remove(@params.textDocument.uri); 64 | Logger.Instance.Log($"{@params.textDocument.uri} closed."); 65 | } 66 | 67 | protected override void DidChangeConfiguration(DidChangeConfigurationParams @params) 68 | { 69 | _maxNumberOfProblems = @params?.settings?.languageServerExample?.maxNumberOfProblems ?? _maxNumberOfProblems; 70 | Logger.Instance.Log($"maxNumberOfProblems is set to {_maxNumberOfProblems}."); 71 | foreach (var document in _documents.All) 72 | { 73 | ValidateTextDocument(document); 74 | } 75 | } 76 | 77 | private void ValidateTextDocument(TextDocumentItem document) 78 | { 79 | var diagnostics = new List(); 80 | var lines = document.text.Split(new[] { "\r\n", "\n" }, StringSplitOptions.None); 81 | var problems = 0; 82 | for (var i = 0; i < lines.Length && problems < _maxNumberOfProblems; i++) 83 | { 84 | var line = lines[i]; 85 | var index = line.IndexOf("typescript"); 86 | if (index >= 0) 87 | { 88 | problems++; 89 | diagnostics.Add(new Diagnostic 90 | { 91 | severity = DiagnosticSeverity.Warning, 92 | range = new Range 93 | { 94 | start = new Position { line = i, character = index }, 95 | end = new Position { line = i, character = index + 10 } 96 | }, 97 | message = $"{line.Substring(index, 10)} should be spelled TypeScript", 98 | source = "ex" 99 | }); 100 | } 101 | } 102 | 103 | Proxy.TextDocument.PublishDiagnostics(new PublishDiagnosticsParams 104 | { 105 | uri = document.uri, 106 | diagnostics = diagnostics.ToArray() 107 | }); 108 | } 109 | 110 | protected override void DidChangeWatchedFiles(DidChangeWatchedFilesParams @params) 111 | { 112 | Logger.Instance.Log("We received an file change event"); 113 | } 114 | 115 | protected override Result Completion(CompletionParams @params) 116 | { 117 | var array = new[] 118 | { 119 | new CompletionItem 120 | { 121 | label = "TypeScript", 122 | kind = CompletionItemKind.Text, 123 | data = 1 124 | }, 125 | new CompletionItem 126 | { 127 | label = "JavaScript", 128 | kind = CompletionItemKind.Text, 129 | data = 2 130 | } 131 | }; 132 | return Result.Success(array); 133 | } 134 | 135 | protected override Result ResolveCompletionItem(CompletionItem @params) 136 | { 137 | if (@params.data == 1) 138 | { 139 | @params.detail = "TypeScript details"; 140 | @params.documentation = "TypeScript documentation"; 141 | } 142 | else if (@params.data == 2) 143 | { 144 | @params.detail = "JavaScript details"; 145 | @params.documentation = "JavaScript documentation"; 146 | } 147 | return Result.Success(@params); 148 | } 149 | 150 | protected override VoidResult Shutdown() 151 | { 152 | Logger.Instance.Log("Language Server is about to shutdown."); 153 | // WORKAROUND: Language Server does not receive an exit notification. 154 | Task.Delay(1000).ContinueWith(_ => Environment.Exit(0)); 155 | return VoidResult.Success(); 156 | } 157 | } 158 | } 159 | -------------------------------------------------------------------------------- /server/SampleServer/Logger.cs: -------------------------------------------------------------------------------- 1 | using LanguageServer; 2 | using LanguageServer.Client; 3 | using LanguageServer.Parameters.Window; 4 | 5 | namespace SampleServer 6 | { 7 | public class Logger 8 | { 9 | public static Logger Instance { get; } = new Logger(); 10 | 11 | private Proxy _proxy; 12 | 13 | public void Attach(Connection connection) 14 | { 15 | if (connection == null) 16 | { 17 | _proxy = null; 18 | } 19 | else 20 | { 21 | _proxy = new Proxy(connection); 22 | } 23 | } 24 | 25 | public void Error(string message) => Send(MessageType.Error, message); 26 | public void Warn(string message) => Send(MessageType.Warning, message); 27 | public void Info(string message) => Send(MessageType.Info, message); 28 | public void Log(string message) => Send(MessageType.Log, message); 29 | 30 | private void Send(MessageType type, string message) 31 | { 32 | this._proxy?.Window.LogMessage(new LogMessageParams 33 | { 34 | type = type, 35 | message = message 36 | }); 37 | } 38 | } 39 | } 40 | -------------------------------------------------------------------------------- /server/SampleServer/Program.cs: -------------------------------------------------------------------------------- 1 | using LanguageServer.Infrastructure.JsonDotNet; 2 | using LanguageServer.Json; 3 | using System; 4 | using System.Collections.Generic; 5 | using System.IO; 6 | using System.Linq; 7 | using System.Text; 8 | using System.Threading.Tasks; 9 | 10 | namespace SampleServer 11 | { 12 | class Program 13 | { 14 | static void Main(string[] args) 15 | { 16 | Console.OutputEncoding = new UTF8Encoding(); // UTF8N for non-Windows platform 17 | var app = new App(Console.OpenStandardInput(), Console.OpenStandardOutput()); 18 | Logger.Instance.Attach(app); 19 | try 20 | { 21 | app.Listen().Wait(); 22 | } 23 | catch (AggregateException ex) 24 | { 25 | Console.Error.WriteLine(ex.InnerExceptions[0]); 26 | Environment.Exit(-1); 27 | } 28 | } 29 | } 30 | } 31 | -------------------------------------------------------------------------------- /server/SampleServer/Properties/AssemblyInfo.cs: -------------------------------------------------------------------------------- 1 | using System.Reflection; 2 | using System.Runtime.CompilerServices; 3 | using System.Runtime.InteropServices; 4 | 5 | // アセンブリに関する一般情報は以下の属性セットをとおして制御されます。 6 | // アセンブリに関連付けられている情報を変更するには、 7 | // これらの属性値を変更してください。 8 | [assembly: AssemblyTitle("SampleServer")] 9 | [assembly: AssemblyDescription("")] 10 | [assembly: AssemblyConfiguration("")] 11 | [assembly: AssemblyCompany("")] 12 | [assembly: AssemblyProduct("SampleServer")] 13 | [assembly: AssemblyCopyright("Copyright © 2017")] 14 | [assembly: AssemblyTrademark("")] 15 | [assembly: AssemblyCulture("")] 16 | 17 | // ComVisible を false に設定すると、このアセンブリ内の型は COM コンポーネントから 18 | // 参照できなくなります。COM からこのアセンブリ内の型にアクセスする必要がある場合は、 19 | // その型の ComVisible 属性を true に設定してください。 20 | [assembly: ComVisible(false)] 21 | 22 | // このプロジェクトが COM に公開される場合、次の GUID が typelib の ID になります 23 | [assembly: Guid("ec7eaa0a-e2c3-4ecc-99c3-a9f684529d6d")] 24 | 25 | // アセンブリのバージョン情報は次の 4 つの値で構成されています: 26 | // 27 | // メジャー バージョン 28 | // マイナー バージョン 29 | // ビルド番号 30 | // Revision 31 | // 32 | // すべての値を指定するか、次を使用してビルド番号とリビジョン番号を既定に設定できます 33 | // 既定値にすることができます: 34 | // [assembly: AssemblyVersion("1.0.*")] 35 | [assembly: AssemblyVersion("1.0.0.0")] 36 | [assembly: AssemblyFileVersion("1.0.0.0")] 37 | -------------------------------------------------------------------------------- /server/SampleServer/SampleServer.csproj: -------------------------------------------------------------------------------- 1 |  2 | 3 | 4 | 5 | Debug 6 | AnyCPU 7 | {EC7EAA0A-E2C3-4ECC-99C3-A9F684529D6D} 8 | Exe 9 | SampleServer 10 | SampleServer 11 | v4.6.2 12 | 512 13 | true 14 | 15 | 16 | AnyCPU 17 | true 18 | full 19 | false 20 | ..\..\client\server\ 21 | DEBUG;TRACE 22 | prompt 23 | 4 24 | 25 | 26 | AnyCPU 27 | pdbonly 28 | true 29 | ..\..\client\server\ 30 | TRACE 31 | prompt 32 | 4 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 7.0.0 57 | 58 | 59 | 4.3.0 60 | 61 | 62 | 63 | -------------------------------------------------------------------------------- /server/SampleServer/TextDocumentChangedEventArgs.cs: -------------------------------------------------------------------------------- 1 | using LanguageServer.Parameters.TextDocument; 2 | using System; 3 | using System.Collections.Generic; 4 | using System.Linq; 5 | using System.Text; 6 | using System.Threading.Tasks; 7 | 8 | namespace SampleServer 9 | { 10 | public class TextDocumentChangedEventArgs : EventArgs 11 | { 12 | private readonly TextDocumentItem _document; 13 | 14 | public TextDocumentChangedEventArgs(TextDocumentItem document) 15 | { 16 | _document = document; 17 | } 18 | 19 | public TextDocumentItem Document => _document; 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /server/SampleServer/TextDocumentManager.cs: -------------------------------------------------------------------------------- 1 | using LanguageServer.Parameters; 2 | using LanguageServer.Parameters.TextDocument; 3 | using System; 4 | using System.Collections.Generic; 5 | using System.Linq; 6 | using System.Text; 7 | using System.Threading.Tasks; 8 | 9 | namespace SampleServer 10 | { 11 | public class TextDocumentManager 12 | { 13 | private readonly List _all = new List(); 14 | public IReadOnlyList All => _all; 15 | 16 | public void Add(TextDocumentItem document) 17 | { 18 | if (_all.Any(x => x.uri == document.uri)) 19 | { 20 | return; 21 | } 22 | _all.Add(document); 23 | OnChanged(document); 24 | } 25 | 26 | public void Change(Uri uri, long version, TextDocumentContentChangeEvent[] changeEvents) 27 | { 28 | var index = _all.FindIndex(x => x.uri == uri); 29 | if (index < 0) 30 | { 31 | return; 32 | } 33 | var document = _all[index]; 34 | if (document.version >= version) 35 | { 36 | return; 37 | } 38 | foreach(var ev in changeEvents) 39 | { 40 | Apply(document, ev); 41 | } 42 | document.version = version; 43 | OnChanged(document); 44 | } 45 | 46 | private void Apply(TextDocumentItem document, TextDocumentContentChangeEvent ev) 47 | { 48 | if (ev.range != null) 49 | { 50 | var startPos = GetPosition(document.text, (int)ev.range.start.line, (int)ev.range.start.character); 51 | var endPos = GetPosition(document.text, (int)ev.range.end.line, (int)ev.range.end.character); 52 | var newText = document.text.Substring(0, startPos) + ev.text + document.text.Substring(endPos); 53 | document.text = newText; 54 | } 55 | else 56 | { 57 | document.text = ev.text; 58 | } 59 | } 60 | 61 | private static int GetPosition(string text, int line, int character) 62 | { 63 | var pos = 0; 64 | for (; 0 <= line; line--) 65 | { 66 | var lf = text.IndexOf('\n', pos); 67 | if (lf < 0) 68 | { 69 | return text.Length; 70 | } 71 | pos = lf + 1; 72 | } 73 | var linefeed = text.IndexOf('\n', pos); 74 | var max = 0; 75 | if (linefeed < 0) 76 | { 77 | max = text.Length; 78 | } 79 | else if (linefeed > 0 && text[linefeed - 1] == '\r') 80 | { 81 | max = linefeed - 1; 82 | } 83 | else 84 | { 85 | max = linefeed; 86 | } 87 | pos += character; 88 | return (pos < max) ? pos : max; 89 | } 90 | 91 | public void Remove(Uri uri) 92 | { 93 | var index = _all.FindIndex(x => x.uri == uri); 94 | if (index < 0) 95 | { 96 | return; 97 | } 98 | _all.RemoveAt(index); 99 | } 100 | 101 | public event EventHandler Changed; 102 | 103 | protected virtual void OnChanged(TextDocumentItem document) 104 | { 105 | Changed?.Invoke(this, new TextDocumentChangedEventArgs(document)); 106 | } 107 | } 108 | } 109 | --------------------------------------------------------------------------------