├── .gitignore ├── .vscode ├── extensions.json ├── launch.json ├── settings.json └── tasks.json ├── .vscodeignore ├── CHANGELOG.md ├── LICENSE ├── README.md ├── adv-cppdbg-0.0.2.vsix ├── images └── regpanel.jpg ├── package-lock.json ├── package.json ├── src ├── config.ts ├── da-tracker.ts ├── extension.ts ├── monitor.ts ├── register.ts.unused └── test │ ├── extension.test.ts │ └── index.ts ├── test └── stdc-threads │ ├── .vscode │ ├── ipch │ │ ├── 4e7a706829d5f787 │ │ │ ├── main.ipch │ │ │ └── mmap_address.bin │ │ └── b8dcf81d69950906 │ │ │ ├── main.ipch │ │ │ └── mmap_address.bin │ ├── launch.json │ ├── settings.json │ └── tasks.json │ ├── Makefile │ ├── bin │ ├── main │ └── main.dSYM │ │ └── Contents │ │ ├── Info.plist │ │ └── Resources │ │ └── DWARF │ │ └── main │ └── src │ └── main.cpp ├── tsconfig.json ├── tslint.json └── vsc-extension-quickstart.md /.gitignore: -------------------------------------------------------------------------------- 1 | out 2 | node_modules 3 | .vscode-test/ 4 | #*.vsix 5 | .DS_Store 6 | 7 | -------------------------------------------------------------------------------- /.vscode/extensions.json: -------------------------------------------------------------------------------- 1 | { 2 | // See http://go.microsoft.com/fwlink/?LinkId=827846 3 | // for the documentation about the extensions.json format 4 | "recommendations": [ 5 | "ms-vscode.vscode-typescript-tslint-plugin" 6 | ] 7 | } -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | // A launch configuration that compiles the extension and then opens it inside a new window 2 | // Use IntelliSense to learn about possible attributes. 3 | // Hover to view descriptions of existing attributes. 4 | // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 5 | { 6 | "version": "0.2.0", 7 | "configurations": [{ 8 | "name": "Run Extension", 9 | "type": "extensionHost", 10 | "request": "launch", 11 | "runtimeExecutable": "${execPath}", 12 | "args": [ 13 | //"/Users/hdm/cypress/vscode/vscode", 14 | "--extensionDevelopmentPath=${workspaceFolder}" 15 | ], 16 | "outFiles": [ 17 | "${workspaceFolder}/out/**/*.js" 18 | ], 19 | "preLaunchTask": "npm: watch" 20 | }, 21 | { 22 | "name": "Extension Tests", 23 | "type": "extensionHost", 24 | "request": "launch", 25 | "runtimeExecutable": "${execPath}", 26 | "args": [ 27 | "--extensionDevelopmentPath=${workspaceFolder}", 28 | "--extensionTestsPath=${workspaceFolder}/out/test" 29 | ], 30 | "outFiles": [ 31 | "${workspaceFolder}/out/test/**/*.js" 32 | ], 33 | "preLaunchTask": "npm: watch" 34 | } 35 | ] 36 | } 37 | -------------------------------------------------------------------------------- /.vscode/settings.json: -------------------------------------------------------------------------------- 1 | // Place your settings in this file to overwrite default and user settings. 2 | { 3 | "files.exclude": { 4 | "out": false // set this to true to hide the "out" folder with the compiled JS files 5 | }, 6 | "search.exclude": { 7 | "out": true // set this to false to include "out" folder in search results 8 | }, 9 | // Turn off tsc task auto detection since we have the necessary tasks as npm scripts 10 | "typescript.tsc.autoDetect": "off" 11 | } -------------------------------------------------------------------------------- /.vscode/tasks.json: -------------------------------------------------------------------------------- 1 | // See https://go.microsoft.com/fwlink/?LinkId=733558 2 | // for the documentation about the tasks.json format 3 | { 4 | "version": "2.0.0", 5 | "tasks": [ 6 | { 7 | "type": "npm", 8 | "script": "watch", 9 | "problemMatcher": "$tsc-watch", 10 | "isBackground": true, 11 | "presentation": { 12 | "reveal": "never" 13 | }, 14 | "group": { 15 | "kind": "build", 16 | "isDefault": true 17 | } 18 | } 19 | ] 20 | } 21 | -------------------------------------------------------------------------------- /.vscodeignore: -------------------------------------------------------------------------------- 1 | .vscode/** 2 | .vscode-test/** 3 | out/test/** 4 | src/** 5 | .gitignore 6 | vsc-extension-quickstart.md 7 | **/tsconfig.json 8 | **/tslint.json 9 | **/*.map 10 | **/*.ts -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Change Log 2 | 3 | All notable changes to the "adv-cppdbg" extension will be documented in this file. 4 | 5 | Check [Keep a Changelog](http://keepachangelog.com/) for recommendations on how to structure this file. 6 | 7 | ## [Unreleased] 8 | 9 | - Initial release -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | adv-cppdbg 2 | 3 | The MIT License (MIT) 4 | 5 | Copyright (c) Cypress Semiconductor, Haneef Mohammed 6 | 7 | Permission is hereby granted, free of charge, to any person obtaining a copy 8 | of this software and associated documentation files (the "Software"), to deal 9 | in the Software without restriction, including without limitation the rights 10 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 11 | copies of the Software, and to permit persons to whom the Software is 12 | furnished to do so, subject to the following conditions: 13 | 14 | The above copyright notice and this permission notice shall be included in all 15 | copies or substantial portions of the Software. 16 | 17 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 18 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 19 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 20 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 21 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 22 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 23 | SOFTWARE. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # adv-cppdbg README 2 | 3 | This extension is intended to provide features that the default [vscode-cpptools](https://marketplace.visualstudio.com/items?itemName=ms-vscode.cpptools) does not for C/C++ development. Main intent is to provide a view for CPU registers, memory windows and perhaps a disassbmly window. It is intended to supplement the vscode-cpptools extension 4 | 5 | This is not yet available on the market place so, you have to download the vsix file and install it manually. 6 | 7 | code --install-extension filename.vsix 8 | 9 | We may abandon this project if we cannot implement memory and/or disassembly windows. We may need help from the core VSCode team to get those implemented. We can do everything if we write our own adapter but that is a big task. At least, for now registers view works pretty well and auto-refreshes thanks to a MS engineer guiding me. 10 | 11 | ## Features 12 | 13 | The following features are intended to work for programs running on a local machine or on a remote machine or a development board with totally different CPU architectures or OSes 14 | 15 | ### Register View 16 | 17 | The Registers VIew diplays all the registers reported by gdb/lldb. The are not grouped or filtered. We may add a feature for you to specify what to filter. You cannot yet change register values. I want to see if I can color code for what changed. 18 | 19 | ![Registers](images/regpanel.jpg) 20 | 21 | ### Memory Windows (coming) 22 | 23 | One or more windows to show a range of memory. Right now, you can do it in the **Watch** window using an appropriate C expression. We will implement memory windows is only if we can do registers properly and efficiently. 24 | 25 | ### Disassembly Window (maybe) 26 | 27 | This is a much more ambitious feature for those focused on performance and compiler efficiency and how their C/C++ code translates into machine code. We will also need to do stepi/nexti (assembly level step and next) whch the VSCode API/protocol does not support yet. 28 | 29 | ## Requirements 30 | 31 | None. The extention automatically triggers when it detects that a debug session of type 'cppdbg' (lldb/gdb) has started. Will add cppvsdbg shortly. 32 | 33 | ## Extension Settings 34 | 35 | There are two settings currently available (in your .vscode/settings.json) 36 | 37 | ```"adv-cppdbg.debugLevel": integer``` 38 | 39 | Must be >= 0. Default=1 You can use this to get information about what the extension is doing. Currently it is 0 for silent, 1 for small amount information and 2 for bit more involved debug output. To see the debug information however, you have to use "Help->Toggle Developer Tools" and look in the Console tab. We will find a better way soon. 40 | 41 | ```"adv-cppdbg.disableRegisterView": boolean``` 42 | Default=false 43 | 44 | ## Known Issues 45 | 46 | No way to change register values. It is a prototype. **VERY VERY RAW** 47 | 48 | ## Release Notes 49 | 50 | Not release yet. 51 | 52 | ### 0.0.2 53 | 54 | Mostly functional register view. Works with gdb/lldb. Tested on Mac x64 and ARM processors. 55 | 56 | ----------------------------------------------------------------------------------------------------------- 57 | -------------------------------------------------------------------------------- /adv-cppdbg-0.0.2.vsix: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/haneefdm/adv-cppdbg/5b7cdaaa6d195c9bd9997187eb6d340e37ded6e8/adv-cppdbg-0.0.2.vsix -------------------------------------------------------------------------------- /images/regpanel.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/haneefdm/adv-cppdbg/5b7cdaaa6d195c9bd9997187eb6d340e37ded6e8/images/regpanel.jpg -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "adv-cppdbg", 3 | "version": "0.0.2", 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": "10.14.1", 15 | "resolved": "https://registry.npmjs.org/@types/node/-/node-10.14.1.tgz", 16 | "integrity": "sha512-Rymt08vh1GaW4vYB6QP61/5m/CFLGnFZP++bJpWbiNxceNa6RBipDmb413jvtSf/R1gg5a/jQVl2jY4XVRscEA==", 17 | "dev": true 18 | }, 19 | "ajv": { 20 | "version": "6.10.0", 21 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.0.tgz", 22 | "integrity": "sha512-nffhOpkymDECQyR0mnsUtoCE8RlX38G0rYP+wgLWFyZuUyuuojSSvi/+euOiQBIn63whYwYVIIH1TvE3tu4OEg==", 23 | "dev": true, 24 | "requires": { 25 | "fast-deep-equal": "^2.0.1", 26 | "fast-json-stable-stringify": "^2.0.0", 27 | "json-schema-traverse": "^0.4.1", 28 | "uri-js": "^4.2.2" 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-regex": { 50 | "version": "2.1.1", 51 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 52 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 53 | "dev": true 54 | }, 55 | "ansi-styles": { 56 | "version": "2.2.1", 57 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 58 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 59 | "dev": true 60 | }, 61 | "ansi-wrap": { 62 | "version": "0.1.0", 63 | "resolved": "https://registry.npmjs.org/ansi-wrap/-/ansi-wrap-0.1.0.tgz", 64 | "integrity": "sha1-qCJQ3bABXponyoLoLqYDu/pF768=", 65 | "dev": true 66 | }, 67 | "append-buffer": { 68 | "version": "1.0.2", 69 | "resolved": "https://registry.npmjs.org/append-buffer/-/append-buffer-1.0.2.tgz", 70 | "integrity": "sha1-2CIM9GYIFSXv6lBhTz3mUU36WPE=", 71 | "dev": true, 72 | "requires": { 73 | "buffer-equal": "^1.0.0" 74 | } 75 | }, 76 | "argparse": { 77 | "version": "1.0.10", 78 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 79 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 80 | "dev": true, 81 | "requires": { 82 | "sprintf-js": "~1.0.2" 83 | } 84 | }, 85 | "arr-diff": { 86 | "version": "1.1.0", 87 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-1.1.0.tgz", 88 | "integrity": "sha1-aHwydYFjWI/vfeezb6vklesaOZo=", 89 | "dev": true, 90 | "requires": { 91 | "arr-flatten": "^1.0.1", 92 | "array-slice": "^0.2.3" 93 | } 94 | }, 95 | "arr-flatten": { 96 | "version": "1.1.0", 97 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 98 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", 99 | "dev": true 100 | }, 101 | "arr-union": { 102 | "version": "2.1.0", 103 | "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-2.1.0.tgz", 104 | "integrity": "sha1-IPnqtexw9cfSFbEHexw5Fh0pLH0=", 105 | "dev": true 106 | }, 107 | "array-differ": { 108 | "version": "1.0.0", 109 | "resolved": "https://registry.npmjs.org/array-differ/-/array-differ-1.0.0.tgz", 110 | "integrity": "sha1-7/UuN1gknTO+QCuLuOVkuytdQDE=", 111 | "dev": true 112 | }, 113 | "array-slice": { 114 | "version": "0.2.3", 115 | "resolved": "https://registry.npmjs.org/array-slice/-/array-slice-0.2.3.tgz", 116 | "integrity": "sha1-3Tz7gO15c6dRF82sabC5nshhhvU=", 117 | "dev": true 118 | }, 119 | "array-union": { 120 | "version": "1.0.2", 121 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", 122 | "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", 123 | "dev": true, 124 | "requires": { 125 | "array-uniq": "^1.0.1" 126 | } 127 | }, 128 | "array-uniq": { 129 | "version": "1.0.3", 130 | "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", 131 | "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", 132 | "dev": true 133 | }, 134 | "arrify": { 135 | "version": "1.0.1", 136 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 137 | "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", 138 | "dev": true 139 | }, 140 | "asn1": { 141 | "version": "0.2.4", 142 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 143 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 144 | "dev": true, 145 | "requires": { 146 | "safer-buffer": "~2.1.0" 147 | } 148 | }, 149 | "assert-plus": { 150 | "version": "1.0.0", 151 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 152 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 153 | "dev": true 154 | }, 155 | "asynckit": { 156 | "version": "0.4.0", 157 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 158 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 159 | "dev": true 160 | }, 161 | "aws-sign2": { 162 | "version": "0.7.0", 163 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 164 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 165 | "dev": true 166 | }, 167 | "aws4": { 168 | "version": "1.8.0", 169 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.8.0.tgz", 170 | "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==", 171 | "dev": true 172 | }, 173 | "babel-code-frame": { 174 | "version": "6.26.0", 175 | "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", 176 | "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", 177 | "dev": true, 178 | "requires": { 179 | "chalk": "^1.1.3", 180 | "esutils": "^2.0.2", 181 | "js-tokens": "^3.0.2" 182 | }, 183 | "dependencies": { 184 | "chalk": { 185 | "version": "1.1.3", 186 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 187 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 188 | "dev": true, 189 | "requires": { 190 | "ansi-styles": "^2.2.1", 191 | "escape-string-regexp": "^1.0.2", 192 | "has-ansi": "^2.0.0", 193 | "strip-ansi": "^3.0.0", 194 | "supports-color": "^2.0.0" 195 | } 196 | } 197 | } 198 | }, 199 | "balanced-match": { 200 | "version": "1.0.0", 201 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 202 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 203 | "dev": true 204 | }, 205 | "bcrypt-pbkdf": { 206 | "version": "1.0.2", 207 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 208 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 209 | "dev": true, 210 | "requires": { 211 | "tweetnacl": "^0.14.3" 212 | } 213 | }, 214 | "block-stream": { 215 | "version": "0.0.9", 216 | "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz", 217 | "integrity": "sha1-E+v+d4oDIFz+A3UUgeu0szAMEmo=", 218 | "dev": true, 219 | "requires": { 220 | "inherits": "~2.0.0" 221 | } 222 | }, 223 | "brace-expansion": { 224 | "version": "1.1.11", 225 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 226 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 227 | "dev": true, 228 | "requires": { 229 | "balanced-match": "^1.0.0", 230 | "concat-map": "0.0.1" 231 | } 232 | }, 233 | "browser-stdout": { 234 | "version": "1.3.0", 235 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.0.tgz", 236 | "integrity": "sha1-81HTKWnTL6XXpVZxVCY9korjvR8=", 237 | "dev": true 238 | }, 239 | "buffer-crc32": { 240 | "version": "0.2.13", 241 | "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", 242 | "integrity": "sha1-DTM+PwDqxQqhRUq9MO+MKl2ackI=", 243 | "dev": true 244 | }, 245 | "buffer-equal": { 246 | "version": "1.0.0", 247 | "resolved": "https://registry.npmjs.org/buffer-equal/-/buffer-equal-1.0.0.tgz", 248 | "integrity": "sha1-WWFrSYME1Var1GaWayLu2j7KX74=", 249 | "dev": true 250 | }, 251 | "buffer-from": { 252 | "version": "1.1.1", 253 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 254 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 255 | "dev": true 256 | }, 257 | "builtin-modules": { 258 | "version": "1.1.1", 259 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 260 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", 261 | "dev": true 262 | }, 263 | "caseless": { 264 | "version": "0.12.0", 265 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 266 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", 267 | "dev": true 268 | }, 269 | "chalk": { 270 | "version": "2.4.2", 271 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 272 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 273 | "dev": true, 274 | "requires": { 275 | "ansi-styles": "^3.2.1", 276 | "escape-string-regexp": "^1.0.5", 277 | "supports-color": "^5.3.0" 278 | }, 279 | "dependencies": { 280 | "ansi-styles": { 281 | "version": "3.2.1", 282 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 283 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 284 | "dev": true, 285 | "requires": { 286 | "color-convert": "^1.9.0" 287 | } 288 | }, 289 | "supports-color": { 290 | "version": "5.5.0", 291 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 292 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 293 | "dev": true, 294 | "requires": { 295 | "has-flag": "^3.0.0" 296 | } 297 | } 298 | } 299 | }, 300 | "clone": { 301 | "version": "0.2.0", 302 | "resolved": "https://registry.npmjs.org/clone/-/clone-0.2.0.tgz", 303 | "integrity": "sha1-xhJqkK1Pctv1rNskPMN3JP6T/B8=", 304 | "dev": true 305 | }, 306 | "clone-buffer": { 307 | "version": "1.0.0", 308 | "resolved": "https://registry.npmjs.org/clone-buffer/-/clone-buffer-1.0.0.tgz", 309 | "integrity": "sha1-4+JbIHrE5wGvch4staFnksrD3Fg=", 310 | "dev": true 311 | }, 312 | "clone-stats": { 313 | "version": "0.0.1", 314 | "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-0.0.1.tgz", 315 | "integrity": "sha1-uI+UqCzzi4eR1YBG6kAprYjKmdE=", 316 | "dev": true 317 | }, 318 | "cloneable-readable": { 319 | "version": "1.1.2", 320 | "resolved": "https://registry.npmjs.org/cloneable-readable/-/cloneable-readable-1.1.2.tgz", 321 | "integrity": "sha512-Bq6+4t+lbM8vhTs/Bef5c5AdEMtapp/iFb6+s4/Hh9MVTt8OLKH7ZOOZSCT+Ys7hsHvqv0GuMPJ1lnQJVHvxpg==", 322 | "dev": true, 323 | "requires": { 324 | "inherits": "^2.0.1", 325 | "process-nextick-args": "^2.0.0", 326 | "readable-stream": "^2.3.5" 327 | } 328 | }, 329 | "color-convert": { 330 | "version": "1.9.3", 331 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 332 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 333 | "dev": true, 334 | "requires": { 335 | "color-name": "1.1.3" 336 | } 337 | }, 338 | "color-name": { 339 | "version": "1.1.3", 340 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 341 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 342 | "dev": true 343 | }, 344 | "combined-stream": { 345 | "version": "1.0.7", 346 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.7.tgz", 347 | "integrity": "sha512-brWl9y6vOB1xYPZcpZde3N9zDByXTosAeMDo4p1wzo6UMOX4vumB+TP1RZ76sfE6Md68Q0NJSrE/gbezd4Ul+w==", 348 | "dev": true, 349 | "requires": { 350 | "delayed-stream": "~1.0.0" 351 | } 352 | }, 353 | "commander": { 354 | "version": "2.19.0", 355 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.19.0.tgz", 356 | "integrity": "sha512-6tvAOO+D6OENvRAh524Dh9jcfKTYDQAqvqezbCW82xj5X0pSrcpxtvRKHLG0yBY6SD7PSDrJaj+0AiOcKVd1Xg==", 357 | "dev": true 358 | }, 359 | "concat-map": { 360 | "version": "0.0.1", 361 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 362 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 363 | "dev": true 364 | }, 365 | "convert-source-map": { 366 | "version": "1.6.0", 367 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.6.0.tgz", 368 | "integrity": "sha512-eFu7XigvxdZ1ETfbgPBohgyQ/Z++C0eEhTor0qRwBw9unw+L0/6V8wkSuGgzdThkiS5lSpdptOQPD8Ak40a+7A==", 369 | "dev": true, 370 | "requires": { 371 | "safe-buffer": "~5.1.1" 372 | } 373 | }, 374 | "core-util-is": { 375 | "version": "1.0.2", 376 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 377 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 378 | "dev": true 379 | }, 380 | "dashdash": { 381 | "version": "1.14.1", 382 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 383 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 384 | "dev": true, 385 | "requires": { 386 | "assert-plus": "^1.0.0" 387 | } 388 | }, 389 | "debug": { 390 | "version": "3.1.0", 391 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 392 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 393 | "dev": true, 394 | "requires": { 395 | "ms": "2.0.0" 396 | } 397 | }, 398 | "deep-assign": { 399 | "version": "1.0.0", 400 | "resolved": "https://registry.npmjs.org/deep-assign/-/deep-assign-1.0.0.tgz", 401 | "integrity": "sha1-sJJ0O+hCfcYh6gBnzex+cN0Z83s=", 402 | "dev": true, 403 | "requires": { 404 | "is-obj": "^1.0.0" 405 | } 406 | }, 407 | "define-properties": { 408 | "version": "1.1.3", 409 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 410 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 411 | "dev": true, 412 | "requires": { 413 | "object-keys": "^1.0.12" 414 | } 415 | }, 416 | "delayed-stream": { 417 | "version": "1.0.0", 418 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 419 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 420 | "dev": true 421 | }, 422 | "diff": { 423 | "version": "3.5.0", 424 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 425 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 426 | "dev": true 427 | }, 428 | "duplexer": { 429 | "version": "0.1.1", 430 | "resolved": "http://registry.npmjs.org/duplexer/-/duplexer-0.1.1.tgz", 431 | "integrity": "sha1-rOb/gIwc5mtX0ev5eXessCM0z8E=", 432 | "dev": true 433 | }, 434 | "duplexify": { 435 | "version": "3.6.1", 436 | "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.6.1.tgz", 437 | "integrity": "sha512-vM58DwdnKmty+FSPzT14K9JXb90H+j5emaR4KYbr2KTIz00WHGbWOe5ghQTx233ZCLZtrGDALzKwcjEtSt35mA==", 438 | "dev": true, 439 | "requires": { 440 | "end-of-stream": "^1.0.0", 441 | "inherits": "^2.0.1", 442 | "readable-stream": "^2.0.0", 443 | "stream-shift": "^1.0.0" 444 | } 445 | }, 446 | "ecc-jsbn": { 447 | "version": "0.1.2", 448 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 449 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 450 | "dev": true, 451 | "requires": { 452 | "jsbn": "~0.1.0", 453 | "safer-buffer": "^2.1.0" 454 | } 455 | }, 456 | "end-of-stream": { 457 | "version": "1.4.1", 458 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz", 459 | "integrity": "sha512-1MkrZNvWTKCaigbn+W15elq2BB/L22nqrSY5DKlo3X6+vclJm8Bb5djXJBmEX6fS3+zCh/F4VBK5Z2KxJt4s2Q==", 460 | "dev": true, 461 | "requires": { 462 | "once": "^1.4.0" 463 | } 464 | }, 465 | "escape-string-regexp": { 466 | "version": "1.0.5", 467 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 468 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 469 | "dev": true 470 | }, 471 | "esprima": { 472 | "version": "4.0.1", 473 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 474 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 475 | "dev": true 476 | }, 477 | "esutils": { 478 | "version": "2.0.2", 479 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 480 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 481 | "dev": true 482 | }, 483 | "event-stream": { 484 | "version": "3.3.4", 485 | "resolved": "https://registry.npmjs.org/event-stream/-/event-stream-3.3.4.tgz", 486 | "integrity": "sha1-SrTJoPWlTbkzi0w02Gv86PSzVXE=", 487 | "dev": true, 488 | "requires": { 489 | "duplexer": "~0.1.1", 490 | "from": "~0", 491 | "map-stream": "~0.1.0", 492 | "pause-stream": "0.0.11", 493 | "split": "0.3", 494 | "stream-combiner": "~0.0.4", 495 | "through": "~2.3.1" 496 | } 497 | }, 498 | "extend": { 499 | "version": "3.0.2", 500 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 501 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 502 | "dev": true 503 | }, 504 | "extend-shallow": { 505 | "version": "1.1.4", 506 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-1.1.4.tgz", 507 | "integrity": "sha1-Gda/lN/AnXa6cR85uHLSH/TdkHE=", 508 | "dev": true, 509 | "requires": { 510 | "kind-of": "^1.1.0" 511 | } 512 | }, 513 | "extsprintf": { 514 | "version": "1.3.0", 515 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 516 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 517 | "dev": true 518 | }, 519 | "fast-deep-equal": { 520 | "version": "2.0.1", 521 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 522 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 523 | "dev": true 524 | }, 525 | "fast-json-stable-stringify": { 526 | "version": "2.0.0", 527 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 528 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 529 | "dev": true 530 | }, 531 | "fd-slicer": { 532 | "version": "1.1.0", 533 | "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", 534 | "integrity": "sha1-JcfInLH5B3+IkbvmHY85Dq4lbx4=", 535 | "dev": true, 536 | "requires": { 537 | "pend": "~1.2.0" 538 | } 539 | }, 540 | "flush-write-stream": { 541 | "version": "1.1.1", 542 | "resolved": "https://registry.npmjs.org/flush-write-stream/-/flush-write-stream-1.1.1.tgz", 543 | "integrity": "sha512-3Z4XhFZ3992uIq0XOqb9AreonueSYphE6oYbpt5+3u06JWklbsPkNv3ZKkP9Bz/r+1MWCaMoSQ28P85+1Yc77w==", 544 | "dev": true, 545 | "requires": { 546 | "inherits": "^2.0.3", 547 | "readable-stream": "^2.3.6" 548 | } 549 | }, 550 | "forever-agent": { 551 | "version": "0.6.1", 552 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 553 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 554 | "dev": true 555 | }, 556 | "form-data": { 557 | "version": "2.3.3", 558 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 559 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 560 | "dev": true, 561 | "requires": { 562 | "asynckit": "^0.4.0", 563 | "combined-stream": "^1.0.6", 564 | "mime-types": "^2.1.12" 565 | } 566 | }, 567 | "from": { 568 | "version": "0.1.7", 569 | "resolved": "https://registry.npmjs.org/from/-/from-0.1.7.tgz", 570 | "integrity": "sha1-g8YK/Fi5xWmXAH7Rp2izqzA6RP4=", 571 | "dev": true 572 | }, 573 | "fs-mkdirp-stream": { 574 | "version": "1.0.0", 575 | "resolved": "https://registry.npmjs.org/fs-mkdirp-stream/-/fs-mkdirp-stream-1.0.0.tgz", 576 | "integrity": "sha1-C3gV/DIBxqaeFNuYzgmMFpNSWes=", 577 | "dev": true, 578 | "requires": { 579 | "graceful-fs": "^4.1.11", 580 | "through2": "^2.0.3" 581 | } 582 | }, 583 | "fs.realpath": { 584 | "version": "1.0.0", 585 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 586 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 587 | "dev": true 588 | }, 589 | "fstream": { 590 | "version": "1.0.12", 591 | "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.12.tgz", 592 | "integrity": "sha512-WvJ193OHa0GHPEL+AycEJgxvBEwyfRkN1vhjca23OaPVMCaLCXTd5qAu82AjTcgP1UJmytkOKb63Ypde7raDIg==", 593 | "dev": true, 594 | "requires": { 595 | "graceful-fs": "^4.1.2", 596 | "inherits": "~2.0.0", 597 | "mkdirp": ">=0.5 0", 598 | "rimraf": "2" 599 | } 600 | }, 601 | "function-bind": { 602 | "version": "1.1.1", 603 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 604 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 605 | "dev": true 606 | }, 607 | "getpass": { 608 | "version": "0.1.7", 609 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 610 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 611 | "dev": true, 612 | "requires": { 613 | "assert-plus": "^1.0.0" 614 | } 615 | }, 616 | "glob": { 617 | "version": "7.1.3", 618 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 619 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 620 | "dev": true, 621 | "requires": { 622 | "fs.realpath": "^1.0.0", 623 | "inflight": "^1.0.4", 624 | "inherits": "2", 625 | "minimatch": "^3.0.4", 626 | "once": "^1.3.0", 627 | "path-is-absolute": "^1.0.0" 628 | } 629 | }, 630 | "glob-parent": { 631 | "version": "3.1.0", 632 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", 633 | "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", 634 | "dev": true, 635 | "requires": { 636 | "is-glob": "^3.1.0", 637 | "path-dirname": "^1.0.0" 638 | } 639 | }, 640 | "glob-stream": { 641 | "version": "6.1.0", 642 | "resolved": "https://registry.npmjs.org/glob-stream/-/glob-stream-6.1.0.tgz", 643 | "integrity": "sha1-cEXJlBOz65SIjYOrRtC0BMx73eQ=", 644 | "dev": true, 645 | "requires": { 646 | "extend": "^3.0.0", 647 | "glob": "^7.1.1", 648 | "glob-parent": "^3.1.0", 649 | "is-negated-glob": "^1.0.0", 650 | "ordered-read-streams": "^1.0.0", 651 | "pumpify": "^1.3.5", 652 | "readable-stream": "^2.1.5", 653 | "remove-trailing-separator": "^1.0.1", 654 | "to-absolute-glob": "^2.0.0", 655 | "unique-stream": "^2.0.2" 656 | } 657 | }, 658 | "graceful-fs": { 659 | "version": "4.1.15", 660 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", 661 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==", 662 | "dev": true 663 | }, 664 | "growl": { 665 | "version": "1.10.3", 666 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.3.tgz", 667 | "integrity": "sha512-hKlsbA5Vu3xsh1Cg3J7jSmX/WaW6A5oBeqzM88oNbCRQFz+zUaXm6yxS4RVytp1scBoJzSYl4YAEOQIt6O8V1Q==", 668 | "dev": true 669 | }, 670 | "gulp-chmod": { 671 | "version": "2.0.0", 672 | "resolved": "https://registry.npmjs.org/gulp-chmod/-/gulp-chmod-2.0.0.tgz", 673 | "integrity": "sha1-AMOQuSigeZslGsz2MaoJ4BzGKZw=", 674 | "dev": true, 675 | "requires": { 676 | "deep-assign": "^1.0.0", 677 | "stat-mode": "^0.2.0", 678 | "through2": "^2.0.0" 679 | } 680 | }, 681 | "gulp-filter": { 682 | "version": "5.1.0", 683 | "resolved": "https://registry.npmjs.org/gulp-filter/-/gulp-filter-5.1.0.tgz", 684 | "integrity": "sha1-oF4Rr/sHz33PQafeHLe2OsN4PnM=", 685 | "dev": true, 686 | "requires": { 687 | "multimatch": "^2.0.0", 688 | "plugin-error": "^0.1.2", 689 | "streamfilter": "^1.0.5" 690 | } 691 | }, 692 | "gulp-gunzip": { 693 | "version": "1.0.0", 694 | "resolved": "https://registry.npmjs.org/gulp-gunzip/-/gulp-gunzip-1.0.0.tgz", 695 | "integrity": "sha1-FbdBFF6Dqcb1CIYkG1fMWHHxUak=", 696 | "dev": true, 697 | "requires": { 698 | "through2": "~0.6.5", 699 | "vinyl": "~0.4.6" 700 | }, 701 | "dependencies": { 702 | "isarray": { 703 | "version": "0.0.1", 704 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 705 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 706 | "dev": true 707 | }, 708 | "readable-stream": { 709 | "version": "1.0.34", 710 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.0.34.tgz", 711 | "integrity": "sha1-Elgg40vIQtLyqq+v5MKRbuMsFXw=", 712 | "dev": true, 713 | "requires": { 714 | "core-util-is": "~1.0.0", 715 | "inherits": "~2.0.1", 716 | "isarray": "0.0.1", 717 | "string_decoder": "~0.10.x" 718 | } 719 | }, 720 | "string_decoder": { 721 | "version": "0.10.31", 722 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 723 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", 724 | "dev": true 725 | }, 726 | "through2": { 727 | "version": "0.6.5", 728 | "resolved": "https://registry.npmjs.org/through2/-/through2-0.6.5.tgz", 729 | "integrity": "sha1-QaucZ7KdVyCQcUEOHXp6lozTrUg=", 730 | "dev": true, 731 | "requires": { 732 | "readable-stream": ">=1.0.33-1 <1.1.0-0", 733 | "xtend": ">=4.0.0 <4.1.0-0" 734 | } 735 | } 736 | } 737 | }, 738 | "gulp-remote-src-vscode": { 739 | "version": "0.5.1", 740 | "resolved": "https://registry.npmjs.org/gulp-remote-src-vscode/-/gulp-remote-src-vscode-0.5.1.tgz", 741 | "integrity": "sha512-mw4OGjtC/jlCWJFhbcAlel4YPvccChlpsl3JceNiB/DLJi24/UPxXt53/N26lgI3dknEqd4ErfdHrO8sJ5bATQ==", 742 | "dev": true, 743 | "requires": { 744 | "event-stream": "3.3.4", 745 | "node.extend": "^1.1.2", 746 | "request": "^2.79.0", 747 | "through2": "^2.0.3", 748 | "vinyl": "^2.0.1" 749 | }, 750 | "dependencies": { 751 | "clone": { 752 | "version": "2.1.2", 753 | "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.2.tgz", 754 | "integrity": "sha1-G39Ln1kfHo+DZwQBYANFoCiHQ18=", 755 | "dev": true 756 | }, 757 | "clone-stats": { 758 | "version": "1.0.0", 759 | "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-1.0.0.tgz", 760 | "integrity": "sha1-s3gt/4u1R04Yuba/D9/ngvh3doA=", 761 | "dev": true 762 | }, 763 | "vinyl": { 764 | "version": "2.2.0", 765 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-2.2.0.tgz", 766 | "integrity": "sha512-MBH+yP0kC/GQ5GwBqrTPTzEfiiLjta7hTtvQtbxBgTeSXsmKQRQecjibMbxIXzVT3Y9KJK+drOz1/k+vsu8Nkg==", 767 | "dev": true, 768 | "requires": { 769 | "clone": "^2.1.1", 770 | "clone-buffer": "^1.0.0", 771 | "clone-stats": "^1.0.0", 772 | "cloneable-readable": "^1.0.0", 773 | "remove-trailing-separator": "^1.0.1", 774 | "replace-ext": "^1.0.0" 775 | } 776 | } 777 | } 778 | }, 779 | "gulp-untar": { 780 | "version": "0.0.7", 781 | "resolved": "https://registry.npmjs.org/gulp-untar/-/gulp-untar-0.0.7.tgz", 782 | "integrity": "sha512-0QfbCH2a1k2qkTLWPqTX+QO4qNsHn3kC546YhAP3/n0h+nvtyGITDuDrYBMDZeW4WnFijmkOvBWa5HshTic1tw==", 783 | "dev": true, 784 | "requires": { 785 | "event-stream": "~3.3.4", 786 | "streamifier": "~0.1.1", 787 | "tar": "^2.2.1", 788 | "through2": "~2.0.3", 789 | "vinyl": "^1.2.0" 790 | }, 791 | "dependencies": { 792 | "clone": { 793 | "version": "1.0.4", 794 | "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", 795 | "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", 796 | "dev": true 797 | }, 798 | "replace-ext": { 799 | "version": "0.0.1", 800 | "resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-0.0.1.tgz", 801 | "integrity": "sha1-KbvZIHinOfC8zitO5B6DeVNSKSQ=", 802 | "dev": true 803 | }, 804 | "vinyl": { 805 | "version": "1.2.0", 806 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-1.2.0.tgz", 807 | "integrity": "sha1-XIgDbPVl5d8FVYv8kR+GVt8hiIQ=", 808 | "dev": true, 809 | "requires": { 810 | "clone": "^1.0.0", 811 | "clone-stats": "^0.0.1", 812 | "replace-ext": "0.0.1" 813 | } 814 | } 815 | } 816 | }, 817 | "gulp-vinyl-zip": { 818 | "version": "2.1.2", 819 | "resolved": "https://registry.npmjs.org/gulp-vinyl-zip/-/gulp-vinyl-zip-2.1.2.tgz", 820 | "integrity": "sha512-wJn09jsb8PyvUeyFF7y7ImEJqJwYy40BqL9GKfJs6UGpaGW9A+N68Q+ajsIpb9AeR6lAdjMbIdDPclIGo1/b7Q==", 821 | "dev": true, 822 | "requires": { 823 | "event-stream": "3.3.4", 824 | "queue": "^4.2.1", 825 | "through2": "^2.0.3", 826 | "vinyl": "^2.0.2", 827 | "vinyl-fs": "^3.0.3", 828 | "yauzl": "^2.2.1", 829 | "yazl": "^2.2.1" 830 | }, 831 | "dependencies": { 832 | "clone": { 833 | "version": "2.1.2", 834 | "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.2.tgz", 835 | "integrity": "sha1-G39Ln1kfHo+DZwQBYANFoCiHQ18=", 836 | "dev": true 837 | }, 838 | "clone-stats": { 839 | "version": "1.0.0", 840 | "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-1.0.0.tgz", 841 | "integrity": "sha1-s3gt/4u1R04Yuba/D9/ngvh3doA=", 842 | "dev": true 843 | }, 844 | "vinyl": { 845 | "version": "2.2.0", 846 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-2.2.0.tgz", 847 | "integrity": "sha512-MBH+yP0kC/GQ5GwBqrTPTzEfiiLjta7hTtvQtbxBgTeSXsmKQRQecjibMbxIXzVT3Y9KJK+drOz1/k+vsu8Nkg==", 848 | "dev": true, 849 | "requires": { 850 | "clone": "^2.1.1", 851 | "clone-buffer": "^1.0.0", 852 | "clone-stats": "^1.0.0", 853 | "cloneable-readable": "^1.0.0", 854 | "remove-trailing-separator": "^1.0.1", 855 | "replace-ext": "^1.0.0" 856 | } 857 | } 858 | } 859 | }, 860 | "har-schema": { 861 | "version": "2.0.0", 862 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 863 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 864 | "dev": true 865 | }, 866 | "har-validator": { 867 | "version": "5.1.3", 868 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", 869 | "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", 870 | "dev": true, 871 | "requires": { 872 | "ajv": "^6.5.5", 873 | "har-schema": "^2.0.0" 874 | } 875 | }, 876 | "has": { 877 | "version": "1.0.3", 878 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 879 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 880 | "dev": true, 881 | "requires": { 882 | "function-bind": "^1.1.1" 883 | } 884 | }, 885 | "has-ansi": { 886 | "version": "2.0.0", 887 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 888 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 889 | "dev": true, 890 | "requires": { 891 | "ansi-regex": "^2.0.0" 892 | } 893 | }, 894 | "has-flag": { 895 | "version": "3.0.0", 896 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 897 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 898 | "dev": true 899 | }, 900 | "has-symbols": { 901 | "version": "1.0.0", 902 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 903 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 904 | "dev": true 905 | }, 906 | "he": { 907 | "version": "1.1.1", 908 | "resolved": "https://registry.npmjs.org/he/-/he-1.1.1.tgz", 909 | "integrity": "sha1-k0EP0hsAlzUVH4howvJx80J+I/0=", 910 | "dev": true 911 | }, 912 | "http-signature": { 913 | "version": "1.2.0", 914 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 915 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 916 | "dev": true, 917 | "requires": { 918 | "assert-plus": "^1.0.0", 919 | "jsprim": "^1.2.2", 920 | "sshpk": "^1.7.0" 921 | } 922 | }, 923 | "inflight": { 924 | "version": "1.0.6", 925 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 926 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 927 | "dev": true, 928 | "requires": { 929 | "once": "^1.3.0", 930 | "wrappy": "1" 931 | } 932 | }, 933 | "inherits": { 934 | "version": "2.0.3", 935 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 936 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 937 | "dev": true 938 | }, 939 | "is": { 940 | "version": "3.3.0", 941 | "resolved": "https://registry.npmjs.org/is/-/is-3.3.0.tgz", 942 | "integrity": "sha512-nW24QBoPcFGGHJGUwnfpI7Yc5CdqWNdsyHQszVE/z2pKHXzh7FZ5GWhJqSyaQ9wMkQnsTx+kAI8bHlCX4tKdbg==", 943 | "dev": true 944 | }, 945 | "is-absolute": { 946 | "version": "1.0.0", 947 | "resolved": "https://registry.npmjs.org/is-absolute/-/is-absolute-1.0.0.tgz", 948 | "integrity": "sha512-dOWoqflvcydARa360Gvv18DZ/gRuHKi2NU/wU5X1ZFzdYfH29nkiNZsF3mp4OJ3H4yo9Mx8A/uAGNzpzPN3yBA==", 949 | "dev": true, 950 | "requires": { 951 | "is-relative": "^1.0.0", 952 | "is-windows": "^1.0.1" 953 | } 954 | }, 955 | "is-buffer": { 956 | "version": "1.1.6", 957 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 958 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 959 | "dev": true 960 | }, 961 | "is-extglob": { 962 | "version": "2.1.1", 963 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 964 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 965 | "dev": true 966 | }, 967 | "is-glob": { 968 | "version": "3.1.0", 969 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", 970 | "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", 971 | "dev": true, 972 | "requires": { 973 | "is-extglob": "^2.1.0" 974 | } 975 | }, 976 | "is-negated-glob": { 977 | "version": "1.0.0", 978 | "resolved": "https://registry.npmjs.org/is-negated-glob/-/is-negated-glob-1.0.0.tgz", 979 | "integrity": "sha1-aRC8pdqMleeEtXUbl2z1oQ/uNtI=", 980 | "dev": true 981 | }, 982 | "is-obj": { 983 | "version": "1.0.1", 984 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", 985 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=", 986 | "dev": true 987 | }, 988 | "is-relative": { 989 | "version": "1.0.0", 990 | "resolved": "https://registry.npmjs.org/is-relative/-/is-relative-1.0.0.tgz", 991 | "integrity": "sha512-Kw/ReK0iqwKeu0MITLFuj0jbPAmEiOsIwyIXvvbfa6QfmN9pkD1M+8pdk7Rl/dTKbH34/XBFMbgD4iMJhLQbGA==", 992 | "dev": true, 993 | "requires": { 994 | "is-unc-path": "^1.0.0" 995 | } 996 | }, 997 | "is-typedarray": { 998 | "version": "1.0.0", 999 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1000 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1001 | "dev": true 1002 | }, 1003 | "is-unc-path": { 1004 | "version": "1.0.0", 1005 | "resolved": "https://registry.npmjs.org/is-unc-path/-/is-unc-path-1.0.0.tgz", 1006 | "integrity": "sha512-mrGpVd0fs7WWLfVsStvgF6iEJnbjDFZh9/emhRDcGWTduTfNHd9CHeUwH3gYIjdbwo4On6hunkztwOaAw0yllQ==", 1007 | "dev": true, 1008 | "requires": { 1009 | "unc-path-regex": "^0.1.2" 1010 | } 1011 | }, 1012 | "is-utf8": { 1013 | "version": "0.2.1", 1014 | "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", 1015 | "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=", 1016 | "dev": true 1017 | }, 1018 | "is-valid-glob": { 1019 | "version": "1.0.0", 1020 | "resolved": "https://registry.npmjs.org/is-valid-glob/-/is-valid-glob-1.0.0.tgz", 1021 | "integrity": "sha1-Kb8+/3Ab4tTTFdusw5vDn+j2Aao=", 1022 | "dev": true 1023 | }, 1024 | "is-windows": { 1025 | "version": "1.0.2", 1026 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", 1027 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", 1028 | "dev": true 1029 | }, 1030 | "isarray": { 1031 | "version": "1.0.0", 1032 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1033 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1034 | "dev": true 1035 | }, 1036 | "isstream": { 1037 | "version": "0.1.2", 1038 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 1039 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", 1040 | "dev": true 1041 | }, 1042 | "js-tokens": { 1043 | "version": "3.0.2", 1044 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", 1045 | "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=", 1046 | "dev": true 1047 | }, 1048 | "js-yaml": { 1049 | "version": "3.13.1", 1050 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1051 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1052 | "dev": true, 1053 | "requires": { 1054 | "argparse": "^1.0.7", 1055 | "esprima": "^4.0.0" 1056 | } 1057 | }, 1058 | "jsbn": { 1059 | "version": "0.1.1", 1060 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 1061 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 1062 | "dev": true 1063 | }, 1064 | "json-schema": { 1065 | "version": "0.2.3", 1066 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 1067 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", 1068 | "dev": true 1069 | }, 1070 | "json-schema-traverse": { 1071 | "version": "0.4.1", 1072 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1073 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1074 | "dev": true 1075 | }, 1076 | "json-stable-stringify": { 1077 | "version": "1.0.1", 1078 | "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", 1079 | "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", 1080 | "dev": true, 1081 | "requires": { 1082 | "jsonify": "~0.0.0" 1083 | } 1084 | }, 1085 | "json-stringify-safe": { 1086 | "version": "5.0.1", 1087 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 1088 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", 1089 | "dev": true 1090 | }, 1091 | "jsonify": { 1092 | "version": "0.0.0", 1093 | "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", 1094 | "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=", 1095 | "dev": true 1096 | }, 1097 | "jsprim": { 1098 | "version": "1.4.1", 1099 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 1100 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 1101 | "dev": true, 1102 | "requires": { 1103 | "assert-plus": "1.0.0", 1104 | "extsprintf": "1.3.0", 1105 | "json-schema": "0.2.3", 1106 | "verror": "1.10.0" 1107 | } 1108 | }, 1109 | "kind-of": { 1110 | "version": "1.1.0", 1111 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-1.1.0.tgz", 1112 | "integrity": "sha1-FAo9LUGjbS78+pN3tiwk+ElaXEQ=", 1113 | "dev": true 1114 | }, 1115 | "lazystream": { 1116 | "version": "1.0.0", 1117 | "resolved": "https://registry.npmjs.org/lazystream/-/lazystream-1.0.0.tgz", 1118 | "integrity": "sha1-9plf4PggOS9hOWvolGJAe7dxaOQ=", 1119 | "dev": true, 1120 | "requires": { 1121 | "readable-stream": "^2.0.5" 1122 | } 1123 | }, 1124 | "lead": { 1125 | "version": "1.0.0", 1126 | "resolved": "https://registry.npmjs.org/lead/-/lead-1.0.0.tgz", 1127 | "integrity": "sha1-bxT5mje+Op3XhPVJVpDlkDRm7kI=", 1128 | "dev": true, 1129 | "requires": { 1130 | "flush-write-stream": "^1.0.2" 1131 | } 1132 | }, 1133 | "map-stream": { 1134 | "version": "0.1.0", 1135 | "resolved": "https://registry.npmjs.org/map-stream/-/map-stream-0.1.0.tgz", 1136 | "integrity": "sha1-5WqpTEyAVaFkBKBnS3jyFffI4ZQ=", 1137 | "dev": true 1138 | }, 1139 | "mime-db": { 1140 | "version": "1.38.0", 1141 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.38.0.tgz", 1142 | "integrity": "sha512-bqVioMFFzc2awcdJZIzR3HjZFX20QhilVS7hytkKrv7xFAn8bM1gzc/FOX2awLISvWe0PV8ptFKcon+wZ5qYkg==", 1143 | "dev": true 1144 | }, 1145 | "mime-types": { 1146 | "version": "2.1.22", 1147 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.22.tgz", 1148 | "integrity": "sha512-aGl6TZGnhm/li6F7yx82bJiBZwgiEa4Hf6CNr8YO+r5UHr53tSTYZb102zyU50DOWWKeOv0uQLRL0/9EiKWCog==", 1149 | "dev": true, 1150 | "requires": { 1151 | "mime-db": "~1.38.0" 1152 | } 1153 | }, 1154 | "minimatch": { 1155 | "version": "3.0.4", 1156 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1157 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1158 | "dev": true, 1159 | "requires": { 1160 | "brace-expansion": "^1.1.7" 1161 | } 1162 | }, 1163 | "minimist": { 1164 | "version": "0.0.8", 1165 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1166 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1167 | "dev": true 1168 | }, 1169 | "mkdirp": { 1170 | "version": "0.5.1", 1171 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1172 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1173 | "dev": true, 1174 | "requires": { 1175 | "minimist": "0.0.8" 1176 | } 1177 | }, 1178 | "mocha": { 1179 | "version": "4.1.0", 1180 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-4.1.0.tgz", 1181 | "integrity": "sha512-0RVnjg1HJsXY2YFDoTNzcc1NKhYuXKRrBAG2gDygmJJA136Cs2QlRliZG1mA0ap7cuaT30mw16luAeln+4RiNA==", 1182 | "dev": true, 1183 | "requires": { 1184 | "browser-stdout": "1.3.0", 1185 | "commander": "2.11.0", 1186 | "debug": "3.1.0", 1187 | "diff": "3.3.1", 1188 | "escape-string-regexp": "1.0.5", 1189 | "glob": "7.1.2", 1190 | "growl": "1.10.3", 1191 | "he": "1.1.1", 1192 | "mkdirp": "0.5.1", 1193 | "supports-color": "4.4.0" 1194 | }, 1195 | "dependencies": { 1196 | "commander": { 1197 | "version": "2.11.0", 1198 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.11.0.tgz", 1199 | "integrity": "sha512-b0553uYA5YAEGgyYIGYROzKQ7X5RAqedkfjiZxwi0kL1g3bOaBNNZfYkzt/CL0umgD5wc9Jec2FbB98CjkMRvQ==", 1200 | "dev": true 1201 | }, 1202 | "diff": { 1203 | "version": "3.3.1", 1204 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.3.1.tgz", 1205 | "integrity": "sha512-MKPHZDMB0o6yHyDryUOScqZibp914ksXwAMYMTHj6KO8UeKsRYNJD3oNCKjTqZon+V488P7N/HzXF8t7ZR95ww==", 1206 | "dev": true 1207 | }, 1208 | "glob": { 1209 | "version": "7.1.2", 1210 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 1211 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 1212 | "dev": true, 1213 | "requires": { 1214 | "fs.realpath": "^1.0.0", 1215 | "inflight": "^1.0.4", 1216 | "inherits": "2", 1217 | "minimatch": "^3.0.4", 1218 | "once": "^1.3.0", 1219 | "path-is-absolute": "^1.0.0" 1220 | } 1221 | }, 1222 | "has-flag": { 1223 | "version": "2.0.0", 1224 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz", 1225 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=", 1226 | "dev": true 1227 | }, 1228 | "supports-color": { 1229 | "version": "4.4.0", 1230 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.4.0.tgz", 1231 | "integrity": "sha512-rKC3+DyXWgK0ZLKwmRsrkyHVZAjNkfzeehuFWdGGcqGDTZFH73+RH6S/RDAAxl9GusSjZSUWYLmT9N5pzXFOXQ==", 1232 | "dev": true, 1233 | "requires": { 1234 | "has-flag": "^2.0.0" 1235 | } 1236 | } 1237 | } 1238 | }, 1239 | "ms": { 1240 | "version": "2.0.0", 1241 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1242 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1243 | "dev": true 1244 | }, 1245 | "multimatch": { 1246 | "version": "2.1.0", 1247 | "resolved": "https://registry.npmjs.org/multimatch/-/multimatch-2.1.0.tgz", 1248 | "integrity": "sha1-nHkGoi+0wCkZ4vX3UWG0zb1LKis=", 1249 | "dev": true, 1250 | "requires": { 1251 | "array-differ": "^1.0.0", 1252 | "array-union": "^1.0.1", 1253 | "arrify": "^1.0.0", 1254 | "minimatch": "^3.0.0" 1255 | } 1256 | }, 1257 | "node.extend": { 1258 | "version": "1.1.8", 1259 | "resolved": "https://registry.npmjs.org/node.extend/-/node.extend-1.1.8.tgz", 1260 | "integrity": "sha512-L/dvEBwyg3UowwqOUTyDsGBU6kjBQOpOhshio9V3i3BMPv5YUb9+mWNN8MK0IbWqT0AqaTSONZf0aTuMMahWgA==", 1261 | "dev": true, 1262 | "requires": { 1263 | "has": "^1.0.3", 1264 | "is": "^3.2.1" 1265 | } 1266 | }, 1267 | "normalize-path": { 1268 | "version": "2.1.1", 1269 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 1270 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 1271 | "dev": true, 1272 | "requires": { 1273 | "remove-trailing-separator": "^1.0.1" 1274 | } 1275 | }, 1276 | "now-and-later": { 1277 | "version": "2.0.0", 1278 | "resolved": "https://registry.npmjs.org/now-and-later/-/now-and-later-2.0.0.tgz", 1279 | "integrity": "sha1-vGHLtFbXnLMiB85HygUTb/Ln1u4=", 1280 | "dev": true, 1281 | "requires": { 1282 | "once": "^1.3.2" 1283 | } 1284 | }, 1285 | "oauth-sign": { 1286 | "version": "0.9.0", 1287 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 1288 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", 1289 | "dev": true 1290 | }, 1291 | "object-keys": { 1292 | "version": "1.1.0", 1293 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.0.tgz", 1294 | "integrity": "sha512-6OO5X1+2tYkNyNEx6TsCxEqFfRWaqx6EtMiSbGrw8Ob8v9Ne+Hl8rBAgLBZn5wjEz3s/s6U1WXFUFOcxxAwUpg==", 1295 | "dev": true 1296 | }, 1297 | "object.assign": { 1298 | "version": "4.1.0", 1299 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1300 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1301 | "dev": true, 1302 | "requires": { 1303 | "define-properties": "^1.1.2", 1304 | "function-bind": "^1.1.1", 1305 | "has-symbols": "^1.0.0", 1306 | "object-keys": "^1.0.11" 1307 | } 1308 | }, 1309 | "once": { 1310 | "version": "1.4.0", 1311 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1312 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1313 | "dev": true, 1314 | "requires": { 1315 | "wrappy": "1" 1316 | } 1317 | }, 1318 | "ordered-read-streams": { 1319 | "version": "1.0.1", 1320 | "resolved": "https://registry.npmjs.org/ordered-read-streams/-/ordered-read-streams-1.0.1.tgz", 1321 | "integrity": "sha1-d8DLN8QVJdZBZtmQ/61+xqDhNj4=", 1322 | "dev": true, 1323 | "requires": { 1324 | "readable-stream": "^2.0.1" 1325 | } 1326 | }, 1327 | "path-dirname": { 1328 | "version": "1.0.2", 1329 | "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", 1330 | "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", 1331 | "dev": true 1332 | }, 1333 | "path-is-absolute": { 1334 | "version": "1.0.1", 1335 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1336 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1337 | "dev": true 1338 | }, 1339 | "path-parse": { 1340 | "version": "1.0.6", 1341 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1342 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 1343 | "dev": true 1344 | }, 1345 | "pause-stream": { 1346 | "version": "0.0.11", 1347 | "resolved": "https://registry.npmjs.org/pause-stream/-/pause-stream-0.0.11.tgz", 1348 | "integrity": "sha1-/lo0sMvOErWqaitAPuLnO2AvFEU=", 1349 | "dev": true, 1350 | "requires": { 1351 | "through": "~2.3" 1352 | } 1353 | }, 1354 | "pend": { 1355 | "version": "1.2.0", 1356 | "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", 1357 | "integrity": "sha1-elfrVQpng/kRUzH89GY9XI4AelA=", 1358 | "dev": true 1359 | }, 1360 | "performance-now": { 1361 | "version": "2.1.0", 1362 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 1363 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", 1364 | "dev": true 1365 | }, 1366 | "plugin-error": { 1367 | "version": "0.1.2", 1368 | "resolved": "https://registry.npmjs.org/plugin-error/-/plugin-error-0.1.2.tgz", 1369 | "integrity": "sha1-O5uzM1zPAPQl4HQ34ZJ2ln2kes4=", 1370 | "dev": true, 1371 | "requires": { 1372 | "ansi-cyan": "^0.1.1", 1373 | "ansi-red": "^0.1.1", 1374 | "arr-diff": "^1.0.1", 1375 | "arr-union": "^2.0.1", 1376 | "extend-shallow": "^1.1.2" 1377 | } 1378 | }, 1379 | "process-nextick-args": { 1380 | "version": "2.0.0", 1381 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 1382 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", 1383 | "dev": true 1384 | }, 1385 | "psl": { 1386 | "version": "1.1.31", 1387 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.1.31.tgz", 1388 | "integrity": "sha512-/6pt4+C+T+wZUieKR620OpzN/LlnNKuWjy1iFLQ/UG35JqHlR/89MP1d96dUfkf6Dne3TuLQzOYEYshJ+Hx8mw==", 1389 | "dev": true 1390 | }, 1391 | "pump": { 1392 | "version": "2.0.1", 1393 | "resolved": "https://registry.npmjs.org/pump/-/pump-2.0.1.tgz", 1394 | "integrity": "sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==", 1395 | "dev": true, 1396 | "requires": { 1397 | "end-of-stream": "^1.1.0", 1398 | "once": "^1.3.1" 1399 | } 1400 | }, 1401 | "pumpify": { 1402 | "version": "1.5.1", 1403 | "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-1.5.1.tgz", 1404 | "integrity": "sha512-oClZI37HvuUJJxSKKrC17bZ9Cu0ZYhEAGPsPUy9KlMUmv9dKX2o77RUmq7f3XjIxbwyGwYzbzQ1L2Ks8sIradQ==", 1405 | "dev": true, 1406 | "requires": { 1407 | "duplexify": "^3.6.0", 1408 | "inherits": "^2.0.3", 1409 | "pump": "^2.0.0" 1410 | } 1411 | }, 1412 | "punycode": { 1413 | "version": "2.1.1", 1414 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1415 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1416 | "dev": true 1417 | }, 1418 | "qs": { 1419 | "version": "6.5.2", 1420 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 1421 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", 1422 | "dev": true 1423 | }, 1424 | "queue": { 1425 | "version": "4.5.1", 1426 | "resolved": "https://registry.npmjs.org/queue/-/queue-4.5.1.tgz", 1427 | "integrity": "sha512-AMD7w5hRXcFSb8s9u38acBZ+309u6GsiibP4/0YacJeaurRshogB7v/ZcVPxP5gD5+zIw6ixRHdutiYUJfwKHw==", 1428 | "dev": true, 1429 | "requires": { 1430 | "inherits": "~2.0.0" 1431 | } 1432 | }, 1433 | "readable-stream": { 1434 | "version": "2.3.6", 1435 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 1436 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 1437 | "dev": true, 1438 | "requires": { 1439 | "core-util-is": "~1.0.0", 1440 | "inherits": "~2.0.3", 1441 | "isarray": "~1.0.0", 1442 | "process-nextick-args": "~2.0.0", 1443 | "safe-buffer": "~5.1.1", 1444 | "string_decoder": "~1.1.1", 1445 | "util-deprecate": "~1.0.1" 1446 | } 1447 | }, 1448 | "remove-bom-buffer": { 1449 | "version": "3.0.0", 1450 | "resolved": "https://registry.npmjs.org/remove-bom-buffer/-/remove-bom-buffer-3.0.0.tgz", 1451 | "integrity": "sha512-8v2rWhaakv18qcvNeli2mZ/TMTL2nEyAKRvzo1WtnZBl15SHyEhrCu2/xKlJyUFKHiHgfXIyuY6g2dObJJycXQ==", 1452 | "dev": true, 1453 | "requires": { 1454 | "is-buffer": "^1.1.5", 1455 | "is-utf8": "^0.2.1" 1456 | } 1457 | }, 1458 | "remove-bom-stream": { 1459 | "version": "1.2.0", 1460 | "resolved": "https://registry.npmjs.org/remove-bom-stream/-/remove-bom-stream-1.2.0.tgz", 1461 | "integrity": "sha1-BfGlk/FuQuH7kOv1nejlaVJflSM=", 1462 | "dev": true, 1463 | "requires": { 1464 | "remove-bom-buffer": "^3.0.0", 1465 | "safe-buffer": "^5.1.0", 1466 | "through2": "^2.0.3" 1467 | } 1468 | }, 1469 | "remove-trailing-separator": { 1470 | "version": "1.1.0", 1471 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 1472 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", 1473 | "dev": true 1474 | }, 1475 | "replace-ext": { 1476 | "version": "1.0.0", 1477 | "resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-1.0.0.tgz", 1478 | "integrity": "sha1-3mMSg3P8v3w8z6TeWkgMRaZ5WOs=", 1479 | "dev": true 1480 | }, 1481 | "request": { 1482 | "version": "2.88.0", 1483 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", 1484 | "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", 1485 | "dev": true, 1486 | "requires": { 1487 | "aws-sign2": "~0.7.0", 1488 | "aws4": "^1.8.0", 1489 | "caseless": "~0.12.0", 1490 | "combined-stream": "~1.0.6", 1491 | "extend": "~3.0.2", 1492 | "forever-agent": "~0.6.1", 1493 | "form-data": "~2.3.2", 1494 | "har-validator": "~5.1.0", 1495 | "http-signature": "~1.2.0", 1496 | "is-typedarray": "~1.0.0", 1497 | "isstream": "~0.1.2", 1498 | "json-stringify-safe": "~5.0.1", 1499 | "mime-types": "~2.1.19", 1500 | "oauth-sign": "~0.9.0", 1501 | "performance-now": "^2.1.0", 1502 | "qs": "~6.5.2", 1503 | "safe-buffer": "^5.1.2", 1504 | "tough-cookie": "~2.4.3", 1505 | "tunnel-agent": "^0.6.0", 1506 | "uuid": "^3.3.2" 1507 | } 1508 | }, 1509 | "requires-port": { 1510 | "version": "1.0.0", 1511 | "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", 1512 | "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=", 1513 | "dev": true 1514 | }, 1515 | "resolve": { 1516 | "version": "1.10.0", 1517 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.0.tgz", 1518 | "integrity": "sha512-3sUr9aq5OfSg2S9pNtPA9hL1FVEAjvfOC4leW0SNf/mpnaakz2a9femSd6LqAww2RaFctwyf1lCqnTHuF1rxDg==", 1519 | "dev": true, 1520 | "requires": { 1521 | "path-parse": "^1.0.6" 1522 | } 1523 | }, 1524 | "resolve-options": { 1525 | "version": "1.1.0", 1526 | "resolved": "https://registry.npmjs.org/resolve-options/-/resolve-options-1.1.0.tgz", 1527 | "integrity": "sha1-MrueOcBtZzONyTeMDW1gdFZq0TE=", 1528 | "dev": true, 1529 | "requires": { 1530 | "value-or-function": "^3.0.0" 1531 | } 1532 | }, 1533 | "rimraf": { 1534 | "version": "2.6.3", 1535 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1536 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1537 | "dev": true, 1538 | "requires": { 1539 | "glob": "^7.1.3" 1540 | } 1541 | }, 1542 | "safe-buffer": { 1543 | "version": "5.1.2", 1544 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1545 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1546 | "dev": true 1547 | }, 1548 | "safer-buffer": { 1549 | "version": "2.1.2", 1550 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1551 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1552 | "dev": true 1553 | }, 1554 | "semver": { 1555 | "version": "5.6.0", 1556 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz", 1557 | "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==", 1558 | "dev": true 1559 | }, 1560 | "source-map": { 1561 | "version": "0.6.1", 1562 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1563 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1564 | "dev": true 1565 | }, 1566 | "source-map-support": { 1567 | "version": "0.5.11", 1568 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.11.tgz", 1569 | "integrity": "sha512-//sajEx/fGL3iw6fltKMdPvy8kL3kJ2O3iuYlRoT3k9Kb4BjOoZ+BZzaNHeuaruSt+Kf3Zk9tnfAQg9/AJqUVQ==", 1570 | "dev": true, 1571 | "requires": { 1572 | "buffer-from": "^1.0.0", 1573 | "source-map": "^0.6.0" 1574 | } 1575 | }, 1576 | "split": { 1577 | "version": "0.3.3", 1578 | "resolved": "https://registry.npmjs.org/split/-/split-0.3.3.tgz", 1579 | "integrity": "sha1-zQ7qXmOiEd//frDwkcQTPi0N0o8=", 1580 | "dev": true, 1581 | "requires": { 1582 | "through": "2" 1583 | } 1584 | }, 1585 | "sprintf-js": { 1586 | "version": "1.0.3", 1587 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1588 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1589 | "dev": true 1590 | }, 1591 | "sshpk": { 1592 | "version": "1.16.1", 1593 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", 1594 | "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", 1595 | "dev": true, 1596 | "requires": { 1597 | "asn1": "~0.2.3", 1598 | "assert-plus": "^1.0.0", 1599 | "bcrypt-pbkdf": "^1.0.0", 1600 | "dashdash": "^1.12.0", 1601 | "ecc-jsbn": "~0.1.1", 1602 | "getpass": "^0.1.1", 1603 | "jsbn": "~0.1.0", 1604 | "safer-buffer": "^2.0.2", 1605 | "tweetnacl": "~0.14.0" 1606 | } 1607 | }, 1608 | "stat-mode": { 1609 | "version": "0.2.2", 1610 | "resolved": "https://registry.npmjs.org/stat-mode/-/stat-mode-0.2.2.tgz", 1611 | "integrity": "sha1-5sgLYjEj19gM8TLOU480YokHJQI=", 1612 | "dev": true 1613 | }, 1614 | "stream-combiner": { 1615 | "version": "0.0.4", 1616 | "resolved": "http://registry.npmjs.org/stream-combiner/-/stream-combiner-0.0.4.tgz", 1617 | "integrity": "sha1-TV5DPBhSYd3mI8o/RMWGvPXErRQ=", 1618 | "dev": true, 1619 | "requires": { 1620 | "duplexer": "~0.1.1" 1621 | } 1622 | }, 1623 | "stream-shift": { 1624 | "version": "1.0.0", 1625 | "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.0.tgz", 1626 | "integrity": "sha1-1cdSgl5TZ+eG944Y5EXqIjoVWVI=", 1627 | "dev": true 1628 | }, 1629 | "streamfilter": { 1630 | "version": "1.0.7", 1631 | "resolved": "https://registry.npmjs.org/streamfilter/-/streamfilter-1.0.7.tgz", 1632 | "integrity": "sha512-Gk6KZM+yNA1JpW0KzlZIhjo3EaBJDkYfXtYSbOwNIQ7Zd6006E6+sCFlW1NDvFG/vnXhKmw6TJJgiEQg/8lXfQ==", 1633 | "dev": true, 1634 | "requires": { 1635 | "readable-stream": "^2.0.2" 1636 | } 1637 | }, 1638 | "streamifier": { 1639 | "version": "0.1.1", 1640 | "resolved": "https://registry.npmjs.org/streamifier/-/streamifier-0.1.1.tgz", 1641 | "integrity": "sha1-l+mNj6TRBdYqJpHR3AfoINuN/E8=", 1642 | "dev": true 1643 | }, 1644 | "string_decoder": { 1645 | "version": "1.1.1", 1646 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1647 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1648 | "dev": true, 1649 | "requires": { 1650 | "safe-buffer": "~5.1.0" 1651 | } 1652 | }, 1653 | "strip-ansi": { 1654 | "version": "3.0.1", 1655 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 1656 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 1657 | "dev": true, 1658 | "requires": { 1659 | "ansi-regex": "^2.0.0" 1660 | } 1661 | }, 1662 | "supports-color": { 1663 | "version": "2.0.0", 1664 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 1665 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 1666 | "dev": true 1667 | }, 1668 | "tar": { 1669 | "version": "2.2.2", 1670 | "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.2.tgz", 1671 | "integrity": "sha512-FCEhQ/4rE1zYv9rYXJw/msRqsnmlje5jHP6huWeBZ704jUTy02c5AZyWujpMR1ax6mVw9NyJMfuK2CMDWVIfgA==", 1672 | "dev": true, 1673 | "requires": { 1674 | "block-stream": "*", 1675 | "fstream": "^1.0.12", 1676 | "inherits": "2" 1677 | } 1678 | }, 1679 | "through": { 1680 | "version": "2.3.8", 1681 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1682 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1683 | "dev": true 1684 | }, 1685 | "through2": { 1686 | "version": "2.0.5", 1687 | "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", 1688 | "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==", 1689 | "dev": true, 1690 | "requires": { 1691 | "readable-stream": "~2.3.6", 1692 | "xtend": "~4.0.1" 1693 | } 1694 | }, 1695 | "through2-filter": { 1696 | "version": "2.0.0", 1697 | "resolved": "https://registry.npmjs.org/through2-filter/-/through2-filter-2.0.0.tgz", 1698 | "integrity": "sha1-YLxVoNrLdghdsfna6Zq0P4PWIuw=", 1699 | "dev": true, 1700 | "requires": { 1701 | "through2": "~2.0.0", 1702 | "xtend": "~4.0.0" 1703 | } 1704 | }, 1705 | "to-absolute-glob": { 1706 | "version": "2.0.2", 1707 | "resolved": "https://registry.npmjs.org/to-absolute-glob/-/to-absolute-glob-2.0.2.tgz", 1708 | "integrity": "sha1-GGX0PZ50sIItufFFt4z/fQ98hJs=", 1709 | "dev": true, 1710 | "requires": { 1711 | "is-absolute": "^1.0.0", 1712 | "is-negated-glob": "^1.0.0" 1713 | } 1714 | }, 1715 | "to-through": { 1716 | "version": "2.0.0", 1717 | "resolved": "https://registry.npmjs.org/to-through/-/to-through-2.0.0.tgz", 1718 | "integrity": "sha1-/JKtq6ByZHvAtn1rA2ZKoZUJOvY=", 1719 | "dev": true, 1720 | "requires": { 1721 | "through2": "^2.0.3" 1722 | } 1723 | }, 1724 | "tough-cookie": { 1725 | "version": "2.4.3", 1726 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", 1727 | "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", 1728 | "dev": true, 1729 | "requires": { 1730 | "psl": "^1.1.24", 1731 | "punycode": "^1.4.1" 1732 | }, 1733 | "dependencies": { 1734 | "punycode": { 1735 | "version": "1.4.1", 1736 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 1737 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", 1738 | "dev": true 1739 | } 1740 | } 1741 | }, 1742 | "tslib": { 1743 | "version": "1.9.3", 1744 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz", 1745 | "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==", 1746 | "dev": true 1747 | }, 1748 | "tslint": { 1749 | "version": "5.14.0", 1750 | "resolved": "https://registry.npmjs.org/tslint/-/tslint-5.14.0.tgz", 1751 | "integrity": "sha512-IUla/ieHVnB8Le7LdQFRGlVJid2T/gaJe5VkjzRVSRR6pA2ODYrnfR1hmxi+5+au9l50jBwpbBL34txgv4NnTQ==", 1752 | "dev": true, 1753 | "requires": { 1754 | "babel-code-frame": "^6.22.0", 1755 | "builtin-modules": "^1.1.1", 1756 | "chalk": "^2.3.0", 1757 | "commander": "^2.12.1", 1758 | "diff": "^3.2.0", 1759 | "glob": "^7.1.1", 1760 | "js-yaml": "^3.7.0", 1761 | "minimatch": "^3.0.4", 1762 | "mkdirp": "^0.5.1", 1763 | "resolve": "^1.3.2", 1764 | "semver": "^5.3.0", 1765 | "tslib": "^1.8.0", 1766 | "tsutils": "^2.29.0" 1767 | } 1768 | }, 1769 | "tsutils": { 1770 | "version": "2.29.0", 1771 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-2.29.0.tgz", 1772 | "integrity": "sha512-g5JVHCIJwzfISaXpXE1qvNalca5Jwob6FjI4AoPlqMusJ6ftFE7IkkFoMhVLRgK+4Kx3gkzb8UZK5t5yTTvEmA==", 1773 | "dev": true, 1774 | "requires": { 1775 | "tslib": "^1.8.1" 1776 | } 1777 | }, 1778 | "tunnel-agent": { 1779 | "version": "0.6.0", 1780 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 1781 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 1782 | "dev": true, 1783 | "requires": { 1784 | "safe-buffer": "^5.0.1" 1785 | } 1786 | }, 1787 | "tweetnacl": { 1788 | "version": "0.14.5", 1789 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 1790 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 1791 | "dev": true 1792 | }, 1793 | "typescript": { 1794 | "version": "3.3.3333", 1795 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.3.3333.tgz", 1796 | "integrity": "sha512-JjSKsAfuHBE/fB2oZ8NxtRTk5iGcg6hkYXMnZ3Wc+b2RSqejEqTaem11mHASMnFilHrax3sLK0GDzcJrekZYLw==", 1797 | "dev": true 1798 | }, 1799 | "unc-path-regex": { 1800 | "version": "0.1.2", 1801 | "resolved": "https://registry.npmjs.org/unc-path-regex/-/unc-path-regex-0.1.2.tgz", 1802 | "integrity": "sha1-5z3T17DXxe2G+6xrCufYxqadUPo=", 1803 | "dev": true 1804 | }, 1805 | "unique-stream": { 1806 | "version": "2.2.1", 1807 | "resolved": "https://registry.npmjs.org/unique-stream/-/unique-stream-2.2.1.tgz", 1808 | "integrity": "sha1-WqADz76Uxf+GbE59ZouxxNuts2k=", 1809 | "dev": true, 1810 | "requires": { 1811 | "json-stable-stringify": "^1.0.0", 1812 | "through2-filter": "^2.0.0" 1813 | } 1814 | }, 1815 | "uri-js": { 1816 | "version": "4.2.2", 1817 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1818 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1819 | "dev": true, 1820 | "requires": { 1821 | "punycode": "^2.1.0" 1822 | } 1823 | }, 1824 | "url-parse": { 1825 | "version": "1.5.1", 1826 | "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.1.tgz", 1827 | "integrity": "sha512-HOfCOUJt7iSYzEx/UqgtwKRMC6EU91NFhsCHMv9oM03VJcVo2Qrp8T8kI9D7amFf1cu+/3CEhgb3rF9zL7k85Q==", 1828 | "dev": true, 1829 | "requires": { 1830 | "querystringify": "^2.1.1", 1831 | "requires-port": "^1.0.0" 1832 | }, 1833 | "dependencies": { 1834 | "querystringify": { 1835 | "version": "2.2.0", 1836 | "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz", 1837 | "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==", 1838 | "dev": true 1839 | } 1840 | } 1841 | }, 1842 | "util-deprecate": { 1843 | "version": "1.0.2", 1844 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1845 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 1846 | "dev": true 1847 | }, 1848 | "uuid": { 1849 | "version": "3.3.2", 1850 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 1851 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==", 1852 | "dev": true 1853 | }, 1854 | "value-or-function": { 1855 | "version": "3.0.0", 1856 | "resolved": "https://registry.npmjs.org/value-or-function/-/value-or-function-3.0.0.tgz", 1857 | "integrity": "sha1-HCQ6ULWVwb5Up1S/7OhWO5/42BM=", 1858 | "dev": true 1859 | }, 1860 | "verror": { 1861 | "version": "1.10.0", 1862 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 1863 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 1864 | "dev": true, 1865 | "requires": { 1866 | "assert-plus": "^1.0.0", 1867 | "core-util-is": "1.0.2", 1868 | "extsprintf": "^1.2.0" 1869 | } 1870 | }, 1871 | "vinyl": { 1872 | "version": "0.4.6", 1873 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-0.4.6.tgz", 1874 | "integrity": "sha1-LzVsh6VQolVGHza76ypbqL94SEc=", 1875 | "dev": true, 1876 | "requires": { 1877 | "clone": "^0.2.0", 1878 | "clone-stats": "^0.0.1" 1879 | } 1880 | }, 1881 | "vinyl-fs": { 1882 | "version": "3.0.3", 1883 | "resolved": "https://registry.npmjs.org/vinyl-fs/-/vinyl-fs-3.0.3.tgz", 1884 | "integrity": "sha512-vIu34EkyNyJxmP0jscNzWBSygh7VWhqun6RmqVfXePrOwi9lhvRs//dOaGOTRUQr4tx7/zd26Tk5WeSVZitgng==", 1885 | "dev": true, 1886 | "requires": { 1887 | "fs-mkdirp-stream": "^1.0.0", 1888 | "glob-stream": "^6.1.0", 1889 | "graceful-fs": "^4.0.0", 1890 | "is-valid-glob": "^1.0.0", 1891 | "lazystream": "^1.0.0", 1892 | "lead": "^1.0.0", 1893 | "object.assign": "^4.0.4", 1894 | "pumpify": "^1.3.5", 1895 | "readable-stream": "^2.3.3", 1896 | "remove-bom-buffer": "^3.0.0", 1897 | "remove-bom-stream": "^1.2.0", 1898 | "resolve-options": "^1.1.0", 1899 | "through2": "^2.0.0", 1900 | "to-through": "^2.0.0", 1901 | "value-or-function": "^3.0.0", 1902 | "vinyl": "^2.0.0", 1903 | "vinyl-sourcemap": "^1.1.0" 1904 | }, 1905 | "dependencies": { 1906 | "clone": { 1907 | "version": "2.1.2", 1908 | "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.2.tgz", 1909 | "integrity": "sha1-G39Ln1kfHo+DZwQBYANFoCiHQ18=", 1910 | "dev": true 1911 | }, 1912 | "clone-stats": { 1913 | "version": "1.0.0", 1914 | "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-1.0.0.tgz", 1915 | "integrity": "sha1-s3gt/4u1R04Yuba/D9/ngvh3doA=", 1916 | "dev": true 1917 | }, 1918 | "vinyl": { 1919 | "version": "2.2.0", 1920 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-2.2.0.tgz", 1921 | "integrity": "sha512-MBH+yP0kC/GQ5GwBqrTPTzEfiiLjta7hTtvQtbxBgTeSXsmKQRQecjibMbxIXzVT3Y9KJK+drOz1/k+vsu8Nkg==", 1922 | "dev": true, 1923 | "requires": { 1924 | "clone": "^2.1.1", 1925 | "clone-buffer": "^1.0.0", 1926 | "clone-stats": "^1.0.0", 1927 | "cloneable-readable": "^1.0.0", 1928 | "remove-trailing-separator": "^1.0.1", 1929 | "replace-ext": "^1.0.0" 1930 | } 1931 | } 1932 | } 1933 | }, 1934 | "vinyl-source-stream": { 1935 | "version": "1.1.2", 1936 | "resolved": "https://registry.npmjs.org/vinyl-source-stream/-/vinyl-source-stream-1.1.2.tgz", 1937 | "integrity": "sha1-YrU6E1YQqJbpjKlr7jqH8Aio54A=", 1938 | "dev": true, 1939 | "requires": { 1940 | "through2": "^2.0.3", 1941 | "vinyl": "^0.4.3" 1942 | } 1943 | }, 1944 | "vinyl-sourcemap": { 1945 | "version": "1.1.0", 1946 | "resolved": "https://registry.npmjs.org/vinyl-sourcemap/-/vinyl-sourcemap-1.1.0.tgz", 1947 | "integrity": "sha1-kqgAWTo4cDqM2xHYswCtS+Y7PhY=", 1948 | "dev": true, 1949 | "requires": { 1950 | "append-buffer": "^1.0.2", 1951 | "convert-source-map": "^1.5.0", 1952 | "graceful-fs": "^4.1.6", 1953 | "normalize-path": "^2.1.1", 1954 | "now-and-later": "^2.0.0", 1955 | "remove-bom-buffer": "^3.0.0", 1956 | "vinyl": "^2.0.0" 1957 | }, 1958 | "dependencies": { 1959 | "clone": { 1960 | "version": "2.1.2", 1961 | "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.2.tgz", 1962 | "integrity": "sha1-G39Ln1kfHo+DZwQBYANFoCiHQ18=", 1963 | "dev": true 1964 | }, 1965 | "clone-stats": { 1966 | "version": "1.0.0", 1967 | "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-1.0.0.tgz", 1968 | "integrity": "sha1-s3gt/4u1R04Yuba/D9/ngvh3doA=", 1969 | "dev": true 1970 | }, 1971 | "vinyl": { 1972 | "version": "2.2.0", 1973 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-2.2.0.tgz", 1974 | "integrity": "sha512-MBH+yP0kC/GQ5GwBqrTPTzEfiiLjta7hTtvQtbxBgTeSXsmKQRQecjibMbxIXzVT3Y9KJK+drOz1/k+vsu8Nkg==", 1975 | "dev": true, 1976 | "requires": { 1977 | "clone": "^2.1.1", 1978 | "clone-buffer": "^1.0.0", 1979 | "clone-stats": "^1.0.0", 1980 | "cloneable-readable": "^1.0.0", 1981 | "remove-trailing-separator": "^1.0.1", 1982 | "replace-ext": "^1.0.0" 1983 | } 1984 | } 1985 | } 1986 | }, 1987 | "vscode": { 1988 | "version": "1.1.30", 1989 | "resolved": "https://registry.npmjs.org/vscode/-/vscode-1.1.30.tgz", 1990 | "integrity": "sha512-YDj5w0TGOcS8XLIdekT4q6LlLV6hv1ZvuT2aGT3KJll4gMz6dUPDgo2VVAf0i0E8igbbZthwvmaUGRwW9yPIaw==", 1991 | "dev": true, 1992 | "requires": { 1993 | "glob": "^7.1.2", 1994 | "gulp-chmod": "^2.0.0", 1995 | "gulp-filter": "^5.0.1", 1996 | "gulp-gunzip": "1.0.0", 1997 | "gulp-remote-src-vscode": "^0.5.1", 1998 | "gulp-untar": "^0.0.7", 1999 | "gulp-vinyl-zip": "^2.1.2", 2000 | "mocha": "^4.0.1", 2001 | "request": "^2.88.0", 2002 | "semver": "^5.4.1", 2003 | "source-map-support": "^0.5.0", 2004 | "url-parse": "^1.4.3", 2005 | "vinyl-fs": "^3.0.3", 2006 | "vinyl-source-stream": "^1.1.0" 2007 | } 2008 | }, 2009 | "vscode-cpptools": { 2010 | "version": "2.1.2", 2011 | "resolved": "https://registry.npmjs.org/vscode-cpptools/-/vscode-cpptools-2.1.2.tgz", 2012 | "integrity": "sha512-oMx/wsLQM6NggnmWn4t8lIrt1K7Zpl5G34zxNu+J6KHGnCxBzc+NHnxXS1Vu1hLxGWwANAvdxr3mEcA2LMe7hQ==", 2013 | "dev": true 2014 | }, 2015 | "vscode-debugadapter": { 2016 | "version": "1.33.0", 2017 | "resolved": "https://registry.npmjs.org/vscode-debugadapter/-/vscode-debugadapter-1.33.0.tgz", 2018 | "integrity": "sha512-GsSD6PyVokjyW+7LU3FRXbu8SINv9muQtMQEDvwB6SIGQfrQzld8kECpQRr71j3mgXW+sTY+44/XMzueeaU6/Q==", 2019 | "dev": true, 2020 | "requires": { 2021 | "mkdirp": "^0.5.1", 2022 | "vscode-debugprotocol": "1.33.0" 2023 | } 2024 | }, 2025 | "vscode-debugprotocol": { 2026 | "version": "1.33.0", 2027 | "resolved": "https://registry.npmjs.org/vscode-debugprotocol/-/vscode-debugprotocol-1.33.0.tgz", 2028 | "integrity": "sha512-d+l4lrEz6OP2kmGpweqe37x9H7icAMV8S4m8azTWGAIlNJxBP4rlSTnZa7NMLcbgqWkWG9lTGY7fJ+rSPaW7yg==", 2029 | "dev": true 2030 | }, 2031 | "wrappy": { 2032 | "version": "1.0.2", 2033 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2034 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2035 | "dev": true 2036 | }, 2037 | "xtend": { 2038 | "version": "4.0.1", 2039 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 2040 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=", 2041 | "dev": true 2042 | }, 2043 | "yauzl": { 2044 | "version": "2.10.0", 2045 | "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz", 2046 | "integrity": "sha1-x+sXyT4RLLEIb6bY5R+wZnt5pfk=", 2047 | "dev": true, 2048 | "requires": { 2049 | "buffer-crc32": "~0.2.3", 2050 | "fd-slicer": "~1.1.0" 2051 | } 2052 | }, 2053 | "yazl": { 2054 | "version": "2.5.1", 2055 | "resolved": "https://registry.npmjs.org/yazl/-/yazl-2.5.1.tgz", 2056 | "integrity": "sha512-phENi2PLiHnHb6QBVot+dJnaAZ0xosj7p3fWl+znIjBDlnMI2PsZCJZ306BPTFOaHf5qdDEI8x5qFrSOBN5vrw==", 2057 | "dev": true, 2058 | "requires": { 2059 | "buffer-crc32": "~0.2.3" 2060 | } 2061 | } 2062 | } 2063 | } 2064 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "adv-cppdbg", 3 | "displayName": "adv-cppdbg", 4 | "description": "VSCode Extension for advanced C/C++ debugging", 5 | "version": "0.0.2", 6 | "publisher": "haneefdm", 7 | "engines": { 8 | "vscode": "^1.32.0" 9 | }, 10 | "license": "MIT", 11 | "repository": { 12 | "type": "git", 13 | "url": "https://github.com/haneefdm/adv-cppdbg.git" 14 | }, 15 | "activationEvents": [ 16 | "onDebugResolve:cppdbg", 17 | "onCommand:adv-cppdbg.hello" 18 | ], 19 | "categories": [ 20 | "Debuggers", 21 | "Other" 22 | ], 23 | "main": "./out/extension.js", 24 | "contributes": { 25 | "commands": [ 26 | { 27 | "command": "adv-cpp.refresh", 28 | "title": "Adv-Cppdbg: Refresh" 29 | } 30 | ], 31 | "views": { 32 | "debug": [ 33 | { 34 | "id": "adv-cppdbg.registers", 35 | "name": "Registers", 36 | "when": "debugType == cppdbg" 37 | } 38 | ] 39 | }, 40 | "configuration": { 41 | "type": "object", 42 | "title": "Advanced CppDbg Configuration", 43 | "properties": { 44 | "adv-cppdbg.debugLevel": { 45 | "type": "integer", 46 | "default": 1, 47 | "description": "Enables printing extension debugging information to the console. Valid values 0-3" 48 | }, 49 | "adv-cppdbg.disableRegisterView": { 50 | "type": "boolean", 51 | "default": false, 52 | "description": "Disables showing the Registers View" 53 | } 54 | } 55 | } 56 | }, 57 | "scripts": { 58 | "vscode:prepublish": "npm run compile", 59 | "compile": "tsc -p ./", 60 | "watch": "tsc -watch -p ./", 61 | "postinstall": "node ./node_modules/vscode/bin/install", 62 | "test": "npm run compile && node ./node_modules/vscode/bin/test" 63 | }, 64 | "devDependencies": { 65 | "typescript": "^3.3.1", 66 | "vscode": "^1.1.28", 67 | "vscode-cpptools": "^2.1.2", 68 | "vscode-debugadapter": "~1.33.0", 69 | "vscode-debugprotocol": "~1.33.0", 70 | "tslint": "^5.12.1", 71 | "@types/node": "^10.12.21", 72 | "@types/mocha": "^2.2.42", 73 | "performance-now": "^2.1.0" 74 | } 75 | } 76 | -------------------------------------------------------------------------------- /src/config.ts: -------------------------------------------------------------------------------- 1 | import * as vscode from 'vscode'; 2 | 3 | export class ConfigVars { 4 | public static debugLevel : number = 2; 5 | public static disableRegisterView: boolean = false; 6 | 7 | static initConfigVars() : void { 8 | const configuration = vscode.workspace.getConfiguration('adv-cppdbg'); 9 | if (configuration) { 10 | if (configuration.debugLevel !== undefined) { 11 | ConfigVars.debugLevel = configuration.debugLevel; 12 | } 13 | if (configuration.disableRegisterView !== undefined) { 14 | ConfigVars.disableRegisterView = configuration.disableRegisterView; 15 | } 16 | } 17 | } 18 | } -------------------------------------------------------------------------------- /src/da-tracker.ts: -------------------------------------------------------------------------------- 1 | // 2 | // This file contains a tracker for a debug adapter that exists somewher else. 3 | // We are interested in state change of the debugger 4 | // 5 | // Much of the code assumes we are tracking a C/C++ debugger 6 | // 7 | 8 | import * as vscode from 'vscode'; 9 | import { DebugProtocol } from 'vscode-debugprotocol'; 10 | import { DebugAdapterTrackerFactory, DebugAdapterTracker } from 'vscode'; 11 | import { ConfigVars } from './config'; 12 | 13 | export enum DbgAdapterState { 14 | Unknown, 15 | Running, 16 | Stopped 17 | } 18 | 19 | export class CppDbgDebugAdapterTracker implements DebugAdapterTracker { 20 | private _dbgRunningState: DbgAdapterState = DbgAdapterState.Unknown; 21 | public get dbgRunningState(): DbgAdapterState { 22 | return this._dbgRunningState; 23 | } 24 | 25 | private _trackRegisterQueries: boolean = false; 26 | public get trackRegisterQueries(): boolean { 27 | return this._trackRegisterQueries; 28 | } 29 | public set trackRegisterQueries(value: boolean) { 30 | this._trackRegisterQueries = value; 31 | if (value === true) { 32 | // Clear any previously cached stuff 33 | this.trackedRegisterNames = []; 34 | this.trackedRegisterValues.clear(); 35 | } 36 | } 37 | 38 | public trackedRegisterNames: string[] = []; 39 | public trackedRegisterValues = new Map(); 40 | public onStateChanged: vscode.EventEmitter; 41 | constructor() { 42 | this.onStateChanged = new vscode.EventEmitter(); 43 | } 44 | 45 | protected _dbgSetRunningState(value: DbgAdapterState) { 46 | if (value !== this._dbgRunningState) { 47 | this._dbgRunningState = value; 48 | if (ConfigVars.debugLevel > 0) { 49 | console.log('CppDbgDebugAdapterTracker: state changed to ' + DbgAdapterState[value]); 50 | } 51 | this.onStateChanged.fire(this); 52 | } 53 | } 54 | 55 | /** 56 | * A session with the debug adapter is about to be started. 57 | */ 58 | onWillStartSession?(): void { 59 | if (ConfigVars.debugLevel > 0) { 60 | console.log('onWillStartSession called'); 61 | } 62 | } 63 | /** 64 | * The debug adapter is about to receive a Debug Adapter Protocol message from VS Code. 65 | */ 66 | onWillReceiveMessage?(message: any): void { 67 | //if (message) { 68 | // console.log('onWillReceiveMessage called ' + message.command); 69 | //} 70 | } 71 | /** 72 | * The debug adapter has sent a Debug Adapter Protocol message to VS Code. 73 | */ 74 | onDidSendMessage?(_msg: any): void { 75 | const message = _msg as DebugProtocol.ProtocolMessage; 76 | if (!message) { 77 | if (ConfigVars.debugLevel > 0) { 78 | console.log('Huh?: arg is not a DebugProtocol.ProtocolMessage type? ' + JSON.stringify(_msg)); 79 | } 80 | return; 81 | } 82 | switch (message.type) { 83 | case 'event': { 84 | this.handleDAEvent(message); 85 | break; 86 | } 87 | case 'response': { 88 | this.handleDAResponse(message); 89 | break; 90 | } 91 | default: { 92 | console.log('Unhandled Message type ' + message.type); 93 | break; 94 | } 95 | } 96 | } 97 | /** 98 | * The debug adapter session is about to be stopped. 99 | */ 100 | onWillStopSession?(): void { 101 | if (ConfigVars.debugLevel > 0) { 102 | console.log('onWillStopSession called'); 103 | } 104 | } 105 | /** 106 | * An error with the debug adapter has occurred. 107 | */ 108 | onError?(error: Error): void { 109 | if (ConfigVars.debugLevel > 0) { 110 | console.log('onError called ' + error); 111 | } 112 | } 113 | /** 114 | * The debug adapter has exited with the given exit code or signal. 115 | */ 116 | onExit?(code: number | undefined, signal: string | undefined): void { 117 | if (ConfigVars.debugLevel > 0) { 118 | console.log('onExit called code=' + code + ', signal=', signal); 119 | } 120 | this._dbgSetRunningState(DbgAdapterState.Unknown); 121 | } 122 | 123 | handleDAResponse(message: DebugProtocol.ProtocolMessage) : void { 124 | const rsp: DebugProtocol.Response = message as DebugProtocol.Response; 125 | //console.log('*** Got response for command: ' + rsp.command + ' Success:' + rsp.success); 126 | if (!rsp.success) { 127 | if (ConfigVars.debugLevel > 0) { 128 | console.log('****** Failed response, Details: ' + JSON.stringify(message)); 129 | } 130 | } 131 | switch (rsp.command) { 132 | case 'launch': 133 | case 'continue': 134 | case 'next': 135 | case 'step': { 136 | if (rsp.success) { 137 | this._dbgSetRunningState(DbgAdapterState.Running); 138 | } 139 | break; 140 | } 141 | case 'disconnect': 142 | case 'exited': { 143 | this._dbgSetRunningState(DbgAdapterState.Unknown); 144 | break; 145 | } 146 | case 'threads': { 147 | break; 148 | } 149 | case 'stackTrace': { 150 | break; 151 | } 152 | case 'scopes': { 153 | break; 154 | } 155 | case 'configurationDone': { 156 | break; 157 | } 158 | case 'setBreakpoints': { 159 | break; 160 | } 161 | case 'setFunctionBreakpoints': { 162 | break; 163 | } 164 | case 'setExceptionBreakpoints': { 165 | break; 166 | } 167 | case 'variables': { 168 | break; 169 | } 170 | case 'evaluate': { 171 | break; 172 | } 173 | case 'initialize': { 174 | break; 175 | } 176 | default: { 177 | if (ConfigVars.debugLevel > 0) { 178 | console.log('*** Unhandled response command: ' + rsp.command); 179 | } 180 | break; 181 | } 182 | } 183 | } 184 | 185 | handleDAEvent(message: DebugProtocol.ProtocolMessage) : void { 186 | const ev: DebugProtocol.Event = message as DebugProtocol.Event; 187 | switch (ev.event) { 188 | case 'output': { 189 | const outEv: DebugProtocol.OutputEvent = ev as DebugProtocol.OutputEvent; 190 | if (this.trackRegisterQueries && outEv && outEv.body.category === 'stdout') { 191 | this.parseRegisterQueries(outEv); 192 | } 193 | break; 194 | } 195 | case 'stopped': { 196 | this._dbgSetRunningState(DbgAdapterState.Stopped); 197 | const stoppedEvent = ev as DebugProtocol.StoppedEvent; 198 | if (ConfigVars.debugLevel > 0) { 199 | console.log('Event: Stopped: Reason: ' + stoppedEvent.body.reason); 200 | console.log('====> ' + JSON.stringify(ev)); 201 | } 202 | break; 203 | } 204 | case 'continued': { 205 | this._dbgSetRunningState(DbgAdapterState.Running); 206 | // This is rarely called but track it anyway. See Protocol description 207 | const continuedEvent = ev as DebugProtocol.ContinuedEvent; 208 | if (ConfigVars.debugLevel > 0) { 209 | console.log('Event: Continued: ' + JSON.stringify(ev)); 210 | } 211 | break; 212 | } 213 | case 'initialized': { 214 | break; 215 | } 216 | case 'breakpoint': { 217 | break; 218 | } 219 | case 'thread': { 220 | break; 221 | } 222 | case 'terminated': { 223 | this._dbgSetRunningState(DbgAdapterState.Unknown); 224 | break; 225 | } 226 | default: { 227 | console.log('Unhandled Event type ' + ev.event + ', ' + ev); 228 | break; 229 | } 230 | } 231 | } 232 | 233 | protected parseRegisterQueries(outEv: DebugProtocol.OutputEvent) { 234 | let outStr = outEv.body.output; 235 | const reg_vlues_key = 'register-values: '; 236 | const values_pos = outStr.indexOf(reg_vlues_key); 237 | if (values_pos >= 0) { 238 | //console.log('+++++ reg_values-full: ' + outStr); 239 | outStr = outStr.substr(reg_vlues_key.length + values_pos); 240 | let rexp = /\{[^}]*\}/g; 241 | const match = outStr.match(rexp); 242 | const reg_values = new Map(); 243 | if (match && (match.length > 0)) { 244 | rexp = /\{number=([0-9]+),value=([^}]*)\}/; 245 | match.forEach((pair) => { 246 | const nv_match = pair.match(rexp); 247 | if (nv_match) { 248 | reg_values.set(+nv_match[1], nv_match[2]); 249 | } 250 | }); 251 | } 252 | 253 | this.trackedRegisterValues = reg_values; 254 | 255 | if (ConfigVars.debugLevel > 1) { 256 | for (let [key, value] of reg_values) { 257 | console.log(key, value); 258 | } 259 | } 260 | outEv.body.output = ''; 261 | return; 262 | } 263 | 264 | const reg_names_key = 'register-names: '; 265 | outStr = outEv.body.output; 266 | if (outStr.indexOf(reg_names_key) >= 0) { 267 | const rexp = /\[(.*)\]/; 268 | const match = outStr.match(rexp); 269 | if (match && (match.length === 2)) { 270 | this.trackedRegisterNames = match[1].split(','); 271 | if (ConfigVars.debugLevel > 1) { 272 | console.log('+++++ Found-reg-names ' + JSON.stringify(this.trackedRegisterNames)); 273 | } 274 | } 275 | outEv.body.output = ''; 276 | return; 277 | } 278 | } 279 | } 280 | 281 | export class CppDbgAdapterTrackerFactory implements DebugAdapterTrackerFactory { 282 | public DATracker: CppDbgDebugAdapterTracker = new CppDbgDebugAdapterTracker(); 283 | createDebugAdapterTracker(s: vscode.DebugSession): vscode.ProviderResult { 284 | return this.DATracker; 285 | } 286 | } 287 | -------------------------------------------------------------------------------- /src/extension.ts: -------------------------------------------------------------------------------- 1 | // The module 'vscode' contains the VS Code extensibility API 2 | // Import the module and reference it with the alias vscode in your code below 3 | import * as vscode from 'vscode'; 4 | import * as monitor from './monitor'; 5 | import { ConfigVars } from './config'; 6 | 7 | //import {CppToolsApi, Version, CustomConfigurationProvider, getCppToolsApi} from 'vscode-cpptools'; 8 | 9 | var dbgMonitor : monitor.MonitorDbgEvents; 10 | // this method is called when your extension is activated 11 | // your extension is activated the very first time the command is executed 12 | export function activate(context: vscode.ExtensionContext) { 13 | // Use the console to output diagnostic information (console.log) and errors (console.error) 14 | // This line of code will only be executed once when your extension is activated 15 | console.log('"adv-cppdbg" extension is now active!'); 16 | 17 | ConfigVars.initConfigVars(); 18 | dbgMonitor = new monitor.MonitorDbgEvents(context); 19 | 20 | // The command has been defined in the package.json file 21 | // Now provide the implementation of the command with registerCommand 22 | // The commandId parameter must match the command field in package.json 23 | let disposable = vscode.commands.registerCommand('adv-cpp.refresh', dbgMonitor.sendRequest.bind(dbgMonitor)); 24 | 25 | context.subscriptions.push(disposable); 26 | } 27 | 28 | // this method is called when your extension is deactivated 29 | export function deactivate() { 30 | console.log('"adv-cppdbg" extentions is now deactivated!'); 31 | } 32 | -------------------------------------------------------------------------------- /src/monitor.ts: -------------------------------------------------------------------------------- 1 | /// 2 | /// This is in no way production ready code and will be split up into 3 | /// multiple re-usable files. It is currently a demo for what is possible. 4 | /// Until we have proper APIs from VSCode, it is neither fully functional 5 | /// *manual* refresh required, nor is it very efficient 6 | /// 7 | import * as vscode from 'vscode'; 8 | import { DebugProtocol } from 'vscode-debugprotocol'; 9 | //import { DebugSession, InitializedEvent } from 'vscode-debugadapter'; 10 | import { CppDbgAdapterTrackerFactory, CppDbgDebugAdapterTracker, DbgAdapterState } from './da-tracker'; 11 | import { ConfigVars } from './config'; 12 | 13 | export class MyTreeNode extends vscode.TreeItem { 14 | value: string = ':-(('; 15 | children : MyTreeNode[] = [] ; 16 | constructor( 17 | public readonly name: string, 18 | public readonly collapsibleState: vscode.TreeItemCollapsibleState = vscode.TreeItemCollapsibleState.None,) { 19 | super(name, collapsibleState); 20 | } 21 | } 22 | 23 | export class RegisterView implements vscode.TreeDataProvider { 24 | // I don't know what the set of registers are valid for a given cpu. and what we should actually 25 | // display. Hate this hardcoded stuff but this is what I got for now. 26 | static armRegs = [ 27 | "r0","r1","r2","r3","r4","r5","r6","r7","r8","r9","r10","r11","r12","sp","lr","pc", 28 | "xpsr","msp","psp","primask","basepri","faultmask","control","fpscr","s0","s1","s2", 29 | "s3","s4","s5","s6","s7","s8","s9","s10","s11","s12","s13","s14","s15","s16","s17", 30 | "s18","s19","s20","s21","s22","s23","s24","s25","s26","s27","s28","s29","s30","s31", 31 | "d0","d1","d2","d3","d4","d5","d6","d7","d8","d9","d10","d11","d12","d13","d14","d15" 32 | ]; 33 | static x64Regs = [ 34 | "rax","rbx","rcx","rdx","rdi","rsi","rbp","rsp","r8","r9","r10","r11","r12","r13","r14","r15", 35 | "rip","rflags","cs","fs","gs","eax","ebx","ecx","edx","edi","esi","ebp","esp","r8d","r9d", 36 | "r10d","r11d","r12d","r13d","r14d","r15d","ax","bx","cx","dx","di","si","bp","sp","r8w", 37 | "r9w","r10w","r11w","r12w","r13w","r14w","r15w","ah","bh","ch","dh","al","bl","cl","dl","dil", 38 | "sil","bpl","spl","r8l","r9l","r10l","r11l","r12l","r13l","r14l","r15l","fctrl","fstat", 39 | "ftag","fop","fioff","fiseg","fooff","foseg","mxcsr","mxcsrmask","stmm0","stmm1","stmm2", 40 | "stmm3","stmm4","stmm5","stmm6","stmm7","ymm0","ymm1","ymm2","ymm3","ymm4","ymm5","ymm6", 41 | "ymm7","ymm8","ymm9","ymm10","ymm11","ymm12","ymm13","ymm14","ymm15","xmm0","xmm1","xmm2", 42 | "xmm3","xmm4","xmm5","xmm6","xmm7","xmm8","xmm9","xmm10","xmm11","xmm12","xmm13","xmm14", 43 | "xmm15","trapno","err","faultvaddr" 44 | ]; 45 | static x32Regs = [ 46 | "eax","ecx","edx","ebx","esp","ebp","esi","edi","eip", 47 | "eflags","cs","ss","ds","es","fs","gs" 48 | ]; 49 | 50 | private orig_regnames: string[] = []; // Original list of names as reported by GDB. Can have empty strings 51 | private regnames: string[] = [] ; // non-empty names 52 | private regmap = new Map(); // non-empty name to index in regnames/items 53 | public initialized: boolean = false ; 54 | public onDidChangeTreeDataEmitter: vscode.EventEmitter = new vscode.EventEmitter(); 55 | public readonly onDidChangeTreeData: vscode.Event = this.onDidChangeTreeDataEmitter.event; 56 | items: MyTreeNode[] = [] ; 57 | 58 | constructor(protected DAtracker: CppDbgDebugAdapterTracker) { 59 | this.onDidChangeTreeData(this.refresh.bind(this)); 60 | } 61 | 62 | // override/interface 63 | getTreeItem(element: MyTreeNode): vscode.TreeItem | Thenable { 64 | element.label = element.name + ': ' + element.value; 65 | return element; 66 | //throw new Error("Method not implemented."); 67 | } 68 | 69 | // override/interface 70 | getChildren(element?: MyTreeNode | undefined): vscode.ProviderResult { 71 | if (element) { 72 | return [] ; 73 | } else { 74 | //return this.items.map((e) => e); 75 | return this.items; 76 | } 77 | } 78 | 79 | refresh() { 80 | if (ConfigVars.debugLevel > 0) { 81 | console.log('RegisterView got event'); 82 | } 83 | } 84 | 85 | private async _tryInitialize(names: string[], frameId: any, arch: string, hint?: string) { 86 | if (!this.initialized && vscode.debug.activeDebugSession) { 87 | hint = hint ? hint : names[0]; 88 | hint = '$' + hint; 89 | const arg : DebugProtocol.EvaluateArguments = {expression: hint, frameId: frameId, context:'hover'}; 90 | try { 91 | const regval = await vscode.debug.activeDebugSession.customRequest('evaluate', arg); 92 | if (regval.result) { 93 | const val: string = regval.result; 94 | if (!val.toLowerCase().includes('error')) { 95 | this.regnames = names; 96 | this.items = []; 97 | for (let name of this.regnames) { 98 | this.items.push(new MyTreeNode(name)); 99 | } 100 | this.initialized = true; 101 | console.log('adv-cppdbg: It looks like the CPU type is ' + arch + '.'); 102 | } 103 | } 104 | } catch(e) { 105 | console.log('adv-cppdbg: It does not appear to be an ' + arch + ' CPU type.'); 106 | } 107 | } 108 | } 109 | 110 | async initialize(frameId: any) { 111 | /* 112 | * This method of initialization of valid register names is kind a crap. 113 | * If I could just ask the debugger for all valid registers then I don't have 114 | * to guess or hardcode anything. Given VSCode API, I have to guess 115 | */ 116 | if (!this.initialized) { 117 | this.deInitialize() ; // Just make sure 118 | if (vscode.debug.activeDebugSession) { 119 | this.DAtracker.trackRegisterQueries = true; 120 | const arg : DebugProtocol.EvaluateArguments = {expression: '', frameId: frameId, context:'hover'}; 121 | arg.expression = '-exec -data-list-register-names'; 122 | await vscode.debug.activeDebugSession.customRequest('evaluate', arg); 123 | this.orig_regnames = this.DAtracker.trackedRegisterNames; 124 | const len = this.orig_regnames.length; 125 | for (let i = 0; i < len; i++) { 126 | const rname = this.orig_regnames[i]; 127 | if (rname !== '') { 128 | this.regmap.set(rname, this.regnames.length); 129 | this.regnames.push(rname); 130 | this.items.push(new MyTreeNode(rname)); 131 | if (ConfigVars.debugLevel > 1) { 132 | console.log(rname, i); 133 | } 134 | } 135 | } 136 | } 137 | this.initialized = true; 138 | return; 139 | 140 | /* NOT REACHED */ 141 | /* 142 | if (vscode.debug.activeDebugSession) { 143 | await this._tryInitialize(RegisterView.armRegs, frameId, 'ARM', 'lr'); 144 | await this._tryInitialize(RegisterView.x64Regs, frameId, 'x64'); 145 | await this._tryInitialize(RegisterView.x32Regs, frameId, 'x32'); 146 | } 147 | 148 | // We tried everything, still not good pretend like there are no registers and not 149 | // slow down future queries in a debug session. 150 | this.initialized = true; 151 | */ 152 | } 153 | } 154 | 155 | deInitialize() { 156 | this.regmap.clear(); 157 | this.orig_regnames = []; 158 | this.regnames = []; 159 | this.items = []; 160 | this.initialized = false; 161 | } 162 | 163 | async updateRegisters() { 164 | if (this.initialized && (this.regnames.length === 0)) { 165 | return ; 166 | } 167 | 168 | if (vscode.debug.activeDebugSession) { // Make sure we still have a session 169 | // Wish I can skip this? I don't need a thread or frame id for global references but API demands it?? 170 | let frameId = 0 ; 171 | try { 172 | // Yeah, unfortunately, thread-ids do not always start at 1. They can be like 5000 173 | const threads = await vscode.debug.activeDebugSession.customRequest('threads', {}); 174 | const threadId = threads.threads[0].id; 175 | const sTrace = await vscode.debug.activeDebugSession.customRequest('stackTrace', { threadId: threadId }); 176 | frameId = sTrace.stackFrames[0].id; 177 | } catch (e) { 178 | console.log('updateRegisters threads/stackTrace query failed. Err = ', e); 179 | return; 180 | } 181 | 182 | if (!this.initialized) { 183 | await this.initialize(frameId); 184 | } 185 | 186 | if (vscode.debug.activeDebugSession) { // Make sure we still have a session 187 | const marker = 'RegQuery'; 188 | if (ConfigVars.debugLevel > 0) { 189 | console.time(marker); 190 | } 191 | 192 | this.DAtracker.trackRegisterQueries = true; 193 | const arg : DebugProtocol.EvaluateArguments = {expression: '', frameId: frameId, context:'hover'}; 194 | arg.expression = '-exec -data-list-register-values N'; 195 | await vscode.debug.activeDebugSession.customRequest('evaluate', arg); 196 | for (let [key, value] of this.DAtracker.trackedRegisterValues) { 197 | const rname = this.orig_regnames[key]; 198 | const ix = this.regmap.get(rname); 199 | if (ix !== undefined) { 200 | this.items[ix].value = value; 201 | if (ConfigVars.debugLevel > 1) { 202 | console.log('RegNum=', key, 'RegName=', rname, 'value=', value, 'MapIx=', ix); 203 | } 204 | } else { 205 | console.error('Error finding register value for reg=' + rname + ' ' + key); 206 | } 207 | } 208 | this.DAtracker.trackRegisterQueries = false; 209 | if (ConfigVars.debugLevel > 0) { 210 | console.timeEnd(marker); 211 | } 212 | this.onDidChangeTreeDataEmitter.fire(); 213 | if (ConfigVars.debugLevel > 0) { 214 | console.log('Done listing registers'); 215 | } 216 | return; 217 | } 218 | 219 | /* NOT REACHED */ 220 | /* 221 | const marker = 'RegQuery'; 222 | console.time(marker); 223 | const arg : DebugProtocol.EvaluateArguments = {expression: '', frameId: frameId, context:'repl'}; 224 | let ix = 0 ; 225 | for (let reg of this.regnames) { 226 | arg.expression = '$' + reg; 227 | let val = ':('; 228 | if (vscode.debug.activeDebugSession) { 229 | const regval = await vscode.debug.activeDebugSession.customRequest('evaluate', arg); 230 | if (regval.result) { 231 | val = regval.result; 232 | } 233 | } 234 | this.items[ix++].value = val; 235 | } 236 | console.timeEnd(marker); 237 | this.onDidChangeTreeDataEmitter.fire(); 238 | console.log('Done listing registers'); 239 | */ 240 | } 241 | } 242 | } 243 | 244 | export class MonitorDbgEvents { 245 | public isDebugSessionRunning : boolean = false; 246 | public myid : string = 'adv-cppdbg: MonitorDbgEvents'; 247 | public registerProvider : RegisterView; 248 | 249 | constructor(protected context: vscode.ExtensionContext) { 250 | const fac = new CppDbgAdapterTrackerFactory(); 251 | vscode.debug.registerDebugAdapterTrackerFactory('cppdbg', fac); 252 | fac.DATracker.onStateChanged.event(this.onDebuggerStateChanged.bind(this)); 253 | 254 | this.registerProvider = new RegisterView(fac.DATracker); 255 | 256 | context.subscriptions.push( 257 | vscode.debug.onDidStartDebugSession(this.onDebugStarted.bind(this)), 258 | vscode.debug.onDidTerminateDebugSession(this.onDebugTerminated.bind(this)), 259 | vscode.debug.onDidReceiveDebugSessionCustomEvent(this.onCustomEvent.bind(this)), 260 | vscode.window.registerTreeDataProvider('adv-cppdbg.registers', this.registerProvider) 261 | ); 262 | } 263 | 264 | protected onDebugStarted(session: vscode.DebugSession) { 265 | this.isDebugSessionRunning = true; 266 | if (ConfigVars.debugLevel > 0) { 267 | this.consoleLog('Debug Started'); 268 | } 269 | } 270 | 271 | protected onDebugTerminated(session: vscode.DebugSession) { 272 | this.isDebugSessionRunning = false; 273 | this.registerProvider.deInitialize(); 274 | if (ConfigVars.debugLevel > 0) { 275 | this.consoleLog('Debug Terminated'); 276 | } 277 | } 278 | 279 | protected onCustomEvent(ev: vscode.DebugSessionCustomEvent) { 280 | if (ConfigVars.debugLevel > 0) { 281 | this.consoleLog('Debug Custom Event' + ev); 282 | } 283 | } 284 | 285 | protected onDebuggerStateChanged(tracker: CppDbgDebugAdapterTracker) { 286 | if (!ConfigVars.disableRegisterView) { 287 | if (ConfigVars.debugLevel > 0) { 288 | console.log('Debugger Status Changed Event ', DbgAdapterState[tracker.dbgRunningState]); 289 | } 290 | if (tracker.dbgRunningState === DbgAdapterState.Stopped) { 291 | this.registerProvider.updateRegisters(); 292 | } 293 | } 294 | } 295 | 296 | public sendRequest(req?:string) { 297 | if (this.isDebugSessionRunning) { 298 | this.registerProvider.updateRegisters(); 299 | } else { 300 | this.consoleLog('Debug sendRequest only valid when debugger running'); 301 | } 302 | } 303 | 304 | private consoleLog(msg: any) : void { 305 | console.log(this.myid + ': ' + msg); 306 | } 307 | } -------------------------------------------------------------------------------- /src/register.ts.unused: -------------------------------------------------------------------------------- 1 | import * as vscode from 'vscode'; 2 | import { DebugProtocol } from 'vscode-debugprotocol'; 3 | import { DebugSession } from 'vscode-debugadapter'; 4 | 5 | export enum NodeType { 6 | Fields, 7 | Terminal 8 | } 9 | 10 | export class ANode { 11 | public expanded : boolean; 12 | constructor( 13 | public lbl: string, 14 | public type: NodeType 15 | ) { 16 | this.expanded = false; 17 | let session = vscode.debug.activeDebugSession as unknown as DebugSession; 18 | } 19 | } 20 | 21 | export class CppDbgRegTreeNode extends vscode.TreeItem { 22 | constructor( 23 | public readonly lbl: string, 24 | public readonly collapsibleState: vscode.TreeItemCollapsibleState, 25 | public contextValue: string, 26 | public node: ANode 27 | ) { 28 | super(lbl, collapsibleState); 29 | 30 | this.command = { 31 | command: 'adv-cppdbg.registers.selectedNode', 32 | arguments: [node], 33 | title: 'Selected Node' 34 | }; 35 | } 36 | } 37 | 38 | export class CppDbgRegViewDataProvider implements vscode.TreeDataProvider { 39 | onDidChangeTreeData?: vscode.Event | undefined; getTreeItem(element: CppDbgRegTreeNode): vscode.TreeItem | Thenable { 40 | throw new Error("Method not implemented."); 41 | } 42 | getChildren(element?: CppDbgRegTreeNode | undefined): vscode.ProviderResult { 43 | throw new Error("Method not implemented."); 44 | } 45 | } 46 | 47 | export class CppDbgRegisterView { 48 | 49 | } -------------------------------------------------------------------------------- /src/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 '../extension'; 13 | 14 | // Defines a Mocha test suite to group tests of similar kind together 15 | suite("Extension Tests", function () { 16 | 17 | // Defines a Mocha unit test 18 | test("Something 1", function() { 19 | assert.equal(-1, [1, 2, 3].indexOf(5)); 20 | assert.equal(-1, [1, 2, 3].indexOf(0)); 21 | }); 22 | }); -------------------------------------------------------------------------------- /src/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(testsRoot: string, clb: (error: Error, failures?: number) => void): void 9 | // that the extension 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 | import * as testRunner from 'vscode/lib/testrunner'; 14 | 15 | // You can directly control Mocha options by configuring the test runner below 16 | // See https://github.com/mochajs/mocha/wiki/Using-mocha-programmatically#set-options 17 | // for more info 18 | testRunner.configure({ 19 | ui: 'tdd', // the TDD UI is being used in extension.test.ts (suite, test, etc.) 20 | useColors: true // colored output from test results 21 | }); 22 | 23 | module.exports = testRunner; -------------------------------------------------------------------------------- /test/stdc-threads/.vscode/ipch/4e7a706829d5f787/main.ipch: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/haneefdm/adv-cppdbg/5b7cdaaa6d195c9bd9997187eb6d340e37ded6e8/test/stdc-threads/.vscode/ipch/4e7a706829d5f787/main.ipch -------------------------------------------------------------------------------- /test/stdc-threads/.vscode/ipch/4e7a706829d5f787/mmap_address.bin: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/haneefdm/adv-cppdbg/5b7cdaaa6d195c9bd9997187eb6d340e37ded6e8/test/stdc-threads/.vscode/ipch/4e7a706829d5f787/mmap_address.bin -------------------------------------------------------------------------------- /test/stdc-threads/.vscode/ipch/b8dcf81d69950906/main.ipch: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/haneefdm/adv-cppdbg/5b7cdaaa6d195c9bd9997187eb6d340e37ded6e8/test/stdc-threads/.vscode/ipch/b8dcf81d69950906/main.ipch -------------------------------------------------------------------------------- /test/stdc-threads/.vscode/ipch/b8dcf81d69950906/mmap_address.bin: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/haneefdm/adv-cppdbg/5b7cdaaa6d195c9bd9997187eb6d340e37ded6e8/test/stdc-threads/.vscode/ipch/b8dcf81d69950906/mmap_address.bin -------------------------------------------------------------------------------- /test/stdc-threads/.vscode/launch.json: -------------------------------------------------------------------------------- 1 | { 2 | "version": "0.2.0", 3 | "configurations": [ 4 | { 5 | "name": "(gdb/lldb) Launch", 6 | "type": "cppdbg", 7 | "request": "launch", 8 | "args": [], 9 | "stopAtEntry": false, 10 | "cwd": "${workspaceFolder}", 11 | "program": "${workspaceFolder}/bin/main", 12 | "environment": [], 13 | "externalConsole": true, 14 | "MIMode": "gdb", 15 | "preLaunchTask": "Build C++ project", 16 | "windows": { 17 | "program": "${workspaceFolder}/bin/main.exe", 18 | }, 19 | "osx": { 20 | "MIMode": "lldb", 21 | }, 22 | "loggingx" : { // Fix the typo to enable logging 23 | "trace": true, 24 | "traceResponse": false, // turn this off for less output 25 | "engineLogging": true, 26 | "programOutput": true, 27 | "moduleLoad": true, 28 | "exceptions": true 29 | } 30 | } 31 | ] 32 | } -------------------------------------------------------------------------------- /test/stdc-threads/.vscode/settings.json: -------------------------------------------------------------------------------- 1 | { 2 | "files.associations": { 3 | "*.tpp": "cpp" 4 | }, 5 | "terminal.integrated.shell.windows": "cmd.exe", 6 | "adv-cppdbg.debugLevel":2, 7 | "adv-cppdbg.disableRegisterView": false 8 | } -------------------------------------------------------------------------------- /test/stdc-threads/.vscode/tasks.json: -------------------------------------------------------------------------------- 1 | { 2 | "version": "2.0.0", 3 | "tasks": [ 4 | { 5 | "label": "Build C++ project", 6 | "type": "shell", 7 | "group": { 8 | "kind": "build", 9 | "isDefault": true 10 | }, 11 | "command": "make", 12 | }, 13 | { 14 | "label": "Build & run C++ project", 15 | "type": "shell", 16 | "group": { 17 | "kind": "test", 18 | "isDefault": true 19 | }, 20 | "command": "make", 21 | "args": [ 22 | "run" 23 | ] 24 | } 25 | ] 26 | } -------------------------------------------------------------------------------- /test/stdc-threads/Makefile: -------------------------------------------------------------------------------- 1 | UNAME := $(shell uname -s) 2 | 3 | ifeq ($(OS),Darwin) 4 | CXX := clang++ 5 | CXX_FLAGS := -Wall -Wextra -std=c++17 -g 6 | else 7 | CXX := g++ 8 | CXX_FLAGS := -Wall -Wextra -std=c++17 -g 9 | endif 10 | 11 | BIN := bin 12 | SRC := src 13 | INCLUDE := include 14 | LIB := lib 15 | 16 | LIBRARIES := 17 | 18 | ifeq ($(OS),Windows_NT) 19 | EXECUTABLE := main.exe 20 | else 21 | EXECUTABLE := main 22 | endif 23 | 24 | 25 | all: $(BIN)/$(EXECUTABLE) 26 | 27 | run: clean all 28 | ./$(BIN)/$(EXECUTABLE) 29 | 30 | $(BIN)/$(EXECUTABLE): $(SRC)/*.cpp 31 | $(CXX) $(CXX_FLAGS) -I$(INCLUDE) -L$(LIB) $^ -o $@ $(LIBRARIES) 32 | 33 | clean: 34 | -rm -fr $(BIN)/* -------------------------------------------------------------------------------- /test/stdc-threads/bin/main: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/haneefdm/adv-cppdbg/5b7cdaaa6d195c9bd9997187eb6d340e37ded6e8/test/stdc-threads/bin/main -------------------------------------------------------------------------------- /test/stdc-threads/bin/main.dSYM/Contents/Info.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | CFBundleDevelopmentRegion 6 | English 7 | CFBundleIdentifier 8 | com.apple.xcode.dsym.main 9 | CFBundleInfoDictionaryVersion 10 | 6.0 11 | CFBundlePackageType 12 | dSYM 13 | CFBundleSignature 14 | ???? 15 | CFBundleShortVersionString 16 | 1.0 17 | CFBundleVersion 18 | 1 19 | 20 | 21 | -------------------------------------------------------------------------------- /test/stdc-threads/bin/main.dSYM/Contents/Resources/DWARF/main: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/haneefdm/adv-cppdbg/5b7cdaaa6d195c9bd9997187eb6d340e37ded6e8/test/stdc-threads/bin/main.dSYM/Contents/Resources/DWARF/main -------------------------------------------------------------------------------- /test/stdc-threads/src/main.cpp: -------------------------------------------------------------------------------- 1 | // CPP program to demonstrate multithreading 2 | // using three different callables. 3 | #include 4 | #include 5 | using namespace std; 6 | 7 | int global = 10 ; 8 | static int stglobal = 20 ; 9 | 10 | static int buf[1024] ; 11 | void *bufptr = buf ; 12 | 13 | // A dummy function 14 | void foo(int Z) 15 | { 16 | for (int i = 0; i < Z; i++) { 17 | cout << "Thread using function" 18 | " pointer as callable " << global << "\n"; 19 | global++ ; 20 | } 21 | } 22 | 23 | // A callable object 24 | class thread_obj { 25 | public: 26 | void operator()(int x) 27 | { 28 | for (int i = 0; i < x; i++) { 29 | cout << "Thread using function" 30 | " object as callable " << stglobal << "\n"; 31 | stglobal++ ; 32 | } 33 | } 34 | }; 35 | 36 | int main() 37 | { 38 | volatile int local = 3 ; 39 | cout << "Threads 1 and 2 and 3 " 40 | "operating independently" << endl; 41 | 42 | // This thread is launched by using 43 | // function pointer as callable 44 | thread th1(foo, 3); 45 | 46 | // This thread is launched by using 47 | // function object as callable 48 | thread th2(thread_obj(), 3); 49 | 50 | // Define a Lambda Expression 51 | auto f = [](int x) { 52 | for (int i = 0; i < x; i++) { 53 | cout << "Thread using lambda" 54 | " expression as callable " << i << "\n"; 55 | } 56 | }; 57 | 58 | // This thread is launched by using 59 | // lamda expression as callable 60 | thread th3(f, local); 61 | 62 | // Wait for the threads to finish 63 | // Wait for thread t1 to finish 64 | th1.join(); 65 | 66 | // Wait for thread t2 to finish 67 | th2.join(); 68 | 69 | // Wait for thread t3 to finish 70 | th3.join(); 71 | 72 | return 0; 73 | } 74 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "target": "es6", 5 | "outDir": "out", 6 | "lib": [ 7 | "es6" 8 | ], 9 | "sourceMap": true, 10 | "rootDir": "src", 11 | "strict": true /* enable all strict type-checking options */ 12 | /* Additional Checks */ 13 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ 14 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ 15 | // "noUnusedParameters": true, /* Report errors on unused parameters. */ 16 | }, 17 | "exclude": [ 18 | "node_modules", 19 | ".vscode-test" 20 | ] 21 | } 22 | -------------------------------------------------------------------------------- /tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "rules": { 3 | "no-string-throw": true, 4 | "no-unused-expression": true, 5 | "no-duplicate-variable": true, 6 | "curly": true, 7 | "class-name": true, 8 | "semicolon": [ 9 | true, 10 | "always" 11 | ], 12 | "triple-equals": true 13 | }, 14 | "defaultSeverity": "warning" 15 | } 16 | -------------------------------------------------------------------------------- /vsc-extension-quickstart.md: -------------------------------------------------------------------------------- 1 | # Welcome to your VS Code Extension 2 | 3 | ## What's in the folder 4 | 5 | * This folder contains all of the files necessary for your extension. 6 | * `package.json` - this is the manifest file in which you declare your extension and command. 7 | * The sample plugin registers a command and defines its title and command name. With this information VS Code can show the command in the command palette. It doesn’t yet need to load the plugin. 8 | * `src/extension.ts` - this is the main file where you will provide the implementation of your command. 9 | * The file exports one function, `activate`, which is called the very first time your extension is activated (in this case by executing the command). Inside the `activate` function we call `registerCommand`. 10 | * We pass the function containing the implementation of the command as the second parameter to `registerCommand`. 11 | 12 | ## Get up and running straight away 13 | 14 | * Press `F5` to open a new window with your extension loaded. 15 | * Run your command from the command palette by pressing (`Ctrl+Shift+P` or `Cmd+Shift+P` on Mac) and typing `Hello World`. 16 | * Set breakpoints in your code inside `src/extension.ts` to debug your extension. 17 | * Find output from your extension in the debug console. 18 | 19 | ## Make changes 20 | 21 | * You can relaunch the extension from the debug toolbar after changing code in `src/extension.ts`. 22 | * You can also reload (`Ctrl+R` or `Cmd+R` on Mac) the VS Code window with your extension to load your changes. 23 | 24 | ## Explore the API 25 | 26 | * You can open the full set of our API when you open the file `node_modules/vscode/vscode.d.ts`. 27 | 28 | ## Run tests 29 | 30 | * Open the debug viewlet (`Ctrl+Shift+D` or `Cmd+Shift+D` on Mac) and from the launch configuration dropdown pick `Extension Tests`. 31 | * Press `F5` to run the tests in a new window with your extension loaded. 32 | * See the output of the test result in the debug console. 33 | * Make changes to `test/extension.test.ts` or create new test files inside the `test` folder. 34 | * By convention, the test runner will only consider files matching the name pattern `**.test.ts`. 35 | * You can create folders inside the `test` folder to structure your tests any way you want. 36 | --------------------------------------------------------------------------------