typia 4.3.2 → 4.3.3

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 (241) hide show
  1. package/lib/factories/internal/metadata/iterate_metadata_intersection.js +2 -0
  2. package/lib/factories/internal/metadata/iterate_metadata_intersection.js.map +1 -1
  3. package/lib/programmers/helpers/CloneJoiner.js +10 -2
  4. package/lib/programmers/helpers/CloneJoiner.js.map +1 -1
  5. package/lib/programmers/internal/check_dynamic_properties.js +1 -1
  6. package/lib/programmers/internal/check_dynamic_properties.js.map +1 -1
  7. package/package.json +2 -2
  8. package/src/CustomValidatorMap.ts +126 -126
  9. package/src/IRandomGenerator.ts +34 -34
  10. package/src/IValidation.ts +21 -21
  11. package/src/Primitive.ts +131 -131
  12. package/src/TypeGuardError.ts +36 -36
  13. package/src/executable/TypiaGenerateWizard.ts +85 -85
  14. package/src/executable/TypiaSetupWizard.ts +153 -153
  15. package/src/executable/setup/ArgumentParser.ts +45 -45
  16. package/src/executable/setup/CommandExecutor.ts +8 -8
  17. package/src/executable/setup/FileRetriever.ts +22 -22
  18. package/src/executable/setup/PackageManager.ts +71 -71
  19. package/src/executable/setup/PluginConfigurator.ts +70 -70
  20. package/src/executable/typia.ts +52 -52
  21. package/src/factories/CommentFactory.ts +84 -84
  22. package/src/factories/ExpressionFactory.ts +77 -77
  23. package/src/factories/IdentifierFactory.ts +59 -59
  24. package/src/factories/LiteralFactory.ts +39 -39
  25. package/src/factories/MetadataCollection.ts +269 -269
  26. package/src/factories/MetadataFactory.ts +34 -34
  27. package/src/factories/MetadataTagFactory.ts +361 -361
  28. package/src/factories/StatementFactory.ts +24 -24
  29. package/src/factories/TemplateFactory.ts +58 -58
  30. package/src/factories/TypeFactory.ts +124 -124
  31. package/src/factories/ValueFactory.ts +12 -12
  32. package/src/factories/internal/metadata/MetadataHelper.ts +12 -12
  33. package/src/factories/internal/metadata/emend_metadata_atomics.ts +33 -33
  34. package/src/factories/internal/metadata/emplace_metadata_alias.ts +40 -40
  35. package/src/factories/internal/metadata/emplace_metadata_array.ts +34 -34
  36. package/src/factories/internal/metadata/emplace_metadata_object.ts +136 -136
  37. package/src/factories/internal/metadata/emplace_metadata_tuple.ts +50 -50
  38. package/src/factories/internal/metadata/explore_metadata.ts +38 -38
  39. package/src/factories/internal/metadata/iterate_metadata.ts +81 -81
  40. package/src/factories/internal/metadata/iterate_metadata_alias.ts +30 -30
  41. package/src/factories/internal/metadata/iterate_metadata_array.ts +24 -24
  42. package/src/factories/internal/metadata/iterate_metadata_atomic.ts +59 -59
  43. package/src/factories/internal/metadata/iterate_metadata_coalesce.ts +33 -33
  44. package/src/factories/internal/metadata/iterate_metadata_collection.ts +133 -133
  45. package/src/factories/internal/metadata/iterate_metadata_constant.ts +58 -58
  46. package/src/factories/internal/metadata/iterate_metadata_intersection.ts +88 -84
  47. package/src/factories/internal/metadata/iterate_metadata_map.ts +41 -41
  48. package/src/factories/internal/metadata/iterate_metadata_native.ts +219 -219
  49. package/src/factories/internal/metadata/iterate_metadata_object.ts +43 -43
  50. package/src/factories/internal/metadata/iterate_metadata_resolve.ts +49 -49
  51. package/src/factories/internal/metadata/iterate_metadata_set.ts +33 -33
  52. package/src/factories/internal/metadata/iterate_metadata_sort.ts +69 -69
  53. package/src/factories/internal/metadata/iterate_metadata_tag.ts +31 -31
  54. package/src/factories/internal/metadata/iterate_metadata_template.ts +38 -38
  55. package/src/factories/internal/metadata/iterate_metadata_tuple.ts +24 -24
  56. package/src/factories/internal/metadata/iterate_metadata_union.ts +24 -24
  57. package/src/functional/$any.ts +2 -2
  58. package/src/functional/$dictionary.ts +25 -25
  59. package/src/functional/$every.ts +11 -11
  60. package/src/functional/$guard.ts +35 -35
  61. package/src/functional/$is_between.ts +2 -2
  62. package/src/functional/$is_custom.ts +14 -14
  63. package/src/functional/$is_date.ts +3 -3
  64. package/src/functional/$is_datetime.ts +2 -2
  65. package/src/functional/$is_email.ts +4 -4
  66. package/src/functional/$is_ipv4.ts +4 -4
  67. package/src/functional/$is_ipv6.ts +4 -4
  68. package/src/functional/$is_url.ts +4 -4
  69. package/src/functional/$is_uuid.ts +4 -4
  70. package/src/functional/$join.ts +46 -46
  71. package/src/functional/$number.ts +12 -12
  72. package/src/functional/$report.ts +15 -15
  73. package/src/functional/$rest.ts +3 -3
  74. package/src/functional/$string.ts +50 -50
  75. package/src/functional/$tail.ts +5 -5
  76. package/src/functional/Namespace.ts +127 -127
  77. package/src/index.ts +4 -4
  78. package/src/metadata/ICommentTag.ts +4 -4
  79. package/src/metadata/IJsDocTagInfo.ts +10 -10
  80. package/src/metadata/IMetadata.ts +28 -28
  81. package/src/metadata/IMetadataAlias.ts +14 -14
  82. package/src/metadata/IMetadataApplication.ts +7 -7
  83. package/src/metadata/IMetadataArray.ts +10 -10
  84. package/src/metadata/IMetadataCollection.ts +11 -11
  85. package/src/metadata/IMetadataConstant.ts +16 -16
  86. package/src/metadata/IMetadataDictionary.ts +14 -14
  87. package/src/metadata/IMetadataEntry.ts +6 -6
  88. package/src/metadata/IMetadataObject.ts +18 -18
  89. package/src/metadata/IMetadataProperty.ts +11 -11
  90. package/src/metadata/IMetadataResolved.ts +6 -6
  91. package/src/metadata/IMetadataTag.ts +112 -112
  92. package/src/metadata/IMetadataTuple.ts +10 -10
  93. package/src/metadata/Metadata.ts +607 -607
  94. package/src/metadata/MetadataAlias.ts +66 -66
  95. package/src/metadata/MetadataArray.ts +55 -55
  96. package/src/metadata/MetadataConstant.ts +3 -3
  97. package/src/metadata/MetadataObject.ts +129 -129
  98. package/src/metadata/MetadataProperty.ts +64 -64
  99. package/src/metadata/MetadataResolved.ts +51 -51
  100. package/src/metadata/MetadataTuple.ts +58 -58
  101. package/src/module.ts +2038 -2038
  102. package/src/programmers/ApplicationProgrammer.ts +47 -47
  103. package/src/programmers/AssertCloneProgrammer.ts +71 -71
  104. package/src/programmers/AssertParseProgrammer.ts +66 -66
  105. package/src/programmers/AssertProgrammer.ts +279 -279
  106. package/src/programmers/AssertPruneProgrammer.ts +68 -68
  107. package/src/programmers/AssertStringifyProgrammer.ts +66 -66
  108. package/src/programmers/CheckerProgrammer.ts +1173 -1173
  109. package/src/programmers/CloneProgrammer.ts +587 -587
  110. package/src/programmers/FeatureProgrammer.ts +495 -495
  111. package/src/programmers/IsCloneProgrammer.ts +78 -78
  112. package/src/programmers/IsParseProgrammer.ts +72 -72
  113. package/src/programmers/IsProgrammer.ts +239 -239
  114. package/src/programmers/IsPruneProgrammer.ts +73 -73
  115. package/src/programmers/IsStringifyProgrammer.ts +76 -76
  116. package/src/programmers/LiteralsProgrammer.ts +64 -64
  117. package/src/programmers/PruneProgrammer.ts +542 -542
  118. package/src/programmers/RandomProgrammer.ts +578 -578
  119. package/src/programmers/StringifyProgrammer.ts +986 -986
  120. package/src/programmers/TypiaProgrammer.ts +129 -129
  121. package/src/programmers/ValidateCloneProgrammer.ts +85 -85
  122. package/src/programmers/ValidateParseProgrammer.ts +70 -70
  123. package/src/programmers/ValidateProgrammer.ts +305 -305
  124. package/src/programmers/ValidatePruneProgrammer.ts +78 -78
  125. package/src/programmers/ValidateStringifyProgrammer.ts +84 -84
  126. package/src/programmers/helpers/AtomicPredicator.ts +31 -31
  127. package/src/programmers/helpers/CloneJoiner.ts +168 -131
  128. package/src/programmers/helpers/FunctionImporeter.ts +78 -78
  129. package/src/programmers/helpers/ICheckEntry.ts +12 -12
  130. package/src/programmers/helpers/IExpressionEntry.ts +12 -12
  131. package/src/programmers/helpers/OptionPredicator.ts +15 -15
  132. package/src/programmers/helpers/PruneJoiner.ts +143 -143
  133. package/src/programmers/helpers/RandomJoiner.ts +173 -173
  134. package/src/programmers/helpers/RandomRanger.ts +208 -208
  135. package/src/programmers/helpers/StringifyJoinder.ts +113 -113
  136. package/src/programmers/helpers/StringifyPredicator.ts +13 -13
  137. package/src/programmers/helpers/UnionExplorer.ts +305 -305
  138. package/src/programmers/helpers/UnionPredicator.ts +81 -81
  139. package/src/programmers/helpers/disable_function_importer_declare.ts +26 -26
  140. package/src/programmers/internal/JSON_SCHEMA_PREFIX.ts +1 -1
  141. package/src/programmers/internal/application_alias.ts +66 -66
  142. package/src/programmers/internal/application_array.ts +30 -30
  143. package/src/programmers/internal/application_boolean.ts +15 -15
  144. package/src/programmers/internal/application_constant.ts +26 -26
  145. package/src/programmers/internal/application_default.ts +17 -17
  146. package/src/programmers/internal/application_default_string.ts +33 -33
  147. package/src/programmers/internal/application_native.ts +39 -39
  148. package/src/programmers/internal/application_number.ts +80 -80
  149. package/src/programmers/internal/application_object.ts +165 -165
  150. package/src/programmers/internal/application_resolved.ts +55 -55
  151. package/src/programmers/internal/application_schema.ts +157 -157
  152. package/src/programmers/internal/application_string.ts +44 -44
  153. package/src/programmers/internal/application_templates.ts +25 -25
  154. package/src/programmers/internal/application_tuple.ts +57 -57
  155. package/src/programmers/internal/check_array.ts +30 -30
  156. package/src/programmers/internal/check_array_length.ts +35 -35
  157. package/src/programmers/internal/check_bigint.ts +110 -110
  158. package/src/programmers/internal/check_custom.ts +31 -31
  159. package/src/programmers/internal/check_dynamic_properties.ts +194 -195
  160. package/src/programmers/internal/check_everything.ts +28 -28
  161. package/src/programmers/internal/check_native.ts +21 -21
  162. package/src/programmers/internal/check_object.ts +55 -55
  163. package/src/programmers/internal/check_string.ts +25 -25
  164. package/src/programmers/internal/check_string_tags.ts +67 -67
  165. package/src/programmers/internal/check_template.ts +56 -56
  166. package/src/programmers/internal/check_union_array_like.ts +329 -329
  167. package/src/programmers/internal/decode_union_object.ts +73 -73
  168. package/src/programmers/internal/feature_object_entries.ts +63 -63
  169. package/src/programmers/internal/get_comment_tags.ts +23 -23
  170. package/src/programmers/internal/metadata_to_pattern.ts +34 -34
  171. package/src/programmers/internal/prune_object_properties.ts +60 -60
  172. package/src/programmers/internal/random_custom.ts +29 -29
  173. package/src/programmers/internal/stringify_dynamic_properties.ts +171 -171
  174. package/src/programmers/internal/stringify_native.ts +7 -7
  175. package/src/programmers/internal/stringify_regular_properties.ts +83 -83
  176. package/src/programmers/internal/template_to_pattern.ts +15 -15
  177. package/src/programmers/internal/wrap_metadata_rest_tuple.ts +16 -16
  178. package/src/schemas/IJsonApplication.ts +8 -8
  179. package/src/schemas/IJsonComponents.ts +33 -33
  180. package/src/schemas/IJsonSchema.ts +133 -133
  181. package/src/transform.ts +27 -27
  182. package/src/transformers/CallExpressionTransformer.ts +179 -179
  183. package/src/transformers/FileTransformer.ts +47 -47
  184. package/src/transformers/IProject.ts +11 -11
  185. package/src/transformers/ITransformOptions.ts +62 -62
  186. package/src/transformers/ImportTransformer.ts +66 -66
  187. package/src/transformers/NodeTransformer.ts +13 -13
  188. package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +112 -112
  189. package/src/transformers/features/miscellaneous/AssertCloneTransformer.ts +9 -9
  190. package/src/transformers/features/miscellaneous/AssertPruneTransformer.ts +9 -9
  191. package/src/transformers/features/miscellaneous/CloneTransformer.ts +9 -9
  192. package/src/transformers/features/miscellaneous/CreateAssertCloneTransformer.ts +9 -9
  193. package/src/transformers/features/miscellaneous/CreateAssertPruneTransformer.ts +9 -9
  194. package/src/transformers/features/miscellaneous/CreateCloneTransformer.ts +9 -9
  195. package/src/transformers/features/miscellaneous/CreateIsCloneTransformer.ts +9 -9
  196. package/src/transformers/features/miscellaneous/CreateIsPruneTransformer.ts +9 -9
  197. package/src/transformers/features/miscellaneous/CreatePruneTransformer.ts +9 -9
  198. package/src/transformers/features/miscellaneous/CreateRandomTransformer.ts +39 -39
  199. package/src/transformers/features/miscellaneous/CreateValidateCloneTransformer.ts +9 -9
  200. package/src/transformers/features/miscellaneous/CreateValidatePruneTransformer.ts +9 -9
  201. package/src/transformers/features/miscellaneous/IsCloneTransformer.ts +9 -9
  202. package/src/transformers/features/miscellaneous/IsPruneTransformer.ts +9 -9
  203. package/src/transformers/features/miscellaneous/LiteralsTransformer.ts +28 -28
  204. package/src/transformers/features/miscellaneous/MetadataTransformer.ts +53 -53
  205. package/src/transformers/features/miscellaneous/PruneTransformer.ts +9 -9
  206. package/src/transformers/features/miscellaneous/RandomTransformer.ts +42 -42
  207. package/src/transformers/features/miscellaneous/ValidateCloneTransformer.ts +9 -9
  208. package/src/transformers/features/miscellaneous/ValidatePruneTransformer.ts +9 -9
  209. package/src/transformers/features/parsers/AssertParseTransformer.ts +9 -9
  210. package/src/transformers/features/parsers/CreateAssertParseTransformer.ts +9 -9
  211. package/src/transformers/features/parsers/CreateIsParseTransformer.ts +9 -9
  212. package/src/transformers/features/parsers/CreateValidateParseTransformer.ts +9 -9
  213. package/src/transformers/features/parsers/IsParseTransformer.ts +9 -9
  214. package/src/transformers/features/parsers/ValidateParseTransformer.ts +9 -9
  215. package/src/transformers/features/stringifiers/AssertStringifyTransformer.ts +10 -10
  216. package/src/transformers/features/stringifiers/CreateAssertStringifyTransformer.ts +12 -12
  217. package/src/transformers/features/stringifiers/CreateIsStringifyTransformer.ts +9 -9
  218. package/src/transformers/features/stringifiers/CreateStringifyTransformer.ts +9 -9
  219. package/src/transformers/features/stringifiers/CreateValidateStringifyProgrammer.ts +12 -12
  220. package/src/transformers/features/stringifiers/IsStringifyTransformer.ts +9 -9
  221. package/src/transformers/features/stringifiers/StringifyTransformer.ts +9 -9
  222. package/src/transformers/features/stringifiers/ValidateStringifyTransformer.ts +10 -10
  223. package/src/transformers/features/validators/AssertTransformer.ts +11 -11
  224. package/src/transformers/features/validators/CreateAssertTransformer.ts +13 -13
  225. package/src/transformers/features/validators/CreateIsTransformer.ts +11 -11
  226. package/src/transformers/features/validators/CreateValidateTransformer.ts +13 -13
  227. package/src/transformers/features/validators/IsTransformer.ts +11 -11
  228. package/src/transformers/features/validators/ValidateTransformer.ts +11 -11
  229. package/src/transformers/internal/GenericTransformer.ts +97 -97
  230. package/src/typings/Atomic.ts +17 -17
  231. package/src/typings/ClassProperties.ts +5 -5
  232. package/src/typings/Customizable.ts +5 -5
  233. package/src/typings/OmitNever.ts +3 -3
  234. package/src/typings/SpecialFields.ts +3 -3
  235. package/src/typings/Writable.ts +11 -11
  236. package/src/utils/ArrayUtil.ts +45 -45
  237. package/src/utils/Escaper.ts +46 -46
  238. package/src/utils/MapUtil.ts +12 -12
  239. package/src/utils/PatternUtil.ts +33 -33
  240. package/src/utils/RandomGenerator.ts +81 -81
  241. package/src/utils/Singleton.ts +17 -17
