typia 9.2.0 → 9.3.0-dev.20250511

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 (534) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +149 -149
  3. package/lib/executable/setup/PluginConfigurator.js +3 -3
  4. package/lib/executable/setup/PluginConfigurator.mjs +3 -3
  5. package/lib/executable/typia.js +15 -15
  6. package/lib/executable/typia.mjs +15 -15
  7. package/lib/factories/ExpressionFactory.d.mts +1 -1
  8. package/lib/factories/ExpressionFactory.d.ts +1 -1
  9. package/lib/factories/ExpressionFactory.js +2 -2
  10. package/lib/factories/ExpressionFactory.js.map +1 -1
  11. package/lib/factories/ExpressionFactory.mjs +2 -2
  12. package/lib/llm.d.mts +6 -4
  13. package/lib/llm.d.ts +6 -4
  14. package/lib/llm.js +7 -0
  15. package/lib/llm.js.map +1 -1
  16. package/lib/llm.mjs +7 -1
  17. package/lib/transformers/CallExpressionTransformer.js +2 -0
  18. package/lib/transformers/CallExpressionTransformer.js.map +1 -1
  19. package/lib/transformers/CallExpressionTransformer.mjs +2 -0
  20. package/lib/transformers/features/llm/LlmApplicationTransformer.js +46 -35
  21. package/lib/transformers/features/llm/LlmApplicationTransformer.js.map +1 -1
  22. package/lib/transformers/features/llm/LlmApplicationTransformer.mjs +44 -34
  23. package/lib/transformers/features/llm/LlmControllerTransformer.d.mts +5 -0
  24. package/lib/transformers/features/llm/LlmControllerTransformer.d.ts +5 -0
  25. package/lib/transformers/features/llm/LlmControllerTransformer.js +67 -0
  26. package/lib/transformers/features/llm/LlmControllerTransformer.js.map +1 -0
  27. package/lib/transformers/features/llm/LlmControllerTransformer.mjs +63 -0
  28. package/lib/transformers/features/llm/LlmControllerTransformer.mjs.map +1 -0
  29. package/package.json +2 -2
  30. package/src/AssertionGuard.ts +1 -1
  31. package/src/CamelCase.ts +75 -75
  32. package/src/IRandomGenerator.ts +49 -49
  33. package/src/IReadableURLSearchParams.ts +9 -9
  34. package/src/IValidation.ts +1 -1
  35. package/src/PascalCase.ts +71 -71
  36. package/src/Primitive.ts +92 -92
  37. package/src/Resolved.ts +74 -74
  38. package/src/SnakeCase.ts +126 -126
  39. package/src/TypeGuardError.ts +37 -37
  40. package/src/executable/TypiaGenerateWizard.ts +83 -83
  41. package/src/executable/TypiaPatchWizard.ts +45 -45
  42. package/src/executable/TypiaSetupWizard.ts +171 -171
  43. package/src/executable/setup/ArgumentParser.ts +42 -42
  44. package/src/executable/setup/CommandExecutor.ts +8 -8
  45. package/src/executable/setup/FileRetriever.ts +19 -19
  46. package/src/executable/setup/PackageManager.ts +87 -87
  47. package/src/executable/setup/PluginConfigurator.ts +69 -69
  48. package/src/executable/typia.ts +55 -55
  49. package/src/factories/CommentFactory.ts +79 -79
  50. package/src/factories/ExpressionFactory.ts +219 -216
  51. package/src/factories/IdentifierFactory.ts +89 -89
  52. package/src/factories/JsonMetadataFactory.ts +83 -83
  53. package/src/factories/LiteralFactory.ts +52 -52
  54. package/src/factories/MetadataCollection.ts +278 -278
  55. package/src/factories/MetadataCommentTagFactory.ts +648 -648
  56. package/src/factories/MetadataFactory.ts +404 -404
  57. package/src/factories/MetadataTypeTagFactory.ts +413 -413
  58. package/src/factories/MetadataTypeTagSchemaFactory.ts +82 -82
  59. package/src/factories/NumericRangeFactory.ts +72 -72
  60. package/src/factories/ProtobufFactory.ts +875 -875
  61. package/src/factories/StatementFactory.ts +90 -90
  62. package/src/factories/TemplateFactory.ts +64 -64
  63. package/src/factories/TypeFactory.ts +140 -140
  64. package/src/factories/ValueFactory.ts +12 -12
  65. package/src/factories/internal/metadata/IMetadataIteratorProps.ts +17 -17
  66. package/src/factories/internal/metadata/MetadataHelper.ts +21 -21
  67. package/src/factories/internal/metadata/emend_metadata_atomics.ts +45 -45
  68. package/src/factories/internal/metadata/emplace_metadata_alias.ts +33 -33
  69. package/src/factories/internal/metadata/emplace_metadata_array_type.ts +39 -39
  70. package/src/factories/internal/metadata/emplace_metadata_object.ts +212 -212
  71. package/src/factories/internal/metadata/emplace_metadata_tuple.ts +57 -57
  72. package/src/factories/internal/metadata/explore_metadata.ts +31 -31
  73. package/src/factories/internal/metadata/iterate_metadata.ts +54 -54
  74. package/src/factories/internal/metadata/iterate_metadata_alias.ts +33 -33
  75. package/src/factories/internal/metadata/iterate_metadata_array.ts +63 -63
  76. package/src/factories/internal/metadata/iterate_metadata_atomic.ts +62 -62
  77. package/src/factories/internal/metadata/iterate_metadata_coalesce.ts +28 -28
  78. package/src/factories/internal/metadata/iterate_metadata_collection.ts +146 -146
  79. package/src/factories/internal/metadata/iterate_metadata_comment_tags.ts +32 -32
  80. package/src/factories/internal/metadata/iterate_metadata_constant.ts +76 -76
  81. package/src/factories/internal/metadata/iterate_metadata_escape.ts +49 -49
  82. package/src/factories/internal/metadata/iterate_metadata_function.ts +91 -91
  83. package/src/factories/internal/metadata/iterate_metadata_intersection.ts +212 -212
  84. package/src/factories/internal/metadata/iterate_metadata_map.ts +57 -57
  85. package/src/factories/internal/metadata/iterate_metadata_native.ts +264 -264
  86. package/src/factories/internal/metadata/iterate_metadata_object.ts +35 -35
  87. package/src/factories/internal/metadata/iterate_metadata_set.ts +57 -57
  88. package/src/factories/internal/metadata/iterate_metadata_sort.ts +87 -87
  89. package/src/factories/internal/metadata/iterate_metadata_template.ts +41 -41
  90. package/src/factories/internal/metadata/iterate_metadata_tuple.ts +26 -26
  91. package/src/factories/internal/metadata/iterate_metadata_union.ts +19 -19
  92. package/src/functional.ts +740 -740
  93. package/src/http.ts +1040 -1040
  94. package/src/index.ts +4 -4
  95. package/src/internal/_IProtobufWriter.ts +18 -18
  96. package/src/internal/_ProtobufReader.ts +194 -194
  97. package/src/internal/_ProtobufSizer.ts +145 -145
  98. package/src/internal/_ProtobufWriter.ts +145 -145
  99. package/src/internal/_accessExpressionAsString.ts +46 -46
  100. package/src/internal/_assertGuard.ts +13 -13
  101. package/src/internal/_createStandardSchema.ts +134 -134
  102. package/src/internal/_functionalTypeGuardErrorFactory.ts +4 -4
  103. package/src/internal/_httpFormDataReadArray.ts +4 -4
  104. package/src/internal/_httpFormDataReadBigint.ts +18 -18
  105. package/src/internal/_httpFormDataReadBlob.ts +10 -10
  106. package/src/internal/_httpFormDataReadBoolean.ts +16 -16
  107. package/src/internal/_httpFormDataReadFile.ts +10 -10
  108. package/src/internal/_httpFormDataReadNumber.ts +15 -15
  109. package/src/internal/_httpFormDataReadString.ts +10 -10
  110. package/src/internal/_httpHeaderReadBigint.ts +10 -10
  111. package/src/internal/_httpHeaderReadBoolean.ts +8 -8
  112. package/src/internal/_httpHeaderReadNumber.ts +7 -7
  113. package/src/internal/_httpParameterReadBigint.ts +10 -10
  114. package/src/internal/_httpParameterReadBoolean.ts +8 -8
  115. package/src/internal/_httpParameterReadNumber.ts +7 -7
  116. package/src/internal/_httpParameterReadString.ts +2 -2
  117. package/src/internal/_httpQueryParseURLSearchParams.ts +12 -12
  118. package/src/internal/_httpQueryReadArray.ts +4 -4
  119. package/src/internal/_httpQueryReadBigint.ts +12 -12
  120. package/src/internal/_httpQueryReadBoolean.ts +14 -14
  121. package/src/internal/_httpQueryReadNumber.ts +9 -9
  122. package/src/internal/_httpQueryReadString.ts +4 -4
  123. package/src/internal/_isBetween.ts +2 -2
  124. package/src/internal/_isBigintString.ts +8 -8
  125. package/src/internal/_isFormatByte.ts +7 -7
  126. package/src/internal/_isFormatDate.ts +3 -3
  127. package/src/internal/_isFormatDateTime.ts +4 -4
  128. package/src/internal/_isFormatDuration.ts +4 -4
  129. package/src/internal/_isFormatEmail.ts +4 -4
  130. package/src/internal/_isFormatHostname.ts +4 -4
  131. package/src/internal/_isFormatIdnEmail.ts +4 -4
  132. package/src/internal/_isFormatIdnHostname.ts +4 -4
  133. package/src/internal/_isFormatIpv4.ts +4 -4
  134. package/src/internal/_isFormatIpv6.ts +4 -4
  135. package/src/internal/_isFormatIri.ts +3 -3
  136. package/src/internal/_isFormatIriReference.ts +4 -4
  137. package/src/internal/_isFormatJsonPointer.ts +3 -3
  138. package/src/internal/_isFormatPassword.ts +1 -1
  139. package/src/internal/_isFormatRegex.ts +8 -8
  140. package/src/internal/_isFormatRelativeJsonPointer.ts +4 -4
  141. package/src/internal/_isFormatTime.ts +4 -4
  142. package/src/internal/_isFormatUri.ts +6 -6
  143. package/src/internal/_isFormatUriReference.ts +5 -5
  144. package/src/internal/_isFormatUriTemplate.ts +4 -4
  145. package/src/internal/_isFormatUrl.ts +4 -4
  146. package/src/internal/_isFormatUuid.ts +3 -3
  147. package/src/internal/_isTypeFloat.ts +5 -5
  148. package/src/internal/_isTypeInt32.ts +5 -5
  149. package/src/internal/_isTypeInt64.ts +5 -5
  150. package/src/internal/_isTypeUint32.ts +5 -5
  151. package/src/internal/_isTypeUint64.ts +5 -5
  152. package/src/internal/_isUniqueItems.ts +159 -159
  153. package/src/internal/_jsonStringifyNumber.ts +12 -12
  154. package/src/internal/_jsonStringifyRest.ts +3 -3
  155. package/src/internal/_jsonStringifyString.ts +42 -42
  156. package/src/internal/_jsonStringifyTail.ts +2 -2
  157. package/src/internal/_llmApplicationFinalize.ts +20 -20
  158. package/src/internal/_miscCloneAny.ts +46 -46
  159. package/src/internal/_notationAny.ts +37 -37
  160. package/src/internal/_notationCamel.ts +13 -13
  161. package/src/internal/_notationPascal.ts +8 -8
  162. package/src/internal/_notationSnake.ts +43 -43
  163. package/src/internal/_randomArray.ts +21 -21
  164. package/src/internal/_randomBigint.ts +6 -6
  165. package/src/internal/_randomBoolean.ts +1 -1
  166. package/src/internal/_randomFormatByte.ts +3 -3
  167. package/src/internal/_randomFormatDate.ts +18 -18
  168. package/src/internal/_randomFormatDatetime.ts +16 -16
  169. package/src/internal/_randomFormatDuration.ts +27 -27
  170. package/src/internal/_randomFormatEmail.ts +11 -11
  171. package/src/internal/_randomFormatHostname.ts +6 -6
  172. package/src/internal/_randomFormatIdnEmail.ts +3 -3
  173. package/src/internal/_randomFormatIdnHostname.ts +3 -3
  174. package/src/internal/_randomFormatIpv4.ts +11 -11
  175. package/src/internal/_randomFormatIpv6.ts +11 -11
  176. package/src/internal/_randomFormatIri.ts +3 -3
  177. package/src/internal/_randomFormatIriReference.ts +3 -3
  178. package/src/internal/_randomFormatJsonPointer.ts +7 -7
  179. package/src/internal/_randomFormatPassword.ts +8 -8
  180. package/src/internal/_randomFormatRegex.ts +4 -4
  181. package/src/internal/_randomFormatRelativeJsonPointer.ts +8 -8
  182. package/src/internal/_randomFormatTime.ts +14 -14
  183. package/src/internal/_randomFormatUri.ts +3 -3
  184. package/src/internal/_randomFormatUriReference.ts +3 -3
  185. package/src/internal/_randomFormatUriTemplate.ts +3 -3
  186. package/src/internal/_randomFormatUrl.ts +11 -11
  187. package/src/internal/_randomFormatUuid.ts +6 -6
  188. package/src/internal/_randomInteger.ts +53 -53
  189. package/src/internal/_randomNumber.ts +80 -80
  190. package/src/internal/_randomPattern.ts +10 -10
  191. package/src/internal/_randomPick.ts +9 -9
  192. package/src/internal/_randomString.ts +24 -24
  193. package/src/internal/_throwTypeGuardError.ts +5 -5
  194. package/src/internal/_validateReport.ts +13 -13
  195. package/src/internal/private/__notationCapitalize.ts +2 -2
  196. package/src/internal/private/__notationUnsnake.ts +24 -24
  197. package/src/json.ts +696 -696
  198. package/src/llm.ts +358 -335
  199. package/src/misc.ts +651 -651
  200. package/src/module.ts +936 -936
  201. package/src/notations.ts +820 -820
  202. package/src/programmers/AssertProgrammer.ts +454 -454
  203. package/src/programmers/CheckerProgrammer.ts +1617 -1617
  204. package/src/programmers/FeatureProgrammer.ts +627 -627
  205. package/src/programmers/ImportProgrammer.ts +185 -185
  206. package/src/programmers/IsProgrammer.ts +273 -273
  207. package/src/programmers/RandomProgrammer.ts +1190 -1190
  208. package/src/programmers/TypiaProgrammer.ts +175 -175
  209. package/src/programmers/ValidateProgrammer.ts +448 -448
  210. package/src/programmers/functional/FunctionalAssertFunctionProgrammer.ts +153 -153
  211. package/src/programmers/functional/FunctionalAssertParametersProgrammer.ts +125 -125
  212. package/src/programmers/functional/FunctionalAssertReturnProgrammer.ts +115 -115
  213. package/src/programmers/functional/FunctionalIsFunctionProgrammer.ts +72 -72
  214. package/src/programmers/functional/FunctionalIsParametersProgrammer.ts +113 -113
  215. package/src/programmers/functional/FunctionalIsReturnProgrammer.ts +116 -116
  216. package/src/programmers/functional/FunctionalValidateFunctionProgrammer.ts +119 -119
  217. package/src/programmers/functional/FunctionalValidateParametersProgrammer.ts +274 -274
  218. package/src/programmers/functional/FunctionalValidateReturnProgrammer.ts +135 -135
  219. package/src/programmers/functional/internal/FunctionalGeneralProgrammer.ts +34 -34
  220. package/src/programmers/helpers/AtomicPredicator.ts +35 -35
  221. package/src/programmers/helpers/CloneJoiner.ts +143 -143
  222. package/src/programmers/helpers/FunctionProgrammer.ts +67 -67
  223. package/src/programmers/helpers/HttpMetadataUtil.ts +21 -21
  224. package/src/programmers/helpers/ICheckEntry.ts +13 -13
  225. package/src/programmers/helpers/IExpressionEntry.ts +12 -12
  226. package/src/programmers/helpers/NotationJoiner.ts +144 -144
  227. package/src/programmers/helpers/OptionPredicator.ts +15 -15
  228. package/src/programmers/helpers/ProtobufUtil.ts +228 -228
  229. package/src/programmers/helpers/ProtobufWire.ts +34 -34
  230. package/src/programmers/helpers/PruneJoiner.ts +148 -148
  231. package/src/programmers/helpers/RandomJoiner.ts +168 -168
  232. package/src/programmers/helpers/StringifyJoinder.ts +115 -115
  233. package/src/programmers/helpers/StringifyPredicator.ts +13 -13
  234. package/src/programmers/helpers/UnionExplorer.ts +372 -372
  235. package/src/programmers/helpers/UnionPredicator.ts +79 -79
  236. package/src/programmers/helpers/disable_function_programmer_declare.ts +32 -32
  237. package/src/programmers/http/HttpAssertFormDataProgrammer.ts +99 -99
  238. package/src/programmers/http/HttpAssertHeadersProgrammer.ts +99 -99
  239. package/src/programmers/http/HttpAssertQueryProgrammer.ts +105 -105
  240. package/src/programmers/http/HttpFormDataProgrammer.ts +308 -308
  241. package/src/programmers/http/HttpHeadersProgrammer.ts +400 -400
  242. package/src/programmers/http/HttpIsFormDataProgrammer.ts +108 -108
  243. package/src/programmers/http/HttpIsHeadersProgrammer.ts +108 -108
  244. package/src/programmers/http/HttpIsQueryProgrammer.ts +114 -114
  245. package/src/programmers/http/HttpParameterProgrammer.ts +115 -115
  246. package/src/programmers/http/HttpQueryProgrammer.ts +336 -336
  247. package/src/programmers/http/HttpValidateFormDataProgrammer.ts +92 -92
  248. package/src/programmers/http/HttpValidateHeadersProgrammer.ts +92 -92
  249. package/src/programmers/http/HttpValidateQueryProgrammer.ts +98 -98
  250. package/src/programmers/internal/check_array_length.ts +47 -47
  251. package/src/programmers/internal/check_bigint.ts +50 -50
  252. package/src/programmers/internal/check_dynamic_key.ts +201 -201
  253. package/src/programmers/internal/check_dynamic_properties.ts +208 -208
  254. package/src/programmers/internal/check_everything.ts +23 -23
  255. package/src/programmers/internal/check_native.ts +27 -27
  256. package/src/programmers/internal/check_number.ts +112 -112
  257. package/src/programmers/internal/check_object.ts +75 -75
  258. package/src/programmers/internal/check_string.ts +50 -50
  259. package/src/programmers/internal/check_template.ts +48 -48
  260. package/src/programmers/internal/check_union_array_like.ts +335 -335
  261. package/src/programmers/internal/decode_union_object.ts +116 -116
  262. package/src/programmers/internal/feature_object_entries.ts +61 -61
  263. package/src/programmers/internal/json_schema_alias.ts +47 -47
  264. package/src/programmers/internal/json_schema_array.ts +45 -45
  265. package/src/programmers/internal/json_schema_bigint.ts +15 -15
  266. package/src/programmers/internal/json_schema_boolean.ts +15 -15
  267. package/src/programmers/internal/json_schema_constant.ts +26 -26
  268. package/src/programmers/internal/json_schema_description.ts +12 -12
  269. package/src/programmers/internal/json_schema_discriminator.ts +35 -35
  270. package/src/programmers/internal/json_schema_escaped.ts +82 -82
  271. package/src/programmers/internal/json_schema_native.ts +33 -33
  272. package/src/programmers/internal/json_schema_number.ts +15 -15
  273. package/src/programmers/internal/json_schema_object.ts +158 -158
  274. package/src/programmers/internal/json_schema_plugin.ts +18 -18
  275. package/src/programmers/internal/json_schema_station.ts +185 -185
  276. package/src/programmers/internal/json_schema_string.ts +15 -15
  277. package/src/programmers/internal/json_schema_template.ts +55 -55
  278. package/src/programmers/internal/json_schema_title.ts +20 -20
  279. package/src/programmers/internal/json_schema_tuple.ts +35 -35
  280. package/src/programmers/internal/metadata_to_pattern.ts +42 -42
  281. package/src/programmers/internal/postfix_of_tuple.ts +5 -5
  282. package/src/programmers/internal/prune_object_properties.ts +71 -71
  283. package/src/programmers/internal/stringify_dynamic_properties.ts +162 -162
  284. package/src/programmers/internal/stringify_native.ts +7 -7
  285. package/src/programmers/internal/stringify_regular_properties.ts +81 -81
  286. package/src/programmers/internal/template_to_pattern.ts +23 -23
  287. package/src/programmers/internal/wrap_metadata_rest_tuple.ts +23 -23
  288. package/src/programmers/json/JsonApplicationProgrammer.ts +266 -266
  289. package/src/programmers/json/JsonAssertParseProgrammer.ts +113 -113
  290. package/src/programmers/json/JsonAssertStringifyProgrammer.ts +115 -115
  291. package/src/programmers/json/JsonIsParseProgrammer.ts +114 -114
  292. package/src/programmers/json/JsonIsStringifyProgrammer.ts +108 -108
  293. package/src/programmers/json/JsonSchemaProgrammer.ts +26 -26
  294. package/src/programmers/json/JsonSchemasProgrammer.ts +91 -91
  295. package/src/programmers/json/JsonStringifyProgrammer.ts +1124 -1124
  296. package/src/programmers/json/JsonValidateParseProgrammer.ts +105 -105
  297. package/src/programmers/json/JsonValidateStringifyProgrammer.ts +124 -124
  298. package/src/programmers/llm/LlmApplicationProgrammer.ts +401 -401
  299. package/src/programmers/llm/LlmModelPredicator.ts +127 -127
  300. package/src/programmers/llm/LlmParametersProgrammer.ts +93 -93
  301. package/src/programmers/llm/LlmSchemaProgrammer.ts +192 -192
  302. package/src/programmers/misc/MiscAssertCloneProgrammer.ts +95 -95
  303. package/src/programmers/misc/MiscAssertPruneProgrammer.ts +116 -116
  304. package/src/programmers/misc/MiscCloneProgrammer.ts +1032 -1032
  305. package/src/programmers/misc/MiscIsCloneProgrammer.ts +99 -99
  306. package/src/programmers/misc/MiscIsPruneProgrammer.ts +97 -97
  307. package/src/programmers/misc/MiscLiteralsProgrammer.ts +80 -80
  308. package/src/programmers/misc/MiscPruneProgrammer.ts +728 -728
  309. package/src/programmers/misc/MiscValidateCloneProgrammer.ts +111 -111
  310. package/src/programmers/misc/MiscValidatePruneProgrammer.ts +113 -113
  311. package/src/programmers/notations/NotationAssertGeneralProgrammer.ts +101 -101
  312. package/src/programmers/notations/NotationGeneralProgrammer.ts +984 -984
  313. package/src/programmers/notations/NotationIsGeneralProgrammer.ts +105 -105
  314. package/src/programmers/notations/NotationValidateGeneralProgrammer.ts +119 -119
  315. package/src/programmers/protobuf/ProtobufAssertDecodeProgrammer.ts +98 -98
  316. package/src/programmers/protobuf/ProtobufAssertEncodeProgrammer.ts +102 -102
  317. package/src/programmers/protobuf/ProtobufDecodeProgrammer.ts +654 -654
  318. package/src/programmers/protobuf/ProtobufEncodeProgrammer.ts +945 -945
  319. package/src/programmers/protobuf/ProtobufIsDecodeProgrammer.ts +109 -109
  320. package/src/programmers/protobuf/ProtobufIsEncodeProgrammer.ts +98 -98
  321. package/src/programmers/protobuf/ProtobufMessageProgrammer.ts +179 -179
  322. package/src/programmers/protobuf/ProtobufValidateDecodeProgrammer.ts +92 -92
  323. package/src/programmers/protobuf/ProtobufValidateEncodeProgrammer.ts +119 -119
  324. package/src/protobuf.ts +861 -861
  325. package/src/reflect.ts +50 -50
  326. package/src/schemas/json/IJsonApplication.ts +73 -73
  327. package/src/schemas/json/IJsonSchemaCollection.ts +29 -29
  328. package/src/schemas/json/IJsonSchemaUnit.ts +32 -32
  329. package/src/schemas/json/__IJsonApplication.ts +63 -63
  330. package/src/schemas/metadata/IJsDocTagInfo.ts +10 -10
  331. package/src/schemas/metadata/IMetadata.ts +35 -35
  332. package/src/schemas/metadata/IMetadataAlias.ts +6 -6
  333. package/src/schemas/metadata/IMetadataAliasType.ts +12 -12
  334. package/src/schemas/metadata/IMetadataApplication.ts +7 -7
  335. package/src/schemas/metadata/IMetadataArray.ts +6 -6
  336. package/src/schemas/metadata/IMetadataArrayType.ts +10 -10
  337. package/src/schemas/metadata/IMetadataAtomic.ts +6 -6
  338. package/src/schemas/metadata/IMetadataComponents.ts +11 -11
  339. package/src/schemas/metadata/IMetadataConstant.ts +18 -18
  340. package/src/schemas/metadata/IMetadataConstantValue.ts +11 -11
  341. package/src/schemas/metadata/IMetadataDictionary.ts +11 -11
  342. package/src/schemas/metadata/IMetadataEscaped.ts +6 -6
  343. package/src/schemas/metadata/IMetadataFunction.ts +8 -8
  344. package/src/schemas/metadata/IMetadataMap.ts +8 -8
  345. package/src/schemas/metadata/IMetadataNative.ts +6 -6
  346. package/src/schemas/metadata/IMetadataObject.ts +6 -6
  347. package/src/schemas/metadata/IMetadataObjectType.ts +13 -13
  348. package/src/schemas/metadata/IMetadataParameter.ts +9 -9
  349. package/src/schemas/metadata/IMetadataProperty.ts +9 -9
  350. package/src/schemas/metadata/IMetadataSet.ts +7 -7
  351. package/src/schemas/metadata/IMetadataTemplate.ts +7 -7
  352. package/src/schemas/metadata/IMetadataTuple.ts +6 -6
  353. package/src/schemas/metadata/IMetadataTupleType.ts +10 -10
  354. package/src/schemas/metadata/IMetadataTypeTag.ts +16 -16
  355. package/src/schemas/metadata/Metadata.ts +687 -687
  356. package/src/schemas/metadata/MetadataAlias.ts +46 -46
  357. package/src/schemas/metadata/MetadataAliasType.ts +63 -63
  358. package/src/schemas/metadata/MetadataApplication.ts +44 -44
  359. package/src/schemas/metadata/MetadataArray.ts +49 -49
  360. package/src/schemas/metadata/MetadataArrayType.ts +57 -57
  361. package/src/schemas/metadata/MetadataAtomic.ts +87 -87
  362. package/src/schemas/metadata/MetadataComponents.ts +98 -98
  363. package/src/schemas/metadata/MetadataConstant.ts +34 -34
  364. package/src/schemas/metadata/MetadataConstantValue.ts +62 -62
  365. package/src/schemas/metadata/MetadataEscaped.ts +51 -51
  366. package/src/schemas/metadata/MetadataFunction.ts +49 -49
  367. package/src/schemas/metadata/MetadataMap.ts +48 -48
  368. package/src/schemas/metadata/MetadataNative.ts +44 -44
  369. package/src/schemas/metadata/MetadataObject.ts +48 -48
  370. package/src/schemas/metadata/MetadataObjectType.ts +149 -149
  371. package/src/schemas/metadata/MetadataParameter.ts +54 -54
  372. package/src/schemas/metadata/MetadataProperty.ts +59 -59
  373. package/src/schemas/metadata/MetadataSet.ts +45 -45
  374. package/src/schemas/metadata/MetadataTemplate.ts +80 -80
  375. package/src/schemas/metadata/MetadataTuple.ts +32 -32
  376. package/src/schemas/metadata/MetadataTupleType.ts +67 -67
  377. package/src/schemas/protobuf/IProtobufProperty.ts +6 -6
  378. package/src/schemas/protobuf/IProtobufPropertyType.ts +37 -37
  379. package/src/schemas/protobuf/IProtobufSchema.ts +50 -50
  380. package/src/tags/Constant.ts +15 -15
  381. package/src/tags/ContentMediaType.ts +10 -10
  382. package/src/tags/Default.ts +22 -22
  383. package/src/tags/Example.ts +24 -24
  384. package/src/tags/Examples.ts +16 -16
  385. package/src/tags/ExclusiveMaximum.ts +23 -23
  386. package/src/tags/ExclusiveMinimum.ts +23 -23
  387. package/src/tags/Format.ts +50 -50
  388. package/src/tags/JsonSchemaPlugin.ts +8 -8
  389. package/src/tags/MaxItems.ts +12 -12
  390. package/src/tags/MaxLength.ts +12 -12
  391. package/src/tags/Maximum.ts +19 -19
  392. package/src/tags/MinItems.ts +12 -12
  393. package/src/tags/MinLength.ts +12 -12
  394. package/src/tags/Minimum.ts +19 -19
  395. package/src/tags/MultipleOf.ts +21 -21
  396. package/src/tags/Pattern.ts +31 -31
  397. package/src/tags/Sequence.ts +10 -10
  398. package/src/tags/TagBase.ts +82 -82
  399. package/src/tags/Type.ts +37 -37
  400. package/src/tags/UniqueItems.ts +14 -14
  401. package/src/tags/index.ts +21 -21
  402. package/src/tags/internal/FormatCheatSheet.ts +73 -73
  403. package/src/transform.ts +35 -35
  404. package/src/transformers/CallExpressionTransformer.ts +554 -552
  405. package/src/transformers/FileTransformer.ts +136 -136
  406. package/src/transformers/IProgrammerProps.ts +11 -11
  407. package/src/transformers/ITransformOptions.ts +62 -62
  408. package/src/transformers/ITransformProps.ts +9 -9
  409. package/src/transformers/ITypiaContext.ts +18 -18
  410. package/src/transformers/ImportTransformer.ts +81 -81
  411. package/src/transformers/NoTransformConfigurationError.ts +18 -18
  412. package/src/transformers/NodeTransformer.ts +17 -17
  413. package/src/transformers/TransformerError.ts +60 -60
  414. package/src/transformers/features/AssertTransformer.ts +24 -24
  415. package/src/transformers/features/CreateAssertTransformer.ts +24 -24
  416. package/src/transformers/features/CreateIsTransformer.ts +18 -18
  417. package/src/transformers/features/CreateRandomTransformer.ts +43 -43
  418. package/src/transformers/features/CreateValidateTransformer.ts +18 -18
  419. package/src/transformers/features/IsTransformer.ts +18 -18
  420. package/src/transformers/features/RandomTransformer.ts +41 -41
  421. package/src/transformers/features/ValidateTransformer.ts +18 -18
  422. package/src/transformers/features/functional/FunctionalGenericTransformer.ts +57 -57
  423. package/src/transformers/features/http/CreateHttpAssertFormDataTransformer.ts +13 -13
  424. package/src/transformers/features/http/CreateHttpAssertHeadersTransformer.ts +13 -13
  425. package/src/transformers/features/http/CreateHttpAssertQueryTransformer.ts +13 -13
  426. package/src/transformers/features/http/CreateHttpFormDataTransformer.ts +13 -13
  427. package/src/transformers/features/http/CreateHttpHeadersTransformer.ts +13 -13
  428. package/src/transformers/features/http/CreateHttpIsFormDataTransformer.ts +13 -13
  429. package/src/transformers/features/http/CreateHttpIsHeadersTransformer.ts +13 -13
  430. package/src/transformers/features/http/CreateHttpIsQueryTransformer.ts +13 -13
  431. package/src/transformers/features/http/CreateHttpParameterTransformer.ts +13 -13
  432. package/src/transformers/features/http/CreateHttpQueryTransformer.ts +13 -13
  433. package/src/transformers/features/http/CreateHttpValidateFormDataTransformer.ts +13 -13
  434. package/src/transformers/features/http/CreateHttpValidateHeadersTransformer.ts +13 -13
  435. package/src/transformers/features/http/CreateHttpValidateQueryTransformer.ts +13 -13
  436. package/src/transformers/features/http/HttpAssertFormDataTransformer.ts +13 -13
  437. package/src/transformers/features/http/HttpAssertHeadersTransformer.ts +13 -13
  438. package/src/transformers/features/http/HttpAssertQueryTransformer.ts +13 -13
  439. package/src/transformers/features/http/HttpFormDataTransformer.ts +13 -13
  440. package/src/transformers/features/http/HttpHeadersTransformer.ts +13 -13
  441. package/src/transformers/features/http/HttpIsFormDataTransformer.ts +13 -13
  442. package/src/transformers/features/http/HttpIsHeadersTransformer.ts +13 -13
  443. package/src/transformers/features/http/HttpIsQueryTransformer.ts +13 -13
  444. package/src/transformers/features/http/HttpParameterTransformer.ts +13 -13
  445. package/src/transformers/features/http/HttpQueryTransformer.ts +13 -13
  446. package/src/transformers/features/http/HttpValidateFormDataTransformer.ts +13 -13
  447. package/src/transformers/features/http/HttpValidateHeadersTransformer.ts +13 -13
  448. package/src/transformers/features/http/HttpValidateQueryTransformer.ts +13 -13
  449. package/src/transformers/features/json/JsonApplicationTransformer.ts +105 -105
  450. package/src/transformers/features/json/JsonAssertParseTransformer.ts +13 -13
  451. package/src/transformers/features/json/JsonAssertStringifyTransformer.ts +13 -13
  452. package/src/transformers/features/json/JsonCreateAssertParseTransformer.ts +13 -13
  453. package/src/transformers/features/json/JsonCreateAssertStringifyTransformer.ts +13 -13
  454. package/src/transformers/features/json/JsonCreateIsParseTransformer.ts +13 -13
  455. package/src/transformers/features/json/JsonCreateIsStringifyTransformer.ts +13 -13
  456. package/src/transformers/features/json/JsonCreateStringifyTransformer.ts +13 -13
  457. package/src/transformers/features/json/JsonCreateValidateParseTransformer.ts +13 -13
  458. package/src/transformers/features/json/JsonCreateValidateStringifyProgrammer.ts +13 -13
  459. package/src/transformers/features/json/JsonIsParseTransformer.ts +13 -13
  460. package/src/transformers/features/json/JsonIsStringifyTransformer.ts +13 -13
  461. package/src/transformers/features/json/JsonSchemaTransformer.ts +135 -135
  462. package/src/transformers/features/json/JsonSchemasTransformer.ts +145 -145
  463. package/src/transformers/features/json/JsonStringifyTransformer.ts +13 -13
  464. package/src/transformers/features/json/JsonValidateParseTransformer.ts +13 -13
  465. package/src/transformers/features/json/JsonValidateStringifyTransformer.ts +13 -13
  466. package/src/transformers/features/llm/LlmApplicationTransformer.ts +145 -128
  467. package/src/transformers/features/llm/LlmControllerTransformer.ts +93 -0
  468. package/src/transformers/features/llm/LlmParametersTransformer.ts +102 -102
  469. package/src/transformers/features/llm/LlmSchemaTransformer.ts +170 -170
  470. package/src/transformers/features/misc/MiscAssertCloneTransformer.ts +13 -13
  471. package/src/transformers/features/misc/MiscAssertPruneTransformer.ts +13 -13
  472. package/src/transformers/features/misc/MiscCloneTransformer.ts +13 -13
  473. package/src/transformers/features/misc/MiscCreateAssertCloneTransformer.ts +13 -13
  474. package/src/transformers/features/misc/MiscCreateAssertPruneTransformer.ts +13 -13
  475. package/src/transformers/features/misc/MiscCreateCloneTransformer.ts +13 -13
  476. package/src/transformers/features/misc/MiscCreateIsCloneTransformer.ts +13 -13
  477. package/src/transformers/features/misc/MiscCreateIsPruneTransformer.ts +13 -13
  478. package/src/transformers/features/misc/MiscCreatePruneTransformer.ts +13 -13
  479. package/src/transformers/features/misc/MiscCreateValidateCloneTransformer.ts +13 -13
  480. package/src/transformers/features/misc/MiscCreateValidatePruneTransformer.ts +13 -13
  481. package/src/transformers/features/misc/MiscIsCloneTransformer.ts +13 -13
  482. package/src/transformers/features/misc/MiscIsPruneTransformer.ts +13 -13
  483. package/src/transformers/features/misc/MiscLiteralsTransformer.ts +35 -35
  484. package/src/transformers/features/misc/MiscPruneTransformer.ts +13 -13
  485. package/src/transformers/features/misc/MiscValidateCloneTransformer.ts +13 -13
  486. package/src/transformers/features/misc/MiscValidatePruneTransformer.ts +13 -13
  487. package/src/transformers/features/notations/NotationAssertGeneralTransformer.ts +20 -20
  488. package/src/transformers/features/notations/NotationCreateAssertGeneralTransformer.ts +20 -20
  489. package/src/transformers/features/notations/NotationCreateGeneralTransformer.ts +20 -20
  490. package/src/transformers/features/notations/NotationCreateIsGeneralTransformer.ts +20 -20
  491. package/src/transformers/features/notations/NotationCreateValidateGeneralTransformer.ts +20 -20
  492. package/src/transformers/features/notations/NotationGeneralTransformer.ts +18 -18
  493. package/src/transformers/features/notations/NotationIsGeneralTransformer.ts +20 -20
  494. package/src/transformers/features/notations/NotationValidateGeneralTransformer.ts +20 -20
  495. package/src/transformers/features/protobuf/ProtobufAssertDecodeTransformer.ts +13 -13
  496. package/src/transformers/features/protobuf/ProtobufAssertEncodeTransformer.ts +13 -13
  497. package/src/transformers/features/protobuf/ProtobufCreateAssertDecodeTransformer.ts +13 -13
  498. package/src/transformers/features/protobuf/ProtobufCreateAssertEncodeTransformer.ts +13 -13
  499. package/src/transformers/features/protobuf/ProtobufCreateDecodeTransformer.ts +13 -13
  500. package/src/transformers/features/protobuf/ProtobufCreateEncodeTransformer.ts +13 -13
  501. package/src/transformers/features/protobuf/ProtobufCreateIsDecodeTransformer.ts +13 -13
  502. package/src/transformers/features/protobuf/ProtobufCreateIsEncodeTransformer.ts +13 -13
  503. package/src/transformers/features/protobuf/ProtobufCreateValidateDecodeTransformer.ts +13 -13
  504. package/src/transformers/features/protobuf/ProtobufCreateValidateEncodeTransformer.ts +13 -13
  505. package/src/transformers/features/protobuf/ProtobufDecodeTransformer.ts +13 -13
  506. package/src/transformers/features/protobuf/ProtobufEncodeTransformer.ts +13 -13
  507. package/src/transformers/features/protobuf/ProtobufIsDecodeTransformer.ts +13 -13
  508. package/src/transformers/features/protobuf/ProtobufIsEncodeTransformer.ts +13 -13
  509. package/src/transformers/features/protobuf/ProtobufMessageTransformer.ts +35 -35
  510. package/src/transformers/features/protobuf/ProtobufValidateDecodeTransformer.ts +13 -13
  511. package/src/transformers/features/protobuf/ProtobufValidateEncodeTransformer.ts +13 -13
  512. package/src/transformers/features/reflect/ReflectMetadataTransformer.ts +69 -69
  513. package/src/transformers/features/reflect/ReflectNameTransformer.ts +82 -82
  514. package/src/transformers/internal/GenericTransformer.ts +101 -101
  515. package/src/typings/Atomic.ts +13 -13
  516. package/src/typings/ClassProperties.ts +5 -5
  517. package/src/typings/Customizable.ts +5 -5
  518. package/src/typings/Equal.ts +18 -18
  519. package/src/typings/IsTuple.ts +9 -9
  520. package/src/typings/NativeClass.ts +23 -23
  521. package/src/typings/OmitNever.ts +3 -3
  522. package/src/typings/ProtobufAtomic.ts +19 -19
  523. package/src/typings/SpecialFields.ts +3 -3
  524. package/src/typings/ValidationPipe.ts +9 -9
  525. package/src/typings/ValueOf.ts +20 -20
  526. package/src/typings/Writable.ts +11 -11
  527. package/src/utils/ArrayUtil.ts +41 -41
  528. package/src/utils/Escaper.ts +50 -50
  529. package/src/utils/MapUtil.ts +14 -14
  530. package/src/utils/NamingConvention.ts +94 -94
  531. package/src/utils/PatternUtil.ts +29 -29
  532. package/src/utils/ProtobufNameEncoder.ts +32 -32
  533. package/src/utils/Singleton.ts +16 -16
  534. package/src/utils/StringUtil.ts +16 -16
