typia 3.5.8 → 3.6.0-dev.20230225

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 (279) hide show
  1. package/README.md +2 -0
  2. package/lib/Primitive.d.ts +2 -1
  3. package/lib/executable/TypiaGenerateWizard.d.ts +8 -0
  4. package/lib/executable/TypiaGenerateWizard.js +182 -0
  5. package/lib/executable/TypiaGenerateWizard.js.map +1 -0
  6. package/lib/executable/typia.js +11 -4
  7. package/lib/executable/typia.js.map +1 -1
  8. package/lib/factories/IdentifierFactory.d.ts +1 -1
  9. package/lib/factories/IdentifierFactory.js +3 -3
  10. package/lib/factories/IdentifierFactory.js.map +1 -1
  11. package/lib/factories/TypeFactory.d.ts +1 -0
  12. package/lib/factories/TypeFactory.js +17 -1
  13. package/lib/factories/TypeFactory.js.map +1 -1
  14. package/lib/factories/TypiaFileFactory.d.ts +8 -0
  15. package/lib/factories/TypiaFileFactory.js +236 -0
  16. package/lib/factories/TypiaFileFactory.js.map +1 -0
  17. package/lib/programmers/AssertCloneProgrammer.js +4 -1
  18. package/lib/programmers/AssertCloneProgrammer.js.map +1 -1
  19. package/lib/programmers/AssertParseProgrammer.js +4 -1
  20. package/lib/programmers/AssertParseProgrammer.js.map +1 -1
  21. package/lib/programmers/AssertProgrammer.js +4 -1
  22. package/lib/programmers/AssertProgrammer.js.map +1 -1
  23. package/lib/programmers/AssertPruneProgrammer.js +4 -1
  24. package/lib/programmers/AssertPruneProgrammer.js.map +1 -1
  25. package/lib/programmers/AssertStringifyProgrammer.js +4 -1
  26. package/lib/programmers/AssertStringifyProgrammer.js.map +1 -1
  27. package/lib/programmers/CheckerProgrammer.d.ts +1 -1
  28. package/lib/programmers/CheckerProgrammer.js +8 -0
  29. package/lib/programmers/CheckerProgrammer.js.map +1 -1
  30. package/lib/programmers/CloneProgrammer.d.ts +1 -1
  31. package/lib/programmers/CloneProgrammer.js +17 -2
  32. package/lib/programmers/CloneProgrammer.js.map +1 -1
  33. package/lib/programmers/FeatureProgrammer.d.ts +10 -1
  34. package/lib/programmers/FeatureProgrammer.js +24 -16
  35. package/lib/programmers/FeatureProgrammer.js.map +1 -1
  36. package/lib/programmers/IsCloneProgrammer.js +7 -1
  37. package/lib/programmers/IsCloneProgrammer.js.map +1 -1
  38. package/lib/programmers/IsParseProgrammer.js +5 -2
  39. package/lib/programmers/IsParseProgrammer.js.map +1 -1
  40. package/lib/programmers/IsProgrammer.d.ts +1 -1
  41. package/lib/programmers/IsPruneProgrammer.js +4 -1
  42. package/lib/programmers/IsPruneProgrammer.js.map +1 -1
  43. package/lib/programmers/IsStringifyProgrammer.js +7 -1
  44. package/lib/programmers/IsStringifyProgrammer.js.map +1 -1
  45. package/lib/programmers/PruneProgrammer.d.ts +1 -1
  46. package/lib/programmers/PruneProgrammer.js +7 -0
  47. package/lib/programmers/PruneProgrammer.js.map +1 -1
  48. package/lib/programmers/RandomProgrammer.js +9 -8
  49. package/lib/programmers/RandomProgrammer.js.map +1 -1
  50. package/lib/programmers/StringifyProgrammer.d.ts +1 -1
  51. package/lib/programmers/StringifyProgrammer.js +7 -0
  52. package/lib/programmers/StringifyProgrammer.js.map +1 -1
  53. package/lib/programmers/ValidateCloneProgrammer.js +5 -2
  54. package/lib/programmers/ValidateCloneProgrammer.js.map +1 -1
  55. package/lib/programmers/ValidateParseProgrammer.js +4 -1
  56. package/lib/programmers/ValidateParseProgrammer.js.map +1 -1
  57. package/lib/programmers/ValidateProgrammer.js +7 -4
  58. package/lib/programmers/ValidateProgrammer.js.map +1 -1
  59. package/lib/programmers/ValidatePruneProgrammer.js +4 -1
  60. package/lib/programmers/ValidatePruneProgrammer.js.map +1 -1
  61. package/lib/programmers/ValidateStringifyProgrammer.js +5 -2
  62. package/lib/programmers/ValidateStringifyProgrammer.js.map +1 -1
  63. package/lib/programmers/helpers/CloneJoiner.js +5 -4
  64. package/lib/programmers/helpers/CloneJoiner.js.map +1 -1
  65. package/lib/programmers/helpers/FunctionImporeter.js +2 -1
  66. package/lib/programmers/helpers/FunctionImporeter.js.map +1 -1
  67. package/lib/programmers/helpers/RandomJoiner.js +3 -2
  68. package/lib/programmers/helpers/RandomJoiner.js.map +1 -1
  69. package/lib/programmers/internal/check_everything.js +4 -1
  70. package/lib/programmers/internal/check_everything.js.map +1 -1
  71. package/lib/programmers/internal/check_union_array_like.js +10 -3
  72. package/lib/programmers/internal/check_union_array_like.js.map +1 -1
  73. package/lib/programmers/internal/stringify_dynamic_properties.js +1 -1
  74. package/lib/programmers/internal/stringify_dynamic_properties.js.map +1 -1
  75. package/lib/transformers/CallExpressionTransformer.js +4 -1
  76. package/lib/transformers/CallExpressionTransformer.js.map +1 -1
  77. package/lib/transformers/ImportTransformer.d.ts +4 -0
  78. package/lib/transformers/ImportTransformer.js +51 -0
  79. package/lib/transformers/ImportTransformer.js.map +1 -0
  80. package/package.json +1 -1
  81. package/src/IRandomGenerator.ts +16 -16
  82. package/src/IValidation.ts +21 -21
  83. package/src/Primitive.ts +104 -82
  84. package/src/TypeGuardError.ts +36 -36
  85. package/src/executable/TypiaGenerateWizard.ts +87 -0
  86. package/src/executable/TypiaSetupWizard.ts +142 -142
  87. package/src/executable/setup/ArgumentParser.ts +91 -91
  88. package/src/executable/setup/CommandExecutor.ts +8 -8
  89. package/src/executable/setup/FileRetriever.ts +33 -33
  90. package/src/executable/setup/PackageManager.ts +92 -92
  91. package/src/executable/setup/PluginConfigurator.ts +99 -99
  92. package/src/executable/typia.ts +38 -29
  93. package/src/factories/CommentFactory.ts +10 -10
  94. package/src/factories/ExpressionFactory.ts +77 -77
  95. package/src/factories/IdentifierFactory.ts +73 -72
  96. package/src/factories/LiteralFactory.ts +44 -44
  97. package/src/factories/MetadataCollection.ts +122 -122
  98. package/src/factories/MetadataFactory.ts +51 -51
  99. package/src/factories/MetadataTagFactory.ts +265 -265
  100. package/src/factories/StatementFactory.ts +60 -60
  101. package/src/factories/TemplateFactory.ts +56 -56
  102. package/src/factories/TypeFactory.ts +129 -101
  103. package/src/factories/TypiaFileFactory.ts +117 -0
  104. package/src/factories/ValueFactory.ts +12 -12
  105. package/src/factories/internal/metadata/MetadataHelper.ts +12 -12
  106. package/src/factories/internal/metadata/emplace_metadata_object.ts +140 -140
  107. package/src/factories/internal/metadata/explore_metadata.ts +92 -92
  108. package/src/factories/internal/metadata/iterate_metadata.ts +80 -80
  109. package/src/factories/internal/metadata/iterate_metadata_array.ts +29 -29
  110. package/src/factories/internal/metadata/iterate_metadata_atomic.ts +59 -59
  111. package/src/factories/internal/metadata/iterate_metadata_coalesce.ts +33 -33
  112. package/src/factories/internal/metadata/iterate_metadata_constant.ts +58 -58
  113. package/src/factories/internal/metadata/iterate_metadata_map.ts +41 -41
  114. package/src/factories/internal/metadata/iterate_metadata_native.ts +222 -222
  115. package/src/factories/internal/metadata/iterate_metadata_object.ts +48 -48
  116. package/src/factories/internal/metadata/iterate_metadata_resolve.ts +27 -27
  117. package/src/factories/internal/metadata/iterate_metadata_set.ts +33 -33
  118. package/src/factories/internal/metadata/iterate_metadata_template.ts +38 -38
  119. package/src/factories/internal/metadata/iterate_metadata_tuple.ts +45 -45
  120. package/src/factories/internal/metadata/iterate_metadata_union.ts +59 -59
  121. package/src/functional/$any.ts +3 -3
  122. package/src/functional/$every.ts +11 -11
  123. package/src/functional/$guard.ts +35 -35
  124. package/src/functional/$is_between.ts +7 -7
  125. package/src/functional/$is_email.ts +5 -5
  126. package/src/functional/$is_ipv4.ts +5 -5
  127. package/src/functional/$is_ipv6.ts +5 -5
  128. package/src/functional/$is_url.ts +5 -5
  129. package/src/functional/$is_uuid.ts +5 -5
  130. package/src/functional/$join.ts +50 -50
  131. package/src/functional/$number.ts +12 -12
  132. package/src/functional/$report.ts +15 -15
  133. package/src/functional/$rest.ts +3 -3
  134. package/src/functional/$string.ts +37 -37
  135. package/src/functional/$tail.ts +6 -6
  136. package/src/functional/Namespace.ts +121 -121
  137. package/src/index.ts +4 -4
  138. package/src/metadata/IJsDocTagInfo.ts +10 -10
  139. package/src/metadata/IMetadata.ts +25 -25
  140. package/src/metadata/IMetadataApplication.ts +7 -7
  141. package/src/metadata/IMetadataConstant.ts +16 -16
  142. package/src/metadata/IMetadataEntry.ts +6 -6
  143. package/src/metadata/IMetadataObject.ts +29 -29
  144. package/src/metadata/IMetadataProperty.ts +11 -11
  145. package/src/metadata/IMetadataTag.ts +113 -113
  146. package/src/metadata/Metadata.ts +534 -534
  147. package/src/metadata/MetadataConstant.ts +3 -3
  148. package/src/metadata/MetadataObject.ts +131 -131
  149. package/src/metadata/MetadataProperty.ts +64 -64
  150. package/src/module.ts +1946 -1946
  151. package/src/programmers/ApplicationProgrammer.ts +55 -55
  152. package/src/programmers/AssertCloneProgrammer.ts +71 -60
  153. package/src/programmers/AssertParseProgrammer.ts +66 -55
  154. package/src/programmers/AssertProgrammer.ts +232 -435
  155. package/src/programmers/AssertPruneProgrammer.ts +67 -59
  156. package/src/programmers/AssertStringifyProgrammer.ts +71 -65
  157. package/src/programmers/CheckerProgrammer.ts +892 -879
  158. package/src/programmers/CloneProgrammer.ts +387 -361
  159. package/src/programmers/FeatureProgrammer.ts +505 -462
  160. package/src/programmers/IsCloneProgrammer.ts +80 -66
  161. package/src/programmers/IsParseProgrammer.ts +75 -61
  162. package/src/programmers/IsProgrammer.ts +200 -200
  163. package/src/programmers/IsPruneProgrammer.ts +75 -63
  164. package/src/programmers/IsStringifyProgrammer.ts +80 -69
  165. package/src/programmers/PruneProgrammer.ts +341 -333
  166. package/src/programmers/RandomProgrammer.ts +392 -373
  167. package/src/programmers/StringifyProgrammer.ts +795 -787
  168. package/src/programmers/ValidateCloneProgrammer.ts +91 -77
  169. package/src/programmers/ValidateParseProgrammer.ts +70 -59
  170. package/src/programmers/ValidateProgrammer.ts +267 -238
  171. package/src/programmers/ValidatePruneProgrammer.ts +84 -73
  172. package/src/programmers/ValidateStringifyProgrammer.ts +88 -77
  173. package/src/programmers/helpers/AtomicPredicator.ts +31 -31
  174. package/src/programmers/helpers/CloneJoiner.ts +134 -124
  175. package/src/programmers/helpers/FunctionImporeter.ts +55 -46
  176. package/src/programmers/helpers/IExpressionEntry.ts +12 -12
  177. package/src/programmers/helpers/OptionPredicator.ts +19 -19
  178. package/src/programmers/helpers/PruneJoiner.ts +52 -52
  179. package/src/programmers/helpers/RandomJoiner.ts +149 -142
  180. package/src/programmers/helpers/RandomRanger.ts +216 -216
  181. package/src/programmers/helpers/StringifyJoinder.ts +114 -114
  182. package/src/programmers/helpers/StringifyPredicator.ts +18 -18
  183. package/src/programmers/helpers/UnionExplorer.ts +274 -274
  184. package/src/programmers/helpers/UnionPredicator.ts +81 -81
  185. package/src/programmers/internal/application_array.ts +37 -37
  186. package/src/programmers/internal/application_boolean.ts +17 -17
  187. package/src/programmers/internal/application_constant.ts +29 -29
  188. package/src/programmers/internal/application_default.ts +17 -17
  189. package/src/programmers/internal/application_default_string.ts +32 -32
  190. package/src/programmers/internal/application_native.ts +29 -29
  191. package/src/programmers/internal/application_number.ts +70 -70
  192. package/src/programmers/internal/application_object.ts +153 -153
  193. package/src/programmers/internal/application_schema.ts +184 -184
  194. package/src/programmers/internal/application_string.ts +41 -41
  195. package/src/programmers/internal/application_templates.ts +27 -27
  196. package/src/programmers/internal/application_tuple.ts +29 -29
  197. package/src/programmers/internal/check_array.ts +22 -22
  198. package/src/programmers/internal/check_array_length.ts +44 -44
  199. package/src/programmers/internal/check_bigint.ts +64 -64
  200. package/src/programmers/internal/check_dynamic_properties.ts +197 -197
  201. package/src/programmers/internal/check_everything.ts +28 -25
  202. package/src/programmers/internal/check_native.ts +21 -21
  203. package/src/programmers/internal/check_number.ts +145 -145
  204. package/src/programmers/internal/check_object.ts +48 -48
  205. package/src/programmers/internal/check_string.ts +24 -24
  206. package/src/programmers/internal/check_string_tags.ts +63 -63
  207. package/src/programmers/internal/check_template.ts +50 -50
  208. package/src/programmers/internal/check_union_array_like.ts +260 -244
  209. package/src/programmers/internal/check_union_tuple.ts +33 -33
  210. package/src/programmers/internal/decode_union_object.ts +73 -73
  211. package/src/programmers/internal/feature_object_entries.ts +59 -59
  212. package/src/programmers/internal/metadata_to_pattern.ts +31 -31
  213. package/src/programmers/internal/prune_object_properties.ts +60 -60
  214. package/src/programmers/internal/stringify_dynamic_properties.ts +165 -164
  215. package/src/programmers/internal/stringify_native.ts +8 -8
  216. package/src/programmers/internal/stringify_regular_properties.ts +81 -81
  217. package/src/programmers/internal/template_to_pattern.ts +15 -15
  218. package/src/schemas/IJsonApplication.ts +9 -9
  219. package/src/schemas/IJsonComponents.ts +26 -26
  220. package/src/schemas/IJsonSchema.ts +127 -127
  221. package/src/transform.ts +21 -21
  222. package/src/transformers/CallExpressionTransformer.ts +172 -165
  223. package/src/transformers/ExpressionWithArgumentTransformer.ts +66 -66
  224. package/src/transformers/FileTransformer.ts +49 -49
  225. package/src/transformers/IProject.ts +11 -11
  226. package/src/transformers/ITransformOptions.ts +62 -62
  227. package/src/transformers/ImportTransformer.ts +60 -0
  228. package/src/transformers/NodeTransformer.ts +19 -19
  229. package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +120 -120
  230. package/src/transformers/features/miscellaneous/AssertCloneTransformer.ts +38 -38
  231. package/src/transformers/features/miscellaneous/AssertPruneTransformer.ts +38 -38
  232. package/src/transformers/features/miscellaneous/CloneTransformer.ts +46 -46
  233. package/src/transformers/features/miscellaneous/CreateAssertCloneTransformer.ts +32 -32
  234. package/src/transformers/features/miscellaneous/CreateAssertPruneTransformer.ts +32 -32
  235. package/src/transformers/features/miscellaneous/CreateCloneTransformer.ts +31 -31
  236. package/src/transformers/features/miscellaneous/CreateIsCloneTransformer.ts +32 -32
  237. package/src/transformers/features/miscellaneous/CreateIsPruneTransformer.ts +32 -32
  238. package/src/transformers/features/miscellaneous/CreatePruneTransformer.ts +31 -31
  239. package/src/transformers/features/miscellaneous/CreateRandomGenerator.ts +39 -39
  240. package/src/transformers/features/miscellaneous/CreateValidateCloneTransformer.ts +32 -32
  241. package/src/transformers/features/miscellaneous/CreateValidatePruneTransformer.ts +32 -32
  242. package/src/transformers/features/miscellaneous/IsCloneTransformer.ts +38 -38
  243. package/src/transformers/features/miscellaneous/IsPruneTransformer.ts +38 -38
  244. package/src/transformers/features/miscellaneous/MetadataTransformer.ts +55 -55
  245. package/src/transformers/features/miscellaneous/PruneTransformer.ts +46 -46
  246. package/src/transformers/features/miscellaneous/RandomTransformer.ts +45 -45
  247. package/src/transformers/features/miscellaneous/ValidateCloneTransformer.ts +38 -38
  248. package/src/transformers/features/miscellaneous/ValidatePruneTransformer.ts +38 -38
  249. package/src/transformers/features/parsers/AssertParseTransformer.ts +36 -36
  250. package/src/transformers/features/parsers/CreateAssertParseTransformer.ts +32 -32
  251. package/src/transformers/features/parsers/CreateIsParseTransformer.ts +32 -32
  252. package/src/transformers/features/parsers/CreateValidateParseTransformer.ts +32 -32
  253. package/src/transformers/features/parsers/IsParseTransformer.ts +36 -36
  254. package/src/transformers/features/parsers/ValidateParseTransformer.ts +36 -36
  255. package/src/transformers/features/stringifiers/AssertStringifyTransformer.ts +38 -38
  256. package/src/transformers/features/stringifiers/CreateAssertStringifyTransformer.ts +32 -32
  257. package/src/transformers/features/stringifiers/CreateIsStringifyTransformer.ts +32 -32
  258. package/src/transformers/features/stringifiers/CreateStringifyTransformer.ts +31 -31
  259. package/src/transformers/features/stringifiers/CreateValidateStringifyProgrammer.ts +32 -32
  260. package/src/transformers/features/stringifiers/IsStringifyTransformer.ts +38 -38
  261. package/src/transformers/features/stringifiers/StringifyTransformer.ts +46 -46
  262. package/src/transformers/features/stringifiers/ValidateStringifyTransformer.ts +38 -38
  263. package/src/transformers/features/validators/AssertTransformer.ts +43 -43
  264. package/src/transformers/features/validators/CreateAssertTransformer.ts +35 -35
  265. package/src/transformers/features/validators/CreateIsTransformer.ts +35 -35
  266. package/src/transformers/features/validators/CreateValidateTransformer.ts +35 -35
  267. package/src/transformers/features/validators/IsTransformer.ts +43 -43
  268. package/src/transformers/features/validators/ValidateTransformer.ts +43 -43
  269. package/src/typings/Atomic.ts +17 -17
  270. package/src/typings/ClassProperties.ts +5 -5
  271. package/src/typings/OmitNever.ts +3 -3
  272. package/src/typings/SpecialFields.ts +3 -3
  273. package/src/typings/Writable.ts +11 -11
  274. package/src/utils/ArrayUtil.ts +49 -49
  275. package/src/utils/Escaper.ts +50 -50
  276. package/src/utils/MapUtil.ts +14 -14
  277. package/src/utils/PatternUtil.ts +30 -30
  278. package/src/utils/RandomGenerator.ts +90 -90
  279. package/src/utils/Singleton.ts +17 -17