@@ -1,587 +1,587 @@
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 "../metadata/IJsDocTagInfo";
11
- import { IMetadataTag } from "../metadata/IMetadataTag";
12
- import { Metadata } from "../metadata/Metadata";
13
- import { MetadataArray } from "../metadata/MetadataArray";
14
- import { MetadataTuple } from "../metadata/MetadataTuple";
15
-
16
- import { IProject } from "../transformers/IProject";
17
-
18
- import { FeatureProgrammer } from "./FeatureProgrammer";
19
- import { IsProgrammer } from "./IsProgrammer";
20
- import { CloneJoiner } from "./helpers/CloneJoiner";
21
- import { FunctionImporter } from "./helpers/FunctionImporeter";
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 CloneProgrammer {
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.Expression => {
118
- // ANY TYPE
119
- if (
120
- meta.any ||
121
- meta.arrays.some((a) => a.value.any) ||
122
- meta.tuples.some((t) => t.elements.every((e) => e.any))
123
- )
124
- return ts.factory.createCallExpression(
125
- importer.use("any"),
126
- undefined,
127
- [input],
128
- );
129
-
130
- interface IUnion {
131
- type: string;
132
- is: () => ts.Expression;
133
- value: () => ts.Expression;
134
- }
135
- const unions: IUnion[] = [];
136
-
137
- //----
138
- // LIST UP UNION TYPES
139
- //----
140
- // toJSON() METHOD
141
- if (meta.resolved !== null)
142
- unions.push({
143
- type: "resolved",
144
- is: () => IsProgrammer.decode_to_json(true)(input),
145
- value: () =>
146
- decode_to_json(project)(config)(importer)(
147
- input,
148
- meta.resolved!.returns,
149
- explore,
150
- ),
151
- });
152
-
153
- // TUPLES
154
- for (const tuple of meta.tuples)
155
- unions.push({
156
- type: "tuple",
157
- is: () =>
158
- IsProgrammer.decode(project)(importer)(
159
- input,
160
- (() => {
161
- const partial = Metadata.initialize();
162
- partial.tuples.push(tuple);
163
- return partial;
164
- })(),
165
- explore,
166
- [],
167
- [],
168
- ),
169
- value: () =>
170
- decode_tuple(project)(config)(importer)(
171
- input,
172
- tuple,
173
- explore,
174
- ),
175
- });
176
-
177
- // ARRAYS
178
- if (meta.arrays.length)
179
- unions.push({
180
- type: "array",
181
- is: () => ExpressionFactory.isArray(input),
182
- value: () =>
183
- explore_arrays(project)(config)(importer)(
184
- input,
185
- meta.arrays,
186
- {
187
- ...explore,
188
- from: "array",
189
- },
190
- ),
191
- });
192
-
193
- // NATIVE TYPES
194
- if (meta.sets.length)
195
- unions.push({
196
- type: "set",
197
- is: () => ExpressionFactory.isInstanceOf("Set")(input),
198
- value: () => ts.factory.createIdentifier("{}"),
199
- });
200
- if (meta.maps.length)
201
- unions.push({
202
- type: "map",
203
- is: () => ExpressionFactory.isInstanceOf("Map")(input),
204
- value: () => ts.factory.createIdentifier("{}"),
205
- });
206
- for (const native of meta.natives)
207
- unions.push({
208
- type: "native",
209
- is: () => ExpressionFactory.isInstanceOf(native)(input),
210
- value: () =>
211
- native === "Boolean" ||
212
- native === "Number" ||
213
- native === "String"
214
- ? ts.factory.createCallExpression(
215
- IdentifierFactory.access(input)("valueOf"),
216
- undefined,
217
- undefined,
218
- )
219
- : ts.factory.createIdentifier("{}"),
220
- });
221
-
222
- // OBJECTS
223
- if (meta.objects.length)
224
- unions.push({
225
- type: "object",
226
- is: () =>
227
- ExpressionFactory.isObject({
228
- checkNull: true,
229
- checkArray: false,
230
- })(input),
231
- value: () =>
232
- explore_objects(config)(importer)(input, meta, {
233
- ...explore,
234
- from: "object",
235
- }),
236
- });
237
-
238
- // COMPOSITION
239
- let last: ts.Expression = input;
240
- for (const u of unions.reverse())
241
- last = ts.factory.createConditionalExpression(
242
- u.is(),
243
- undefined,
244
- u.value(),
245
- undefined,
246
- last,
247
- );
248
- return ts.factory.createAsExpression(
249
- last,
250
- TypeFactory.keyword("any"),
251
- );
252
- };
253
-
254
- const decode_to_json =
255
- (project: IProject) =>
256
- (config: FeatureProgrammer.IConfig) =>
257
- (importer: FunctionImporter) =>
258
- (
259
- input: ts.Expression,
260
- resolved: Metadata,
261
- explore: FeatureProgrammer.IExplore,
262
- ): ts.Expression => {
263
- return decode(project)(config)(importer)(
264
- ts.factory.createCallExpression(
265
- IdentifierFactory.access(input)("toJSON"),
266
- undefined,
267
- [],
268
- ),
269
- resolved,
270
- explore,
271
- );
272
- };
273
-
274
- const decode_object = (importer: FunctionImporter) =>
275
- FeatureProgrammer.decode_object({
276
- trace: false,
277
- path: false,
278
- prefix: PREFIX,
279
- })(importer);
280
-
281
- const decode_array =
282
- (config: FeatureProgrammer.IConfig) =>
283
- (importer: FunctionImporter) =>
284
- (
285
- input: ts.Expression,
286
- array: MetadataArray,
287
- explore: FeatureProgrammer.IExplore,
288
- ) =>
289
- array.recursive
290
- ? ts.factory.createCallExpression(
291
- ts.factory.createIdentifier(
292
- importer.useLocal(`${config.prefix}a${array.index}`),
293
- ),
294
- undefined,
295
- FeatureProgrammer.argumentsArray(config)({
296
- ...explore,
297
- source: "function",
298
- from: "array",
299
- })(input),
300
- )
301
- : decode_array_inline(config)(importer)(input, array, explore);
302
-
303
- const decode_array_inline =
304
- (config: FeatureProgrammer.IConfig) =>
305
- (importer: FunctionImporter) =>
306
- (
307
- input: ts.Expression,
308
- array: MetadataArray,
309
- explore: FeatureProgrammer.IExplore,
310
- ) =>
311
- FeatureProgrammer.decode_array(config)(importer)(CloneJoiner.array)(
312
- input,
313
- array,
314
- explore,
315
- [],
316
- [],
317
- );
318
-
319
- const decode_tuple =
320
- (project: IProject) =>
321
- (config: FeatureProgrammer.IConfig) =>
322
- (importer: FunctionImporter) =>
323
- (
324
- input: ts.Expression,
325
- tuple: MetadataTuple,
326
- explore: FeatureProgrammer.IExplore,
327
- ): ts.Expression =>
328
- tuple.recursive
329
- ? ts.factory.createCallExpression(
330
- ts.factory.createIdentifier(
331
- importer.useLocal(`${config.prefix}t${tuple.index}`),
332
- ),
333
- undefined,
334
- FeatureProgrammer.argumentsArray(config)({
335
- ...explore,
336
- source: "function",
337
- })(input),
338
- )
339
- : decode_tuple_inline(project)(config)(importer)(
340
- input,
341
- tuple,
342
- explore,
343
- );
344
-
345
- const decode_tuple_inline =
346
- (project: IProject) =>
347
- (config: FeatureProgrammer.IConfig) =>
348
- (importer: FunctionImporter) =>
349
- (
350
- input: ts.Expression,
351
- tuple: MetadataTuple,
352
- explore: FeatureProgrammer.IExplore,
353
- ): ts.Expression => {
354
- const children: ts.Expression[] = tuple.elements
355
- .filter((m) => m.rest === null)
356
- .map((elem, index) =>
357
- decode(project)(config)(importer)(
358
- ts.factory.createElementAccessExpression(input, index),
359
- elem,
360
- {
361
- ...explore,
362
- from: "array",
363
- postfix: explore.postfix.length
364
- ? `${explore.postfix.slice(0, -1)}[${index}]"`
365
- : `"[${index}]"`,
366
- },
367
- ),
368
- );
369
- const rest = (() => {
370
- if (tuple.elements.length === 0) return null;
371
-
372
- const last: Metadata = tuple.elements.at(-1)!;
373
- const rest: Metadata | null = last.rest;
374
- if (rest === null) return null;
375
-
376
- return decode(project)(config)(importer)(
377
- ts.factory.createCallExpression(
378
- IdentifierFactory.access(input)("slice"),
379
- undefined,
380
- [
381
- ts.factory.createNumericLiteral(
382
- tuple.elements.length - 1,
383
- ),
384
- ],
385
- ),
386
- wrap_metadata_rest_tuple(tuple.elements.at(-1)!.rest!),
387
- {
388
- ...explore,
389
- start: tuple.elements.length - 1,
390
- },
391
- );
392
- })();
393
- return CloneJoiner.tuple(children, rest);
394
- };
395
-
396
- /* -----------------------------------------------------------
397
- EXPLORERS FOR UNION TYPES
398
- ----------------------------------------------------------- */
399
- const explore_objects =
400
- (config: FeatureProgrammer.IConfig) =>
401
- (importer: FunctionImporter) =>
402
- (
403
- input: ts.Expression,
404
- meta: Metadata,
405
- explore: FeatureProgrammer.IExplore,
406
- ) => {
407
- if (meta.objects.length === 1)
408
- return decode_object(importer)(
409
- input,
410
- meta.objects[0]!,
411
- explore,
412
- );
413
-
414
- return ts.factory.createCallExpression(
415
- ts.factory.createIdentifier(
416
- importer.useLocal(`${PREFIX}u${meta.union_index!}`),
417
- ),
418
- undefined,
419
- FeatureProgrammer.argumentsArray(config)(explore)(input),
420
- );
421
- };
422
-
423
- const explore_arrays =
424
- (project: IProject) =>
425
- (config: FeatureProgrammer.IConfig) =>
426
- (importer: FunctionImporter) =>
427
- (
428
- input: ts.Expression,
429
- elements: MetadataArray[],
430
- explore: FeatureProgrammer.IExplore,
431
- ): ts.Expression =>
432
- explore_array_like_union_types(config)(importer)(
433
- UnionExplorer.array({
434
- checker: IsProgrammer.decode(project)(importer),
435
- decoder: decode_array(config)(importer),
436
- empty: ts.factory.createIdentifier("[]"),
437
- success: ts.factory.createTrue(),
438
- failure: (input, expected) =>
439
- create_throw_error(importer)(expected)(input),
440
- }),
441
- )(input, elements, explore);
442
-
443
- const explore_array_like_union_types =
444
- (config: FeatureProgrammer.IConfig) =>
445
- (importer: FunctionImporter) =>
446
- <T extends MetadataArray | MetadataTuple>(
447
- factory: (
448
- parameters: ts.ParameterDeclaration[],
449
- ) => (
450
- input: ts.Expression,
451
- elements: T[],
452
- explore: FeatureProgrammer.IExplore,
453
- tags: IMetadataTag[],
454
- jsDocTags: IJsDocTagInfo[],
455
- ) => ts.ArrowFunction,
456
- ) =>
457
- (
458
- input: ts.Expression,
459
- elements: T[],
460
- explore: FeatureProgrammer.IExplore,
461
- ): ts.Expression => {
462
- const arrow =
463
- (parameters: ts.ParameterDeclaration[]) =>
464
- (explore: FeatureProgrammer.IExplore) =>
465
- (input: ts.Expression): ts.ArrowFunction =>
466
- factory(parameters)(input, elements, explore, [], []);
467
- if (elements.every((e) => e.recursive === false))
468
- ts.factory.createCallExpression(
469
- arrow([])(explore)(input),
470
- undefined,
471
- [],
472
- );
473
-
474
- explore = {
475
- ...explore,
476
- source: "function",
477
- from: "array",
478
- };
479
- return ts.factory.createCallExpression(
480
- ts.factory.createIdentifier(
481
- importer.emplaceUnion(
482
- config.prefix,
483
- elements.map((e) => e.name).join(" | "),
484
- () =>
485
- arrow(
486
- FeatureProgrammer.parameterDeclarations(config)(
487
- TypeFactory.keyword("any"),
488
- )(ts.factory.createIdentifier("input")),
489
- )({
490
- ...explore,
491
- postfix: "",
492
- })(ts.factory.createIdentifier("input")),
493
- ),
494
- ),
495
- undefined,
496
- FeatureProgrammer.argumentsArray(config)(explore)(input),
497
- );
498
- };
499
-
500
- /* -----------------------------------------------------------
501
- CONFIGURATIONS
502
- ----------------------------------------------------------- */
503
- const PREFIX = "$c";
504
-
505
- const configure =
506
- (project: IProject) =>
507
- (importer: FunctionImporter): FeatureProgrammer.IConfig => {
508
- const config: FeatureProgrammer.IConfig = {
509
- types: {
510
- input: (type, name) =>
511
- ts.factory.createTypeReferenceNode(
512
- name ??
513
- TypeFactory.getFullName(project.checker)(type),
514
- ),
515
- output: (type, name) =>
516
- ts.factory.createTypeReferenceNode(
517
- `typia.Primitive<${
518
- name ??
519
- TypeFactory.getFullName(project.checker)(type)
520
- }>`,
521
- ),
522
- },
523
- prefix: PREFIX,
524
- trace: false,
525
- path: false,
526
- initializer,
527
- decoder: () => decode(project)(config)(importer),
528
- objector: {
529
- checker: () => IsProgrammer.decode(project)(importer),
530
- decoder: () => decode_object(importer),
531
- joiner: CloneJoiner.object,
532
- unionizer: decode_union_object(
533
- IsProgrammer.decode_object(importer),
534
- )(decode_object(importer))((exp) => exp)(
535
- (input, expected) =>
536
- create_throw_error(importer)(expected)(input),
537
- ),
538
- failure: (input, expected) =>
539
- create_throw_error(importer)(expected)(input),
540
- },
541
- generator: {
542
- arrays: () => write_array_functions(config)(importer),
543
- tuples: () =>
544
- write_tuple_functions(project)(config)(importer),
545
- },
546
- };
547
- return config;
548
- };
549
-
550
- const initializer: FeatureProgrammer.IConfig["initializer"] =
551
- ({ checker }) =>
552
- (type) => {
553
- const collection = new MetadataCollection();
554
- const meta = MetadataFactory.analyze(checker)({
555
- resolve: true,
556
- constant: true,
557
- absorb: true,
558
- })(collection)(type);
559
- return [collection, meta];
560
- };
561
-
562
- const create_throw_error =
563
- (importer: FunctionImporter) =>
564
- (expected: string) =>
565
- (value: ts.Expression) =>
566
- ts.factory.createExpressionStatement(
567
- ts.factory.createCallExpression(
568
- importer.use("throws"),
569
- [],
570
- [
571
- ts.factory.createObjectLiteralExpression(
572
- [
573
- ts.factory.createPropertyAssignment(
574
- "expected",
575
- ts.factory.createStringLiteral(expected),
576
- ),
577
- ts.factory.createPropertyAssignment(
578
- "value",
579
- value,
580
- ),
581
- ],
582
- true,
583
- ),
584
- ],
585
- ),
586
- );
587
- }
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 "../metadata/IJsDocTagInfo";
11
+ import { IMetadataTag } from "../metadata/IMetadataTag";
12
+ import { Metadata } from "../metadata/Metadata";
13
+ import { MetadataArray } from "../metadata/MetadataArray";
14
+ import { MetadataTuple } from "../metadata/MetadataTuple";
15
+
16
+ import { IProject } from "../transformers/IProject";
17
+
18
+ import { FeatureProgrammer } from "./FeatureProgrammer";
19
+ import { IsProgrammer } from "./IsProgrammer";
20
+ import { CloneJoiner } from "./helpers/CloneJoiner";
21
+ import { FunctionImporter } from "./helpers/FunctionImporeter";
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 CloneProgrammer {
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.Expression => {
118
+ // ANY TYPE
119
+ if (
120
+ meta.any ||
121
+ meta.arrays.some((a) => a.value.any) ||
122
+ meta.tuples.some((t) => t.elements.every((e) => e.any))
123
+ )
124
+ return ts.factory.createCallExpression(
125
+ importer.use("any"),
126
+ undefined,
127
+ [input],
128
+ );
129
+
130
+ interface IUnion {
131
+ type: string;
132
+ is: () => ts.Expression;
133
+ value: () => ts.Expression;
134
+ }
135
+ const unions: IUnion[] = [];
136
+
137
+ //----
138
+ // LIST UP UNION TYPES
139
+ //----
140
+ // toJSON() METHOD
141
+ if (meta.resolved !== null)
142
+ unions.push({
143
+ type: "resolved",
144
+ is: () => IsProgrammer.decode_to_json(true)(input),
145
+ value: () =>
146
+ decode_to_json(project)(config)(importer)(
147
+ input,
148
+ meta.resolved!.returns,
149
+ explore,
150
+ ),
151
+ });
152
+
153
+ // TUPLES
154
+ for (const tuple of meta.tuples)
155
+ unions.push({
156
+ type: "tuple",
157
+ is: () =>
158
+ IsProgrammer.decode(project)(importer)(
159
+ input,
160
+ (() => {
161
+ const partial = Metadata.initialize();
162
+ partial.tuples.push(tuple);
163
+ return partial;
164
+ })(),
165
+ explore,
166
+ [],
167
+ [],
168
+ ),
169
+ value: () =>
170
+ decode_tuple(project)(config)(importer)(
171
+ input,
172
+ tuple,
173
+ explore,
174
+ ),
175
+ });
176
+
177
+ // ARRAYS
178
+ if (meta.arrays.length)
179
+ unions.push({
180
+ type: "array",
181
+ is: () => ExpressionFactory.isArray(input),
182
+ value: () =>
183
+ explore_arrays(project)(config)(importer)(
184
+ input,
185
+ meta.arrays,
186
+ {
187
+ ...explore,
188
+ from: "array",
189
+ },
190
+ ),
191
+ });
192
+
193
+ // NATIVE TYPES
194
+ if (meta.sets.length)
195
+ unions.push({
196
+ type: "set",
197
+ is: () => ExpressionFactory.isInstanceOf("Set")(input),
198
+ value: () => ts.factory.createIdentifier("{}"),
199
+ });
200
+ if (meta.maps.length)
201
+ unions.push({
202
+ type: "map",
203
+ is: () => ExpressionFactory.isInstanceOf("Map")(input),
204
+ value: () => ts.factory.createIdentifier("{}"),
205
+ });
206
+ for (const native of meta.natives)
207
+ unions.push({
208
+ type: "native",
209
+ is: () => ExpressionFactory.isInstanceOf(native)(input),
210
+ value: () =>
211
+ native === "Boolean" ||
212
+ native === "Number" ||
213
+ native === "String"
214
+ ? ts.factory.createCallExpression(
215
+ IdentifierFactory.access(input)("valueOf"),
216
+ undefined,
217
+ undefined,
218
+ )
219
+ : ts.factory.createIdentifier("{}"),
220
+ });
221
+
222
+ // OBJECTS
223
+ if (meta.objects.length)
224
+ unions.push({
225
+ type: "object",
226
+ is: () =>
227
+ ExpressionFactory.isObject({
228
+ checkNull: true,
229
+ checkArray: false,
230
+ })(input),
231
+ value: () =>
232
+ explore_objects(config)(importer)(input, meta, {
233
+ ...explore,
234
+ from: "object",
235
+ }),
236
+ });
237
+
238
+ // COMPOSITION
239
+ let last: ts.Expression = input;
240
+ for (const u of unions.reverse())
241
+ last = ts.factory.createConditionalExpression(
242
+ u.is(),
243
+ undefined,
244
+ u.value(),
245
+ undefined,
246
+ last,
247
+ );
248
+ return ts.factory.createAsExpression(
249
+ last,
250
+ TypeFactory.keyword("any"),
251
+ );
252
+ };
253
+
254
+ const decode_to_json =
255
+ (project: IProject) =>
256
+ (config: FeatureProgrammer.IConfig) =>
257
+ (importer: FunctionImporter) =>
258
+ (
259
+ input: ts.Expression,
260
+ resolved: Metadata,
261
+ explore: FeatureProgrammer.IExplore,
262
+ ): ts.Expression => {
263
+ return decode(project)(config)(importer)(
264
+ ts.factory.createCallExpression(
265
+ IdentifierFactory.access(input)("toJSON"),
266
+ undefined,
267
+ [],
268
+ ),
269
+ resolved,
270
+ explore,
271
+ );
272
+ };
273
+
274
+ const decode_object = (importer: FunctionImporter) =>
275
+ FeatureProgrammer.decode_object({
276
+ trace: false,
277
+ path: false,
278
+ prefix: PREFIX,
279
+ })(importer);
280
+
281
+ const decode_array =
282
+ (config: FeatureProgrammer.IConfig) =>
283
+ (importer: FunctionImporter) =>
284
+ (
285
+ input: ts.Expression,
286
+ array: MetadataArray,
287
+ explore: FeatureProgrammer.IExplore,
288
+ ) =>
289
+ array.recursive
290
+ ? ts.factory.createCallExpression(
291
+ ts.factory.createIdentifier(
292
+ importer.useLocal(`${config.prefix}a${array.index}`),
293
+ ),
294
+ undefined,
295
+ FeatureProgrammer.argumentsArray(config)({
296
+ ...explore,
297
+ source: "function",
298
+ from: "array",
299
+ })(input),
300
+ )
301
+ : decode_array_inline(config)(importer)(input, array, explore);
302
+
303
+ const decode_array_inline =
304
+ (config: FeatureProgrammer.IConfig) =>
305
+ (importer: FunctionImporter) =>
306
+ (
307
+ input: ts.Expression,
308
+ array: MetadataArray,
309
+ explore: FeatureProgrammer.IExplore,
310
+ ) =>
311
+ FeatureProgrammer.decode_array(config)(importer)(CloneJoiner.array)(
312
+ input,
313
+ array,
314
+ explore,
315
+ [],
316
+ [],
317
+ );
318
+
319
+ const decode_tuple =
320
+ (project: IProject) =>
321
+ (config: FeatureProgrammer.IConfig) =>
322
+ (importer: FunctionImporter) =>
323
+ (
324
+ input: ts.Expression,
325
+ tuple: MetadataTuple,
326
+ explore: FeatureProgrammer.IExplore,
327
+ ): ts.Expression =>
328
+ tuple.recursive
329
+ ? ts.factory.createCallExpression(
330
+ ts.factory.createIdentifier(
331
+ importer.useLocal(`${config.prefix}t${tuple.index}`),
332
+ ),
333
+ undefined,
334
+ FeatureProgrammer.argumentsArray(config)({
335
+ ...explore,
336
+ source: "function",
337
+ })(input),
338
+ )
339
+ : decode_tuple_inline(project)(config)(importer)(
340
+ input,
341
+ tuple,
342
+ explore,
343
+ );
344
+
345
+ const decode_tuple_inline =
346
+ (project: IProject) =>
347
+ (config: FeatureProgrammer.IConfig) =>
348
+ (importer: FunctionImporter) =>
349
+ (
350
+ input: ts.Expression,
351
+ tuple: MetadataTuple,
352
+ explore: FeatureProgrammer.IExplore,
353
+ ): ts.Expression => {
354
+ const children: ts.Expression[] = tuple.elements
355
+ .filter((m) => m.rest === null)
356
+ .map((elem, index) =>
357
+ decode(project)(config)(importer)(
358
+ ts.factory.createElementAccessExpression(input, index),
359
+ elem,
360
+ {
361
+ ...explore,
362
+ from: "array",
363
+ postfix: explore.postfix.length
364
+ ? `${explore.postfix.slice(0, -1)}[${index}]"`
365
+ : `"[${index}]"`,
366
+ },
367
+ ),
368
+ );
369
+ const rest = (() => {
370
+ if (tuple.elements.length === 0) return null;
371
+
372
+ const last: Metadata = tuple.elements.at(-1)!;
373
+ const rest: Metadata | null = last.rest;
374
+ if (rest === null) return null;
375
+
376
+ return decode(project)(config)(importer)(
377
+ ts.factory.createCallExpression(
378
+ IdentifierFactory.access(input)("slice"),
379
+ undefined,
380
+ [
381
+ ts.factory.createNumericLiteral(
382
+ tuple.elements.length - 1,
383
+ ),
384
+ ],
385
+ ),
386
+ wrap_metadata_rest_tuple(tuple.elements.at(-1)!.rest!),
387
+ {
388
+ ...explore,
389
+ start: tuple.elements.length - 1,
390
+ },
391
+ );
392
+ })();
393
+ return CloneJoiner.tuple(children, rest);
394
+ };
395
+
396
+ /* -----------------------------------------------------------
397
+ EXPLORERS FOR UNION TYPES
398
+ ----------------------------------------------------------- */
399
+ const explore_objects =
400
+ (config: FeatureProgrammer.IConfig) =>
401
+ (importer: FunctionImporter) =>
402
+ (
403
+ input: ts.Expression,
404
+ meta: Metadata,
405
+ explore: FeatureProgrammer.IExplore,
406
+ ) => {
407
+ if (meta.objects.length === 1)
408
+ return decode_object(importer)(
409
+ input,
410
+ meta.objects[0]!,
411
+ explore,
412
+ );
413
+
414
+ return ts.factory.createCallExpression(
415
+ ts.factory.createIdentifier(
416
+ importer.useLocal(`${PREFIX}u${meta.union_index!}`),
417
+ ),
418
+ undefined,
419
+ FeatureProgrammer.argumentsArray(config)(explore)(input),
420
+ );
421
+ };
422
+
423
+ const explore_arrays =
424
+ (project: IProject) =>
425
+ (config: FeatureProgrammer.IConfig) =>
426
+ (importer: FunctionImporter) =>
427
+ (
428
+ input: ts.Expression,
429
+ elements: MetadataArray[],
430
+ explore: FeatureProgrammer.IExplore,
431
+ ): ts.Expression =>
432
+ explore_array_like_union_types(config)(importer)(
433
+ UnionExplorer.array({
434
+ checker: IsProgrammer.decode(project)(importer),
435
+ decoder: decode_array(config)(importer),
436
+ empty: ts.factory.createIdentifier("[]"),
437
+ success: ts.factory.createTrue(),
438
+ failure: (input, expected) =>
439
+ create_throw_error(importer)(expected)(input),
440
+ }),
441
+ )(input, elements, explore);
442
+
443
+ const explore_array_like_union_types =
444
+ (config: FeatureProgrammer.IConfig) =>
445
+ (importer: FunctionImporter) =>
446
+ <T extends MetadataArray | MetadataTuple>(
447
+ factory: (
448
+ parameters: ts.ParameterDeclaration[],
449
+ ) => (
450
+ input: ts.Expression,
451
+ elements: T[],
452
+ explore: FeatureProgrammer.IExplore,
453
+ tags: IMetadataTag[],
454
+ jsDocTags: IJsDocTagInfo[],
455
+ ) => ts.ArrowFunction,
456
+ ) =>
457
+ (
458
+ input: ts.Expression,
459
+ elements: T[],
460
+ explore: FeatureProgrammer.IExplore,
461
+ ): ts.Expression => {
462
+ const arrow =
463
+ (parameters: ts.ParameterDeclaration[]) =>
464
+ (explore: FeatureProgrammer.IExplore) =>
465
+ (input: ts.Expression): ts.ArrowFunction =>
466
+ factory(parameters)(input, elements, explore, [], []);
467
+ if (elements.every((e) => e.recursive === false))
468
+ ts.factory.createCallExpression(
469
+ arrow([])(explore)(input),
470
+ undefined,
471
+ [],
472
+ );
473
+
474
+ explore = {
475
+ ...explore,
476
+ source: "function",
477
+ from: "array",
478
+ };
479
+ return ts.factory.createCallExpression(
480
+ ts.factory.createIdentifier(
481
+ importer.emplaceUnion(
482
+ config.prefix,
483
+ elements.map((e) => e.name).join(" | "),
484
+ () =>
485
+ arrow(
486
+ FeatureProgrammer.parameterDeclarations(config)(
487
+ TypeFactory.keyword("any"),
488
+ )(ts.factory.createIdentifier("input")),
489
+ )({
490
+ ...explore,
491
+ postfix: "",
492
+ })(ts.factory.createIdentifier("input")),
493
+ ),
494
+ ),
495
+ undefined,
496
+ FeatureProgrammer.argumentsArray(config)(explore)(input),
497
+ );
498
+ };
499
+
500
+ /* -----------------------------------------------------------
501
+ CONFIGURATIONS
502
+ ----------------------------------------------------------- */
503
+ const PREFIX = "$c";
504
+
505
+ const configure =
506
+ (project: IProject) =>
507
+ (importer: FunctionImporter): FeatureProgrammer.IConfig => {
508
+ const config: FeatureProgrammer.IConfig = {
509
+ types: {
510
+ input: (type, name) =>
511
+ ts.factory.createTypeReferenceNode(
512
+ name ??
513
+ TypeFactory.getFullName(project.checker)(type),
514
+ ),
515
+ output: (type, name) =>
516
+ ts.factory.createTypeReferenceNode(
517
+ `typia.Primitive<${
518
+ name ??
519
+ TypeFactory.getFullName(project.checker)(type)
520
+ }>`,
521
+ ),
522
+ },
523
+ prefix: PREFIX,
524
+ trace: false,
525
+ path: false,
526
+ initializer,
527
+ decoder: () => decode(project)(config)(importer),
528
+ objector: {
529
+ checker: () => IsProgrammer.decode(project)(importer),
530
+ decoder: () => decode_object(importer),
531
+ joiner: CloneJoiner.object,
532
+ unionizer: decode_union_object(
533
+ IsProgrammer.decode_object(importer),
534
+ )(decode_object(importer))((exp) => exp)(
535
+ (input, expected) =>
536
+ create_throw_error(importer)(expected)(input),
537
+ ),
538
+ failure: (input, expected) =>
539
+ create_throw_error(importer)(expected)(input),
540
+ },
541
+ generator: {
542
+ arrays: () => write_array_functions(config)(importer),
543
+ tuples: () =>
544
+ write_tuple_functions(project)(config)(importer),
545
+ },
546
+ };
547
+ return config;
548
+ };
549
+
550
+ const initializer: FeatureProgrammer.IConfig["initializer"] =
551
+ ({ checker }) =>
552
+ (type) => {
553
+ const collection = new MetadataCollection();
554
+ const meta = MetadataFactory.analyze(checker)({
555
+ resolve: true,
556
+ constant: true,
557
+ absorb: true,
558
+ })(collection)(type);
559
+ return [collection, meta];
560
+ };
561
+
562
+ const create_throw_error =
563
+ (importer: FunctionImporter) =>
564
+ (expected: string) =>
565
+ (value: ts.Expression) =>
566
+ ts.factory.createExpressionStatement(
567
+ ts.factory.createCallExpression(
568
+ importer.use("throws"),
569
+ [],
570
+ [
571
+ ts.factory.createObjectLiteralExpression(
572
+ [
573
+ ts.factory.createPropertyAssignment(
574
+ "expected",
575
+ ts.factory.createStringLiteral(expected),
576
+ ),
577
+ ts.factory.createPropertyAssignment(
578
+ "value",
579
+ value,
580
+ ),
581
+ ],
582
+ true,
583
+ ),
584
+ ],
585
+ ),
586
+ );
587
+ }