├── .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 | 
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 | 
24 |
25 | 4. Follow the command prompts and accept the defaults...
26 | 
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 |
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 | }
--------------------------------------------------------------------------------