├── .gitignore ├── .vscode ├── launch.json ├── settings.json └── tasks.json ├── CHANGELOG.md ├── README.md ├── package-lock.json ├── package.json ├── res ├── Step1.png ├── defaults.PNG ├── gitflow.png ├── icon.svg └── icon_128.png ├── src ├── cmd.ts ├── config.ts ├── extension.ts ├── fail.ts ├── flow.ts ├── fs.ts └── git.ts ├── tsconfig.json └── tslint.json /.gitignore: -------------------------------------------------------------------------------- 1 | out 2 | node_modules -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | // A launch configuration that compiles the extension and then opens it inside a new window 2 | { 3 | "version": "0.1.0", 4 | "configurations": [ 5 | { 6 | "name": "Launch Extension", 7 | "type": "extensionHost", 8 | "request": "launch", 9 | "runtimeExecutable": "${execPath}", 10 | "args": ["--extensionDevelopmentPath=${workspaceRoot}" ], 11 | "stopOnEntry": false, 12 | "sourceMaps": true, 13 | "outDir": "${workspaceRoot}/out/src", 14 | "preLaunchTask": "npm" 15 | }, 16 | { 17 | "name": "Launch Tests", 18 | "type": "extensionHost", 19 | "request": "launch", 20 | "runtimeExecutable": "${execPath}", 21 | "args": ["--extensionDevelopmentPath=${workspaceRoot}", "--extensionTestsPath=${workspaceRoot}/out/test" ], 22 | "stopOnEntry": false, 23 | "sourceMaps": true, 24 | "outDir": "${workspaceRoot}/out/test", 25 | "preLaunchTask": "npm" 26 | } 27 | ] 28 | } 29 | -------------------------------------------------------------------------------- /.vscode/settings.json: -------------------------------------------------------------------------------- 1 | // Place your settings in this file to overwrite default and user settings. 2 | { 3 | "files.exclude": { 4 | "out": false // set this to true to hide the "out" folder with the compiled JS files 5 | }, 6 | "search.exclude": { 7 | "out": true // set this to false to include "out" folder in search results 8 | }, 9 | "typescript.tsdk": "./node_modules/typescript/lib" // we want to use the TS server from our node_modules folder to control its version 10 | } -------------------------------------------------------------------------------- /.vscode/tasks.json: -------------------------------------------------------------------------------- 1 | // Available variables which can be used inside of strings. 2 | // ${workspaceRoot}: the root folder of the team 3 | // ${file}: the current opened file 4 | // ${fileBasename}: the current opened file's basename 5 | // ${fileDirname}: the current opened file's dirname 6 | // ${fileExtname}: the current opened file's extension 7 | // ${cwd}: the current working directory of the spawned process 8 | 9 | // A task runner that calls a custom npm script that compiles the extension. 10 | { 11 | "version": "0.1.0", 12 | 13 | // we want to run npm 14 | "command": "npm", 15 | 16 | // the command is a shell script 17 | "isShellCommand": true, 18 | 19 | // show the output window only if unrecognized errors occur. 20 | "showOutput": "silent", 21 | 22 | // we run the custom script "compile" as defined in package.json 23 | "args": ["run", "compile", "--loglevel", "silent"], 24 | 25 | // The tsc compiler is started in watching mode 26 | "isWatching": true, 27 | 28 | // use the standard tsc in watch mode problem matcher to find compile problems in the output. 29 | "problemMatcher": "$tsc-watch" 30 | } -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # 1.2.0 2 | 3 | - Add `bugfix` branch support [Thanks Vincent Biret ([baywet](https://github.com/baywet))] 4 | - Fix unhelpful error messages sometimes appearing 5 | - (1.2.1 fixes the changelog to include 1.2.0) 6 | 7 | # 1.1.2 8 | 9 | - *Fix intermittent assertion failure during init* [Thanks `RobDesideri`] 10 | - Respect tag prefix for releases [Thanks `poohnix`] 11 | - Guess the next release version automatically [Thanks `poohnix`] 12 | 13 | # 1.1.1 14 | 15 | - Progress messages while performing git operations 16 | 17 | # 1.1.0 18 | 19 | - Large refactor 20 | - Bugfixes when git is not available on `PATH` but is otherwise installed. 21 | - Shiny new icon. 22 | 23 | # 1.0.0 24 | 25 | - New configuration options: 26 | - `gitflow.deleteBranchOnfinish` 27 | - `gitflow.deleteRemoteBranches` 28 | - `gitflow.default.development` 29 | - `gitflow.default.production` 30 | - Fix issue with hardcoded development branch to `develop`. 31 | - Fix unhelpful errors from git when doing a gitflow operation on an unclean 32 | working tree 33 | 34 | # 0.1.0 35 | 36 | - Update to TypeScript 2.0 and enforce strict `null` checks. May now catch some 37 | latent issues. 38 | 39 | # 0.0.5 40 | 41 | - Fixed missing push of ``master`` and tags after finishing a release or a 42 | hotfix. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Gitflow integration for Visual Studio Code 2 | 3 | This extension provides integration and support for [gitflow](http://nvie.com/posts/a-successful-git-branching-model/). 4 | It is based on [this gitflow implementation](https://github.com/nvie/gitflow) 5 | and intends to be fully compatible with it. 6 | 7 | # Getting Started 8 | 9 | If you already have gitflow set up for your repository, just start execcuting 10 | gitflow commands from the Command Palette! 11 | 12 | ![Opening example](res/gitflow.png) 13 | 14 | ## Starting from Scratch 15 | 16 | 1. First, initialize git: 17 | ```sh 18 | $ git init 19 | ``` 20 | 2. Open the VS Code Command Palette and type 'gitflow' 21 | 22 | 3. Select 'Initialize repository for gitflow' 23 | ![Initializing Git Flow](res/Step1.png) 24 | 25 | 4. Follow the command prompts and accept the defaults... 26 | ![Defaults](res/defaults.PNG) 27 | 28 | 5. Setup complete! 29 | 30 | ### Note 31 | 32 | Development is ongoing. Please help support this project by trying it out 33 | and submitting issues and feature requests to [the github page](https://github.com/vector-of-bool/vscode-gitflow). 34 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "gitflow", 3 | "version": "1.1.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": "7.0.59", 15 | "resolved": "https://registry.npmjs.org/@types/node/-/node-7.0.59.tgz", 16 | "integrity": "sha512-FRRJ2hkgzySTgLnwQhXQCGkLRu1ImISVu/YKYWXCIbF6261nqXwDPQ+6xPzZw+c2Il2Zx2JfM/t0tCaw8wzbmA==", 17 | "dev": true 18 | }, 19 | "ajv": { 20 | "version": "5.5.2", 21 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.2.tgz", 22 | "integrity": "sha1-c7Xuyj+rZT49P5Qis0GtQiBdyWU=", 23 | "dev": true, 24 | "requires": { 25 | "co": "4.6.0", 26 | "fast-deep-equal": "1.1.0", 27 | "fast-json-stable-stringify": "2.0.0", 28 | "json-schema-traverse": "0.3.1" 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-gray": { 41 | "version": "0.1.1", 42 | "resolved": "https://registry.npmjs.org/ansi-gray/-/ansi-gray-0.1.1.tgz", 43 | "integrity": "sha1-KWLPVOyXksSFEKPetSRDaGHvclE=", 44 | "dev": true, 45 | "requires": { 46 | "ansi-wrap": "0.1.0" 47 | } 48 | }, 49 | "ansi-red": { 50 | "version": "0.1.1", 51 | "resolved": "https://registry.npmjs.org/ansi-red/-/ansi-red-0.1.1.tgz", 52 | "integrity": "sha1-jGOPnRCAgAo1PJwoyKgcpHBdlGw=", 53 | "dev": true, 54 | "requires": { 55 | "ansi-wrap": "0.1.0" 56 | } 57 | }, 58 | "ansi-regex": { 59 | "version": "2.1.1", 60 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 61 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 62 | "dev": true 63 | }, 64 | "ansi-styles": { 65 | "version": "2.2.1", 66 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 67 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 68 | "dev": true 69 | }, 70 | "ansi-wrap": { 71 | "version": "0.1.0", 72 | "resolved": "https://registry.npmjs.org/ansi-wrap/-/ansi-wrap-0.1.0.tgz", 73 | "integrity": "sha1-qCJQ3bABXponyoLoLqYDu/pF768=", 74 | "dev": true 75 | }, 76 | "arr-diff": { 77 | "version": "1.1.0", 78 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-1.1.0.tgz", 79 | "integrity": "sha1-aHwydYFjWI/vfeezb6vklesaOZo=", 80 | "dev": true, 81 | "requires": { 82 | "arr-flatten": "1.1.0", 83 | "array-slice": "0.2.3" 84 | } 85 | }, 86 | "arr-flatten": { 87 | "version": "1.1.0", 88 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 89 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", 90 | "dev": true 91 | }, 92 | "arr-union": { 93 | "version": "2.1.0", 94 | "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-2.1.0.tgz", 95 | "integrity": "sha1-IPnqtexw9cfSFbEHexw5Fh0pLH0=", 96 | "dev": true 97 | }, 98 | "array-differ": { 99 | "version": "1.0.0", 100 | "resolved": "https://registry.npmjs.org/array-differ/-/array-differ-1.0.0.tgz", 101 | "integrity": "sha1-7/UuN1gknTO+QCuLuOVkuytdQDE=", 102 | "dev": true 103 | }, 104 | "array-slice": { 105 | "version": "0.2.3", 106 | "resolved": "https://registry.npmjs.org/array-slice/-/array-slice-0.2.3.tgz", 107 | "integrity": "sha1-3Tz7gO15c6dRF82sabC5nshhhvU=", 108 | "dev": true 109 | }, 110 | "array-union": { 111 | "version": "1.0.2", 112 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", 113 | "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", 114 | "dev": true, 115 | "requires": { 116 | "array-uniq": "1.0.3" 117 | } 118 | }, 119 | "array-uniq": { 120 | "version": "1.0.3", 121 | "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", 122 | "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", 123 | "dev": true 124 | }, 125 | "array-unique": { 126 | "version": "0.2.1", 127 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", 128 | "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", 129 | "dev": true 130 | }, 131 | "arrify": { 132 | "version": "1.0.1", 133 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 134 | "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", 135 | "dev": true 136 | }, 137 | "asn1": { 138 | "version": "0.2.3", 139 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.3.tgz", 140 | "integrity": "sha1-2sh4dxPJlmhJ/IGAd36+nB3fO4Y=", 141 | "dev": true 142 | }, 143 | "assert-plus": { 144 | "version": "0.2.0", 145 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-0.2.0.tgz", 146 | "integrity": "sha1-104bh+ev/A24qttwIfP+SBAasjQ=", 147 | "dev": true 148 | }, 149 | "asynckit": { 150 | "version": "0.4.0", 151 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 152 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 153 | "dev": true 154 | }, 155 | "aws-sign2": { 156 | "version": "0.6.0", 157 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.6.0.tgz", 158 | "integrity": "sha1-FDQt0428yU0OW4fXY81jYSwOeU8=", 159 | "dev": true 160 | }, 161 | "aws4": { 162 | "version": "1.6.0", 163 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.6.0.tgz", 164 | "integrity": "sha1-g+9cqGCysy5KDe7e6MdxudtXRx4=", 165 | "dev": true 166 | }, 167 | "balanced-match": { 168 | "version": "1.0.0", 169 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 170 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 171 | "dev": true 172 | }, 173 | "bcrypt-pbkdf": { 174 | "version": "1.0.1", 175 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz", 176 | "integrity": "sha1-Y7xdy2EzG5K8Bf1SiVPDNGKgb40=", 177 | "dev": true, 178 | "optional": true, 179 | "requires": { 180 | "tweetnacl": "0.14.5" 181 | } 182 | }, 183 | "beeper": { 184 | "version": "1.1.1", 185 | "resolved": "https://registry.npmjs.org/beeper/-/beeper-1.1.1.tgz", 186 | "integrity": "sha1-5tXqjF2tABMEpwsiY4RH9pyy+Ak=", 187 | "dev": true 188 | }, 189 | "block-stream": { 190 | "version": "0.0.9", 191 | "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz", 192 | "integrity": "sha1-E+v+d4oDIFz+A3UUgeu0szAMEmo=", 193 | "dev": true, 194 | "requires": { 195 | "inherits": "2.0.3" 196 | } 197 | }, 198 | "boom": { 199 | "version": "2.10.1", 200 | "resolved": "https://registry.npmjs.org/boom/-/boom-2.10.1.tgz", 201 | "integrity": "sha1-OciRjO/1eZ+D+UkqhI9iWt0Mdm8=", 202 | "dev": true, 203 | "requires": { 204 | "hoek": "2.16.3" 205 | } 206 | }, 207 | "brace-expansion": { 208 | "version": "1.1.11", 209 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 210 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 211 | "dev": true, 212 | "requires": { 213 | "balanced-match": "1.0.0", 214 | "concat-map": "0.0.1" 215 | } 216 | }, 217 | "braces": { 218 | "version": "1.8.5", 219 | "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", 220 | "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", 221 | "dev": true, 222 | "requires": { 223 | "expand-range": "1.8.2", 224 | "preserve": "0.2.0", 225 | "repeat-element": "1.1.2" 226 | } 227 | }, 228 | "browser-stdout": { 229 | "version": "1.3.0", 230 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.0.tgz", 231 | "integrity": "sha1-81HTKWnTL6XXpVZxVCY9korjvR8=", 232 | "dev": true 233 | }, 234 | "buffer-crc32": { 235 | "version": "0.2.13", 236 | "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", 237 | "integrity": "sha1-DTM+PwDqxQqhRUq9MO+MKl2ackI=", 238 | "dev": true 239 | }, 240 | "caseless": { 241 | "version": "0.11.0", 242 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.11.0.tgz", 243 | "integrity": "sha1-cVuW6phBWTzDMGeSP17GDr2k99c=", 244 | "dev": true 245 | }, 246 | "chalk": { 247 | "version": "1.1.3", 248 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 249 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 250 | "dev": true, 251 | "requires": { 252 | "ansi-styles": "2.2.1", 253 | "escape-string-regexp": "1.0.5", 254 | "has-ansi": "2.0.0", 255 | "strip-ansi": "3.0.1", 256 | "supports-color": "2.0.0" 257 | }, 258 | "dependencies": { 259 | "supports-color": { 260 | "version": "2.0.0", 261 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 262 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 263 | "dev": true 264 | } 265 | } 266 | }, 267 | "clone": { 268 | "version": "0.2.0", 269 | "resolved": "https://registry.npmjs.org/clone/-/clone-0.2.0.tgz", 270 | "integrity": "sha1-xhJqkK1Pctv1rNskPMN3JP6T/B8=", 271 | "dev": true 272 | }, 273 | "clone-buffer": { 274 | "version": "1.0.0", 275 | "resolved": "https://registry.npmjs.org/clone-buffer/-/clone-buffer-1.0.0.tgz", 276 | "integrity": "sha1-4+JbIHrE5wGvch4staFnksrD3Fg=", 277 | "dev": true 278 | }, 279 | "clone-stats": { 280 | "version": "0.0.1", 281 | "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-0.0.1.tgz", 282 | "integrity": "sha1-uI+UqCzzi4eR1YBG6kAprYjKmdE=", 283 | "dev": true 284 | }, 285 | "cloneable-readable": { 286 | "version": "1.1.2", 287 | "resolved": "https://registry.npmjs.org/cloneable-readable/-/cloneable-readable-1.1.2.tgz", 288 | "integrity": "sha512-Bq6+4t+lbM8vhTs/Bef5c5AdEMtapp/iFb6+s4/Hh9MVTt8OLKH7ZOOZSCT+Ys7hsHvqv0GuMPJ1lnQJVHvxpg==", 289 | "dev": true, 290 | "requires": { 291 | "inherits": "2.0.3", 292 | "process-nextick-args": "2.0.0", 293 | "readable-stream": "2.3.5" 294 | } 295 | }, 296 | "co": { 297 | "version": "4.6.0", 298 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 299 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", 300 | "dev": true 301 | }, 302 | "color-support": { 303 | "version": "1.1.3", 304 | "resolved": "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz", 305 | "integrity": "sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg==", 306 | "dev": true 307 | }, 308 | "combined-stream": { 309 | "version": "1.0.6", 310 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.6.tgz", 311 | "integrity": "sha1-cj599ugBrFYTETp+RFqbactjKBg=", 312 | "dev": true, 313 | "requires": { 314 | "delayed-stream": "1.0.0" 315 | } 316 | }, 317 | "commander": { 318 | "version": "2.9.0", 319 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.9.0.tgz", 320 | "integrity": "sha1-nJkJQXbhIkDLItbFFGCYQA/g99Q=", 321 | "dev": true, 322 | "requires": { 323 | "graceful-readlink": "1.0.1" 324 | } 325 | }, 326 | "concat-map": { 327 | "version": "0.0.1", 328 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 329 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 330 | "dev": true 331 | }, 332 | "convert-source-map": { 333 | "version": "1.5.1", 334 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.5.1.tgz", 335 | "integrity": "sha1-uCeAl7m8IpNl3lxiz1/K7YtVmeU=", 336 | "dev": true 337 | }, 338 | "core-util-is": { 339 | "version": "1.0.2", 340 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 341 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 342 | "dev": true 343 | }, 344 | "cryptiles": { 345 | "version": "2.0.5", 346 | "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-2.0.5.tgz", 347 | "integrity": "sha1-O9/s3GCBR8HGcgL6KR59ylnqo7g=", 348 | "dev": true, 349 | "requires": { 350 | "boom": "2.10.1" 351 | } 352 | }, 353 | "dashdash": { 354 | "version": "1.14.1", 355 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 356 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 357 | "dev": true, 358 | "requires": { 359 | "assert-plus": "1.0.0" 360 | }, 361 | "dependencies": { 362 | "assert-plus": { 363 | "version": "1.0.0", 364 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 365 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 366 | "dev": true 367 | } 368 | } 369 | }, 370 | "dateformat": { 371 | "version": "2.2.0", 372 | "resolved": "https://registry.npmjs.org/dateformat/-/dateformat-2.2.0.tgz", 373 | "integrity": "sha1-QGXiATz5+5Ft39gu+1Bq1MZ2kGI=", 374 | "dev": true 375 | }, 376 | "debug": { 377 | "version": "2.6.8", 378 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.8.tgz", 379 | "integrity": "sha1-5zFTHKLt4n0YgiJCfaF4IdaP9Pw=", 380 | "dev": true, 381 | "requires": { 382 | "ms": "2.0.0" 383 | } 384 | }, 385 | "deep-assign": { 386 | "version": "1.0.0", 387 | "resolved": "https://registry.npmjs.org/deep-assign/-/deep-assign-1.0.0.tgz", 388 | "integrity": "sha1-sJJ0O+hCfcYh6gBnzex+cN0Z83s=", 389 | "dev": true, 390 | "requires": { 391 | "is-obj": "1.0.1" 392 | } 393 | }, 394 | "delayed-stream": { 395 | "version": "1.0.0", 396 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 397 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 398 | "dev": true 399 | }, 400 | "diff": { 401 | "version": "3.2.0", 402 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.2.0.tgz", 403 | "integrity": "sha1-yc45Okt8vQsFinJck98pkCeGj/k=", 404 | "dev": true 405 | }, 406 | "duplexer": { 407 | "version": "0.1.1", 408 | "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.1.tgz", 409 | "integrity": "sha1-rOb/gIwc5mtX0ev5eXessCM0z8E=", 410 | "dev": true 411 | }, 412 | "duplexer2": { 413 | "version": "0.0.2", 414 | "resolved": "https://registry.npmjs.org/duplexer2/-/duplexer2-0.0.2.tgz", 415 | "integrity": "sha1-xhTc9n4vsUmVqRcR5aYX6KYKMds=", 416 | "dev": true, 417 | "requires": { 418 | "readable-stream": "1.1.14" 419 | }, 420 | "dependencies": { 421 | "isarray": { 422 | "version": "0.0.1", 423 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 424 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 425 | "dev": true 426 | }, 427 | "readable-stream": { 428 | "version": "1.1.14", 429 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", 430 | "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", 431 | "dev": true, 432 | "requires": { 433 | "core-util-is": "1.0.2", 434 | "inherits": "2.0.3", 435 | "isarray": "0.0.1", 436 | "string_decoder": "0.10.31" 437 | } 438 | }, 439 | "string_decoder": { 440 | "version": "0.10.31", 441 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 442 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", 443 | "dev": true 444 | } 445 | } 446 | }, 447 | "duplexify": { 448 | "version": "3.5.4", 449 | "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.5.4.tgz", 450 | "integrity": "sha512-JzYSLYMhoVVBe8+mbHQ4KgpvHpm0DZpJuL8PY93Vyv1fW7jYJ90LoXa1di/CVbJM+TgMs91rbDapE/RNIfnJsA==", 451 | "dev": true, 452 | "requires": { 453 | "end-of-stream": "1.4.1", 454 | "inherits": "2.0.3", 455 | "readable-stream": "2.3.5", 456 | "stream-shift": "1.0.0" 457 | } 458 | }, 459 | "ecc-jsbn": { 460 | "version": "0.1.1", 461 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz", 462 | "integrity": "sha1-D8c6ntXw1Tw4GTOYUj735UN3dQU=", 463 | "dev": true, 464 | "optional": true, 465 | "requires": { 466 | "jsbn": "0.1.1" 467 | } 468 | }, 469 | "end-of-stream": { 470 | "version": "1.4.1", 471 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz", 472 | "integrity": "sha512-1MkrZNvWTKCaigbn+W15elq2BB/L22nqrSY5DKlo3X6+vclJm8Bb5djXJBmEX6fS3+zCh/F4VBK5Z2KxJt4s2Q==", 473 | "dev": true, 474 | "requires": { 475 | "once": "1.4.0" 476 | } 477 | }, 478 | "escape-string-regexp": { 479 | "version": "1.0.5", 480 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 481 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 482 | "dev": true 483 | }, 484 | "event-stream": { 485 | "version": "3.3.4", 486 | "resolved": "http://registry.npmjs.org/event-stream/-/event-stream-3.3.4.tgz", 487 | "integrity": "sha1-SrTJoPWlTbkzi0w02Gv86PSzVXE=", 488 | "dev": true, 489 | "requires": { 490 | "duplexer": "0.1.1", 491 | "from": "0.1.7", 492 | "map-stream": "0.1.0", 493 | "pause-stream": "0.0.11", 494 | "split": "0.3.3", 495 | "stream-combiner": "0.0.4", 496 | "through": "2.3.8" 497 | } 498 | }, 499 | "expand-brackets": { 500 | "version": "0.1.5", 501 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", 502 | "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", 503 | "dev": true, 504 | "requires": { 505 | "is-posix-bracket": "0.1.1" 506 | } 507 | }, 508 | "expand-range": { 509 | "version": "1.8.2", 510 | "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz", 511 | "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", 512 | "dev": true, 513 | "requires": { 514 | "fill-range": "2.2.3" 515 | } 516 | }, 517 | "extend": { 518 | "version": "3.0.1", 519 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", 520 | "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=", 521 | "dev": true 522 | }, 523 | "extend-shallow": { 524 | "version": "1.1.4", 525 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-1.1.4.tgz", 526 | "integrity": "sha1-Gda/lN/AnXa6cR85uHLSH/TdkHE=", 527 | "dev": true, 528 | "requires": { 529 | "kind-of": "1.1.0" 530 | } 531 | }, 532 | "extglob": { 533 | "version": "0.3.2", 534 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", 535 | "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", 536 | "dev": true, 537 | "requires": { 538 | "is-extglob": "1.0.0" 539 | }, 540 | "dependencies": { 541 | "is-extglob": { 542 | "version": "1.0.0", 543 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 544 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 545 | "dev": true 546 | } 547 | } 548 | }, 549 | "extsprintf": { 550 | "version": "1.3.0", 551 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 552 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 553 | "dev": true 554 | }, 555 | "fancy-log": { 556 | "version": "1.3.2", 557 | "resolved": "https://registry.npmjs.org/fancy-log/-/fancy-log-1.3.2.tgz", 558 | "integrity": "sha1-9BEl49hPLn2JpD0G2VjI94vha+E=", 559 | "dev": true, 560 | "requires": { 561 | "ansi-gray": "0.1.1", 562 | "color-support": "1.1.3", 563 | "time-stamp": "1.1.0" 564 | } 565 | }, 566 | "fast-deep-equal": { 567 | "version": "1.1.0", 568 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz", 569 | "integrity": "sha1-wFNHeBfIa1HaqFPIHgWbcz0CNhQ=", 570 | "dev": true 571 | }, 572 | "fast-json-stable-stringify": { 573 | "version": "2.0.0", 574 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 575 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 576 | "dev": true 577 | }, 578 | "fd-slicer": { 579 | "version": "1.0.1", 580 | "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.0.1.tgz", 581 | "integrity": "sha1-i1vL2ewyfFBBv5qwI/1nUPEXfmU=", 582 | "dev": true, 583 | "requires": { 584 | "pend": "1.2.0" 585 | } 586 | }, 587 | "filename-regex": { 588 | "version": "2.0.1", 589 | "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", 590 | "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=", 591 | "dev": true 592 | }, 593 | "fill-range": { 594 | "version": "2.2.3", 595 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.3.tgz", 596 | "integrity": "sha1-ULd9/X5Gm8dJJHCWNpn+eoSFpyM=", 597 | "dev": true, 598 | "requires": { 599 | "is-number": "2.1.0", 600 | "isobject": "2.1.0", 601 | "randomatic": "1.1.7", 602 | "repeat-element": "1.1.2", 603 | "repeat-string": "1.6.1" 604 | } 605 | }, 606 | "first-chunk-stream": { 607 | "version": "1.0.0", 608 | "resolved": "https://registry.npmjs.org/first-chunk-stream/-/first-chunk-stream-1.0.0.tgz", 609 | "integrity": "sha1-Wb+1DNkF9g18OUzT2ayqtOatk04=", 610 | "dev": true 611 | }, 612 | "for-in": { 613 | "version": "1.0.2", 614 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 615 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", 616 | "dev": true 617 | }, 618 | "for-own": { 619 | "version": "0.1.5", 620 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", 621 | "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", 622 | "dev": true, 623 | "requires": { 624 | "for-in": "1.0.2" 625 | } 626 | }, 627 | "forever-agent": { 628 | "version": "0.6.1", 629 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 630 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 631 | "dev": true 632 | }, 633 | "form-data": { 634 | "version": "2.1.4", 635 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.1.4.tgz", 636 | "integrity": "sha1-M8GDrPGTJ27KqYFDpp6Uv+4XUNE=", 637 | "dev": true, 638 | "requires": { 639 | "asynckit": "0.4.0", 640 | "combined-stream": "1.0.6", 641 | "mime-types": "2.1.18" 642 | } 643 | }, 644 | "from": { 645 | "version": "0.1.7", 646 | "resolved": "https://registry.npmjs.org/from/-/from-0.1.7.tgz", 647 | "integrity": "sha1-g8YK/Fi5xWmXAH7Rp2izqzA6RP4=", 648 | "dev": true 649 | }, 650 | "fs.realpath": { 651 | "version": "1.0.0", 652 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 653 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 654 | "dev": true 655 | }, 656 | "fstream": { 657 | "version": "1.0.11", 658 | "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz", 659 | "integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=", 660 | "dev": true, 661 | "requires": { 662 | "graceful-fs": "4.1.11", 663 | "inherits": "2.0.3", 664 | "mkdirp": "0.5.1", 665 | "rimraf": "2.6.2" 666 | } 667 | }, 668 | "generate-function": { 669 | "version": "2.0.0", 670 | "resolved": "https://registry.npmjs.org/generate-function/-/generate-function-2.0.0.tgz", 671 | "integrity": "sha1-aFj+fAlpt9TpCTM3ZHrHn2DfvnQ=", 672 | "dev": true 673 | }, 674 | "generate-object-property": { 675 | "version": "1.2.0", 676 | "resolved": "https://registry.npmjs.org/generate-object-property/-/generate-object-property-1.2.0.tgz", 677 | "integrity": "sha1-nA4cQDCM6AT0eDYYuTf6iPmdUNA=", 678 | "dev": true, 679 | "requires": { 680 | "is-property": "1.0.2" 681 | } 682 | }, 683 | "getpass": { 684 | "version": "0.1.7", 685 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 686 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 687 | "dev": true, 688 | "requires": { 689 | "assert-plus": "1.0.0" 690 | }, 691 | "dependencies": { 692 | "assert-plus": { 693 | "version": "1.0.0", 694 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 695 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 696 | "dev": true 697 | } 698 | } 699 | }, 700 | "glob": { 701 | "version": "7.1.1", 702 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.1.tgz", 703 | "integrity": "sha1-gFIR3wT6rxxjo2ADBs31reULLsg=", 704 | "dev": true, 705 | "requires": { 706 | "fs.realpath": "1.0.0", 707 | "inflight": "1.0.6", 708 | "inherits": "2.0.3", 709 | "minimatch": "3.0.4", 710 | "once": "1.4.0", 711 | "path-is-absolute": "1.0.1" 712 | } 713 | }, 714 | "glob-base": { 715 | "version": "0.3.0", 716 | "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", 717 | "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", 718 | "dev": true, 719 | "requires": { 720 | "glob-parent": "2.0.0", 721 | "is-glob": "2.0.1" 722 | }, 723 | "dependencies": { 724 | "glob-parent": { 725 | "version": "2.0.0", 726 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", 727 | "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", 728 | "dev": true, 729 | "requires": { 730 | "is-glob": "2.0.1" 731 | } 732 | }, 733 | "is-extglob": { 734 | "version": "1.0.0", 735 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 736 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 737 | "dev": true 738 | }, 739 | "is-glob": { 740 | "version": "2.0.1", 741 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 742 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 743 | "dev": true, 744 | "requires": { 745 | "is-extglob": "1.0.0" 746 | } 747 | } 748 | } 749 | }, 750 | "glob-parent": { 751 | "version": "3.1.0", 752 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", 753 | "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", 754 | "dev": true, 755 | "requires": { 756 | "is-glob": "3.1.0", 757 | "path-dirname": "1.0.2" 758 | } 759 | }, 760 | "glob-stream": { 761 | "version": "5.3.5", 762 | "resolved": "https://registry.npmjs.org/glob-stream/-/glob-stream-5.3.5.tgz", 763 | "integrity": "sha1-pVZlqajM3EGRWofHAeMtTgFvrSI=", 764 | "dev": true, 765 | "requires": { 766 | "extend": "3.0.1", 767 | "glob": "5.0.15", 768 | "glob-parent": "3.1.0", 769 | "micromatch": "2.3.11", 770 | "ordered-read-streams": "0.3.0", 771 | "through2": "0.6.5", 772 | "to-absolute-glob": "0.1.1", 773 | "unique-stream": "2.2.1" 774 | }, 775 | "dependencies": { 776 | "glob": { 777 | "version": "5.0.15", 778 | "resolved": "https://registry.npmjs.org/glob/-/glob-5.0.15.tgz", 779 | "integrity": "sha1-G8k2ueAvSmA/zCIuz3Yz0wuLk7E=", 780 | "dev": true, 781 | "requires": { 782 | "inflight": "1.0.6", 783 | "inherits": "2.0.3", 784 | "minimatch": "3.0.4", 785 | "once": "1.4.0", 786 | "path-is-absolute": "1.0.1" 787 | } 788 | }, 789 | "isarray": { 790 | "version": "0.0.1", 791 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 792 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 793 | "dev": true 794 | }, 795 | "readable-stream": { 796 | "version": "1.0.34", 797 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.0.34.tgz", 798 | "integrity": "sha1-Elgg40vIQtLyqq+v5MKRbuMsFXw=", 799 | "dev": true, 800 | "requires": { 801 | "core-util-is": "1.0.2", 802 | "inherits": "2.0.3", 803 | "isarray": "0.0.1", 804 | "string_decoder": "0.10.31" 805 | } 806 | }, 807 | "string_decoder": { 808 | "version": "0.10.31", 809 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 810 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", 811 | "dev": true 812 | }, 813 | "through2": { 814 | "version": "0.6.5", 815 | "resolved": "https://registry.npmjs.org/through2/-/through2-0.6.5.tgz", 816 | "integrity": "sha1-QaucZ7KdVyCQcUEOHXp6lozTrUg=", 817 | "dev": true, 818 | "requires": { 819 | "readable-stream": "1.0.34", 820 | "xtend": "4.0.1" 821 | } 822 | } 823 | } 824 | }, 825 | "glogg": { 826 | "version": "1.0.1", 827 | "resolved": "https://registry.npmjs.org/glogg/-/glogg-1.0.1.tgz", 828 | "integrity": "sha512-ynYqXLoluBKf9XGR1gA59yEJisIL7YHEH4xr3ZziHB5/yl4qWfaK8Js9jGe6gBGCSCKVqiyO30WnRZADvemUNw==", 829 | "dev": true, 830 | "requires": { 831 | "sparkles": "1.0.0" 832 | } 833 | }, 834 | "graceful-fs": { 835 | "version": "4.1.11", 836 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 837 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", 838 | "dev": true 839 | }, 840 | "graceful-readlink": { 841 | "version": "1.0.1", 842 | "resolved": "https://registry.npmjs.org/graceful-readlink/-/graceful-readlink-1.0.1.tgz", 843 | "integrity": "sha1-TK+tdrxi8C+gObL5Tpo906ORpyU=", 844 | "dev": true 845 | }, 846 | "growl": { 847 | "version": "1.9.2", 848 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.9.2.tgz", 849 | "integrity": "sha1-Dqd0NxXbjY3ixe3hd14bRayFwC8=", 850 | "dev": true 851 | }, 852 | "gulp-chmod": { 853 | "version": "2.0.0", 854 | "resolved": "https://registry.npmjs.org/gulp-chmod/-/gulp-chmod-2.0.0.tgz", 855 | "integrity": "sha1-AMOQuSigeZslGsz2MaoJ4BzGKZw=", 856 | "dev": true, 857 | "requires": { 858 | "deep-assign": "1.0.0", 859 | "stat-mode": "0.2.2", 860 | "through2": "2.0.3" 861 | } 862 | }, 863 | "gulp-filter": { 864 | "version": "5.1.0", 865 | "resolved": "https://registry.npmjs.org/gulp-filter/-/gulp-filter-5.1.0.tgz", 866 | "integrity": "sha1-oF4Rr/sHz33PQafeHLe2OsN4PnM=", 867 | "dev": true, 868 | "requires": { 869 | "multimatch": "2.1.0", 870 | "plugin-error": "0.1.2", 871 | "streamfilter": "1.0.7" 872 | } 873 | }, 874 | "gulp-gunzip": { 875 | "version": "1.0.0", 876 | "resolved": "https://registry.npmjs.org/gulp-gunzip/-/gulp-gunzip-1.0.0.tgz", 877 | "integrity": "sha1-FbdBFF6Dqcb1CIYkG1fMWHHxUak=", 878 | "dev": true, 879 | "requires": { 880 | "through2": "0.6.5", 881 | "vinyl": "0.4.6" 882 | }, 883 | "dependencies": { 884 | "isarray": { 885 | "version": "0.0.1", 886 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 887 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 888 | "dev": true 889 | }, 890 | "readable-stream": { 891 | "version": "1.0.34", 892 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.0.34.tgz", 893 | "integrity": "sha1-Elgg40vIQtLyqq+v5MKRbuMsFXw=", 894 | "dev": true, 895 | "requires": { 896 | "core-util-is": "1.0.2", 897 | "inherits": "2.0.3", 898 | "isarray": "0.0.1", 899 | "string_decoder": "0.10.31" 900 | } 901 | }, 902 | "string_decoder": { 903 | "version": "0.10.31", 904 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 905 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", 906 | "dev": true 907 | }, 908 | "through2": { 909 | "version": "0.6.5", 910 | "resolved": "https://registry.npmjs.org/through2/-/through2-0.6.5.tgz", 911 | "integrity": "sha1-QaucZ7KdVyCQcUEOHXp6lozTrUg=", 912 | "dev": true, 913 | "requires": { 914 | "readable-stream": "1.0.34", 915 | "xtend": "4.0.1" 916 | } 917 | } 918 | } 919 | }, 920 | "gulp-remote-src": { 921 | "version": "0.4.3", 922 | "resolved": "https://registry.npmjs.org/gulp-remote-src/-/gulp-remote-src-0.4.3.tgz", 923 | "integrity": "sha1-VyjP1kNDPdSEXd7wlp8PlxoqtKE=", 924 | "dev": true, 925 | "requires": { 926 | "event-stream": "3.3.4", 927 | "node.extend": "1.1.6", 928 | "request": "2.79.0", 929 | "through2": "2.0.3", 930 | "vinyl": "2.0.2" 931 | }, 932 | "dependencies": { 933 | "clone": { 934 | "version": "1.0.4", 935 | "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", 936 | "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", 937 | "dev": true 938 | }, 939 | "clone-stats": { 940 | "version": "1.0.0", 941 | "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-1.0.0.tgz", 942 | "integrity": "sha1-s3gt/4u1R04Yuba/D9/ngvh3doA=", 943 | "dev": true 944 | }, 945 | "request": { 946 | "version": "2.79.0", 947 | "resolved": "https://registry.npmjs.org/request/-/request-2.79.0.tgz", 948 | "integrity": "sha1-Tf5b9r6LjNw3/Pk+BLZVd3InEN4=", 949 | "dev": true, 950 | "requires": { 951 | "aws-sign2": "0.6.0", 952 | "aws4": "1.6.0", 953 | "caseless": "0.11.0", 954 | "combined-stream": "1.0.6", 955 | "extend": "3.0.1", 956 | "forever-agent": "0.6.1", 957 | "form-data": "2.1.4", 958 | "har-validator": "2.0.6", 959 | "hawk": "3.1.3", 960 | "http-signature": "1.1.1", 961 | "is-typedarray": "1.0.0", 962 | "isstream": "0.1.2", 963 | "json-stringify-safe": "5.0.1", 964 | "mime-types": "2.1.18", 965 | "oauth-sign": "0.8.2", 966 | "qs": "6.3.2", 967 | "stringstream": "0.0.5", 968 | "tough-cookie": "2.3.4", 969 | "tunnel-agent": "0.4.3", 970 | "uuid": "3.2.1" 971 | } 972 | }, 973 | "vinyl": { 974 | "version": "2.0.2", 975 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-2.0.2.tgz", 976 | "integrity": "sha1-CjcT2NTpIhxY8QyhbAEWyeJe2nw=", 977 | "dev": true, 978 | "requires": { 979 | "clone": "1.0.4", 980 | "clone-buffer": "1.0.0", 981 | "clone-stats": "1.0.0", 982 | "cloneable-readable": "1.1.2", 983 | "is-stream": "1.1.0", 984 | "remove-trailing-separator": "1.1.0", 985 | "replace-ext": "1.0.0" 986 | } 987 | } 988 | } 989 | }, 990 | "gulp-sourcemaps": { 991 | "version": "1.6.0", 992 | "resolved": "https://registry.npmjs.org/gulp-sourcemaps/-/gulp-sourcemaps-1.6.0.tgz", 993 | "integrity": "sha1-uG/zSdgBzrVuHZ59x7vLS33uYAw=", 994 | "dev": true, 995 | "requires": { 996 | "convert-source-map": "1.5.1", 997 | "graceful-fs": "4.1.11", 998 | "strip-bom": "2.0.0", 999 | "through2": "2.0.3", 1000 | "vinyl": "1.2.0" 1001 | }, 1002 | "dependencies": { 1003 | "clone": { 1004 | "version": "1.0.4", 1005 | "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", 1006 | "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", 1007 | "dev": true 1008 | }, 1009 | "replace-ext": { 1010 | "version": "0.0.1", 1011 | "resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-0.0.1.tgz", 1012 | "integrity": "sha1-KbvZIHinOfC8zitO5B6DeVNSKSQ=", 1013 | "dev": true 1014 | }, 1015 | "vinyl": { 1016 | "version": "1.2.0", 1017 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-1.2.0.tgz", 1018 | "integrity": "sha1-XIgDbPVl5d8FVYv8kR+GVt8hiIQ=", 1019 | "dev": true, 1020 | "requires": { 1021 | "clone": "1.0.4", 1022 | "clone-stats": "0.0.1", 1023 | "replace-ext": "0.0.1" 1024 | } 1025 | } 1026 | } 1027 | }, 1028 | "gulp-symdest": { 1029 | "version": "1.1.0", 1030 | "resolved": "https://registry.npmjs.org/gulp-symdest/-/gulp-symdest-1.1.0.tgz", 1031 | "integrity": "sha1-wWUyBzLRks5W/ZQnH/oSMjS/KuA=", 1032 | "dev": true, 1033 | "requires": { 1034 | "event-stream": "3.3.4", 1035 | "mkdirp": "0.5.1", 1036 | "queue": "3.1.0", 1037 | "vinyl-fs": "2.4.4" 1038 | } 1039 | }, 1040 | "gulp-untar": { 1041 | "version": "0.0.6", 1042 | "resolved": "https://registry.npmjs.org/gulp-untar/-/gulp-untar-0.0.6.tgz", 1043 | "integrity": "sha1-1r3v3n6ajgVMnxYjhaB4LEvnQAA=", 1044 | "dev": true, 1045 | "requires": { 1046 | "event-stream": "3.3.4", 1047 | "gulp-util": "3.0.8", 1048 | "streamifier": "0.1.1", 1049 | "tar": "2.2.1", 1050 | "through2": "2.0.3" 1051 | } 1052 | }, 1053 | "gulp-util": { 1054 | "version": "3.0.8", 1055 | "resolved": "https://registry.npmjs.org/gulp-util/-/gulp-util-3.0.8.tgz", 1056 | "integrity": "sha1-AFTh50RQLifATBh8PsxQXdVLu08=", 1057 | "dev": true, 1058 | "requires": { 1059 | "array-differ": "1.0.0", 1060 | "array-uniq": "1.0.3", 1061 | "beeper": "1.1.1", 1062 | "chalk": "1.1.3", 1063 | "dateformat": "2.2.0", 1064 | "fancy-log": "1.3.2", 1065 | "gulplog": "1.0.0", 1066 | "has-gulplog": "0.1.0", 1067 | "lodash._reescape": "3.0.0", 1068 | "lodash._reevaluate": "3.0.0", 1069 | "lodash._reinterpolate": "3.0.0", 1070 | "lodash.template": "3.6.2", 1071 | "minimist": "1.2.0", 1072 | "multipipe": "0.1.2", 1073 | "object-assign": "3.0.0", 1074 | "replace-ext": "0.0.1", 1075 | "through2": "2.0.3", 1076 | "vinyl": "0.5.3" 1077 | }, 1078 | "dependencies": { 1079 | "clone": { 1080 | "version": "1.0.4", 1081 | "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", 1082 | "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", 1083 | "dev": true 1084 | }, 1085 | "minimist": { 1086 | "version": "1.2.0", 1087 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1088 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 1089 | "dev": true 1090 | }, 1091 | "object-assign": { 1092 | "version": "3.0.0", 1093 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-3.0.0.tgz", 1094 | "integrity": "sha1-m+3VygiXlJvKR+f/QIBi1Un1h/I=", 1095 | "dev": true 1096 | }, 1097 | "replace-ext": { 1098 | "version": "0.0.1", 1099 | "resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-0.0.1.tgz", 1100 | "integrity": "sha1-KbvZIHinOfC8zitO5B6DeVNSKSQ=", 1101 | "dev": true 1102 | }, 1103 | "vinyl": { 1104 | "version": "0.5.3", 1105 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-0.5.3.tgz", 1106 | "integrity": "sha1-sEVbOPxeDPMNQyUTLkYZcMIJHN4=", 1107 | "dev": true, 1108 | "requires": { 1109 | "clone": "1.0.4", 1110 | "clone-stats": "0.0.1", 1111 | "replace-ext": "0.0.1" 1112 | } 1113 | } 1114 | } 1115 | }, 1116 | "gulp-vinyl-zip": { 1117 | "version": "2.1.0", 1118 | "resolved": "https://registry.npmjs.org/gulp-vinyl-zip/-/gulp-vinyl-zip-2.1.0.tgz", 1119 | "integrity": "sha1-JOQGhdwFtxSZlSRQmeBZAmO+ja0=", 1120 | "dev": true, 1121 | "requires": { 1122 | "event-stream": "3.3.4", 1123 | "queue": "4.4.2", 1124 | "through2": "2.0.3", 1125 | "vinyl": "2.1.0", 1126 | "vinyl-fs": "2.4.4", 1127 | "yauzl": "2.9.1", 1128 | "yazl": "2.4.3" 1129 | }, 1130 | "dependencies": { 1131 | "clone": { 1132 | "version": "2.1.2", 1133 | "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.2.tgz", 1134 | "integrity": "sha1-G39Ln1kfHo+DZwQBYANFoCiHQ18=", 1135 | "dev": true 1136 | }, 1137 | "clone-stats": { 1138 | "version": "1.0.0", 1139 | "resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-1.0.0.tgz", 1140 | "integrity": "sha1-s3gt/4u1R04Yuba/D9/ngvh3doA=", 1141 | "dev": true 1142 | }, 1143 | "queue": { 1144 | "version": "4.4.2", 1145 | "resolved": "https://registry.npmjs.org/queue/-/queue-4.4.2.tgz", 1146 | "integrity": "sha512-fSMRXbwhMwipcDZ08enW2vl+YDmAmhcNcr43sCJL8DIg+CFOsoRLG23ctxA+fwNk1w55SePSiS7oqQQSgQoVJQ==", 1147 | "dev": true, 1148 | "requires": { 1149 | "inherits": "2.0.3" 1150 | } 1151 | }, 1152 | "vinyl": { 1153 | "version": "2.1.0", 1154 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-2.1.0.tgz", 1155 | "integrity": "sha1-Ah+cLPlR1rk5lDyJ617lrdT9kkw=", 1156 | "dev": true, 1157 | "requires": { 1158 | "clone": "2.1.2", 1159 | "clone-buffer": "1.0.0", 1160 | "clone-stats": "1.0.0", 1161 | "cloneable-readable": "1.1.2", 1162 | "remove-trailing-separator": "1.1.0", 1163 | "replace-ext": "1.0.0" 1164 | } 1165 | } 1166 | } 1167 | }, 1168 | "gulplog": { 1169 | "version": "1.0.0", 1170 | "resolved": "https://registry.npmjs.org/gulplog/-/gulplog-1.0.0.tgz", 1171 | "integrity": "sha1-4oxNRdBey77YGDY86PnFkmIp/+U=", 1172 | "dev": true, 1173 | "requires": { 1174 | "glogg": "1.0.1" 1175 | } 1176 | }, 1177 | "har-schema": { 1178 | "version": "2.0.0", 1179 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 1180 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 1181 | "dev": true 1182 | }, 1183 | "har-validator": { 1184 | "version": "2.0.6", 1185 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-2.0.6.tgz", 1186 | "integrity": "sha1-zcvAgYgmWtEZtqWnyKtw7s+10n0=", 1187 | "dev": true, 1188 | "requires": { 1189 | "chalk": "1.1.3", 1190 | "commander": "2.9.0", 1191 | "is-my-json-valid": "2.17.2", 1192 | "pinkie-promise": "2.0.1" 1193 | } 1194 | }, 1195 | "has-ansi": { 1196 | "version": "2.0.0", 1197 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 1198 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 1199 | "dev": true, 1200 | "requires": { 1201 | "ansi-regex": "2.1.1" 1202 | } 1203 | }, 1204 | "has-flag": { 1205 | "version": "1.0.0", 1206 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-1.0.0.tgz", 1207 | "integrity": "sha1-nZ55MWXOAXoA8AQYxD+UKnsdEfo=", 1208 | "dev": true 1209 | }, 1210 | "has-gulplog": { 1211 | "version": "0.1.0", 1212 | "resolved": "https://registry.npmjs.org/has-gulplog/-/has-gulplog-0.1.0.tgz", 1213 | "integrity": "sha1-ZBTIKRNpfaUVkDl9r7EvIpZ4Ec4=", 1214 | "dev": true, 1215 | "requires": { 1216 | "sparkles": "1.0.0" 1217 | } 1218 | }, 1219 | "hawk": { 1220 | "version": "3.1.3", 1221 | "resolved": "https://registry.npmjs.org/hawk/-/hawk-3.1.3.tgz", 1222 | "integrity": "sha1-B4REvXwWQLD+VA0sm3PVlnjo4cQ=", 1223 | "dev": true, 1224 | "requires": { 1225 | "boom": "2.10.1", 1226 | "cryptiles": "2.0.5", 1227 | "hoek": "2.16.3", 1228 | "sntp": "1.0.9" 1229 | } 1230 | }, 1231 | "he": { 1232 | "version": "1.1.1", 1233 | "resolved": "https://registry.npmjs.org/he/-/he-1.1.1.tgz", 1234 | "integrity": "sha1-k0EP0hsAlzUVH4howvJx80J+I/0=", 1235 | "dev": true 1236 | }, 1237 | "hoek": { 1238 | "version": "2.16.3", 1239 | "resolved": "https://registry.npmjs.org/hoek/-/hoek-2.16.3.tgz", 1240 | "integrity": "sha1-ILt0A9POo5jpHcRxCo/xuCdKJe0=", 1241 | "dev": true 1242 | }, 1243 | "http-signature": { 1244 | "version": "1.1.1", 1245 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.1.1.tgz", 1246 | "integrity": "sha1-33LiZwZs0Kxn+3at+OE0qPvPkb8=", 1247 | "dev": true, 1248 | "requires": { 1249 | "assert-plus": "0.2.0", 1250 | "jsprim": "1.4.1", 1251 | "sshpk": "1.14.1" 1252 | } 1253 | }, 1254 | "inflight": { 1255 | "version": "1.0.6", 1256 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1257 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1258 | "dev": true, 1259 | "requires": { 1260 | "once": "1.4.0", 1261 | "wrappy": "1.0.2" 1262 | } 1263 | }, 1264 | "inherits": { 1265 | "version": "2.0.3", 1266 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1267 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 1268 | "dev": true 1269 | }, 1270 | "is": { 1271 | "version": "3.2.1", 1272 | "resolved": "https://registry.npmjs.org/is/-/is-3.2.1.tgz", 1273 | "integrity": "sha1-0Kwq1V63sL7JJqUmb2xmKqqD3KU=", 1274 | "dev": true 1275 | }, 1276 | "is-buffer": { 1277 | "version": "1.1.6", 1278 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 1279 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 1280 | "dev": true 1281 | }, 1282 | "is-dotfile": { 1283 | "version": "1.0.3", 1284 | "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", 1285 | "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=", 1286 | "dev": true 1287 | }, 1288 | "is-equal-shallow": { 1289 | "version": "0.1.3", 1290 | "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", 1291 | "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", 1292 | "dev": true, 1293 | "requires": { 1294 | "is-primitive": "2.0.0" 1295 | } 1296 | }, 1297 | "is-extendable": { 1298 | "version": "0.1.1", 1299 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 1300 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", 1301 | "dev": true 1302 | }, 1303 | "is-extglob": { 1304 | "version": "2.1.1", 1305 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1306 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1307 | "dev": true 1308 | }, 1309 | "is-glob": { 1310 | "version": "3.1.0", 1311 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", 1312 | "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", 1313 | "dev": true, 1314 | "requires": { 1315 | "is-extglob": "2.1.1" 1316 | } 1317 | }, 1318 | "is-my-ip-valid": { 1319 | "version": "1.0.0", 1320 | "resolved": "https://registry.npmjs.org/is-my-ip-valid/-/is-my-ip-valid-1.0.0.tgz", 1321 | "integrity": "sha512-gmh/eWXROncUzRnIa1Ubrt5b8ep/MGSnfAUI3aRp+sqTCs1tv1Isl8d8F6JmkN3dXKc3ehZMrtiPN9eL03NuaQ==", 1322 | "dev": true 1323 | }, 1324 | "is-my-json-valid": { 1325 | "version": "2.17.2", 1326 | "resolved": "https://registry.npmjs.org/is-my-json-valid/-/is-my-json-valid-2.17.2.tgz", 1327 | "integrity": "sha512-IBhBslgngMQN8DDSppmgDv7RNrlFotuuDsKcrCP3+HbFaVivIBU7u9oiiErw8sH4ynx3+gOGQ3q2otkgiSi6kg==", 1328 | "dev": true, 1329 | "requires": { 1330 | "generate-function": "2.0.0", 1331 | "generate-object-property": "1.2.0", 1332 | "is-my-ip-valid": "1.0.0", 1333 | "jsonpointer": "4.0.1", 1334 | "xtend": "4.0.1" 1335 | } 1336 | }, 1337 | "is-number": { 1338 | "version": "2.1.0", 1339 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", 1340 | "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", 1341 | "dev": true, 1342 | "requires": { 1343 | "kind-of": "3.2.2" 1344 | }, 1345 | "dependencies": { 1346 | "kind-of": { 1347 | "version": "3.2.2", 1348 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1349 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1350 | "dev": true, 1351 | "requires": { 1352 | "is-buffer": "1.1.6" 1353 | } 1354 | } 1355 | } 1356 | }, 1357 | "is-obj": { 1358 | "version": "1.0.1", 1359 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", 1360 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=", 1361 | "dev": true 1362 | }, 1363 | "is-posix-bracket": { 1364 | "version": "0.1.1", 1365 | "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", 1366 | "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=", 1367 | "dev": true 1368 | }, 1369 | "is-primitive": { 1370 | "version": "2.0.0", 1371 | "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", 1372 | "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=", 1373 | "dev": true 1374 | }, 1375 | "is-property": { 1376 | "version": "1.0.2", 1377 | "resolved": "https://registry.npmjs.org/is-property/-/is-property-1.0.2.tgz", 1378 | "integrity": "sha1-V/4cTkhHTt1lsJkR8msc1Ald2oQ=", 1379 | "dev": true 1380 | }, 1381 | "is-stream": { 1382 | "version": "1.1.0", 1383 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 1384 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", 1385 | "dev": true 1386 | }, 1387 | "is-typedarray": { 1388 | "version": "1.0.0", 1389 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1390 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1391 | "dev": true 1392 | }, 1393 | "is-utf8": { 1394 | "version": "0.2.1", 1395 | "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", 1396 | "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=", 1397 | "dev": true 1398 | }, 1399 | "is-valid-glob": { 1400 | "version": "0.3.0", 1401 | "resolved": "https://registry.npmjs.org/is-valid-glob/-/is-valid-glob-0.3.0.tgz", 1402 | "integrity": "sha1-1LVcafUYhvm2XHDWwmItN+KfSP4=", 1403 | "dev": true 1404 | }, 1405 | "isarray": { 1406 | "version": "1.0.0", 1407 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1408 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1409 | "dev": true 1410 | }, 1411 | "isobject": { 1412 | "version": "2.1.0", 1413 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 1414 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 1415 | "dev": true, 1416 | "requires": { 1417 | "isarray": "1.0.0" 1418 | } 1419 | }, 1420 | "isstream": { 1421 | "version": "0.1.2", 1422 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 1423 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", 1424 | "dev": true 1425 | }, 1426 | "jsbn": { 1427 | "version": "0.1.1", 1428 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 1429 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 1430 | "dev": true, 1431 | "optional": true 1432 | }, 1433 | "json-schema": { 1434 | "version": "0.2.3", 1435 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 1436 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", 1437 | "dev": true 1438 | }, 1439 | "json-schema-traverse": { 1440 | "version": "0.3.1", 1441 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", 1442 | "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=", 1443 | "dev": true 1444 | }, 1445 | "json-stable-stringify": { 1446 | "version": "1.0.1", 1447 | "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", 1448 | "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", 1449 | "dev": true, 1450 | "requires": { 1451 | "jsonify": "0.0.0" 1452 | } 1453 | }, 1454 | "json-stringify-safe": { 1455 | "version": "5.0.1", 1456 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 1457 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", 1458 | "dev": true 1459 | }, 1460 | "json3": { 1461 | "version": "3.3.2", 1462 | "resolved": "https://registry.npmjs.org/json3/-/json3-3.3.2.tgz", 1463 | "integrity": "sha1-PAQ0dD35Pi9cQq7nsZvLSDV19OE=", 1464 | "dev": true 1465 | }, 1466 | "jsonify": { 1467 | "version": "0.0.0", 1468 | "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", 1469 | "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=", 1470 | "dev": true 1471 | }, 1472 | "jsonpointer": { 1473 | "version": "4.0.1", 1474 | "resolved": "https://registry.npmjs.org/jsonpointer/-/jsonpointer-4.0.1.tgz", 1475 | "integrity": "sha1-T9kss04OnbPInIYi7PUfm5eMbLk=", 1476 | "dev": true 1477 | }, 1478 | "jsprim": { 1479 | "version": "1.4.1", 1480 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 1481 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 1482 | "dev": true, 1483 | "requires": { 1484 | "assert-plus": "1.0.0", 1485 | "extsprintf": "1.3.0", 1486 | "json-schema": "0.2.3", 1487 | "verror": "1.10.0" 1488 | }, 1489 | "dependencies": { 1490 | "assert-plus": { 1491 | "version": "1.0.0", 1492 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 1493 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 1494 | "dev": true 1495 | } 1496 | } 1497 | }, 1498 | "kind-of": { 1499 | "version": "1.1.0", 1500 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-1.1.0.tgz", 1501 | "integrity": "sha1-FAo9LUGjbS78+pN3tiwk+ElaXEQ=", 1502 | "dev": true 1503 | }, 1504 | "lazystream": { 1505 | "version": "1.0.0", 1506 | "resolved": "https://registry.npmjs.org/lazystream/-/lazystream-1.0.0.tgz", 1507 | "integrity": "sha1-9plf4PggOS9hOWvolGJAe7dxaOQ=", 1508 | "dev": true, 1509 | "requires": { 1510 | "readable-stream": "2.3.5" 1511 | } 1512 | }, 1513 | "lodash._baseassign": { 1514 | "version": "3.2.0", 1515 | "resolved": "https://registry.npmjs.org/lodash._baseassign/-/lodash._baseassign-3.2.0.tgz", 1516 | "integrity": "sha1-jDigmVAPIVrQnlnxci/QxSv+Ck4=", 1517 | "dev": true, 1518 | "requires": { 1519 | "lodash._basecopy": "3.0.1", 1520 | "lodash.keys": "3.1.2" 1521 | } 1522 | }, 1523 | "lodash._basecopy": { 1524 | "version": "3.0.1", 1525 | "resolved": "https://registry.npmjs.org/lodash._basecopy/-/lodash._basecopy-3.0.1.tgz", 1526 | "integrity": "sha1-jaDmqHbPNEwK2KVIghEd08XHyjY=", 1527 | "dev": true 1528 | }, 1529 | "lodash._basecreate": { 1530 | "version": "3.0.3", 1531 | "resolved": "https://registry.npmjs.org/lodash._basecreate/-/lodash._basecreate-3.0.3.tgz", 1532 | "integrity": "sha1-G8ZhYU2qf8MRt9A78WgGoCE8+CE=", 1533 | "dev": true 1534 | }, 1535 | "lodash._basetostring": { 1536 | "version": "3.0.1", 1537 | "resolved": "https://registry.npmjs.org/lodash._basetostring/-/lodash._basetostring-3.0.1.tgz", 1538 | "integrity": "sha1-0YYdh3+CSlL2aYMtyvPuFVZqB9U=", 1539 | "dev": true 1540 | }, 1541 | "lodash._basevalues": { 1542 | "version": "3.0.0", 1543 | "resolved": "https://registry.npmjs.org/lodash._basevalues/-/lodash._basevalues-3.0.0.tgz", 1544 | "integrity": "sha1-W3dXYoAr3j0yl1A+JjAIIP32Ybc=", 1545 | "dev": true 1546 | }, 1547 | "lodash._getnative": { 1548 | "version": "3.9.1", 1549 | "resolved": "https://registry.npmjs.org/lodash._getnative/-/lodash._getnative-3.9.1.tgz", 1550 | "integrity": "sha1-VwvH3t5G1hzc3mh9ZdPuy6o6r/U=", 1551 | "dev": true 1552 | }, 1553 | "lodash._isiterateecall": { 1554 | "version": "3.0.9", 1555 | "resolved": "https://registry.npmjs.org/lodash._isiterateecall/-/lodash._isiterateecall-3.0.9.tgz", 1556 | "integrity": "sha1-UgOte6Ql+uhCRg5pbbnPPmqsBXw=", 1557 | "dev": true 1558 | }, 1559 | "lodash._reescape": { 1560 | "version": "3.0.0", 1561 | "resolved": "https://registry.npmjs.org/lodash._reescape/-/lodash._reescape-3.0.0.tgz", 1562 | "integrity": "sha1-Kx1vXf4HyKNVdT5fJ/rH8c3hYWo=", 1563 | "dev": true 1564 | }, 1565 | "lodash._reevaluate": { 1566 | "version": "3.0.0", 1567 | "resolved": "https://registry.npmjs.org/lodash._reevaluate/-/lodash._reevaluate-3.0.0.tgz", 1568 | "integrity": "sha1-WLx0xAZklTrgsSTYBpltrKQx4u0=", 1569 | "dev": true 1570 | }, 1571 | "lodash._reinterpolate": { 1572 | "version": "3.0.0", 1573 | "resolved": "https://registry.npmjs.org/lodash._reinterpolate/-/lodash._reinterpolate-3.0.0.tgz", 1574 | "integrity": "sha1-DM8tiRZq8Ds2Y8eWU4t1rG4RTZ0=", 1575 | "dev": true 1576 | }, 1577 | "lodash._root": { 1578 | "version": "3.0.1", 1579 | "resolved": "https://registry.npmjs.org/lodash._root/-/lodash._root-3.0.1.tgz", 1580 | "integrity": "sha1-+6HEUkwZ7ppfgTa0YJ8BfPTe1pI=", 1581 | "dev": true 1582 | }, 1583 | "lodash.create": { 1584 | "version": "3.1.1", 1585 | "resolved": "https://registry.npmjs.org/lodash.create/-/lodash.create-3.1.1.tgz", 1586 | "integrity": "sha1-1/KEnw29p+BGgruM1yqwIkYd6+c=", 1587 | "dev": true, 1588 | "requires": { 1589 | "lodash._baseassign": "3.2.0", 1590 | "lodash._basecreate": "3.0.3", 1591 | "lodash._isiterateecall": "3.0.9" 1592 | } 1593 | }, 1594 | "lodash.escape": { 1595 | "version": "3.2.0", 1596 | "resolved": "https://registry.npmjs.org/lodash.escape/-/lodash.escape-3.2.0.tgz", 1597 | "integrity": "sha1-mV7g3BjBtIzJLv+ucaEKq1tIdpg=", 1598 | "dev": true, 1599 | "requires": { 1600 | "lodash._root": "3.0.1" 1601 | } 1602 | }, 1603 | "lodash.isarguments": { 1604 | "version": "3.1.0", 1605 | "resolved": "https://registry.npmjs.org/lodash.isarguments/-/lodash.isarguments-3.1.0.tgz", 1606 | "integrity": "sha1-L1c9hcaiQon/AGY7SRwdM4/zRYo=", 1607 | "dev": true 1608 | }, 1609 | "lodash.isarray": { 1610 | "version": "3.0.4", 1611 | "resolved": "https://registry.npmjs.org/lodash.isarray/-/lodash.isarray-3.0.4.tgz", 1612 | "integrity": "sha1-eeTriMNqgSKvhvhEqpvNhRtfu1U=", 1613 | "dev": true 1614 | }, 1615 | "lodash.isequal": { 1616 | "version": "4.5.0", 1617 | "resolved": "https://registry.npmjs.org/lodash.isequal/-/lodash.isequal-4.5.0.tgz", 1618 | "integrity": "sha1-QVxEePK8wwEgwizhDtMib30+GOA=", 1619 | "dev": true 1620 | }, 1621 | "lodash.keys": { 1622 | "version": "3.1.2", 1623 | "resolved": "https://registry.npmjs.org/lodash.keys/-/lodash.keys-3.1.2.tgz", 1624 | "integrity": "sha1-TbwEcrFWvlCgsoaFXRvQsMZWCYo=", 1625 | "dev": true, 1626 | "requires": { 1627 | "lodash._getnative": "3.9.1", 1628 | "lodash.isarguments": "3.1.0", 1629 | "lodash.isarray": "3.0.4" 1630 | } 1631 | }, 1632 | "lodash.restparam": { 1633 | "version": "3.6.1", 1634 | "resolved": "https://registry.npmjs.org/lodash.restparam/-/lodash.restparam-3.6.1.tgz", 1635 | "integrity": "sha1-k2pOMJ7zMKdkXtQUWYbIWuWyCAU=", 1636 | "dev": true 1637 | }, 1638 | "lodash.template": { 1639 | "version": "3.6.2", 1640 | "resolved": "https://registry.npmjs.org/lodash.template/-/lodash.template-3.6.2.tgz", 1641 | "integrity": "sha1-+M3sxhaaJVvpCYrosMU9N4kx0U8=", 1642 | "dev": true, 1643 | "requires": { 1644 | "lodash._basecopy": "3.0.1", 1645 | "lodash._basetostring": "3.0.1", 1646 | "lodash._basevalues": "3.0.0", 1647 | "lodash._isiterateecall": "3.0.9", 1648 | "lodash._reinterpolate": "3.0.0", 1649 | "lodash.escape": "3.2.0", 1650 | "lodash.keys": "3.1.2", 1651 | "lodash.restparam": "3.6.1", 1652 | "lodash.templatesettings": "3.1.1" 1653 | } 1654 | }, 1655 | "lodash.templatesettings": { 1656 | "version": "3.1.1", 1657 | "resolved": "https://registry.npmjs.org/lodash.templatesettings/-/lodash.templatesettings-3.1.1.tgz", 1658 | "integrity": "sha1-+zB4RHU7Zrnxr6VOJix0UwfbqOU=", 1659 | "dev": true, 1660 | "requires": { 1661 | "lodash._reinterpolate": "3.0.0", 1662 | "lodash.escape": "3.2.0" 1663 | } 1664 | }, 1665 | "map-stream": { 1666 | "version": "0.1.0", 1667 | "resolved": "https://registry.npmjs.org/map-stream/-/map-stream-0.1.0.tgz", 1668 | "integrity": "sha1-5WqpTEyAVaFkBKBnS3jyFffI4ZQ=", 1669 | "dev": true 1670 | }, 1671 | "merge-stream": { 1672 | "version": "1.0.1", 1673 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-1.0.1.tgz", 1674 | "integrity": "sha1-QEEgLVCKNCugAXQAjfDCUbjBNeE=", 1675 | "dev": true, 1676 | "requires": { 1677 | "readable-stream": "2.3.5" 1678 | } 1679 | }, 1680 | "micromatch": { 1681 | "version": "2.3.11", 1682 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", 1683 | "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", 1684 | "dev": true, 1685 | "requires": { 1686 | "arr-diff": "2.0.0", 1687 | "array-unique": "0.2.1", 1688 | "braces": "1.8.5", 1689 | "expand-brackets": "0.1.5", 1690 | "extglob": "0.3.2", 1691 | "filename-regex": "2.0.1", 1692 | "is-extglob": "1.0.0", 1693 | "is-glob": "2.0.1", 1694 | "kind-of": "3.2.2", 1695 | "normalize-path": "2.1.1", 1696 | "object.omit": "2.0.1", 1697 | "parse-glob": "3.0.4", 1698 | "regex-cache": "0.4.4" 1699 | }, 1700 | "dependencies": { 1701 | "arr-diff": { 1702 | "version": "2.0.0", 1703 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", 1704 | "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", 1705 | "dev": true, 1706 | "requires": { 1707 | "arr-flatten": "1.1.0" 1708 | } 1709 | }, 1710 | "is-extglob": { 1711 | "version": "1.0.0", 1712 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 1713 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 1714 | "dev": true 1715 | }, 1716 | "is-glob": { 1717 | "version": "2.0.1", 1718 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 1719 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 1720 | "dev": true, 1721 | "requires": { 1722 | "is-extglob": "1.0.0" 1723 | } 1724 | }, 1725 | "kind-of": { 1726 | "version": "3.2.2", 1727 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1728 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1729 | "dev": true, 1730 | "requires": { 1731 | "is-buffer": "1.1.6" 1732 | } 1733 | } 1734 | } 1735 | }, 1736 | "mime-db": { 1737 | "version": "1.33.0", 1738 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.33.0.tgz", 1739 | "integrity": "sha512-BHJ/EKruNIqJf/QahvxwQZXKygOQ256myeN/Ew+THcAa5q+PjyTTMMeNQC4DZw5AwfvelsUrA6B67NKMqXDbzQ==", 1740 | "dev": true 1741 | }, 1742 | "mime-types": { 1743 | "version": "2.1.18", 1744 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.18.tgz", 1745 | "integrity": "sha512-lc/aahn+t4/SWV/qcmumYjymLsWfN3ELhpmVuUFjgsORruuZPVSwAQryq+HHGvO/SI2KVX26bx+En+zhM8g8hQ==", 1746 | "dev": true, 1747 | "requires": { 1748 | "mime-db": "1.33.0" 1749 | } 1750 | }, 1751 | "minimatch": { 1752 | "version": "3.0.4", 1753 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1754 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1755 | "dev": true, 1756 | "requires": { 1757 | "brace-expansion": "1.1.11" 1758 | } 1759 | }, 1760 | "minimist": { 1761 | "version": "0.0.8", 1762 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1763 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1764 | "dev": true 1765 | }, 1766 | "mkdirp": { 1767 | "version": "0.5.1", 1768 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1769 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1770 | "dev": true, 1771 | "requires": { 1772 | "minimist": "0.0.8" 1773 | } 1774 | }, 1775 | "mocha": { 1776 | "version": "3.5.3", 1777 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-3.5.3.tgz", 1778 | "integrity": "sha512-/6na001MJWEtYxHOV1WLfsmR4YIynkUEhBwzsb+fk2qmQ3iqsi258l/Q2MWHJMImAcNpZ8DEdYAK72NHoIQ9Eg==", 1779 | "dev": true, 1780 | "requires": { 1781 | "browser-stdout": "1.3.0", 1782 | "commander": "2.9.0", 1783 | "debug": "2.6.8", 1784 | "diff": "3.2.0", 1785 | "escape-string-regexp": "1.0.5", 1786 | "glob": "7.1.1", 1787 | "growl": "1.9.2", 1788 | "he": "1.1.1", 1789 | "json3": "3.3.2", 1790 | "lodash.create": "3.1.1", 1791 | "mkdirp": "0.5.1", 1792 | "supports-color": "3.1.2" 1793 | } 1794 | }, 1795 | "ms": { 1796 | "version": "2.0.0", 1797 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1798 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1799 | "dev": true 1800 | }, 1801 | "multimatch": { 1802 | "version": "2.1.0", 1803 | "resolved": "https://registry.npmjs.org/multimatch/-/multimatch-2.1.0.tgz", 1804 | "integrity": "sha1-nHkGoi+0wCkZ4vX3UWG0zb1LKis=", 1805 | "dev": true, 1806 | "requires": { 1807 | "array-differ": "1.0.0", 1808 | "array-union": "1.0.2", 1809 | "arrify": "1.0.1", 1810 | "minimatch": "3.0.4" 1811 | } 1812 | }, 1813 | "multipipe": { 1814 | "version": "0.1.2", 1815 | "resolved": "https://registry.npmjs.org/multipipe/-/multipipe-0.1.2.tgz", 1816 | "integrity": "sha1-Ko8t33Du1WTf8tV/HhoTfZ8FB4s=", 1817 | "dev": true, 1818 | "requires": { 1819 | "duplexer2": "0.0.2" 1820 | } 1821 | }, 1822 | "node.extend": { 1823 | "version": "1.1.6", 1824 | "resolved": "https://registry.npmjs.org/node.extend/-/node.extend-1.1.6.tgz", 1825 | "integrity": "sha1-p7iCyC1sk6SGOlUEvV3o7IYli5Y=", 1826 | "dev": true, 1827 | "requires": { 1828 | "is": "3.2.1" 1829 | } 1830 | }, 1831 | "normalize-path": { 1832 | "version": "2.1.1", 1833 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 1834 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 1835 | "dev": true, 1836 | "requires": { 1837 | "remove-trailing-separator": "1.1.0" 1838 | } 1839 | }, 1840 | "oauth-sign": { 1841 | "version": "0.8.2", 1842 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.8.2.tgz", 1843 | "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=", 1844 | "dev": true 1845 | }, 1846 | "object-assign": { 1847 | "version": "4.1.1", 1848 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1849 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1850 | "dev": true 1851 | }, 1852 | "object.omit": { 1853 | "version": "2.0.1", 1854 | "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz", 1855 | "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", 1856 | "dev": true, 1857 | "requires": { 1858 | "for-own": "0.1.5", 1859 | "is-extendable": "0.1.1" 1860 | } 1861 | }, 1862 | "once": { 1863 | "version": "1.4.0", 1864 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1865 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1866 | "dev": true, 1867 | "requires": { 1868 | "wrappy": "1.0.2" 1869 | } 1870 | }, 1871 | "ordered-read-streams": { 1872 | "version": "0.3.0", 1873 | "resolved": "https://registry.npmjs.org/ordered-read-streams/-/ordered-read-streams-0.3.0.tgz", 1874 | "integrity": "sha1-cTfmmzKYuzQiR6G77jiByA4v14s=", 1875 | "dev": true, 1876 | "requires": { 1877 | "is-stream": "1.1.0", 1878 | "readable-stream": "2.3.5" 1879 | } 1880 | }, 1881 | "parse-glob": { 1882 | "version": "3.0.4", 1883 | "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", 1884 | "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", 1885 | "dev": true, 1886 | "requires": { 1887 | "glob-base": "0.3.0", 1888 | "is-dotfile": "1.0.3", 1889 | "is-extglob": "1.0.0", 1890 | "is-glob": "2.0.1" 1891 | }, 1892 | "dependencies": { 1893 | "is-extglob": { 1894 | "version": "1.0.0", 1895 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 1896 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 1897 | "dev": true 1898 | }, 1899 | "is-glob": { 1900 | "version": "2.0.1", 1901 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 1902 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 1903 | "dev": true, 1904 | "requires": { 1905 | "is-extglob": "1.0.0" 1906 | } 1907 | } 1908 | } 1909 | }, 1910 | "path-dirname": { 1911 | "version": "1.0.2", 1912 | "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", 1913 | "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", 1914 | "dev": true 1915 | }, 1916 | "path-is-absolute": { 1917 | "version": "1.0.1", 1918 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1919 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1920 | "dev": true 1921 | }, 1922 | "pause-stream": { 1923 | "version": "0.0.11", 1924 | "resolved": "https://registry.npmjs.org/pause-stream/-/pause-stream-0.0.11.tgz", 1925 | "integrity": "sha1-/lo0sMvOErWqaitAPuLnO2AvFEU=", 1926 | "dev": true, 1927 | "requires": { 1928 | "through": "2.3.8" 1929 | } 1930 | }, 1931 | "pend": { 1932 | "version": "1.2.0", 1933 | "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", 1934 | "integrity": "sha1-elfrVQpng/kRUzH89GY9XI4AelA=", 1935 | "dev": true 1936 | }, 1937 | "performance-now": { 1938 | "version": "2.1.0", 1939 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 1940 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", 1941 | "dev": true 1942 | }, 1943 | "pinkie": { 1944 | "version": "2.0.4", 1945 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", 1946 | "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", 1947 | "dev": true 1948 | }, 1949 | "pinkie-promise": { 1950 | "version": "2.0.1", 1951 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", 1952 | "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", 1953 | "dev": true, 1954 | "requires": { 1955 | "pinkie": "2.0.4" 1956 | } 1957 | }, 1958 | "plugin-error": { 1959 | "version": "0.1.2", 1960 | "resolved": "https://registry.npmjs.org/plugin-error/-/plugin-error-0.1.2.tgz", 1961 | "integrity": "sha1-O5uzM1zPAPQl4HQ34ZJ2ln2kes4=", 1962 | "dev": true, 1963 | "requires": { 1964 | "ansi-cyan": "0.1.1", 1965 | "ansi-red": "0.1.1", 1966 | "arr-diff": "1.1.0", 1967 | "arr-union": "2.1.0", 1968 | "extend-shallow": "1.1.4" 1969 | } 1970 | }, 1971 | "preserve": { 1972 | "version": "0.2.0", 1973 | "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", 1974 | "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", 1975 | "dev": true 1976 | }, 1977 | "process-nextick-args": { 1978 | "version": "2.0.0", 1979 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 1980 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", 1981 | "dev": true 1982 | }, 1983 | "punycode": { 1984 | "version": "1.4.1", 1985 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 1986 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", 1987 | "dev": true 1988 | }, 1989 | "qs": { 1990 | "version": "6.3.2", 1991 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.3.2.tgz", 1992 | "integrity": "sha1-51vV9uJoEioqDgvaYwslUMFmUCw=", 1993 | "dev": true 1994 | }, 1995 | "querystringify": { 1996 | "version": "1.0.0", 1997 | "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-1.0.0.tgz", 1998 | "integrity": "sha1-YoYkIRLFtxL6ZU5SZlK/ahP/Bcs=", 1999 | "dev": true 2000 | }, 2001 | "queue": { 2002 | "version": "3.1.0", 2003 | "resolved": "https://registry.npmjs.org/queue/-/queue-3.1.0.tgz", 2004 | "integrity": "sha1-bEnQHwCeIlZ4h4nyv/rGuLmZBYU=", 2005 | "dev": true, 2006 | "requires": { 2007 | "inherits": "2.0.3" 2008 | } 2009 | }, 2010 | "randomatic": { 2011 | "version": "1.1.7", 2012 | "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-1.1.7.tgz", 2013 | "integrity": "sha512-D5JUjPyJbaJDkuAazpVnSfVkLlpeO3wDlPROTMLGKG1zMFNFRgrciKo1ltz/AzNTkqE0HzDx655QOL51N06how==", 2014 | "dev": true, 2015 | "requires": { 2016 | "is-number": "3.0.0", 2017 | "kind-of": "4.0.0" 2018 | }, 2019 | "dependencies": { 2020 | "is-number": { 2021 | "version": "3.0.0", 2022 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", 2023 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", 2024 | "dev": true, 2025 | "requires": { 2026 | "kind-of": "3.2.2" 2027 | }, 2028 | "dependencies": { 2029 | "kind-of": { 2030 | "version": "3.2.2", 2031 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2032 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2033 | "dev": true, 2034 | "requires": { 2035 | "is-buffer": "1.1.6" 2036 | } 2037 | } 2038 | } 2039 | }, 2040 | "kind-of": { 2041 | "version": "4.0.0", 2042 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", 2043 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", 2044 | "dev": true, 2045 | "requires": { 2046 | "is-buffer": "1.1.6" 2047 | } 2048 | } 2049 | } 2050 | }, 2051 | "readable-stream": { 2052 | "version": "2.3.5", 2053 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.5.tgz", 2054 | "integrity": "sha512-tK0yDhrkygt/knjowCUiWP9YdV7c5R+8cR0r/kt9ZhBU906Fs6RpQJCEilamRJj1Nx2rWI6LkW9gKqjTkshhEw==", 2055 | "dev": true, 2056 | "requires": { 2057 | "core-util-is": "1.0.2", 2058 | "inherits": "2.0.3", 2059 | "isarray": "1.0.0", 2060 | "process-nextick-args": "2.0.0", 2061 | "safe-buffer": "5.1.1", 2062 | "string_decoder": "1.0.3", 2063 | "util-deprecate": "1.0.2" 2064 | } 2065 | }, 2066 | "regex-cache": { 2067 | "version": "0.4.4", 2068 | "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.4.tgz", 2069 | "integrity": "sha512-nVIZwtCjkC9YgvWkpM55B5rBhBYRZhAaJbgcFYXXsHnbZ9UZI9nnVWYZpBlCqv9ho2eZryPnWrZGsOdPwVWXWQ==", 2070 | "dev": true, 2071 | "requires": { 2072 | "is-equal-shallow": "0.1.3" 2073 | } 2074 | }, 2075 | "remove-trailing-separator": { 2076 | "version": "1.1.0", 2077 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 2078 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", 2079 | "dev": true 2080 | }, 2081 | "repeat-element": { 2082 | "version": "1.1.2", 2083 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.2.tgz", 2084 | "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=", 2085 | "dev": true 2086 | }, 2087 | "repeat-string": { 2088 | "version": "1.6.1", 2089 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 2090 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", 2091 | "dev": true 2092 | }, 2093 | "replace-ext": { 2094 | "version": "1.0.0", 2095 | "resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-1.0.0.tgz", 2096 | "integrity": "sha1-3mMSg3P8v3w8z6TeWkgMRaZ5WOs=", 2097 | "dev": true 2098 | }, 2099 | "request": { 2100 | "version": "2.85.0", 2101 | "resolved": "https://registry.npmjs.org/request/-/request-2.85.0.tgz", 2102 | "integrity": "sha512-8H7Ehijd4js+s6wuVPLjwORxD4zeuyjYugprdOXlPSqaApmL/QOy+EB/beICHVCHkGMKNh5rvihb5ov+IDw4mg==", 2103 | "dev": true, 2104 | "requires": { 2105 | "aws-sign2": "0.7.0", 2106 | "aws4": "1.6.0", 2107 | "caseless": "0.12.0", 2108 | "combined-stream": "1.0.6", 2109 | "extend": "3.0.1", 2110 | "forever-agent": "0.6.1", 2111 | "form-data": "2.3.2", 2112 | "har-validator": "5.0.3", 2113 | "hawk": "6.0.2", 2114 | "http-signature": "1.2.0", 2115 | "is-typedarray": "1.0.0", 2116 | "isstream": "0.1.2", 2117 | "json-stringify-safe": "5.0.1", 2118 | "mime-types": "2.1.18", 2119 | "oauth-sign": "0.8.2", 2120 | "performance-now": "2.1.0", 2121 | "qs": "6.5.1", 2122 | "safe-buffer": "5.1.1", 2123 | "stringstream": "0.0.5", 2124 | "tough-cookie": "2.3.4", 2125 | "tunnel-agent": "0.6.0", 2126 | "uuid": "3.2.1" 2127 | }, 2128 | "dependencies": { 2129 | "assert-plus": { 2130 | "version": "1.0.0", 2131 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 2132 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 2133 | "dev": true 2134 | }, 2135 | "aws-sign2": { 2136 | "version": "0.7.0", 2137 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 2138 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 2139 | "dev": true 2140 | }, 2141 | "boom": { 2142 | "version": "4.3.1", 2143 | "resolved": "https://registry.npmjs.org/boom/-/boom-4.3.1.tgz", 2144 | "integrity": "sha1-T4owBctKfjiJ90kDD9JbluAdLjE=", 2145 | "dev": true, 2146 | "requires": { 2147 | "hoek": "4.2.1" 2148 | } 2149 | }, 2150 | "caseless": { 2151 | "version": "0.12.0", 2152 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 2153 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", 2154 | "dev": true 2155 | }, 2156 | "cryptiles": { 2157 | "version": "3.1.2", 2158 | "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-3.1.2.tgz", 2159 | "integrity": "sha1-qJ+7Ig9c4l7FboxKqKT9e1sNKf4=", 2160 | "dev": true, 2161 | "requires": { 2162 | "boom": "5.2.0" 2163 | }, 2164 | "dependencies": { 2165 | "boom": { 2166 | "version": "5.2.0", 2167 | "resolved": "https://registry.npmjs.org/boom/-/boom-5.2.0.tgz", 2168 | "integrity": "sha512-Z5BTk6ZRe4tXXQlkqftmsAUANpXmuwlsF5Oov8ThoMbQRzdGTA1ngYRW160GexgOgjsFOKJz0LYhoNi+2AMBUw==", 2169 | "dev": true, 2170 | "requires": { 2171 | "hoek": "4.2.1" 2172 | } 2173 | } 2174 | } 2175 | }, 2176 | "form-data": { 2177 | "version": "2.3.2", 2178 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.2.tgz", 2179 | "integrity": "sha1-SXBJi+YEwgwAXU9cI67NIda0kJk=", 2180 | "dev": true, 2181 | "requires": { 2182 | "asynckit": "0.4.0", 2183 | "combined-stream": "1.0.6", 2184 | "mime-types": "2.1.18" 2185 | } 2186 | }, 2187 | "har-validator": { 2188 | "version": "5.0.3", 2189 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.0.3.tgz", 2190 | "integrity": "sha1-ukAsJmGU8VlW7xXg/PJCmT9qff0=", 2191 | "dev": true, 2192 | "requires": { 2193 | "ajv": "5.5.2", 2194 | "har-schema": "2.0.0" 2195 | } 2196 | }, 2197 | "hawk": { 2198 | "version": "6.0.2", 2199 | "resolved": "https://registry.npmjs.org/hawk/-/hawk-6.0.2.tgz", 2200 | "integrity": "sha512-miowhl2+U7Qle4vdLqDdPt9m09K6yZhkLDTWGoUiUzrQCn+mHHSmfJgAyGaLRZbPmTqfFFjRV1QWCW0VWUJBbQ==", 2201 | "dev": true, 2202 | "requires": { 2203 | "boom": "4.3.1", 2204 | "cryptiles": "3.1.2", 2205 | "hoek": "4.2.1", 2206 | "sntp": "2.1.0" 2207 | } 2208 | }, 2209 | "hoek": { 2210 | "version": "4.2.1", 2211 | "resolved": "https://registry.npmjs.org/hoek/-/hoek-4.2.1.tgz", 2212 | "integrity": "sha512-QLg82fGkfnJ/4iy1xZ81/9SIJiq1NGFUMGs6ParyjBZr6jW2Ufj/snDqTHixNlHdPNwN2RLVD0Pi3igeK9+JfA==", 2213 | "dev": true 2214 | }, 2215 | "http-signature": { 2216 | "version": "1.2.0", 2217 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 2218 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 2219 | "dev": true, 2220 | "requires": { 2221 | "assert-plus": "1.0.0", 2222 | "jsprim": "1.4.1", 2223 | "sshpk": "1.14.1" 2224 | } 2225 | }, 2226 | "qs": { 2227 | "version": "6.5.1", 2228 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.1.tgz", 2229 | "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==", 2230 | "dev": true 2231 | }, 2232 | "sntp": { 2233 | "version": "2.1.0", 2234 | "resolved": "https://registry.npmjs.org/sntp/-/sntp-2.1.0.tgz", 2235 | "integrity": "sha512-FL1b58BDrqS3A11lJ0zEdnJ3UOKqVxawAkF3k7F0CVN7VQ34aZrV+G8BZ1WC9ZL7NyrwsW0oviwsWDgRuVYtJg==", 2236 | "dev": true, 2237 | "requires": { 2238 | "hoek": "4.2.1" 2239 | } 2240 | }, 2241 | "tunnel-agent": { 2242 | "version": "0.6.0", 2243 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 2244 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 2245 | "dev": true, 2246 | "requires": { 2247 | "safe-buffer": "5.1.1" 2248 | } 2249 | } 2250 | } 2251 | }, 2252 | "requires-port": { 2253 | "version": "1.0.0", 2254 | "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", 2255 | "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=", 2256 | "dev": true 2257 | }, 2258 | "rimraf": { 2259 | "version": "2.6.2", 2260 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 2261 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 2262 | "dev": true, 2263 | "requires": { 2264 | "glob": "7.1.1" 2265 | } 2266 | }, 2267 | "safe-buffer": { 2268 | "version": "5.1.1", 2269 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 2270 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==", 2271 | "dev": true 2272 | }, 2273 | "semver": { 2274 | "version": "5.5.0", 2275 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.0.tgz", 2276 | "integrity": "sha512-4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA==", 2277 | "dev": true 2278 | }, 2279 | "sntp": { 2280 | "version": "1.0.9", 2281 | "resolved": "https://registry.npmjs.org/sntp/-/sntp-1.0.9.tgz", 2282 | "integrity": "sha1-ZUEYTMkK7qbG57NeJlkIJEPGYZg=", 2283 | "dev": true, 2284 | "requires": { 2285 | "hoek": "2.16.3" 2286 | } 2287 | }, 2288 | "source-map": { 2289 | "version": "0.6.1", 2290 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2291 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2292 | "dev": true 2293 | }, 2294 | "source-map-support": { 2295 | "version": "0.5.4", 2296 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.4.tgz", 2297 | "integrity": "sha512-PETSPG6BjY1AHs2t64vS2aqAgu6dMIMXJULWFBGbh2Gr8nVLbCFDo6i/RMMvviIQ2h1Z8+5gQhVKSn2je9nmdg==", 2298 | "dev": true, 2299 | "requires": { 2300 | "source-map": "0.6.1" 2301 | } 2302 | }, 2303 | "sparkles": { 2304 | "version": "1.0.0", 2305 | "resolved": "https://registry.npmjs.org/sparkles/-/sparkles-1.0.0.tgz", 2306 | "integrity": "sha1-Gsu/tZJDbRC76PeFt8xvgoFQEsM=", 2307 | "dev": true 2308 | }, 2309 | "split": { 2310 | "version": "0.3.3", 2311 | "resolved": "https://registry.npmjs.org/split/-/split-0.3.3.tgz", 2312 | "integrity": "sha1-zQ7qXmOiEd//frDwkcQTPi0N0o8=", 2313 | "dev": true, 2314 | "requires": { 2315 | "through": "2.3.8" 2316 | } 2317 | }, 2318 | "sshpk": { 2319 | "version": "1.14.1", 2320 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.14.1.tgz", 2321 | "integrity": "sha1-Ew9Zde3a2WPx1W+SuaxsUfqfg+s=", 2322 | "dev": true, 2323 | "requires": { 2324 | "asn1": "0.2.3", 2325 | "assert-plus": "1.0.0", 2326 | "bcrypt-pbkdf": "1.0.1", 2327 | "dashdash": "1.14.1", 2328 | "ecc-jsbn": "0.1.1", 2329 | "getpass": "0.1.7", 2330 | "jsbn": "0.1.1", 2331 | "tweetnacl": "0.14.5" 2332 | }, 2333 | "dependencies": { 2334 | "assert-plus": { 2335 | "version": "1.0.0", 2336 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 2337 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 2338 | "dev": true 2339 | } 2340 | } 2341 | }, 2342 | "stat-mode": { 2343 | "version": "0.2.2", 2344 | "resolved": "https://registry.npmjs.org/stat-mode/-/stat-mode-0.2.2.tgz", 2345 | "integrity": "sha1-5sgLYjEj19gM8TLOU480YokHJQI=", 2346 | "dev": true 2347 | }, 2348 | "stream-combiner": { 2349 | "version": "0.0.4", 2350 | "resolved": "https://registry.npmjs.org/stream-combiner/-/stream-combiner-0.0.4.tgz", 2351 | "integrity": "sha1-TV5DPBhSYd3mI8o/RMWGvPXErRQ=", 2352 | "dev": true, 2353 | "requires": { 2354 | "duplexer": "0.1.1" 2355 | } 2356 | }, 2357 | "stream-shift": { 2358 | "version": "1.0.0", 2359 | "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.0.tgz", 2360 | "integrity": "sha1-1cdSgl5TZ+eG944Y5EXqIjoVWVI=", 2361 | "dev": true 2362 | }, 2363 | "streamfilter": { 2364 | "version": "1.0.7", 2365 | "resolved": "https://registry.npmjs.org/streamfilter/-/streamfilter-1.0.7.tgz", 2366 | "integrity": "sha512-Gk6KZM+yNA1JpW0KzlZIhjo3EaBJDkYfXtYSbOwNIQ7Zd6006E6+sCFlW1NDvFG/vnXhKmw6TJJgiEQg/8lXfQ==", 2367 | "dev": true, 2368 | "requires": { 2369 | "readable-stream": "2.3.5" 2370 | } 2371 | }, 2372 | "streamifier": { 2373 | "version": "0.1.1", 2374 | "resolved": "https://registry.npmjs.org/streamifier/-/streamifier-0.1.1.tgz", 2375 | "integrity": "sha1-l+mNj6TRBdYqJpHR3AfoINuN/E8=", 2376 | "dev": true 2377 | }, 2378 | "string_decoder": { 2379 | "version": "1.0.3", 2380 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", 2381 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", 2382 | "dev": true, 2383 | "requires": { 2384 | "safe-buffer": "5.1.1" 2385 | } 2386 | }, 2387 | "stringstream": { 2388 | "version": "0.0.5", 2389 | "resolved": "https://registry.npmjs.org/stringstream/-/stringstream-0.0.5.tgz", 2390 | "integrity": "sha1-TkhM1N5aC7vuGORjB3EKioFiGHg=", 2391 | "dev": true 2392 | }, 2393 | "strip-ansi": { 2394 | "version": "3.0.1", 2395 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 2396 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 2397 | "dev": true, 2398 | "requires": { 2399 | "ansi-regex": "2.1.1" 2400 | } 2401 | }, 2402 | "strip-bom": { 2403 | "version": "2.0.0", 2404 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz", 2405 | "integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=", 2406 | "dev": true, 2407 | "requires": { 2408 | "is-utf8": "0.2.1" 2409 | } 2410 | }, 2411 | "strip-bom-stream": { 2412 | "version": "1.0.0", 2413 | "resolved": "https://registry.npmjs.org/strip-bom-stream/-/strip-bom-stream-1.0.0.tgz", 2414 | "integrity": "sha1-5xRDmFd9Uaa+0PoZlPoF9D/ZiO4=", 2415 | "dev": true, 2416 | "requires": { 2417 | "first-chunk-stream": "1.0.0", 2418 | "strip-bom": "2.0.0" 2419 | } 2420 | }, 2421 | "supports-color": { 2422 | "version": "3.1.2", 2423 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.1.2.tgz", 2424 | "integrity": "sha1-cqJiiU2dQIuVbKBf83su2KbiotU=", 2425 | "dev": true, 2426 | "requires": { 2427 | "has-flag": "1.0.0" 2428 | } 2429 | }, 2430 | "tar": { 2431 | "version": "2.2.1", 2432 | "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.1.tgz", 2433 | "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=", 2434 | "dev": true, 2435 | "requires": { 2436 | "block-stream": "0.0.9", 2437 | "fstream": "1.0.11", 2438 | "inherits": "2.0.3" 2439 | } 2440 | }, 2441 | "through": { 2442 | "version": "2.3.8", 2443 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2444 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2445 | "dev": true 2446 | }, 2447 | "through2": { 2448 | "version": "2.0.3", 2449 | "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.3.tgz", 2450 | "integrity": "sha1-AARWmzfHx0ujnEPzzteNGtlBQL4=", 2451 | "dev": true, 2452 | "requires": { 2453 | "readable-stream": "2.3.5", 2454 | "xtend": "4.0.1" 2455 | } 2456 | }, 2457 | "through2-filter": { 2458 | "version": "2.0.0", 2459 | "resolved": "https://registry.npmjs.org/through2-filter/-/through2-filter-2.0.0.tgz", 2460 | "integrity": "sha1-YLxVoNrLdghdsfna6Zq0P4PWIuw=", 2461 | "dev": true, 2462 | "requires": { 2463 | "through2": "2.0.3", 2464 | "xtend": "4.0.1" 2465 | } 2466 | }, 2467 | "time-stamp": { 2468 | "version": "1.1.0", 2469 | "resolved": "https://registry.npmjs.org/time-stamp/-/time-stamp-1.1.0.tgz", 2470 | "integrity": "sha1-dkpaEa9QVhkhsTPztE5hhofg9cM=", 2471 | "dev": true 2472 | }, 2473 | "to-absolute-glob": { 2474 | "version": "0.1.1", 2475 | "resolved": "https://registry.npmjs.org/to-absolute-glob/-/to-absolute-glob-0.1.1.tgz", 2476 | "integrity": "sha1-HN+kcqnvUMI57maZm2YsoOs5k38=", 2477 | "dev": true, 2478 | "requires": { 2479 | "extend-shallow": "2.0.1" 2480 | }, 2481 | "dependencies": { 2482 | "extend-shallow": { 2483 | "version": "2.0.1", 2484 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2485 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2486 | "dev": true, 2487 | "requires": { 2488 | "is-extendable": "0.1.1" 2489 | } 2490 | } 2491 | } 2492 | }, 2493 | "tough-cookie": { 2494 | "version": "2.3.4", 2495 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.4.tgz", 2496 | "integrity": "sha512-TZ6TTfI5NtZnuyy/Kecv+CnoROnyXn2DN97LontgQpCwsX2XyLYCC0ENhYkehSOwAp8rTQKc/NUIF7BkQ5rKLA==", 2497 | "dev": true, 2498 | "requires": { 2499 | "punycode": "1.4.1" 2500 | } 2501 | }, 2502 | "tunnel-agent": { 2503 | "version": "0.4.3", 2504 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.4.3.tgz", 2505 | "integrity": "sha1-Y3PbdpCf5XDgjXNYM2Xtgop07us=", 2506 | "dev": true 2507 | }, 2508 | "tweetnacl": { 2509 | "version": "0.14.5", 2510 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 2511 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 2512 | "dev": true, 2513 | "optional": true 2514 | }, 2515 | "typescript": { 2516 | "version": "2.8.1", 2517 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-2.8.1.tgz", 2518 | "integrity": "sha512-Ao/f6d/4EPLq0YwzsQz8iXflezpTkQzqAyenTiw4kCUGr1uPiFLC3+fZ+gMZz6eeI/qdRUqvC+HxIJzUAzEFdg==", 2519 | "dev": true 2520 | }, 2521 | "unique-stream": { 2522 | "version": "2.2.1", 2523 | "resolved": "https://registry.npmjs.org/unique-stream/-/unique-stream-2.2.1.tgz", 2524 | "integrity": "sha1-WqADz76Uxf+GbE59ZouxxNuts2k=", 2525 | "dev": true, 2526 | "requires": { 2527 | "json-stable-stringify": "1.0.1", 2528 | "through2-filter": "2.0.0" 2529 | } 2530 | }, 2531 | "url-parse": { 2532 | "version": "1.2.0", 2533 | "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.2.0.tgz", 2534 | "integrity": "sha512-DT1XbYAfmQP65M/mE6OALxmXzZ/z1+e5zk2TcSKe/KiYbNGZxgtttzC0mR/sjopbpOXcbniq7eIKmocJnUWlEw==", 2535 | "dev": true, 2536 | "requires": { 2537 | "querystringify": "1.0.0", 2538 | "requires-port": "1.0.0" 2539 | } 2540 | }, 2541 | "util-deprecate": { 2542 | "version": "1.0.2", 2543 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2544 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2545 | "dev": true 2546 | }, 2547 | "uuid": { 2548 | "version": "3.2.1", 2549 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.2.1.tgz", 2550 | "integrity": "sha512-jZnMwlb9Iku/O3smGWvZhauCf6cvvpKi4BKRiliS3cxnI+Gz9j5MEpTz2UFuXiKPJocb7gnsLHwiS05ige5BEA==", 2551 | "dev": true 2552 | }, 2553 | "vali-date": { 2554 | "version": "1.0.0", 2555 | "resolved": "https://registry.npmjs.org/vali-date/-/vali-date-1.0.0.tgz", 2556 | "integrity": "sha1-G5BKWWCfsyjvB4E4Qgk09rhnCaY=", 2557 | "dev": true 2558 | }, 2559 | "verror": { 2560 | "version": "1.10.0", 2561 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 2562 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 2563 | "dev": true, 2564 | "requires": { 2565 | "assert-plus": "1.0.0", 2566 | "core-util-is": "1.0.2", 2567 | "extsprintf": "1.3.0" 2568 | }, 2569 | "dependencies": { 2570 | "assert-plus": { 2571 | "version": "1.0.0", 2572 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 2573 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 2574 | "dev": true 2575 | } 2576 | } 2577 | }, 2578 | "vinyl": { 2579 | "version": "0.4.6", 2580 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-0.4.6.tgz", 2581 | "integrity": "sha1-LzVsh6VQolVGHza76ypbqL94SEc=", 2582 | "dev": true, 2583 | "requires": { 2584 | "clone": "0.2.0", 2585 | "clone-stats": "0.0.1" 2586 | } 2587 | }, 2588 | "vinyl-fs": { 2589 | "version": "2.4.4", 2590 | "resolved": "https://registry.npmjs.org/vinyl-fs/-/vinyl-fs-2.4.4.tgz", 2591 | "integrity": "sha1-vm/zJwy1Xf19MGNkDegfJddTIjk=", 2592 | "dev": true, 2593 | "requires": { 2594 | "duplexify": "3.5.4", 2595 | "glob-stream": "5.3.5", 2596 | "graceful-fs": "4.1.11", 2597 | "gulp-sourcemaps": "1.6.0", 2598 | "is-valid-glob": "0.3.0", 2599 | "lazystream": "1.0.0", 2600 | "lodash.isequal": "4.5.0", 2601 | "merge-stream": "1.0.1", 2602 | "mkdirp": "0.5.1", 2603 | "object-assign": "4.1.1", 2604 | "readable-stream": "2.3.5", 2605 | "strip-bom": "2.0.0", 2606 | "strip-bom-stream": "1.0.0", 2607 | "through2": "2.0.3", 2608 | "through2-filter": "2.0.0", 2609 | "vali-date": "1.0.0", 2610 | "vinyl": "1.2.0" 2611 | }, 2612 | "dependencies": { 2613 | "clone": { 2614 | "version": "1.0.4", 2615 | "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", 2616 | "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", 2617 | "dev": true 2618 | }, 2619 | "replace-ext": { 2620 | "version": "0.0.1", 2621 | "resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-0.0.1.tgz", 2622 | "integrity": "sha1-KbvZIHinOfC8zitO5B6DeVNSKSQ=", 2623 | "dev": true 2624 | }, 2625 | "vinyl": { 2626 | "version": "1.2.0", 2627 | "resolved": "https://registry.npmjs.org/vinyl/-/vinyl-1.2.0.tgz", 2628 | "integrity": "sha1-XIgDbPVl5d8FVYv8kR+GVt8hiIQ=", 2629 | "dev": true, 2630 | "requires": { 2631 | "clone": "1.0.4", 2632 | "clone-stats": "0.0.1", 2633 | "replace-ext": "0.0.1" 2634 | } 2635 | } 2636 | } 2637 | }, 2638 | "vinyl-source-stream": { 2639 | "version": "1.1.2", 2640 | "resolved": "https://registry.npmjs.org/vinyl-source-stream/-/vinyl-source-stream-1.1.2.tgz", 2641 | "integrity": "sha1-YrU6E1YQqJbpjKlr7jqH8Aio54A=", 2642 | "dev": true, 2643 | "requires": { 2644 | "through2": "2.0.3", 2645 | "vinyl": "0.4.6" 2646 | } 2647 | }, 2648 | "vscode": { 2649 | "version": "1.1.14", 2650 | "resolved": "https://registry.npmjs.org/vscode/-/vscode-1.1.14.tgz", 2651 | "integrity": "sha512-acfn3fzGtTm7UjChAN7/YjsC0qIyJeuSrJwvm6qb7tLN6Geq1FmCz1JnBOc3kaY+HCLjQBAfwG/CsgnasOdXMw==", 2652 | "dev": true, 2653 | "requires": { 2654 | "glob": "7.1.2", 2655 | "gulp-chmod": "2.0.0", 2656 | "gulp-filter": "5.1.0", 2657 | "gulp-gunzip": "1.0.0", 2658 | "gulp-remote-src": "0.4.3", 2659 | "gulp-symdest": "1.1.0", 2660 | "gulp-untar": "0.0.6", 2661 | "gulp-vinyl-zip": "2.1.0", 2662 | "mocha": "4.1.0", 2663 | "request": "2.85.0", 2664 | "semver": "5.5.0", 2665 | "source-map-support": "0.5.4", 2666 | "url-parse": "1.2.0", 2667 | "vinyl-source-stream": "1.1.2" 2668 | }, 2669 | "dependencies": { 2670 | "commander": { 2671 | "version": "2.11.0", 2672 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.11.0.tgz", 2673 | "integrity": "sha512-b0553uYA5YAEGgyYIGYROzKQ7X5RAqedkfjiZxwi0kL1g3bOaBNNZfYkzt/CL0umgD5wc9Jec2FbB98CjkMRvQ==", 2674 | "dev": true 2675 | }, 2676 | "debug": { 2677 | "version": "3.1.0", 2678 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 2679 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 2680 | "dev": true, 2681 | "requires": { 2682 | "ms": "2.0.0" 2683 | } 2684 | }, 2685 | "diff": { 2686 | "version": "3.3.1", 2687 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.3.1.tgz", 2688 | "integrity": "sha512-MKPHZDMB0o6yHyDryUOScqZibp914ksXwAMYMTHj6KO8UeKsRYNJD3oNCKjTqZon+V488P7N/HzXF8t7ZR95ww==", 2689 | "dev": true 2690 | }, 2691 | "glob": { 2692 | "version": "7.1.2", 2693 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 2694 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 2695 | "dev": true, 2696 | "requires": { 2697 | "fs.realpath": "1.0.0", 2698 | "inflight": "1.0.6", 2699 | "inherits": "2.0.3", 2700 | "minimatch": "3.0.4", 2701 | "once": "1.4.0", 2702 | "path-is-absolute": "1.0.1" 2703 | } 2704 | }, 2705 | "growl": { 2706 | "version": "1.10.3", 2707 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.3.tgz", 2708 | "integrity": "sha512-hKlsbA5Vu3xsh1Cg3J7jSmX/WaW6A5oBeqzM88oNbCRQFz+zUaXm6yxS4RVytp1scBoJzSYl4YAEOQIt6O8V1Q==", 2709 | "dev": true 2710 | }, 2711 | "has-flag": { 2712 | "version": "2.0.0", 2713 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz", 2714 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=", 2715 | "dev": true 2716 | }, 2717 | "mocha": { 2718 | "version": "4.1.0", 2719 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-4.1.0.tgz", 2720 | "integrity": "sha512-0RVnjg1HJsXY2YFDoTNzcc1NKhYuXKRrBAG2gDygmJJA136Cs2QlRliZG1mA0ap7cuaT30mw16luAeln+4RiNA==", 2721 | "dev": true, 2722 | "requires": { 2723 | "browser-stdout": "1.3.0", 2724 | "commander": "2.11.0", 2725 | "debug": "3.1.0", 2726 | "diff": "3.3.1", 2727 | "escape-string-regexp": "1.0.5", 2728 | "glob": "7.1.2", 2729 | "growl": "1.10.3", 2730 | "he": "1.1.1", 2731 | "mkdirp": "0.5.1", 2732 | "supports-color": "4.4.0" 2733 | } 2734 | }, 2735 | "supports-color": { 2736 | "version": "4.4.0", 2737 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.4.0.tgz", 2738 | "integrity": "sha512-rKC3+DyXWgK0ZLKwmRsrkyHVZAjNkfzeehuFWdGGcqGDTZFH73+RH6S/RDAAxl9GusSjZSUWYLmT9N5pzXFOXQ==", 2739 | "dev": true, 2740 | "requires": { 2741 | "has-flag": "2.0.0" 2742 | } 2743 | } 2744 | } 2745 | }, 2746 | "wrappy": { 2747 | "version": "1.0.2", 2748 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2749 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2750 | "dev": true 2751 | }, 2752 | "xtend": { 2753 | "version": "4.0.1", 2754 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 2755 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=", 2756 | "dev": true 2757 | }, 2758 | "yauzl": { 2759 | "version": "2.9.1", 2760 | "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.9.1.tgz", 2761 | "integrity": "sha1-qBmB6nCleUYTOIPwKcWCGok1mn8=", 2762 | "dev": true, 2763 | "requires": { 2764 | "buffer-crc32": "0.2.13", 2765 | "fd-slicer": "1.0.1" 2766 | } 2767 | }, 2768 | "yazl": { 2769 | "version": "2.4.3", 2770 | "resolved": "https://registry.npmjs.org/yazl/-/yazl-2.4.3.tgz", 2771 | "integrity": "sha1-7CblzIfVYBud+EMtvdPNLlFzoHE=", 2772 | "dev": true, 2773 | "requires": { 2774 | "buffer-crc32": "0.2.13" 2775 | } 2776 | } 2777 | } 2778 | } 2779 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "gitflow", 3 | "displayName": "gitflow", 4 | "description": "Gitflow integration and support in Visual Studio Code", 5 | "version": "1.2.1", 6 | "publisher": "vector-of-bool", 7 | "repository": { 8 | "type": "git", 9 | "url": "https://github.com/vector-of-bool/vscode-gitflow" 10 | }, 11 | "bugs": { 12 | "url": "https://github.com/vector-of-bool/vscode-gitflow/issues" 13 | }, 14 | "homepage": "https://github.com/vector-of-bool/vscode-gitflow", 15 | "keywords": [ 16 | "git", 17 | "flow" 18 | ], 19 | "engines": { 20 | "vscode": "^1.13.0" 21 | }, 22 | "categories": [ 23 | "Other" 24 | ], 25 | "galleryBanner": { 26 | "color": "#09585e", 27 | "theme": "dark" 28 | }, 29 | "icon": "res/icon_128.png", 30 | "activationEvents": [ 31 | "*" 32 | ], 33 | "main": "./out/src/extension", 34 | "contributes": { 35 | "commands": [ 36 | { 37 | "command": "gitflow.initialize", 38 | "title": "Initialize repository for gitflow", 39 | "category": "Gitflow" 40 | }, 41 | { 42 | "command": "gitflow.featureStart", 43 | "title": "Feature: start", 44 | "category": "Gitflow" 45 | }, 46 | { 47 | "command": "gitflow.featureRebase", 48 | "title": "Feature: rebase", 49 | "category": "Gitflow" 50 | }, 51 | { 52 | "command": "gitflow.featureFinish", 53 | "title": "Feature: finish", 54 | "category": "Gitflow" 55 | }, 56 | { 57 | "command": "gitflow.bugfixStart", 58 | "title": "Bugfix: start", 59 | "category": "Gitflow" 60 | }, 61 | { 62 | "command": "gitflow.bugfixRebase", 63 | "title": "Bugfix: rebase", 64 | "category": "Gitflow" 65 | }, 66 | { 67 | "command": "gitflow.bugfixFinish", 68 | "title": "Bugfix: finish", 69 | "category": "Gitflow" 70 | }, 71 | { 72 | "command": "gitflow.releaseStart", 73 | "title": "Release: start", 74 | "category": "Gitflow" 75 | }, 76 | { 77 | "command": "gitflow.releaseFinish", 78 | "title": "Release: finish", 79 | "category": "Gitflow" 80 | }, 81 | { 82 | "command": "gitflow.hotfixStart", 83 | "title": "Hotfix: start", 84 | "category": "Gitflow" 85 | }, 86 | { 87 | "command": "gitflow.hotfixFinish", 88 | "title": "Hotfix: finish", 89 | "category": "Gitflow" 90 | } 91 | ], 92 | "configuration": { 93 | "properties": { 94 | "gitflow.deleteBranchOnFinish": { 95 | "type": "boolean", 96 | "default": true, 97 | "description": "After finishing a branch, delete the branch" 98 | }, 99 | "gitflow.deleteRemoteBranches": { 100 | "type": "boolean", 101 | "default": true, 102 | "description": "If true, and `gitflow.deleteBranchOnFinish` is true, remote branches will be deleted when finishing a branch" 103 | }, 104 | "gitflow.default.development": { 105 | "type": "string", 106 | "default": "develop", 107 | "description": "Default name for the development branch [develop]" 108 | }, 109 | "gitflow.default.production": { 110 | "type": "string", 111 | "default": "master", 112 | "description": "Default name for the production branch [master]" 113 | } 114 | } 115 | } 116 | }, 117 | "scripts": { 118 | "vscode:prepublish": "./node_modules/typescript/bin/tsc -p ./", 119 | "compile": "./node_modules/typescript/bin/tsc -watch -p ./", 120 | "postinstall": "node ./node_modules/vscode/bin/install" 121 | }, 122 | "devDependencies": { 123 | "typescript": "^2.0.3", 124 | "@types/node": "~7.0.31", 125 | "mocha": "^3.2.0", 126 | "@types/mocha": "^2.2.34", 127 | "vscode": "^1.1.0" 128 | } 129 | } 130 | -------------------------------------------------------------------------------- /res/Step1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/vector-of-bool/vscode-gitflow/863324574a3ca1e201e570ccc3bcc31ff8f89afb/res/Step1.png -------------------------------------------------------------------------------- /res/defaults.PNG: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/vector-of-bool/vscode-gitflow/863324574a3ca1e201e570ccc3bcc31ff8f89afb/res/defaults.PNG -------------------------------------------------------------------------------- /res/gitflow.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/vector-of-bool/vscode-gitflow/863324574a3ca1e201e570ccc3bcc31ff8f89afb/res/gitflow.png -------------------------------------------------------------------------------- /res/icon.svg: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 22 | 24 | 27 | 31 | 35 | 39 | 43 | 44 | 47 | 51 | 55 | 56 | 59 | 63 | 67 | 71 | 75 | 76 | 79 | 83 | 87 | 91 | 95 | 96 | 98 | 102 | 106 | 107 | 114 | 119 | 120 | 127 | 132 | 133 | 140 | 145 | 146 | 153 | 158 | 159 | 166 | 171 | 172 | 182 | 191 | 202 | 213 | 224 | 235 | 246 | 249 | 255 | 256 | 259 | 266 | 267 | 270 | 276 | 277 | 280 | 287 | 288 | 291 | 297 | 298 | 301 | 308 | 309 | 312 | 318 | 319 | 322 | 328 | 329 | 332 | 339 | 340 | 343 | 350 | 351 | 354 | 361 | 362 | 365 | 372 | 373 | 376 | 382 | 383 | 394 | 395 | 421 | 425 | 426 | 428 | 429 | 431 | image/svg+xml 432 | 434 | 435 | 436 | 437 | 438 | 443 | 450 | 456 | 462 | 468 | 471 | 474 | 479 | 483 | 490 | 497 | 504 | 505 | 513 | 517 | 524 | 531 | 538 | 539 | 547 | 551 | 558 | 565 | 572 | 573 | 581 | 589 | 597 | 602 | 609 | 610 | 618 | 626 | 634 | 642 | 650 | 658 | 659 | 660 | -------------------------------------------------------------------------------- /res/icon_128.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/vector-of-bool/vscode-gitflow/863324574a3ca1e201e570ccc3bcc31ff8f89afb/res/icon_128.png -------------------------------------------------------------------------------- /src/cmd.ts: -------------------------------------------------------------------------------- 1 | import * as proc from 'child_process'; 2 | import * as vscode from 'vscode'; 3 | 4 | import {fail} from './fail'; 5 | 6 | 7 | export namespace cmd { 8 | export interface ExecutionResult { 9 | retc: number; 10 | stdout: string; 11 | stderr: string; 12 | } 13 | 14 | export function execute( 15 | command: string, args: string[], 16 | options?: proc.SpawnOptions): Promise { 17 | return new Promise((resolve, reject) => { 18 | options = options || {}; 19 | options.cwd = options.cwd || vscode.workspace.rootPath; 20 | console.log(`[gitflow] Execute ${command}`, args.join(' ')); 21 | const child = proc.spawn(command, args, options); 22 | child.on('error', (err) => { 23 | reject(err); 24 | }); 25 | let stdout_acc = ''; 26 | let stderr_acc = ''; 27 | child.stdout.on('data', (data: Uint8Array) => { 28 | stdout_acc += data.toString(); 29 | }); 30 | child.stderr.on('data', (data: Uint8Array) => { 31 | stderr_acc += data.toString(); 32 | }); 33 | child.on('close', (retc) => { 34 | console.log(`[gitflow] Command "${command}" returned code ${retc 35 | }: ${stderr_acc}`); 36 | resolve({retc: retc, stdout: stdout_acc, stderr: stderr_acc}); 37 | }); 38 | }); 39 | }; 40 | 41 | export async function 42 | executeRequired(command: string, args: string[], options?: proc.SpawnOptions): 43 | Promise { 44 | const result = await execute(command, args, options); 45 | if (result.retc !== 0) { 46 | fail.error({message: `"${command}" returned status ${result.retc}`}); 47 | } 48 | return result; 49 | } 50 | } -------------------------------------------------------------------------------- /src/config.ts: -------------------------------------------------------------------------------- 1 | import * as vscode from 'vscode'; 2 | 3 | class ConfigReader { 4 | private _readConfig(key: string, default_: T): T { 5 | const val = vscode.workspace.getConfiguration('gitflow').get(key); 6 | if (val === undefined) { 7 | return default_; 8 | } 9 | return val; 10 | } 11 | 12 | get deleteBranchOnFinish(): boolean { 13 | return this._readConfig('deleteBranchOnFinish', true); 14 | } 15 | 16 | get deleteRemoteBranches(): boolean { 17 | return this._readConfig('deleteRemoteBranches', true); 18 | } 19 | 20 | get default_development(): string { 21 | return this._readConfig('default.development', 'develop'); 22 | } 23 | 24 | get default_production(): string { 25 | return this._readConfig('default.production', 'master'); 26 | } 27 | } 28 | 29 | export const config = new ConfigReader(); -------------------------------------------------------------------------------- /src/extension.ts: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | import * as vscode from 'vscode'; 4 | import {findGit, git} from './git'; 5 | import {flow} from './flow'; 6 | import {fail} from './fail' 7 | 8 | async function runWrapped(fn: (...any) => Thenable, args: any[] = []): Promise { 9 | try { 10 | return await fn(...args); 11 | } catch (e) { 12 | if (!e.handlers && !e.message) { 13 | throw e; 14 | } 15 | 16 | const err: fail.IError = e; 17 | const chosen = await vscode.window.showErrorMessage(err.message, ...(err.handlers || [])); 18 | if (!!chosen) { 19 | return await runWrapped(chosen.cb); 20 | } 21 | return null; 22 | } 23 | } 24 | 25 | async function setup(disposables: vscode.Disposable[]) { 26 | const pathHint = vscode.workspace.getConfiguration('git').get('path'); 27 | git.info = await findGit(pathHint); 28 | vscode.window.setStatusBarMessage( 29 | 'gitflow using git executable: ' + git.info.path + ' with version ' + 30 | git.info.version, 5000); 31 | const commands = [ 32 | vscode.commands.registerCommand( 33 | 'gitflow.initialize', 34 | async () => { 35 | await runWrapped(flow.initialize); 36 | }), 37 | vscode.commands.registerCommand( 38 | 'gitflow.featureStart', 39 | async () => { 40 | await runWrapped(flow.requireFlowEnabled); 41 | await runWrapped(flow.feature.precheck); 42 | const name = await vscode.window.showInputBox({ 43 | placeHolder: 'my-awesome-feature', 44 | prompt: 'A new name for your feature', 45 | }); 46 | if (!name) { return; } 47 | await runWrapped(flow.feature.start, [name.split(' ').join('-'), 'feature']); 48 | }), 49 | vscode.commands.registerCommand( 50 | 'gitflow.featureRebase', 51 | async () => { 52 | await runWrapped(flow.feature.rebase, ['feature']); 53 | }), 54 | vscode.commands.registerCommand( 55 | 'gitflow.featureFinish', 56 | async () => { 57 | await runWrapped(flow.feature.finish, ['feature']); 58 | }), 59 | vscode.commands.registerCommand( 60 | 'gitflow.bugfixStart', 61 | async () => { 62 | await runWrapped(flow.requireFlowEnabled); 63 | await runWrapped(flow.feature.precheck); 64 | const name = await vscode.window.showInputBox({ 65 | placeHolder: 'my-awesome-bugfix', 66 | prompt: 'A new name for your bugfix', 67 | }); 68 | if (!name) { return; } 69 | await runWrapped(flow.feature.start, [name.split(' ').join('-'), 'bugfix']); 70 | }), 71 | vscode.commands.registerCommand( 72 | 'gitflow.bugfixRebase', 73 | async () => { 74 | await runWrapped(flow.feature.rebase, ['bugfix']); 75 | }), 76 | vscode.commands.registerCommand( 77 | 'gitflow.bugfixFinish', 78 | async () => { 79 | await runWrapped(flow.feature.finish, ['bugfix']); 80 | }), 81 | vscode.commands.registerCommand( 82 | 'gitflow.releaseStart', 83 | async () => { 84 | await runWrapped(flow.requireFlowEnabled); 85 | await runWrapped(flow.release.precheck); 86 | const guessedVersion = await runWrapped( 87 | flow.release.guess_new_version) || ''; 88 | const name = await vscode.window.showInputBox({ 89 | placeHolder: guessedVersion, 90 | prompt: 'The name of the release', 91 | value: guessedVersion, 92 | }); 93 | if (!name) { return; } 94 | await runWrapped(flow.release.start, [name.split(' ').join('-')]); 95 | }), 96 | vscode.commands.registerCommand( 97 | 'gitflow.releaseFinish', 98 | async () => { 99 | await runWrapped(flow.release.finish); 100 | }), 101 | vscode.commands.registerCommand( 102 | 'gitflow.hotfixStart', 103 | async () => { 104 | await runWrapped(flow.requireFlowEnabled); 105 | const guessedVersion = await runWrapped( 106 | flow.hotfix.guess_new_version) || ''; 107 | const name = await vscode.window.showInputBox({ 108 | placeHolder: guessedVersion, 109 | prompt: 'The name of the hotfix version', 110 | value: guessedVersion, 111 | }); 112 | if (!name) { return; } 113 | await runWrapped(flow.hotfix.start, [name.split(' ').join('-')]); 114 | }), 115 | vscode.commands.registerCommand( 116 | 'gitflow.hotfixFinish', 117 | async () => { 118 | await runWrapped(flow.hotfix.finish); 119 | }), 120 | ]; 121 | // add disposable 122 | disposables.push(...commands); 123 | } 124 | 125 | export function activate(context: vscode.ExtensionContext) { 126 | const disposables: vscode.Disposable[] = []; 127 | context.subscriptions.push(new vscode.Disposable( 128 | () => vscode.Disposable.from(...disposables).dispose())); 129 | 130 | setup(disposables).catch((err) => console.error(err)); 131 | } 132 | 133 | export function 134 | // tslint:disable-next-line:no-empty 135 | deactivate() {} 136 | -------------------------------------------------------------------------------- /src/fail.ts: -------------------------------------------------------------------------------- 1 | import {MessageItem} from 'vscode'; 2 | 3 | export namespace fail { 4 | export interface ErrorMessageHandler extends MessageItem { 5 | title: string; 6 | cb: () => Promise; 7 | }; 8 | 9 | export interface IError { 10 | message: string; 11 | handlers?: ErrorMessageHandler[]; 12 | }; 13 | 14 | export function error(exc: IError) { 15 | throw exc; 16 | } 17 | } -------------------------------------------------------------------------------- /src/flow.ts: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | import * as vscode from 'vscode'; 4 | 5 | import * as path from 'path'; 6 | 7 | import {fail} from './fail'; 8 | import {git} from './git'; 9 | import {cmd} from './cmd'; 10 | import {fs} from './fs'; 11 | import {config} from './config'; 12 | 13 | const withProgress = vscode.window.withProgress; 14 | 15 | export namespace flow { 16 | export const gitDir = path.join(vscode.workspace.rootPath!, '.git'); 17 | export const gitflowDir = path.join(gitDir, '.gitflow'); 18 | 19 | /** 20 | * Get the release branch prefix 21 | */ 22 | export function releasePrefix() { 23 | return git.config.get('gitflow.prefix.release'); 24 | } 25 | 26 | /** 27 | * Get the tag prefix 28 | */ 29 | export function tagPrefix() { 30 | return git.config.get('gitflow.prefix.versiontag'); 31 | } 32 | 33 | /** 34 | * Get develop branch name 35 | */ 36 | export function developBranch(): Promise { 37 | return git.config.get('gitflow.branch.develop') 38 | .then(git.BranchRef.fromName); 39 | } 40 | 41 | /** 42 | * Get the master branch name 43 | */ 44 | export function masterBranch(): Promise { 45 | return git.config.get('gitflow.branch.master').then(git.BranchRef.fromName); 46 | } 47 | 48 | export async function flowEnabled(): Promise { 49 | const master = await git.config.get('gitflow.branch.master'); 50 | const develop = await git.config.get('gitflow.branch.develop'); 51 | return !!(master) && !!(develop); 52 | } 53 | 54 | export async function requireFlowEnabled() { 55 | if (!(await flowEnabled())) { 56 | // Ask the user to enable gitflow 57 | fail.error({ 58 | message: 'Gitflow is not initialized for this project', 59 | handlers: [{ 60 | title: 'Enable now', 61 | cb: flow.initialize, 62 | }] 63 | }) 64 | } 65 | } 66 | 67 | export async function 68 | requireNoSuchBranch(br: git.BranchRef, err: fail.IError) { 69 | if (await br.exists()) { 70 | fail.error(err); 71 | } 72 | } 73 | 74 | export function throwNotInitializedError(): never { 75 | throw fail.error({ 76 | message: 'Gitflow has not been initialized for this repository', 77 | handlers: [{ 78 | title: 'Initialize', 79 | cb() { 80 | return flow.initialize(); 81 | } 82 | }] 83 | }); 84 | } 85 | 86 | export async function initialize() { 87 | console.log('Init'); 88 | if (await flowEnabled()) { 89 | const do_reinit = !!(await vscode.window.showWarningMessage( 90 | 'Gitflow has already been initialized for this repository. Would you like to re-initialize?', 91 | 'Yes')); 92 | if (!do_reinit) return; 93 | } 94 | 95 | const branchNonEmpty = str => !!str ? '' : 'A branch name is required' 96 | const master_name = await vscode.window.showInputBox({ 97 | prompt: 'Enter a name for the production branch', 98 | value: config.default_production, 99 | validateInput: branchNonEmpty, 100 | }); 101 | if (!master_name) return; 102 | const develop_name = await vscode.window.showInputBox({ 103 | prompt: 'Enter a name for the development branch', 104 | value: config.default_development, 105 | validateInput: branchNonEmpty, 106 | }); 107 | if (!develop_name) return; 108 | if (master_name === develop_name) { 109 | fail.error({ 110 | message: 'Production and development branches must differ', 111 | }); 112 | } 113 | 114 | const develop = git.BranchRef.fromName(develop_name); 115 | const master = git.BranchRef.fromName(master_name); 116 | 117 | const remote_develop = git.BranchRef.fromName('origin/' + develop_name); 118 | const remote_master = git.BranchRef.fromName('origin/' + master_name); 119 | 120 | // Check if the repository needs to be initialized before we proceed 121 | if (!!(await cmd.execute(git.info.path, [ 122 | 'rev-parse', '--quiet', '--verify', 'HEAD' 123 | ])).retc) { 124 | await cmd.executeRequired( 125 | git.info.path, ['symbolic-ref', 'HEAD', `refs/heads/${master.name}`]); 126 | await cmd.executeRequired( 127 | git.info.path, 128 | ['commit', '--allow-empty', '--quiet', '-m', 'Initial commit']); 129 | } 130 | 131 | // Ensure the develop branch exists 132 | if (!(await develop.exists())) { 133 | if (await remote_develop.exists()) { 134 | // If there is a remote with the branch, set up our local copy to track 135 | // that one 136 | cmd.executeRequired( 137 | git.info.path, ['branch', develop.name, remote_develop.name]); 138 | } else { 139 | // Otherwise, create it on top of the master branch 140 | cmd.executeRequired( 141 | git.info.path, ['branch', '--no-track', develop.name, master.name]); 142 | } 143 | // Checkout develop since we just created it 144 | await git.checkout(develop); 145 | } 146 | 147 | // Create the branch prefixes and store those in git config 148 | for (const what of ['bugfix', 'feature', 'release', 'hotfix', 'support']) { 149 | const prefix = await vscode.window.showInputBox({ 150 | prompt: `Enter a prefix for "${what}" branches`, 151 | value: `${what}/`, 152 | validateInput: branchNonEmpty, 153 | }); 154 | if (!prefix) return; 155 | await git.config.set(`gitflow.prefix.${what}`, prefix); 156 | } 157 | 158 | const version_tag_prefix = await vscode.window.showInputBox({ 159 | prompt: 'Enter a prefix for version tags (optional)', 160 | }); 161 | if (version_tag_prefix === null) return; 162 | await git.config.set('gitflow.prefix.versiontag', version_tag_prefix); 163 | 164 | // Set the main branches, and gitflow is officially 'enabled' 165 | await git.config.set('gitflow.branch.master', master.name); 166 | await git.config.set('gitflow.branch.develop', develop.name); 167 | 168 | console.assert(await flowEnabled()); 169 | 170 | vscode.window.showInformationMessage( 171 | 'Gitflow has been initialized for this repository!'); 172 | } 173 | } 174 | 175 | export namespace flow.feature { 176 | /** 177 | * Get the feature/bugfix branch prefix 178 | */ 179 | export function prefix(branchType: string) { 180 | return git.config.get(`gitflow.prefix.${branchType}`); 181 | } 182 | 183 | /** 184 | * Get the current feature/bugfix branch as well as its name. 185 | */ 186 | export async function current( 187 | msg: string = 'Not working on a feature or bugfix branch', branchType: string) { 188 | const current_branch = await git.currentBranch(); 189 | const prefix = await feature.prefix(branchType); 190 | if (!prefix) { 191 | throw throwNotInitializedError(); 192 | } 193 | if (!current_branch || !current_branch.name.startsWith(prefix)) { 194 | throw fail.error({message: msg}); 195 | } 196 | const name = current_branch.name.substr(prefix.length); 197 | return {branch: current_branch, name: name}; 198 | } 199 | 200 | export async function precheck() { 201 | const local_develop = await developBranch(); 202 | const remote_develop = 203 | git.BranchRef.fromName(`origin/${local_develop.name}`); 204 | const local_ref = await local_develop.ref(); 205 | if (await remote_develop.exists()) { 206 | await git.requireEqual(local_develop, remote_develop, true); 207 | } 208 | } 209 | 210 | export async function start(feature_name: string, branchType: string) { 211 | console.assert(!!feature_name); 212 | await requireFlowEnabled(); 213 | const prefix = await feature.prefix(branchType); 214 | if (!prefix) { 215 | throw throwNotInitializedError(); 216 | } 217 | const new_branch = git.BranchRef.fromName(`${prefix}${feature_name}`); 218 | await requireNoSuchBranch( 219 | new_branch, {message: `The ${branchType} "${feature_name}" already exists`}); 220 | 221 | // Create our new branch 222 | const local_develop = await developBranch(); 223 | await cmd.executeRequired( 224 | git.info.path, ['checkout', '-b', new_branch.name, local_develop.name]); 225 | vscode.window.showInformationMessage( 226 | `New branch "${new_branch.name}" was created`); 227 | } 228 | 229 | /** 230 | * Rebase the current feature branch on develop 231 | */ 232 | export async function rebase(branchType: string) { 233 | await requireFlowEnabled(); 234 | const {branch: feature_branch} = await current( 235 | `You must checkout the ${branchType} branch you wish to rebase on develop`, branchType); 236 | 237 | const remote = feature_branch.remoteAt(git.primaryRemote()); 238 | const develop = await developBranch(); 239 | if (await remote.exists() && !(await git.isMerged(remote, develop))) { 240 | const do_rebase = !!(await vscode.window.showWarningMessage( 241 | `A remote branch for ${feature_branch.name} exists, and rebasing ` + 242 | `will rewrite history for this branch that may be visible to ` + 243 | `other users!`, 244 | 'Rebase anyway')); 245 | if (!do_rebase) return; 246 | } 247 | 248 | await git.requireClean(); 249 | const result = await git.rebase({branch: feature_branch, onto: develop}); 250 | if (result.retc) { 251 | const abort_result = 252 | await cmd.executeRequired(git.info.path, ['rebase', '--abort']); 253 | fail.error({ 254 | message: `Rebase command failed with exit code ${result.retc}. ` + 255 | `The rebase has been aborted: Please perform this rebase from ` + 256 | `the command line and resolve the appearing errors.` 257 | }); 258 | } 259 | await vscode.window.showInformationMessage( 260 | `${feature_branch.name} has been rebased onto ${develop.name}`); 261 | } 262 | 263 | export async function finish(branchType: string) { 264 | return withProgress({ 265 | location: vscode.ProgressLocation.Window, 266 | title: `Finishing ${branchType}`, 267 | }, async (pr) => { 268 | pr.report({message: 'Getting current branch...'}) 269 | const {branch: feature_branch, name: feature_name} = await current( 270 | `You must checkout the ${branchType} branch you wish to finish`, branchType); 271 | 272 | pr.report({message: 'Checking for cleanliness...'}) 273 | const is_clean = await git.isClean(); 274 | 275 | pr.report({message: 'Checking for incomplete merge...'}) 276 | const merge_base_file = path.join(gitflowDir, 'MERGE_BASE'); 277 | if (await fs.exists(merge_base_file)) { 278 | const merge_base = git.BranchRef.fromName( 279 | (await fs.readFile(merge_base_file)).toString()); 280 | if (is_clean) { 281 | // The user must have resolved the conflict themselves, so 282 | // all we need to do is delete the merge file 283 | await fs.remove(merge_base_file); 284 | if (await git.isMerged(feature_branch, merge_base)) { 285 | // The user already merged this feature branch. We'll just exit! 286 | await finishCleanup(feature_branch, branchType); 287 | return; 288 | } 289 | } else { 290 | // They have an unresolved merge conflict. Tell them what they must do 291 | fail.error({ 292 | message: 293 | `You have merge conflicts! Resolve them before trying to finish ${branchType} branch.` 294 | }); 295 | } 296 | } 297 | 298 | await git.requireClean(); 299 | 300 | pr.report({message: 'Checking remotes...'}) 301 | const all_branches = await git.BranchRef.all(); 302 | // Make sure that the local feature and the remote feature haven't diverged 303 | const remote_branch = 304 | all_branches.find(br => br.name === 'origin/' + feature_branch.name); 305 | if (remote_branch) { 306 | await git.requireEqual(feature_branch, remote_branch, true); 307 | } 308 | // Make sure the local develop and remote develop haven't diverged either 309 | const develop = await developBranch(); 310 | const remote_develop = git.BranchRef.fromName('origin/' + develop.name); 311 | if (await remote_develop.exists()) { 312 | await git.requireEqual(develop, remote_develop, true); 313 | } 314 | 315 | pr.report({message: `Merging ${feature_branch.name} into ${develop}...`}); 316 | // Switch to develop and merge in the feature branch 317 | await git.checkout(develop); 318 | const result = await cmd.execute( 319 | git.info.path, ['merge', '--no-ff', feature_branch.name]); 320 | if (result.retc) { 321 | // Merge conflict. Badness 322 | await fs.writeFile(gitflowDir, develop.name); 323 | fail.error({ 324 | message: `There were conflicts while merging into ${develop.name 325 | }. Fix the issues before trying to finish the ${branchType} branch` 326 | }); 327 | } 328 | pr.report({message: 'Cleaning up...'}); 329 | await finishCleanup(feature_branch, branchType); 330 | }); 331 | } 332 | 333 | async function finishCleanup(branch: git.BranchRef, branchType: string) { 334 | console.assert(await branch.exists()); 335 | console.assert(await git.isClean()); 336 | const origin = git.RemoteRef.fromName('origin'); 337 | const remote = git.BranchRef.fromName(origin.name + '/' + branch.name); 338 | if (config.deleteBranchOnFinish) { 339 | if (config.deleteRemoteBranches && await remote.exists()) { 340 | // Delete the branch on the remote 341 | await git.push( 342 | git.RemoteRef.fromName('origin'), 343 | git.BranchRef.fromName(`:refs/heads/${branch.name}`)); 344 | } 345 | await cmd.executeRequired(git.info.path, ['branch', '-d', branch.name]); 346 | } 347 | vscode.window.showInformationMessage( 348 | `${branchType.substring(0, 1).toUpperCase()}${branchType.substring(1)} branch ${branch.name} has been closed`); 349 | } 350 | } 351 | 352 | export namespace flow.release { 353 | export async function current() { 354 | const branches = await git.BranchRef.all(); 355 | const prefix = await releasePrefix(); 356 | if (!prefix) { 357 | throw throwNotInitializedError(); 358 | } 359 | return branches.find(br => br.name.startsWith(prefix)); 360 | } 361 | 362 | export async function precheck() { 363 | await git.requireClean(); 364 | 365 | const develop = await developBranch(); 366 | const remote_develop = develop.remoteAt(git.primaryRemote()); 367 | if (await remote_develop.exists()) { 368 | await git.requireEqual(develop, remote_develop); 369 | } 370 | } 371 | 372 | /** 373 | * Get the tag for a new release branch 374 | */ 375 | export async function guess_new_version() { 376 | const tag = git.TagRef.fromName("_start_new_release"); 377 | const tag_prefix = await tagPrefix() || ''; 378 | let version_tag = await tag.latest() || '0.0.0'; 379 | version_tag = version_tag.replace(tag_prefix, ''); 380 | if (version_tag.match(/^\d+\.\d+\.\d+$/)) { 381 | let version_numbers = version_tag.split('.'); 382 | version_numbers[1] = String(Number(version_numbers[1]) + 1); 383 | version_numbers[2] = "0"; 384 | version_tag = version_numbers.join('.'); 385 | } 386 | return version_tag; 387 | } 388 | 389 | export async function start(name: string) { 390 | await requireFlowEnabled(); 391 | const current_release = await release.current(); 392 | if (!!current_release) { 393 | fail.error({ 394 | message: `There is an existing release branch "${current_release.name 395 | }". Finish that release before starting a new one.` 396 | }); 397 | } 398 | 399 | const tag = git.TagRef.fromName(name); 400 | if (await tag.exists()) { 401 | fail.error({ 402 | message: `The tag "${name 403 | }" is an existing tag. Please chose another release name.` 404 | }); 405 | } 406 | 407 | const prefix = await releasePrefix(); 408 | const new_branch = git.BranchRef.fromName(`${prefix}${name}`); 409 | const develop = await developBranch(); 410 | await cmd.executeRequired( 411 | git.info.path, ['checkout', '-b', new_branch.name, develop.name]); 412 | await vscode.window.showInformationMessage( 413 | `New branch ${new_branch.name} has been created. ` + 414 | `Now is the time to update your version numbers and fix any ` + 415 | `last minute bugs.`); 416 | } 417 | 418 | export async function finish() { 419 | await requireFlowEnabled(); 420 | const prefix = await releasePrefix(); 421 | if (!prefix) { 422 | throw throwNotInitializedError(); 423 | } 424 | const current_release = await release.current(); 425 | if (!current_release) { 426 | throw fail.error({message: 'No active release branch to finish'}); 427 | } 428 | await finalizeWithBranch(prefix, current_release, finish); 429 | } 430 | 431 | export async function finalizeWithBranch( 432 | rel_prefix: string, branch: git.BranchRef, reenter: Function) { 433 | return withProgress({ 434 | location: vscode.ProgressLocation.Window, 435 | title: 'Finishing release branch' 436 | }, async (pr) => { 437 | await requireFlowEnabled(); 438 | pr.report({message: 'Getting current branch...'}); 439 | const current_branch = await git.currentBranch(); 440 | if (!current_branch) { 441 | throw fail.error({message: 'Unable to detect a current git branch.'}); 442 | } 443 | if (current_branch.name !== branch.name) { 444 | fail.error({ 445 | message: `You are not currently on the "${branch.name}" branch`, 446 | handlers: [{ 447 | title: `Checkout ${branch.name} and continue.`, 448 | cb: async function() { 449 | await git.checkout(branch); 450 | await reenter(); 451 | } 452 | }] 453 | }); 454 | } 455 | 456 | pr.report({message: 'Checking cleanliness...'}); 457 | await git.requireClean(); 458 | 459 | pr.report({message: 'Checking remotes...'}); 460 | const master = await masterBranch(); 461 | const remote_master = master.remoteAt(git.primaryRemote()); 462 | if (await remote_master.exists()) { 463 | await git.requireEqual(master, remote_master); 464 | } 465 | 466 | const develop = await developBranch(); 467 | const remote_develop = develop.remoteAt(git.primaryRemote()); 468 | if (await remote_develop.exists()) { 469 | await git.requireEqual(develop, remote_develop); 470 | } 471 | 472 | // Get the name of the tag we will use. Default is the branch's flow name 473 | pr.report({message: 'Getting a tag message...'}); 474 | const tag_message = await vscode.window.showInputBox({ 475 | prompt: 'Enter a tag message (optional)', 476 | }); 477 | if (tag_message === undefined) return; 478 | 479 | // Now the crux of the logic, after we've done all our sanity checking 480 | pr.report({message: 'Switching to master...'}); 481 | await git.checkout(master); 482 | 483 | // Merge the branch into the master branch 484 | if (!(await git.isMerged(branch, master))) { 485 | pr.report({message: `Merging ${branch} into ${master}...`}); 486 | await git.merge(branch); 487 | } 488 | 489 | // Create a tag for the release 490 | const tag_prefix = await tagPrefix() || ''; 491 | const release_name = tag_prefix.concat(branch.name.substr( 492 | rel_prefix.length)); 493 | pr.report({message: `Tagging ${master}: ${release_name}...`}); 494 | await cmd.executeRequired( 495 | git.info.path, ['tag', '-m', tag_message, release_name, master.name]); 496 | 497 | // Merge the release into develop 498 | pr.report({message: `Checking out ${develop}...`}); 499 | await git.checkout(develop); 500 | if (!(await git.isMerged(branch, develop))) { 501 | pr.report({message: `Merging ${branch} into ${develop}...`}); 502 | await git.merge(branch); 503 | } 504 | 505 | if (config.deleteBranchOnFinish) { 506 | // Delete the release branch 507 | pr.report({message: `Deleting ${branch.name}...`}); 508 | await cmd.executeRequired(git.info.path, ['branch', '-d', branch.name]); 509 | if (config.deleteRemoteBranches && await remote_develop.exists() && 510 | await remote_master.exists()) { 511 | const remote = git.primaryRemote(); 512 | pr.report({message: `Pushing to ${remote.name}/${develop.name}...`}); 513 | await git.push(remote, develop); 514 | pr.report({message: `Pushing to ${remote.name}/${master.name}...`}); 515 | await git.push(remote, master); 516 | const remote_branch = branch.remoteAt(remote); 517 | pr.report({message: `Pushing tag ${release_name}...`}); 518 | cmd.executeRequired(git.info.path, ['push', '--tags', remote.name]); 519 | if (await remote_branch.exists()) { 520 | // Delete the remote branch 521 | pr.report({message: `Deleting remote ${remote.name}/${branch.name}`}); 522 | await git.push(remote, git.BranchRef.fromName(':' + branch.name)); 523 | } 524 | } 525 | } 526 | 527 | vscode.window.showInformationMessage( 528 | `The release "${release_name 529 | }" has been created. You are now on the ${develop.name} branch.`); 530 | }); 531 | } 532 | } 533 | 534 | export namespace flow.hotfix { 535 | /** 536 | * Get the hotfix branch prefix 537 | */ 538 | export function prefix() { 539 | return git.config.get('gitflow.prefix.hotfix'); 540 | } 541 | 542 | /** 543 | * Get the current hotfix branch, or null if there is nonesuch 544 | */ 545 | export async function current() { 546 | const branches = await git.BranchRef.all(); 547 | const prefix = await hotfix.prefix(); 548 | if (!prefix) { 549 | throw throwNotInitializedError(); 550 | } 551 | return branches.find(br => br.name.startsWith(prefix)); 552 | } 553 | 554 | /** 555 | * Get the tag for a new hotfix branch 556 | */ 557 | export async function guess_new_version() { 558 | const tag = git.TagRef.fromName("_start_new_hotfix"); 559 | const tag_prefix = await tagPrefix() || ''; 560 | let version_tag = await tag.latest() || '0.0.0'; 561 | version_tag = version_tag.replace(tag_prefix, ''); 562 | if (version_tag.match(/^\d+\.\d+\.\d+$/)) { 563 | let version_numbers = version_tag.split('.'); 564 | version_numbers[2] = String(Number(version_numbers[2]) + 1); 565 | version_tag = version_numbers.join('.'); 566 | } 567 | return version_tag; 568 | } 569 | 570 | export async function start(name: string) { 571 | await requireFlowEnabled(); 572 | const current_hotfix = await current(); 573 | if (!!current_hotfix) { 574 | fail.error({ 575 | message: `There is an existing hotfix branch "${current_hotfix.name 576 | }". Finish that one first.` 577 | }); 578 | } 579 | 580 | await git.requireClean(); 581 | 582 | const master = await masterBranch(); 583 | const remote_master = master.remoteAt(git.primaryRemote()); 584 | if (await remote_master.exists()) { 585 | await git.requireEqual(master, remote_master); 586 | } 587 | 588 | const tag = git.TagRef.fromName(name); 589 | if (await tag.exists()) { 590 | fail.error({ 591 | message: `The tag "${tag.name 592 | }" is an existing tag. Choose another hotfix name.` 593 | }); 594 | } 595 | 596 | const prefix = await hotfix.prefix(); 597 | const new_branch = git.BranchRef.fromName(`${prefix}${name}`); 598 | if (await new_branch.exists()) { 599 | fail.error( 600 | {message: `"${new_branch.name}" is the name of an existing branch`}); 601 | } 602 | await cmd.executeRequired( 603 | git.info.path, ['checkout', '-b', new_branch.name, master.name]); 604 | } 605 | 606 | export async function finish() { 607 | await requireFlowEnabled(); 608 | const prefix = await hotfix.prefix(); 609 | if (!prefix) { 610 | throw throwNotInitializedError(); 611 | } 612 | const current_hotfix = await hotfix.current(); 613 | if (!current_hotfix) { 614 | throw fail.error({message: 'No active hotfix branch to finish'}); 615 | } 616 | await release.finalizeWithBranch(prefix, current_hotfix, finish); 617 | } 618 | } 619 | -------------------------------------------------------------------------------- /src/fs.ts: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | import * as nodefs from 'fs'; 4 | 5 | 6 | export namespace fs { 7 | export function exists(path: string): Promise { 8 | return new Promise((resolve, _) => { 9 | nodefs.exists(path, resolve); 10 | }); 11 | } 12 | 13 | export function readFile(path: string): Promise { 14 | return new Promise((resolve, reject) => { 15 | nodefs.readFile(path, (err, data) => { 16 | if (err) 17 | reject(err); 18 | else 19 | resolve(data); 20 | }); 21 | }) 22 | } 23 | 24 | export function writeFile(path: string, buf: any): Promise { 25 | return new Promise((resolve, reject) => { 26 | nodefs.writeFile(path, buf, (err) => { 27 | if (err) 28 | reject(err); 29 | else 30 | resolve(); 31 | }); 32 | }); 33 | } 34 | 35 | export function remove(path: string) { 36 | return new Promise((resolve, reject) => { 37 | nodefs.unlink(path, (err) => { 38 | if (err) 39 | reject(err); 40 | else 41 | resolve(); 42 | }); 43 | }); 44 | } 45 | } -------------------------------------------------------------------------------- /src/git.ts: -------------------------------------------------------------------------------- 1 | import * as cp from 'child_process'; 2 | import * as fs from 'fs'; 3 | import * as path from 'path'; 4 | 5 | import {cmd} from './cmd' 6 | import {fail} from './fail'; 7 | 8 | // Taken from 9 | // https://github.com/Microsoft/vscode/blob/cda3584a99d2832ab9d478c6b65ea45c96fe00c9/extensions/git/src/util.ts 10 | export function denodeify(fn: Function): (...args) => Promise { 11 | return (...args) => new Promise( 12 | (c, e) => fn(...args, (err, r) => err ? e(err) : c(r))); 13 | } 14 | 15 | const readdir = denodeify(fs.readdir); 16 | 17 | // Taken from 18 | // https://github.com/Microsoft/vscode/blob/cda3584a99d2832ab9d478c6b65ea45c96fe00c9/extensions/git/src/git.ts 19 | export interface IGit { 20 | path: string; 21 | version: string; 22 | } 23 | 24 | function parseVersion(raw: string): string { 25 | return raw.replace(/^git version /, ''); 26 | } 27 | 28 | function findSpecificGit(path: string): Promise { 29 | return new Promise((c, e) => { 30 | const buffers: Buffer[] = []; 31 | const child = cp.spawn(path, ['--version']); 32 | child.stdout.on('data', (b: Buffer) => buffers.push(b)); 33 | child.on('error', e); 34 | child.on( 35 | 'exit', 36 | code => code ? e(new Error('Not found')) : c({ 37 | path, 38 | version: parseVersion(Buffer.concat(buffers).toString('utf8').trim()) 39 | })); 40 | }); 41 | } 42 | 43 | function findGitDarwin(): Promise { 44 | return new Promise((c, e) => { 45 | cp.exec('which git', (err, gitPathBuffer) => { 46 | if (err) { 47 | return e('git not found'); 48 | } 49 | 50 | const path = gitPathBuffer.toString().replace(/^\s+|\s+$/g, ''); 51 | 52 | function getVersion(path: string) { 53 | // make sure git executes 54 | cp.exec('git --version', (err: Error, stdout: string) => { 55 | if (err) { 56 | return e('git not found'); 57 | } 58 | 59 | return c( 60 | {path, version: parseVersion(stdout.trim())}); 61 | }); 62 | } 63 | 64 | if (path !== '/usr/bin/git') { 65 | return getVersion(path); 66 | } 67 | 68 | // must check if XCode is installed 69 | cp.exec('xcode-select -p', (err: any) => { 70 | if (err && err.code === 2) { 71 | // git is not installed, and launching /usr/bin/git 72 | // will prompt the user to install it 73 | 74 | return e('git not found'); 75 | } 76 | 77 | getVersion(path); 78 | }); 79 | }); 80 | }); 81 | } 82 | 83 | function findSystemGitWin32(base: string): Promise { 84 | if (!base) { 85 | return Promise.reject('Not found'); 86 | } 87 | 88 | return findSpecificGit(path.join(base, 'Git', 'cmd', 'git.exe')); 89 | } 90 | 91 | function findGitHubGitWin32(): Promise { 92 | const github = path.join(process.env['LOCALAPPDATA'], 'GitHub'); 93 | 94 | return readdir(github).then(children => { 95 | const git = children.filter(child => /^PortableGit/.test(child))[0]; 96 | 97 | if (!git) { 98 | return Promise.reject('Not found'); 99 | } 100 | 101 | return findSpecificGit(path.join(github, git, 'cmd', 'git.exe')); 102 | }); 103 | } 104 | 105 | function id(val: T): T { 106 | return val; 107 | } 108 | 109 | function findGitWin32(): Promise { 110 | return findSystemGitWin32(process.env['ProgramW6432']) 111 | .then(id, () => findSystemGitWin32(process.env['ProgramFiles(x86)'])) 112 | .then(id, () => findSystemGitWin32(process.env['ProgramFiles'])) 113 | .then(id, () => findSpecificGit('git')) 114 | .then(id, () => findGitHubGitWin32()); 115 | } 116 | 117 | export function findGit(hint: string|undefined): Promise { 118 | var first = hint ? findSpecificGit(hint) : Promise.reject(null); 119 | 120 | return first.then(id, () => { 121 | switch (process.platform) { 122 | case 'darwin': 123 | return findGitDarwin(); 124 | case 'win32': 125 | return findGitWin32(); 126 | default: 127 | return findSpecificGit('git'); 128 | } 129 | }); 130 | } 131 | 132 | export namespace git { 133 | export let info: IGit; 134 | /** 135 | * Represents a git remote 136 | */ 137 | export class RemoteRef { 138 | constructor(public name: string) {} 139 | 140 | /// Create a remote reference from a remote's name 141 | public static fromName(name: string) { 142 | return new RemoteRef(name); 143 | } 144 | } 145 | 146 | export namespace config { 147 | /// Get a git config value 148 | export async function get(setting: string): Promise { 149 | const result = await cmd.execute(info.path, ['config', '--get', setting]); 150 | if (result.retc) { 151 | return null; 152 | } 153 | return result.stdout.trim(); 154 | } 155 | 156 | /// Set a git config value 157 | export async function set(setting: string, value: any): Promise { 158 | const result = await cmd.execute(info.path, ['config', setting, value]); 159 | return result.retc; 160 | } 161 | } 162 | 163 | export class TagRef { 164 | constructor(public name: string) {} 165 | 166 | /** 167 | * Get a tag reference by name 168 | */ 169 | public static fromName(name: string) { 170 | return new TagRef(name); 171 | } 172 | 173 | /** 174 | * Parse a list of tags returned by git 175 | */ 176 | public static parseListing(output: string): TagRef[] { 177 | return output.replace('\r\n', '\n') 178 | .trim() 179 | .split('\n') 180 | .filter(line => !!line.length) 181 | .map(line => line.trim()) 182 | .reduce( 183 | (acc, name) => { 184 | if (!(name in acc)) acc.push(name); 185 | return acc; 186 | }, 187 | [] as string[]) 188 | .map(name => new TagRef(name)); 189 | } 190 | 191 | /** 192 | * Get a list of all tags 193 | */ 194 | public static async all() { 195 | const result = await cmd.executeRequired(info.path, ['tag', '-l']); 196 | return TagRef.parseListing(result.stdout); 197 | } 198 | 199 | /** 200 | * Get latest tag 201 | */ 202 | public async latest(): Promise { 203 | let last_tag = ''; 204 | const a_tag_exists = await cmd.executeRequired( 205 | info.path, ['tag', '-l']); 206 | if (a_tag_exists.stdout.trim()) { 207 | const latest_tagged_commit = await cmd.executeRequired( 208 | info.path, ['rev-list', '--tags', '--max-count=1']); 209 | const result = await cmd.executeRequired( 210 | info.path, 211 | ['describe', '--tags', latest_tagged_commit.stdout.trim()]); 212 | last_tag = result.stdout.trim(); 213 | } 214 | return last_tag; 215 | } 216 | 217 | /** 218 | * Check if the tag exists 219 | */ 220 | public async exists(): Promise { 221 | const self: TagRef = this; 222 | const all = await TagRef.all(); 223 | return all.some(tag => tag.name === self.name); 224 | } 225 | } 226 | 227 | export class BranchRef { 228 | constructor(public name: string) {} 229 | 230 | /** 231 | * Create a branch reference from a string name 232 | */ 233 | public static fromName(name: string) { 234 | return new BranchRef(name); 235 | } 236 | 237 | /** 238 | * Parse a list of branches returned by git stdout 239 | */ 240 | public static parseListing(output: string): BranchRef[] { 241 | return output.replace('\r\n', '\n') 242 | .trim() 243 | .split('\n') 244 | .filter(line => !!line.length) 245 | .filter(line => line !== 'no branch') 246 | .map(line => line.trim()) 247 | .map(line => line.replace(/^\* /, '')) 248 | .reduce( 249 | (acc, name) => { 250 | if (!(name in acc)) acc.push(name); 251 | return acc; 252 | }, 253 | [] as string[]) 254 | .map(name => new BranchRef(name)); 255 | } 256 | 257 | /** 258 | * Get a list of branches available in the current directory 259 | */ 260 | public static async all() { 261 | const local_result = 262 | await cmd.execute(info.path, ['branch', '--no-color']); 263 | const local_stdout = local_result.stdout; 264 | const remote_result = 265 | await cmd.execute(info.path, ['branch', '-r', '--no-color']); 266 | const remote_stdout = remote_result.stdout; 267 | const filter = 268 | (output) => { 269 | return output; 270 | } 271 | 272 | return BranchRef.parseListing( 273 | local_stdout + remote_stdout) 274 | } 275 | 276 | /** 277 | * Test if a given branch exists 278 | */ 279 | public async exists(): Promise { 280 | const self: BranchRef = this; 281 | const all = await BranchRef.all(); 282 | return !!(all.find((branch: BranchRef) => branch.name === self.name)); 283 | } 284 | 285 | /** 286 | * Get the git hash that the branch points to 287 | */ 288 | public async ref(): Promise { 289 | const self: BranchRef = this; 290 | const result = await cmd.execute(info.path, ['rev-parse', self.name]); 291 | return result.stdout.trim(); 292 | } 293 | 294 | /** 295 | * Get the name of the branch at a remote 296 | */ 297 | public remoteAt(remote: RemoteRef): BranchRef { 298 | return BranchRef.fromName(`${remote.name}/${this.name}`); 299 | } 300 | }; 301 | 302 | /** 303 | * Get a reference to the currently checked out branch 304 | */ 305 | export async function currentBranch(): Promise { 306 | const result = await cmd.executeRequired( 307 | info.path, ['rev-parse', '--abbrev-ref', 'HEAD']); 308 | const name = result.stdout.trim(); 309 | if (name === 'HEAD') { 310 | // We aren't attached to a branch at the moment 311 | return null; 312 | } 313 | return BranchRef.fromName(name); 314 | } 315 | 316 | /** 317 | * Pull updates from the given ``remote`` for ``branch`` 318 | */ 319 | export async function pull(remote: RemoteRef, branch: BranchRef): 320 | Promise { 321 | const result = 322 | await cmd.execute(info.path, ['pull', remote.name, branch.name]); 323 | if (result.retc !== 0) { 324 | fail.error({message: 'Failed to pull from remote. See git output'}); 325 | } 326 | return result.retc; 327 | } 328 | 329 | /** 330 | * Push updates to ``remote`` at ``branch`` 331 | */ 332 | export async function push(remote: RemoteRef, branch: BranchRef): 333 | Promise { 334 | const result = 335 | await cmd.execute(info.path, ['push', remote.name, branch.name]); 336 | if (result.retc !== 0) { 337 | fail.error({ 338 | message: 'Failed to push to remote. See git output', 339 | }); 340 | } 341 | return result.retc; 342 | } 343 | 344 | /** 345 | * Check if we have any unsaved changes 346 | */ 347 | export async function isClean(): Promise { 348 | const diff_res = await cmd.execute(info.path, [ 349 | 'diff', '--no-ext-diff', '--ignore-submodules', '--quiet', '--exit-code' 350 | ]); 351 | if (!!diff_res.retc) { 352 | return false; 353 | } 354 | const diff_index_res = await cmd.execute(info.path, [ 355 | 'diff-index', '--cached', '--quiet', '--ignore-submodules', 'HEAD', '--' 356 | ]); 357 | if (!!diff_index_res.retc) { 358 | return false; 359 | } 360 | return true; 361 | } 362 | 363 | /** 364 | * Detect if the branch "subject" was merged into "base" 365 | */ 366 | export async function isMerged(subject: BranchRef, base: BranchRef) { 367 | const result = await cmd.executeRequired( 368 | info.path, ['branch', '--no-color', '--contains', subject.name]); 369 | const branches = BranchRef.parseListing(result.stdout); 370 | return branches.some((br) => br.name === base.name); 371 | } 372 | 373 | /** 374 | * Checkout the given branch 375 | */ 376 | export function checkout(branch: BranchRef) { 377 | return checkoutRef(branch.name); 378 | } 379 | 380 | /** 381 | * Checkout the given git hash 382 | */ 383 | export function checkoutRef(ref: string) { 384 | return cmd.executeRequired(info.path, ['checkout', ref]); 385 | } 386 | 387 | /** 388 | * Merge one branch into the currently checked out branch 389 | */ 390 | export function merge(other: BranchRef) { 391 | return cmd.executeRequired(info.path, ['merge', '--no-ff', other.name]); 392 | } 393 | 394 | interface IRebaseParameters { 395 | branch: BranchRef; 396 | onto: BranchRef; 397 | } 398 | ; 399 | 400 | /** 401 | * Rebase one branch onto another 402 | */ 403 | export function rebase(args: IRebaseParameters) { 404 | return cmd.executeRequired( 405 | info.path, ['rebase', args.onto.name, args.branch.name]); 406 | } 407 | 408 | /** 409 | * Require that two branches point to the same commit. 410 | * 411 | * If given ``true`` for ``offer_pull``, will offer the use the ability 412 | * to quickly pull from 'origin' onto the ``a`` branch. 413 | */ 414 | export async function 415 | requireEqual(a: BranchRef, b: BranchRef, offer_pull: boolean = false) { 416 | const aref = await a.ref(); 417 | const bref = await b.ref(); 418 | 419 | if (aref !== bref) { 420 | fail.error({ 421 | message: `Branch "${a.name}" has diverged from ${b.name}`, 422 | handlers: !offer_pull ? [] : 423 | [ 424 | { 425 | title: 'Pull now', 426 | cb: async function() { 427 | git.pull(primaryRemote(), a); 428 | }, 429 | }, 430 | ], 431 | }); 432 | } 433 | } 434 | 435 | export async function requireClean() { 436 | if (!(await isClean())) { 437 | fail.error({ 438 | message: 439 | 'Unsaved changes detected. Please commit or stash your changes and try again' 440 | }); 441 | } 442 | } 443 | 444 | export function primaryRemote() { 445 | return RemoteRef.fromName('origin'); 446 | } 447 | } 448 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "target": "es6", 5 | "outDir": "out", 6 | "lib": [ 7 | "es6" 8 | ], 9 | "sourceMap": true, 10 | "rootDir": ".", 11 | "noImplicitReturns": true, 12 | "strictNullChecks": true 13 | }, 14 | "exclude": [ 15 | "node_modules", 16 | ".vscode-test" 17 | ] 18 | } -------------------------------------------------------------------------------- /tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "defaultSeverity": "error", 3 | "extends": [ 4 | "tslint:recommended" 5 | ], 6 | "jsRules": {}, 7 | "rules": { 8 | "quotemark": false, 9 | "no-console": false, 10 | "no-namespace": false, 11 | "variable-name": false, 12 | 13 | }, 14 | "rulesDirectory": [] 15 | } --------------------------------------------------------------------------------