decoders 2.0.0-beta5 → 2.0.0-beta9

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.
Files changed (139) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/NotSupportedTSVersion.d.ts +1 -0
  3. package/README.md +934 -387
  4. package/_guard.d.ts +7 -0
  5. package/_guard.js +2 -6
  6. package/_guard.js.flow +3 -3
  7. package/{_esm/_guard.js → _guard.mjs} +3 -3
  8. package/_types.d.ts +13 -0
  9. package/{_esm/_types.js → _types.mjs} +0 -0
  10. package/_utils.d.ts +10 -0
  11. package/_utils.js +1 -1
  12. package/_utils.js.flow +3 -3
  13. package/{_esm/_utils.js → _utils.mjs} +1 -1
  14. package/annotate.d.ts +62 -0
  15. package/{_esm/annotate.js → annotate.mjs} +0 -0
  16. package/core/_helpers.d.ts +79 -0
  17. package/core/array.d.ts +8 -0
  18. package/core/array.js +19 -12
  19. package/core/array.js.flow +15 -11
  20. package/{_esm/core/array.js → core/array.mjs} +19 -10
  21. package/core/boolean.d.ts +5 -0
  22. package/core/boolean.js +5 -9
  23. package/core/boolean.js.flow +5 -7
  24. package/{_esm/core/boolean.js → core/boolean.mjs} +7 -7
  25. package/core/composition.d.ts +18 -0
  26. package/core/composition.js +41 -15
  27. package/core/composition.js.flow +41 -10
  28. package/core/composition.mjs +70 -0
  29. package/core/constants.d.ts +11 -0
  30. package/core/constants.js +6 -10
  31. package/core/constants.js.flow +7 -9
  32. package/{_esm/core/constants.js → core/constants.mjs} +7 -7
  33. package/core/date.d.ts +4 -0
  34. package/core/date.js +5 -9
  35. package/core/date.js.flow +4 -6
  36. package/{_esm/core/date.js → core/date.mjs} +7 -7
  37. package/core/describe.d.ts +3 -0
  38. package/core/describe.js +2 -6
  39. package/core/describe.js.flow +2 -2
  40. package/{_esm/core/describe.js → core/describe.mjs} +3 -3
  41. package/core/dispatch.d.ts +8 -0
  42. package/core/dispatch.js +11 -13
  43. package/core/dispatch.js.flow +13 -12
  44. package/{_esm/core/dispatch.js → core/dispatch.mjs} +12 -11
  45. package/core/either.d.ts +66 -0
  46. package/core/either.js +34 -50
  47. package/core/either.js.flow +40 -86
  48. package/core/either.mjs +90 -0
  49. package/core/fail.d.ts +3 -0
  50. package/core/fail.js +2 -6
  51. package/core/fail.js.flow +2 -2
  52. package/{_esm/core/fail.js → core/fail.mjs} +3 -3
  53. package/core/instanceOf.d.ts +3 -0
  54. package/core/instanceOf.js +2 -6
  55. package/core/instanceOf.js.flow +3 -3
  56. package/core/instanceOf.mjs +8 -0
  57. package/core/json.d.ts +11 -0
  58. package/core/json.js +3 -3
  59. package/core/json.js.flow +3 -3
  60. package/core/json.mjs +15 -0
  61. package/core/lazy.d.ts +3 -0
  62. package/{_esm/core/lazy.js → core/lazy.mjs} +0 -0
  63. package/core/number.d.ts +6 -0
  64. package/core/number.js +9 -13
  65. package/core/number.js.flow +18 -12
  66. package/core/number.mjs +25 -0
  67. package/core/object.d.ts +38 -0
  68. package/core/object.js +66 -13
  69. package/core/object.js.flow +84 -28
  70. package/{_esm/core/object.js → core/object.mjs} +64 -11
  71. package/core/optional.d.ts +5 -0
  72. package/core/optional.js +4 -8
  73. package/core/optional.js.flow +3 -3
  74. package/{_esm/core/optional.js → core/optional.mjs} +6 -6
  75. package/core/string.d.ts +13 -0
  76. package/core/string.js +31 -49
  77. package/core/string.js.flow +29 -39
  78. package/core/string.mjs +58 -0
  79. package/core/tuple.d.ts +30 -0
  80. package/core/tuple.js +30 -149
  81. package/core/tuple.js.flow +33 -197
  82. package/core/tuple.mjs +45 -0
  83. package/format.d.ts +4 -0
  84. package/{format/inline.js → format.js} +6 -1
  85. package/{_esm/format/inline.js.flow → format.js.flow} +6 -2
  86. package/{_esm/format/inline.js → format.mjs} +4 -1
  87. package/index.d.ts +42 -0
  88. package/index.js +33 -42
  89. package/index.js.flow +17 -18
  90. package/{_esm/index.js → index.mjs} +18 -19
  91. package/package.json +15 -3
  92. package/result.d.ts +39 -0
  93. package/result.js +9 -90
  94. package/result.js.flow +11 -87
  95. package/result.mjs +81 -0
  96. package/_esm/_guard.js.flow +0 -20
  97. package/_esm/_types.js.flow +0 -20
  98. package/_esm/_utils.js.flow +0 -97
  99. package/_esm/annotate.js.flow +0 -218
  100. package/_esm/core/array.js.flow +0 -103
  101. package/_esm/core/boolean.js.flow +0 -29
  102. package/_esm/core/composition.js +0 -42
  103. package/_esm/core/composition.js.flow +0 -43
  104. package/_esm/core/constants.js.flow +0 -46
  105. package/_esm/core/date.js.flow +0 -40
  106. package/_esm/core/describe.js.flow +0 -17
  107. package/_esm/core/dispatch.js.flow +0 -58
  108. package/_esm/core/either.js +0 -90
  109. package/_esm/core/either.js.flow +0 -151
  110. package/_esm/core/fail.js.flow +0 -12
  111. package/_esm/core/instanceOf.js +0 -8
  112. package/_esm/core/instanceOf.js.flow +0 -20
  113. package/_esm/core/json.js +0 -15
  114. package/_esm/core/json.js.flow +0 -28
  115. package/_esm/core/lazy.js.flow +0 -15
  116. package/_esm/core/mapping.js +0 -54
  117. package/_esm/core/mapping.js.flow +0 -54
  118. package/_esm/core/number.js +0 -25
  119. package/_esm/core/number.js.flow +0 -34
  120. package/_esm/core/object.js.flow +0 -203
  121. package/_esm/core/optional.js.flow +0 -41
  122. package/_esm/core/string.js +0 -76
  123. package/_esm/core/string.js.flow +0 -82
  124. package/_esm/core/tuple.js +0 -155
  125. package/_esm/core/tuple.js.flow +0 -215
  126. package/_esm/format/index.js +0 -2
  127. package/_esm/format/index.js.flow +0 -4
  128. package/_esm/format/short.js +0 -4
  129. package/_esm/format/short.js.flow +0 -8
  130. package/_esm/index.js.flow +0 -63
  131. package/_esm/result.js +0 -148
  132. package/_esm/result.js.flow +0 -174
  133. package/core/mapping.js +0 -67
  134. package/core/mapping.js.flow +0 -54
  135. package/format/index.js +0 -12
  136. package/format/index.js.flow +0 -4
  137. package/format/inline.js.flow +0 -122
  138. package/format/short.js +0 -10
  139. package/format/short.js.flow +0 -8