@@ -1,462 +1,505 @@
1
- import ts from "typescript";
2
-
3
- import { IdentifierFactory } from "../factories/IdentifierFactory";
4
- import { MetadataCollection } from "../factories/MetadataCollection";
5
- import { StatementFactory } from "../factories/StatementFactory";
6
- import { ValueFactory } from "../factories/ValueFactory";
7
-
8
- import { IMetadataTag } from "../metadata/IMetadataTag";
9
- import { Metadata } from "../metadata/Metadata";
10
- import { MetadataObject } from "../metadata/MetadataObject";
11
-
12
- import { IProject } from "../transformers/IProject";
13
-
14
- import { CheckerProgrammer } from "./CheckerProgrammer";
15
- import { FunctionImporter } from "./helpers/FunctionImporeter";
16
- import { IExpressionEntry } from "./helpers/IExpressionEntry";
17
- import { UnionExplorer } from "./helpers/UnionExplorer";
18
- import { feature_object_entries } from "./internal/feature_object_entries";
19
-
20
- export namespace FeatureProgrammer {
21
- /* -----------------------------------------------------------
22
- PARAMETERS
23
- ----------------------------------------------------------- */
24
- export interface IConfig<Output extends ts.ConciseBody = ts.ConciseBody> {
25
- /**
26
- * Prefix name of functions for specific object types.
27
- */
28
- functors: string;
29
-
30
- /**
31
- * Prefix name of functions for union object types.
32
- */
33
- unioners: string;
34
-
35
- /**
36
- * Whether to archive access path or not.
37
- */
38
- path: boolean;
39
-
40
- /**
41
- * Whether to trace exception or not.
42
- */
43
- trace: boolean;
44
-
45
- /**
46
- * Initializer of metadata.
47
- */
48
- initializer(
49
- project: IProject,
50
- type: ts.Type,
51
- ): [MetadataCollection, Metadata];
52
-
53
- /**
54
- * Decoder, station of every types.
55
- */
56
- decoder: Decoder<Metadata, Output>;
57
-
58
- /**
59
- * Object configurator.
60
- */
61
- objector: IConfig.IObjector;
62
-
63
- /**
64
- * Generator of functions for object types.
65
- */
66
- generator?: Partial<IConfig.IGenerator>;
67
- }
68
- export namespace IConfig {
69
- export interface IObjector {
70
- /**
71
- * Type checker when union object type comes.
72
- */
73
- checker: Decoder<Metadata, ts.Expression>;
74
-
75
- /**
76
- * Decoder, function call expression generator of specific typed objects.
77
- */
78
- decoder: Decoder<MetadataObject, ts.Expression>;
79
-
80
- /**
81
- * Joiner of expressions from properties.
82
- */
83
- joiner(
84
- input: ts.Expression,
85
- entries: IExpressionEntry[],
86
- parent: MetadataObject,
87
- ): ts.ConciseBody;
88
-
89
- /**
90
- * Union type specificator.
91
- *
92
- * Expression of an algorithm specifying object type and calling
93
- * the `decoder` function of the specified object type.
94
- */
95
- unionizer: Decoder<MetadataObject[], ts.Expression>;
96
-
97
- /**
98
- * Handler of union type specification failure.
99
- *
100
- * @param value Expression of input parameter
101
- * @param expected Expected type name
102
- * @param explore Exploration info
103
- * @returns Statement of failure
104
- */
105
- failure(
106
- value: ts.Expression,
107
- expected: string,
108
- explore?: IExplore,
109
- ): ts.Statement;
110
-
111
- /**
112
- * Transformer of type checking expression by discrimination.
113
- *
114
- * When an object type has been specified by a discrimination without full
115
- * iteration, the `unionizer` will decode the object instance after
116
- * the last type checking.
117
- *
118
- * In such circumtance, you can transform the last type checking function.
119
- *
120
- * @param exp Current expression about type checking
121
- * @returns Transformed expression
122
- * @deprecated
123
- */
124
- is?(exp: ts.Expression): ts.Expression;
125
-
126
- /**
127
- * Transformer of non-undefined type checking by discrimination.
128
- *
129
- * When specifying an union type of objects, `typia` tries to find
130
- * descrimination way just by checking only one property type.
131
- * If succeeded to find the discrimination way, `typia` will check the target
132
- * property type and in the checking, non-undefined type checking would be
133
- * done.
134
- *
135
- * In such process, you can transform the non-undefined type checking.
136
- *
137
- * @param exp
138
- * @returns Transformed expression
139
- * @deprecated
140
- */
141
- required?(exp: ts.Expression): ts.Expression;
142
-
143
- /**
144
- * Conditon wrapper when unable to specify any object type.
145
- *
146
- * When failed to specify an object type through discrimination, full
147
- * iteration type checking would be happend. In such circumstance, you
148
- * can wrap the condition with additional function.
149
- *
150
- * @param condition Current condition
151
- * @returns A function wrapped current condition
152
- */
153
- full?: (
154
- condition: ts.Expression,
155
- ) => (
156
- input: ts.Expression,
157
- expected: string,
158
- explore: IExplore,
159
- ) => ts.Expression;
160
- }
161
- export interface IGenerator {
162
- /**
163
- *
164
- * @param col
165
- */
166
- functors(col: MetadataCollection): ts.VariableStatement[];
167
-
168
- /**
169
- *
170
- * @param col
171
- */
172
- unioners(col: MetadataCollection): ts.VariableStatement[];
173
- }
174
- }
175
-
176
- export interface IExplore {
177
- tracable: boolean;
178
- source: "top" | "object";
179
- from: "top" | "array" | "object";
180
- postfix: string;
181
- start?: number;
182
- }
183
-
184
- export interface Decoder<
185
- T,
186
- Output extends ts.ConciseBody = ts.ConciseBody,
187
- > {
188
- (
189
- input: ts.Expression,
190
- target: T,
191
- explore: IExplore,
192
- tags: IMetadataTag[],
193
- ): Output;
194
- }
195
-
196
- /* -----------------------------------------------------------
197
- GENERATORS
198
- ----------------------------------------------------------- */
199
- /**
200
- * Generates a decoder function for a specific type.
201
- *
202
- * @param project Project configuration
203
- * @param config Detailed configuration for programming
204
- * @param importer Function importer
205
- * @param addition Generator of additinal statements in the top of function
206
- * @returns Currying function generating type decoder function
207
- */
208
- export const generate =
209
- (
210
- project: IProject,
211
- config: IConfig,
212
- importer: FunctionImporter,
213
- addition: (
214
- collection: MetadataCollection,
215
- ) => ts.Statement[] | undefined,
216
- ) =>
217
- (type: ts.Type) => {
218
- const [collection, meta] = config.initializer(project, type);
219
-
220
- // ITERATE OVER ALL METADATA
221
- const output: ts.ConciseBody = config.decoder(
222
- ValueFactory.INPUT(),
223
- meta,
224
- {
225
- tracable: config.path || config.trace,
226
- source: "top",
227
- from: "top",
228
- postfix: '""',
229
- },
230
- [],
231
- );
232
-
233
- // RETURNS THE OPTIMAL ARROW FUNCTION
234
- const functors: ts.VariableStatement[] = (
235
- config.generator?.functors ??
236
- generate_functors(config)(importer)
237
- )(collection);
238
- const unioners: ts.VariableStatement[] = (
239
- config.generator?.unioners ??
240
- generate_unioners(config)(importer)
241
- )(collection);
242
- const added: ts.Statement[] | undefined = addition(collection);
243
-
244
- return ts.factory.createArrowFunction(
245
- undefined,
246
- undefined,
247
- PARAMETERS(config)(ValueFactory.INPUT()),
248
- undefined,
249
- undefined,
250
- ts.factory.createBlock(
251
- [
252
- ...(added || []),
253
- ...functors.filter((_, i) =>
254
- importer.hasLocal(`${config.functors}${i}`),
255
- ),
256
- ...unioners.filter((_, i) =>
257
- importer.hasLocal(`${config.unioners}${i}`),
258
- ),
259
- ...(ts.isBlock(output)
260
- ? output.statements
261
- : [ts.factory.createReturnStatement(output)]),
262
- ],
263
- true,
264
- ),
265
- );
266
- };
267
-
268
- export const generate_functors =
269
- (config: IConfig) =>
270
- (importer: FunctionImporter) =>
271
- (collection: MetadataCollection) =>
272
- collection
273
- .objects()
274
- .map((obj, i) =>
275
- StatementFactory.constant(
276
- `${config.functors}${i}`,
277
- generate_object(config)(importer)(obj),
278
- ),
279
- );
280
-
281
- export const generate_unioners =
282
- (config: IConfig) =>
283
- (importer: FunctionImporter) =>
284
- (collection: MetadataCollection) =>
285
- collection
286
- .unions()
287
- .map((union, i) =>
288
- StatementFactory.constant(
289
- importer.useLocal(`${config.unioners}${i}`),
290
- generate_union(config)(union),
291
- ),
292
- );
293
-
294
- const generate_object =
295
- (config: IConfig) =>
296
- (importer: FunctionImporter) =>
297
- (obj: MetadataObject) =>
298
- ts.factory.createArrowFunction(
299
- undefined,
300
- undefined,
301
- PARAMETERS(config)(ValueFactory.INPUT()),
302
- undefined,
303
- undefined,
304
- config.objector.joiner(
305
- ts.factory.createIdentifier("input"),
306
- feature_object_entries(config)(importer)(obj)(
307
- ts.factory.createIdentifier("input"),
308
- ),
309
- obj,
310
- ),
311
- );
312
-
313
- function generate_union(config: IConfig) {
314
- const explorer = UnionExplorer.object(config);
315
- const input = ValueFactory.INPUT();
316
-
317
- return (meta: MetadataObject[]) =>
318
- ts.factory.createArrowFunction(
319
- undefined,
320
- undefined,
321
- PARAMETERS(config)(ValueFactory.INPUT()),
322
- undefined,
323
- undefined,
324
- explorer(
325
- input,
326
- meta,
327
- {
328
- tracable: config.path || config.trace,
329
- source: "object",
330
- from: "object",
331
- postfix: "",
332
- },
333
- [],
334
- ),
335
- );
336
- }
337
-
338
- /* -----------------------------------------------------------
339
- DECODERS
340
- ----------------------------------------------------------- */
341
- export function decode_array(
342
- config: Pick<IConfig, "trace" | "path" | "decoder">,
343
- importer: FunctionImporter,
344
- combiner: (
345
- input: ts.Expression,
346
- arrow: ts.ArrowFunction,
347
- tags: IMetadataTag[],
348
- ) => ts.Expression,
349
- ) {
350
- const rand: string = importer.increment().toString();
351
- const tail =
352
- config.path || config.trace
353
- ? [IdentifierFactory.parameter("index" + rand)]
354
- : [];
355
-
356
- return (
357
- input: ts.Expression,
358
- meta: Metadata,
359
- explore: IExplore,
360
- tags: IMetadataTag[],
361
- ) => {
362
- const arrow: ts.ArrowFunction = ts.factory.createArrowFunction(
363
- undefined,
364
- undefined,
365
- [IdentifierFactory.parameter("elem"), ...tail],
366
- undefined,
367
- undefined,
368
- config.decoder(
369
- ValueFactory.INPUT("elem"),
370
- meta,
371
- {
372
- tracable: explore.tracable,
373
- source: explore.source,
374
- from: "array",
375
- postfix: INDEX_SYMBOL(explore.start ?? null)(
376
- explore.postfix,
377
- )(rand),
378
- },
379
- tags,
380
- ),
381
- );
382
- return combiner(input, arrow, tags);
383
- };
384
- }
385
-
386
- export const decode_object =
387
- (config: Pick<IConfig, "trace" | "path" | "functors">) =>
388
- (importer: FunctionImporter) =>
389
- (input: ts.Expression, obj: MetadataObject, explore: IExplore) =>
390
- ts.factory.createCallExpression(
391
- ts.factory.createIdentifier(
392
- importer.useLocal(`${config.functors}${obj.index}`),
393
- ),
394
- undefined,
395
- get_object_arguments(config)(explore)(input),
396
- );
397
-
398
- export const get_object_arguments =
399
- (config: Pick<IConfig, "path" | "trace">) =>
400
- (explore: FeatureProgrammer.IExplore) => {
401
- const tail: ts.Expression[] =
402
- config.path === false && config.trace === false
403
- ? []
404
- : config.path === true && config.trace === true
405
- ? [
406
- ts.factory.createIdentifier(
407
- explore.postfix
408
- ? `_path + ${explore.postfix}`
409
- : "_path",
410
- ),
411
- explore.source === "object"
412
- ? ts.factory.createIdentifier(
413
- `${explore.tracable} && _exceptionable`,
414
- )
415
- : explore.tracable
416
- ? ts.factory.createTrue()
417
- : ts.factory.createFalse(),
418
- ]
419
- : config.path === true
420
- ? [
421
- ts.factory.createIdentifier(
422
- explore.postfix
423
- ? `_path + ${explore.postfix}`
424
- : "_path",
425
- ),
426
- ]
427
- : [
428
- explore.source === "object"
429
- ? ts.factory.createIdentifier(
430
- `${explore.tracable} && _exceptionable`,
431
- )
432
- : explore.tracable
433
- ? ts.factory.createTrue()
434
- : ts.factory.createFalse(),
435
- ];
436
- return (input: ts.Expression) => [input, ...tail];
437
- };
438
- }
439
-
440
- const INDEX_SYMBOL =
441
- (start: number | null) => (prev: string) => (rand: string) => {
442
- const tail: string =
443
- start !== null
444
- ? `"[" + (${start} + index${rand}) + "]"`
445
- : `"[" + index${rand} + "]"`;
446
- if (prev === "") return tail;
447
- else if (prev[prev.length - 1] === `"`)
448
- return prev.substring(0, prev.length - 1) + tail.substring(1);
449
- return prev + ` + ${tail}`;
450
- };
451
- const PARAMETERS = (
452
- props: Pick<CheckerProgrammer.IConfig, "path" | "trace">,
453
- ) => {
454
- const tail: ts.ParameterDeclaration[] = [];
455
- if (props.path) tail.push(IdentifierFactory.parameter("_path"));
456
- if (props.trace) tail.push(IdentifierFactory.parameter("_exceptionable"));
457
-
458
- return (input: ts.Identifier) => [
459
- IdentifierFactory.parameter(input),
460
- ...tail,
461
- ];
462
- };
1
+ import ts from "typescript";
2
+
3
+ import { IdentifierFactory } from "../factories/IdentifierFactory";
4
+ import { MetadataCollection } from "../factories/MetadataCollection";
5
+ import { StatementFactory } from "../factories/StatementFactory";
6
+ import { TypeFactory } from "../factories/TypeFactory";
7
+ import { ValueFactory } from "../factories/ValueFactory";
8
+
9
+ import { IMetadataTag } from "../metadata/IMetadataTag";
10
+ import { Metadata } from "../metadata/Metadata";
11
+ import { MetadataObject } from "../metadata/MetadataObject";
12
+
13
+ import { IProject } from "../transformers/IProject";
14
+
15
+ import { CheckerProgrammer } from "./CheckerProgrammer";
16
+ import { FunctionImporter } from "./helpers/FunctionImporeter";
17
+ import { IExpressionEntry } from "./helpers/IExpressionEntry";
18
+ import { UnionExplorer } from "./helpers/UnionExplorer";
19
+ import { feature_object_entries } from "./internal/feature_object_entries";
20
+
21
+ export namespace FeatureProgrammer {
22
+ /* -----------------------------------------------------------
23
+ PARAMETERS
24
+ ----------------------------------------------------------- */
25
+ export interface IConfig<Output extends ts.ConciseBody = ts.ConciseBody> {
26
+ types: IConfig.ITypes;
27
+
28
+ /**
29
+ * Prefix name of functions for specific object types.
30
+ */
31
+ functors: string;
32
+
33
+ /**
34
+ * Prefix name of functions for union object types.
35
+ */
36
+ unioners: string;
37
+
38
+ /**
39
+ * Whether to archive access path or not.
40
+ */
41
+ path: boolean;
42
+
43
+ /**
44
+ * Whether to trace exception or not.
45
+ */
46
+ trace: boolean;
47
+
48
+ /**
49
+ * Initializer of metadata.
50
+ */
51
+ initializer(
52
+ project: IProject,
53
+ type: ts.Type,
54
+ ): [MetadataCollection, Metadata];
55
+
56
+ /**
57
+ * Decoder, station of every types.
58
+ */
59
+ decoder: Decoder<Metadata, Output>;
60
+
61
+ /**
62
+ * Object configurator.
63
+ */
64
+ objector: IConfig.IObjector;
65
+
66
+ /**
67
+ * Generator of functions for object types.
68
+ */
69
+ generator?: Partial<IConfig.IGenerator>;
70
+ }
71
+ export namespace IConfig {
72
+ export interface ITypes {
73
+ input: (type: ts.Type, node?: ts.TypeNode) => ts.TypeNode;
74
+ output: (type: ts.Type, node?: ts.TypeNode) => ts.TypeNode;
75
+ }
76
+
77
+ export interface IObjector {
78
+ /**
79
+ * Type checker when union object type comes.
80
+ */
81
+ checker: Decoder<Metadata, ts.Expression>;
82
+
83
+ /**
84
+ * Decoder, function call expression generator of specific typed objects.
85
+ */
86
+ decoder: Decoder<MetadataObject, ts.Expression>;
87
+
88
+ /**
89
+ * Joiner of expressions from properties.
90
+ */
91
+ joiner(
92
+ input: ts.Expression,
93
+ entries: IExpressionEntry[],
94
+ parent: MetadataObject,
95
+ ): ts.ConciseBody;
96
+
97
+ /**
98
+ * Union type specificator.
99
+ *
100
+ * Expression of an algorithm specifying object type and calling
101
+ * the `decoder` function of the specified object type.
102
+ */
103
+ unionizer: Decoder<MetadataObject[], ts.Expression>;
104
+
105
+ /**
106
+ * Handler of union type specification failure.
107
+ *
108
+ * @param value Expression of input parameter
109
+ * @param expected Expected type name
110
+ * @param explore Exploration info
111
+ * @returns Statement of failure
112
+ */
113
+ failure(
114
+ value: ts.Expression,
115
+ expected: string,
116
+ explore?: IExplore,
117
+ ): ts.Statement;
118
+
119
+ /**
120
+ * Transformer of type checking expression by discrimination.
121
+ *
122
+ * When an object type has been specified by a discrimination without full
123
+ * iteration, the `unionizer` will decode the object instance after
124
+ * the last type checking.
125
+ *
126
+ * In such circumtance, you can transform the last type checking function.
127
+ *
128
+ * @param exp Current expression about type checking
129
+ * @returns Transformed expression
130
+ * @deprecated
131
+ */
132
+ is?(exp: ts.Expression): ts.Expression;
133
+
134
+ /**
135
+ * Transformer of non-undefined type checking by discrimination.
136
+ *
137
+ * When specifying an union type of objects, `typia` tries to find
138
+ * descrimination way just by checking only one property type.
139
+ * If succeeded to find the discrimination way, `typia` will check the target
140
+ * property type and in the checking, non-undefined type checking would be
141
+ * done.
142
+ *
143
+ * In such process, you can transform the non-undefined type checking.
144
+ *
145
+ * @param exp
146
+ * @returns Transformed expression
147
+ * @deprecated
148
+ */
149
+ required?(exp: ts.Expression): ts.Expression;
150
+
151
+ /**
152
+ * Conditon wrapper when unable to specify any object type.
153
+ *
154
+ * When failed to specify an object type through discrimination, full
155
+ * iteration type checking would be happend. In such circumstance, you
156
+ * can wrap the condition with additional function.
157
+ *
158
+ * @param condition Current condition
159
+ * @returns A function wrapped current condition
160
+ */
161
+ full?: (
162
+ condition: ts.Expression,
163
+ ) => (
164
+ input: ts.Expression,
165
+ expected: string,
166
+ explore: IExplore,
167
+ ) => ts.Expression;
168
+
169
+ /**
170
+ * Return type.
171
+ */
172
+ type?: ts.TypeNode;
173
+ }
174
+ export interface IGenerator {
175
+ /**
176
+ *
177
+ * @param col
178
+ */
179
+ functors(col: MetadataCollection): ts.VariableStatement[];
180
+
181
+ /**
182
+ *
183
+ * @param col
184
+ */
185
+ unioners(col: MetadataCollection): ts.VariableStatement[];
186
+ }
187
+ }
188
+
189
+ export interface IExplore {
190
+ tracable: boolean;
191
+ source: "top" | "object";
192
+ from: "top" | "array" | "object";
193
+ postfix: string;
194
+ start?: number;
195
+ }
196
+
197
+ export interface Decoder<
198
+ T,
199
+ Output extends ts.ConciseBody = ts.ConciseBody,
200
+ > {
201
+ (
202
+ input: ts.Expression,
203
+ target: T,
204
+ explore: IExplore,
205
+ tags: IMetadataTag[],
206
+ ): Output;
207
+ }
208
+
209
+ /* -----------------------------------------------------------
210
+ GENERATORS
211
+ ----------------------------------------------------------- */
212
+ /**
213
+ * Generates a decoder function for a specific type.
214
+ *
215
+ * @param project Project configuration
216
+ * @param config Detailed configuration for programming
217
+ * @param importer Function importer
218
+ * @param addition Generator of additinal statements in the top of function
219
+ * @returns Currying function generating type decoder function
220
+ */
221
+ export const generate =
222
+ (
223
+ project: IProject,
224
+ config: IConfig,
225
+ importer: FunctionImporter,
226
+ addition: (
227
+ collection: MetadataCollection,
228
+ ) => ts.Statement[] | undefined,
229
+ ) =>
230
+ (type: ts.Type, typeNode?: ts.TypeNode) => {
231
+ const [collection, meta] = config.initializer(project, type);
232
+
233
+ // ITERATE OVER ALL METADATA
234
+ const output: ts.ConciseBody = config.decoder(
235
+ ValueFactory.INPUT(),
236
+ meta,
237
+ {
238
+ tracable: config.path || config.trace,
239
+ source: "top",
240
+ from: "top",
241
+ postfix: '""',
242
+ },
243
+ [],
244
+ );
245
+
246
+ // RETURNS THE OPTIMAL ARROW FUNCTION
247
+ const functors: ts.VariableStatement[] = (
248
+ config.generator?.functors ??
249
+ generate_functors(config)(importer)
250
+ )(collection);
251
+ const unioners: ts.VariableStatement[] = (
252
+ config.generator?.unioners ??
253
+ generate_unioners(config)(importer)
254
+ )(collection);
255
+ const added: ts.Statement[] | undefined = addition(collection);
256
+
257
+ return ts.factory.createArrowFunction(
258
+ undefined,
259
+ undefined,
260
+ PARAMETERS(config)(config.types.input(type, typeNode))(
261
+ ValueFactory.INPUT(),
262
+ ),
263
+ config.types.output(type, typeNode),
264
+ undefined,
265
+ ts.factory.createBlock(
266
+ [
267
+ ...(added || []),
268
+ ...functors.filter((_, i) =>
269
+ importer.hasLocal(`${config.functors}${i}`),
270
+ ),
271
+ ...unioners.filter((_, i) =>
272
+ importer.hasLocal(`${config.unioners}${i}`),
273
+ ),
274
+ ...(ts.isBlock(output)
275
+ ? output.statements
276
+ : [ts.factory.createReturnStatement(output)]),
277
+ ],
278
+ true,
279
+ ),
280
+ );
281
+ };
282
+
283
+ export const generate_functors =
284
+ (config: IConfig) =>
285
+ (importer: FunctionImporter) =>
286
+ (collection: MetadataCollection) =>
287
+ collection
288
+ .objects()
289
+ .map((obj, i) =>
290
+ StatementFactory.constant(
291
+ `${config.functors}${i}`,
292
+ generate_object(config)(importer)(obj),
293
+ ),
294
+ );
295
+
296
+ export const generate_unioners =
297
+ (config: IConfig) =>
298
+ (importer: FunctionImporter) =>
299
+ (collection: MetadataCollection) =>
300
+ collection
301
+ .unions()
302
+ .map((union, i) =>
303
+ StatementFactory.constant(
304
+ importer.useLocal(`${config.unioners}${i}`),
305
+ generate_union(config)(union),
306
+ ),
307
+ );
308
+
309
+ const generate_object =
310
+ (config: IConfig) =>
311
+ (importer: FunctionImporter) =>
312
+ (obj: MetadataObject) =>
313
+ ts.factory.createArrowFunction(
314
+ undefined,
315
+ undefined,
316
+ PARAMETERS(config)(TypeFactory.keyword("any"))(
317
+ ValueFactory.INPUT(),
318
+ ),
319
+ config.objector.type ?? TypeFactory.keyword("any"),
320
+ undefined,
321
+ config.objector.joiner(
322
+ ts.factory.createIdentifier("input"),
323
+ feature_object_entries(config)(importer)(obj)(
324
+ ts.factory.createIdentifier("input"),
325
+ ),
326
+ obj,
327
+ ),
328
+ );
329
+
330
+ function generate_union(config: IConfig) {
331
+ const explorer = UnionExplorer.object(config);
332
+ const input = ValueFactory.INPUT();
333
+
334
+ return (meta: MetadataObject[]) =>
335
+ ts.factory.createArrowFunction(
336
+ undefined,
337
+ undefined,
338
+ PARAMETERS(config)(TypeFactory.keyword("any"))(
339
+ ValueFactory.INPUT(),
340
+ ),
341
+ TypeFactory.keyword("any"),
342
+ undefined,
343
+ explorer(
344
+ input,
345
+ meta,
346
+ {
347
+ tracable: config.path || config.trace,
348
+ source: "object",
349
+ from: "object",
350
+ postfix: "",
351
+ },
352
+ [],
353
+ ),
354
+ );
355
+ }
356
+
357
+ /* -----------------------------------------------------------
358
+ DECODERS
359
+ ----------------------------------------------------------- */
360
+ export function decode_array(
361
+ config: Pick<IConfig, "trace" | "path" | "decoder">,
362
+ importer: FunctionImporter,
363
+ combiner: (
364
+ input: ts.Expression,
365
+ arrow: ts.ArrowFunction,
366
+ tags: IMetadataTag[],
367
+ ) => ts.Expression,
368
+ ) {
369
+ const rand: string = importer.increment().toString();
370
+ const tail =
371
+ config.path || config.trace
372
+ ? [
373
+ IdentifierFactory.parameter(
374
+ "_index" + rand,
375
+ TypeFactory.keyword("number"),
376
+ ),
377
+ ]
378
+ : [];
379
+
380
+ return (
381
+ input: ts.Expression,
382
+ meta: Metadata,
383
+ explore: IExplore,
384
+ tags: IMetadataTag[],
385
+ ) => {
386
+ const arrow: ts.ArrowFunction = ts.factory.createArrowFunction(
387
+ undefined,
388
+ undefined,
389
+ [
390
+ IdentifierFactory.parameter(
391
+ "elem",
392
+ TypeFactory.keyword("any"),
393
+ ),
394
+ ...tail,
395
+ ],
396
+ undefined,
397
+ undefined,
398
+ config.decoder(
399
+ ValueFactory.INPUT("elem"),
400
+ meta,
401
+ {
402
+ tracable: explore.tracable,
403
+ source: explore.source,
404
+ from: "array",
405
+ postfix: INDEX_SYMBOL(explore.start ?? null)(
406
+ explore.postfix,
407
+ )(rand),
408
+ },
409
+ tags,
410
+ ),
411
+ );
412
+ return combiner(input, arrow, tags);
413
+ };
414
+ }
415
+
416
+ export const decode_object =
417
+ (config: Pick<IConfig, "trace" | "path" | "functors">) =>
418
+ (importer: FunctionImporter) =>
419
+ (input: ts.Expression, obj: MetadataObject, explore: IExplore) =>
420
+ ts.factory.createCallExpression(
421
+ ts.factory.createIdentifier(
422
+ importer.useLocal(`${config.functors}${obj.index}`),
423
+ ),
424
+ undefined,
425
+ get_object_arguments(config)(explore)(input),
426
+ );
427
+
428
+ export const get_object_arguments =
429
+ (config: Pick<IConfig, "path" | "trace">) =>
430
+ (explore: FeatureProgrammer.IExplore) => {
431
+ const tail: ts.Expression[] =
432
+ config.path === false && config.trace === false
433
+ ? []
434
+ : config.path === true && config.trace === true
435
+ ? [
436
+ ts.factory.createIdentifier(
437
+ explore.postfix
438
+ ? `_path + ${explore.postfix}`
439
+ : "_path",
440
+ ),
441
+ explore.source === "object"
442
+ ? ts.factory.createIdentifier(
443
+ `${explore.tracable} && _exceptionable`,
444
+ )
445
+ : explore.tracable
446
+ ? ts.factory.createTrue()
447
+ : ts.factory.createFalse(),
448
+ ]
449
+ : config.path === true
450
+ ? [
451
+ ts.factory.createIdentifier(
452
+ explore.postfix
453
+ ? `_path + ${explore.postfix}`
454
+ : "_path",
455
+ ),
456
+ ]
457
+ : [
458
+ explore.source === "object"
459
+ ? ts.factory.createIdentifier(
460
+ `${explore.tracable} && _exceptionable`,
461
+ )
462
+ : explore.tracable
463
+ ? ts.factory.createTrue()
464
+ : ts.factory.createFalse(),
465
+ ];
466
+ return (input: ts.Expression) => [input, ...tail];
467
+ };
468
+ }
469
+
470
+ const INDEX_SYMBOL =
471
+ (start: number | null) => (prev: string) => (rand: string) => {
472
+ const tail: string =
473
+ start !== null
474
+ ? `"[" + (${start} + _index${rand}) + "]"`
475
+ : `"[" + _index${rand} + "]"`;
476
+ if (prev === "") return tail;
477
+ else if (prev[prev.length - 1] === `"`)
478
+ return prev.substring(0, prev.length - 1) + tail.substring(1);
479
+ return prev + ` + ${tail}`;
480
+ };
481
+
482
+ const PARAMETERS =
483
+ (props: Pick<CheckerProgrammer.IConfig, "path" | "trace">) =>
484
+ (type: ts.TypeNode) => {
485
+ const tail: ts.ParameterDeclaration[] = [];
486
+ if (props.path)
487
+ tail.push(
488
+ IdentifierFactory.parameter(
489
+ "_path",
490
+ TypeFactory.keyword("string"),
491
+ ),
492
+ );
493
+ if (props.trace)
494
+ tail.push(
495
+ IdentifierFactory.parameter(
496
+ "_exceptionable",
497
+ TypeFactory.keyword("boolean"),
498
+ ts.factory.createTrue(),
499
+ ),
500
+ );
501
+ return (input: ts.Identifier) => [
502
+ IdentifierFactory.parameter(input, type),
503
+ ...tail,
504
+ ];
505
+ };