aurix-ai 2.7.3 → 2.7.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/aurix.js +2 -2
- package/dist/agent/AgentLoop.d.ts.map +1 -1
- package/dist/agent/AgentLoop.js +1 -52
- package/dist/agent/AgentLoop.js.map +1 -1
- package/dist/cli/App.d.ts.map +1 -1
- package/dist/cli/App.js +6 -0
- package/dist/cli/App.js.map +1 -1
- package/dist/cli/commands.d.ts.map +1 -1
- package/dist/cli/commands.js +7 -0
- package/dist/cli/commands.js.map +1 -1
- package/dist/tools/Browser.d.ts.map +1 -1
- package/dist/tools/Browser.js +44 -615
- package/dist/tools/Browser.js.map +1 -1
- package/dist/tools/captcha/CaptchaRouter.d.ts +6 -0
- package/dist/tools/captcha/CaptchaRouter.d.ts.map +1 -0
- package/dist/tools/captcha/CaptchaRouter.js +371 -0
- package/dist/tools/captcha/CaptchaRouter.js.map +1 -0
- package/dist/tools/captcha/RecaptchaSolver.d.ts +2 -0
- package/dist/tools/captcha/RecaptchaSolver.d.ts.map +1 -0
- package/dist/tools/captcha/RecaptchaSolver.js +1114 -0
- package/dist/tools/captcha/RecaptchaSolver.js.map +1 -0
- package/dist/tools/captcha/common.d.ts +35 -0
- package/dist/tools/captcha/common.d.ts.map +1 -0
- package/dist/tools/captcha/common.js +445 -0
- package/dist/tools/captcha/common.js.map +1 -0
- package/dist/tools/captcha/index.d.ts +5 -0
- package/dist/tools/captcha/index.d.ts.map +1 -0
- package/dist/tools/captcha/index.js +4 -0
- package/dist/tools/captcha/index.js.map +1 -0
- package/package.json +2 -2
- package/scripts/build.cjs +0 -15
- package/scripts/run-task.mjs +86 -0
- package/training/captcha-training.json +930 -0
- package/native/token-counter/index.d.ts +0 -7
- package/native/token-counter/index.js +0 -316
- package/native/token-counter/node_modules/.package-lock.json +0 -568
- package/native/token-counter/node_modules/2/array.js +0 -25
- package/native/token-counter/node_modules/2/index.js +0 -12
- package/native/token-counter/node_modules/2/iterator.js +0 -13
- package/native/token-counter/node_modules/2/license.txt +0 -21
- package/native/token-counter/node_modules/2/map.js +0 -27
- package/native/token-counter/node_modules/2/number.js +0 -109
- package/native/token-counter/node_modules/2/object.js +0 -23
- package/native/token-counter/node_modules/2/package.json +0 -60
- package/native/token-counter/node_modules/2/readme.md +0 -246
- package/native/token-counter/node_modules/2/string.js +0 -11
- package/native/token-counter/node_modules/2/test.js +0 -520
- package/native/token-counter/node_modules/@lamansky/every/index.js +0 -16
- package/native/token-counter/node_modules/@lamansky/every/license.txt +0 -21
- package/native/token-counter/node_modules/@lamansky/every/package.json +0 -38
- package/native/token-counter/node_modules/@lamansky/every/readme.md +0 -46
- package/native/token-counter/node_modules/@lamansky/flatten/index.js +0 -5
- package/native/token-counter/node_modules/@lamansky/flatten/license.txt +0 -21
- package/native/token-counter/node_modules/@lamansky/flatten/package.json +0 -35
- package/native/token-counter/node_modules/@lamansky/flatten/readme.md +0 -41
- package/native/token-counter/node_modules/@napi-rs/cli/LICENSE +0 -21
- package/native/token-counter/node_modules/@napi-rs/cli/README.md +0 -96
- package/native/token-counter/node_modules/@napi-rs/cli/package.json +0 -65
- package/native/token-counter/node_modules/@napi-rs/cli/scripts/index.js +0 -51371
- package/native/token-counter/node_modules/add-counter/index.js +0 -3
- package/native/token-counter/node_modules/add-counter/license.txt +0 -21
- package/native/token-counter/node_modules/add-counter/package.json +0 -34
- package/native/token-counter/node_modules/add-counter/readme.md +0 -36
- package/native/token-counter/node_modules/array-pad/LICENSE +0 -22
- package/native/token-counter/node_modules/array-pad/README.md +0 -80
- package/native/token-counter/node_modules/array-pad/index.js +0 -30
- package/native/token-counter/node_modules/array-pad/package.json +0 -28
- package/native/token-counter/node_modules/arrify/index.js +0 -8
- package/native/token-counter/node_modules/arrify/license +0 -21
- package/native/token-counter/node_modules/arrify/package.json +0 -33
- package/native/token-counter/node_modules/arrify/readme.md +0 -36
- package/native/token-counter/node_modules/case-insensitive/index.js +0 -72
- package/native/token-counter/node_modules/case-insensitive/license.txt +0 -21
- package/native/token-counter/node_modules/case-insensitive/package.json +0 -39
- package/native/token-counter/node_modules/case-insensitive/readme.md +0 -39
- package/native/token-counter/node_modules/case-insensitive/test.js +0 -114
- package/native/token-counter/node_modules/class-chain/index.js +0 -32
- package/native/token-counter/node_modules/class-chain/license.txt +0 -21
- package/native/token-counter/node_modules/class-chain/package.json +0 -39
- package/native/token-counter/node_modules/class-chain/readme.md +0 -23
- package/native/token-counter/node_modules/class-chain/test.js +0 -77
- package/native/token-counter/node_modules/copy-own/index.js +0 -10
- package/native/token-counter/node_modules/copy-own/license.txt +0 -21
- package/native/token-counter/node_modules/copy-own/package.json +0 -37
- package/native/token-counter/node_modules/copy-own/readme.md +0 -67
- package/native/token-counter/node_modules/def-props/index.js +0 -43
- package/native/token-counter/node_modules/def-props/license.txt +0 -21
- package/native/token-counter/node_modules/def-props/node_modules/is-obj/index.d.ts +0 -22
- package/native/token-counter/node_modules/def-props/node_modules/is-obj/index.js +0 -6
- package/native/token-counter/node_modules/def-props/node_modules/is-obj/license +0 -9
- package/native/token-counter/node_modules/def-props/node_modules/is-obj/package.json +0 -34
- package/native/token-counter/node_modules/def-props/node_modules/is-obj/readme.md +0 -39
- package/native/token-counter/node_modules/def-props/package.json +0 -51
- package/native/token-counter/node_modules/def-props/readme.md +0 -117
- package/native/token-counter/node_modules/empty-iterator/index.js +0 -3
- package/native/token-counter/node_modules/empty-iterator/license.txt +0 -21
- package/native/token-counter/node_modules/empty-iterator/package.json +0 -33
- package/native/token-counter/node_modules/empty-iterator/readme.md +0 -23
- package/native/token-counter/node_modules/enforce-range/index.js +0 -15
- package/native/token-counter/node_modules/enforce-range/license.txt +0 -21
- package/native/token-counter/node_modules/enforce-range/node_modules/2/array.js +0 -43
- package/native/token-counter/node_modules/enforce-range/node_modules/2/index.js +0 -10
- package/native/token-counter/node_modules/enforce-range/node_modules/2/iterator.js +0 -26
- package/native/token-counter/node_modules/enforce-range/node_modules/2/license.txt +0 -21
- package/native/token-counter/node_modules/enforce-range/node_modules/2/map.js +0 -47
- package/native/token-counter/node_modules/enforce-range/node_modules/2/number.js +0 -33
- package/native/token-counter/node_modules/enforce-range/node_modules/2/object.js +0 -61
- package/native/token-counter/node_modules/enforce-range/node_modules/2/package.json +0 -41
- package/native/token-counter/node_modules/enforce-range/node_modules/2/readme.md +0 -210
- package/native/token-counter/node_modules/enforce-range/node_modules/2/string.js +0 -37
- package/native/token-counter/node_modules/enforce-range/node_modules/2/test.js +0 -413
- package/native/token-counter/node_modules/enforce-range/package.json +0 -36
- package/native/token-counter/node_modules/enforce-range/readme.md +0 -53
- package/native/token-counter/node_modules/english-list/.travis.yml +0 -6
- package/native/token-counter/node_modules/english-list/LICENSE +0 -22
- package/native/token-counter/node_modules/english-list/README.md +0 -44
- package/native/token-counter/node_modules/english-list/index.js +0 -34
- package/native/token-counter/node_modules/english-list/package.json +0 -31
- package/native/token-counter/node_modules/english-list/test.log +0 -6
- package/native/token-counter/node_modules/errate/index.js +0 -19
- package/native/token-counter/node_modules/errate/license.txt +0 -21
- package/native/token-counter/node_modules/errate/package.json +0 -39
- package/native/token-counter/node_modules/errate/readme.md +0 -79
- package/native/token-counter/node_modules/ffn/index.js +0 -9
- package/native/token-counter/node_modules/ffn/license.txt +0 -21
- package/native/token-counter/node_modules/ffn/package.json +0 -34
- package/native/token-counter/node_modules/ffn/readme.md +0 -51
- package/native/token-counter/node_modules/get-own-property/index.js +0 -5
- package/native/token-counter/node_modules/get-own-property/license.txt +0 -21
- package/native/token-counter/node_modules/get-own-property/package.json +0 -31
- package/native/token-counter/node_modules/get-own-property/readme.md +0 -22
- package/native/token-counter/node_modules/has-duplicates/index.js +0 -11
- package/native/token-counter/node_modules/has-duplicates/license.txt +0 -21
- package/native/token-counter/node_modules/has-duplicates/package.json +0 -32
- package/native/token-counter/node_modules/has-duplicates/readme.md +0 -23
- package/native/token-counter/node_modules/has-duplicates/test.js +0 -30
- package/native/token-counter/node_modules/if-else-throw/index.js +0 -8
- package/native/token-counter/node_modules/if-else-throw/license.txt +0 -21
- package/native/token-counter/node_modules/if-else-throw/package.json +0 -37
- package/native/token-counter/node_modules/if-else-throw/readme.md +0 -32
- package/native/token-counter/node_modules/is-array-of-length/index.js +0 -7
- package/native/token-counter/node_modules/is-array-of-length/license.txt +0 -21
- package/native/token-counter/node_modules/is-array-of-length/package.json +0 -42
- package/native/token-counter/node_modules/is-array-of-length/readme.md +0 -41
- package/native/token-counter/node_modules/is-class-of/index.js +0 -7
- package/native/token-counter/node_modules/is-class-of/license.txt +0 -21
- package/native/token-counter/node_modules/is-class-of/package.json +0 -35
- package/native/token-counter/node_modules/is-class-of/readme.md +0 -57
- package/native/token-counter/node_modules/is-global-object/index.js +0 -6
- package/native/token-counter/node_modules/is-global-object/license.txt +0 -21
- package/native/token-counter/node_modules/is-global-object/package.json +0 -34
- package/native/token-counter/node_modules/is-global-object/readme.md +0 -22
- package/native/token-counter/node_modules/is-instance-of/index.js +0 -28
- package/native/token-counter/node_modules/is-instance-of/license.txt +0 -21
- package/native/token-counter/node_modules/is-instance-of/package.json +0 -44
- package/native/token-counter/node_modules/is-instance-of/readme.md +0 -55
- package/native/token-counter/node_modules/is-iterable/index.js +0 -5
- package/native/token-counter/node_modules/is-iterable/license +0 -21
- package/native/token-counter/node_modules/is-iterable/package.json +0 -30
- package/native/token-counter/node_modules/is-iterable/readme.md +0 -23
- package/native/token-counter/node_modules/is-nil/LICENSE +0 -21
- package/native/token-counter/node_modules/is-nil/README.md +0 -47
- package/native/token-counter/node_modules/is-nil/index.js +0 -6
- package/native/token-counter/node_modules/is-nil/package.json +0 -46
- package/native/token-counter/node_modules/is-obj/index.js +0 -5
- package/native/token-counter/node_modules/is-obj/license +0 -21
- package/native/token-counter/node_modules/is-obj/package.json +0 -33
- package/native/token-counter/node_modules/is-obj/readme.md +0 -34
- package/native/token-counter/node_modules/is-object/.eslintignore +0 -1
- package/native/token-counter/node_modules/is-object/.eslintrc +0 -5
- package/native/token-counter/node_modules/is-object/.nycrc +0 -13
- package/native/token-counter/node_modules/is-object/.testem.json +0 -14
- package/native/token-counter/node_modules/is-object/CHANGELOG.md +0 -121
- package/native/token-counter/node_modules/is-object/LICENSE +0 -19
- package/native/token-counter/node_modules/is-object/README.md +0 -48
- package/native/token-counter/node_modules/is-object/index.js +0 -5
- package/native/token-counter/node_modules/is-object/package.json +0 -78
- package/native/token-counter/node_modules/is-object/test/index.js +0 -44
- package/native/token-counter/node_modules/is-plain-object/LICENSE +0 -21
- package/native/token-counter/node_modules/is-plain-object/README.md +0 -104
- package/native/token-counter/node_modules/is-plain-object/index.d.ts +0 -5
- package/native/token-counter/node_modules/is-plain-object/index.js +0 -37
- package/native/token-counter/node_modules/is-plain-object/package.json +0 -79
- package/native/token-counter/node_modules/isobject/LICENSE +0 -21
- package/native/token-counter/node_modules/isobject/README.md +0 -122
- package/native/token-counter/node_modules/isobject/index.d.ts +0 -5
- package/native/token-counter/node_modules/isobject/index.js +0 -12
- package/native/token-counter/node_modules/isobject/package.json +0 -74
- package/native/token-counter/node_modules/lodash.set/LICENSE +0 -47
- package/native/token-counter/node_modules/lodash.set/README.md +0 -18
- package/native/token-counter/node_modules/lodash.set/index.js +0 -990
- package/native/token-counter/node_modules/lodash.set/package.json +0 -17
- package/native/token-counter/node_modules/longest-first/index.js +0 -3
- package/native/token-counter/node_modules/longest-first/license.txt +0 -21
- package/native/token-counter/node_modules/longest-first/package.json +0 -36
- package/native/token-counter/node_modules/longest-first/readme.md +0 -29
- package/native/token-counter/node_modules/m-o/index.js +0 -27
- package/native/token-counter/node_modules/m-o/license.txt +0 -21
- package/native/token-counter/node_modules/m-o/node_modules/new-object/index.js +0 -23
- package/native/token-counter/node_modules/m-o/node_modules/new-object/license.txt +0 -21
- package/native/token-counter/node_modules/m-o/node_modules/new-object/package.json +0 -40
- package/native/token-counter/node_modules/m-o/node_modules/new-object/readme.md +0 -55
- package/native/token-counter/node_modules/m-o/package.json +0 -45
- package/native/token-counter/node_modules/m-o/readme.md +0 -87
- package/native/token-counter/node_modules/map-iter/index.js +0 -6
- package/native/token-counter/node_modules/map-iter/license.txt +0 -21
- package/native/token-counter/node_modules/map-iter/package.json +0 -40
- package/native/token-counter/node_modules/map-iter/readme.md +0 -46
- package/native/token-counter/node_modules/new-object/index.js +0 -5
- package/native/token-counter/node_modules/new-object/license.txt +0 -21
- package/native/token-counter/node_modules/new-object/package.json +0 -49
- package/native/token-counter/node_modules/new-object/readme.md +0 -145
- package/native/token-counter/node_modules/ofn/index.js +0 -22
- package/native/token-counter/node_modules/ofn/license.txt +0 -21
- package/native/token-counter/node_modules/ofn/package.json +0 -40
- package/native/token-counter/node_modules/ofn/readme.md +0 -63
- package/native/token-counter/node_modules/otherwise/index.js +0 -11
- package/native/token-counter/node_modules/otherwise/license.txt +0 -21
- package/native/token-counter/node_modules/otherwise/package.json +0 -38
- package/native/token-counter/node_modules/otherwise/readme.md +0 -29
- package/native/token-counter/node_modules/parser-factory/index.js +0 -138
- package/native/token-counter/node_modules/parser-factory/license.txt +0 -21
- package/native/token-counter/node_modules/parser-factory/node_modules/arrify/index.d.ts +0 -38
- package/native/token-counter/node_modules/parser-factory/node_modules/arrify/index.js +0 -23
- package/native/token-counter/node_modules/parser-factory/node_modules/arrify/license +0 -9
- package/native/token-counter/node_modules/parser-factory/node_modules/arrify/package.json +0 -35
- package/native/token-counter/node_modules/parser-factory/node_modules/arrify/readme.md +0 -39
- package/native/token-counter/node_modules/parser-factory/package.json +0 -38
- package/native/token-counter/node_modules/parser-factory/readme.md +0 -15
- package/native/token-counter/node_modules/pfn/index.js +0 -5
- package/native/token-counter/node_modules/pfn/license.txt +0 -21
- package/native/token-counter/node_modules/pfn/package.json +0 -41
- package/native/token-counter/node_modules/pfn/readme.md +0 -111
- package/native/token-counter/node_modules/pfn/strict.js +0 -8
- package/native/token-counter/node_modules/plainify/index.js +0 -5
- package/native/token-counter/node_modules/plainify/license.txt +0 -21
- package/native/token-counter/node_modules/plainify/package.json +0 -36
- package/native/token-counter/node_modules/plainify/readme.md +0 -47
- package/native/token-counter/node_modules/possible-function/changelog.md +0 -7
- package/native/token-counter/node_modules/possible-function/index.js +0 -43
- package/native/token-counter/node_modules/possible-function/license.txt +0 -21
- package/native/token-counter/node_modules/possible-function/package.json +0 -34
- package/native/token-counter/node_modules/possible-function/readme.md +0 -77
- package/native/token-counter/node_modules/possible-function/test.js +0 -32
- package/native/token-counter/node_modules/qfn/index.js +0 -11
- package/native/token-counter/node_modules/qfn/license.txt +0 -21
- package/native/token-counter/node_modules/qfn/package.json +0 -40
- package/native/token-counter/node_modules/qfn/readme.md +0 -45
- package/native/token-counter/node_modules/roadblock/index.js +0 -3
- package/native/token-counter/node_modules/roadblock/license.txt +0 -21
- package/native/token-counter/node_modules/roadblock/package.json +0 -40
- package/native/token-counter/node_modules/roadblock/readme.md +0 -59
- package/native/token-counter/node_modules/round-to/index.d.ts +0 -56
- package/native/token-counter/node_modules/round-to/index.js +0 -37
- package/native/token-counter/node_modules/round-to/license +0 -9
- package/native/token-counter/node_modules/round-to/package.json +0 -38
- package/native/token-counter/node_modules/round-to/readme.md +0 -71
- package/native/token-counter/node_modules/rtrim-array/index.js +0 -10
- package/native/token-counter/node_modules/rtrim-array/license.txt +0 -21
- package/native/token-counter/node_modules/rtrim-array/package.json +0 -41
- package/native/token-counter/node_modules/rtrim-array/readme.md +0 -75
- package/native/token-counter/node_modules/sbo/index.js +0 -25
- package/native/token-counter/node_modules/sbo/license.txt +0 -21
- package/native/token-counter/node_modules/sbo/package.json +0 -50
- package/native/token-counter/node_modules/sbo/readme.md +0 -105
- package/native/token-counter/node_modules/sorp/index.js +0 -3
- package/native/token-counter/node_modules/sorp/license.txt +0 -21
- package/native/token-counter/node_modules/sorp/package.json +0 -34
- package/native/token-counter/node_modules/sorp/readme.md +0 -25
- package/native/token-counter/node_modules/trim-call/index.js +0 -6
- package/native/token-counter/node_modules/trim-call/license.txt +0 -21
- package/native/token-counter/node_modules/trim-call/package.json +0 -40
- package/native/token-counter/node_modules/trim-call/readme.md +0 -80
- package/native/token-counter/node_modules/type-error/LICENSE +0 -21
- package/native/token-counter/node_modules/type-error/README.md +0 -24
- package/native/token-counter/node_modules/type-error/index.js +0 -35
- package/native/token-counter/node_modules/type-error/package.json +0 -11
- package/native/token-counter/node_modules/vfn/index.js +0 -21
- package/native/token-counter/node_modules/vfn/license.txt +0 -21
- package/native/token-counter/node_modules/vfn/package.json +0 -40
- package/native/token-counter/node_modules/vfn/readme.md +0 -81
- package/native/token-counter/node_modules/wfn/index.js +0 -43
- package/native/token-counter/node_modules/wfn/license.txt +0 -21
- package/native/token-counter/node_modules/wfn/package.json +0 -38
- package/native/token-counter/node_modules/wfn/readme.md +0 -81
- package/native/token-counter/package-lock.json +0 -578
- package/native/token-counter/package.json +0 -21
- package/native/token-counter/token-counter.linux-x64-gnu.node +0 -0
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
# arrify [](https://travis-ci.org/sindresorhus/arrify)
|
|
2
|
-
|
|
3
|
-
> Convert a value to an array
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
## Install
|
|
7
|
-
|
|
8
|
-
```
|
|
9
|
-
$ npm install arrify
|
|
10
|
-
```
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
## Usage
|
|
14
|
-
|
|
15
|
-
```js
|
|
16
|
-
const arrify = require('arrify');
|
|
17
|
-
|
|
18
|
-
arrify('🦄');
|
|
19
|
-
//=> ['🦄']
|
|
20
|
-
|
|
21
|
-
arrify(['🦄']);
|
|
22
|
-
//=> ['🦄']
|
|
23
|
-
|
|
24
|
-
arrify(new Set(['🦄']));
|
|
25
|
-
//=> ['🦄']
|
|
26
|
-
|
|
27
|
-
arrify(null);
|
|
28
|
-
//=> []
|
|
29
|
-
|
|
30
|
-
arrify(undefined);
|
|
31
|
-
//=> []
|
|
32
|
-
```
|
|
33
|
-
|
|
34
|
-
*Supplying `null` or `undefined` results in an empty array.*
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
## License
|
|
38
|
-
|
|
39
|
-
MIT © [Sindre Sorhus](https://sindresorhus.com)
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "parser-factory",
|
|
3
|
-
"version": "1.1.1",
|
|
4
|
-
"description": "Helps you construct a custom string parser, for times when you need something more procedural than regex.",
|
|
5
|
-
"keywords": [
|
|
6
|
-
"build",
|
|
7
|
-
"custom",
|
|
8
|
-
"string",
|
|
9
|
-
"parser"
|
|
10
|
-
],
|
|
11
|
-
"author": {
|
|
12
|
-
"name": "Fr. John Lamansky",
|
|
13
|
-
"url": "lamansky.com"
|
|
14
|
-
},
|
|
15
|
-
"license": "MIT",
|
|
16
|
-
"homepage": "https://github.com/lamansky/parser-factory",
|
|
17
|
-
"repository": "lamansky/parser-factory",
|
|
18
|
-
"main": "index.js",
|
|
19
|
-
"files": [],
|
|
20
|
-
"engines": {
|
|
21
|
-
"node": ">=8.3.0"
|
|
22
|
-
},
|
|
23
|
-
"dependencies": {
|
|
24
|
-
"arrify": "^2.0.1",
|
|
25
|
-
"case-insensitive": "^1.0.0",
|
|
26
|
-
"enforce-range": "^1.0.0",
|
|
27
|
-
"is-instance-of": "^1.0.2",
|
|
28
|
-
"longest-first": "^1.0.0",
|
|
29
|
-
"m-o": "^2.2.0",
|
|
30
|
-
"vfn": "^1.1.0"
|
|
31
|
-
},
|
|
32
|
-
"devDependencies": {
|
|
33
|
-
"eslint-config-lamansky": "^2.0.0"
|
|
34
|
-
},
|
|
35
|
-
"eslintConfig": {
|
|
36
|
-
"extends": "lamansky"
|
|
37
|
-
}
|
|
38
|
-
}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
# parser-factory
|
|
2
|
-
|
|
3
|
-
Helps you construct a custom string parser, for times when you need something more procedural than regex.
|
|
4
|
-
|
|
5
|
-
## Installation
|
|
6
|
-
|
|
7
|
-
Requires [Node.js](https://nodejs.org/) 8.3.0 or above.
|
|
8
|
-
|
|
9
|
-
```bash
|
|
10
|
-
npm i parser-factory
|
|
11
|
-
```
|
|
12
|
-
|
|
13
|
-
## Example
|
|
14
|
-
|
|
15
|
-
To see this module in action, check out the [conscript](https://github.com/lamansky/conscript.js) module.
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
MIT License
|
|
2
|
-
|
|
3
|
-
Copyright ©2018–2019 Fr. John Lamansky
|
|
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.
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "pfn",
|
|
3
|
-
"version": "1.1.0",
|
|
4
|
-
"description": "Possible Function. Wraps what might be a function, with fallback behavior in case it’s not. Perfect for use in functions that accept optional callback arguments.",
|
|
5
|
-
"keywords": [
|
|
6
|
-
"optional",
|
|
7
|
-
"function",
|
|
8
|
-
"callback",
|
|
9
|
-
"fallback"
|
|
10
|
-
],
|
|
11
|
-
"author": {
|
|
12
|
-
"name": "Fr. John Lamansky",
|
|
13
|
-
"url": "lamansky.com"
|
|
14
|
-
},
|
|
15
|
-
"license": "MIT",
|
|
16
|
-
"homepage": "https://github.com/lamansky/pfn",
|
|
17
|
-
"repository": "lamansky/pfn",
|
|
18
|
-
"main": "index.js",
|
|
19
|
-
"files": [
|
|
20
|
-
"strict.js"
|
|
21
|
-
],
|
|
22
|
-
"engines": {
|
|
23
|
-
"node": ">=6.0.0"
|
|
24
|
-
},
|
|
25
|
-
"dependencies": {
|
|
26
|
-
"is-nil": "^1.0.1"
|
|
27
|
-
},
|
|
28
|
-
"devDependencies": {
|
|
29
|
-
"eslint-config-lamansky": "^2.0.0",
|
|
30
|
-
"mocha": "^6.2.2"
|
|
31
|
-
},
|
|
32
|
-
"scripts": {
|
|
33
|
-
"test": "mocha"
|
|
34
|
-
},
|
|
35
|
-
"eslintConfig": {
|
|
36
|
-
"extends": "lamansky",
|
|
37
|
-
"env": {
|
|
38
|
-
"mocha": true
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
}
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
# Possible Function (pfn)
|
|
2
|
-
|
|
3
|
-
Wraps what might be a function, with fallback behavior in case it’s not. Perfect for use in functions that accept optional callback arguments.
|
|
4
|
-
|
|
5
|
-
## Installation
|
|
6
|
-
|
|
7
|
-
Requires [Node.js](https://nodejs.org/) 6.0.0 or above.
|
|
8
|
-
|
|
9
|
-
```bash
|
|
10
|
-
npm i pfn
|
|
11
|
-
```
|
|
12
|
-
|
|
13
|
-
## API
|
|
14
|
-
|
|
15
|
-
There are two ways you can import the module: `require('pfn')` or `require('pfn/strict')`. Each exposes a single function with the same signature. The difference is that strict mode will throw an error if `fn` is anything other than a function, `null`, or `undefined`. Normal mode will silently defer to `or` if `fn` is of an unexpected type.
|
|
16
|
-
|
|
17
|
-
### Parameters
|
|
18
|
-
|
|
19
|
-
1. `fn` (any): The value that may or may not be a function.
|
|
20
|
-
2. Optional: `or` (any): The function that will be called, or the value that will be returned, if `fn` is not a function. Defaults to a passthrough function (`a => a`).
|
|
21
|
-
|
|
22
|
-
### Return Value
|
|
23
|
-
|
|
24
|
-
Always returns a Function.
|
|
25
|
-
|
|
26
|
-
* `fn`, if `fn` is a Function
|
|
27
|
-
* `or`, if `or` is a Function
|
|
28
|
-
* A Function that returns `or`, if neither `fn` nor `or` is a function
|
|
29
|
-
|
|
30
|
-
## Examples
|
|
31
|
-
|
|
32
|
-
`pfn` wraps a value that may or may not be a function. If the underlying value is not a function, then `pfn` will execute one of the following fallback behaviors.
|
|
33
|
-
|
|
34
|
-
### Passthrough Fallback
|
|
35
|
-
|
|
36
|
-
If the value turns out to not be a function, `pfn` will, by default, pass through whatever is given as the first argument. This is useful for optional filters.
|
|
37
|
-
|
|
38
|
-
```javascript
|
|
39
|
-
const pfn = require('pfn')
|
|
40
|
-
|
|
41
|
-
function sayHello (name, filter) {
|
|
42
|
-
filter = pfn(filter)
|
|
43
|
-
return filter('Hello, ' + name)
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
// No filter is provided, so the hello message is returned without change:
|
|
47
|
-
sayHello('world') // 'Hello, world'
|
|
48
|
-
|
|
49
|
-
// A filter is provided which changes the hello message:
|
|
50
|
-
sayHello('world', m => m + '!!') // 'Hello, world!!'
|
|
51
|
-
```
|
|
52
|
-
|
|
53
|
-
### Return-Value Fallback
|
|
54
|
-
|
|
55
|
-
If the value turns out to not be a function, `pfn` can be configured to return a value of your choosing.
|
|
56
|
-
|
|
57
|
-
```javascript
|
|
58
|
-
const pfn = require('pfn')
|
|
59
|
-
|
|
60
|
-
function sayHello (nameCallback) {
|
|
61
|
-
nameCallback = pfn(nameCallback, 'world')
|
|
62
|
-
return 'Hello, ' + nameCallback()
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
sayHello() // 'Hello, world'
|
|
66
|
-
sayHello(() => 'Dolly') // 'Hello, Dolly'
|
|
67
|
-
```
|
|
68
|
-
|
|
69
|
-
### Self Fallback
|
|
70
|
-
|
|
71
|
-
If you provide the possible function as its own fallback, then you can accept either a value or a function as an argument for your code. For example, the `sayHello` function in the following example can accept either a string or a function.
|
|
72
|
-
|
|
73
|
-
Don’t use the module’s strict mode (`require('pfn/strict')`) if you want self-fallback behavior, because strict mode will throw an error if the first parameter is anything other than a function, `null`, or `undefined`.
|
|
74
|
-
|
|
75
|
-
```javascript
|
|
76
|
-
const pfn = require('pfn')
|
|
77
|
-
|
|
78
|
-
function sayHello (name) {
|
|
79
|
-
name = pfn(name, name)
|
|
80
|
-
return 'Hello, ' + name()
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
sayHello('world') // 'Hello, world'
|
|
84
|
-
sayHello(() => 'world') // 'Hello, world'
|
|
85
|
-
```
|
|
86
|
-
|
|
87
|
-
### Custom Fallback
|
|
88
|
-
|
|
89
|
-
If the wrapped value turns out to not be a function, the wrapping function can execute a custom fallback function instead:
|
|
90
|
-
|
|
91
|
-
```javascript
|
|
92
|
-
const pfn = require('pfn')
|
|
93
|
-
const mightBeAFunction = null
|
|
94
|
-
const callback = pfn(mightBeAFunction, (...args) => args.length)
|
|
95
|
-
callback('arg 1', 'arg 2') // 2
|
|
96
|
-
```
|
|
97
|
-
|
|
98
|
-
## Related
|
|
99
|
-
|
|
100
|
-
This module is part of the `fn` family of modules.
|
|
101
|
-
|
|
102
|
-
* [efn](https://github.com/lamansky/efn): Extracted Function
|
|
103
|
-
* [ffn](https://github.com/lamansky/ffn): Filtering Function
|
|
104
|
-
* [jfn](https://github.com/lamansky/jfn): Joined Function
|
|
105
|
-
* [mfn](https://github.com/lamansky/mfn): Memoized Function
|
|
106
|
-
* [ofn](https://github.com/lamansky/ofn): Overloaded Function
|
|
107
|
-
* [qfn](https://github.com/lamansky/qfn): Qualified Function
|
|
108
|
-
* [vfn](https://github.com/lamansky/vfn): Variadic Function
|
|
109
|
-
* [wfn](https://github.com/lamansky/wfn): Wrapper Function
|
|
110
|
-
* [xfn](https://github.com/lamansky/xfn): Extended Function
|
|
111
|
-
* [3fn](https://github.com/lamansky/3fn): Three-Way Comparison Function
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
'use strict'
|
|
2
|
-
|
|
3
|
-
const f = x => typeof x === 'function'
|
|
4
|
-
const nil = require('is-nil')
|
|
5
|
-
const toss = err => { throw err }
|
|
6
|
-
|
|
7
|
-
module.exports = (x, or = a => a) => f(x) ? x : nil(x) ? (f(or) ? or : () => or)
|
|
8
|
-
: toss(new TypeError('Value cannot be a non-function'))
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
MIT License
|
|
2
|
-
|
|
3
|
-
Copyright ©2018 John Lamansky
|
|
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.
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "plainify",
|
|
3
|
-
"version": "1.0.0",
|
|
4
|
-
"description": "Wraps a value in a plain object, if it isn’t one already.",
|
|
5
|
-
"keywords": [
|
|
6
|
-
"plain",
|
|
7
|
-
"object",
|
|
8
|
-
"options"
|
|
9
|
-
],
|
|
10
|
-
"author": "John Lamansky",
|
|
11
|
-
"license": "MIT",
|
|
12
|
-
"homepage": "https://github.com/lamansky/plainify",
|
|
13
|
-
"repository": "lamansky/plainify",
|
|
14
|
-
"main": "index.js",
|
|
15
|
-
"files": [],
|
|
16
|
-
"engines": {
|
|
17
|
-
"node": ">=4.0.0"
|
|
18
|
-
},
|
|
19
|
-
"dependencies": {
|
|
20
|
-
"is-plain-object": "^2.0.4"
|
|
21
|
-
},
|
|
22
|
-
"devDependencies": {
|
|
23
|
-
"equals": "^1.0.5",
|
|
24
|
-
"eslint-config-lamansky": "^1.0.0",
|
|
25
|
-
"mocha": "^5.1.0"
|
|
26
|
-
},
|
|
27
|
-
"scripts": {
|
|
28
|
-
"test": "mocha"
|
|
29
|
-
},
|
|
30
|
-
"eslintConfig": {
|
|
31
|
-
"extends": "lamansky",
|
|
32
|
-
"env": {
|
|
33
|
-
"mocha": true
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
# plainify
|
|
2
|
-
|
|
3
|
-
Wraps a value in a plain object, if it isn’t one already.
|
|
4
|
-
|
|
5
|
-
Lets you specify a default single key for an options object, for example.
|
|
6
|
-
|
|
7
|
-
## Installation
|
|
8
|
-
|
|
9
|
-
Requires [Node.js](https://nodejs.org/) 4.0.0 or above.
|
|
10
|
-
|
|
11
|
-
```bash
|
|
12
|
-
npm i plainify
|
|
13
|
-
```
|
|
14
|
-
|
|
15
|
-
## API
|
|
16
|
-
|
|
17
|
-
The module exports a single function.
|
|
18
|
-
|
|
19
|
-
### Parameters
|
|
20
|
-
|
|
21
|
-
1. `key` (string or symbol): The key under which to file `x` if it’s not already a plain object.
|
|
22
|
-
2. `x` (any)
|
|
23
|
-
|
|
24
|
-
### Return Value
|
|
25
|
-
|
|
26
|
-
Returns `x` as-is if it’s a plain object. Otherwise, returns a new plain object with one entry, having `key` as the key and `x` as the value.
|
|
27
|
-
|
|
28
|
-
## Example
|
|
29
|
-
|
|
30
|
-
Let’s say you have an options object with keys `a`, `b`, and `c`. You can use `plainify` to specify `b` as the default key.
|
|
31
|
-
|
|
32
|
-
```javascript
|
|
33
|
-
const plainify = require('plainify')
|
|
34
|
-
|
|
35
|
-
function example (options) {
|
|
36
|
-
const {a, b, c} = plainify('b', options)
|
|
37
|
-
// ...
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
example({a: 1}) // a=1; b and c are undefined
|
|
41
|
-
example(2) // b=2; a and c are undefined
|
|
42
|
-
example() // a, b, and c are undefined
|
|
43
|
-
```
|
|
44
|
-
|
|
45
|
-
## Related
|
|
46
|
-
|
|
47
|
-
Inspired by [arrify](https://github.com/sindresorhus/arrify).
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
'use strict'
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Wraps what might be a function. Returns a wrapper-function that provides
|
|
5
|
-
* fallback behavior in case the underlying value is not a function.
|
|
6
|
-
* @param {function|array=} mightBeAFunction A value that might be a function,
|
|
7
|
-
* or a two-element array with [object, 'method'] that might refer to an
|
|
8
|
-
* object method.
|
|
9
|
-
* @param {function|any=} elseReturn A value to return if `mightBeAFunction`
|
|
10
|
-
* is not a function, or a function that generates such a return value.
|
|
11
|
-
* If omitted, the first argument given to the returned wrapper-function is
|
|
12
|
-
* passed through.
|
|
13
|
-
* @return {function} A function that calls `mightBeAFunction` if it’s a
|
|
14
|
-
* function, and if not, returns a value as defined by `elseReturn`.
|
|
15
|
-
*/
|
|
16
|
-
module.exports = function PossibleFunction (mightBeAFunction, elseReturn) {
|
|
17
|
-
if (this instanceof PossibleFunction) {
|
|
18
|
-
throw new TypeError('PossibleFunction is not a constructor')
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
if (Array.isArray(mightBeAFunction) && mightBeAFunction.length === 2) {
|
|
22
|
-
const [object, functionName] = mightBeAFunction
|
|
23
|
-
if (typeof object === 'object' && typeof functionName === 'string' && typeof object[functionName] === 'function') {
|
|
24
|
-
mightBeAFunction = object[functionName].bind(object)
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
return function () {
|
|
29
|
-
if (typeof mightBeAFunction === 'function') {
|
|
30
|
-
return mightBeAFunction(...arguments)
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
if (typeof elseReturn === 'undefined' && arguments.length > 0) {
|
|
34
|
-
return arguments[0]
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
if (typeof elseReturn === 'function') {
|
|
38
|
-
return elseReturn(...arguments)
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
return elseReturn
|
|
42
|
-
}
|
|
43
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
MIT License
|
|
2
|
-
|
|
3
|
-
Copyright ©2017 John Lamansky
|
|
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.
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "possible-function",
|
|
3
|
-
"version": "1.0.1",
|
|
4
|
-
"description": "Defines fallback behavior in case a variable is not a function. Perfect for optional callback parameters.",
|
|
5
|
-
"keywords": [
|
|
6
|
-
"function",
|
|
7
|
-
"callback",
|
|
8
|
-
"filter",
|
|
9
|
-
"optional",
|
|
10
|
-
"fallback",
|
|
11
|
-
"wrapper"
|
|
12
|
-
],
|
|
13
|
-
"author": "John Lamansky",
|
|
14
|
-
"license": "MIT",
|
|
15
|
-
"homepage": "https://github.com/lamansky/possible-function",
|
|
16
|
-
"repository": "lamansky/possible-function",
|
|
17
|
-
"main": "index.js",
|
|
18
|
-
"engines": {
|
|
19
|
-
"node": ">=5.0.0"
|
|
20
|
-
},
|
|
21
|
-
"devDependencies": {
|
|
22
|
-
"eslint-config-lamansky": "^1.0.0",
|
|
23
|
-
"mocha": "^3.2.0"
|
|
24
|
-
},
|
|
25
|
-
"scripts": {
|
|
26
|
-
"test": "mocha"
|
|
27
|
-
},
|
|
28
|
-
"eslintConfig": {
|
|
29
|
-
"extends": "lamansky",
|
|
30
|
-
"env": {
|
|
31
|
-
"mocha": true
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
}
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
# possible-function
|
|
2
|
-
|
|
3
|
-
Defines fallback behavior in case a variable is not a function. Perfect for optional callback parameters. Packaged as a [Node.js](https://nodejs.org/) module.
|
|
4
|
-
|
|
5
|
-
## Installation
|
|
6
|
-
|
|
7
|
-
```
|
|
8
|
-
npm install possible-function --save
|
|
9
|
-
```
|
|
10
|
-
|
|
11
|
-
The module exposes a single factory function.
|
|
12
|
-
|
|
13
|
-
## Usage
|
|
14
|
-
|
|
15
|
-
`PossibleFunction` wraps a value that may or may be a function. If the underlying value is not a function, then the `PossibleFunction` wrapper will execute one of the following fallback behaviors.
|
|
16
|
-
|
|
17
|
-
### Passthrough Fallback
|
|
18
|
-
|
|
19
|
-
If the wrapped value turns out to not be a function, the wrapping function will, by default, pass through whatever is given as the first argument. This is useful for optional filters.
|
|
20
|
-
|
|
21
|
-
```javascript
|
|
22
|
-
const PossibleFunction = require('possible-function')
|
|
23
|
-
|
|
24
|
-
function sayHello (name, filter) {
|
|
25
|
-
filter = PossibleFunction(filter)
|
|
26
|
-
return filter('Hello, ' + name)
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
// No filter is provided, so the hello message is returned without change:
|
|
30
|
-
sayHello('world') // 'Hello, world'
|
|
31
|
-
|
|
32
|
-
// A filter is provided which changes the hello message:
|
|
33
|
-
sayHello('world', m => m + '!!') // 'Hello, world!!'
|
|
34
|
-
```
|
|
35
|
-
|
|
36
|
-
### Return-Value Fallback
|
|
37
|
-
|
|
38
|
-
If the wrapped value turns out to not be a function, the wrapping function can be configured to return a value of your choosing.
|
|
39
|
-
|
|
40
|
-
```javascript
|
|
41
|
-
const PossibleFunction = require('possible-function')
|
|
42
|
-
|
|
43
|
-
function sayHello (nameCallback) {
|
|
44
|
-
nameCallback = PossibleFunction(nameCallback, 'world')
|
|
45
|
-
return 'Hello, ' + nameCallback()
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
sayHello() // 'Hello, world'
|
|
49
|
-
sayHello(() => 'Dolly') // 'Hello, Dolly'
|
|
50
|
-
```
|
|
51
|
-
|
|
52
|
-
### Self Fallback
|
|
53
|
-
|
|
54
|
-
If you provide the possible function as its own fallback, then you can accept either a value or a function as an argument for your code. For example, the `sayHello` function in the following example can accept either a string or a function.
|
|
55
|
-
|
|
56
|
-
```javascript
|
|
57
|
-
const PossibleFunction = require('possible-function')
|
|
58
|
-
|
|
59
|
-
function sayHello (nameCallback) {
|
|
60
|
-
nameCallback = PossibleFunction(nameCallback, nameCallback)
|
|
61
|
-
return 'Hello, ' + nameCallback()
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
sayHello('world') // 'Hello, world'
|
|
65
|
-
sayHello(() => 'world') // 'Hello, world'
|
|
66
|
-
```
|
|
67
|
-
|
|
68
|
-
### Custom Fallback
|
|
69
|
-
|
|
70
|
-
If the wrapped value turns out to not be a function, the wrapping function can execute a custom fallback function instead:
|
|
71
|
-
|
|
72
|
-
```javascript
|
|
73
|
-
const PossibleFunction = require('possible-function')
|
|
74
|
-
const mightBeAFunction = null
|
|
75
|
-
const callback = PossibleFunction(mightBeAFunction, (...args) => args.length)
|
|
76
|
-
callback('arg 1', 'arg 2') // 2
|
|
77
|
-
```
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
'use strict'
|
|
2
|
-
|
|
3
|
-
const assert = require('assert')
|
|
4
|
-
const PossibleFunction = require('.')
|
|
5
|
-
|
|
6
|
-
describe('PossibleFunction()', function () {
|
|
7
|
-
it('should call the underlying value if it’s a function', function (done) {
|
|
8
|
-
PossibleFunction(done)()
|
|
9
|
-
})
|
|
10
|
-
|
|
11
|
-
it('should pass through the first argument if wrapped value is not a function', function () {
|
|
12
|
-
assert.strictEqual(PossibleFunction(null)('test'), 'test')
|
|
13
|
-
})
|
|
14
|
-
|
|
15
|
-
it('should return fallback value if wrapped value is not a function', function () {
|
|
16
|
-
assert.strictEqual(PossibleFunction(null, 'fallback')('test'), 'fallback')
|
|
17
|
-
})
|
|
18
|
-
|
|
19
|
-
it('should support class method arrays', function (done) {
|
|
20
|
-
class Test {
|
|
21
|
-
example (arg) {
|
|
22
|
-
if (arg && this instanceof Test) done()
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
const test = new Test()
|
|
26
|
-
PossibleFunction([test, 'example'])(true)
|
|
27
|
-
})
|
|
28
|
-
|
|
29
|
-
it('should support a fallback function', function () {
|
|
30
|
-
assert.strictEqual(PossibleFunction(null, arg => arg ? 'yes' : 'no')(true), 'yes')
|
|
31
|
-
})
|
|
32
|
-
})
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
'use strict'
|
|
2
|
-
|
|
3
|
-
const pfn = require('pfn')
|
|
4
|
-
const wfn = require('wfn')
|
|
5
|
-
|
|
6
|
-
module.exports = (fn, test = false) => {
|
|
7
|
-
test = pfn(test, test)
|
|
8
|
-
return wfn(fn, function qfn () {
|
|
9
|
-
return test.apply(this, arguments) ? fn.apply(this, arguments) : arguments[0]
|
|
10
|
-
})
|
|
11
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
MIT License
|
|
2
|
-
|
|
3
|
-
Copyright ©2018 John Lamansky
|
|
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.
|