package/core/tuple.js CHANGED
@@ -1,12 +1,7 @@
1
1
  "use strict";
2
2
 
3
3
  exports.__esModule = true;
4
- exports.tuple1 = tuple1;
5
- exports.tuple2 = tuple2;
6
- exports.tuple3 = tuple3;
7
- exports.tuple4 = tuple4;
8
- exports.tuple5 = tuple5;
9
- exports.tuple6 = tuple6;
4
+ exports.tuple = void 0;
10
5
 
11
6
  var _annotate = require("../annotate");
12
7
 
@@ -17,157 +12,43 @@ var _result = require("../result");
17
12
  var _array = require("./array");
18
13
 
19
14
  var ntuple = function ntuple(n) {
20
- return (0, _composition.compose)(_array.poja, (0, _composition.predicate)(function (arr) {
15
+ return (0, _composition.predicate)(_array.poja, function (arr) {
21
16
  return arr.length === n;
22
- }, "Must be a " + n + "-tuple"));
23
- };
24
- /**
25
- * Builds a Decoder that returns Ok for 1-tuple of [T], given a Decoder for T.
26
- * Err otherwise.
27
- */
17
+ }, "Must be a " + n + "-tuple");
18
+ }; // prettier-ignore
28
19
 
29
20
 
30
- function tuple1(decoder1) {
31
- return (0, _composition.compose)(ntuple(1), function (blobs) {
32
- var blob1 = blobs[0];
33
- var result1 = decoder1(blob1);
34
-
35
- try {
36
- return (0, _result.ok)([(0, _result.unwrap)(result1)]);
37
- } catch (e) {
38
- // If a decoder error has happened while unwrapping all the
39
- // results, try to construct a good error message
40
- return (0, _result.err)((0, _annotate.annotate)([(0, _result.okOrErrValue)(result1)]));
41
- }
42
- });
43
- }
44
21
  /**
45
- * Builds a Decoder that returns Ok for 2-tuples of [T1, T2], given Decoders
46
- * for T1 and T2. Err otherwise.
22
+ * Accepts n-tuples [A, B, C, ...] matching the given decoders A, B, C, ...
47
23
  */
