typia 5.2.6 → 5.3.0-dev.20231112

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