typia 5.0.0-dev.20230823 → 5.0.0-dev.2023084

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 (217) hide show
  1. package/lib/Primitive.d.ts +14 -12
  2. package/lib/Resolved.d.ts +46 -0
  3. package/lib/{schemas/metadata/IMetadataResolved.js → Resolved.js} +1 -1
  4. package/lib/Resolved.js.map +1 -0
  5. package/lib/factories/MetadataFactory.d.ts +1 -1
  6. package/lib/factories/MetadataTagFactory.js +10 -8
  7. package/lib/factories/MetadataTagFactory.js.map +1 -1
  8. package/lib/factories/ProtobufFactory.js +4 -3
  9. package/lib/factories/ProtobufFactory.js.map +1 -1
  10. package/lib/factories/internal/metadata/emend_metadata_atomics.js +6 -6
  11. package/lib/factories/internal/metadata/emend_metadata_atomics.js.map +1 -1
  12. package/lib/factories/internal/metadata/explore_metadata.js +3 -3
  13. package/lib/factories/internal/metadata/explore_metadata.js.map +1 -1
  14. package/lib/factories/internal/metadata/iterate_metadata_atomic.js +1 -1
  15. package/lib/factories/internal/metadata/iterate_metadata_atomic.js.map +1 -1
  16. package/lib/factories/internal/metadata/iterate_metadata_collection.js +6 -6
  17. package/lib/factories/internal/metadata/iterate_metadata_collection.js.map +1 -1
  18. package/lib/factories/internal/metadata/iterate_metadata_native.js +2 -10
  19. package/lib/factories/internal/metadata/iterate_metadata_native.js.map +1 -1
  20. package/lib/factories/internal/metadata/iterate_metadata_resolve.js +6 -6
  21. package/lib/factories/internal/metadata/iterate_metadata_resolve.js.map +1 -1
  22. package/lib/factories/internal/metadata/iterate_metadata_sort.js +2 -2
  23. package/lib/factories/internal/metadata/iterate_metadata_sort.js.map +1 -1
  24. package/lib/functional/$ProtobufWriter.js.map +1 -1
  25. package/lib/json.d.ts +15 -15
  26. package/lib/misc.d.ts +42 -42
  27. package/lib/module.d.ts +18 -17
  28. package/lib/module.js +1 -0
  29. package/lib/module.js.map +1 -1
  30. package/lib/programmers/AssertProgrammer.js +1 -1
  31. package/lib/programmers/AssertProgrammer.js.map +1 -1
  32. package/lib/programmers/CheckerProgrammer.js +7 -7
  33. package/lib/programmers/CheckerProgrammer.js.map +1 -1
  34. package/lib/programmers/IsProgrammer.js +2 -2
  35. package/lib/programmers/IsProgrammer.js.map +1 -1
  36. package/lib/programmers/RandomProgrammer.js +311 -136
  37. package/lib/programmers/RandomProgrammer.js.map +1 -1
  38. package/lib/programmers/ValidateProgrammer.js +1 -1
  39. package/lib/programmers/ValidateProgrammer.js.map +1 -1
  40. package/lib/programmers/helpers/AtomicPredicator.js +2 -2
  41. package/lib/programmers/helpers/AtomicPredicator.js.map +1 -1
  42. package/lib/programmers/helpers/FunctionImporeter.d.ts +2 -0
  43. package/lib/programmers/helpers/FunctionImporeter.js +2 -1
  44. package/lib/programmers/helpers/FunctionImporeter.js.map +1 -1
  45. package/lib/programmers/helpers/ProtobufUtil.js +2 -2
  46. package/lib/programmers/helpers/ProtobufUtil.js.map +1 -1
  47. package/lib/programmers/helpers/StringifyPredicator.js +1 -2
  48. package/lib/programmers/helpers/StringifyPredicator.js.map +1 -1
  49. package/lib/programmers/helpers/disable_function_importer_declare.js +1 -0
  50. package/lib/programmers/helpers/disable_function_importer_declare.js.map +1 -1
  51. package/lib/programmers/internal/application_default_string.js +2 -2
  52. package/lib/programmers/internal/application_default_string.js.map +1 -1
  53. package/lib/programmers/internal/application_resolved.d.ts +2 -2
  54. package/lib/programmers/internal/application_resolved.js.map +1 -1
  55. package/lib/programmers/internal/application_schema.js +7 -7
  56. package/lib/programmers/internal/application_schema.js.map +1 -1
  57. package/lib/programmers/internal/metadata_to_pattern.js +4 -4
  58. package/lib/programmers/internal/metadata_to_pattern.js.map +1 -1
  59. package/lib/programmers/internal/stringify_dynamic_properties.js +2 -1
  60. package/lib/programmers/internal/stringify_dynamic_properties.js.map +1 -1
  61. package/lib/programmers/json/JsonStringifyProgrammer.js +20 -14
  62. package/lib/programmers/json/JsonStringifyProgrammer.js.map +1 -1
  63. package/lib/programmers/misc/MiscAssertCloneProgrammer.js +1 -1
  64. package/lib/programmers/misc/MiscAssertCloneProgrammer.js.map +1 -1
  65. package/lib/programmers/misc/MiscCloneProgrammer.js +114 -33
  66. package/lib/programmers/misc/MiscCloneProgrammer.js.map +1 -1
  67. package/lib/programmers/misc/MiscIsCloneProgrammer.js +1 -1
  68. package/lib/programmers/misc/MiscIsCloneProgrammer.js.map +1 -1
  69. package/lib/programmers/misc/MiscLiteralsProgrammer.js +3 -3
  70. package/lib/programmers/misc/MiscLiteralsProgrammer.js.map +1 -1
  71. package/lib/programmers/misc/MiscPruneProgrammer.js +2 -2
  72. package/lib/programmers/misc/MiscPruneProgrammer.js.map +1 -1
  73. package/lib/programmers/misc/MiscValidateCloneProgrammer.js +1 -1
  74. package/lib/programmers/misc/MiscValidateCloneProgrammer.js.map +1 -1
  75. package/lib/programmers/protobuf/ProtobufAssertDecodeProgrammer.js +3 -3
  76. package/lib/programmers/protobuf/ProtobufAssertDecodeProgrammer.js.map +1 -1
  77. package/lib/programmers/protobuf/ProtobufDecodeProgrammer.js +3 -3
  78. package/lib/programmers/protobuf/ProtobufDecodeProgrammer.js.map +1 -1
  79. package/lib/programmers/protobuf/ProtobufEncodeProgrammer.js +1 -1
  80. package/lib/programmers/protobuf/ProtobufEncodeProgrammer.js.map +1 -1
  81. package/lib/programmers/protobuf/ProtobufIsDecodeProgrammer.js +2 -2
  82. package/lib/programmers/protobuf/ProtobufIsDecodeProgrammer.js.map +1 -1
  83. package/lib/programmers/protobuf/ProtobufValidateDecodeProgrammer.js +1 -1
  84. package/lib/programmers/protobuf/ProtobufValidateDecodeProgrammer.js.map +1 -1
  85. package/lib/protobuf.d.ts +631 -10
  86. package/lib/protobuf.js +13 -13
  87. package/lib/protobuf.js.map +1 -1
  88. package/lib/schemas/metadata/IMetadata.d.ts +4 -4
  89. package/lib/schemas/metadata/IMetadataAtomic.d.ts +12 -0
  90. package/lib/schemas/metadata/IMetadataAtomic.js +3 -0
  91. package/lib/schemas/metadata/IMetadataAtomic.js.map +1 -0
  92. package/lib/schemas/metadata/{IMetadataResolved.d.ts → IMetadataEscaped.d.ts} +1 -1
  93. package/lib/schemas/metadata/IMetadataEscaped.js +3 -0
  94. package/lib/schemas/metadata/IMetadataEscaped.js.map +1 -0
  95. package/lib/schemas/metadata/Metadata.d.ts +4 -4
  96. package/lib/schemas/metadata/Metadata.js +64 -59
  97. package/lib/schemas/metadata/Metadata.js.map +1 -1
  98. package/lib/schemas/metadata/{MetadataResolved.d.ts → MetadataEscaped.d.ts} +3 -3
  99. package/lib/schemas/metadata/{MetadataResolved.js → MetadataEscaped.js} +11 -11
  100. package/lib/schemas/metadata/MetadataEscaped.js.map +1 -0
  101. package/lib/tags/ExclusiveMaximum.d.ts +8 -0
  102. package/lib/tags/ExclusiveMaximum.js +3 -0
  103. package/lib/tags/ExclusiveMaximum.js.map +1 -0
  104. package/lib/tags/ExclusiveMinimum.d.ts +8 -0
  105. package/lib/tags/ExclusiveMinimum.js +3 -0
  106. package/lib/tags/ExclusiveMinimum.js.map +1 -0
  107. package/lib/tags/Format.d.ts +8 -0
  108. package/lib/tags/Format.js +3 -0
  109. package/lib/tags/Format.js.map +1 -0
  110. package/lib/tags/MaxItems.d.ts +8 -0
  111. package/lib/tags/MaxItems.js +3 -0
  112. package/lib/tags/MaxItems.js.map +1 -0
  113. package/lib/tags/MaxLength.d.ts +8 -0
  114. package/lib/tags/MaxLength.js +3 -0
  115. package/lib/tags/MaxLength.js.map +1 -0
  116. package/lib/tags/Maximum.d.ts +8 -0
  117. package/lib/tags/Maximum.js +3 -0
  118. package/lib/tags/Maximum.js.map +1 -0
  119. package/lib/tags/MinItems.d.ts +8 -0
  120. package/lib/tags/MinItems.js +3 -0
  121. package/lib/tags/MinItems.js.map +1 -0
  122. package/lib/tags/MinLength.d.ts +8 -0
  123. package/lib/tags/MinLength.js +3 -0
  124. package/lib/tags/MinLength.js.map +1 -0
  125. package/lib/tags/Minimum.d.ts +8 -0
  126. package/lib/tags/Minimum.js +3 -0
  127. package/lib/tags/Minimum.js.map +1 -0
  128. package/lib/tags/MultipleOf.d.ts +8 -0
  129. package/lib/tags/MultipleOf.js +3 -0
  130. package/lib/tags/MultipleOf.js.map +1 -0
  131. package/lib/tags/Pattern.d.ts +8 -0
  132. package/lib/tags/Pattern.js +3 -0
  133. package/lib/tags/Pattern.js.map +1 -0
  134. package/lib/tags/TagBase.d.ts +10 -0
  135. package/lib/tags/TagBase.js +3 -0
  136. package/lib/tags/TagBase.js.map +1 -0
  137. package/lib/tags/Type.d.ts +13 -0
  138. package/lib/tags/Type.js +3 -0
  139. package/lib/tags/Type.js.map +1 -0
  140. package/lib/tags/index.d.ts +12 -0
  141. package/lib/tags/index.js +29 -0
  142. package/lib/tags/index.js.map +1 -0
  143. package/lib/transformers/features/json/JsonApplicationTransformer.js +2 -2
  144. package/lib/transformers/features/json/JsonApplicationTransformer.js.map +1 -1
  145. package/lib/transformers/features/misc/MetadataTransformer.js +1 -1
  146. package/lib/transformers/features/misc/MetadataTransformer.js.map +1 -1
  147. package/lib/utils/RandomGenerator.js +3 -2
  148. package/lib/utils/RandomGenerator.js.map +1 -1
  149. package/package.json +2 -1
  150. package/src/Primitive.ts +135 -131
  151. package/src/Resolved.ts +116 -0
  152. package/src/factories/MetadataFactory.ts +46 -46
  153. package/src/factories/MetadataTagFactory.ts +366 -364
  154. package/src/factories/ProtobufFactory.ts +268 -266
  155. package/src/factories/internal/metadata/emend_metadata_atomics.ts +35 -33
  156. package/src/factories/internal/metadata/explore_metadata.ts +38 -38
  157. package/src/factories/internal/metadata/iterate_metadata_atomic.ts +63 -59
  158. package/src/factories/internal/metadata/iterate_metadata_collection.ts +133 -133
  159. package/src/factories/internal/metadata/iterate_metadata_native.ts +210 -219
  160. package/src/factories/internal/metadata/iterate_metadata_resolve.ts +49 -49
  161. package/src/factories/internal/metadata/iterate_metadata_sort.ts +69 -69
  162. package/src/functional/$ProtobufWriter.ts +151 -151
  163. package/src/json.ts +648 -648
  164. package/src/misc.ts +651 -651
  165. package/src/module.ts +709 -708
  166. package/src/programmers/AssertProgrammer.ts +281 -279
  167. package/src/programmers/CheckerProgrammer.ts +1174 -1173
  168. package/src/programmers/IsProgrammer.ts +241 -239
  169. package/src/programmers/RandomProgrammer.ts +874 -578
  170. package/src/programmers/ValidateProgrammer.ts +307 -305
  171. package/src/programmers/helpers/AtomicPredicator.ts +31 -31
  172. package/src/programmers/helpers/FunctionImporeter.ts +91 -89
  173. package/src/programmers/helpers/ProtobufUtil.ts +29 -29
  174. package/src/programmers/helpers/StringifyPredicator.ts +12 -13
  175. package/src/programmers/helpers/disable_function_importer_declare.ts +32 -27
  176. package/src/programmers/internal/application_default_string.ts +37 -33
  177. package/src/programmers/internal/application_resolved.ts +55 -55
  178. package/src/programmers/internal/application_schema.ts +157 -157
  179. package/src/programmers/internal/metadata_to_pattern.ts +34 -34
  180. package/src/programmers/internal/stringify_dynamic_properties.ts +171 -171
  181. package/src/programmers/json/JsonStringifyProgrammer.ts +995 -987
  182. package/src/programmers/misc/MiscAssertCloneProgrammer.ts +71 -71
  183. package/src/programmers/misc/MiscCloneProgrammer.ts +775 -587
  184. package/src/programmers/misc/MiscIsCloneProgrammer.ts +78 -78
  185. package/src/programmers/misc/MiscLiteralsProgrammer.ts +64 -64
  186. package/src/programmers/misc/MiscPruneProgrammer.ts +544 -542
  187. package/src/programmers/misc/MiscValidateCloneProgrammer.ts +85 -85
  188. package/src/programmers/protobuf/ProtobufAssertDecodeProgrammer.ts +75 -66
  189. package/src/programmers/protobuf/ProtobufDecodeProgrammer.ts +673 -669
  190. package/src/programmers/protobuf/ProtobufEncodeProgrammer.ts +814 -814
  191. package/src/programmers/protobuf/ProtobufIsDecodeProgrammer.ts +85 -75
  192. package/src/programmers/protobuf/ProtobufValidateDecodeProgrammer.ts +75 -75
  193. package/src/protobuf.ts +881 -249
  194. package/src/schemas/metadata/IMetadata.ts +27 -28
  195. package/src/schemas/metadata/IMetadataAtomic.ts +13 -0
  196. package/src/schemas/metadata/{IMetadataResolved.ts → IMetadataEscaped.ts} +6 -6
  197. package/src/schemas/metadata/Metadata.ts +643 -637
  198. package/src/schemas/metadata/{MetadataResolved.ts → MetadataEscaped.ts} +51 -51
  199. package/src/tags/ExclusiveMaximum.ts +8 -0
  200. package/src/tags/ExclusiveMinimum.ts +8 -0
  201. package/src/tags/Format.ts +29 -0
  202. package/src/tags/MaxItems.ts +8 -0
  203. package/src/tags/MaxLength.ts +8 -0
  204. package/src/tags/Maximum.ts +8 -0
  205. package/src/tags/MinItems.ts +8 -0
  206. package/src/tags/MinLength.ts +8 -0
  207. package/src/tags/Minimum.ts +8 -0
  208. package/src/tags/MultipleOf.ts +10 -0
  209. package/src/tags/Pattern.ts +8 -0
  210. package/src/tags/TagBase.ts +17 -0
  211. package/src/tags/Type.ts +30 -0
  212. package/src/tags/index.ts +12 -0
  213. package/src/transformers/features/json/JsonApplicationTransformer.ts +111 -111
  214. package/src/transformers/features/misc/MetadataTransformer.ts +53 -53
  215. package/src/utils/RandomGenerator.ts +83 -81
  216. package/lib/schemas/metadata/IMetadataResolved.js.map +0 -1
  217. package/lib/schemas/metadata/MetadataResolved.js.map +0 -1