48
-
49
-
50
- function tuple2(decoder1, decoder2) {
51
- return (0, _composition.compose)(ntuple(2), function (blobs) {
52
- var blob1 = blobs[0],
53
- blob2 = blobs[1];
54
- var result1 = decoder1(blob1);
55
- var result2 = decoder2(blob2);
56
-
57
- try {
58
- return (0, _result.ok)([(0, _result.unwrap)(result1), (0, _result.unwrap)(result2)]);
59
- } catch (e) {
24
+ function _tuple() {
25
+ for (var _len = arguments.length, decoders = new Array(_len), _key = 0; _key < _len; _key++) {
26
+ decoders[_key] = arguments[_key];
27
+ }
28
+
29
+ return (0, _composition.compose)(ntuple(decoders.length), function (blobs) {
30
+ var allOk = true;
31
+ var rvs = decoders.map(function (decoder, i) {
32
+ var blob = blobs[i];
33
+ var result = decoder(blob);
34
+
35
+ if (result.ok) {
36
+ return result.value;
37
+ } else {
38
+ allOk = false;
39
+ return result.error;
40
+ }
41
+ });
42
+
43
+ if (allOk) {
44
+ return (0, _result.ok)(rvs);
45
+ } else {
60
46
  // If a decoder error has happened while unwrapping all the
61
47
  // results, try to construct a good error message
62
- return (0, _result.err)((0, _annotate.annotate)([(0, _result.okOrErrValue)(result1), (0, _result.okOrErrValue)(result2)]));
48
+ return (0, _result.err)((0, _annotate.annotate)(rvs));
63
49
  }
64
50
  });
65
51
  }
66
- /**
67
- * Builds a Decoder that returns Ok for 3-tuples of [T1, T2, T3], given
68
- * Decoders for T1, T2, and T3. Err otherwise.
69
- */
70
-
71
-
72
- function tuple3(decoder1, decoder2, decoder3) {
73
- return (0, _composition.compose)(ntuple(3), function (blobs) {
74
- var blob1 = blobs[0],
75
- blob2 = blobs[1],
76
- blob3 = blobs[2];
77
- var result1 = decoder1(blob1);
78
- var result2 = decoder2(blob2);
79
- var result3 = decoder3(blob3);
80
-
81
- try {
82
- return (0, _result.ok)([(0, _result.unwrap)(result1), (0, _result.unwrap)(result2), (0, _result.unwrap)(result3)]);
83
- } catch (e) {
84
- // If a decoder error has happened while unwrapping all the
85
- // results, try to construct a good error message
86
- return (0, _result.err)((0, _annotate.annotate)([(0, _result.okOrErrValue)(result1), (0, _result.okOrErrValue)(result2), (0, _result.okOrErrValue)(result3)]));
87
- }
88
- });
89
- }
90
- /**
91
- * Builds a Decoder that returns Ok for 4-tuples of [T1, T2, T3, T4], given
92
- * Decoders for T1, T2, T3, and T4. Err otherwise.
93
- */
94
-
95
-
96
- function tuple4(decoder1, decoder2, decoder3, decoder4) {
97
- return (0, _composition.compose)(ntuple(4), function (blobs) {
98
- var blob1 = blobs[0],
99
- blob2 = blobs[1],
100
- blob3 = blobs[2],
101
- blob4 = blobs[3];
102
- var result1 = decoder1(blob1);
103
- var result2 = decoder2(blob2);
104
- var result3 = decoder3(blob3);
105
- var result4 = decoder4(blob4);
106
52
 
107
- try {
108
- return (0, _result.ok)([(0, _result.unwrap)(result1), (0, _result.unwrap)(result2), (0, _result.unwrap)(result3), (0, _result.unwrap)(result4)]);
109
- } catch (e) {
110
- // If a decoder error has happened while unwrapping all the
111
- // results, try to construct a good error message
112
- return (0, _result.err)((0, _annotate.annotate)([(0, _result.okOrErrValue)(result1), (0, _result.okOrErrValue)(result2), (0, _result.okOrErrValue)(result3), (0, _result.okOrErrValue)(result4)]));
113
- }
114
- });
115
- }
116
- /**
117
- * Builds a Decoder that returns Ok for 5-tuples of [T1, T2, T3, T4, T5], given
118
- * Decoders for T1, T2, T3, T4, and T5. Err otherwise.
119
- */
120
-
121
-
122
- function tuple5(decoder1, decoder2, decoder3, decoder4, decoder5) {
123
- return (0, _composition.compose)(ntuple(5), function (blobs) {
124
- var blob1 = blobs[0],
125
- blob2 = blobs[1],
126
- blob3 = blobs[2],
127
- blob4 = blobs[3],
128
- blob5 = blobs[4];
129
- var result1 = decoder1(blob1);
130
- var result2 = decoder2(blob2);
131
- var result3 = decoder3(blob3);
132
- var result4 = decoder4(blob4);
133
- var result5 = decoder5(blob5);
134
-
135
- try {
136
- return (0, _result.ok)([(0, _result.unwrap)(result1), (0, _result.unwrap)(result2), (0, _result.unwrap)(result3), (0, _result.unwrap)(result4), (0, _result.unwrap)(result5)]);
137
- } catch (e) {
138
- // If a decoder error has happened while unwrapping all the
139
- // results, try to construct a good error message
140
- return (0, _result.err)((0, _annotate.annotate)([(0, _result.okOrErrValue)(result1), (0, _result.okOrErrValue)(result2), (0, _result.okOrErrValue)(result3), (0, _result.okOrErrValue)(result4), (0, _result.okOrErrValue)(result5)]));
141
- }
142
- });
143
- }
144
- /**
145
- * Builds a Decoder that returns Ok for 5-tuples of [T1, T2, T3, T4, T5], given
146
- * Decoders for T1, T2, T3, T4, T5, and T6. Err otherwise.
147
- */
148
-
149
-
150
- function tuple6(decoder1, decoder2, decoder3, decoder4, decoder5, decoder6) {
151
- return (0, _composition.compose)(ntuple(6), function (blobs) {
152
- var blob1 = blobs[0],
153
- blob2 = blobs[1],
154
- blob3 = blobs[2],
155
- blob4 = blobs[3],
156
- blob5 = blobs[4],
157
- blob6 = blobs[5];
158
- var result1 = decoder1(blob1);
159
- var result2 = decoder2(blob2);
160
- var result3 = decoder3(blob3);
161
- var result4 = decoder4(blob4);
162
- var result5 = decoder5(blob5);
163
- var result6 = decoder6(blob6);
164
-
165
- try {
166
- return (0, _result.ok)([(0, _result.unwrap)(result1), (0, _result.unwrap)(result2), (0, _result.unwrap)(result3), (0, _result.unwrap)(result4), (0, _result.unwrap)(result5), (0, _result.unwrap)(result6)]);
167
- } catch (e) {
168
- // If a decoder error has happened while unwrapping all the
169
- // results, try to construct a good error message
170
- return (0, _result.err)((0, _annotate.annotate)([(0, _result.okOrErrValue)(result1), (0, _result.okOrErrValue)(result2), (0, _result.okOrErrValue)(result3), (0, _result.okOrErrValue)(result4), (0, _result.okOrErrValue)(result5), (0, _result.okOrErrValue)(result6)]));
171
- }
172
- });
173
- }
53
+ var tuple = _tuple;
54
+ exports.tuple = tuple;
@@ -2,214 +2,50 @@
2
2
 
3
3
  import { annotate } from '../annotate';
4
4
  import { compose, predicate } from './composition';
5
- import { err, ok, okOrErrValue, unwrap } from '../result';
5
+ import { err, ok } from '../result';
6
6
  import { poja } from './array';
7
+ import type { _Any } from '../_utils';
7
8
  import type { Decoder } from '../_types';
8
9
 
9
10
  const ntuple = (n: number) =>
10
- compose(
11
- poja,
12
- predicate((arr) => arr.length === n, `Must be a ${n}-tuple`),
13
- );
14
-
15
- /**
16
- * Builds a Decoder that returns Ok for 1-tuple of [T], given a Decoder for T.
17
- * Err otherwise.
18
- */
19
- export function tuple1<T>(decoder1: Decoder<T>): Decoder<[T]> {
20
- return compose(ntuple(1), (blobs: $ReadOnlyArray<mixed>) => {
21
- const [blob1] = blobs;
22
-
23
- const result1 = decoder1(blob1);
24
- try {
25
- return ok([unwrap(result1)]);
26
- } catch (e) {
27
- // If a decoder error has happened while unwrapping all the
28
- // results, try to construct a good error message
29
- return err(annotate([okOrErrValue(result1)]));
30
- }
31
- });
32
- }
33
-
34
- /**
35
- * Builds a Decoder that returns Ok for 2-tuples of [T1, T2], given Decoders
36
- * for T1 and T2. Err otherwise.
37
- */
38
- export function tuple2<T1, T2>(
39
- decoder1: Decoder<T1>,
40
- decoder2: Decoder<T2>,
41
- ): Decoder<[T1, T2]> {
42
- return compose(ntuple(2), (blobs: $ReadOnlyArray<mixed>) => {
43
- const [blob1, blob2] = blobs;
44
-
45
- const result1 = decoder1(blob1);
46
- const result2 = decoder2(blob2);
47
- try {
48
- return ok([unwrap(result1), unwrap(result2)]);
49
- } catch (e) {
50
- // If a decoder error has happened while unwrapping all the
51
- // results, try to construct a good error message
52
- return err(annotate([okOrErrValue(result1), okOrErrValue(result2)]));
53
- }
54
- });
55
- }
56
-
57
- /**
58
- * Builds a Decoder that returns Ok for 3-tuples of [T1, T2, T3], given
59
- * Decoders for T1, T2, and T3. Err otherwise.
60
- */
61
- export function tuple3<T1, T2, T3>(
62
- decoder1: Decoder<T1>,
63
- decoder2: Decoder<T2>,
64
- decoder3: Decoder<T3>,
65
- ): Decoder<[T1, T2, T3]> {
66
- return compose(ntuple(3), (blobs: $ReadOnlyArray<mixed>) => {
67
- const [blob1, blob2, blob3] = blobs;
68
-
69
- const result1 = decoder1(blob1);
70
- const result2 = decoder2(blob2);
71
- const result3 = decoder3(blob3);
72
- try {
73
- return ok([unwrap(result1), unwrap(result2), unwrap(result3)]);
74
- } catch (e) {
75
- // If a decoder error has happened while unwrapping all the
76
- // results, try to construct a good error message
77
- return err(
78
- annotate([
79
- okOrErrValue(result1),
80
- okOrErrValue(result2),
81
- okOrErrValue(result3),
82
- ]),
83
- );
84
- }
85
- });
86
- }
87
-
88
- /**
89
- * Builds a Decoder that returns Ok for 4-tuples of [T1, T2, T3, T4], given
90
- * Decoders for T1, T2, T3, and T4. Err otherwise.
91
- */
92
- export function tuple4<T1, T2, T3, T4>(
93
- decoder1: Decoder<T1>,
94
- decoder2: Decoder<T2>,
95
- decoder3: Decoder<T3>,
96
- decoder4: Decoder<T4>,
97
- ): Decoder<[T1, T2, T3, T4]> {
98
- return compose(ntuple(4), (blobs: $ReadOnlyArray<mixed>) => {
99
- const [blob1, blob2, blob3, blob4] = blobs;
100
-
101
- const result1 = decoder1(blob1);
102
- const result2 = decoder2(blob2);
103
- const result3 = decoder3(blob3);
104
- const result4 = decoder4(blob4);
105
- try {
106
- return ok([
107
- unwrap(result1),
108
- unwrap(result2),
109
- unwrap(result3),
110
- unwrap(result4),
111
- ]);
112
- } catch (e) {
113
- // If a decoder error has happened while unwrapping all the
114
- // results, try to construct a good error message
115
- return err(
116
- annotate([
117
- okOrErrValue(result1),
118
- okOrErrValue(result2),
119
- okOrErrValue(result3),
120
- okOrErrValue(result4),
121
- ]),
122
- );
123
- }
124
- });
11
+ predicate(poja, (arr) => arr.length === n, `Must be a ${n}-tuple`);
12
+
13
+ // prettier-ignore
14
+ interface TupleFuncSignature {
15
+ <A>(a: Decoder<A>): Decoder<[A]>;
16
+ <A, B>(a: Decoder<A>, b: Decoder<B>): Decoder<[A, B]>;
17
+ <A, B, C>(a: Decoder<A>, b: Decoder<B>, c: Decoder<C>): Decoder<[A, B, C]>;
18
+ <A, B, C, D>(a: Decoder<A>, b: Decoder<B>, c: Decoder<C>, d: Decoder<D>): Decoder<[A, B, C, D]>;
19
+ <A, B, C, D, E>(a: Decoder<A>, b: Decoder<B>, c: Decoder<C>, d: Decoder<D>, e: Decoder<E>): Decoder<[A, B, C, D, E]>;
20
+ <A, B, C, D, E, F>(a: Decoder<A>, b: Decoder<B>, c: Decoder<C>, d: Decoder<D>, e: Decoder<E>, f: Decoder<F>): Decoder<[A, B, C, D, E, F]>;
125
21
  }
126
22
 
127
23
  /**
128
- * Builds a Decoder that returns Ok for 5-tuples of [T1, T2, T3, T4, T5], given
129
- * Decoders for T1, T2, T3, T4, and T5. Err otherwise.
24
+ * Accepts n-tuples [A, B, C, ...] matching the given decoders A, B, C, ...
130
25
  */
131
- export function tuple5<T1, T2, T3, T4, T5>(
132
- decoder1: Decoder<T1>,
133
- decoder2: Decoder<T2>,
134
- decoder3: Decoder<T3>,
135
- decoder4: Decoder<T4>,
136
- decoder5: Decoder<T5>,
137
- ): Decoder<[T1, T2, T3, T4, T5]> {
138
- return compose(ntuple(5), (blobs: $ReadOnlyArray<mixed>) => {
139
- const [blob1, blob2, blob3, blob4, blob5] = blobs;
140
-
141
- const result1 = decoder1(blob1);
142
- const result2 = decoder2(blob2);
143
- const result3 = decoder3(blob3);
144
- const result4 = decoder4(blob4);
145
- const result5 = decoder5(blob5);
146
- try {
147
- return ok([
148
- unwrap(result1),
149
- unwrap(result2),
150
- unwrap(result3),
151
- unwrap(result4),
152
- unwrap(result5),
153
- ]);
154
- } catch (e) {
26
+ function _tuple(...decoders: $ReadOnlyArray<Decoder<mixed>>): Decoder<mixed> {
27
+ return compose(ntuple(decoders.length), (blobs: $ReadOnlyArray<mixed>) => {
28
+ let allOk = true;
29
+
30
+ const rvs = decoders.map((decoder, i) => {
31
+ const blob = blobs[i];
32
+ const result = decoder(blob);
33
+ if (result.ok) {
34
+ return result.value;
35
+ } else {
36
+ allOk = false;
37
+ return result.error;
38
+ }
39
+ });
40
+
41
+ if (allOk) {
42
+ return ok(rvs);
43
+ } else {
155
44
  // If a decoder error has happened while unwrapping all the
156
45
  // results, try to construct a good error message
157
- return err(
158
- annotate([
159
- okOrErrValue(result1),
160
- okOrErrValue(result2),
161
- okOrErrValue(result3),
162
- okOrErrValue(result4),
163
- okOrErrValue(result5),
164
- ]),
165
- );
46
+ return err(annotate(rvs));
166
47
  }
167
48
  });
168
49
  }
169
50
 
170
- /**
171
- * Builds a Decoder that returns Ok for 5-tuples of [T1, T2, T3, T4, T5], given
172
- * Decoders for T1, T2, T3, T4, T5, and T6. Err otherwise.
173
- */
174
- export function tuple6<T1, T2, T3, T4, T5, T6>(
175
- decoder1: Decoder<T1>,
176
- decoder2: Decoder<T2>,
177
- decoder3: Decoder<T3>,
178
- decoder4: Decoder<T4>,
179
- decoder5: Decoder<T5>,
180
- decoder6: Decoder<T6>,
181
- ): Decoder<[T1, T2, T3, T4, T5, T6]> {
182
- return compose(ntuple(6), (blobs: $ReadOnlyArray<mixed>) => {
183
- const [blob1, blob2, blob3, blob4, blob5, blob6] = blobs;
184
-
185
- const result1 = decoder1(blob1);
186
- const result2 = decoder2(blob2);
187
- const result3 = decoder3(blob3);
188
- const result4 = decoder4(blob4);
189
- const result5 = decoder5(blob5);
190
- const result6 = decoder6(blob6);
191
- try {
192
- return ok([
193
- unwrap(result1),
194
- unwrap(result2),
195
- unwrap(result3),
196
- unwrap(result4),
197
- unwrap(result5),
198
- unwrap(result6),
199
- ]);
200
- } catch (e) {
201
- // If a decoder error has happened while unwrapping all the
202
- // results, try to construct a good error message
203
- return err(
204
- annotate([
205
- okOrErrValue(result1),
206
- okOrErrValue(result2),
207
- okOrErrValue(result3),
208
- okOrErrValue(result4),
209
- okOrErrValue(result5),
210
- okOrErrValue(result6),
211
- ]),
212
- );
213
- }
214
- });
215
- }
51
+ export const tuple: TupleFuncSignature = (_tuple: _Any);
package/core/tuple.mjs ADDED
@@ -0,0 +1,45 @@
1
+ import { annotate } from '../annotate.mjs';
2
+ import { compose, predicate } from './composition.mjs';
3
+ import { err, ok } from '../result.mjs';
4
+ import { poja } from './array.mjs';
5
+
6
+ var ntuple = function ntuple(n) {
7
+ return predicate(poja, function (arr) {
8
+ return arr.length === n;
9
+ }, "Must be a " + n + "-tuple");
10
+ }; // prettier-ignore
11
+
12
+
13
+ /**
14
+ * Accepts n-tuples [A, B, C, ...] matching the given decoders A, B, C, ...
15
+ */
16
+ function _tuple() {
17
+ for (var _len = arguments.length, decoders = new Array(_len), _key = 0; _key < _len; _key++) {
18
+ decoders[_key] = arguments[_key];
19
+ }
20
+
21
+ return compose(ntuple(decoders.length), function (blobs) {
22
+ var allOk = true;
23
+ var rvs = decoders.map(function (decoder, i) {
24
+ var blob = blobs[i];
25
+ var result = decoder(blob);
26
+
27
+ if (result.ok) {
28
+ return result.value;
29
+ } else {
30
+ allOk = false;
31
+ return result.error;
32
+ }
33
+ });
34
+
35
+ if (allOk) {
36
+ return ok(rvs);
37
+ } else {
38
+ // If a decoder error has happened while unwrapping all the
39
+ // results, try to construct a good error message
40
+ return err(annotate(rvs));
41
+ }
42
+ });
43
+ }
44
+
45
+ export var tuple = _tuple;
package/format.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ import { Annotation } from './annotate';
2
+
3
+ export function formatInline(ann: Annotation): string;
4
+ export function formatShort(ann: Annotation): string;
@@ -2,10 +2,11 @@
2
2
 
3
3
  exports.__esModule = true;
4
4
  exports.formatInline = formatInline;
5
+ exports.formatShort = formatShort;
5
6
  exports.serializeAnnotation = serializeAnnotation;
6
7
  exports.serializeValue = serializeValue;
7
8
 
8
- var _utils = require("../_utils");
9
+ var _utils = require("./_utils");
9
10
 
10
11
  function serializeString(s, width) {
11
12
  if (width === void 0) {
@@ -143,4 +144,8 @@ function formatInline(ann) {
143
144
  } else {
144
145
  return serialized;
145
146
  }
147
+ }
148
+
149
+ function formatShort(ann) {
150
+ return (0, _utils.summarize)(ann, []).join('\n');
146
151
  }
@@ -1,7 +1,7 @@
1
1
  // @flow strict
2
2
 
3
- import { asDate, indent, INDENT, isMultiline } from '../_utils';
4
- import type { Annotation, ArrayAnnotation, ObjectAnnotation } from '../annotate';
3
+ import { summarize as _summarize, asDate, INDENT, indent, isMultiline } from './_utils';
4
+ import type { Annotation, ArrayAnnotation, ObjectAnnotation } from './annotate';
5
5
 
6
6
  function serializeString(s: string, width: number = 80): string {
7
7
  // Full string
@@ -120,3 +120,7 @@ export function formatInline(ann: Annotation): string {
120
120
  return serialized;
121
121
  }
122
122
  }
123
+
124
+ export function formatShort(ann: Annotation): string {
125
+ return _summarize(ann, []).join('\n');
126
+ }
@@ -1,4 +1,4 @@
1
- import { asDate, indent, INDENT, isMultiline } from '../_utils';
1
+ import { summarize as _summarize, asDate, INDENT, indent, isMultiline } from './_utils.mjs';
2
2
 
3
3
  function serializeString(s, width) {
4
4
  if (width === void 0) {
@@ -134,4 +134,7 @@ export function formatInline(ann) {
134
134
  } else {
135
135
  return serialized;
136
136
  }
137
+ }
138
+ export function formatShort(ann) {
139
+ return _summarize(ann, []).join('\n');
137
140
  }
package/index.d.ts ADDED
@@ -0,0 +1,42 @@
1
+ export {
2
+ Decoder,
3
+ DecodeResult,
4
+ DecoderType,
5
+ Guard,
6
+ GuardType,
7
+ Predicate,
8
+ Scalar,
9
+ } from './_types';
10
+ export { Result } from './result';
11
+ export { JSONValue, JSONObject, JSONArray } from './core/json';
12
+
13
+ export { guard } from './_guard';
14
+
15
+ export { compose, predicate, prep, transform } from './core/composition';
16
+
17
+ export { array, nonEmptyArray, poja, set } from './core/array';
18
+ export { boolean, numericBoolean, truthy } from './core/boolean';
19
+ export { constant, hardcoded, mixed, null_, undefined_, unknown } from './core/constants';
20
+ export { date, iso8601 } from './core/date';
21
+ export { describe } from './core/describe';
22
+ export { dict, exact, inexact, mapping, object, pojo } from './core/object';
23
+ export { either, oneOf } from './core/either';
24
+ export {
25
+ email,
26
+ httpsUrl,
27
+ nonEmptyString,
28
+ regex,
29
+ string,
30
+ url,
31
+ uuid,
32
+ uuidv1,
33
+ uuidv4,
34
+ } from './core/string';
35
+ export { fail } from './core/fail';
36
+ export { instanceOf } from './core/instanceOf';
37
+ export { integer, number, positiveInteger, positiveNumber } from './core/number';
38
+ export { json, jsonObject, jsonArray } from './core/json';
39
+ export { lazy } from './core/lazy';
40
+ export { maybe, nullable, optional } from './core/optional';
41
+ export { taggedUnion } from './core/dispatch';
42
+ export { tuple } from './core/tuple';