package/src/notations.ts CHANGED
@@ -1,820 +1,820 @@
1
- import { NoTransformConfigurationError } from "./transformers/NoTransformConfigurationError";
2
-
3
- import { CamelCase } from "./CamelCase";
4
- import { IValidation } from "./IValidation";
5
- import { PascalCase } from "./PascalCase";
6
- import { SnakeCase } from "./SnakeCase";
7
- import { TypeGuardError } from "./TypeGuardError";
8
-
9
- /* ===========================================================
10
- NOTATIONS (NAMING CONVENTIONS)
11
- - CAMEL CASE
12
- - PASCAL CASE
13
- - SNAKE CASE
14
- - FACTORY FUNCTIONS
15
- ==============================================================
16
- CAMEL CASE
17
- ----------------------------------------------------------- */
18
- /**
19
- * Convert to camel case.
20
- *
21
- * Convert every property names of nested objects to follow the camel case convention.
22
- *
23
- * For reference, this `typia.notations.camel()` function does not validate the input value
24
- * type. It just believes that the input value is following the type `T`. Therefore,
25
- * if you can't ensure the input value type, it would be better to call one of them below:
26
- *
27
- * - {@link assertCamel}
28
- * - {@link isCamel}
29
- * - {@link validateCamel}
30
- *
31
- * @template T Type of the input value
32
- * @param input Target object
33
- * @returns Camel case object
34
- *
35
- * @author Jeongho Nam - https://github.com/samchon
36
- */
37
- export function camel<T>(input: T): CamelCase<T>;
38
-
39
- /**
40
- * @internal
41
- */
42
- export function camel(): never {
43
- return NoTransformConfigurationError("notations.camel");
44
- }
45
-
46
- /**
47
- * Converts to camel case with type assertion.
48
- *
49
- * Convert every property names of nested objects to follow the camel case convention.
50
- * If the input value does not follow the type `T`, it throws {@link TypeGuardError}.
51
- *
52
- * @template T Type of the input value
53
- * @param input Target object
54
- * @param errorFactory Custom error factory. Default is `TypeGuardError`
55
- * @returns Camel case object
56
- *
57
- * @author Jeongho Nam - https://github.com/samchon
58
- */
59
- export function assertCamel<T>(
60
- input: T,
61
- errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
62
- ): CamelCase<T>;
63
-
64
- /**
65
- * Converts to camel case with type assertion.
66
- *
67
- * Convert every property names of nested objects to follow the camel case convention.
68
- * If the input value does not follow the type `T`, it throws {@link TypeGuardError}.
69
- *
70
- * @template T Type of the input value
71
- * @param input Target object
72
- * @param errorFactory Custom error factory. Default is `TypeGuardError`
73
- * @returns Camel case object
74
- *
75
- * @author Jeongho Nam - https://github.com/samchon
76
- */
77
- export function assertCamel<T>(
78
- input: unknown,
79
- errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
80
- ): CamelCase<T>;
81
-
82
- /**
83
- * @internal
84
- */
85
- export function assertCamel(): never {
86
- return NoTransformConfigurationError("notations.assertCamel");
87
- }
88
-
89
- /**
90
- * Converts to camel case with type checking.
91
- *
92
- * Convert every property names of nested objects to follow the camel case convention.
93
- * If the input value does not follow the type `T`, it returns `null` value instead.
94
- *
95
- * @template T Type of the input value
96
- * @param input Target object
97
- * @returns Camel case object when exact type, otherwise null
98
- *
99
- * @author Jeongho Nam - https://github.com/samchon
100
- */
101
- export function isCamel<T>(input: T): CamelCase<T> | null;
102
-
103
- /**
104
- * Converts to camel case with type checking.
105
- *
106
- * Convert every property names of nested objects to follow the camel case convention.
107
- * If the input value does not follow the type `T`, it returns `null` value instead.
108
- *
109
- * @template T Type of the input value
110
- * @param input Target object
111
- * @returns Camel case object when exact type, otherwise null
112
- *
113
- * @author Jeongho Nam - https://github.com/samchon
114
- */
115
- export function isCamel<T>(input: unknown): CamelCase<T> | null;
116
-
117
- /**
118
- * @internal
119
- */
120
- export function isCamel(): never {
121
- return NoTransformConfigurationError("notations.isCamel");
122
- }
123
-
124
- /**
125
- * Converts to camel case with type validation.
126
- *
127
- * Convert every property names of nested objects to follow the camel case convention.
128
- * If the input value does not follow the type `T`, it returns {@link IValidation.Failure}
129
- * object. Otherwise, there's no problem on the input value, camel cased converted data
130
- * would be stored in the `data` property of the output {@link IValidation.Success} object.
131
- *
132
- * @template T Type of the input value
133
- * @param input Target object
134
- * @returns Validation result with camel case object
135
- *
136
- * @author Jeongho Nam - https://github.com/samchon
137
- */
138
- export function validateCamel<T>(input: T): IValidation<CamelCase<T>>;
139
-
140
- /**
141
- * Converts to camel case with type validation.
142
- *
143
- * Convert every property names of nested objects to follow the camel case convention.
144
- * If the input value does not follow the type `T`, it returns {@link IValidation.Failure}
145
- * object. Otherwise, there's no problem on the input value, camel cased converted data
146
- * would be stored in the `data` property of the output {@link IValidation.Success} object.
147
- *
148
- * @template T Type of the input value
149
- * @param input Target object
150
- * @returns Validation result with camel case object
151
- *
152
- * @author Jeongho Nam - https://github.com/samchon
153
- */
154
- export function validateCamel<T>(input: unknown): IValidation<CamelCase<T>>;
155
-
156
- /**
157
- * @internal
158
- */
159
- export function validateCamel(): never {
160
- return NoTransformConfigurationError("notations.validateCamel");
161
- }
162
-
163
- /* -----------------------------------------------------------
164
- PASCAL CASE
165
- ----------------------------------------------------------- */
166
- /**
167
- * Convert to pascal case.
168
- *
169
- * Convert every property names of nested objects to follow the pascal case convention.
170
- *
171
- * For reference, this `typia.notations.pascal()` function does not validate the input value
172
- * type. It just believes that the input value is following the type `T`. Therefore,
173
- * if you can't ensure the input value type, it would be better to call one of them below:
174
- *
175
- * - {@link assertPascal}
176
- * - {@link isPascal}
177
- * - {@link validatePascal}
178
- *
179
- * @template T Type of the input value
180
- * @param input Target object
181
- * @returns Pascal case object
182
- *
183
- * @author Jeongho Nam - https://github.com/samchon
184
- */
185
- export function pascal<T>(input: T): PascalCase<T>;
186
-
187
- /**
188
- * @internal
189
- */
190
- export function pascal(): never {
191
- return NoTransformConfigurationError("notations.pascal");
192
- }
193
-
194
- /**
195
- * Converts to pascal case with type assertion.
196
- *
197
- * Convert every property names of nested objects to follow the pascal case convention.
198
- * If the input value does not follow the type `T`, it throws {@link TypeGuardError}.
199
- *
200
- * @template T Type of the input value
201
- * @param input Target object
202
- * @param errorFactory Custom error factory. Default is `TypeGuardError`
203
- * @returns Pascal case object
204
- *
205
- * @author Jeongho Nam - https://github.com/samchon
206
- */
207
- export function assertPascal<T>(
208
- input: T,
209
- errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
210
- ): PascalCase<T>;
211
-
212
- /**
213
- * Converts to pascal case with type assertion.
214
- *
215
- * Convert every property names of nested objects to follow the pascal case convention.
216
- * If the input value does not follow the type `T`, it throws {@link TypeGuardError}.
217
- *
218
- * @template T Type of the input value
219
- * @param input Target object
220
- * @param errorFactory Custom error factory. Default is `TypeGuardError`
221
- * @returns Pascal case object
222
- *
223
- * @author Jeongho Nam - https://github.com/samchon
224
- */
225
- export function assertPascal<T>(
226
- input: unknown,
227
- errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
228
- ): PascalCase<T>;
229
-
230
- /**
231
- * @internal
232
- */
233
- export function assertPascal(): never {
234
- return NoTransformConfigurationError("notations.assertPascal");
235
- }
236
-
237
- /**
238
- * Converts to pascal case with type checking.
239
- *
240
- * Convert every property names of nested objects to follow the pascal case convention.
241
- * If the input value does not follow the type `T`, it returns `null` value instead.
242
- *
243
- * @template T Type of the input value
244
- * @param input Target object
245
- * @returns Pascal case object when exact type, otherwise null
246
- *
247
- * @author Jeongho Nam - https://github.com/samchon
248
- */
249
- export function isPascal<T>(input: T): PascalCase<T> | null;
250
-
251
- /**
252
- * Converts to pascal case with type checking.
253
- *
254
- * Convert every property names of nested objects to follow the pascal case convention.
255
- * If the input value does not follow the type `T`, it returns `null` value instead.
256
- *
257
- * @template T Type of the input value
258
- * @param input Target object
259
- * @returns Pascal case object when exact type, otherwise null
260
- *
261
- * @author Jeongho Nam - https://github.com/samchon
262
- */
263
- export function isPascal<T>(input: unknown): PascalCase<T> | null;
264
-
265
- /**
266
- * @internal
267
- */
268
- export function isPascal(): never {
269
- return NoTransformConfigurationError("notations.isPascal");
270
- }
271
-
272
- /**
273
- * Converts to pascal case with type validation.
274
- *
275
- * Convert every property names of nested objects to follow the pascal case convention.
276
- * If the input value does not follow the type `T`, it returns {@link IValidation.Failure}
277
- * object. Otherwise, there's no problem on the input value, pascal cased converted data
278
- * would be stored in the `data` property of the output {@link IValidation.Success} object.
279
- *
280
- * @template T Type of the input value
281
- * @param input Target object
282
- * @returns Validation result with pascal case object
283
- *
284
- * @author Jeongho Nam - https://github.com/samchon
285
- */
286
- export function validatePascal<T>(input: T): IValidation<PascalCase<T>>;
287
-
288
- /**
289
- * Converts to pascal case with type validation.
290
- *
291
- * Convert every property names of nested objects to follow the pascal case convention.
292
- * If the input value does not follow the type `T`, it returns {@link IValidation.Failure}
293
- * object. Otherwise, there's no problem on the input value, pascal cased converted data
294
- * would be stored in the `data` property of the output {@link IValidation.Success} object.
295
- *
296
- * @template T Type of the input value
297
- * @param input Target object
298
- * @returns Validation result with pascal case object
299
- *
300
- * @author Jeongho Nam - https://github.com/samchon
301
- */
302
- export function validatePascal<T>(input: unknown): IValidation<PascalCase<T>>;
303
-
304
- /**
305
- * @internal
306
- */
307
- export function validatePascal(): never {
308
- return NoTransformConfigurationError("notations.validatePascal");
309
- }
310
-
311
- /* -----------------------------------------------------------
312
- SNAKE CASE
313
- ----------------------------------------------------------- */
314
- /**
315
- * Convert to snake case.
316
- *
317
- * Convert every property names of nested objects to follow the snake case convention.
318
- *
319
- * For reference, this `typia.notations.snake()` function does not validate the input value
320
- * type. It just believes that the input value is following the type `T`. Therefore,
321
- * if you can't ensure the input value type, it would be better to call one of them below:
322
- *
323
- * - {@link assertSnake}
324
- * - {@link isSnake}
325
- * - {@link validateSnake}
326
- *
327
- * @template T Type of the input value
328
- * @param input Target object
329
- * @returns Snake case object
330
- *
331
- * @author Jeongho Nam - https://github.com/samchon
332
- */
333
- export function snake<T>(input: T): SnakeCase<T>;
334
-
335
- /**
336
- * @internal
337
- */
338
- export function snake(): never {
339
- return NoTransformConfigurationError("notations.snake");
340
- }
341
-
342
- /**
343
- * Converts to snake case with type assertion.
344
- *
345
- * Convert every property names of nested objects to follow the snake case convention.
346
- * If the input value does not follow the type `T`, it throws {@link TypeGuardError}.
347
- *
348
- * @template T Type of the input value
349
- * @param input Target object
350
- * @param errorFactory Custom error factory. Default is `TypeGuardError`
351
- * @returns Snake case object
352
- *
353
- * @author Jeongho Nam - https://github.com/samchon
354
- */
355
- export function assertSnake<T>(
356
- input: T,
357
- errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
358
- ): SnakeCase<T>;
359
-
360
- /**
361
- * Converts to snake case with type assertion.
362
- *
363
- * Convert every property names of nested objects to follow the snake case convention.
364
- * If the input value does not follow the type `T`, it throws {@link TypeGuardError}.
365
- *
366
- * @template T Type of the input value
367
- * @param input Target object
368
- * @param errorFactory Custom error factory. Default is `TypeGuardError`
369
- * @returns Snake case object
370
- *
371
- * @author Jeongho Nam - https://github.com/samchon
372
- */
373
- export function assertSnake<T>(
374
- input: unknown,
375
- errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
376
- ): SnakeCase<T>;
377
-
378
- /**
379
- * @internal
380
- */
381
- export function assertSnake(): never {
382
- return NoTransformConfigurationError("notations.assertSnake");
383
- }
384
-
385
- /**
386
- * Converts to snake case with type checking.
387
- *
388
- * Convert every property names of nested objects to follow the snake case convention.
389
- * If the input value does not follow the type `T`, it returns `null` value instead.
390
- *
391
- * @template T Type of the input value
392
- * @param input Target object
393
- * @returns Snake case object when exact type, otherwise null
394
- *
395
- * @author Jeongho Nam - https://github.com/samchon
396
- */
397
- export function isSnake<T>(input: T): SnakeCase<T> | null;
398
-
399
- /**
400
- * Converts to snake case with type checking.
401
- *
402
- * Convert every property names of nested objects to follow the snake case convention.
403
- * If the input value does not follow the type `T`, it returns `null` value instead.
404
- *
405
- * @template T Type of the input value
406
- * @param input Target object
407
- * @returns Snake case object when exact type, otherwise null
408
- *
409
- * @author Jeongho Nam - https://github.com/samchon
410
- */
411
- export function isSnake<T>(input: unknown): SnakeCase<T> | null;
412
-
413
- /**
414
- * @internal
415
- */
416
- export function isSnake(): never {
417
- return NoTransformConfigurationError("notations.isSnake");
418
- }
419
-
420
- /**
421
- * Converts to snake case with type validation.
422
- *
423
- * Convert every property names of nested objects to follow the snake case convention.
424
- * If the input value does not follow the type `T`, it returns {@link IValidation.Failure}
425
- * object. Otherwise, there's no problem on the input value, snake cased converted data
426
- * would be stored in the `data` property of the output {@link IValidation.Success} object.
427
- *
428
- * @template T Type of the input value
429
- * @param input Target object
430
- * @returns Validation result with snake case object
431
- *
432
- * @author Jeongho Nam - https://github.com/samchon
433
- */
434
- export function validateSnake<T>(input: T): IValidation<SnakeCase<T>>;
435
-
436
- /**
437
- * Converts to snake case with type validation.
438
- *
439
- * Convert every property names of nested objects to follow the snake case convention.
440
- * If the input value does not follow the type `T`, it returns {@link IValidation.Failure}
441
- * object. Otherwise, there's no problem on the input value, snake cased converted data
442
- * would be stored in the `data` property of the output {@link IValidation.Success} object.
443
- *
444
- * @template T Type of the input value
445
- * @param input Target object
446
- * @returns Validation result with snake case object
447
- *
448
- * @author Jeongho Nam - https://github.com/samchon
449
- */
450
- export function validateSnake<T>(input: unknown): IValidation<SnakeCase<T>>;
451
-
452
- /**
453
- * @internal
454
- */
455
- export function validateSnake(): never {
456
- return NoTransformConfigurationError("notations.validateSnake");
457
- }
458
-
459
- /* -----------------------------------------------------------
460
- FACTORY FUNCTIONS
461
- ----------------------------------------------------------- */
462
- /**
463
- * Creates a reusable {@link camel} function.
464
- *
465
- * @danger You must configure the generic argument `T`
466
- * @returns Nothing until be configure the generic argument `T`
467
- * @throws compile error
468
- *
469
- * @author Jeongho Nam - https://github.com/samchon
470
- */
471
- export function createCamel(): never;
472
-
473
- /**
474
- * Creates a reusable {@link camel} function.
475
- *
476
- * @template T Type of the input value
477
- * @returns A reusable `camel` function
478
- *
479
- * @author Jeongho Nam - https://github.com/samchon
480
- */
481
- export function createCamel<T>(): (input: T) => CamelCase<T>;
482
-
483
- /**
484
- * @internal
485
- */
486
- export function createCamel(): never {
487
- NoTransformConfigurationError("notations.createCamel");
488
- }
489
-
490
- /**
491
- * Creates a reusable {@link assertCamel} function.
492
- *
493
- * @danger You must configure the generic argument `T`
494
- * @param errorFactory Custom error factory. Default is `TypeGuardError`
495
- * @returns Nothing until be configure the generic argument `T`
496
- * @throws compile error
497
- *
498
- * @author Jeongho Nam - https://github.com/samchon
499
- */
500
- export function createAssertCamel(
501
- errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
502
- ): never;
503
-
504
- /**
505
- * Creates a reusable {@link assertCamel} function.
506
- *
507
- * @template T Type of the input value
508
- * @param errorFactory Custom error factory. Default is `TypeGuardError`
509
- * @returns A reusable `assertCamel` function
510
- *
511
- * @author Jeongho Nam - https://github.com/samchon
512
- */
513
- export function createAssertCamel<T>(
514
- errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
515
- ): (input: T) => CamelCase<T>;
516
-
517
- /**
518
- * @internal
519
- */
520
- export function createAssertCamel(): never {
521
- NoTransformConfigurationError("notations.createAssertCamel");
522
- }
523
-
524
- /**
525
- * Creates a reusable {@link isCamel} function.
526
- *
527
- * @danger You must configure the generic argument `T`
528
- * @returns Nothing until be configure the generic argument `T`
529
- * @throws compile error
530
- *
531
- * @author Jeongho Nam - https://github.com/samchon
532
- */
533
- export function createIsCamel(): never;
534
-
535
- /**
536
- * Creates a reusable {@link isCamel} function.
537
- *
538
- * @template T Type of the input value
539
- * @returns A reusable `isCamel` function
540
- *
541
- * @author Jeongho Nam - https://github.com/samchon
542
- */
543
- export function createIsCamel<T>(): (input: T) => CamelCase<T> | null;
544
-
545
- /**
546
- * @internal
547
- */
548
- export function createIsCamel(): never {
549
- NoTransformConfigurationError("notations.createIsCamel");
550
- }
551
-
552
- /**
553
- * Creates a reusable {@link validateCamel} function.
554
- *
555
- * @danger You must configure the generic argument `T`
556
- * @returns Nothing until be configure the generic argument `T`
557
- * @throws compile error
558
- *
559
- * @author Jeongho Nam - https://github.com/samchon
560
- */
561
- export function createValidateCamel(): never;
562
-
563
- /**
564
- * Creates a reusable {@link validateCamel} function.
565
- *
566
- * @template T Type of the input value
567
- * @returns A reusable `validateCamel` function
568
- *
569
- * @author Jeongho Nam - https://github.com/samchon
570
- */
571
- export function createValidateCamel<T>(): (
572
- input: T,
573
- ) => IValidation<CamelCase<T>>;
574
-
575
- /**
576
- * @internal
577
- */
578
- export function createValidateCamel(): never {
579
- NoTransformConfigurationError("notations.createValidateCamel");
580
- }
581
-
582
- /**
583
- * Creates a reusable {@link pascal} function.
584
- *
585
- * @danger You must configure the generic argument `T`
586
- * @returns Nothing until be configure the generic argument `T`
587
- * @throws compile error
588
- *
589
- * @author Jeongho Nam - https://github.com/samchon
590
- */
591
- export function createPascal(): never;
592
-
593
- /**
594
- * Creates a reusable {@link pascal} function.
595
- *
596
- * @template T Type of the input value
597
- * @returns A reusable `pascal` function
598
- *
599
- * @author Jeongho Nam - https://github.com/samchon
600
- */
601
- export function createPascal<T>(): (input: T) => PascalCase<T>;
602
-
603
- /**
604
- * @internal
605
- */
606
- export function createPascal(): never {
607
- NoTransformConfigurationError("notations.createPascal");
608
- }
609
-
610
- /**
611
- * Creates a reusable {@link assertPascal} function.
612
- *
613
- * @danger You must configure the generic argument `T`
614
- * @param errorFactory Custom error factory. Default is `TypeGuardError`
615
- * @returns Nothing until be configure the generic argument `T`
616
- * @throws compile error
617
- *
618
- * @author Jeongho Nam - https://github.com/samchon
619
- */
620
- export function createAssertPascal(
621
- errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
622
- ): never;
623
-
624
- /**
625
- * Creates a reusable {@link assertPascal} function.
626
- *
627
- * @template T Type of the input value
628
- * @param errorFactory Custom error factory. Default is `TypeGuardError`
629
- * @returns A reusable `assertPascal` function
630
- *
631
- * @author Jeongho Nam - https://github.com/samchon
632
- */
633
- export function createAssertPascal<T>(
634
- errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
635
- ): (input: T) => PascalCase<T>;
636
-
637
- /**
638
- * @internal
639
- */
640
- export function createAssertPascal(): never {
641
- NoTransformConfigurationError("notations.createAssertPascal");
642
- }
643
-
644
- /**
645
- * Creates a reusable {@link isPascal} function.
646
- *
647
- * @danger You must configure the generic argument `T`
648
- * @returns Nothing until be configure the generic argument `T`
649
- * @throws compile error
650
- *
651
- * @author Jeongho Nam - https://github.com/samchon
652
- */
653
- export function createIsPascal(): never;
654
-
655
- /**
656
- * Creates a reusable {@link isPascal} function.
657
- *
658
- * @template T Type of the input value
659
- * @returns A reusable `isPascal` function
660
- *
661
- * @author Jeongho Nam - https://github.com/samchon
662
- */
663
- export function createIsPascal<T>(): (input: T) => PascalCase<T> | null;
664
-
665
- /**
666
- * @internal
667
- */
668
- export function createIsPascal(): never {
669
- NoTransformConfigurationError("notations.createIsPascal");
670
- }
671
-
672
- /**
673
- * Creates a reusable {@link validatePascal} function.
674
- *
675
- * @danger You must configure the generic argument `T`
676
- * @returns Nothing until be configure the generic argument `T`
677
- * @throws compile error
678
- *
679
- * @author Jeongho Nam - https://github.com/samchon
680
- */
681
- export function createValidatePascal(): never;
682
-
683
- /**
684
- * Creates a reusable {@link validatePascal} function.
685
- *
686
- * @template T Type of the input value
687
- * @returns A reusable `validatePascal` function
688
- *
689
- * @author Jeongho Nam - https://github.com/samchon
690
- */
691
- export function createValidatePascal<T>(): (
692
- input: T,
693
- ) => IValidation<PascalCase<T>>;
694
-
695
- /**
696
- * @internal
697
- */
698
- export function createValidatePascal(): never {
699
- NoTransformConfigurationError("notations.createValidatePascal");
700
- }
701
-
702
- /**
703
- * Creates a reusable {@link snake} function.
704
- *
705
- * @danger You must configure the generic argument `T`
706
- * @returns Nothing until be configure the generic argument `T`
707
- * @throws compile error
708
- *
709
- * @author Jeongho Nam - https://github.com/samchon
710
- */
711
- export function createSnake(): never;
712
-
713
- /**
714
- * Creates a reusable {@link snake} function.
715
- *
716
- * @template T Type of the input value
717
- * @returns A reusable `snake` function
718
- *
719
- * @author Jeongho Nam - https://github.com/samchon
720
- */
721
- export function createSnake<T>(): (input: T) => SnakeCase<T>;
722
-
723
- /**
724
- * @internal
725
- */
726
- export function createSnake(): never {
727
- NoTransformConfigurationError("notations.createSnake");
728
- }
729
-
730
- /**
731
- * Creates a reusable {@link assertSnake} function.
732
- *
733
- * @danger You must configure the generic argument `T`
734
- * @param errorFactory Custom error factory. Default is `TypeGuardError`
735
- * @returns Nothing until be configure the generic argument `T`
736
- * @throws compile error
737
- *
738
- * @author Jeongho Nam - https://github.com/samchon
739
- */
740
- export function createAssertSnake(
741
- errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
742
- ): never;
743
-
744
- /**
745
- * Creates a reusable {@link assertSnake} function.
746
- *
747
- * @template T Type of the input value
748
- * @param errorFactory Custom error factory. Default is `TypeGuardError`
749
- * @returns A reusable `assertSnake` function
750
- *
751
- * @author Jeongho Nam - https://github.com/samchon
752
- */
753
- export function createAssertSnake<T>(
754
- errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
755
- ): (input: T) => SnakeCase<T>;
756
-
757
- /**
758
- * @internal
759
- */
760
- export function createAssertSnake(): never {
761
- NoTransformConfigurationError("notations.createAssertSnake");
762
- }
763
-
764
- /**
765
- * Creates a reusable {@link isSnake} function.
766
- *
767
- * @danger You must configure the generic argument `T`
768
- * @returns Nothing until be configure the generic argument `T`
769
- * @throws compile error
770
- *
771
- * @author Jeongho Nam - https://github.com/samchon
772
- */
773
- export function createIsSnake(): never;
774
-
775
- /**
776
- * Creates a reusable {@link isSnake} function.
777
- *
778
- * @template T Type of the input value
779
- * @returns A reusable `isSnake` function
780
- *
781
- * @author Jeongho Nam - https://github.com/samchon
782
- */
783
- export function createIsSnake<T>(): (input: T) => SnakeCase<T> | null;
784
-
785
- /**
786
- * @internal
787
- */
788
- export function createIsSnake(): never {
789
- NoTransformConfigurationError("notations.createIsSnake");
790
- }
791
-
792
- /**
793
- * Creates a reusable {@link validateSnake} function.
794
- *
795
- * @danger You must configure the generic argument `T`
796
- * @returns Nothing until be configure the generic argument `T`
797
- * @throws compile error
798
- *
799
- * @author Jeongho Nam - https://github.com/samchon
800
- */
801
- export function createValidateSnake(): never;
802
-
803
- /**
804
- * Creates a reusable {@link validateSnake} function.
805
- *
806
- * @template T Type of the input value
807
- * @returns A reusable `validateSnake` function
808
- *
809
- * @author Jeongho Nam - https://github.com/samchon
810
- */
811
- export function createValidateSnake<T>(): (
812
- input: T,
813
- ) => IValidation<SnakeCase<T>>;
814
-
815
- /**
816
- * @internal
817
- */
818
- export function createValidateSnake(): never {
819
- NoTransformConfigurationError("notations.createValidateSnake");
820
- }
1
+ import { NoTransformConfigurationError } from "./transformers/NoTransformConfigurationError";
2
+
3
+ import { CamelCase } from "./CamelCase";
4
+ import { IValidation } from "./IValidation";
5
+ import { PascalCase } from "./PascalCase";
6
+ import { SnakeCase } from "./SnakeCase";
7
+ import { TypeGuardError } from "./TypeGuardError";
8
+
9
+ /* ===========================================================
10
+ NOTATIONS (NAMING CONVENTIONS)
11
+ - CAMEL CASE
12
+ - PASCAL CASE
13
+ - SNAKE CASE
14
+ - FACTORY FUNCTIONS
15
+ ==============================================================
16
+ CAMEL CASE
17
+ ----------------------------------------------------------- */
18
+ /**
19
+ * Convert to camel case.
20
+ *
21
+ * Convert every property names of nested objects to follow the camel case convention.
22
+ *
23
+ * For reference, this `typia.notations.camel()` function does not validate the input value
24
+ * type. It just believes that the input value is following the type `T`. Therefore,
25
+ * if you can't ensure the input value type, it would be better to call one of them below:
26
+ *
27
+ * - {@link assertCamel}
28
+ * - {@link isCamel}
29
+ * - {@link validateCamel}
30
+ *
31
+ * @template T Type of the input value
32
+ * @param input Target object
33
+ * @returns Camel case object
34
+ *
35
+ * @author Jeongho Nam - https://github.com/samchon
36
+ */
37
+ export function camel<T>(input: T): CamelCase<T>;
38
+
39
+ /**
40
+ * @internal
41
+ */
42
+ export function camel(): never {
43
+ return NoTransformConfigurationError("notations.camel");
44
+ }
45
+
46
+ /**
47
+ * Converts to camel case with type assertion.
48
+ *
49
+ * Convert every property names of nested objects to follow the camel case convention.
50
+ * If the input value does not follow the type `T`, it throws {@link TypeGuardError}.
51
+ *
52
+ * @template T Type of the input value
53
+ * @param input Target object
54
+ * @param errorFactory Custom error factory. Default is `TypeGuardError`
55
+ * @returns Camel case object
56
+ *
57
+ * @author Jeongho Nam - https://github.com/samchon
58
+ */
59
+ export function assertCamel<T>(
60
+ input: T,
61
+ errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
62
+ ): CamelCase<T>;
63
+
64
+ /**
65
+ * Converts to camel case with type assertion.
66
+ *
67
+ * Convert every property names of nested objects to follow the camel case convention.
68
+ * If the input value does not follow the type `T`, it throws {@link TypeGuardError}.
69
+ *
70
+ * @template T Type of the input value
71
+ * @param input Target object
72
+ * @param errorFactory Custom error factory. Default is `TypeGuardError`
73
+ * @returns Camel case object
74
+ *
75
+ * @author Jeongho Nam - https://github.com/samchon
76
+ */
77
+ export function assertCamel<T>(
78
+ input: unknown,
79
+ errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
80
+ ): CamelCase<T>;
81
+
82
+ /**
83
+ * @internal
84
+ */
85
+ export function assertCamel(): never {
86
+ return NoTransformConfigurationError("notations.assertCamel");
87
+ }
88
+
89
+ /**
90
+ * Converts to camel case with type checking.
91
+ *
92
+ * Convert every property names of nested objects to follow the camel case convention.
93
+ * If the input value does not follow the type `T`, it returns `null` value instead.
94
+ *
95
+ * @template T Type of the input value
96
+ * @param input Target object
97
+ * @returns Camel case object when exact type, otherwise null
98
+ *
99
+ * @author Jeongho Nam - https://github.com/samchon
100
+ */
101
+ export function isCamel<T>(input: T): CamelCase<T> | null;
102
+
103
+ /**
104
+ * Converts to camel case with type checking.
105
+ *
106
+ * Convert every property names of nested objects to follow the camel case convention.
107
+ * If the input value does not follow the type `T`, it returns `null` value instead.
108
+ *
109
+ * @template T Type of the input value
110
+ * @param input Target object
111
+ * @returns Camel case object when exact type, otherwise null
112
+ *
113
+ * @author Jeongho Nam - https://github.com/samchon
114
+ */
115
+ export function isCamel<T>(input: unknown): CamelCase<T> | null;
116
+
117
+ /**
118
+ * @internal
119
+ */
120
+ export function isCamel(): never {
121
+ return NoTransformConfigurationError("notations.isCamel");
122
+ }
123
+
124
+ /**
125
+ * Converts to camel case with type validation.
126
+ *
127
+ * Convert every property names of nested objects to follow the camel case convention.
128
+ * If the input value does not follow the type `T`, it returns {@link IValidation.Failure}
129
+ * object. Otherwise, there's no problem on the input value, camel cased converted data
130
+ * would be stored in the `data` property of the output {@link IValidation.Success} object.
131
+ *
132
+ * @template T Type of the input value
133
+ * @param input Target object
134
+ * @returns Validation result with camel case object
135
+ *
136
+ * @author Jeongho Nam - https://github.com/samchon
137
+ */
138
+ export function validateCamel<T>(input: T): IValidation<CamelCase<T>>;
139
+
140
+ /**
141
+ * Converts to camel case with type validation.
142
+ *
143
+ * Convert every property names of nested objects to follow the camel case convention.
144
+ * If the input value does not follow the type `T`, it returns {@link IValidation.Failure}
145
+ * object. Otherwise, there's no problem on the input value, camel cased converted data
146
+ * would be stored in the `data` property of the output {@link IValidation.Success} object.
147
+ *
148
+ * @template T Type of the input value
149
+ * @param input Target object
150
+ * @returns Validation result with camel case object
151
+ *
152
+ * @author Jeongho Nam - https://github.com/samchon
153
+ */
154
+ export function validateCamel<T>(input: unknown): IValidation<CamelCase<T>>;
155
+
156
+ /**
157
+ * @internal
158
+ */
159
+ export function validateCamel(): never {
160
+ return NoTransformConfigurationError("notations.validateCamel");
161
+ }
162
+
163
+ /* -----------------------------------------------------------
164
+ PASCAL CASE
165
+ ----------------------------------------------------------- */
166
+ /**
167
+ * Convert to pascal case.
168
+ *
169
+ * Convert every property names of nested objects to follow the pascal case convention.
170
+ *
171
+ * For reference, this `typia.notations.pascal()` function does not validate the input value
172
+ * type. It just believes that the input value is following the type `T`. Therefore,
173
+ * if you can't ensure the input value type, it would be better to call one of them below:
174
+ *
175
+ * - {@link assertPascal}
176
+ * - {@link isPascal}
177
+ * - {@link validatePascal}
178
+ *
179
+ * @template T Type of the input value
180
+ * @param input Target object
181
+ * @returns Pascal case object
182
+ *
183
+ * @author Jeongho Nam - https://github.com/samchon
184
+ */
185
+ export function pascal<T>(input: T): PascalCase<T>;
186
+
187
+ /**
188
+ * @internal
189
+ */
190
+ export function pascal(): never {
191
+ return NoTransformConfigurationError("notations.pascal");
192
+ }
193
+
194
+ /**
195
+ * Converts to pascal case with type assertion.
196
+ *
197
+ * Convert every property names of nested objects to follow the pascal case convention.
198
+ * If the input value does not follow the type `T`, it throws {@link TypeGuardError}.
199
+ *
200
+ * @template T Type of the input value
201
+ * @param input Target object
202
+ * @param errorFactory Custom error factory. Default is `TypeGuardError`
203
+ * @returns Pascal case object
204
+ *
205
+ * @author Jeongho Nam - https://github.com/samchon
206
+ */
207
+ export function assertPascal<T>(
208
+ input: T,
209
+ errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
210
+ ): PascalCase<T>;
211
+
212
+ /**
213
+ * Converts to pascal case with type assertion.
214
+ *
215
+ * Convert every property names of nested objects to follow the pascal case convention.
216
+ * If the input value does not follow the type `T`, it throws {@link TypeGuardError}.
217
+ *
218
+ * @template T Type of the input value
219
+ * @param input Target object
220
+ * @param errorFactory Custom error factory. Default is `TypeGuardError`
221
+ * @returns Pascal case object
222
+ *
223
+ * @author Jeongho Nam - https://github.com/samchon
224
+ */
225
+ export function assertPascal<T>(
226
+ input: unknown,
227
+ errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
228
+ ): PascalCase<T>;
229
+
230
+ /**
231
+ * @internal
232
+ */
233
+ export function assertPascal(): never {
234
+ return NoTransformConfigurationError("notations.assertPascal");
235
+ }
236
+
237
+ /**
238
+ * Converts to pascal case with type checking.
239
+ *
240
+ * Convert every property names of nested objects to follow the pascal case convention.
241
+ * If the input value does not follow the type `T`, it returns `null` value instead.
242
+ *
243
+ * @template T Type of the input value
244
+ * @param input Target object
245
+ * @returns Pascal case object when exact type, otherwise null
246
+ *
247
+ * @author Jeongho Nam - https://github.com/samchon
248
+ */
249
+ export function isPascal<T>(input: T): PascalCase<T> | null;
250
+
251
+ /**
252
+ * Converts to pascal case with type checking.
253
+ *
254
+ * Convert every property names of nested objects to follow the pascal case convention.
255
+ * If the input value does not follow the type `T`, it returns `null` value instead.
256
+ *
257
+ * @template T Type of the input value
258
+ * @param input Target object
259
+ * @returns Pascal case object when exact type, otherwise null
260
+ *
261
+ * @author Jeongho Nam - https://github.com/samchon
262
+ */
263
+ export function isPascal<T>(input: unknown): PascalCase<T> | null;
264
+
265
+ /**
266
+ * @internal
267
+ */
268
+ export function isPascal(): never {
269
+ return NoTransformConfigurationError("notations.isPascal");
270
+ }
271
+
272
+ /**
273
+ * Converts to pascal case with type validation.
274
+ *
275
+ * Convert every property names of nested objects to follow the pascal case convention.
276
+ * If the input value does not follow the type `T`, it returns {@link IValidation.Failure}
277
+ * object. Otherwise, there's no problem on the input value, pascal cased converted data
278
+ * would be stored in the `data` property of the output {@link IValidation.Success} object.
279
+ *
280
+ * @template T Type of the input value
281
+ * @param input Target object
282
+ * @returns Validation result with pascal case object
283
+ *
284
+ * @author Jeongho Nam - https://github.com/samchon
285
+ */
286
+ export function validatePascal<T>(input: T): IValidation<PascalCase<T>>;
287
+
288
+ /**
289
+ * Converts to pascal case with type validation.
290
+ *
291
+ * Convert every property names of nested objects to follow the pascal case convention.
292
+ * If the input value does not follow the type `T`, it returns {@link IValidation.Failure}
293
+ * object. Otherwise, there's no problem on the input value, pascal cased converted data
294
+ * would be stored in the `data` property of the output {@link IValidation.Success} object.
295
+ *
296
+ * @template T Type of the input value
297
+ * @param input Target object
298
+ * @returns Validation result with pascal case object
299
+ *
300
+ * @author Jeongho Nam - https://github.com/samchon
301
+ */
302
+ export function validatePascal<T>(input: unknown): IValidation<PascalCase<T>>;
303
+
304
+ /**
305
+ * @internal
306
+ */
307
+ export function validatePascal(): never {
308
+ return NoTransformConfigurationError("notations.validatePascal");
309
+ }
310
+
311
+ /* -----------------------------------------------------------
312
+ SNAKE CASE
313
+ ----------------------------------------------------------- */
314
+ /**
315
+ * Convert to snake case.
316
+ *
317
+ * Convert every property names of nested objects to follow the snake case convention.
318
+ *
319
+ * For reference, this `typia.notations.snake()` function does not validate the input value
320
+ * type. It just believes that the input value is following the type `T`. Therefore,
321
+ * if you can't ensure the input value type, it would be better to call one of them below:
322
+ *
323
+ * - {@link assertSnake}
324
+ * - {@link isSnake}
325
+ * - {@link validateSnake}
326
+ *
327
+ * @template T Type of the input value
328
+ * @param input Target object
329
+ * @returns Snake case object
330
+ *
331
+ * @author Jeongho Nam - https://github.com/samchon
332
+ */
333
+ export function snake<T>(input: T): SnakeCase<T>;
334
+
335
+ /**
336
+ * @internal
337
+ */
338
+ export function snake(): never {
339
+ return NoTransformConfigurationError("notations.snake");
340
+ }
341
+
342
+ /**
343
+ * Converts to snake case with type assertion.
344
+ *
345
+ * Convert every property names of nested objects to follow the snake case convention.
346
+ * If the input value does not follow the type `T`, it throws {@link TypeGuardError}.
347
+ *
348
+ * @template T Type of the input value
349
+ * @param input Target object
350
+ * @param errorFactory Custom error factory. Default is `TypeGuardError`
351
+ * @returns Snake case object
352
+ *
353
+ * @author Jeongho Nam - https://github.com/samchon
354
+ */
355
+ export function assertSnake<T>(
356
+ input: T,
357
+ errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
358
+ ): SnakeCase<T>;
359
+
360
+ /**
361
+ * Converts to snake case with type assertion.
362
+ *
363
+ * Convert every property names of nested objects to follow the snake case convention.
364
+ * If the input value does not follow the type `T`, it throws {@link TypeGuardError}.
365
+ *
366
+ * @template T Type of the input value
367
+ * @param input Target object
368
+ * @param errorFactory Custom error factory. Default is `TypeGuardError`
369
+ * @returns Snake case object
370
+ *
371
+ * @author Jeongho Nam - https://github.com/samchon
372
+ */
373
+ export function assertSnake<T>(
374
+ input: unknown,
375
+ errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
376
+ ): SnakeCase<T>;
377
+
378
+ /**
379
+ * @internal
380
+ */
381
+ export function assertSnake(): never {
382
+ return NoTransformConfigurationError("notations.assertSnake");
383
+ }
384
+
385
+ /**
386
+ * Converts to snake case with type checking.
387
+ *
388
+ * Convert every property names of nested objects to follow the snake case convention.
389
+ * If the input value does not follow the type `T`, it returns `null` value instead.
390
+ *
391
+ * @template T Type of the input value
392
+ * @param input Target object
393
+ * @returns Snake case object when exact type, otherwise null
394
+ *
395
+ * @author Jeongho Nam - https://github.com/samchon
396
+ */
397
+ export function isSnake<T>(input: T): SnakeCase<T> | null;
398
+
399
+ /**
400
+ * Converts to snake case with type checking.
401
+ *
402
+ * Convert every property names of nested objects to follow the snake case convention.
403
+ * If the input value does not follow the type `T`, it returns `null` value instead.
404
+ *
405
+ * @template T Type of the input value
406
+ * @param input Target object
407
+ * @returns Snake case object when exact type, otherwise null
408
+ *
409
+ * @author Jeongho Nam - https://github.com/samchon
410
+ */
411
+ export function isSnake<T>(input: unknown): SnakeCase<T> | null;
412
+
413
+ /**
414
+ * @internal
415
+ */
416
+ export function isSnake(): never {
417
+ return NoTransformConfigurationError("notations.isSnake");
418
+ }
419
+
420
+ /**
421
+ * Converts to snake case with type validation.
422
+ *
423
+ * Convert every property names of nested objects to follow the snake case convention.
424
+ * If the input value does not follow the type `T`, it returns {@link IValidation.Failure}
425
+ * object. Otherwise, there's no problem on the input value, snake cased converted data
426
+ * would be stored in the `data` property of the output {@link IValidation.Success} object.
427
+ *
428
+ * @template T Type of the input value
429
+ * @param input Target object
430
+ * @returns Validation result with snake case object
431
+ *
432
+ * @author Jeongho Nam - https://github.com/samchon
433
+ */
434
+ export function validateSnake<T>(input: T): IValidation<SnakeCase<T>>;
435
+
436
+ /**
437
+ * Converts to snake case with type validation.
438
+ *
439
+ * Convert every property names of nested objects to follow the snake case convention.
440
+ * If the input value does not follow the type `T`, it returns {@link IValidation.Failure}
441
+ * object. Otherwise, there's no problem on the input value, snake cased converted data
442
+ * would be stored in the `data` property of the output {@link IValidation.Success} object.
443
+ *
444
+ * @template T Type of the input value
445
+ * @param input Target object
446
+ * @returns Validation result with snake case object
447
+ *
448
+ * @author Jeongho Nam - https://github.com/samchon
449
+ */
450
+ export function validateSnake<T>(input: unknown): IValidation<SnakeCase<T>>;
451
+
452
+ /**
453
+ * @internal
454
+ */
455
+ export function validateSnake(): never {
456
+ return NoTransformConfigurationError("notations.validateSnake");
457
+ }
458
+
459
+ /* -----------------------------------------------------------
460
+ FACTORY FUNCTIONS
461
+ ----------------------------------------------------------- */
462
+ /**
463
+ * Creates a reusable {@link camel} function.
464
+ *
465
+ * @danger You must configure the generic argument `T`
466
+ * @returns Nothing until be configure the generic argument `T`
467
+ * @throws compile error
468
+ *
469
+ * @author Jeongho Nam - https://github.com/samchon
470
+ */
471
+ export function createCamel(): never;
472
+
473
+ /**
474
+ * Creates a reusable {@link camel} function.
475
+ *
476
+ * @template T Type of the input value
477
+ * @returns A reusable `camel` function
478
+ *
479
+ * @author Jeongho Nam - https://github.com/samchon
480
+ */
481
+ export function createCamel<T>(): (input: T) => CamelCase<T>;
482
+
483
+ /**
484
+ * @internal
485
+ */
486
+ export function createCamel(): never {
487
+ NoTransformConfigurationError("notations.createCamel");
488
+ }
489
+
490
+ /**
491
+ * Creates a reusable {@link assertCamel} function.
492
+ *
493
+ * @danger You must configure the generic argument `T`
494
+ * @param errorFactory Custom error factory. Default is `TypeGuardError`
495
+ * @returns Nothing until be configure the generic argument `T`
496
+ * @throws compile error
497
+ *
498
+ * @author Jeongho Nam - https://github.com/samchon
499
+ */
500
+ export function createAssertCamel(
501
+ errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
502
+ ): never;
503
+
504
+ /**
505
+ * Creates a reusable {@link assertCamel} function.
506
+ *
507
+ * @template T Type of the input value
508
+ * @param errorFactory Custom error factory. Default is `TypeGuardError`
509
+ * @returns A reusable `assertCamel` function
510
+ *
511
+ * @author Jeongho Nam - https://github.com/samchon
512
+ */
513
+ export function createAssertCamel<T>(
514
+ errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
515
+ ): (input: T) => CamelCase<T>;
516
+
517
+ /**
518
+ * @internal
519
+ */
520
+ export function createAssertCamel(): never {
521
+ NoTransformConfigurationError("notations.createAssertCamel");
522
+ }
523
+
524
+ /**
525
+ * Creates a reusable {@link isCamel} function.
526
+ *
527
+ * @danger You must configure the generic argument `T`
528
+ * @returns Nothing until be configure the generic argument `T`
529
+ * @throws compile error
530
+ *
531
+ * @author Jeongho Nam - https://github.com/samchon
532
+ */
533
+ export function createIsCamel(): never;
534
+
535
+ /**
536
+ * Creates a reusable {@link isCamel} function.
537
+ *
538
+ * @template T Type of the input value
539
+ * @returns A reusable `isCamel` function
540
+ *
541
+ * @author Jeongho Nam - https://github.com/samchon
542
+ */
543
+ export function createIsCamel<T>(): (input: T) => CamelCase<T> | null;
544
+
545
+ /**
546
+ * @internal
547
+ */
548
+ export function createIsCamel(): never {
549
+ NoTransformConfigurationError("notations.createIsCamel");
550
+ }
551
+
552
+ /**
553
+ * Creates a reusable {@link validateCamel} function.
554
+ *
555
+ * @danger You must configure the generic argument `T`
556
+ * @returns Nothing until be configure the generic argument `T`
557
+ * @throws compile error
558
+ *
559
+ * @author Jeongho Nam - https://github.com/samchon
560
+ */
561
+ export function createValidateCamel(): never;
562
+
563
+ /**
564
+ * Creates a reusable {@link validateCamel} function.
565
+ *
566
+ * @template T Type of the input value
567
+ * @returns A reusable `validateCamel` function
568
+ *
569
+ * @author Jeongho Nam - https://github.com/samchon
570
+ */
571
+ export function createValidateCamel<T>(): (
572
+ input: T,
573
+ ) => IValidation<CamelCase<T>>;
574
+
575
+ /**
576
+ * @internal
577
+ */
578
+ export function createValidateCamel(): never {
579
+ NoTransformConfigurationError("notations.createValidateCamel");
580
+ }
581
+
582
+ /**
583
+ * Creates a reusable {@link pascal} function.
584
+ *
585
+ * @danger You must configure the generic argument `T`
586
+ * @returns Nothing until be configure the generic argument `T`
587
+ * @throws compile error
588
+ *
589
+ * @author Jeongho Nam - https://github.com/samchon
590
+ */
591
+ export function createPascal(): never;
592
+
593
+ /**
594
+ * Creates a reusable {@link pascal} function.
595
+ *
596
+ * @template T Type of the input value
597
+ * @returns A reusable `pascal` function
598
+ *
599
+ * @author Jeongho Nam - https://github.com/samchon
600
+ */
601
+ export function createPascal<T>(): (input: T) => PascalCase<T>;
602
+
603
+ /**
604
+ * @internal
605
+ */
606
+ export function createPascal(): never {
607
+ NoTransformConfigurationError("notations.createPascal");
608
+ }
609
+
610
+ /**
611
+ * Creates a reusable {@link assertPascal} function.
612
+ *
613
+ * @danger You must configure the generic argument `T`
614
+ * @param errorFactory Custom error factory. Default is `TypeGuardError`
615
+ * @returns Nothing until be configure the generic argument `T`
616
+ * @throws compile error
617
+ *
618
+ * @author Jeongho Nam - https://github.com/samchon
619
+ */
620
+ export function createAssertPascal(
621
+ errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
622
+ ): never;
623
+
624
+ /**
625
+ * Creates a reusable {@link assertPascal} function.
626
+ *
627
+ * @template T Type of the input value
628
+ * @param errorFactory Custom error factory. Default is `TypeGuardError`
629
+ * @returns A reusable `assertPascal` function
630
+ *
631
+ * @author Jeongho Nam - https://github.com/samchon
632
+ */
633
+ export function createAssertPascal<T>(
634
+ errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
635
+ ): (input: T) => PascalCase<T>;
636
+
637
+ /**
638
+ * @internal
639
+ */
640
+ export function createAssertPascal(): never {
641
+ NoTransformConfigurationError("notations.createAssertPascal");
642
+ }
643
+
644
+ /**
645
+ * Creates a reusable {@link isPascal} function.
646
+ *
647
+ * @danger You must configure the generic argument `T`
648
+ * @returns Nothing until be configure the generic argument `T`
649
+ * @throws compile error
650
+ *
651
+ * @author Jeongho Nam - https://github.com/samchon
652
+ */
653
+ export function createIsPascal(): never;
654
+
655
+ /**
656
+ * Creates a reusable {@link isPascal} function.
657
+ *
658
+ * @template T Type of the input value
659
+ * @returns A reusable `isPascal` function
660
+ *
661
+ * @author Jeongho Nam - https://github.com/samchon
662
+ */
663
+ export function createIsPascal<T>(): (input: T) => PascalCase<T> | null;
664
+
665
+ /**
666
+ * @internal
667
+ */
668
+ export function createIsPascal(): never {
669
+ NoTransformConfigurationError("notations.createIsPascal");
670
+ }
671
+
672
+ /**
673
+ * Creates a reusable {@link validatePascal} function.
674
+ *
675
+ * @danger You must configure the generic argument `T`
676
+ * @returns Nothing until be configure the generic argument `T`
677
+ * @throws compile error
678
+ *
679
+ * @author Jeongho Nam - https://github.com/samchon
680
+ */
681
+ export function createValidatePascal(): never;
682
+
683
+ /**
684
+ * Creates a reusable {@link validatePascal} function.
685
+ *
686
+ * @template T Type of the input value
687
+ * @returns A reusable `validatePascal` function
688
+ *
689
+ * @author Jeongho Nam - https://github.com/samchon
690
+ */
691
+ export function createValidatePascal<T>(): (
692
+ input: T,
693
+ ) => IValidation<PascalCase<T>>;
694
+
695
+ /**
696
+ * @internal
697
+ */
698
+ export function createValidatePascal(): never {
699
+ NoTransformConfigurationError("notations.createValidatePascal");
700
+ }
701
+
702
+ /**
703
+ * Creates a reusable {@link snake} function.
704
+ *
705
+ * @danger You must configure the generic argument `T`
706
+ * @returns Nothing until be configure the generic argument `T`
707
+ * @throws compile error
708
+ *
709
+ * @author Jeongho Nam - https://github.com/samchon
710
+ */
711
+ export function createSnake(): never;
712
+
713
+ /**
714
+ * Creates a reusable {@link snake} function.
715
+ *
716
+ * @template T Type of the input value
717
+ * @returns A reusable `snake` function
718
+ *
719
+ * @author Jeongho Nam - https://github.com/samchon
720
+ */
721
+ export function createSnake<T>(): (input: T) => SnakeCase<T>;
722
+
723
+ /**
724
+ * @internal
725
+ */
726
+ export function createSnake(): never {
727
+ NoTransformConfigurationError("notations.createSnake");
728
+ }
729
+
730
+ /**
731
+ * Creates a reusable {@link assertSnake} function.
732
+ *
733
+ * @danger You must configure the generic argument `T`
734
+ * @param errorFactory Custom error factory. Default is `TypeGuardError`
735
+ * @returns Nothing until be configure the generic argument `T`
736
+ * @throws compile error
737
+ *
738
+ * @author Jeongho Nam - https://github.com/samchon
739
+ */
740
+ export function createAssertSnake(
741
+ errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
742
+ ): never;
743
+
744
+ /**
745
+ * Creates a reusable {@link assertSnake} function.
746
+ *
747
+ * @template T Type of the input value
748
+ * @param errorFactory Custom error factory. Default is `TypeGuardError`
749
+ * @returns A reusable `assertSnake` function
750
+ *
751
+ * @author Jeongho Nam - https://github.com/samchon
752
+ */
753
+ export function createAssertSnake<T>(
754
+ errorFactory?: undefined | ((props: TypeGuardError.IProps) => Error),
755
+ ): (input: T) => SnakeCase<T>;
756
+
757
+ /**
758
+ * @internal
759
+ */
760
+ export function createAssertSnake(): never {
761
+ NoTransformConfigurationError("notations.createAssertSnake");
762
+ }
763
+
764
+ /**
765
+ * Creates a reusable {@link isSnake} function.
766
+ *
767
+ * @danger You must configure the generic argument `T`
768
+ * @returns Nothing until be configure the generic argument `T`
769
+ * @throws compile error
770
+ *
771
+ * @author Jeongho Nam - https://github.com/samchon
772
+ */
773
+ export function createIsSnake(): never;
774
+
775
+ /**
776
+ * Creates a reusable {@link isSnake} function.
777
+ *
778
+ * @template T Type of the input value
779
+ * @returns A reusable `isSnake` function
780
+ *
781
+ * @author Jeongho Nam - https://github.com/samchon
782
+ */
783
+ export function createIsSnake<T>(): (input: T) => SnakeCase<T> | null;
784
+
785
+ /**
786
+ * @internal
787
+ */
788
+ export function createIsSnake(): never {
789
+ NoTransformConfigurationError("notations.createIsSnake");
790
+ }
791
+
792
+ /**
793
+ * Creates a reusable {@link validateSnake} function.
794
+ *
795
+ * @danger You must configure the generic argument `T`
796
+ * @returns Nothing until be configure the generic argument `T`
797
+ * @throws compile error
798
+ *
799
+ * @author Jeongho Nam - https://github.com/samchon
800
+ */
801
+ export function createValidateSnake(): never;
802
+
803
+ /**
804
+ * Creates a reusable {@link validateSnake} function.
805
+ *
806
+ * @template T Type of the input value
807
+ * @returns A reusable `validateSnake` function
808
+ *
809
+ * @author Jeongho Nam - https://github.com/samchon
810
+ */
811
+ export function createValidateSnake<T>(): (
812
+ input: T,
813
+ ) => IValidation<SnakeCase<T>>;
814
+
815
+ /**
816
+ * @internal
817
+ */
818
+ export function createValidateSnake(): never {
819
+ NoTransformConfigurationError("notations.createValidateSnake");
820
+ }