@@ -1,542 +1,544 @@
1
- import ts from "typescript";
2
-
3
- import { ExpressionFactory } from "../../factories/ExpressionFactory";
4
- import { IdentifierFactory } from "../../factories/IdentifierFactory";
5
- import { MetadataCollection } from "../../factories/MetadataCollection";
6
- import { MetadataFactory } from "../../factories/MetadataFactory";
7
- import { StatementFactory } from "../../factories/StatementFactory";
8
- import { TypeFactory } from "../../factories/TypeFactory";
9
-
10
- import { IJsDocTagInfo } from "../../schemas/metadata/IJsDocTagInfo";
11
- import { IMetadataTag } from "../../schemas/metadata/IMetadataTag";
12
- import { Metadata } from "../../schemas/metadata/Metadata";
13
- import { MetadataArray } from "../../schemas/metadata/MetadataArray";
14
- import { MetadataTuple } from "../../schemas/metadata/MetadataTuple";
15
-
16
- import { IProject } from "../../transformers/IProject";
17
-
18
- import { FeatureProgrammer } from "../FeatureProgrammer";
19
- import { IsProgrammer } from "../IsProgrammer";
20
- import { FunctionImporter } from "../helpers/FunctionImporeter";
21
- import { PruneJoiner } from "../helpers/PruneJoiner";
22
- import { UnionExplorer } from "../helpers/UnionExplorer";
23
- import { decode_union_object } from "../internal/decode_union_object";
24
- import { wrap_metadata_rest_tuple } from "../internal/wrap_metadata_rest_tuple";
25
-
26
- export namespace MiscPruneProgrammer {
27
- export const write =
28
- (project: IProject) => (modulo: ts.LeftHandSideExpression) => {
29
- const importer: FunctionImporter = new FunctionImporter();
30
- return FeatureProgrammer.write(project)({
31
- ...configure(project)(importer),
32
- addition: (collection) => [
33
- ...IsProgrammer.write_function_statements(project)(
34
- importer,
35
- )(collection),
36
- ...importer.declare(modulo),
37
- ],
38
- })(importer);
39
- };
40
-
41
- const write_array_functions =
42
- (config: FeatureProgrammer.IConfig) =>
43
- (importer: FunctionImporter) =>
44
- (collection: MetadataCollection): ts.VariableStatement[] =>
45
- collection
46
- .arrays()
47
- .filter((a) => a.recursive)
48
- .map((array, i) =>
49
- StatementFactory.constant(
50
- `${config.prefix}a${i}`,
51
- ts.factory.createArrowFunction(
52
- undefined,
53
- undefined,
54
- FeatureProgrammer.parameterDeclarations(config)(
55
- TypeFactory.keyword("any"),
56
- )(ts.factory.createIdentifier("input")),
57
- TypeFactory.keyword("any"),
58
- undefined,
59
- decode_array_inline(config)(importer)(
60
- ts.factory.createIdentifier("input"),
61
- array,
62
- {
63
- tracable: config.trace,
64
- source: "function",
65
- from: "array",
66
- postfix: "",
67
- },
68
- ),
69
- ),
70
- ),
71
- );
72
-
73
- const write_tuple_functions =
74
- (project: IProject) =>
75
- (config: FeatureProgrammer.IConfig) =>
76
- (importer: FunctionImporter) =>
77
- (collection: MetadataCollection): ts.VariableStatement[] =>
78
- collection
79
- .tuples()
80
- .filter((t) => t.recursive)
81
- .map((tuple, i) =>
82
- StatementFactory.constant(
83
- `${config.prefix}t${i}`,
84
- ts.factory.createArrowFunction(
85
- undefined,
86
- undefined,
87
- FeatureProgrammer.parameterDeclarations(config)(
88
- TypeFactory.keyword("any"),
89
- )(ts.factory.createIdentifier("input")),
90
- TypeFactory.keyword("any"),
91
- undefined,
92
- decode_tuple_inline(project)(config)(importer)(
93
- ts.factory.createIdentifier("input"),
94
- tuple,
95
- {
96
- tracable: config.trace,
97
- source: "function",
98
- from: "array",
99
- postfix: "",
100
- },
101
- ),
102
- ),
103
- ),
104
- );
105
-
106
- /* -----------------------------------------------------------
107
- DECODERS
108
- ----------------------------------------------------------- */
109
- const decode =
110
- (project: IProject) =>
111
- (config: FeatureProgrammer.IConfig) =>
112
- (importer: FunctionImporter) =>
113
- (
114
- input: ts.Expression,
115
- meta: Metadata,
116
- explore: FeatureProgrammer.IExplore,
117
- ): ts.ConciseBody => {
118
- if (filter(meta) === false) return ts.factory.createBlock([]);
119
-
120
- interface IUnion {
121
- type: string;
122
- is: () => ts.Expression;
123
- value: () => ts.Expression | ts.Block | ts.ReturnStatement;
124
- }
125
- const unions: IUnion[] = [];
126
-
127
- //----
128
- // LIST UP UNION TYPES
129
- //----
130
- // TUPLES
131
- for (const tuple of meta.tuples.filter((t) =>
132
- t.elements.some((e) => filter(e.rest ?? e)),
133
- ))
134
- unions.push({
135
- type: "tuple",
136
- is: () =>
137
- IsProgrammer.decode(project)(importer)(
138
- input,
139
- (() => {
140
- const partial = Metadata.initialize();
141
- partial.tuples.push(tuple);
142
- return partial;
143
- })(),
144
- explore,
145
- [],
146
- [],
147
- ),
148
- value: () =>
149
- decode_tuple(project)(config)(importer)(
150
- input,
151
- tuple,
152
- explore,
153
- ),
154
- });
155
-
156
- // ARRAYS
157
- if (meta.arrays.filter((a) => filter(a.value)).length)
158
- unions.push({
159
- type: "array",
160
- is: () => ExpressionFactory.isArray(input),
161
- value: () =>
162
- explore_arrays(project)(config)(importer)(
163
- input,
164
- meta.arrays,
165
- {
166
- ...explore,
167
- from: "array",
168
- },
169
- ),
170
- });
171
-
172
- // BUILT-IN CLASSES
173
- if (meta.natives.length)
174
- for (const native of meta.natives)
175
- unions.push({
176
- type: "native",
177
- is: () => ExpressionFactory.isInstanceOf(native)(input),
178
- value: () => ts.factory.createReturnStatement(),
179
- });
180
- if (meta.sets.length)
181
- unions.push({
182
- type: "set",
183
- is: () => ExpressionFactory.isInstanceOf("Set")(input),
184
- value: () => ts.factory.createReturnStatement(),
185
- });
186
- if (meta.maps.length)
187
- unions.push({
188
- type: "map",
189
- is: () => ExpressionFactory.isInstanceOf("Map")(input),
190
- value: () => ts.factory.createReturnStatement(),
191
- });
192
-
193
- // OBJECTS
194
- if (meta.objects.length)
195
- unions.push({
196
- type: "object",
197
- is: () =>
198
- ExpressionFactory.isObject({
199
- checkNull: true,
200
- checkArray: false,
201
- })(input),
202
- value: () =>
203
- explore_objects(config)(importer)(input, meta, {
204
- ...explore,
205
- from: "object",
206
- }),
207
- });
208
-
209
- //----
210
- // STATEMENTS
211
- //----
212
- const converter = (
213
- v: ts.Expression | ts.Block | ts.ReturnStatement,
214
- ) =>
215
- ts.isReturnStatement(v) || ts.isBlock(v)
216
- ? v
217
- : ts.factory.createExpressionStatement(v);
218
-
219
- const statements: ts.Statement[] = unions.map((u) =>
220
- ts.factory.createIfStatement(u.is(), converter(u.value())),
221
- );
222
- return ts.factory.createBlock(statements, true);
223
- };
224
-
225
- const decode_object = (importer: FunctionImporter) =>
226
- FeatureProgrammer.decode_object({
227
- trace: false,
228
- path: false,
229
- prefix: PREFIX,
230
- })(importer);
231
-
232
- const decode_array =
233
- (config: FeatureProgrammer.IConfig) =>
234
- (importer: FunctionImporter) =>
235
- (
236
- input: ts.Expression,
237
- array: MetadataArray,
238
- explore: FeatureProgrammer.IExplore,
239
- ) =>
240
- array.recursive
241
- ? ts.factory.createCallExpression(
242
- ts.factory.createIdentifier(
243
- importer.useLocal(`${config.prefix}a${array.index}`),
244
- ),
245
- undefined,
246
- FeatureProgrammer.argumentsArray(config)({
247
- ...explore,
248
- source: "function",
249
- from: "array",
250
- })(input),
251
- )
252
- : decode_array_inline(config)(importer)(input, array, explore);
253
-
254
- const decode_array_inline =
255
- (config: FeatureProgrammer.IConfig) =>
256
- (importer: FunctionImporter) =>
257
- (
258
- input: ts.Expression,
259
- array: MetadataArray,
260
- explore: FeatureProgrammer.IExplore,
261
- ): ts.Expression =>
262
- FeatureProgrammer.decode_array(config)(importer)(PruneJoiner.array)(
263
- input,
264
- array,
265
- explore,
266
- [],
267
- [],
268
- );
269
-
270
- const decode_tuple =
271
- (project: IProject) =>
272
- (config: FeatureProgrammer.IConfig) =>
273
- (importer: FunctionImporter) =>
274
- (
275
- input: ts.Expression,
276
- tuple: MetadataTuple,
277
- explore: FeatureProgrammer.IExplore,
278
- ): ts.Expression | ts.Block =>
279
- tuple.recursive
280
- ? ts.factory.createCallExpression(
281
- ts.factory.createIdentifier(
282
- importer.useLocal(`${config.prefix}t${tuple.index}`),
283
- ),
284
- undefined,
285
- FeatureProgrammer.argumentsArray(config)({
286
- ...explore,
287
- source: "function",
288
- })(input),
289
- )
290
- : decode_tuple_inline(project)(config)(importer)(
291
- input,
292
- tuple,
293
- explore,
294
- );
295
-
296
- const decode_tuple_inline =
297
- (project: IProject) =>
298
- (config: FeatureProgrammer.IConfig) =>
299
- (importer: FunctionImporter) =>
300
- (
301
- input: ts.Expression,
302
- tuple: MetadataTuple,
303
- explore: FeatureProgrammer.IExplore,
304
- ): ts.Block => {
305
- const children: ts.ConciseBody[] = tuple.elements
306
- .map((elem, index) => [elem, index] as const)
307
- .filter(([elem]) => filter(elem) && elem.rest === null)
308
- .map(([elem, index]) =>
309
- decode(project)(config)(importer)(
310
- ts.factory.createElementAccessExpression(input, index),
311
- elem,
312
- {
313
- ...explore,
314
- from: "array",
315
- postfix: explore.postfix.length
316
- ? `${explore.postfix.slice(0, -1)}[${index}]"`
317
- : `"[${index}]"`,
318
- },
319
- ),
320
- );
321
- const rest = (() => {
322
- if (tuple.elements.length === 0) return null;
323
-
324
- const last: Metadata = tuple.elements.at(-1)!;
325
- const rest: Metadata | null = last.rest;
326
- if (rest === null || filter(rest) === false) return null;
327
-
328
- return decode(project)(config)(importer)(
329
- ts.factory.createCallExpression(
330
- IdentifierFactory.access(input)("slice"),
331
- undefined,
332
- [
333
- ts.factory.createNumericLiteral(
334
- tuple.elements.length - 1,
335
- ),
336
- ],
337
- ),
338
- wrap_metadata_rest_tuple(tuple.elements.at(-1)!.rest!),
339
- {
340
- ...explore,
341
- start: tuple.elements.length - 1,
342
- },
343
- );
344
- })();
345
- return PruneJoiner.tuple(children, rest);
346
- };
347
-
348
- /* -----------------------------------------------------------
349
- UNION TYPE EXPLORERS
350
- ----------------------------------------------------------- */
351
- const explore_objects =
352
- (config: FeatureProgrammer.IConfig) =>
353
- (importer: FunctionImporter) =>
354
- (
355
- input: ts.Expression,
356
- meta: Metadata,
357
- explore: FeatureProgrammer.IExplore,
358
- ) => {
359
- if (meta.objects.length === 1)
360
- return decode_object(importer)(
361
- input,
362
- meta.objects[0]!,
363
- explore,
364
- );
365
-
366
- return ts.factory.createCallExpression(
367
- ts.factory.createIdentifier(
368
- importer.useLocal(`${PREFIX}u${meta.union_index!}`),
369
- ),
370
- undefined,
371
- FeatureProgrammer.argumentsArray(config)(explore)(input),
372
- );
373
- };
374
-
375
- const explore_arrays =
376
- (project: IProject) =>
377
- (config: FeatureProgrammer.IConfig) =>
378
- (importer: FunctionImporter) =>
379
- (
380
- input: ts.Expression,
381
- elements: MetadataArray[],
382
- explore: FeatureProgrammer.IExplore,
383
- ): ts.Expression =>
384
- explore_array_like_union_types(config)(importer)(
385
- UnionExplorer.array({
386
- checker: IsProgrammer.decode(project)(importer),
387
- decoder: decode_array(config)(importer),
388
- empty: ts.factory.createStringLiteral("[]"),
389
- success: ts.factory.createTrue(),
390
- failure: (input, expected) =>
391
- create_throw_error(importer)(expected)(input),
392
- }),
393
- )(input, elements, explore);
394
-
395
- const explore_array_like_union_types =
396
- (config: FeatureProgrammer.IConfig) =>
397
- (importer: FunctionImporter) =>
398
- <T extends MetadataArray | MetadataTuple>(
399
- factory: (
400
- parameters: ts.ParameterDeclaration[],
401
- ) => (
402
- input: ts.Expression,
403
- elements: T[],
404
- explore: FeatureProgrammer.IExplore,
405
- tags: IMetadataTag[],
406
- jsDocTags: IJsDocTagInfo[],
407
- ) => ts.ArrowFunction,
408
- ) =>
409
- (
410
- input: ts.Expression,
411
- elements: T[],
412
- explore: FeatureProgrammer.IExplore,
413
- ): ts.Expression => {
414
- const arrow =
415
- (parameters: ts.ParameterDeclaration[]) =>
416
- (explore: FeatureProgrammer.IExplore) =>
417
- (input: ts.Expression): ts.ArrowFunction =>
418
- factory(parameters)(input, elements, explore, [], []);
419
- if (elements.every((e) => e.recursive === false))
420
- ts.factory.createCallExpression(
421
- arrow([])(explore)(input),
422
- undefined,
423
- [],
424
- );
425
-
426
- explore = {
427
- ...explore,
428
- source: "function",
429
- from: "array",
430
- };
431
- return ts.factory.createCallExpression(
432
- ts.factory.createIdentifier(
433
- importer.emplaceUnion(
434
- config.prefix,
435
- elements.map((e) => e.name).join(" | "),
436
- () =>
437
- arrow(
438
- FeatureProgrammer.parameterDeclarations(config)(
439
- TypeFactory.keyword("any"),
440
- )(ts.factory.createIdentifier("input")),
441
- )({
442
- ...explore,
443
- postfix: "",
444
- })(ts.factory.createIdentifier("input")),
445
- ),
446
- ),
447
- undefined,
448
- FeatureProgrammer.argumentsArray(config)(explore)(input),
449
- );
450
- };
451
-
452
- // @todo -> must filter out recursive visit
453
- const filter = (meta: Metadata): boolean =>
454
- meta.any === false &&
455
- (meta.objects.length !== 0 ||
456
- meta.tuples.some((t) =>
457
- t.elements.some((e) => filter(e.rest ?? e)),
458
- ) ||
459
- meta.arrays.some((e) => filter(e.value)));
460
-
461
- /* -----------------------------------------------------------
462
- CONFIGURATIONS
463
- ----------------------------------------------------------- */
464
- const PREFIX = "$p";
465
-
466
- const configure =
467
- (project: IProject) =>
468
- (importer: FunctionImporter): FeatureProgrammer.IConfig => {
469
- const config: FeatureProgrammer.IConfig = {
470
- types: {
471
- input: (type, name) =>
472
- ts.factory.createTypeReferenceNode(
473
- name ??
474
- TypeFactory.getFullName(project.checker)(type),
475
- ),
476
- output: () => TypeFactory.keyword("void"),
477
- },
478
- prefix: PREFIX,
479
- trace: false,
480
- path: false,
481
- initializer,
482
- decoder: () => decode(project)(config)(importer),
483
- objector: {
484
- checker: () => IsProgrammer.decode(project)(importer),
485
- decoder: () => decode_object(importer),
486
- joiner: PruneJoiner.object,
487
- unionizer: decode_union_object(
488
- IsProgrammer.decode_object(importer),
489
- )(decode_object(importer))((exp) => exp)(
490
- (value, expected) =>
491
- create_throw_error(importer)(expected)(value),
492
- ),
493
- failure: (input, expected) =>
494
- create_throw_error(importer)(expected)(input),
495
- },
496
- generator: {
497
- arrays: () => write_array_functions(config)(importer),
498
- tuples: () =>
499
- write_tuple_functions(project)(config)(importer),
500
- },
501
- };
502
- return config;
503
- };
504
-
505
- const initializer: FeatureProgrammer.IConfig["initializer"] =
506
- ({ checker }) =>
507
- (type) => {
508
- const collection = new MetadataCollection();
509
- const meta = MetadataFactory.analyze(checker)({
510
- resolve: false,
511
- constant: true,
512
- absorb: true,
513
- })(collection)(type);
514
- return [collection, meta];
515
- };
516
-
517
- const create_throw_error =
518
- (importer: FunctionImporter) =>
519
- (expected: string) =>
520
- (value: ts.Expression) =>
521
- ts.factory.createExpressionStatement(
522
- ts.factory.createCallExpression(
523
- importer.use("throws"),
524
- [],
525
- [
526
- ts.factory.createObjectLiteralExpression(
527
- [
528
- ts.factory.createPropertyAssignment(
529
- "expected",
530
- ts.factory.createStringLiteral(expected),
531
- ),
532
- ts.factory.createPropertyAssignment(
533
- "value",
534
- value,
535
- ),
536
- ],
537
- true,
538
- ),
539
- ],
540
- ),
541
- );
542
- }
1
+ import ts from "typescript";
2
+
3
+ import { ExpressionFactory } from "../../factories/ExpressionFactory";
4
+ import { IdentifierFactory } from "../../factories/IdentifierFactory";
5
+ import { MetadataCollection } from "../../factories/MetadataCollection";
6
+ import { MetadataFactory } from "../../factories/MetadataFactory";
7
+ import { StatementFactory } from "../../factories/StatementFactory";
8
+ import { TypeFactory } from "../../factories/TypeFactory";
9
+
10
+ import { IJsDocTagInfo } from "../../schemas/metadata/IJsDocTagInfo";
11
+ import { IMetadataTag } from "../../schemas/metadata/IMetadataTag";
12
+ import { Metadata } from "../../schemas/metadata/Metadata";
13
+ import { MetadataArray } from "../../schemas/metadata/MetadataArray";
14
+ import { MetadataTuple } from "../../schemas/metadata/MetadataTuple";
15
+
16
+ import { IProject } from "../../transformers/IProject";
17
+
18
+ import { FeatureProgrammer } from "../FeatureProgrammer";
19
+ import { IsProgrammer } from "../IsProgrammer";
20
+ import { FunctionImporter } from "../helpers/FunctionImporeter";
21
+ import { PruneJoiner } from "../helpers/PruneJoiner";
22
+ import { UnionExplorer } from "../helpers/UnionExplorer";
23
+ import { decode_union_object } from "../internal/decode_union_object";
24
+ import { wrap_metadata_rest_tuple } from "../internal/wrap_metadata_rest_tuple";
25
+
26
+ export namespace MiscPruneProgrammer {
27
+ export const write =
28
+ (project: IProject) => (modulo: ts.LeftHandSideExpression) => {
29
+ const importer: FunctionImporter = new FunctionImporter(
30
+ modulo.getText(),
31
+ );
32
+ return FeatureProgrammer.write(project)({
33
+ ...configure(project)(importer),
34
+ addition: (collection) => [
35
+ ...IsProgrammer.write_function_statements(project)(
36
+ importer,
37
+ )(collection),
38
+ ...importer.declare(modulo),
39
+ ],
40
+ })(importer);
41
+ };
42
+
43
+ const write_array_functions =
44
+ (config: FeatureProgrammer.IConfig) =>
45
+ (importer: FunctionImporter) =>
46
+ (collection: MetadataCollection): ts.VariableStatement[] =>
47
+ collection
48
+ .arrays()
49
+ .filter((a) => a.recursive)
50
+ .map((array, i) =>
51
+ StatementFactory.constant(
52
+ `${config.prefix}a${i}`,
53
+ ts.factory.createArrowFunction(
54
+ undefined,
55
+ undefined,
56
+ FeatureProgrammer.parameterDeclarations(config)(
57
+ TypeFactory.keyword("any"),
58
+ )(ts.factory.createIdentifier("input")),
59
+ TypeFactory.keyword("any"),
60
+ undefined,
61
+ decode_array_inline(config)(importer)(
62
+ ts.factory.createIdentifier("input"),
63
+ array,
64
+ {
65
+ tracable: config.trace,
66
+ source: "function",
67
+ from: "array",
68
+ postfix: "",
69
+ },
70
+ ),
71
+ ),
72
+ ),
73
+ );
74
+
75
+ const write_tuple_functions =
76
+ (project: IProject) =>
77
+ (config: FeatureProgrammer.IConfig) =>
78
+ (importer: FunctionImporter) =>
79
+ (collection: MetadataCollection): ts.VariableStatement[] =>
80
+ collection
81
+ .tuples()
82
+ .filter((t) => t.recursive)
83
+ .map((tuple, i) =>
84
+ StatementFactory.constant(
85
+ `${config.prefix}t${i}`,
86
+ ts.factory.createArrowFunction(
87
+ undefined,
88
+ undefined,
89
+ FeatureProgrammer.parameterDeclarations(config)(
90
+ TypeFactory.keyword("any"),
91
+ )(ts.factory.createIdentifier("input")),
92
+ TypeFactory.keyword("any"),
93
+ undefined,
94
+ decode_tuple_inline(project)(config)(importer)(
95
+ ts.factory.createIdentifier("input"),
96
+ tuple,
97
+ {
98
+ tracable: config.trace,
99
+ source: "function",
100
+ from: "array",
101
+ postfix: "",
102
+ },
103
+ ),
104
+ ),
105
+ ),
106
+ );
107
+
108
+ /* -----------------------------------------------------------
109
+ DECODERS
110
+ ----------------------------------------------------------- */
111
+ const decode =
112
+ (project: IProject) =>
113
+ (config: FeatureProgrammer.IConfig) =>
114
+ (importer: FunctionImporter) =>
115
+ (
116
+ input: ts.Expression,
117
+ meta: Metadata,
118
+ explore: FeatureProgrammer.IExplore,
119
+ ): ts.ConciseBody => {
120
+ if (filter(meta) === false) return ts.factory.createBlock([]);
121
+
122
+ interface IUnion {
123
+ type: string;
124
+ is: () => ts.Expression;
125
+ value: () => ts.Expression | ts.Block | ts.ReturnStatement;
126
+ }
127
+ const unions: IUnion[] = [];
128
+
129
+ //----
130
+ // LIST UP UNION TYPES
131
+ //----
132
+ // TUPLES
133
+ for (const tuple of meta.tuples.filter((t) =>
134
+ t.elements.some((e) => filter(e.rest ?? e)),
135
+ ))
136
+ unions.push({
137
+ type: "tuple",
138
+ is: () =>
139
+ IsProgrammer.decode(project)(importer)(
140
+ input,
141
+ (() => {
142
+ const partial = Metadata.initialize();
143
+ partial.tuples.push(tuple);
144
+ return partial;
145
+ })(),
146
+ explore,
147
+ [],
148
+ [],
149
+ ),
150
+ value: () =>
151
+ decode_tuple(project)(config)(importer)(
152
+ input,
153
+ tuple,
154
+ explore,
155
+ ),
156
+ });
157
+
158
+ // ARRAYS
159
+ if (meta.arrays.filter((a) => filter(a.value)).length)
160
+ unions.push({
161
+ type: "array",
162
+ is: () => ExpressionFactory.isArray(input),
163
+ value: () =>
164
+ explore_arrays(project)(config)(importer)(
165
+ input,
166
+ meta.arrays,
167
+ {
168
+ ...explore,
169
+ from: "array",
170
+ },
171
+ ),
172
+ });
173
+
174
+ // BUILT-IN CLASSES
175
+ if (meta.natives.length)
176
+ for (const native of meta.natives)
177
+ unions.push({
178
+ type: "native",
179
+ is: () => ExpressionFactory.isInstanceOf(native)(input),
180
+ value: () => ts.factory.createReturnStatement(),
181
+ });
182
+ if (meta.sets.length)
183
+ unions.push({
184
+ type: "set",
185
+ is: () => ExpressionFactory.isInstanceOf("Set")(input),
186
+ value: () => ts.factory.createReturnStatement(),
187
+ });
188
+ if (meta.maps.length)
189
+ unions.push({
190
+ type: "map",
191
+ is: () => ExpressionFactory.isInstanceOf("Map")(input),
192
+ value: () => ts.factory.createReturnStatement(),
193
+ });
194
+
195
+ // OBJECTS
196
+ if (meta.objects.length)
197
+ unions.push({
198
+ type: "object",
199
+ is: () =>
200
+ ExpressionFactory.isObject({
201
+ checkNull: true,
202
+ checkArray: false,
203
+ })(input),
204
+ value: () =>
205
+ explore_objects(config)(importer)(input, meta, {
206
+ ...explore,
207
+ from: "object",
208
+ }),
209
+ });
210
+
211
+ //----
212
+ // STATEMENTS
213
+ //----
214
+ const converter = (
215
+ v: ts.Expression | ts.Block | ts.ReturnStatement,
216
+ ) =>
217
+ ts.isReturnStatement(v) || ts.isBlock(v)
218
+ ? v
219
+ : ts.factory.createExpressionStatement(v);
220
+
221
+ const statements: ts.Statement[] = unions.map((u) =>
222
+ ts.factory.createIfStatement(u.is(), converter(u.value())),
223
+ );
224
+ return ts.factory.createBlock(statements, true);
225
+ };
226
+
227
+ const decode_object = (importer: FunctionImporter) =>
228
+ FeatureProgrammer.decode_object({
229
+ trace: false,
230
+ path: false,
231
+ prefix: PREFIX,
232
+ })(importer);
233
+
234
+ const decode_array =
235
+ (config: FeatureProgrammer.IConfig) =>
236
+ (importer: FunctionImporter) =>
237
+ (
238
+ input: ts.Expression,
239
+ array: MetadataArray,
240
+ explore: FeatureProgrammer.IExplore,
241
+ ) =>
242
+ array.recursive
243
+ ? ts.factory.createCallExpression(
244
+ ts.factory.createIdentifier(
245
+ importer.useLocal(`${config.prefix}a${array.index}`),
246
+ ),
247
+ undefined,
248
+ FeatureProgrammer.argumentsArray(config)({
249
+ ...explore,
250
+ source: "function",
251
+ from: "array",
252
+ })(input),
253
+ )
254
+ : decode_array_inline(config)(importer)(input, array, explore);
255
+
256
+ const decode_array_inline =
257
+ (config: FeatureProgrammer.IConfig) =>
258
+ (importer: FunctionImporter) =>
259
+ (
260
+ input: ts.Expression,
261
+ array: MetadataArray,
262
+ explore: FeatureProgrammer.IExplore,
263
+ ): ts.Expression =>
264
+ FeatureProgrammer.decode_array(config)(importer)(PruneJoiner.array)(
265
+ input,
266
+ array,
267
+ explore,
268
+ [],
269
+ [],
270
+ );
271
+
272
+ const decode_tuple =
273
+ (project: IProject) =>
274
+ (config: FeatureProgrammer.IConfig) =>
275
+ (importer: FunctionImporter) =>
276
+ (
277
+ input: ts.Expression,
278
+ tuple: MetadataTuple,
279
+ explore: FeatureProgrammer.IExplore,
280
+ ): ts.Expression | ts.Block =>
281
+ tuple.recursive
282
+ ? ts.factory.createCallExpression(
283
+ ts.factory.createIdentifier(
284
+ importer.useLocal(`${config.prefix}t${tuple.index}`),
285
+ ),
286
+ undefined,
287
+ FeatureProgrammer.argumentsArray(config)({
288
+ ...explore,
289
+ source: "function",
290
+ })(input),
291
+ )
292
+ : decode_tuple_inline(project)(config)(importer)(
293
+ input,
294
+ tuple,
295
+ explore,
296
+ );
297
+
298
+ const decode_tuple_inline =
299
+ (project: IProject) =>
300
+ (config: FeatureProgrammer.IConfig) =>
301
+ (importer: FunctionImporter) =>
302
+ (
303
+ input: ts.Expression,
304
+ tuple: MetadataTuple,
305
+ explore: FeatureProgrammer.IExplore,
306
+ ): ts.Block => {
307
+ const children: ts.ConciseBody[] = tuple.elements
308
+ .map((elem, index) => [elem, index] as const)
309
+ .filter(([elem]) => filter(elem) && elem.rest === null)
310
+ .map(([elem, index]) =>
311
+ decode(project)(config)(importer)(
312
+ ts.factory.createElementAccessExpression(input, index),
313
+ elem,
314
+ {
315
+ ...explore,
316
+ from: "array",
317
+ postfix: explore.postfix.length
318
+ ? `${explore.postfix.slice(0, -1)}[${index}]"`
319
+ : `"[${index}]"`,
320
+ },
321
+ ),
322
+ );
323
+ const rest = (() => {
324
+ if (tuple.elements.length === 0) return null;
325
+
326
+ const last: Metadata = tuple.elements.at(-1)!;
327
+ const rest: Metadata | null = last.rest;
328
+ if (rest === null || filter(rest) === false) return null;
329
+
330
+ return decode(project)(config)(importer)(
331
+ ts.factory.createCallExpression(
332
+ IdentifierFactory.access(input)("slice"),
333
+ undefined,
334
+ [
335
+ ts.factory.createNumericLiteral(
336
+ tuple.elements.length - 1,
337
+ ),
338
+ ],
339
+ ),
340
+ wrap_metadata_rest_tuple(tuple.elements.at(-1)!.rest!),
341
+ {
342
+ ...explore,
343
+ start: tuple.elements.length - 1,
344
+ },
345
+ );
346
+ })();
347
+ return PruneJoiner.tuple(children, rest);
348
+ };
349
+
350
+ /* -----------------------------------------------------------
351
+ UNION TYPE EXPLORERS
352
+ ----------------------------------------------------------- */
353
+ const explore_objects =
354
+ (config: FeatureProgrammer.IConfig) =>
355
+ (importer: FunctionImporter) =>
356
+ (
357
+ input: ts.Expression,
358
+ meta: Metadata,
359
+ explore: FeatureProgrammer.IExplore,
360
+ ) => {
361
+ if (meta.objects.length === 1)
362
+ return decode_object(importer)(
363
+ input,
364
+ meta.objects[0]!,
365
+ explore,
366
+ );
367
+
368
+ return ts.factory.createCallExpression(
369
+ ts.factory.createIdentifier(
370
+ importer.useLocal(`${PREFIX}u${meta.union_index!}`),
371
+ ),
372
+ undefined,
373
+ FeatureProgrammer.argumentsArray(config)(explore)(input),
374
+ );
375
+ };
376
+
377
+ const explore_arrays =
378
+ (project: IProject) =>
379
+ (config: FeatureProgrammer.IConfig) =>
380
+ (importer: FunctionImporter) =>
381
+ (
382
+ input: ts.Expression,
383
+ elements: MetadataArray[],
384
+ explore: FeatureProgrammer.IExplore,
385
+ ): ts.Expression =>
386
+ explore_array_like_union_types(config)(importer)(
387
+ UnionExplorer.array({
388
+ checker: IsProgrammer.decode(project)(importer),
389
+ decoder: decode_array(config)(importer),
390
+ empty: ts.factory.createStringLiteral("[]"),
391
+ success: ts.factory.createTrue(),
392
+ failure: (input, expected) =>
393
+ create_throw_error(importer)(expected)(input),
394
+ }),
395
+ )(input, elements, explore);
396
+
397
+ const explore_array_like_union_types =
398
+ (config: FeatureProgrammer.IConfig) =>
399
+ (importer: FunctionImporter) =>
400
+ <T extends MetadataArray | MetadataTuple>(
401
+ factory: (
402
+ parameters: ts.ParameterDeclaration[],
403
+ ) => (
404
+ input: ts.Expression,
405
+ elements: T[],
406
+ explore: FeatureProgrammer.IExplore,
407
+ tags: IMetadataTag[],
408
+ jsDocTags: IJsDocTagInfo[],
409
+ ) => ts.ArrowFunction,
410
+ ) =>
411
+ (
412
+ input: ts.Expression,
413
+ elements: T[],
414
+ explore: FeatureProgrammer.IExplore,
415
+ ): ts.Expression => {
416
+ const arrow =
417
+ (parameters: ts.ParameterDeclaration[]) =>
418
+ (explore: FeatureProgrammer.IExplore) =>
419
+ (input: ts.Expression): ts.ArrowFunction =>
420
+ factory(parameters)(input, elements, explore, [], []);
421
+ if (elements.every((e) => e.recursive === false))
422
+ ts.factory.createCallExpression(
423
+ arrow([])(explore)(input),
424
+ undefined,
425
+ [],
426
+ );
427
+
428
+ explore = {
429
+ ...explore,
430
+ source: "function",
431
+ from: "array",
432
+ };
433
+ return ts.factory.createCallExpression(
434
+ ts.factory.createIdentifier(
435
+ importer.emplaceUnion(
436
+ config.prefix,
437
+ elements.map((e) => e.name).join(" | "),
438
+ () =>
439
+ arrow(
440
+ FeatureProgrammer.parameterDeclarations(config)(
441
+ TypeFactory.keyword("any"),
442
+ )(ts.factory.createIdentifier("input")),
443
+ )({
444
+ ...explore,
445
+ postfix: "",
446
+ })(ts.factory.createIdentifier("input")),
447
+ ),
448
+ ),
449
+ undefined,
450
+ FeatureProgrammer.argumentsArray(config)(explore)(input),
451
+ );
452
+ };
453
+
454
+ // @todo -> must filter out recursive visit
455
+ const filter = (meta: Metadata): boolean =>
456
+ meta.any === false &&
457
+ (meta.objects.length !== 0 ||
458
+ meta.tuples.some((t) =>
459
+ t.elements.some((e) => filter(e.rest ?? e)),
460
+ ) ||
461
+ meta.arrays.some((e) => filter(e.value)));
462
+
463
+ /* -----------------------------------------------------------
464
+ CONFIGURATIONS
465
+ ----------------------------------------------------------- */
466
+ const PREFIX = "$p";
467
+
468
+ const configure =
469
+ (project: IProject) =>
470
+ (importer: FunctionImporter): FeatureProgrammer.IConfig => {
471
+ const config: FeatureProgrammer.IConfig = {
472
+ types: {
473
+ input: (type, name) =>
474
+ ts.factory.createTypeReferenceNode(
475
+ name ??
476
+ TypeFactory.getFullName(project.checker)(type),
477
+ ),
478
+ output: () => TypeFactory.keyword("void"),
479
+ },
480
+ prefix: PREFIX,
481
+ trace: false,
482
+ path: false,
483
+ initializer,
484
+ decoder: () => decode(project)(config)(importer),
485
+ objector: {
486
+ checker: () => IsProgrammer.decode(project)(importer),
487
+ decoder: () => decode_object(importer),
488
+ joiner: PruneJoiner.object,
489
+ unionizer: decode_union_object(
490
+ IsProgrammer.decode_object(importer),
491
+ )(decode_object(importer))((exp) => exp)(
492
+ (value, expected) =>
493
+ create_throw_error(importer)(expected)(value),
494
+ ),
495
+ failure: (input, expected) =>
496
+ create_throw_error(importer)(expected)(input),
497
+ },
498
+ generator: {
499
+ arrays: () => write_array_functions(config)(importer),
500
+ tuples: () =>
501
+ write_tuple_functions(project)(config)(importer),
502
+ },
503
+ };
504
+ return config;
505
+ };
506
+
507
+ const initializer: FeatureProgrammer.IConfig["initializer"] =
508
+ ({ checker }) =>
509
+ (type) => {
510
+ const collection = new MetadataCollection();
511
+ const meta = MetadataFactory.analyze(checker)({
512
+ escape: false,
513
+ constant: true,
514
+ absorb: true,
515
+ })(collection)(type);
516
+ return [collection, meta];
517
+ };
518
+
519
+ const create_throw_error =
520
+ (importer: FunctionImporter) =>
521
+ (expected: string) =>
522
+ (value: ts.Expression) =>
523
+ ts.factory.createExpressionStatement(
524
+ ts.factory.createCallExpression(
525
+ importer.use("throws"),
526
+ [],
527
+ [
528
+ ts.factory.createObjectLiteralExpression(
529
+ [
530
+ ts.factory.createPropertyAssignment(
531
+ "expected",
532
+ ts.factory.createStringLiteral(expected),
533
+ ),
534
+ ts.factory.createPropertyAssignment(
535
+ "value",
536
+ value,
537
+ ),
538
+ ],
539
+ true,
540
+ ),
541
+ ],
542
+ ),
543
+ );
544
+ }