├── .github └── workflows │ └── ci.yml ├── .gitignore ├── LICENCE ├── LICENCES ├── heterogeneous-extrablatt.LICENCE └── record-extra.LICENCE ├── README.md ├── bower.json ├── package-lock.json ├── package.json ├── packages.dhall ├── spago.dhall ├── src └── Record │ ├── Studio.purs │ └── Studio │ ├── Keys.purs │ ├── Map.purs │ ├── MapKind.purs │ ├── MapUniform.purs │ ├── Merge.purs │ ├── SameKeys.purs │ ├── Sequence.purs │ ├── SequenceUniform.purs │ ├── Shrink.js │ ├── Shrink.purs │ ├── SingletonRecord.js │ └── SingletonRecord.purs ├── test.dhall └── test ├── KeysSpec.purs ├── Main.purs ├── MapRecordKindSpec.purs ├── MapRecordSpec.purs ├── MapUniformRecordSpec.purs ├── MergeFlippedSpec.purs ├── SameKeysSpec.purs ├── SequenceSpec.purs ├── SequenceUniformRecordSpec.purs ├── ShrinkSpec.purs └── SingletonRecordSpec.purs /.github/workflows/ci.yml: -------------------------------------------------------------------------------- 1 | name: CI 2 | 3 | on: 4 | push: 5 | branches: [main] 6 | pull_request: 7 | branches: [main] 8 | 9 | jobs: 10 | build: 11 | runs-on: ubuntu-latest 12 | steps: 13 | - uses: actions/checkout@v2 14 | 15 | - uses: purescript-contrib/setup-purescript@main 16 | 17 | - name: Cache PureScript dependencies 18 | uses: actions/cache@v2 19 | # This cache uses the .dhall files to know when it should reinstall 20 | # and rebuild packages. It caches both the installed packages from 21 | # the `.spago` directory and compilation artifacts from the `output` 22 | # directory. When restored the compiler will rebuild any files that 23 | # have changed. If you do not want to cache compiled output, remove 24 | # the `output` path. 25 | with: 26 | key: ${{ runner.os }}-spago-${{ hashFiles('**/*.dhall') }} 27 | path: | 28 | .spago 29 | output 30 | 31 | - run: spago build 32 | 33 | - run: spago -x test.dhall test 34 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | /bower_components/ 2 | /node_modules/ 3 | /.pulp-cache/ 4 | /output/ 5 | /generated-docs/ 6 | /.psc-package/ 7 | /.psc* 8 | /.purs* 9 | /.psa* 10 | /.spago 11 | -------------------------------------------------------------------------------- /LICENCE: -------------------------------------------------------------------------------- 1 | MIT No Attribution 2 | 3 | Copyright 2022 Jan Schulte 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy of this 6 | software and associated documentation files (the "Software"), to deal in the Software 7 | without restriction, including without limitation the rights to use, copy, modify, 8 | merge, publish, distribute, sublicense, and/or sell copies of the Software, and to 9 | permit persons to whom the Software is furnished to do so. 10 | 11 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, 12 | INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A 13 | PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT 14 | HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION 15 | OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 16 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 17 | -------------------------------------------------------------------------------- /LICENCES/heterogeneous-extrablatt.LICENCE: -------------------------------------------------------------------------------- 1 | MIT No Attribution 2 | 3 | Copyright 2021 Jan Schulte 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy of this 6 | software and associated documentation files (the "Software"), to deal in the Software 7 | without restriction, including without limitation the rights to use, copy, modify, 8 | merge, publish, distribute, sublicense, and/or sell copies of the Software, and to 9 | permit persons to whom the Software is furnished to do so. 10 | 11 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, 12 | INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A 13 | PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT 14 | HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION 15 | OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 16 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 17 | -------------------------------------------------------------------------------- /LICENCES/record-extra.LICENCE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2017 Justin Woo, Adam Saleh 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # purescript-record-studio 📀📀📀 2 | 3 | You finally scored a record deal. 4 | 5 | ## Usage guide 6 | 7 | ### Assert two records have the same keys with `SameKeys` 8 | 9 | ```purescript 10 | -- An example of a function that requires `{|r1}` and `{|r2}` to have the same keys 11 | sameKeys :: forall r1 r2. SameKeys r1 r2 => {|r1} -> {|r2} -> Unit 12 | sameKeys _ _ = unit 13 | let _ = sameKeys { b: "hi", a: 4, c: 4 } { b: "hu", a: "ha" } 14 | -- Won't compile: The key "c" is missing from the second record 15 | ``` 16 | 17 | ### Merge records with `//` 18 | Easily merge two records: 19 | 20 | ```purescript 21 | { a: 5, b: "B" } // { b: false, c: "c" } 22 | -- { a: 5, b: false, c: "c" } 23 | ``` 24 | 25 | This is similar to the `...` operator in ES6: 26 | 27 | PureScript: 28 | ```purescript 29 | import Record.Studio ((//)) 30 | rec1 = { a: 1 } 31 | rec2 = { b: 4, c: 8 } 32 | result = rec1 // rec2 33 | ``` 34 | 35 | JS: 36 | ```js 37 | const rec1 = { a: 1 } 38 | const rec2 = { b: 4, c: 8 } 39 | const result = { ...rec1, ...rec2 } 40 | ``` 41 | 42 | ### Shrink records with `shrink` 43 | Easily adjust a record with too many keys: 44 | ```purescript 45 | import Record.Studio (shrink) 46 | -- We want to call this 47 | -- fn :: { a :: Int } -> Int 48 | 49 | -- We have this 50 | myRec :: { a :: Int, b :: String } 51 | myRec = { a: 4, b: "Hello!" } 52 | 53 | -- Use shrink! 54 | result = fn (shrink myRec) 55 | ``` 56 | 57 | ### Get a record's keys at runtime with `keys` 58 | ```purescript 59 | import Record.Studio (keys) 60 | 61 | theKeys :: Array String 62 | theKeys = keys { a: 3, b: "ooh" } 63 | -- ["a", "b"] 64 | ``` 65 | 66 | ### `sequenceRecord` 67 | Recursively sequence a type constructor out of a record. 68 | 69 | ```purescript 70 | let 71 | input :: SequenceInput 72 | input = 73 | { a: Just 10 74 | , b: "hello" 75 | , c: 76 | { d: Just "world" 77 | , e: true 78 | , f: { g: Just true } 79 | } 80 | , h: 10 81 | } 82 | 83 | expected :: Maybe SequenceOutput 84 | expected = Just 85 | { a: 10 86 | , b: "hello" 87 | , c: 88 | { d: "world" 89 | , e: true 90 | , f: { g: true } 91 | } 92 | , h: 10 93 | } 94 | (sequenceRecord input) `shouldEqual` expected 95 | ``` 96 | 97 | ### `mapUniformRecord` 98 | 99 | Recursively map a function over a record where all entries have the same value. 100 | This is often better at type inference than `mapRecord` 101 | ```purescript 102 | (mapUniformRecord (_ + 1) { a: 1, b: 2 }) `shouldEqual` { a: 2, b: 3} 103 | ``` 104 | 105 | ### `mapRecord` 106 | 107 | Recursively map a function over a record. 108 | ```purescript 109 | let 110 | input :: MapInput 111 | input = 112 | { a: 10 113 | , b: "hello" 114 | , c: 115 | { d: Just "world" 116 | , e: 20 117 | , f: { g: true, h: 30 } 118 | } 119 | , i: 40 120 | } 121 | 122 | f :: Int -> String 123 | f i = show (i + 1) 124 | 125 | expected :: MapOutput 126 | expected = 127 | { a: "11" 128 | , b: "hello" 129 | , c: 130 | { d: Just "world" 131 | , e: "21" 132 | , f: { g: true, h: "31" } 133 | } 134 | , i: "41" 135 | } 136 | (mapRecord f input) `shouldEqual` expected 137 | ``` 138 | 139 | ### `mapRecordKind` 140 | 141 | Recursively map a natural transformation over a record. 142 | 143 | ```purescript 144 | let 145 | input :: MapKInput 146 | input = 147 | { a: Right 10 148 | , b: "hello" 149 | , c: 150 | { d: Left "world" 151 | , e: 20 152 | , f: { g: Right true, h: Left "broken" } 153 | } 154 | , i: Just 40 155 | } 156 | 157 | nt :: Either String ~> Maybe 158 | nt = hush 159 | 160 | expected :: MapKOutput 161 | expected = 162 | { a: Just 10 163 | , b: "hello" 164 | , c: 165 | { d: Nothing 166 | , e: 20 167 | , f: { g: Just true, h: Nothing } 168 | } 169 | , i: Just 40 170 | } 171 | (mapRecordKind nt input) `shouldEqual` expected 172 | ``` 173 | 174 | ### `key` 175 | 176 | Get the only field name of a Record with one field as a `Proxy` 177 | 178 | ```purescript 179 | SingletonRecord.key { foo: unit } `shouldEqual` (Proxy :: Proxy "foo") 180 | ``` 181 | 182 | ## Licence 183 | This is a fork of [heterogeneous-extrablatt](https://github.com/sigma-andex/purescript-heterogeneous-extrablatt), which is licenced under MIT. See the [original licence](./LICENCES/heterogeneous-extrablatt.LICENCE). This work is similarly licenced under [MIT](./LICENCE). 184 | It includes part of [`purescript-record-extra`](https://github.com/justinwoo/purescript-record-extra) as an inline dependency, which is licenced under MIT, see [original licence](./LICENCES/record-extra.LICENCE). 185 | -------------------------------------------------------------------------------- /bower.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "purescript-record-studio", 3 | "license": [ 4 | "MIT-0" 5 | ], 6 | "repository": { 7 | "type": "git", 8 | "url": "https://github.com/rowtype-yoga/purescript-record-studio.git" 9 | }, 10 | "ignore": [ 11 | "**/.*", 12 | "node_modules", 13 | "bower_components", 14 | "output" 15 | ], 16 | "dependencies": { 17 | "purescript-heterogeneous": "^v0.6.0", 18 | "purescript-lists": "^v7.0.0", 19 | "purescript-prelude": "^v6.0.0", 20 | "purescript-record": "^v4.0.0", 21 | "purescript-typelevel-prelude": "^v7.0.0" 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "purescript-heterogeneous-extra", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "version": "1.0.0", 9 | "license": "ISC", 10 | "devDependencies": { 11 | "purescript": "^0.14.0", 12 | "purty": "^7.0.0", 13 | "spago": "^0.19.1" 14 | } 15 | }, 16 | "node_modules/ajv": { 17 | "version": "6.12.6", 18 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 19 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 20 | "dev": true, 21 | "dependencies": { 22 | "fast-deep-equal": "^3.1.1", 23 | "fast-json-stable-stringify": "^2.0.0", 24 | "json-schema-traverse": "^0.4.1", 25 | "uri-js": "^4.2.2" 26 | }, 27 | "funding": { 28 | "type": "github", 29 | "url": "https://github.com/sponsors/epoberezkin" 30 | } 31 | }, 32 | "node_modules/ansi-escapes": { 33 | "version": "3.2.0", 34 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", 35 | "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==", 36 | "dev": true, 37 | "engines": { 38 | "node": ">=4" 39 | } 40 | }, 41 | "node_modules/ansi-regex": { 42 | "version": "4.1.0", 43 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 44 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 45 | "dev": true, 46 | "engines": { 47 | "node": ">=6" 48 | } 49 | }, 50 | "node_modules/ansi-styles": { 51 | "version": "3.2.1", 52 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 53 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 54 | "dev": true, 55 | "dependencies": { 56 | "color-convert": "^1.9.0" 57 | }, 58 | "engines": { 59 | "node": ">=4" 60 | } 61 | }, 62 | "node_modules/aproba": { 63 | "version": "1.2.0", 64 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 65 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==", 66 | "dev": true 67 | }, 68 | "node_modules/arch": { 69 | "version": "2.2.0", 70 | "resolved": "https://registry.npmjs.org/arch/-/arch-2.2.0.tgz", 71 | "integrity": "sha512-Of/R0wqp83cgHozfIYLbBMnej79U/SVGOOyuB3VVFv1NRM/PSFMK12x9KVtiYzJqmnU5WR2qp0Z5rHb7sWGnFQ==", 72 | "dev": true, 73 | "funding": [ 74 | { 75 | "type": "github", 76 | "url": "https://github.com/sponsors/feross" 77 | }, 78 | { 79 | "type": "patreon", 80 | "url": "https://www.patreon.com/feross" 81 | }, 82 | { 83 | "type": "consulting", 84 | "url": "https://feross.org/support" 85 | } 86 | ] 87 | }, 88 | "node_modules/asn1": { 89 | "version": "0.2.4", 90 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 91 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 92 | "dev": true, 93 | "dependencies": { 94 | "safer-buffer": "~2.1.0" 95 | } 96 | }, 97 | "node_modules/assert-plus": { 98 | "version": "1.0.0", 99 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 100 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 101 | "dev": true, 102 | "engines": { 103 | "node": ">=0.8" 104 | } 105 | }, 106 | "node_modules/asynckit": { 107 | "version": "0.4.0", 108 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 109 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 110 | "dev": true 111 | }, 112 | "node_modules/aws-sign2": { 113 | "version": "0.7.0", 114 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 115 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 116 | "dev": true, 117 | "engines": { 118 | "node": "*" 119 | } 120 | }, 121 | "node_modules/aws4": { 122 | "version": "1.11.0", 123 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.11.0.tgz", 124 | "integrity": "sha512-xh1Rl34h6Fi1DC2WWKfxUTVqRsNnr6LsKz2+hfwDxQJWmrx8+c7ylaqBMcHfl1U1r2dsifOvKX3LQuLNZ+XSvA==", 125 | "dev": true 126 | }, 127 | "node_modules/balanced-match": { 128 | "version": "1.0.0", 129 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 130 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 131 | "dev": true 132 | }, 133 | "node_modules/bcrypt-pbkdf": { 134 | "version": "1.0.2", 135 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 136 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 137 | "dev": true, 138 | "dependencies": { 139 | "tweetnacl": "^0.14.3" 140 | } 141 | }, 142 | "node_modules/bluebird": { 143 | "version": "3.7.2", 144 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", 145 | "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==", 146 | "dev": true 147 | }, 148 | "node_modules/brace-expansion": { 149 | "version": "1.1.11", 150 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 151 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 152 | "dev": true, 153 | "dependencies": { 154 | "balanced-match": "^1.0.0", 155 | "concat-map": "0.0.1" 156 | } 157 | }, 158 | "node_modules/buffer-from": { 159 | "version": "1.1.1", 160 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 161 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 162 | "dev": true 163 | }, 164 | "node_modules/byline": { 165 | "version": "5.0.0", 166 | "resolved": "https://registry.npmjs.org/byline/-/byline-5.0.0.tgz", 167 | "integrity": "sha1-dBxSFkaOrcRXsDQQEYrXfejB3bE=", 168 | "dev": true, 169 | "engines": { 170 | "node": ">=0.10.0" 171 | } 172 | }, 173 | "node_modules/cacache": { 174 | "version": "11.3.3", 175 | "resolved": "https://registry.npmjs.org/cacache/-/cacache-11.3.3.tgz", 176 | "integrity": "sha512-p8WcneCytvzPxhDvYp31PD039vi77I12W+/KfR9S8AZbaiARFBCpsPJS+9uhWfeBfeAtW7o/4vt3MUqLkbY6nA==", 177 | "dev": true, 178 | "dependencies": { 179 | "bluebird": "^3.5.5", 180 | "chownr": "^1.1.1", 181 | "figgy-pudding": "^3.5.1", 182 | "glob": "^7.1.4", 183 | "graceful-fs": "^4.1.15", 184 | "lru-cache": "^5.1.1", 185 | "mississippi": "^3.0.0", 186 | "mkdirp": "^0.5.1", 187 | "move-concurrently": "^1.0.1", 188 | "promise-inflight": "^1.0.1", 189 | "rimraf": "^2.6.3", 190 | "ssri": "^6.0.1", 191 | "unique-filename": "^1.1.1", 192 | "y18n": "^4.0.0" 193 | } 194 | }, 195 | "node_modules/caseless": { 196 | "version": "0.12.0", 197 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 198 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", 199 | "dev": true 200 | }, 201 | "node_modules/chalk": { 202 | "version": "2.4.2", 203 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 204 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 205 | "dev": true, 206 | "dependencies": { 207 | "ansi-styles": "^3.2.1", 208 | "escape-string-regexp": "^1.0.5", 209 | "supports-color": "^5.3.0" 210 | }, 211 | "engines": { 212 | "node": ">=4" 213 | } 214 | }, 215 | "node_modules/chownr": { 216 | "version": "1.1.4", 217 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", 218 | "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", 219 | "dev": true 220 | }, 221 | "node_modules/cli-cursor": { 222 | "version": "2.1.0", 223 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 224 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 225 | "dev": true, 226 | "dependencies": { 227 | "restore-cursor": "^2.0.0" 228 | }, 229 | "engines": { 230 | "node": ">=4" 231 | } 232 | }, 233 | "node_modules/color-convert": { 234 | "version": "1.9.3", 235 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 236 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 237 | "dev": true, 238 | "dependencies": { 239 | "color-name": "1.1.3" 240 | } 241 | }, 242 | "node_modules/color-name": { 243 | "version": "1.1.3", 244 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 245 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 246 | "dev": true 247 | }, 248 | "node_modules/combined-stream": { 249 | "version": "1.0.8", 250 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 251 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 252 | "dev": true, 253 | "dependencies": { 254 | "delayed-stream": "~1.0.0" 255 | }, 256 | "engines": { 257 | "node": ">= 0.8" 258 | } 259 | }, 260 | "node_modules/concat-map": { 261 | "version": "0.0.1", 262 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 263 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 264 | "dev": true 265 | }, 266 | "node_modules/concat-stream": { 267 | "version": "1.6.2", 268 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", 269 | "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", 270 | "dev": true, 271 | "engines": [ 272 | "node >= 0.8" 273 | ], 274 | "dependencies": { 275 | "buffer-from": "^1.0.0", 276 | "inherits": "^2.0.3", 277 | "readable-stream": "^2.2.2", 278 | "typedarray": "^0.0.6" 279 | } 280 | }, 281 | "node_modules/copy-concurrently": { 282 | "version": "1.0.5", 283 | "resolved": "https://registry.npmjs.org/copy-concurrently/-/copy-concurrently-1.0.5.tgz", 284 | "integrity": "sha512-f2domd9fsVDFtaFcbaRZuYXwtdmnzqbADSwhSWYxYB/Q8zsdUUFMXVRwXGDMWmbEzAn1kdRrtI1T/KTFOL4X2A==", 285 | "dev": true, 286 | "dependencies": { 287 | "aproba": "^1.1.1", 288 | "fs-write-stream-atomic": "^1.0.8", 289 | "iferr": "^0.1.5", 290 | "mkdirp": "^0.5.1", 291 | "rimraf": "^2.5.4", 292 | "run-queue": "^1.0.0" 293 | } 294 | }, 295 | "node_modules/core-util-is": { 296 | "version": "1.0.2", 297 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 298 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 299 | "dev": true 300 | }, 301 | "node_modules/cross-spawn": { 302 | "version": "7.0.3", 303 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 304 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 305 | "dev": true, 306 | "dependencies": { 307 | "path-key": "^3.1.0", 308 | "shebang-command": "^2.0.0", 309 | "which": "^2.0.1" 310 | }, 311 | "engines": { 312 | "node": ">= 8" 313 | } 314 | }, 315 | "node_modules/cross-spawn/node_modules/which": { 316 | "version": "2.0.2", 317 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 318 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 319 | "dev": true, 320 | "dependencies": { 321 | "isexe": "^2.0.0" 322 | }, 323 | "bin": { 324 | "node-which": "bin/node-which" 325 | }, 326 | "engines": { 327 | "node": ">= 8" 328 | } 329 | }, 330 | "node_modules/cyclist": { 331 | "version": "1.0.1", 332 | "resolved": "https://registry.npmjs.org/cyclist/-/cyclist-1.0.1.tgz", 333 | "integrity": "sha1-WW6WmP0MgOEgOMK4LW6xs1tiJNk=", 334 | "dev": true 335 | }, 336 | "node_modules/dashdash": { 337 | "version": "1.14.1", 338 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 339 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 340 | "dev": true, 341 | "dependencies": { 342 | "assert-plus": "^1.0.0" 343 | }, 344 | "engines": { 345 | "node": ">=0.10" 346 | } 347 | }, 348 | "node_modules/delayed-stream": { 349 | "version": "1.0.0", 350 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 351 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 352 | "dev": true, 353 | "engines": { 354 | "node": ">=0.4.0" 355 | } 356 | }, 357 | "node_modules/duplexify": { 358 | "version": "3.7.1", 359 | "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.7.1.tgz", 360 | "integrity": "sha512-07z8uv2wMyS51kKhD1KsdXJg5WQ6t93RneqRxUHnskXVtlYYkLqM0gqStQZ3pj073g687jPCHrqNfCzawLYh5g==", 361 | "dev": true, 362 | "dependencies": { 363 | "end-of-stream": "^1.0.0", 364 | "inherits": "^2.0.1", 365 | "readable-stream": "^2.0.0", 366 | "stream-shift": "^1.0.0" 367 | } 368 | }, 369 | "node_modules/ecc-jsbn": { 370 | "version": "0.1.2", 371 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 372 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 373 | "dev": true, 374 | "dependencies": { 375 | "jsbn": "~0.1.0", 376 | "safer-buffer": "^2.1.0" 377 | } 378 | }, 379 | "node_modules/emoji-regex": { 380 | "version": "7.0.3", 381 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 382 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 383 | "dev": true 384 | }, 385 | "node_modules/end-of-stream": { 386 | "version": "1.4.4", 387 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 388 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 389 | "dev": true, 390 | "dependencies": { 391 | "once": "^1.4.0" 392 | } 393 | }, 394 | "node_modules/env-paths": { 395 | "version": "2.2.1", 396 | "resolved": "https://registry.npmjs.org/env-paths/-/env-paths-2.2.1.tgz", 397 | "integrity": "sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==", 398 | "dev": true, 399 | "engines": { 400 | "node": ">=6" 401 | } 402 | }, 403 | "node_modules/escape-string-regexp": { 404 | "version": "1.0.5", 405 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 406 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 407 | "dev": true, 408 | "engines": { 409 | "node": ">=0.8.0" 410 | } 411 | }, 412 | "node_modules/execa": { 413 | "version": "2.1.0", 414 | "resolved": "https://registry.npmjs.org/execa/-/execa-2.1.0.tgz", 415 | "integrity": "sha512-Y/URAVapfbYy2Xp/gb6A0E7iR8xeqOCXsuuaoMn7A5PzrXUK84E1gyiEfq0wQd/GHA6GsoHWwhNq8anb0mleIw==", 416 | "dev": true, 417 | "dependencies": { 418 | "cross-spawn": "^7.0.0", 419 | "get-stream": "^5.0.0", 420 | "is-stream": "^2.0.0", 421 | "merge-stream": "^2.0.0", 422 | "npm-run-path": "^3.0.0", 423 | "onetime": "^5.1.0", 424 | "p-finally": "^2.0.0", 425 | "signal-exit": "^3.0.2", 426 | "strip-final-newline": "^2.0.0" 427 | }, 428 | "engines": { 429 | "node": "^8.12.0 || >=9.7.0" 430 | } 431 | }, 432 | "node_modules/extend": { 433 | "version": "3.0.2", 434 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 435 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 436 | "dev": true 437 | }, 438 | "node_modules/extsprintf": { 439 | "version": "1.3.0", 440 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 441 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 442 | "dev": true, 443 | "engines": [ 444 | "node >=0.6.0" 445 | ] 446 | }, 447 | "node_modules/fast-deep-equal": { 448 | "version": "3.1.3", 449 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 450 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 451 | "dev": true 452 | }, 453 | "node_modules/fast-json-stable-stringify": { 454 | "version": "2.1.0", 455 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 456 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 457 | "dev": true 458 | }, 459 | "node_modules/figgy-pudding": { 460 | "version": "3.5.2", 461 | "resolved": "https://registry.npmjs.org/figgy-pudding/-/figgy-pudding-3.5.2.tgz", 462 | "integrity": "sha512-0btnI/H8f2pavGMN8w40mlSKOfTK2SVJmBfBeVIj3kNw0swwgzyRq0d5TJVOwodFmtvpPeWPN/MCcfuWF0Ezbw==", 463 | "dev": true 464 | }, 465 | "node_modules/filesize": { 466 | "version": "4.2.1", 467 | "resolved": "https://registry.npmjs.org/filesize/-/filesize-4.2.1.tgz", 468 | "integrity": "sha512-bP82Hi8VRZX/TUBKfE24iiUGsB/sfm2WUrwTQyAzQrhO3V9IhcBBNBXMyzLY5orACxRyYJ3d2HeRVX+eFv4lmA==", 469 | "dev": true, 470 | "engines": { 471 | "node": ">= 0.4.0" 472 | } 473 | }, 474 | "node_modules/flush-write-stream": { 475 | "version": "1.1.1", 476 | "resolved": "https://registry.npmjs.org/flush-write-stream/-/flush-write-stream-1.1.1.tgz", 477 | "integrity": "sha512-3Z4XhFZ3992uIq0XOqb9AreonueSYphE6oYbpt5+3u06JWklbsPkNv3ZKkP9Bz/r+1MWCaMoSQ28P85+1Yc77w==", 478 | "dev": true, 479 | "dependencies": { 480 | "inherits": "^2.0.3", 481 | "readable-stream": "^2.3.6" 482 | } 483 | }, 484 | "node_modules/forever-agent": { 485 | "version": "0.6.1", 486 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 487 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 488 | "dev": true, 489 | "engines": { 490 | "node": "*" 491 | } 492 | }, 493 | "node_modules/form-data": { 494 | "version": "2.3.3", 495 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 496 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 497 | "dev": true, 498 | "dependencies": { 499 | "asynckit": "^0.4.0", 500 | "combined-stream": "^1.0.6", 501 | "mime-types": "^2.1.12" 502 | }, 503 | "engines": { 504 | "node": ">= 0.12" 505 | } 506 | }, 507 | "node_modules/from2": { 508 | "version": "2.3.0", 509 | "resolved": "https://registry.npmjs.org/from2/-/from2-2.3.0.tgz", 510 | "integrity": "sha1-i/tVAr3kpNNs/e6gB/zKIdfjgq8=", 511 | "dev": true, 512 | "dependencies": { 513 | "inherits": "^2.0.1", 514 | "readable-stream": "^2.0.0" 515 | } 516 | }, 517 | "node_modules/fs-minipass": { 518 | "version": "1.2.7", 519 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.7.tgz", 520 | "integrity": "sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA==", 521 | "dev": true, 522 | "dependencies": { 523 | "minipass": "^2.6.0" 524 | } 525 | }, 526 | "node_modules/fs-write-stream-atomic": { 527 | "version": "1.0.10", 528 | "resolved": "https://registry.npmjs.org/fs-write-stream-atomic/-/fs-write-stream-atomic-1.0.10.tgz", 529 | "integrity": "sha1-tH31NJPvkR33VzHnCp3tAYnbQMk=", 530 | "dev": true, 531 | "dependencies": { 532 | "graceful-fs": "^4.1.2", 533 | "iferr": "^0.1.5", 534 | "imurmurhash": "^0.1.4", 535 | "readable-stream": "1 || 2" 536 | } 537 | }, 538 | "node_modules/fs.realpath": { 539 | "version": "1.0.0", 540 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 541 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 542 | "dev": true 543 | }, 544 | "node_modules/get-stream": { 545 | "version": "5.2.0", 546 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", 547 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", 548 | "dev": true, 549 | "dependencies": { 550 | "pump": "^3.0.0" 551 | }, 552 | "engines": { 553 | "node": ">=8" 554 | }, 555 | "funding": { 556 | "url": "https://github.com/sponsors/sindresorhus" 557 | } 558 | }, 559 | "node_modules/getpass": { 560 | "version": "0.1.7", 561 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 562 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 563 | "dev": true, 564 | "dependencies": { 565 | "assert-plus": "^1.0.0" 566 | } 567 | }, 568 | "node_modules/glob": { 569 | "version": "7.1.6", 570 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 571 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 572 | "dev": true, 573 | "dependencies": { 574 | "fs.realpath": "^1.0.0", 575 | "inflight": "^1.0.4", 576 | "inherits": "2", 577 | "minimatch": "^3.0.4", 578 | "once": "^1.3.0", 579 | "path-is-absolute": "^1.0.0" 580 | }, 581 | "engines": { 582 | "node": "*" 583 | }, 584 | "funding": { 585 | "url": "https://github.com/sponsors/isaacs" 586 | } 587 | }, 588 | "node_modules/graceful-fs": { 589 | "version": "4.2.6", 590 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.6.tgz", 591 | "integrity": "sha512-nTnJ528pbqxYanhpDYsi4Rd8MAeaBA67+RZ10CM1m3bTAVFEDcd5AuA4a6W5YkGZ1iNXHzZz8T6TBKLeBuNriQ==", 592 | "dev": true 593 | }, 594 | "node_modules/har-schema": { 595 | "version": "2.0.0", 596 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 597 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 598 | "dev": true, 599 | "engines": { 600 | "node": ">=4" 601 | } 602 | }, 603 | "node_modules/har-validator": { 604 | "version": "5.1.5", 605 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.5.tgz", 606 | "integrity": "sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w==", 607 | "deprecated": "this library is no longer supported", 608 | "dev": true, 609 | "dependencies": { 610 | "ajv": "^6.12.3", 611 | "har-schema": "^2.0.0" 612 | }, 613 | "engines": { 614 | "node": ">=6" 615 | } 616 | }, 617 | "node_modules/has-flag": { 618 | "version": "3.0.0", 619 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 620 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 621 | "dev": true, 622 | "engines": { 623 | "node": ">=4" 624 | } 625 | }, 626 | "node_modules/http-signature": { 627 | "version": "1.2.0", 628 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 629 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 630 | "dev": true, 631 | "dependencies": { 632 | "assert-plus": "^1.0.0", 633 | "jsprim": "^1.2.2", 634 | "sshpk": "^1.7.0" 635 | }, 636 | "engines": { 637 | "node": ">=0.8", 638 | "npm": ">=1.3.7" 639 | } 640 | }, 641 | "node_modules/iferr": { 642 | "version": "0.1.5", 643 | "resolved": "https://registry.npmjs.org/iferr/-/iferr-0.1.5.tgz", 644 | "integrity": "sha1-xg7taebY/bazEEofy8ocGS3FtQE=", 645 | "dev": true 646 | }, 647 | "node_modules/imurmurhash": { 648 | "version": "0.1.4", 649 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 650 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 651 | "dev": true, 652 | "engines": { 653 | "node": ">=0.8.19" 654 | } 655 | }, 656 | "node_modules/inflight": { 657 | "version": "1.0.6", 658 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 659 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 660 | "dev": true, 661 | "dependencies": { 662 | "once": "^1.3.0", 663 | "wrappy": "1" 664 | } 665 | }, 666 | "node_modules/inherits": { 667 | "version": "2.0.4", 668 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 669 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 670 | "dev": true 671 | }, 672 | "node_modules/is-fullwidth-code-point": { 673 | "version": "2.0.0", 674 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 675 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 676 | "dev": true, 677 | "engines": { 678 | "node": ">=4" 679 | } 680 | }, 681 | "node_modules/is-plain-obj": { 682 | "version": "2.1.0", 683 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 684 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 685 | "dev": true, 686 | "engines": { 687 | "node": ">=8" 688 | } 689 | }, 690 | "node_modules/is-stream": { 691 | "version": "2.0.0", 692 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", 693 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==", 694 | "dev": true, 695 | "engines": { 696 | "node": ">=8" 697 | } 698 | }, 699 | "node_modules/is-typedarray": { 700 | "version": "1.0.0", 701 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 702 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 703 | "dev": true 704 | }, 705 | "node_modules/isarray": { 706 | "version": "1.0.0", 707 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 708 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 709 | "dev": true 710 | }, 711 | "node_modules/isexe": { 712 | "version": "2.0.0", 713 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 714 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 715 | "dev": true 716 | }, 717 | "node_modules/isstream": { 718 | "version": "0.1.2", 719 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 720 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", 721 | "dev": true 722 | }, 723 | "node_modules/jsbn": { 724 | "version": "0.1.1", 725 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 726 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 727 | "dev": true 728 | }, 729 | "node_modules/json-schema": { 730 | "version": "0.2.3", 731 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 732 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", 733 | "dev": true 734 | }, 735 | "node_modules/json-schema-traverse": { 736 | "version": "0.4.1", 737 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 738 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 739 | "dev": true 740 | }, 741 | "node_modules/json-stringify-safe": { 742 | "version": "5.0.1", 743 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 744 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", 745 | "dev": true 746 | }, 747 | "node_modules/jsprim": { 748 | "version": "1.4.1", 749 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 750 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 751 | "dev": true, 752 | "engines": [ 753 | "node >=0.6.0" 754 | ], 755 | "dependencies": { 756 | "assert-plus": "1.0.0", 757 | "extsprintf": "1.3.0", 758 | "json-schema": "0.2.3", 759 | "verror": "1.10.0" 760 | } 761 | }, 762 | "node_modules/log-symbols": { 763 | "version": "3.0.0", 764 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-3.0.0.tgz", 765 | "integrity": "sha512-dSkNGuI7iG3mfvDzUuYZyvk5dD9ocYCYzNU6CYDE6+Xqd+gwme6Z00NS3dUh8mq/73HaEtT7m6W+yUPtU6BZnQ==", 766 | "dev": true, 767 | "dependencies": { 768 | "chalk": "^2.4.2" 769 | }, 770 | "engines": { 771 | "node": ">=8" 772 | } 773 | }, 774 | "node_modules/log-update": { 775 | "version": "3.4.0", 776 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-3.4.0.tgz", 777 | "integrity": "sha512-ILKe88NeMt4gmDvk/eb615U/IVn7K9KWGkoYbdatQ69Z65nj1ZzjM6fHXfcs0Uge+e+EGnMW7DY4T9yko8vWFg==", 778 | "dev": true, 779 | "dependencies": { 780 | "ansi-escapes": "^3.2.0", 781 | "cli-cursor": "^2.1.0", 782 | "wrap-ansi": "^5.0.0" 783 | }, 784 | "engines": { 785 | "node": ">=6" 786 | }, 787 | "funding": { 788 | "url": "https://github.com/sponsors/sindresorhus" 789 | } 790 | }, 791 | "node_modules/lru-cache": { 792 | "version": "5.1.1", 793 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 794 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 795 | "dev": true, 796 | "dependencies": { 797 | "yallist": "^3.0.2" 798 | } 799 | }, 800 | "node_modules/merge-stream": { 801 | "version": "2.0.0", 802 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 803 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 804 | "dev": true 805 | }, 806 | "node_modules/mime-db": { 807 | "version": "1.46.0", 808 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.46.0.tgz", 809 | "integrity": "sha512-svXaP8UQRZ5K7or+ZmfNhg2xX3yKDMUzqadsSqi4NCH/KomcH75MAMYAGVlvXn4+b/xOPhS3I2uHKRUzvjY7BQ==", 810 | "dev": true, 811 | "engines": { 812 | "node": ">= 0.6" 813 | } 814 | }, 815 | "node_modules/mime-types": { 816 | "version": "2.1.29", 817 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.29.tgz", 818 | "integrity": "sha512-Y/jMt/S5sR9OaqteJtslsFZKWOIIqMACsJSiHghlCAyhf7jfVYjKBmLiX8OgpWeW+fjJ2b+Az69aPFPkUOY6xQ==", 819 | "dev": true, 820 | "dependencies": { 821 | "mime-db": "1.46.0" 822 | }, 823 | "engines": { 824 | "node": ">= 0.6" 825 | } 826 | }, 827 | "node_modules/mimic-fn": { 828 | "version": "2.1.0", 829 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 830 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 831 | "dev": true, 832 | "engines": { 833 | "node": ">=6" 834 | } 835 | }, 836 | "node_modules/minimatch": { 837 | "version": "3.0.4", 838 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 839 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 840 | "dev": true, 841 | "dependencies": { 842 | "brace-expansion": "^1.1.7" 843 | }, 844 | "engines": { 845 | "node": "*" 846 | } 847 | }, 848 | "node_modules/minimist": { 849 | "version": "1.2.5", 850 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 851 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 852 | "dev": true 853 | }, 854 | "node_modules/minipass": { 855 | "version": "2.9.0", 856 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.9.0.tgz", 857 | "integrity": "sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg==", 858 | "dev": true, 859 | "dependencies": { 860 | "safe-buffer": "^5.1.2", 861 | "yallist": "^3.0.0" 862 | } 863 | }, 864 | "node_modules/minizlib": { 865 | "version": "1.3.3", 866 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.3.3.tgz", 867 | "integrity": "sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q==", 868 | "dev": true, 869 | "dependencies": { 870 | "minipass": "^2.9.0" 871 | } 872 | }, 873 | "node_modules/mississippi": { 874 | "version": "3.0.0", 875 | "resolved": "https://registry.npmjs.org/mississippi/-/mississippi-3.0.0.tgz", 876 | "integrity": "sha512-x471SsVjUtBRtcvd4BzKE9kFC+/2TeWgKCgw0bZcw1b9l2X3QX5vCWgF+KaZaYm87Ss//rHnWryupDrgLvmSkA==", 877 | "dev": true, 878 | "dependencies": { 879 | "concat-stream": "^1.5.0", 880 | "duplexify": "^3.4.2", 881 | "end-of-stream": "^1.1.0", 882 | "flush-write-stream": "^1.0.0", 883 | "from2": "^2.1.0", 884 | "parallel-transform": "^1.1.0", 885 | "pump": "^3.0.0", 886 | "pumpify": "^1.3.3", 887 | "stream-each": "^1.1.0", 888 | "through2": "^2.0.0" 889 | }, 890 | "engines": { 891 | "node": ">=4.0.0" 892 | } 893 | }, 894 | "node_modules/mkdirp": { 895 | "version": "0.5.5", 896 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 897 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 898 | "dev": true, 899 | "dependencies": { 900 | "minimist": "^1.2.5" 901 | }, 902 | "bin": { 903 | "mkdirp": "bin/cmd.js" 904 | } 905 | }, 906 | "node_modules/move-concurrently": { 907 | "version": "1.0.1", 908 | "resolved": "https://registry.npmjs.org/move-concurrently/-/move-concurrently-1.0.1.tgz", 909 | "integrity": "sha1-viwAX9oy4LKa8fBdfEszIUxwH5I=", 910 | "dev": true, 911 | "dependencies": { 912 | "aproba": "^1.1.1", 913 | "copy-concurrently": "^1.0.0", 914 | "fs-write-stream-atomic": "^1.0.8", 915 | "mkdirp": "^0.5.1", 916 | "rimraf": "^2.5.4", 917 | "run-queue": "^1.0.3" 918 | } 919 | }, 920 | "node_modules/ms": { 921 | "version": "2.1.3", 922 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 923 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 924 | "dev": true 925 | }, 926 | "node_modules/npm-run-path": { 927 | "version": "3.1.0", 928 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-3.1.0.tgz", 929 | "integrity": "sha512-Dbl4A/VfiVGLgQv29URL9xshU8XDY1GeLy+fsaZ1AA8JDSfjvr5P5+pzRbWqRSBxk6/DW7MIh8lTM/PaGnP2kg==", 930 | "dev": true, 931 | "dependencies": { 932 | "path-key": "^3.0.0" 933 | }, 934 | "engines": { 935 | "node": ">=8" 936 | } 937 | }, 938 | "node_modules/oauth-sign": { 939 | "version": "0.9.0", 940 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 941 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", 942 | "dev": true, 943 | "engines": { 944 | "node": "*" 945 | } 946 | }, 947 | "node_modules/once": { 948 | "version": "1.4.0", 949 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 950 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 951 | "dev": true, 952 | "dependencies": { 953 | "wrappy": "1" 954 | } 955 | }, 956 | "node_modules/onetime": { 957 | "version": "5.1.2", 958 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 959 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 960 | "dev": true, 961 | "dependencies": { 962 | "mimic-fn": "^2.1.0" 963 | }, 964 | "engines": { 965 | "node": ">=6" 966 | }, 967 | "funding": { 968 | "url": "https://github.com/sponsors/sindresorhus" 969 | } 970 | }, 971 | "node_modules/p-finally": { 972 | "version": "2.0.1", 973 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-2.0.1.tgz", 974 | "integrity": "sha512-vpm09aKwq6H9phqRQzecoDpD8TmVyGw70qmWlyq5onxY7tqyTTFVvxMykxQSQKILBSFlbXpypIw2T1Ml7+DDtw==", 975 | "dev": true, 976 | "engines": { 977 | "node": ">=8" 978 | } 979 | }, 980 | "node_modules/parallel-transform": { 981 | "version": "1.2.0", 982 | "resolved": "https://registry.npmjs.org/parallel-transform/-/parallel-transform-1.2.0.tgz", 983 | "integrity": "sha512-P2vSmIu38uIlvdcU7fDkyrxj33gTUy/ABO5ZUbGowxNCopBq/OoD42bP4UmMrJoPyk4Uqf0mu3mtWBhHCZD8yg==", 984 | "dev": true, 985 | "dependencies": { 986 | "cyclist": "^1.0.1", 987 | "inherits": "^2.0.3", 988 | "readable-stream": "^2.1.5" 989 | } 990 | }, 991 | "node_modules/path-is-absolute": { 992 | "version": "1.0.1", 993 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 994 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 995 | "dev": true, 996 | "engines": { 997 | "node": ">=0.10.0" 998 | } 999 | }, 1000 | "node_modules/path-key": { 1001 | "version": "3.1.1", 1002 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1003 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1004 | "dev": true, 1005 | "engines": { 1006 | "node": ">=8" 1007 | } 1008 | }, 1009 | "node_modules/performance-now": { 1010 | "version": "2.1.0", 1011 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 1012 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", 1013 | "dev": true 1014 | }, 1015 | "node_modules/process-nextick-args": { 1016 | "version": "2.0.1", 1017 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1018 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 1019 | "dev": true 1020 | }, 1021 | "node_modules/promise-inflight": { 1022 | "version": "1.0.1", 1023 | "resolved": "https://registry.npmjs.org/promise-inflight/-/promise-inflight-1.0.1.tgz", 1024 | "integrity": "sha1-mEcocL8igTL8vdhoEputEsPAKeM=", 1025 | "dev": true 1026 | }, 1027 | "node_modules/psl": { 1028 | "version": "1.8.0", 1029 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz", 1030 | "integrity": "sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==", 1031 | "dev": true 1032 | }, 1033 | "node_modules/pump": { 1034 | "version": "3.0.0", 1035 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1036 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1037 | "dev": true, 1038 | "dependencies": { 1039 | "end-of-stream": "^1.1.0", 1040 | "once": "^1.3.1" 1041 | } 1042 | }, 1043 | "node_modules/pumpify": { 1044 | "version": "1.5.1", 1045 | "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-1.5.1.tgz", 1046 | "integrity": "sha512-oClZI37HvuUJJxSKKrC17bZ9Cu0ZYhEAGPsPUy9KlMUmv9dKX2o77RUmq7f3XjIxbwyGwYzbzQ1L2Ks8sIradQ==", 1047 | "dev": true, 1048 | "dependencies": { 1049 | "duplexify": "^3.6.0", 1050 | "inherits": "^2.0.3", 1051 | "pump": "^2.0.0" 1052 | } 1053 | }, 1054 | "node_modules/pumpify/node_modules/pump": { 1055 | "version": "2.0.1", 1056 | "resolved": "https://registry.npmjs.org/pump/-/pump-2.0.1.tgz", 1057 | "integrity": "sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==", 1058 | "dev": true, 1059 | "dependencies": { 1060 | "end-of-stream": "^1.1.0", 1061 | "once": "^1.3.1" 1062 | } 1063 | }, 1064 | "node_modules/punycode": { 1065 | "version": "2.1.1", 1066 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1067 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1068 | "dev": true, 1069 | "engines": { 1070 | "node": ">=6" 1071 | } 1072 | }, 1073 | "node_modules/purescript": { 1074 | "version": "0.14.0", 1075 | "resolved": "https://registry.npmjs.org/purescript/-/purescript-0.14.0.tgz", 1076 | "integrity": "sha512-iTA1k8mwxHqrJp/K296g6omVfve5RCjnB5D6Up93PVtZdP66mCIqlOYC4hrLBHg2hgkk27xePDt5NUXKvH4ApQ==", 1077 | "dev": true, 1078 | "hasInstallScript": true, 1079 | "dependencies": { 1080 | "purescript-installer": "^0.2.0" 1081 | }, 1082 | "bin": { 1083 | "purs": "purs.bin" 1084 | } 1085 | }, 1086 | "node_modules/purescript-installer": { 1087 | "version": "0.2.5", 1088 | "resolved": "https://registry.npmjs.org/purescript-installer/-/purescript-installer-0.2.5.tgz", 1089 | "integrity": "sha512-fQAWWP5a7scuchXecjpU4r4KEgSPuS6bBnaP01k9f71qqD28HaJ2m4PXHFkhkR4oATAxTPIGCtmTwtVoiBOHog==", 1090 | "dev": true, 1091 | "dependencies": { 1092 | "arch": "^2.1.1", 1093 | "byline": "^5.0.0", 1094 | "cacache": "^11.3.2", 1095 | "chalk": "^2.4.2", 1096 | "env-paths": "^2.2.0", 1097 | "execa": "^2.0.3", 1098 | "filesize": "^4.1.2", 1099 | "is-plain-obj": "^2.0.0", 1100 | "log-symbols": "^3.0.0", 1101 | "log-update": "^3.2.0", 1102 | "minimist": "^1.2.0", 1103 | "mkdirp": "^0.5.1", 1104 | "ms": "^2.1.2", 1105 | "once": "^1.4.0", 1106 | "pump": "^3.0.0", 1107 | "request": "^2.88.0", 1108 | "rimraf": "^2.6.3", 1109 | "tar": "^4.4.6", 1110 | "which": "^1.3.1", 1111 | "zen-observable": "^0.8.14" 1112 | }, 1113 | "bin": { 1114 | "install-purescript": "index.js" 1115 | }, 1116 | "engines": { 1117 | "node": ">=8.3.0" 1118 | } 1119 | }, 1120 | "node_modules/purty": { 1121 | "version": "7.0.0", 1122 | "resolved": "https://registry.npmjs.org/purty/-/purty-7.0.0.tgz", 1123 | "integrity": "sha512-gHHghPEjRY39GUJ8KnOMRfPArJILGCXwEhX6BmEdNiLgZuCjLLBLyawGiKFjYMfy8H5Dsk5NbgwIGslrPrernA==", 1124 | "dev": true, 1125 | "os": [ 1126 | "linux", 1127 | "darwin", 1128 | "win32" 1129 | ], 1130 | "bin": { 1131 | "purty": "bin/purty.js" 1132 | } 1133 | }, 1134 | "node_modules/qs": { 1135 | "version": "6.5.2", 1136 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 1137 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", 1138 | "dev": true, 1139 | "engines": { 1140 | "node": ">=0.6" 1141 | } 1142 | }, 1143 | "node_modules/readable-stream": { 1144 | "version": "2.3.7", 1145 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 1146 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 1147 | "dev": true, 1148 | "dependencies": { 1149 | "core-util-is": "~1.0.0", 1150 | "inherits": "~2.0.3", 1151 | "isarray": "~1.0.0", 1152 | "process-nextick-args": "~2.0.0", 1153 | "safe-buffer": "~5.1.1", 1154 | "string_decoder": "~1.1.1", 1155 | "util-deprecate": "~1.0.1" 1156 | } 1157 | }, 1158 | "node_modules/request": { 1159 | "version": "2.88.2", 1160 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz", 1161 | "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==", 1162 | "deprecated": "request has been deprecated, see https://github.com/request/request/issues/3142", 1163 | "dev": true, 1164 | "dependencies": { 1165 | "aws-sign2": "~0.7.0", 1166 | "aws4": "^1.8.0", 1167 | "caseless": "~0.12.0", 1168 | "combined-stream": "~1.0.6", 1169 | "extend": "~3.0.2", 1170 | "forever-agent": "~0.6.1", 1171 | "form-data": "~2.3.2", 1172 | "har-validator": "~5.1.3", 1173 | "http-signature": "~1.2.0", 1174 | "is-typedarray": "~1.0.0", 1175 | "isstream": "~0.1.2", 1176 | "json-stringify-safe": "~5.0.1", 1177 | "mime-types": "~2.1.19", 1178 | "oauth-sign": "~0.9.0", 1179 | "performance-now": "^2.1.0", 1180 | "qs": "~6.5.2", 1181 | "safe-buffer": "^5.1.2", 1182 | "tough-cookie": "~2.5.0", 1183 | "tunnel-agent": "^0.6.0", 1184 | "uuid": "^3.3.2" 1185 | }, 1186 | "engines": { 1187 | "node": ">= 6" 1188 | } 1189 | }, 1190 | "node_modules/restore-cursor": { 1191 | "version": "2.0.0", 1192 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 1193 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 1194 | "dev": true, 1195 | "dependencies": { 1196 | "onetime": "^2.0.0", 1197 | "signal-exit": "^3.0.2" 1198 | }, 1199 | "engines": { 1200 | "node": ">=4" 1201 | } 1202 | }, 1203 | "node_modules/restore-cursor/node_modules/mimic-fn": { 1204 | "version": "1.2.0", 1205 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 1206 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", 1207 | "dev": true, 1208 | "engines": { 1209 | "node": ">=4" 1210 | } 1211 | }, 1212 | "node_modules/restore-cursor/node_modules/onetime": { 1213 | "version": "2.0.1", 1214 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 1215 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 1216 | "dev": true, 1217 | "dependencies": { 1218 | "mimic-fn": "^1.0.0" 1219 | }, 1220 | "engines": { 1221 | "node": ">=4" 1222 | } 1223 | }, 1224 | "node_modules/rimraf": { 1225 | "version": "2.7.1", 1226 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1227 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1228 | "dev": true, 1229 | "dependencies": { 1230 | "glob": "^7.1.3" 1231 | }, 1232 | "bin": { 1233 | "rimraf": "bin.js" 1234 | } 1235 | }, 1236 | "node_modules/run-queue": { 1237 | "version": "1.0.3", 1238 | "resolved": "https://registry.npmjs.org/run-queue/-/run-queue-1.0.3.tgz", 1239 | "integrity": "sha1-6Eg5bwV9Ij8kOGkkYY4laUFh7Ec=", 1240 | "dev": true, 1241 | "dependencies": { 1242 | "aproba": "^1.1.1" 1243 | } 1244 | }, 1245 | "node_modules/safe-buffer": { 1246 | "version": "5.1.2", 1247 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1248 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1249 | "dev": true 1250 | }, 1251 | "node_modules/safer-buffer": { 1252 | "version": "2.1.2", 1253 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1254 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1255 | "dev": true 1256 | }, 1257 | "node_modules/shebang-command": { 1258 | "version": "2.0.0", 1259 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1260 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1261 | "dev": true, 1262 | "dependencies": { 1263 | "shebang-regex": "^3.0.0" 1264 | }, 1265 | "engines": { 1266 | "node": ">=8" 1267 | } 1268 | }, 1269 | "node_modules/shebang-regex": { 1270 | "version": "3.0.0", 1271 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1272 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1273 | "dev": true, 1274 | "engines": { 1275 | "node": ">=8" 1276 | } 1277 | }, 1278 | "node_modules/signal-exit": { 1279 | "version": "3.0.3", 1280 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 1281 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 1282 | "dev": true 1283 | }, 1284 | "node_modules/spago": { 1285 | "version": "0.19.1", 1286 | "resolved": "https://registry.npmjs.org/spago/-/spago-0.19.1.tgz", 1287 | "integrity": "sha512-OD/yopJZ9Ub+XsFtayDeLAWLT4kLdMxosJEyyp8W5OkyJVVSbCrvYacsO7iq3lSuHJmmNny/TEZdyb7uSyupng==", 1288 | "dev": true, 1289 | "hasInstallScript": true, 1290 | "dependencies": { 1291 | "request": "^2.88.0", 1292 | "tar": "^4.4.8" 1293 | }, 1294 | "bin": { 1295 | "spago": "spago" 1296 | } 1297 | }, 1298 | "node_modules/sshpk": { 1299 | "version": "1.16.1", 1300 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", 1301 | "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", 1302 | "dev": true, 1303 | "dependencies": { 1304 | "asn1": "~0.2.3", 1305 | "assert-plus": "^1.0.0", 1306 | "bcrypt-pbkdf": "^1.0.0", 1307 | "dashdash": "^1.12.0", 1308 | "ecc-jsbn": "~0.1.1", 1309 | "getpass": "^0.1.1", 1310 | "jsbn": "~0.1.0", 1311 | "safer-buffer": "^2.0.2", 1312 | "tweetnacl": "~0.14.0" 1313 | }, 1314 | "bin": { 1315 | "sshpk-conv": "bin/sshpk-conv", 1316 | "sshpk-sign": "bin/sshpk-sign", 1317 | "sshpk-verify": "bin/sshpk-verify" 1318 | }, 1319 | "engines": { 1320 | "node": ">=0.10.0" 1321 | } 1322 | }, 1323 | "node_modules/ssri": { 1324 | "version": "6.0.1", 1325 | "resolved": "https://registry.npmjs.org/ssri/-/ssri-6.0.1.tgz", 1326 | "integrity": "sha512-3Wge10hNcT1Kur4PDFwEieXSCMCJs/7WvSACcrMYrNp+b8kDL1/0wJch5Ni2WrtwEa2IO8OsVfeKIciKCDx/QA==", 1327 | "dev": true, 1328 | "dependencies": { 1329 | "figgy-pudding": "^3.5.1" 1330 | } 1331 | }, 1332 | "node_modules/stream-each": { 1333 | "version": "1.2.3", 1334 | "resolved": "https://registry.npmjs.org/stream-each/-/stream-each-1.2.3.tgz", 1335 | "integrity": "sha512-vlMC2f8I2u/bZGqkdfLQW/13Zihpej/7PmSiMQsbYddxuTsJp8vRe2x2FvVExZg7FaOds43ROAuFJwPR4MTZLw==", 1336 | "dev": true, 1337 | "dependencies": { 1338 | "end-of-stream": "^1.1.0", 1339 | "stream-shift": "^1.0.0" 1340 | } 1341 | }, 1342 | "node_modules/stream-shift": { 1343 | "version": "1.0.1", 1344 | "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.1.tgz", 1345 | "integrity": "sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ==", 1346 | "dev": true 1347 | }, 1348 | "node_modules/string_decoder": { 1349 | "version": "1.1.1", 1350 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1351 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1352 | "dev": true, 1353 | "dependencies": { 1354 | "safe-buffer": "~5.1.0" 1355 | } 1356 | }, 1357 | "node_modules/string-width": { 1358 | "version": "3.1.0", 1359 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1360 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1361 | "dev": true, 1362 | "dependencies": { 1363 | "emoji-regex": "^7.0.1", 1364 | "is-fullwidth-code-point": "^2.0.0", 1365 | "strip-ansi": "^5.1.0" 1366 | }, 1367 | "engines": { 1368 | "node": ">=6" 1369 | } 1370 | }, 1371 | "node_modules/strip-ansi": { 1372 | "version": "5.2.0", 1373 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1374 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1375 | "dev": true, 1376 | "dependencies": { 1377 | "ansi-regex": "^4.1.0" 1378 | }, 1379 | "engines": { 1380 | "node": ">=6" 1381 | } 1382 | }, 1383 | "node_modules/strip-final-newline": { 1384 | "version": "2.0.0", 1385 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 1386 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 1387 | "dev": true, 1388 | "engines": { 1389 | "node": ">=6" 1390 | } 1391 | }, 1392 | "node_modules/supports-color": { 1393 | "version": "5.5.0", 1394 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1395 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1396 | "dev": true, 1397 | "dependencies": { 1398 | "has-flag": "^3.0.0" 1399 | }, 1400 | "engines": { 1401 | "node": ">=4" 1402 | } 1403 | }, 1404 | "node_modules/tar": { 1405 | "version": "4.4.13", 1406 | "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.13.tgz", 1407 | "integrity": "sha512-w2VwSrBoHa5BsSyH+KxEqeQBAllHhccyMFVHtGtdMpF4W7IRWfZjFiQceJPChOeTsSDVUpER2T8FA93pr0L+QA==", 1408 | "dev": true, 1409 | "dependencies": { 1410 | "chownr": "^1.1.1", 1411 | "fs-minipass": "^1.2.5", 1412 | "minipass": "^2.8.6", 1413 | "minizlib": "^1.2.1", 1414 | "mkdirp": "^0.5.0", 1415 | "safe-buffer": "^5.1.2", 1416 | "yallist": "^3.0.3" 1417 | }, 1418 | "engines": { 1419 | "node": ">=4.5" 1420 | } 1421 | }, 1422 | "node_modules/through2": { 1423 | "version": "2.0.5", 1424 | "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", 1425 | "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==", 1426 | "dev": true, 1427 | "dependencies": { 1428 | "readable-stream": "~2.3.6", 1429 | "xtend": "~4.0.1" 1430 | } 1431 | }, 1432 | "node_modules/tough-cookie": { 1433 | "version": "2.5.0", 1434 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", 1435 | "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", 1436 | "dev": true, 1437 | "dependencies": { 1438 | "psl": "^1.1.28", 1439 | "punycode": "^2.1.1" 1440 | }, 1441 | "engines": { 1442 | "node": ">=0.8" 1443 | } 1444 | }, 1445 | "node_modules/tunnel-agent": { 1446 | "version": "0.6.0", 1447 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 1448 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 1449 | "dev": true, 1450 | "dependencies": { 1451 | "safe-buffer": "^5.0.1" 1452 | }, 1453 | "engines": { 1454 | "node": "*" 1455 | } 1456 | }, 1457 | "node_modules/tweetnacl": { 1458 | "version": "0.14.5", 1459 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 1460 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 1461 | "dev": true 1462 | }, 1463 | "node_modules/typedarray": { 1464 | "version": "0.0.6", 1465 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 1466 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", 1467 | "dev": true 1468 | }, 1469 | "node_modules/unique-filename": { 1470 | "version": "1.1.1", 1471 | "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-1.1.1.tgz", 1472 | "integrity": "sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ==", 1473 | "dev": true, 1474 | "dependencies": { 1475 | "unique-slug": "^2.0.0" 1476 | } 1477 | }, 1478 | "node_modules/unique-slug": { 1479 | "version": "2.0.2", 1480 | "resolved": "https://registry.npmjs.org/unique-slug/-/unique-slug-2.0.2.tgz", 1481 | "integrity": "sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w==", 1482 | "dev": true, 1483 | "dependencies": { 1484 | "imurmurhash": "^0.1.4" 1485 | } 1486 | }, 1487 | "node_modules/uri-js": { 1488 | "version": "4.4.1", 1489 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1490 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1491 | "dev": true, 1492 | "dependencies": { 1493 | "punycode": "^2.1.0" 1494 | } 1495 | }, 1496 | "node_modules/util-deprecate": { 1497 | "version": "1.0.2", 1498 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1499 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 1500 | "dev": true 1501 | }, 1502 | "node_modules/uuid": { 1503 | "version": "3.4.0", 1504 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 1505 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", 1506 | "dev": true, 1507 | "bin": { 1508 | "uuid": "bin/uuid" 1509 | } 1510 | }, 1511 | "node_modules/verror": { 1512 | "version": "1.10.0", 1513 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 1514 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 1515 | "dev": true, 1516 | "engines": [ 1517 | "node >=0.6.0" 1518 | ], 1519 | "dependencies": { 1520 | "assert-plus": "^1.0.0", 1521 | "core-util-is": "1.0.2", 1522 | "extsprintf": "^1.2.0" 1523 | } 1524 | }, 1525 | "node_modules/which": { 1526 | "version": "1.3.1", 1527 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1528 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1529 | "dev": true, 1530 | "dependencies": { 1531 | "isexe": "^2.0.0" 1532 | }, 1533 | "bin": { 1534 | "which": "bin/which" 1535 | } 1536 | }, 1537 | "node_modules/wrap-ansi": { 1538 | "version": "5.1.0", 1539 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 1540 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 1541 | "dev": true, 1542 | "dependencies": { 1543 | "ansi-styles": "^3.2.0", 1544 | "string-width": "^3.0.0", 1545 | "strip-ansi": "^5.0.0" 1546 | }, 1547 | "engines": { 1548 | "node": ">=6" 1549 | } 1550 | }, 1551 | "node_modules/wrappy": { 1552 | "version": "1.0.2", 1553 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1554 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1555 | "dev": true 1556 | }, 1557 | "node_modules/xtend": { 1558 | "version": "4.0.2", 1559 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 1560 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 1561 | "dev": true, 1562 | "engines": { 1563 | "node": ">=0.4" 1564 | } 1565 | }, 1566 | "node_modules/y18n": { 1567 | "version": "4.0.1", 1568 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.1.tgz", 1569 | "integrity": "sha512-wNcy4NvjMYL8gogWWYAO7ZFWFfHcbdbE57tZO8e4cbpj8tfUcwrwqSl3ad8HxpYWCdXcJUCeKKZS62Av1affwQ==", 1570 | "dev": true 1571 | }, 1572 | "node_modules/yallist": { 1573 | "version": "3.1.1", 1574 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 1575 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 1576 | "dev": true 1577 | }, 1578 | "node_modules/zen-observable": { 1579 | "version": "0.8.15", 1580 | "resolved": "https://registry.npmjs.org/zen-observable/-/zen-observable-0.8.15.tgz", 1581 | "integrity": "sha512-PQ2PC7R9rslx84ndNBZB/Dkv8V8fZEpk83RLgXtYd0fwUgEjseMn1Dgajh2x6S8QbZAFa9p2qVCEuYZNgve0dQ==", 1582 | "dev": true 1583 | } 1584 | }, 1585 | "dependencies": { 1586 | "ajv": { 1587 | "version": "6.12.6", 1588 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 1589 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 1590 | "dev": true, 1591 | "requires": { 1592 | "fast-deep-equal": "^3.1.1", 1593 | "fast-json-stable-stringify": "^2.0.0", 1594 | "json-schema-traverse": "^0.4.1", 1595 | "uri-js": "^4.2.2" 1596 | } 1597 | }, 1598 | "ansi-escapes": { 1599 | "version": "3.2.0", 1600 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", 1601 | "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==", 1602 | "dev": true 1603 | }, 1604 | "ansi-regex": { 1605 | "version": "4.1.0", 1606 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1607 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1608 | "dev": true 1609 | }, 1610 | "ansi-styles": { 1611 | "version": "3.2.1", 1612 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1613 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1614 | "dev": true, 1615 | "requires": { 1616 | "color-convert": "^1.9.0" 1617 | } 1618 | }, 1619 | "aproba": { 1620 | "version": "1.2.0", 1621 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 1622 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==", 1623 | "dev": true 1624 | }, 1625 | "arch": { 1626 | "version": "2.2.0", 1627 | "resolved": "https://registry.npmjs.org/arch/-/arch-2.2.0.tgz", 1628 | "integrity": "sha512-Of/R0wqp83cgHozfIYLbBMnej79U/SVGOOyuB3VVFv1NRM/PSFMK12x9KVtiYzJqmnU5WR2qp0Z5rHb7sWGnFQ==", 1629 | "dev": true 1630 | }, 1631 | "asn1": { 1632 | "version": "0.2.4", 1633 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 1634 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 1635 | "dev": true, 1636 | "requires": { 1637 | "safer-buffer": "~2.1.0" 1638 | } 1639 | }, 1640 | "assert-plus": { 1641 | "version": "1.0.0", 1642 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 1643 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 1644 | "dev": true 1645 | }, 1646 | "asynckit": { 1647 | "version": "0.4.0", 1648 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 1649 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 1650 | "dev": true 1651 | }, 1652 | "aws-sign2": { 1653 | "version": "0.7.0", 1654 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 1655 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 1656 | "dev": true 1657 | }, 1658 | "aws4": { 1659 | "version": "1.11.0", 1660 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.11.0.tgz", 1661 | "integrity": "sha512-xh1Rl34h6Fi1DC2WWKfxUTVqRsNnr6LsKz2+hfwDxQJWmrx8+c7ylaqBMcHfl1U1r2dsifOvKX3LQuLNZ+XSvA==", 1662 | "dev": true 1663 | }, 1664 | "balanced-match": { 1665 | "version": "1.0.0", 1666 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 1667 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 1668 | "dev": true 1669 | }, 1670 | "bcrypt-pbkdf": { 1671 | "version": "1.0.2", 1672 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 1673 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 1674 | "dev": true, 1675 | "requires": { 1676 | "tweetnacl": "^0.14.3" 1677 | } 1678 | }, 1679 | "bluebird": { 1680 | "version": "3.7.2", 1681 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", 1682 | "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==", 1683 | "dev": true 1684 | }, 1685 | "brace-expansion": { 1686 | "version": "1.1.11", 1687 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1688 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1689 | "dev": true, 1690 | "requires": { 1691 | "balanced-match": "^1.0.0", 1692 | "concat-map": "0.0.1" 1693 | } 1694 | }, 1695 | "buffer-from": { 1696 | "version": "1.1.1", 1697 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 1698 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 1699 | "dev": true 1700 | }, 1701 | "byline": { 1702 | "version": "5.0.0", 1703 | "resolved": "https://registry.npmjs.org/byline/-/byline-5.0.0.tgz", 1704 | "integrity": "sha1-dBxSFkaOrcRXsDQQEYrXfejB3bE=", 1705 | "dev": true 1706 | }, 1707 | "cacache": { 1708 | "version": "11.3.3", 1709 | "resolved": "https://registry.npmjs.org/cacache/-/cacache-11.3.3.tgz", 1710 | "integrity": "sha512-p8WcneCytvzPxhDvYp31PD039vi77I12W+/KfR9S8AZbaiARFBCpsPJS+9uhWfeBfeAtW7o/4vt3MUqLkbY6nA==", 1711 | "dev": true, 1712 | "requires": { 1713 | "bluebird": "^3.5.5", 1714 | "chownr": "^1.1.1", 1715 | "figgy-pudding": "^3.5.1", 1716 | "glob": "^7.1.4", 1717 | "graceful-fs": "^4.1.15", 1718 | "lru-cache": "^5.1.1", 1719 | "mississippi": "^3.0.0", 1720 | "mkdirp": "^0.5.1", 1721 | "move-concurrently": "^1.0.1", 1722 | "promise-inflight": "^1.0.1", 1723 | "rimraf": "^2.6.3", 1724 | "ssri": "^6.0.1", 1725 | "unique-filename": "^1.1.1", 1726 | "y18n": "^4.0.0" 1727 | } 1728 | }, 1729 | "caseless": { 1730 | "version": "0.12.0", 1731 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 1732 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", 1733 | "dev": true 1734 | }, 1735 | "chalk": { 1736 | "version": "2.4.2", 1737 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1738 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1739 | "dev": true, 1740 | "requires": { 1741 | "ansi-styles": "^3.2.1", 1742 | "escape-string-regexp": "^1.0.5", 1743 | "supports-color": "^5.3.0" 1744 | } 1745 | }, 1746 | "chownr": { 1747 | "version": "1.1.4", 1748 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", 1749 | "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", 1750 | "dev": true 1751 | }, 1752 | "cli-cursor": { 1753 | "version": "2.1.0", 1754 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 1755 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 1756 | "dev": true, 1757 | "requires": { 1758 | "restore-cursor": "^2.0.0" 1759 | } 1760 | }, 1761 | "color-convert": { 1762 | "version": "1.9.3", 1763 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1764 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1765 | "dev": true, 1766 | "requires": { 1767 | "color-name": "1.1.3" 1768 | } 1769 | }, 1770 | "color-name": { 1771 | "version": "1.1.3", 1772 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1773 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 1774 | "dev": true 1775 | }, 1776 | "combined-stream": { 1777 | "version": "1.0.8", 1778 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 1779 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 1780 | "dev": true, 1781 | "requires": { 1782 | "delayed-stream": "~1.0.0" 1783 | } 1784 | }, 1785 | "concat-map": { 1786 | "version": "0.0.1", 1787 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1788 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 1789 | "dev": true 1790 | }, 1791 | "concat-stream": { 1792 | "version": "1.6.2", 1793 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", 1794 | "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", 1795 | "dev": true, 1796 | "requires": { 1797 | "buffer-from": "^1.0.0", 1798 | "inherits": "^2.0.3", 1799 | "readable-stream": "^2.2.2", 1800 | "typedarray": "^0.0.6" 1801 | } 1802 | }, 1803 | "copy-concurrently": { 1804 | "version": "1.0.5", 1805 | "resolved": "https://registry.npmjs.org/copy-concurrently/-/copy-concurrently-1.0.5.tgz", 1806 | "integrity": "sha512-f2domd9fsVDFtaFcbaRZuYXwtdmnzqbADSwhSWYxYB/Q8zsdUUFMXVRwXGDMWmbEzAn1kdRrtI1T/KTFOL4X2A==", 1807 | "dev": true, 1808 | "requires": { 1809 | "aproba": "^1.1.1", 1810 | "fs-write-stream-atomic": "^1.0.8", 1811 | "iferr": "^0.1.5", 1812 | "mkdirp": "^0.5.1", 1813 | "rimraf": "^2.5.4", 1814 | "run-queue": "^1.0.0" 1815 | } 1816 | }, 1817 | "core-util-is": { 1818 | "version": "1.0.2", 1819 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 1820 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 1821 | "dev": true 1822 | }, 1823 | "cross-spawn": { 1824 | "version": "7.0.3", 1825 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1826 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1827 | "dev": true, 1828 | "requires": { 1829 | "path-key": "^3.1.0", 1830 | "shebang-command": "^2.0.0", 1831 | "which": "^2.0.1" 1832 | }, 1833 | "dependencies": { 1834 | "which": { 1835 | "version": "2.0.2", 1836 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1837 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1838 | "dev": true, 1839 | "requires": { 1840 | "isexe": "^2.0.0" 1841 | } 1842 | } 1843 | } 1844 | }, 1845 | "cyclist": { 1846 | "version": "1.0.1", 1847 | "resolved": "https://registry.npmjs.org/cyclist/-/cyclist-1.0.1.tgz", 1848 | "integrity": "sha1-WW6WmP0MgOEgOMK4LW6xs1tiJNk=", 1849 | "dev": true 1850 | }, 1851 | "dashdash": { 1852 | "version": "1.14.1", 1853 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 1854 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 1855 | "dev": true, 1856 | "requires": { 1857 | "assert-plus": "^1.0.0" 1858 | } 1859 | }, 1860 | "delayed-stream": { 1861 | "version": "1.0.0", 1862 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 1863 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 1864 | "dev": true 1865 | }, 1866 | "duplexify": { 1867 | "version": "3.7.1", 1868 | "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.7.1.tgz", 1869 | "integrity": "sha512-07z8uv2wMyS51kKhD1KsdXJg5WQ6t93RneqRxUHnskXVtlYYkLqM0gqStQZ3pj073g687jPCHrqNfCzawLYh5g==", 1870 | "dev": true, 1871 | "requires": { 1872 | "end-of-stream": "^1.0.0", 1873 | "inherits": "^2.0.1", 1874 | "readable-stream": "^2.0.0", 1875 | "stream-shift": "^1.0.0" 1876 | } 1877 | }, 1878 | "ecc-jsbn": { 1879 | "version": "0.1.2", 1880 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 1881 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 1882 | "dev": true, 1883 | "requires": { 1884 | "jsbn": "~0.1.0", 1885 | "safer-buffer": "^2.1.0" 1886 | } 1887 | }, 1888 | "emoji-regex": { 1889 | "version": "7.0.3", 1890 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 1891 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 1892 | "dev": true 1893 | }, 1894 | "end-of-stream": { 1895 | "version": "1.4.4", 1896 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 1897 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 1898 | "dev": true, 1899 | "requires": { 1900 | "once": "^1.4.0" 1901 | } 1902 | }, 1903 | "env-paths": { 1904 | "version": "2.2.1", 1905 | "resolved": "https://registry.npmjs.org/env-paths/-/env-paths-2.2.1.tgz", 1906 | "integrity": "sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==", 1907 | "dev": true 1908 | }, 1909 | "escape-string-regexp": { 1910 | "version": "1.0.5", 1911 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1912 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 1913 | "dev": true 1914 | }, 1915 | "execa": { 1916 | "version": "2.1.0", 1917 | "resolved": "https://registry.npmjs.org/execa/-/execa-2.1.0.tgz", 1918 | "integrity": "sha512-Y/URAVapfbYy2Xp/gb6A0E7iR8xeqOCXsuuaoMn7A5PzrXUK84E1gyiEfq0wQd/GHA6GsoHWwhNq8anb0mleIw==", 1919 | "dev": true, 1920 | "requires": { 1921 | "cross-spawn": "^7.0.0", 1922 | "get-stream": "^5.0.0", 1923 | "is-stream": "^2.0.0", 1924 | "merge-stream": "^2.0.0", 1925 | "npm-run-path": "^3.0.0", 1926 | "onetime": "^5.1.0", 1927 | "p-finally": "^2.0.0", 1928 | "signal-exit": "^3.0.2", 1929 | "strip-final-newline": "^2.0.0" 1930 | } 1931 | }, 1932 | "extend": { 1933 | "version": "3.0.2", 1934 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 1935 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 1936 | "dev": true 1937 | }, 1938 | "extsprintf": { 1939 | "version": "1.3.0", 1940 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 1941 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 1942 | "dev": true 1943 | }, 1944 | "fast-deep-equal": { 1945 | "version": "3.1.3", 1946 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1947 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1948 | "dev": true 1949 | }, 1950 | "fast-json-stable-stringify": { 1951 | "version": "2.1.0", 1952 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1953 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1954 | "dev": true 1955 | }, 1956 | "figgy-pudding": { 1957 | "version": "3.5.2", 1958 | "resolved": "https://registry.npmjs.org/figgy-pudding/-/figgy-pudding-3.5.2.tgz", 1959 | "integrity": "sha512-0btnI/H8f2pavGMN8w40mlSKOfTK2SVJmBfBeVIj3kNw0swwgzyRq0d5TJVOwodFmtvpPeWPN/MCcfuWF0Ezbw==", 1960 | "dev": true 1961 | }, 1962 | "filesize": { 1963 | "version": "4.2.1", 1964 | "resolved": "https://registry.npmjs.org/filesize/-/filesize-4.2.1.tgz", 1965 | "integrity": "sha512-bP82Hi8VRZX/TUBKfE24iiUGsB/sfm2WUrwTQyAzQrhO3V9IhcBBNBXMyzLY5orACxRyYJ3d2HeRVX+eFv4lmA==", 1966 | "dev": true 1967 | }, 1968 | "flush-write-stream": { 1969 | "version": "1.1.1", 1970 | "resolved": "https://registry.npmjs.org/flush-write-stream/-/flush-write-stream-1.1.1.tgz", 1971 | "integrity": "sha512-3Z4XhFZ3992uIq0XOqb9AreonueSYphE6oYbpt5+3u06JWklbsPkNv3ZKkP9Bz/r+1MWCaMoSQ28P85+1Yc77w==", 1972 | "dev": true, 1973 | "requires": { 1974 | "inherits": "^2.0.3", 1975 | "readable-stream": "^2.3.6" 1976 | } 1977 | }, 1978 | "forever-agent": { 1979 | "version": "0.6.1", 1980 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 1981 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 1982 | "dev": true 1983 | }, 1984 | "form-data": { 1985 | "version": "2.3.3", 1986 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 1987 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 1988 | "dev": true, 1989 | "requires": { 1990 | "asynckit": "^0.4.0", 1991 | "combined-stream": "^1.0.6", 1992 | "mime-types": "^2.1.12" 1993 | } 1994 | }, 1995 | "from2": { 1996 | "version": "2.3.0", 1997 | "resolved": "https://registry.npmjs.org/from2/-/from2-2.3.0.tgz", 1998 | "integrity": "sha1-i/tVAr3kpNNs/e6gB/zKIdfjgq8=", 1999 | "dev": true, 2000 | "requires": { 2001 | "inherits": "^2.0.1", 2002 | "readable-stream": "^2.0.0" 2003 | } 2004 | }, 2005 | "fs-minipass": { 2006 | "version": "1.2.7", 2007 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.7.tgz", 2008 | "integrity": "sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA==", 2009 | "dev": true, 2010 | "requires": { 2011 | "minipass": "^2.6.0" 2012 | } 2013 | }, 2014 | "fs-write-stream-atomic": { 2015 | "version": "1.0.10", 2016 | "resolved": "https://registry.npmjs.org/fs-write-stream-atomic/-/fs-write-stream-atomic-1.0.10.tgz", 2017 | "integrity": "sha1-tH31NJPvkR33VzHnCp3tAYnbQMk=", 2018 | "dev": true, 2019 | "requires": { 2020 | "graceful-fs": "^4.1.2", 2021 | "iferr": "^0.1.5", 2022 | "imurmurhash": "^0.1.4", 2023 | "readable-stream": "1 || 2" 2024 | } 2025 | }, 2026 | "fs.realpath": { 2027 | "version": "1.0.0", 2028 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2029 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 2030 | "dev": true 2031 | }, 2032 | "get-stream": { 2033 | "version": "5.2.0", 2034 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", 2035 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", 2036 | "dev": true, 2037 | "requires": { 2038 | "pump": "^3.0.0" 2039 | } 2040 | }, 2041 | "getpass": { 2042 | "version": "0.1.7", 2043 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 2044 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 2045 | "dev": true, 2046 | "requires": { 2047 | "assert-plus": "^1.0.0" 2048 | } 2049 | }, 2050 | "glob": { 2051 | "version": "7.1.6", 2052 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 2053 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 2054 | "dev": true, 2055 | "requires": { 2056 | "fs.realpath": "^1.0.0", 2057 | "inflight": "^1.0.4", 2058 | "inherits": "2", 2059 | "minimatch": "^3.0.4", 2060 | "once": "^1.3.0", 2061 | "path-is-absolute": "^1.0.0" 2062 | } 2063 | }, 2064 | "graceful-fs": { 2065 | "version": "4.2.6", 2066 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.6.tgz", 2067 | "integrity": "sha512-nTnJ528pbqxYanhpDYsi4Rd8MAeaBA67+RZ10CM1m3bTAVFEDcd5AuA4a6W5YkGZ1iNXHzZz8T6TBKLeBuNriQ==", 2068 | "dev": true 2069 | }, 2070 | "har-schema": { 2071 | "version": "2.0.0", 2072 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 2073 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 2074 | "dev": true 2075 | }, 2076 | "har-validator": { 2077 | "version": "5.1.5", 2078 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.5.tgz", 2079 | "integrity": "sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w==", 2080 | "dev": true, 2081 | "requires": { 2082 | "ajv": "^6.12.3", 2083 | "har-schema": "^2.0.0" 2084 | } 2085 | }, 2086 | "has-flag": { 2087 | "version": "3.0.0", 2088 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2089 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 2090 | "dev": true 2091 | }, 2092 | "http-signature": { 2093 | "version": "1.2.0", 2094 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 2095 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 2096 | "dev": true, 2097 | "requires": { 2098 | "assert-plus": "^1.0.0", 2099 | "jsprim": "^1.2.2", 2100 | "sshpk": "^1.7.0" 2101 | } 2102 | }, 2103 | "iferr": { 2104 | "version": "0.1.5", 2105 | "resolved": "https://registry.npmjs.org/iferr/-/iferr-0.1.5.tgz", 2106 | "integrity": "sha1-xg7taebY/bazEEofy8ocGS3FtQE=", 2107 | "dev": true 2108 | }, 2109 | "imurmurhash": { 2110 | "version": "0.1.4", 2111 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2112 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 2113 | "dev": true 2114 | }, 2115 | "inflight": { 2116 | "version": "1.0.6", 2117 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2118 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 2119 | "dev": true, 2120 | "requires": { 2121 | "once": "^1.3.0", 2122 | "wrappy": "1" 2123 | } 2124 | }, 2125 | "inherits": { 2126 | "version": "2.0.4", 2127 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2128 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2129 | "dev": true 2130 | }, 2131 | "is-fullwidth-code-point": { 2132 | "version": "2.0.0", 2133 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2134 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2135 | "dev": true 2136 | }, 2137 | "is-plain-obj": { 2138 | "version": "2.1.0", 2139 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 2140 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 2141 | "dev": true 2142 | }, 2143 | "is-stream": { 2144 | "version": "2.0.0", 2145 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", 2146 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==", 2147 | "dev": true 2148 | }, 2149 | "is-typedarray": { 2150 | "version": "1.0.0", 2151 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 2152 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 2153 | "dev": true 2154 | }, 2155 | "isarray": { 2156 | "version": "1.0.0", 2157 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2158 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 2159 | "dev": true 2160 | }, 2161 | "isexe": { 2162 | "version": "2.0.0", 2163 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2164 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 2165 | "dev": true 2166 | }, 2167 | "isstream": { 2168 | "version": "0.1.2", 2169 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 2170 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", 2171 | "dev": true 2172 | }, 2173 | "jsbn": { 2174 | "version": "0.1.1", 2175 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 2176 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 2177 | "dev": true 2178 | }, 2179 | "json-schema": { 2180 | "version": "0.2.3", 2181 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 2182 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", 2183 | "dev": true 2184 | }, 2185 | "json-schema-traverse": { 2186 | "version": "0.4.1", 2187 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2188 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2189 | "dev": true 2190 | }, 2191 | "json-stringify-safe": { 2192 | "version": "5.0.1", 2193 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 2194 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", 2195 | "dev": true 2196 | }, 2197 | "jsprim": { 2198 | "version": "1.4.1", 2199 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 2200 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 2201 | "dev": true, 2202 | "requires": { 2203 | "assert-plus": "1.0.0", 2204 | "extsprintf": "1.3.0", 2205 | "json-schema": "0.2.3", 2206 | "verror": "1.10.0" 2207 | } 2208 | }, 2209 | "log-symbols": { 2210 | "version": "3.0.0", 2211 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-3.0.0.tgz", 2212 | "integrity": "sha512-dSkNGuI7iG3mfvDzUuYZyvk5dD9ocYCYzNU6CYDE6+Xqd+gwme6Z00NS3dUh8mq/73HaEtT7m6W+yUPtU6BZnQ==", 2213 | "dev": true, 2214 | "requires": { 2215 | "chalk": "^2.4.2" 2216 | } 2217 | }, 2218 | "log-update": { 2219 | "version": "3.4.0", 2220 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-3.4.0.tgz", 2221 | "integrity": "sha512-ILKe88NeMt4gmDvk/eb615U/IVn7K9KWGkoYbdatQ69Z65nj1ZzjM6fHXfcs0Uge+e+EGnMW7DY4T9yko8vWFg==", 2222 | "dev": true, 2223 | "requires": { 2224 | "ansi-escapes": "^3.2.0", 2225 | "cli-cursor": "^2.1.0", 2226 | "wrap-ansi": "^5.0.0" 2227 | } 2228 | }, 2229 | "lru-cache": { 2230 | "version": "5.1.1", 2231 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 2232 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 2233 | "dev": true, 2234 | "requires": { 2235 | "yallist": "^3.0.2" 2236 | } 2237 | }, 2238 | "merge-stream": { 2239 | "version": "2.0.0", 2240 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 2241 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 2242 | "dev": true 2243 | }, 2244 | "mime-db": { 2245 | "version": "1.46.0", 2246 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.46.0.tgz", 2247 | "integrity": "sha512-svXaP8UQRZ5K7or+ZmfNhg2xX3yKDMUzqadsSqi4NCH/KomcH75MAMYAGVlvXn4+b/xOPhS3I2uHKRUzvjY7BQ==", 2248 | "dev": true 2249 | }, 2250 | "mime-types": { 2251 | "version": "2.1.29", 2252 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.29.tgz", 2253 | "integrity": "sha512-Y/jMt/S5sR9OaqteJtslsFZKWOIIqMACsJSiHghlCAyhf7jfVYjKBmLiX8OgpWeW+fjJ2b+Az69aPFPkUOY6xQ==", 2254 | "dev": true, 2255 | "requires": { 2256 | "mime-db": "1.46.0" 2257 | } 2258 | }, 2259 | "mimic-fn": { 2260 | "version": "2.1.0", 2261 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 2262 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 2263 | "dev": true 2264 | }, 2265 | "minimatch": { 2266 | "version": "3.0.4", 2267 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2268 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2269 | "dev": true, 2270 | "requires": { 2271 | "brace-expansion": "^1.1.7" 2272 | } 2273 | }, 2274 | "minimist": { 2275 | "version": "1.2.5", 2276 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 2277 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 2278 | "dev": true 2279 | }, 2280 | "minipass": { 2281 | "version": "2.9.0", 2282 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.9.0.tgz", 2283 | "integrity": "sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg==", 2284 | "dev": true, 2285 | "requires": { 2286 | "safe-buffer": "^5.1.2", 2287 | "yallist": "^3.0.0" 2288 | } 2289 | }, 2290 | "minizlib": { 2291 | "version": "1.3.3", 2292 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.3.3.tgz", 2293 | "integrity": "sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q==", 2294 | "dev": true, 2295 | "requires": { 2296 | "minipass": "^2.9.0" 2297 | } 2298 | }, 2299 | "mississippi": { 2300 | "version": "3.0.0", 2301 | "resolved": "https://registry.npmjs.org/mississippi/-/mississippi-3.0.0.tgz", 2302 | "integrity": "sha512-x471SsVjUtBRtcvd4BzKE9kFC+/2TeWgKCgw0bZcw1b9l2X3QX5vCWgF+KaZaYm87Ss//rHnWryupDrgLvmSkA==", 2303 | "dev": true, 2304 | "requires": { 2305 | "concat-stream": "^1.5.0", 2306 | "duplexify": "^3.4.2", 2307 | "end-of-stream": "^1.1.0", 2308 | "flush-write-stream": "^1.0.0", 2309 | "from2": "^2.1.0", 2310 | "parallel-transform": "^1.1.0", 2311 | "pump": "^3.0.0", 2312 | "pumpify": "^1.3.3", 2313 | "stream-each": "^1.1.0", 2314 | "through2": "^2.0.0" 2315 | } 2316 | }, 2317 | "mkdirp": { 2318 | "version": "0.5.5", 2319 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 2320 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 2321 | "dev": true, 2322 | "requires": { 2323 | "minimist": "^1.2.5" 2324 | } 2325 | }, 2326 | "move-concurrently": { 2327 | "version": "1.0.1", 2328 | "resolved": "https://registry.npmjs.org/move-concurrently/-/move-concurrently-1.0.1.tgz", 2329 | "integrity": "sha1-viwAX9oy4LKa8fBdfEszIUxwH5I=", 2330 | "dev": true, 2331 | "requires": { 2332 | "aproba": "^1.1.1", 2333 | "copy-concurrently": "^1.0.0", 2334 | "fs-write-stream-atomic": "^1.0.8", 2335 | "mkdirp": "^0.5.1", 2336 | "rimraf": "^2.5.4", 2337 | "run-queue": "^1.0.3" 2338 | } 2339 | }, 2340 | "ms": { 2341 | "version": "2.1.3", 2342 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2343 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2344 | "dev": true 2345 | }, 2346 | "npm-run-path": { 2347 | "version": "3.1.0", 2348 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-3.1.0.tgz", 2349 | "integrity": "sha512-Dbl4A/VfiVGLgQv29URL9xshU8XDY1GeLy+fsaZ1AA8JDSfjvr5P5+pzRbWqRSBxk6/DW7MIh8lTM/PaGnP2kg==", 2350 | "dev": true, 2351 | "requires": { 2352 | "path-key": "^3.0.0" 2353 | } 2354 | }, 2355 | "oauth-sign": { 2356 | "version": "0.9.0", 2357 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 2358 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", 2359 | "dev": true 2360 | }, 2361 | "once": { 2362 | "version": "1.4.0", 2363 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2364 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2365 | "dev": true, 2366 | "requires": { 2367 | "wrappy": "1" 2368 | } 2369 | }, 2370 | "onetime": { 2371 | "version": "5.1.2", 2372 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 2373 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 2374 | "dev": true, 2375 | "requires": { 2376 | "mimic-fn": "^2.1.0" 2377 | } 2378 | }, 2379 | "p-finally": { 2380 | "version": "2.0.1", 2381 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-2.0.1.tgz", 2382 | "integrity": "sha512-vpm09aKwq6H9phqRQzecoDpD8TmVyGw70qmWlyq5onxY7tqyTTFVvxMykxQSQKILBSFlbXpypIw2T1Ml7+DDtw==", 2383 | "dev": true 2384 | }, 2385 | "parallel-transform": { 2386 | "version": "1.2.0", 2387 | "resolved": "https://registry.npmjs.org/parallel-transform/-/parallel-transform-1.2.0.tgz", 2388 | "integrity": "sha512-P2vSmIu38uIlvdcU7fDkyrxj33gTUy/ABO5ZUbGowxNCopBq/OoD42bP4UmMrJoPyk4Uqf0mu3mtWBhHCZD8yg==", 2389 | "dev": true, 2390 | "requires": { 2391 | "cyclist": "^1.0.1", 2392 | "inherits": "^2.0.3", 2393 | "readable-stream": "^2.1.5" 2394 | } 2395 | }, 2396 | "path-is-absolute": { 2397 | "version": "1.0.1", 2398 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2399 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2400 | "dev": true 2401 | }, 2402 | "path-key": { 2403 | "version": "3.1.1", 2404 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2405 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2406 | "dev": true 2407 | }, 2408 | "performance-now": { 2409 | "version": "2.1.0", 2410 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 2411 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", 2412 | "dev": true 2413 | }, 2414 | "process-nextick-args": { 2415 | "version": "2.0.1", 2416 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2417 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 2418 | "dev": true 2419 | }, 2420 | "promise-inflight": { 2421 | "version": "1.0.1", 2422 | "resolved": "https://registry.npmjs.org/promise-inflight/-/promise-inflight-1.0.1.tgz", 2423 | "integrity": "sha1-mEcocL8igTL8vdhoEputEsPAKeM=", 2424 | "dev": true 2425 | }, 2426 | "psl": { 2427 | "version": "1.8.0", 2428 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz", 2429 | "integrity": "sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==", 2430 | "dev": true 2431 | }, 2432 | "pump": { 2433 | "version": "3.0.0", 2434 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 2435 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 2436 | "dev": true, 2437 | "requires": { 2438 | "end-of-stream": "^1.1.0", 2439 | "once": "^1.3.1" 2440 | } 2441 | }, 2442 | "pumpify": { 2443 | "version": "1.5.1", 2444 | "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-1.5.1.tgz", 2445 | "integrity": "sha512-oClZI37HvuUJJxSKKrC17bZ9Cu0ZYhEAGPsPUy9KlMUmv9dKX2o77RUmq7f3XjIxbwyGwYzbzQ1L2Ks8sIradQ==", 2446 | "dev": true, 2447 | "requires": { 2448 | "duplexify": "^3.6.0", 2449 | "inherits": "^2.0.3", 2450 | "pump": "^2.0.0" 2451 | }, 2452 | "dependencies": { 2453 | "pump": { 2454 | "version": "2.0.1", 2455 | "resolved": "https://registry.npmjs.org/pump/-/pump-2.0.1.tgz", 2456 | "integrity": "sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==", 2457 | "dev": true, 2458 | "requires": { 2459 | "end-of-stream": "^1.1.0", 2460 | "once": "^1.3.1" 2461 | } 2462 | } 2463 | } 2464 | }, 2465 | "punycode": { 2466 | "version": "2.1.1", 2467 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2468 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2469 | "dev": true 2470 | }, 2471 | "purescript": { 2472 | "version": "0.14.0", 2473 | "resolved": "https://registry.npmjs.org/purescript/-/purescript-0.14.0.tgz", 2474 | "integrity": "sha512-iTA1k8mwxHqrJp/K296g6omVfve5RCjnB5D6Up93PVtZdP66mCIqlOYC4hrLBHg2hgkk27xePDt5NUXKvH4ApQ==", 2475 | "dev": true, 2476 | "requires": { 2477 | "purescript-installer": "^0.2.0" 2478 | } 2479 | }, 2480 | "purescript-installer": { 2481 | "version": "0.2.5", 2482 | "resolved": "https://registry.npmjs.org/purescript-installer/-/purescript-installer-0.2.5.tgz", 2483 | "integrity": "sha512-fQAWWP5a7scuchXecjpU4r4KEgSPuS6bBnaP01k9f71qqD28HaJ2m4PXHFkhkR4oATAxTPIGCtmTwtVoiBOHog==", 2484 | "dev": true, 2485 | "requires": { 2486 | "arch": "^2.1.1", 2487 | "byline": "^5.0.0", 2488 | "cacache": "^11.3.2", 2489 | "chalk": "^2.4.2", 2490 | "env-paths": "^2.2.0", 2491 | "execa": "^2.0.3", 2492 | "filesize": "^4.1.2", 2493 | "is-plain-obj": "^2.0.0", 2494 | "log-symbols": "^3.0.0", 2495 | "log-update": "^3.2.0", 2496 | "minimist": "^1.2.0", 2497 | "mkdirp": "^0.5.1", 2498 | "ms": "^2.1.2", 2499 | "once": "^1.4.0", 2500 | "pump": "^3.0.0", 2501 | "request": "^2.88.0", 2502 | "rimraf": "^2.6.3", 2503 | "tar": "^4.4.6", 2504 | "which": "^1.3.1", 2505 | "zen-observable": "^0.8.14" 2506 | } 2507 | }, 2508 | "purty": { 2509 | "version": "7.0.0", 2510 | "resolved": "https://registry.npmjs.org/purty/-/purty-7.0.0.tgz", 2511 | "integrity": "sha512-gHHghPEjRY39GUJ8KnOMRfPArJILGCXwEhX6BmEdNiLgZuCjLLBLyawGiKFjYMfy8H5Dsk5NbgwIGslrPrernA==", 2512 | "dev": true 2513 | }, 2514 | "qs": { 2515 | "version": "6.5.2", 2516 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 2517 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", 2518 | "dev": true 2519 | }, 2520 | "readable-stream": { 2521 | "version": "2.3.7", 2522 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 2523 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 2524 | "dev": true, 2525 | "requires": { 2526 | "core-util-is": "~1.0.0", 2527 | "inherits": "~2.0.3", 2528 | "isarray": "~1.0.0", 2529 | "process-nextick-args": "~2.0.0", 2530 | "safe-buffer": "~5.1.1", 2531 | "string_decoder": "~1.1.1", 2532 | "util-deprecate": "~1.0.1" 2533 | } 2534 | }, 2535 | "request": { 2536 | "version": "2.88.2", 2537 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz", 2538 | "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==", 2539 | "dev": true, 2540 | "requires": { 2541 | "aws-sign2": "~0.7.0", 2542 | "aws4": "^1.8.0", 2543 | "caseless": "~0.12.0", 2544 | "combined-stream": "~1.0.6", 2545 | "extend": "~3.0.2", 2546 | "forever-agent": "~0.6.1", 2547 | "form-data": "~2.3.2", 2548 | "har-validator": "~5.1.3", 2549 | "http-signature": "~1.2.0", 2550 | "is-typedarray": "~1.0.0", 2551 | "isstream": "~0.1.2", 2552 | "json-stringify-safe": "~5.0.1", 2553 | "mime-types": "~2.1.19", 2554 | "oauth-sign": "~0.9.0", 2555 | "performance-now": "^2.1.0", 2556 | "qs": "~6.5.2", 2557 | "safe-buffer": "^5.1.2", 2558 | "tough-cookie": "~2.5.0", 2559 | "tunnel-agent": "^0.6.0", 2560 | "uuid": "^3.3.2" 2561 | } 2562 | }, 2563 | "restore-cursor": { 2564 | "version": "2.0.0", 2565 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 2566 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 2567 | "dev": true, 2568 | "requires": { 2569 | "onetime": "^2.0.0", 2570 | "signal-exit": "^3.0.2" 2571 | }, 2572 | "dependencies": { 2573 | "mimic-fn": { 2574 | "version": "1.2.0", 2575 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 2576 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", 2577 | "dev": true 2578 | }, 2579 | "onetime": { 2580 | "version": "2.0.1", 2581 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 2582 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 2583 | "dev": true, 2584 | "requires": { 2585 | "mimic-fn": "^1.0.0" 2586 | } 2587 | } 2588 | } 2589 | }, 2590 | "rimraf": { 2591 | "version": "2.7.1", 2592 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 2593 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 2594 | "dev": true, 2595 | "requires": { 2596 | "glob": "^7.1.3" 2597 | } 2598 | }, 2599 | "run-queue": { 2600 | "version": "1.0.3", 2601 | "resolved": "https://registry.npmjs.org/run-queue/-/run-queue-1.0.3.tgz", 2602 | "integrity": "sha1-6Eg5bwV9Ij8kOGkkYY4laUFh7Ec=", 2603 | "dev": true, 2604 | "requires": { 2605 | "aproba": "^1.1.1" 2606 | } 2607 | }, 2608 | "safe-buffer": { 2609 | "version": "5.1.2", 2610 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2611 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2612 | "dev": true 2613 | }, 2614 | "safer-buffer": { 2615 | "version": "2.1.2", 2616 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2617 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 2618 | "dev": true 2619 | }, 2620 | "shebang-command": { 2621 | "version": "2.0.0", 2622 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2623 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2624 | "dev": true, 2625 | "requires": { 2626 | "shebang-regex": "^3.0.0" 2627 | } 2628 | }, 2629 | "shebang-regex": { 2630 | "version": "3.0.0", 2631 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2632 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2633 | "dev": true 2634 | }, 2635 | "signal-exit": { 2636 | "version": "3.0.3", 2637 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 2638 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 2639 | "dev": true 2640 | }, 2641 | "spago": { 2642 | "version": "0.19.1", 2643 | "resolved": "https://registry.npmjs.org/spago/-/spago-0.19.1.tgz", 2644 | "integrity": "sha512-OD/yopJZ9Ub+XsFtayDeLAWLT4kLdMxosJEyyp8W5OkyJVVSbCrvYacsO7iq3lSuHJmmNny/TEZdyb7uSyupng==", 2645 | "dev": true, 2646 | "requires": { 2647 | "request": "^2.88.0", 2648 | "tar": "^4.4.8" 2649 | } 2650 | }, 2651 | "sshpk": { 2652 | "version": "1.16.1", 2653 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", 2654 | "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", 2655 | "dev": true, 2656 | "requires": { 2657 | "asn1": "~0.2.3", 2658 | "assert-plus": "^1.0.0", 2659 | "bcrypt-pbkdf": "^1.0.0", 2660 | "dashdash": "^1.12.0", 2661 | "ecc-jsbn": "~0.1.1", 2662 | "getpass": "^0.1.1", 2663 | "jsbn": "~0.1.0", 2664 | "safer-buffer": "^2.0.2", 2665 | "tweetnacl": "~0.14.0" 2666 | } 2667 | }, 2668 | "ssri": { 2669 | "version": "6.0.1", 2670 | "resolved": "https://registry.npmjs.org/ssri/-/ssri-6.0.1.tgz", 2671 | "integrity": "sha512-3Wge10hNcT1Kur4PDFwEieXSCMCJs/7WvSACcrMYrNp+b8kDL1/0wJch5Ni2WrtwEa2IO8OsVfeKIciKCDx/QA==", 2672 | "dev": true, 2673 | "requires": { 2674 | "figgy-pudding": "^3.5.1" 2675 | } 2676 | }, 2677 | "stream-each": { 2678 | "version": "1.2.3", 2679 | "resolved": "https://registry.npmjs.org/stream-each/-/stream-each-1.2.3.tgz", 2680 | "integrity": "sha512-vlMC2f8I2u/bZGqkdfLQW/13Zihpej/7PmSiMQsbYddxuTsJp8vRe2x2FvVExZg7FaOds43ROAuFJwPR4MTZLw==", 2681 | "dev": true, 2682 | "requires": { 2683 | "end-of-stream": "^1.1.0", 2684 | "stream-shift": "^1.0.0" 2685 | } 2686 | }, 2687 | "stream-shift": { 2688 | "version": "1.0.1", 2689 | "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.1.tgz", 2690 | "integrity": "sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ==", 2691 | "dev": true 2692 | }, 2693 | "string_decoder": { 2694 | "version": "1.1.1", 2695 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2696 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2697 | "dev": true, 2698 | "requires": { 2699 | "safe-buffer": "~5.1.0" 2700 | } 2701 | }, 2702 | "string-width": { 2703 | "version": "3.1.0", 2704 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2705 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2706 | "dev": true, 2707 | "requires": { 2708 | "emoji-regex": "^7.0.1", 2709 | "is-fullwidth-code-point": "^2.0.0", 2710 | "strip-ansi": "^5.1.0" 2711 | } 2712 | }, 2713 | "strip-ansi": { 2714 | "version": "5.2.0", 2715 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2716 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2717 | "dev": true, 2718 | "requires": { 2719 | "ansi-regex": "^4.1.0" 2720 | } 2721 | }, 2722 | "strip-final-newline": { 2723 | "version": "2.0.0", 2724 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 2725 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 2726 | "dev": true 2727 | }, 2728 | "supports-color": { 2729 | "version": "5.5.0", 2730 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2731 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2732 | "dev": true, 2733 | "requires": { 2734 | "has-flag": "^3.0.0" 2735 | } 2736 | }, 2737 | "tar": { 2738 | "version": "4.4.13", 2739 | "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.13.tgz", 2740 | "integrity": "sha512-w2VwSrBoHa5BsSyH+KxEqeQBAllHhccyMFVHtGtdMpF4W7IRWfZjFiQceJPChOeTsSDVUpER2T8FA93pr0L+QA==", 2741 | "dev": true, 2742 | "requires": { 2743 | "chownr": "^1.1.1", 2744 | "fs-minipass": "^1.2.5", 2745 | "minipass": "^2.8.6", 2746 | "minizlib": "^1.2.1", 2747 | "mkdirp": "^0.5.0", 2748 | "safe-buffer": "^5.1.2", 2749 | "yallist": "^3.0.3" 2750 | } 2751 | }, 2752 | "through2": { 2753 | "version": "2.0.5", 2754 | "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", 2755 | "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==", 2756 | "dev": true, 2757 | "requires": { 2758 | "readable-stream": "~2.3.6", 2759 | "xtend": "~4.0.1" 2760 | } 2761 | }, 2762 | "tough-cookie": { 2763 | "version": "2.5.0", 2764 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", 2765 | "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", 2766 | "dev": true, 2767 | "requires": { 2768 | "psl": "^1.1.28", 2769 | "punycode": "^2.1.1" 2770 | } 2771 | }, 2772 | "tunnel-agent": { 2773 | "version": "0.6.0", 2774 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 2775 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 2776 | "dev": true, 2777 | "requires": { 2778 | "safe-buffer": "^5.0.1" 2779 | } 2780 | }, 2781 | "tweetnacl": { 2782 | "version": "0.14.5", 2783 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 2784 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 2785 | "dev": true 2786 | }, 2787 | "typedarray": { 2788 | "version": "0.0.6", 2789 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 2790 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", 2791 | "dev": true 2792 | }, 2793 | "unique-filename": { 2794 | "version": "1.1.1", 2795 | "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-1.1.1.tgz", 2796 | "integrity": "sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ==", 2797 | "dev": true, 2798 | "requires": { 2799 | "unique-slug": "^2.0.0" 2800 | } 2801 | }, 2802 | "unique-slug": { 2803 | "version": "2.0.2", 2804 | "resolved": "https://registry.npmjs.org/unique-slug/-/unique-slug-2.0.2.tgz", 2805 | "integrity": "sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w==", 2806 | "dev": true, 2807 | "requires": { 2808 | "imurmurhash": "^0.1.4" 2809 | } 2810 | }, 2811 | "uri-js": { 2812 | "version": "4.4.1", 2813 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2814 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2815 | "dev": true, 2816 | "requires": { 2817 | "punycode": "^2.1.0" 2818 | } 2819 | }, 2820 | "util-deprecate": { 2821 | "version": "1.0.2", 2822 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2823 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2824 | "dev": true 2825 | }, 2826 | "uuid": { 2827 | "version": "3.4.0", 2828 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 2829 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", 2830 | "dev": true 2831 | }, 2832 | "verror": { 2833 | "version": "1.10.0", 2834 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 2835 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 2836 | "dev": true, 2837 | "requires": { 2838 | "assert-plus": "^1.0.0", 2839 | "core-util-is": "1.0.2", 2840 | "extsprintf": "^1.2.0" 2841 | } 2842 | }, 2843 | "which": { 2844 | "version": "1.3.1", 2845 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2846 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2847 | "dev": true, 2848 | "requires": { 2849 | "isexe": "^2.0.0" 2850 | } 2851 | }, 2852 | "wrap-ansi": { 2853 | "version": "5.1.0", 2854 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 2855 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 2856 | "dev": true, 2857 | "requires": { 2858 | "ansi-styles": "^3.2.0", 2859 | "string-width": "^3.0.0", 2860 | "strip-ansi": "^5.0.0" 2861 | } 2862 | }, 2863 | "wrappy": { 2864 | "version": "1.0.2", 2865 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2866 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2867 | "dev": true 2868 | }, 2869 | "xtend": { 2870 | "version": "4.0.2", 2871 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 2872 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 2873 | "dev": true 2874 | }, 2875 | "y18n": { 2876 | "version": "4.0.1", 2877 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.1.tgz", 2878 | "integrity": "sha512-wNcy4NvjMYL8gogWWYAO7ZFWFfHcbdbE57tZO8e4cbpj8tfUcwrwqSl3ad8HxpYWCdXcJUCeKKZS62Av1affwQ==", 2879 | "dev": true 2880 | }, 2881 | "yallist": { 2882 | "version": "3.1.1", 2883 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 2884 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 2885 | "dev": true 2886 | }, 2887 | "zen-observable": { 2888 | "version": "0.8.15", 2889 | "resolved": "https://registry.npmjs.org/zen-observable/-/zen-observable-0.8.15.tgz", 2890 | "integrity": "sha512-PQ2PC7R9rslx84ndNBZB/Dkv8V8fZEpk83RLgXtYd0fwUgEjseMn1Dgajh2x6S8QbZAFa9p2qVCEuYZNgve0dQ==", 2891 | "dev": true 2892 | } 2893 | } 2894 | } 2895 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "record-studio", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "keywords": [], 10 | "author": "", 11 | "license": "MIT-0", 12 | "devDependencies": { 13 | "purescript": "^0.14.0", 14 | "purty": "^7.0.0", 15 | "spago": "^0.19.1" 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /packages.dhall: -------------------------------------------------------------------------------- 1 | let upstream = 2 | https://github.com/purescript/package-sets/releases/download/psc-0.15.0-20220513/packages.dhall sha256:1ed784f37ae6131d99acd542d058d5ce39954ccaacc3adba5cc7cf1549d2bffa 3 | 4 | in upstream 5 | -------------------------------------------------------------------------------- /spago.dhall: -------------------------------------------------------------------------------- 1 | { name = "record-studio" 2 | , dependencies = 3 | [ "heterogeneous" 4 | , "lists" 5 | , "prelude" 6 | , "record" 7 | , "typelevel-prelude" 8 | , "unsafe-coerce" 9 | ] 10 | , packages = ./packages.dhall 11 | , sources = [ "src/**/*.purs" ] 12 | , license = "MIT-0" 13 | , repository = "https://github.com/rowtype-yoga/purescript-record-studio.git" 14 | } 15 | -------------------------------------------------------------------------------- /src/Record/Studio.purs: -------------------------------------------------------------------------------- 1 | module Record.Studio 2 | ( module Record.Studio.Sequence 3 | , module Record.Studio.Map 4 | , module Record.Studio.MapKind 5 | , module Record.Studio.MapUniform 6 | , module Record.Studio.Merge 7 | , module Record.Studio.Keys 8 | , module Record.Studio.Shrink 9 | , module Record.Studio.SameKeys 10 | , module Record.Studio.SingletonRecord 11 | ) where 12 | 13 | import Record.Studio.Sequence (SequenceRecord(..), sequenceRecord) 14 | import Record.Studio.Map (MapRecord(..), mapRecord) 15 | import Record.Studio.MapKind (MapRecordKind(..), mapRecordKind) 16 | import Record.Studio.MapUniform (class MapUniformRecord, mapUniformRecord, mapUniformRecordBuilder) 17 | import Record.Studio.Keys (class Keys, keys, recordKeys) 18 | import Record.Studio.Shrink (shrink) 19 | import Record.Studio.Merge (mergeFlipped, (//)) 20 | import Record.Studio.SameKeys (class SameKeys) 21 | import Record.Studio.SingletonRecord (class SingletonRecord, key, value) 22 | -------------------------------------------------------------------------------- /src/Record/Studio/Keys.purs: -------------------------------------------------------------------------------- 1 | module Record.Studio.Keys (class Keys, keys, class KeysRL, keysImpl, recordKeys) where 2 | 3 | import Prelude 4 | 5 | import Data.List (List, (:)) 6 | import Data.List as List 7 | import Data.Symbol (class IsSymbol, reflectSymbol) 8 | import Prim.RowList as RL 9 | import Type.Proxy (Proxy(..)) 10 | 11 | class Keys (r :: Row Type) where 12 | keys :: (Proxy r) -> Array String 13 | 14 | instance (RL.RowToList r rl, KeysRL rl) => Keys r where 15 | keys _ = List.toUnfoldable $ keysImpl (Proxy :: _ rl) 16 | 17 | class KeysRL (xs :: RL.RowList Type) where 18 | keysImpl :: Proxy xs -> List String 19 | 20 | instance KeysRL RL.Nil where 21 | keysImpl _ = mempty 22 | 23 | instance (IsSymbol name, KeysRL tail) => KeysRL (RL.Cons name ty tail) where 24 | keysImpl _ = first : rest 25 | where 26 | first = reflectSymbol (Proxy :: _ name) 27 | rest = keysImpl (Proxy :: _ tail) 28 | 29 | recordKeys :: forall r. Keys r => { | r } -> Array String 30 | recordKeys _ = keys (Proxy :: _ r) 31 | -------------------------------------------------------------------------------- /src/Record/Studio/Map.purs: -------------------------------------------------------------------------------- 1 | module Record.Studio.Map where 2 | 3 | import Prelude 4 | import Data.Symbol (class IsSymbol) 5 | import Heterogeneous.Folding (class FoldingWithIndex, class FoldlRecord, class HFoldlWithIndex, hfoldlWithIndex) 6 | import Prim.Row as Row 7 | import Prim.RowList (class RowToList) 8 | import Record.Builder (Builder) 9 | import Record.Builder as Builder 10 | import Type.Proxy (Proxy) 11 | 12 | -- Helper for type inference 13 | data MapRecord a b = MapRecord (a -> b) 14 | 15 | -- Matches if the type of the current field in the record is a and therefore needs to be mapped. 16 | instance 17 | ( IsSymbol sym 18 | , Row.Lacks sym rb 19 | , Row.Cons sym b rb rc 20 | ) => 21 | FoldingWithIndex 22 | (MapRecord a b) 23 | (Proxy sym) 24 | (Builder { | ra } { | rb }) 25 | a 26 | (Builder { | ra } { | rc }) where 27 | foldingWithIndex (MapRecord f) prop rin a = (rin >>> Builder.insert prop (f a)) 28 | 29 | -- Matches if the type of the current field in the record is another record and therefore needs to be recursed. 30 | else instance 31 | ( IsSymbol sym 32 | , Row.Lacks sym rb 33 | , RowToList x xRL 34 | , Row.Cons sym { | y } rb rc 35 | , FoldlRecord 36 | (MapRecord a b) 37 | (Builder (Record ()) (Record ())) 38 | xRL 39 | x 40 | (Builder (Record ()) (Record y)) 41 | ) => 42 | FoldingWithIndex 43 | (MapRecord a b) 44 | (Proxy sym) 45 | (Builder { | ra } { | rb }) 46 | { | x } 47 | (Builder { | ra } { | rc }) where 48 | foldingWithIndex (MapRecord f) prop rin x = (rin >>> Builder.insert prop fx) 49 | where 50 | fx = mapRecord f x 51 | 52 | -- Matches if the type of the current field in the record is any other type independent of mapping. 53 | else instance 54 | ( IsSymbol sym 55 | , Row.Lacks sym rb 56 | , Row.Cons sym x rb rc 57 | ) => 58 | FoldingWithIndex 59 | (MapRecord a b) 60 | (Proxy sym) 61 | (Builder { | ra } { | rb }) 62 | x 63 | (Builder { | ra } { | rc }) where 64 | foldingWithIndex _ prop rin x = (rin >>> Builder.insert prop x) 65 | 66 | -- | Recursively maps a record using a function f. 67 | -- | ```purescript 68 | -- | let 69 | -- | f :: Int -> String 70 | -- | f i = show (i + 1) 71 | -- | mapRecord f { a : { b : 10, c : { d: 20, e : Just "hello" }}, f : 30 } 72 | -- | -- { a : { b : "11", c : { d: "21", e : Just "hello" }, f : "31" } 73 | -- | ``` 74 | mapRecord 75 | :: forall a b rin rout 76 | . HFoldlWithIndex (MapRecord a b) (Builder {} {}) { | rin } (Builder {} { | rout }) 77 | => (a -> b) 78 | -> { | rin } 79 | -> { | rout } 80 | mapRecord f = 81 | (flip Builder.build {}) 82 | <<< hfoldlWithIndex (MapRecord f :: MapRecord a b) (identity :: Builder {} {}) 83 | -------------------------------------------------------------------------------- /src/Record/Studio/MapKind.purs: -------------------------------------------------------------------------------- 1 | module Record.Studio.MapKind where 2 | 3 | import Prelude 4 | import Data.Symbol (class IsSymbol) 5 | import Heterogeneous.Folding (class FoldingWithIndex, class FoldlRecord, class HFoldlWithIndex, hfoldlWithIndex) 6 | import Prim.Row as Row 7 | import Prim.RowList (class RowToList) 8 | import Record.Builder (Builder) 9 | import Record.Builder as Builder 10 | import Type.Proxy (Proxy) 11 | 12 | -- Helper for type inference 13 | data MapRecordKind :: forall k. (k -> Type) -> (k -> Type) -> Type 14 | data MapRecordKind f g = MapRecordKind (f ~> g) 15 | 16 | -- Matches if the type of the current field in the record is f a and therefore needs to be naturally transformed. 17 | instance 18 | ( IsSymbol sym 19 | , Row.Lacks sym rb 20 | , Row.Cons sym (g a) rb rc 21 | ) => 22 | FoldingWithIndex 23 | (MapRecordKind f g) 24 | (Proxy sym) 25 | (Builder { | ra } { | rb }) 26 | (f a) 27 | (Builder { | ra } { | rc }) where 28 | foldingWithIndex (MapRecordKind nt) prop rin fa = (rin >>> Builder.insert prop (nt fa)) 29 | 30 | -- Matches if the type of the current field in the record is another record and therefore needs to be recursed. 31 | else instance 32 | ( IsSymbol sym 33 | , Row.Lacks sym rb 34 | , RowToList x xRL 35 | , Row.Cons sym { | y } rb rc 36 | , FoldlRecord 37 | (MapRecordKind f g) 38 | (Builder (Record ()) (Record ())) 39 | xRL 40 | x 41 | (Builder (Record ()) (Record y)) 42 | ) => 43 | FoldingWithIndex 44 | (MapRecordKind f g) 45 | (Proxy sym) 46 | (Builder { | ra } { | rb }) 47 | { | x } 48 | (Builder { | ra } { | rc }) where 49 | foldingWithIndex (MapRecordKind nt) prop rin x = (rin >>> Builder.insert prop fx) 50 | where 51 | fx = mapRecordKind nt x 52 | 53 | -- Matches if the type of the current field in the record is any other type independent of the natural transformation. 54 | else instance 55 | ( IsSymbol sym 56 | , Row.Lacks sym rb 57 | , Row.Cons sym x rb rc 58 | ) => 59 | FoldingWithIndex 60 | (MapRecordKind f g) 61 | (Proxy sym) 62 | (Builder { | ra } { | rb }) 63 | x 64 | (Builder { | ra } { | rc }) where 65 | foldingWithIndex _ prop rin x = (rin >>> Builder.insert prop x) 66 | 67 | -- | Recursively mapK a record using a natural transformation. E.g. 68 | -- | ```purescript 69 | -- | let 70 | -- | nt :: Either String ~> Maybe 71 | -- | nt = hush 72 | -- | mapRecordKind { a : { b : { c : { d: Right 10, e : Left "hello" }, f : Right true } 73 | -- | -- Just { a : { b : { c : { d: Just 10, e : Nothing }, f : Just true } 74 | -- | ``` 75 | mapRecordKind 76 | :: forall f g rin rout 77 | . HFoldlWithIndex (MapRecordKind f g) (Builder {} {}) { | rin } (Builder {} { | rout }) 78 | => (f ~> g) 79 | -> { | rin } 80 | -> { | rout } 81 | mapRecordKind nt = 82 | (flip Builder.build {}) 83 | <<< hfoldlWithIndex (MapRecordKind nt :: MapRecordKind f g) (identity :: Builder {} {}) 84 | -------------------------------------------------------------------------------- /src/Record/Studio/MapUniform.purs: -------------------------------------------------------------------------------- 1 | module Record.Studio.MapUniform where 2 | 3 | import Prelude 4 | 5 | import Data.Symbol (class IsSymbol) 6 | import Prim.Row as Row 7 | import Prim.RowList (class RowToList, RowList) 8 | import Prim.RowList as RL 9 | import Record as R 10 | import Record.Builder (Builder) 11 | import Record.Builder as Builder 12 | import Type.Proxy (Proxy(..)) 13 | 14 | mapUniformRecord 15 | :: forall row xs a b row' 16 | . RowToList row xs 17 | => MapUniformRecord xs row a b () row' 18 | => (a -> b) 19 | -> Record row 20 | -> Record row' 21 | mapUniformRecord fn = Builder.buildFromScratch 22 | <<< mapUniformRecordBuilder (Proxy :: Proxy xs) fn 23 | 24 | class 25 | MapUniformRecord (xs :: RowList Type) (row :: Row Type) a b (from :: Row Type) (to :: Row Type) 26 | | xs -> row a b from to where 27 | mapUniformRecordBuilder :: Proxy xs -> (a -> b) -> Record row -> Builder { | from } { | to } 28 | 29 | -- Start the recursion 30 | instance MapUniformRecord RL.Nil row a b () () where 31 | mapUniformRecordBuilder _ _ _ = identity 32 | 33 | instance 34 | ( IsSymbol name 35 | , Row.Cons name a rest row 36 | , Row.Lacks name from' 37 | , Row.Cons name b from' to 38 | , MapUniformRecord tail row a b from from' 39 | ) => 40 | MapUniformRecord (RL.Cons name a tail) row a b from to where 41 | mapUniformRecordBuilder _ fn r = first <<< rest 42 | where 43 | first = Builder.insert nameP value 44 | rest = mapUniformRecordBuilder tailP fn r 45 | value = fn (R.get nameP r) 46 | nameP = Proxy :: Proxy name 47 | tailP = Proxy :: Proxy tail 48 | -------------------------------------------------------------------------------- /src/Record/Studio/Merge.purs: -------------------------------------------------------------------------------- 1 | module Record.Studio.Merge where 2 | 3 | import Prelude 4 | 5 | import Prim.Row (class Nub, class Union) 6 | import Record (merge) 7 | 8 | -- | Like `merge` but with its arguments flipped. I.e. merges two records with the seconds record's labels taking precedence in the 9 | -- | case of overlaps. 10 | -- | 11 | -- | For example: 12 | -- | 13 | -- | ```purescript 14 | -- | mergeFlipped { x: 1, y: "y" } { y: 2, z: true } 15 | -- | = { x: 1, y: 2, z: true } 16 | -- | ``` 17 | mergeFlipped 18 | :: forall r1 r2 r3 r4 19 | . Union r1 r2 r3 20 | => Nub r3 r4 21 | => Record r2 22 | -> Record r1 23 | -> Record r4 24 | mergeFlipped = flip merge 25 | 26 | -- | `record1 // record2` is equivalent to JS's 27 | -- | `{ ...record1, ...record2 }` 28 | infixr 1 mergeFlipped as // 29 | -------------------------------------------------------------------------------- /src/Record/Studio/SameKeys.purs: -------------------------------------------------------------------------------- 1 | module Record.Studio.SameKeys (class SameKeys, class SameKeysRL) where 2 | 3 | import Data.Symbol (class IsSymbol) 4 | import Prim.Row (class Lacks) 5 | import Prim.RowList (class RowToList) 6 | import Prim.RowList as RL 7 | import Prim.TypeError (class Fail, Beside, Quote, Text) 8 | import Type.RowList (class ListToRow) 9 | 10 | class SameKeys (r1 :: Row Type) (r2 :: Row Type) 11 | 12 | instance (RowToList r1 rl1, RowToList r2 rl2, SameKeysRL rl1 rl2) => SameKeys r1 r2 13 | 14 | class SameKeysRL (xs :: RL.RowList Type) (ys :: RL.RowList Type) 15 | 16 | instance SameKeysRL RL.Nil RL.Nil 17 | instance 18 | ( IsSymbol name 19 | , SameKeysRL tail1 tail2 20 | ) => 21 | SameKeysRL (RL.Cons name ty1 tail1) (RL.Cons name ty2 tail2) 22 | else instance 23 | ( ListToRow RL.Nil r 24 | , Fail (Beside (Text "The key ") (Beside (Quote name) (Text " is missing from the second record"))) 25 | ) => 26 | SameKeysRL (RL.Cons name ty tail) RL.Nil 27 | else instance 28 | ( ListToRow RL.Nil r 29 | , Fail (Beside (Text "The key ") (Beside (Quote name) (Text " is missing from the first record"))) 30 | ) => 31 | SameKeysRL RL.Nil (RL.Cons name ty tail) 32 | else instance 33 | ( ListToRow (RL.Cons name2 ty1 tail1) r 34 | , Lacks name1 r 35 | , Fail (Beside (Text "The key ") (Beside (Quote name1) (Text " is missing from the second record"))) 36 | ) => 37 | SameKeysRL (RL.Cons name1 ty1 tail1) (RL.Cons name2 ty2 tail2) 38 | else instance 39 | ( ListToRow (RL.Cons name1 ty1 tail1) r 40 | , Lacks name2 r 41 | , Fail (Beside (Text "The key ") (Beside (Quote name2) (Text " is missing from the first record"))) 42 | ) => 43 | SameKeysRL (RL.Cons name1 ty1 tail1) (RL.Cons name2 ty2 tail2) 44 | -------------------------------------------------------------------------------- /src/Record/Studio/Sequence.purs: -------------------------------------------------------------------------------- 1 | module Record.Studio.Sequence where 2 | 3 | import Prelude 4 | 5 | import Data.Symbol (class IsSymbol) 6 | import Heterogeneous.Folding (class FoldingWithIndex, class FoldlRecord, class HFoldlWithIndex, hfoldlWithIndex) 7 | import Prim.Row as Row 8 | import Prim.RowList (class RowToList) 9 | import Record.Builder (Builder) 10 | import Record.Builder as Builder 11 | import Type.Proxy (Proxy) 12 | 13 | -- Helper for type inference 14 | data SequenceRecord (f :: Type -> Type) = SequenceRecord 15 | 16 | -- Matches if the type of the current field in the record is f a and therefore needs to be sequenced. 17 | instance 18 | ( Applicative f 19 | , IsSymbol sym 20 | , Row.Lacks sym rb 21 | , Row.Cons sym a rb rc 22 | ) => 23 | FoldingWithIndex 24 | (SequenceRecord f) 25 | (Proxy sym) 26 | (f (Builder { | ra } { | rb })) 27 | (f a) 28 | (f (Builder { | ra } { | rc })) where 29 | foldingWithIndex _ prop rin a = (>>>) <$> rin <*> (Builder.insert prop <$> a) 30 | 31 | -- Matches if the type of the current field in the record is another record and therefore needs to be recursed. 32 | else instance 33 | ( Applicative f 34 | , IsSymbol sym 35 | , Row.Lacks sym rb 36 | , RowToList x xRL 37 | , Row.Cons sym { | y } rb rc 38 | , FoldlRecord 39 | (SequenceRecord f) 40 | (f (Builder (Record ()) (Record ()))) 41 | xRL 42 | x 43 | (f (Builder (Record ()) (Record y))) 44 | ) => 45 | FoldingWithIndex 46 | (SequenceRecord f) 47 | (Proxy sym) 48 | (f (Builder { | ra } { | rb })) 49 | { | x } 50 | (f (Builder { | ra } { | rc })) where 51 | foldingWithIndex _ prop rin x = (>>>) <$> rin <*> (fx <#> Builder.insert prop) 52 | where 53 | fx = sequenceRecord x 54 | 55 | -- Matches if the type of the current field in the record is any other type independent of sequencing. 56 | else instance 57 | ( Applicative f 58 | , IsSymbol sym 59 | , Row.Lacks sym rb 60 | , Row.Cons sym x rb rc 61 | ) => 62 | FoldingWithIndex 63 | (SequenceRecord f) 64 | (Proxy sym) 65 | (f (Builder { | ra } { | rb })) 66 | x 67 | (f (Builder { | ra } { | rc })) where 68 | foldingWithIndex _ prop rin x = (_ >>> Builder.insert prop x) <$> rin 69 | 70 | -- | Recursively sequence a record. E.g. 71 | -- | ```purescript 72 | -- | sequenceRecord { a : { b : { c : { d: Just 10, e : Just "hello" }, f : Just true } 73 | -- | -- Just { a : { b : { c : { d: 10, e : "hello" }, f : true } 74 | -- | ``` 75 | sequenceRecord 76 | :: forall f rin rout 77 | . Applicative f 78 | => HFoldlWithIndex (SequenceRecord f) (f (Builder {} {})) { | rin } (f (Builder {} { | rout })) 79 | => { | rin } 80 | -> f { | rout } 81 | sequenceRecord = 82 | map (flip Builder.build {}) 83 | <<< hfoldlWithIndex (SequenceRecord :: SequenceRecord f) (pure identity :: f (Builder {} {})) 84 | -------------------------------------------------------------------------------- /src/Record/Studio/SequenceUniform.purs: -------------------------------------------------------------------------------- 1 | module Record.Studio.SequenceUniform where 2 | 3 | import Prelude 4 | 5 | import Data.Symbol (class IsSymbol) 6 | import Prim.Row as Row 7 | import Prim.RowList as RL 8 | import Record as R 9 | import Record.Builder (Builder) 10 | import Record.Builder as Builder 11 | import Type.Proxy (Proxy(..)) 12 | 13 | sequenceUniformRecord 14 | :: forall row row' rl m 15 | . RL.RowToList row rl 16 | => SequenceUniformRecord rl row () row' m 17 | => Record row 18 | -> m (Record row') 19 | sequenceUniformRecord a = Builder.build <@> {} <$> builder 20 | where 21 | builder = sequenceUniformRecordImpl (Proxy :: _ rl) a 22 | 23 | class 24 | Functor m <= 25 | SequenceUniformRecord (rl :: RL.RowList Type) row from to m 26 | | rl -> row from to m 27 | where 28 | sequenceUniformRecordImpl :: Proxy rl -> Record row -> m (Builder { | from } { | to }) 29 | 30 | instance 31 | ( IsSymbol name 32 | , Row.Cons name (m ty) trash row 33 | , Functor m 34 | , Row.Lacks name () 35 | , Row.Cons name ty () to 36 | ) => 37 | SequenceUniformRecord (RL.Cons name (m ty) RL.Nil) row () to m where 38 | sequenceUniformRecordImpl _ a = 39 | Builder.insert namep <$> valA 40 | where 41 | namep = Proxy :: _ name 42 | valA = R.get namep a 43 | 44 | else instance 45 | ( IsSymbol name 46 | , Row.Cons name (m ty) trash row 47 | , Apply m 48 | , SequenceUniformRecord tail row from from' m 49 | , Row.Lacks name from' 50 | , Row.Cons name ty from' to 51 | ) => 52 | SequenceUniformRecord (RL.Cons name (m ty) tail) row from to m where 53 | sequenceUniformRecordImpl _ a = 54 | fn <$> valA <*> rest 55 | where 56 | namep = Proxy :: _ name 57 | valA = R.get namep a 58 | tailp = Proxy :: _ tail 59 | rest = sequenceUniformRecordImpl tailp a 60 | fn valA' rest' = Builder.insert namep valA' <<< rest' 61 | 62 | instance Applicative m => SequenceUniformRecord RL.Nil row () () m where 63 | sequenceUniformRecordImpl _ _ = pure identity 64 | -------------------------------------------------------------------------------- /src/Record/Studio/Shrink.js: -------------------------------------------------------------------------------- 1 | export const shrinkImpl = keys => record => { 2 | return keys.reduce((acc, key) => { 3 | acc[key] = record[key]; 4 | return acc; 5 | }, {}); 6 | } 7 | -------------------------------------------------------------------------------- /src/Record/Studio/Shrink.purs: -------------------------------------------------------------------------------- 1 | module Record.Studio.Shrink (shrink) where 2 | 3 | import Prim.Row (class Union) 4 | import Record.Studio.Keys (class Keys, keys) 5 | import Type.Proxy (Proxy(..)) 6 | 7 | foreign import shrinkImpl :: forall r1 r2. Array String -> Record r1 -> Record r2 8 | 9 | shrink :: forall a b r. Union b r a => Keys b => { | a } -> { | b } 10 | shrink = shrinkImpl (keys (Proxy :: Proxy b)) 11 | -------------------------------------------------------------------------------- /src/Record/Studio/SingletonRecord.js: -------------------------------------------------------------------------------- 1 | 2 | export const unsafeGetFirstField = rec => Object.values(rec)[0] 3 | -------------------------------------------------------------------------------- /src/Record/Studio/SingletonRecord.purs: -------------------------------------------------------------------------------- 1 | module Record.Studio.SingletonRecord 2 | ( class SingletonRecord 3 | , class SingletonRecordFields 4 | , key 5 | , value 6 | , singletonRecordFields 7 | ) where 8 | 9 | import Prelude 10 | 11 | import Data.Symbol (class IsSymbol) 12 | import Prim.Row as Row 13 | import Prim.RowList (class RowToList) 14 | import Prim.RowList as RL 15 | import Prim.TypeError (class Fail, Beside, Quote, QuoteLabel, Text) 16 | import Type.Proxy (Proxy(..)) 17 | import Unsafe.Coerce (unsafeCoerce) 18 | 19 | class SingletonRecord :: forall k1 k2. k1 -> Type -> Row Type -> k2 -> Constraint 20 | class SingletonRecord key value rec recRL | rec -> key value recRL where 21 | -- | Get the key of a record with only one field as a `Proxy` 22 | key :: Record rec -> Proxy key 23 | value :: Record rec -> value 24 | 25 | foreign import unsafeGetFirstField :: forall r a. { | r } -> a 26 | 27 | instance 28 | ( RowToList rec recRL 29 | , SingletonRecordFields key a rec recRL 30 | ) => 31 | SingletonRecord key a rec rl where 32 | key = singletonRecordFields (Proxy :: Proxy recRL) 33 | value = unsafeGetFirstField 34 | else instance (Fail (Text "The record must have exactly one field")) => SingletonRecord key a rec recRL where 35 | key _ = unsafeCoerce unit 36 | value _ = unsafeCoerce unit 37 | 38 | class SingletonRecordFields :: forall k1 k2. k1 -> Type -> Row Type -> k2 -> Constraint 39 | class 40 | SingletonRecordFields key value rec recRL 41 | | rec -> key value 42 | where 43 | singletonRecordFields :: Proxy recRL -> { | rec } -> Proxy key 44 | 45 | instance 46 | ( RowToList rec (RL.Cons key a RL.Nil) 47 | , Row.Cons key a () rec 48 | , IsSymbol key 49 | ) => 50 | SingletonRecordFields key a rec (RL.Cons key a RL.Nil) where 51 | singletonRecordFields _ _ = (Proxy :: Proxy key) 52 | 53 | instance 54 | ( Fail (Beside ErrorMsg (Text "instead of {}")) 55 | ) => 56 | SingletonRecordFields key a rec RL.Nil where 57 | singletonRecordFields _ _ = unsafeCoerce unit 58 | 59 | else instance 60 | ( Fail 61 | ( ErrorMsg 62 | ++ ButReceivedStart 63 | ++ (QuoteLabel key ++ DblCol ++ Quote a) 64 | ++ Comma 65 | ++ (QuoteLabel key1 ++ DblCol ++ Quote a1) 66 | ++ ButReceivedEnd 67 | ) 68 | ) => 69 | SingletonRecordFields key a rec (RL.Cons key a (RL.Cons key1 a1 rl)) where 70 | singletonRecordFields _ _ = unsafeCoerce unit 71 | 72 | type ErrorMsg = (Text "Must provide a record with exactly one field ") 73 | type ButReceivedStart = (Text "instead of { ") 74 | type ButReceivedEnd = (Text ", ... }") 75 | type DblCol = (Text " :: ") 76 | type Comma = (Text ", ") 77 | 78 | infixl 3 type Beside as ++ 79 | -------------------------------------------------------------------------------- /test.dhall: -------------------------------------------------------------------------------- 1 | let conf = ./spago.dhall 2 | 3 | in conf 4 | // { sources = conf.sources # [ "test/**/*.purs" ] 5 | , dependencies = 6 | conf.dependencies 7 | # [ "aff" 8 | , "effect" 9 | , "spec" 10 | , "spec-discovery" 11 | , "either" 12 | , "maybe" 13 | , "foreign-object" 14 | , "unsafe-coerce" 15 | ] 16 | } 17 | -------------------------------------------------------------------------------- /test/KeysSpec.purs: -------------------------------------------------------------------------------- 1 | module KeysSpec where 2 | 3 | import Prelude 4 | 5 | import Record.Studio (recordKeys) 6 | import Test.Spec (Spec, describe, it) 7 | import Test.Spec.Assertions (shouldEqual) 8 | 9 | spec :: Spec Unit 10 | spec = 11 | describe "keys" do 12 | it "gets the keys of {}" do 13 | recordKeys {} `shouldEqual` [] 14 | it "gets the keys of { a :: String }" do 15 | recordKeys { a: "" } `shouldEqual` [ "a" ] 16 | it "gets the keys of { a :: String, b :: Int }" do 17 | recordKeys { a: "", b: 1 } `shouldEqual` [ "a", "b" ] 18 | -------------------------------------------------------------------------------- /test/Main.purs: -------------------------------------------------------------------------------- 1 | module Test.Main where 2 | 3 | import Prelude 4 | 5 | import Effect (Effect) 6 | import Effect.Aff (launchAff_) 7 | import Test.Spec.Discovery (discover) 8 | import Test.Spec.Reporter.Console (consoleReporter) 9 | import Test.Spec.Runner (runSpec) 10 | 11 | main :: Effect Unit 12 | main = launchAff_ $ discover pattern >>= runSpec [ consoleReporter ] 13 | where 14 | pattern = ".*Spec" 15 | -------------------------------------------------------------------------------- /test/MapRecordKindSpec.purs: -------------------------------------------------------------------------------- 1 | module MapRecordKindSpec where 2 | 3 | import Prelude 4 | 5 | import Data.Either (Either(..), hush) 6 | import Data.Maybe (Maybe(..)) 7 | import Record.Studio (mapRecordKind) 8 | import Test.Spec (Spec, describe, it) 9 | import Test.Spec.Assertions (shouldEqual) 10 | 11 | type MapKindInput = { a :: Either String Int, b :: String, c :: { d :: Either String String, e :: Int, f :: { g :: Either String Boolean, h :: Either String Int } }, i :: Maybe Int } 12 | 13 | type MapKindOutput = { a :: Maybe Int, b :: String, c :: { d :: Maybe String, e :: Int, f :: { g :: Maybe Boolean, h :: Maybe Int } }, i :: Maybe Int } 14 | 15 | spec :: Spec Unit 16 | spec = 17 | describe "mapRecordKind" do 18 | it "should recursively a natural transformation over a record" do 19 | let 20 | input :: MapKindInput 21 | input = 22 | { a: Right 10 23 | , b: "hello" 24 | , c: 25 | { d: Left "world" 26 | , e: 20 27 | , f: { g: Right true, h: Left "broken" } 28 | } 29 | , i: Just 40 30 | } 31 | 32 | nt :: Either String ~> Maybe 33 | nt = hush 34 | 35 | expected :: MapKindOutput 36 | expected = 37 | { a: Just 10 38 | , b: "hello" 39 | , c: 40 | { d: Nothing 41 | , e: 20 42 | , f: { g: Just true, h: Nothing } 43 | } 44 | , i: Just 40 45 | } 46 | (mapRecordKind nt input) `shouldEqual` expected 47 | -------------------------------------------------------------------------------- /test/MapRecordSpec.purs: -------------------------------------------------------------------------------- 1 | module MapRecordSpec where 2 | 3 | import Prelude 4 | 5 | import Data.Maybe (Maybe(..)) 6 | import Record.Studio (mapRecord) 7 | import Test.Spec (Spec, describe, it) 8 | import Test.Spec.Assertions (shouldEqual) 9 | 10 | type MapInput = { a :: Int, b :: String, c :: { d :: Maybe String, e :: Int, f :: { g :: Boolean, h :: Int } }, i :: Int } 11 | 12 | type MapOutput = { a :: String, b :: String, c :: { d :: Maybe String, e :: String, f :: { g :: Boolean, h :: String } }, i :: String } 13 | 14 | spec :: Spec Unit 15 | spec = 16 | describe "mapRecord" do 17 | it "should recursively map a function over a record" do 18 | let 19 | input :: MapInput 20 | input = 21 | { a: 10 22 | , b: "hello" 23 | , c: 24 | { d: Just "world" 25 | , e: 20 26 | , f: { g: true, h: 30 } 27 | } 28 | , i: 40 29 | } 30 | 31 | f :: Int -> String 32 | f i = show (i + 1) 33 | 34 | expected :: MapOutput 35 | expected = 36 | { a: "11" 37 | , b: "hello" 38 | , c: 39 | { d: Just "world" 40 | , e: "21" 41 | , f: { g: true, h: "31" } 42 | } 43 | , i: "41" 44 | } 45 | (mapRecord f input) `shouldEqual` expected 46 | -------------------------------------------------------------------------------- /test/MapUniformRecordSpec.purs: -------------------------------------------------------------------------------- 1 | module MapUniformRecordSpec where 2 | 3 | import Prelude 4 | 5 | import Record.Studio.MapUniform (mapUniformRecord) 6 | import Test.Spec (Spec, describe, it) 7 | import Test.Spec.Assertions (shouldEqual) 8 | 9 | spec :: Spec Unit 10 | spec = 11 | describe "mapUniformRecord" do 12 | it "should map a function over a uniform record" do 13 | let 14 | input = { a: 10, b: 12 } 15 | 16 | f = (_ + 4) 17 | 18 | expected = 19 | { a: 14 20 | , b: 16 21 | } 22 | (mapUniformRecord f input) `shouldEqual` expected 23 | -------------------------------------------------------------------------------- /test/MergeFlippedSpec.purs: -------------------------------------------------------------------------------- 1 | module MergeFlippedSpec where 2 | 3 | import Prelude 4 | 5 | import Record.Studio ((//)) 6 | import Test.Spec (Spec, describe, it) 7 | import Test.Spec.Assertions (shouldEqual) 8 | 9 | spec :: Spec Unit 10 | spec = 11 | describe "Record Operations" do 12 | describe "mergeFlipped (//)" do 13 | it "should merge disjoint records" do 14 | ({ a: 1, b: 2 } // { c: 3 }) `shouldEqual` { a: 1, b: 2, c: 3 } 15 | it "should prioritise the right-hand-side" do 16 | ({ a: 1, b: 2 } // { b: 3 }) `shouldEqual` { a: 1, b: 3 } 17 | it "should prioritise the right-hand-side type" do 18 | ({ a: 1, b: 2 } // { b: "a" }) `shouldEqual` { a: 1, b: "a" } 19 | it "should work with larger records" do 20 | ({ a: 1, b: 2 } // { c: 3, d: 4 }) `shouldEqual` { a: 1, b: 2, c: 3, d: 4 } 21 | -------------------------------------------------------------------------------- /test/SameKeysSpec.purs: -------------------------------------------------------------------------------- 1 | module SameKeysSpec where 2 | 3 | import Prelude 4 | 5 | import Record.Studio.SameKeys (class SameKeys) 6 | import Test.Spec (Spec, describe, it) 7 | 8 | spec :: Spec Unit 9 | spec = 10 | describe "same keys" do 11 | it "asserts the same keys" do 12 | -- let _ = sameKeys { b: "hi", a: 4, c: 4 } { b: "hu", a: "ha" } 13 | -- The key "c" is missing from the second record 14 | 15 | -- let _ = sameKeys { b: "hi", a: 4 } { b: "hu", a: "ha", c: 4 } 16 | -- The key "c" is missing from the first record 17 | 18 | -- let _ = sameKeys { b: "hi", a: 4 } { b: "hu" } 19 | -- The key "a" is missing from the second record 20 | 21 | -- let _ = sameKeys { b: "hi", a: 4 } { b: "hu" } 22 | -- The key "a" is missing from the second record 23 | 24 | let _ = sameKeys { b: "hi", z: 1 } { z: "", b: { c: false } } 25 | pure unit 26 | 27 | sameKeys :: forall r1 r2. SameKeys r1 r2 => {|r1} -> {|r2} -> Unit 28 | sameKeys _ _ = unit 29 | -------------------------------------------------------------------------------- /test/SequenceSpec.purs: -------------------------------------------------------------------------------- 1 | module SequenceRecordSpec where 2 | 3 | import Prelude 4 | 5 | import Data.Maybe (Maybe(..)) 6 | import Record.Studio (sequenceRecord) 7 | import Test.Spec (Spec, describe, it) 8 | import Test.Spec.Assertions (shouldEqual) 9 | 10 | type SequenceInput = { a :: Maybe Int, b :: String, c :: { d :: Maybe String, e :: Boolean, f :: { g :: Maybe Boolean } }, h :: Int } 11 | 12 | type SequenceOutput = { a :: Int, b :: String, c :: { d :: String, e :: Boolean, f :: { g :: Boolean } }, h :: Int } 13 | 14 | spec :: Spec Unit 15 | spec = 16 | describe "sequenceRecord" do 17 | it "should recursively sequence a valid record" do 18 | let 19 | input :: SequenceInput 20 | input = 21 | { a: Just 10 22 | , b: "hello" 23 | , c: 24 | { d: Just "world" 25 | , e: true 26 | , f: { g: Just true } 27 | } 28 | , h: 10 29 | } 30 | 31 | expected :: Maybe SequenceOutput 32 | expected = Just 33 | { a: 10 34 | , b: "hello" 35 | , c: 36 | { d: "world" 37 | , e: true 38 | , f: { g: true } 39 | } 40 | , h: 10 41 | } 42 | (sequenceRecord input) `shouldEqual` expected 43 | it "should recursively sequence an invalid record" do 44 | let 45 | input :: SequenceInput 46 | input = 47 | { a: Just 10 48 | , b: "hello" 49 | , c: 50 | { d: Just "world" 51 | , e: true 52 | , f: { g: Nothing } 53 | } 54 | , h: 10 55 | } 56 | 57 | expected :: Maybe SequenceOutput 58 | expected = Nothing 59 | (sequenceRecord input) `shouldEqual` expected 60 | -------------------------------------------------------------------------------- /test/SequenceUniformRecordSpec.purs: -------------------------------------------------------------------------------- 1 | module SequenceUniformRecordSpec where 2 | 3 | import Prelude 4 | 5 | import Data.Maybe (Maybe(..)) 6 | import Record.Studio.SequenceUniform (sequenceUniformRecord) 7 | import Test.Spec (Spec, describe, it) 8 | import Test.Spec.Assertions (shouldEqual) 9 | 10 | spec :: Spec Unit 11 | spec = 12 | describe "sequenceUniformRecord" do 13 | it "should sequence an homogeneous record" do 14 | let input = { a: Just 4, b: Nothing :: Maybe String } 15 | sequenceUniformRecord input `shouldEqual` Nothing 16 | it "should sequence another homogeneous record" do 17 | let input = { a: Just 4, b: Just "a" } 18 | sequenceUniformRecord input `shouldEqual` (Just { a: 4, b: "a" }) 19 | -------------------------------------------------------------------------------- /test/ShrinkSpec.purs: -------------------------------------------------------------------------------- 1 | module ShrinkSpec where 2 | 3 | import Prelude 4 | 5 | import Foreign.Object as Object 6 | import Record.Studio (shrink) 7 | import Test.Spec (Spec, describe, it) 8 | import Test.Spec.Assertions (shouldEqual) 9 | import Unsafe.Coerce (unsafeCoerce) 10 | 11 | spec :: Spec Unit 12 | spec = 13 | describe "shrink" do 14 | it "shrinks down records all the way" do 15 | shrink { a: 1, b: 2, c: "c" } `shouldEqual` {} 16 | it "shrinks down records a bit" do 17 | shrink { a: 1, b: 2, c: 3, d: 4 } `shouldEqual` { a: 1, b: 2, c: 3 } 18 | it "shrinks to the correct runtime representation" do 19 | let 20 | shrunk :: { c :: Int, e :: Int } 21 | shrunk = shrink { a: 1, b: 2, c: 3, d: 4, e: 5 } 22 | unsafeCoerce shrunk `shouldEqual` Object.fromHomogeneous { c: 3, e: 5 } 23 | it "shrinks heterogeneous records" do 24 | shrink { a: "a", b: { e: 4 }, c: false } `shouldEqual` { c: false } 25 | -------------------------------------------------------------------------------- /test/SingletonRecordSpec.purs: -------------------------------------------------------------------------------- 1 | module SingletonRecordSpec where 2 | 3 | import Prelude 4 | 5 | import Record.Studio.SingletonRecord (key, value) 6 | import Test.Spec (Spec, describe, it) 7 | import Test.Spec.Assertions (shouldEqual) 8 | import Type.Proxy (Proxy(..)) 9 | 10 | spec :: Spec Unit 11 | spec = 12 | describe "key" do 13 | it "should get the only key of a singleton record as a `Proxy`" do 14 | let 15 | input = { a: 10 } 16 | 17 | -- | These should fail to compile with a helpful message 18 | -- inputFails1 = key {} 19 | -- inputFails2 = key { a: 10, b: "a" } 20 | -- inputFails3 = value {} 21 | -- inputFails4 = value { a: 10, b: "a" } 22 | 23 | (key input) `shouldEqual` (Proxy :: Proxy "a") 24 | (value input) `shouldEqual` 10 25 | --------------------------------------------------------------------------------