typia 9.7.1 → 9.7.2

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 (411) hide show
  1. package/lib/AssertionGuard.d.mts +27 -25
  2. package/lib/AssertionGuard.d.ts +27 -25
  3. package/lib/CamelCase.d.mts +1 -1
  4. package/lib/CamelCase.d.ts +1 -1
  5. package/lib/IRandomGenerator.d.mts +44 -42
  6. package/lib/IRandomGenerator.d.ts +44 -42
  7. package/lib/IReadableURLSearchParams.d.mts +2 -2
  8. package/lib/IReadableURLSearchParams.d.ts +2 -2
  9. package/lib/PascalCase.d.mts +1 -1
  10. package/lib/PascalCase.d.ts +1 -1
  11. package/lib/Primitive.d.mts +20 -22
  12. package/lib/Primitive.d.ts +20 -22
  13. package/lib/Resolved.d.mts +16 -18
  14. package/lib/Resolved.d.ts +16 -18
  15. package/lib/SnakeCase.d.mts +3 -2
  16. package/lib/SnakeCase.d.ts +3 -2
  17. package/lib/TypeGuardError.d.mts +88 -61
  18. package/lib/TypeGuardError.d.ts +88 -61
  19. package/lib/TypeGuardError.js +40 -29
  20. package/lib/TypeGuardError.js.map +1 -1
  21. package/lib/TypeGuardError.mjs +70 -48
  22. package/lib/factories/MetadataCollection.js +4 -12
  23. package/lib/factories/MetadataCollection.js.map +1 -1
  24. package/lib/factories/MetadataCollection.mjs +4 -12
  25. package/lib/factories/MetadataCommentTagFactory.js +5 -15
  26. package/lib/factories/MetadataCommentTagFactory.js.map +1 -1
  27. package/lib/factories/MetadataCommentTagFactory.mjs +5 -15
  28. package/lib/factories/MetadataFactory.js +1 -3
  29. package/lib/factories/MetadataFactory.js.map +1 -1
  30. package/lib/factories/MetadataFactory.mjs +1 -3
  31. package/lib/factories/ProtobufFactory.js +1 -3
  32. package/lib/factories/ProtobufFactory.js.map +1 -1
  33. package/lib/factories/ProtobufFactory.mjs +1 -3
  34. package/lib/functional.d.mts +196 -195
  35. package/lib/functional.d.ts +196 -195
  36. package/lib/functional.js +18 -54
  37. package/lib/functional.js.map +1 -1
  38. package/lib/functional.mjs +18 -54
  39. package/lib/http.d.mts +303 -319
  40. package/lib/http.d.ts +303 -319
  41. package/lib/http.js +26 -78
  42. package/lib/http.js.map +1 -1
  43. package/lib/http.mjs +26 -78
  44. package/lib/internal/_ProtobufReader.d.mts +3 -9
  45. package/lib/internal/_ProtobufReader.d.ts +3 -9
  46. package/lib/internal/_ProtobufReader.js.map +1 -1
  47. package/lib/internal/_ProtobufReader.mjs +3 -9
  48. package/lib/internal/_ProtobufSizer.d.mts +4 -12
  49. package/lib/internal/_ProtobufSizer.d.ts +4 -12
  50. package/lib/internal/_ProtobufSizer.js.map +1 -1
  51. package/lib/internal/_ProtobufSizer.mjs +4 -12
  52. package/lib/internal/_ProtobufWriter.d.mts +5 -15
  53. package/lib/internal/_ProtobufWriter.d.ts +5 -15
  54. package/lib/internal/_ProtobufWriter.js.map +1 -1
  55. package/lib/internal/_ProtobufWriter.mjs +5 -15
  56. package/lib/internal/_jsonStringifyString.d.mts +4 -4
  57. package/lib/internal/_jsonStringifyString.d.ts +4 -4
  58. package/lib/internal/_jsonStringifyString.js +4 -4
  59. package/lib/internal/_jsonStringifyString.mjs +4 -4
  60. package/lib/json.d.mts +174 -195
  61. package/lib/json.d.ts +174 -195
  62. package/lib/json.js +16 -48
  63. package/lib/json.js.map +1 -1
  64. package/lib/json.mjs +16 -48
  65. package/lib/llm.d.mts +275 -192
  66. package/lib/llm.d.ts +275 -192
  67. package/lib/llm.js +4 -12
  68. package/lib/llm.js.map +1 -1
  69. package/lib/llm.mjs +4 -12
  70. package/lib/misc.d.mts +149 -172
  71. package/lib/misc.d.ts +149 -172
  72. package/lib/misc.js +17 -51
  73. package/lib/misc.js.map +1 -1
  74. package/lib/misc.mjs +17 -51
  75. package/lib/module.d.mts +263 -275
  76. package/lib/module.d.ts +263 -275
  77. package/lib/module.js +18 -54
  78. package/lib/module.js.map +1 -1
  79. package/lib/module.mjs +18 -54
  80. package/lib/notations.d.mts +153 -174
  81. package/lib/notations.d.ts +153 -174
  82. package/lib/notations.js +24 -72
  83. package/lib/notations.js.map +1 -1
  84. package/lib/notations.mjs +24 -72
  85. package/lib/programmers/FeatureProgrammer.d.mts +19 -41
  86. package/lib/programmers/FeatureProgrammer.d.ts +19 -41
  87. package/lib/programmers/FeatureProgrammer.js.map +1 -1
  88. package/lib/programmers/ImportProgrammer.js +3 -9
  89. package/lib/programmers/ImportProgrammer.js.map +1 -1
  90. package/lib/programmers/ImportProgrammer.mjs +3 -9
  91. package/lib/programmers/RandomProgrammer.js +6 -0
  92. package/lib/programmers/RandomProgrammer.js.map +1 -1
  93. package/lib/programmers/RandomProgrammer.mjs +6 -0
  94. package/lib/programmers/helpers/ProtobufWire.d.mts +13 -13
  95. package/lib/programmers/helpers/ProtobufWire.d.ts +13 -13
  96. package/lib/programmers/internal/check_array_length.js +2 -6
  97. package/lib/programmers/internal/check_array_length.js.map +1 -1
  98. package/lib/programmers/internal/check_array_length.mjs +2 -6
  99. package/lib/programmers/internal/check_bigint.js +2 -6
  100. package/lib/programmers/internal/check_bigint.js.map +1 -1
  101. package/lib/programmers/internal/check_bigint.mjs +2 -6
  102. package/lib/programmers/internal/check_dynamic_key.js +2 -6
  103. package/lib/programmers/internal/check_dynamic_key.js.map +1 -1
  104. package/lib/programmers/internal/check_dynamic_key.mjs +2 -6
  105. package/lib/programmers/internal/check_dynamic_properties.js +3 -9
  106. package/lib/programmers/internal/check_dynamic_properties.js.map +1 -1
  107. package/lib/programmers/internal/check_dynamic_properties.mjs +3 -9
  108. package/lib/programmers/internal/check_everything.js +1 -3
  109. package/lib/programmers/internal/check_everything.js.map +1 -1
  110. package/lib/programmers/internal/check_everything.mjs +1 -3
  111. package/lib/programmers/internal/check_native.js +2 -6
  112. package/lib/programmers/internal/check_native.js.map +1 -1
  113. package/lib/programmers/internal/check_native.mjs +2 -6
  114. package/lib/programmers/internal/check_number.js +2 -6
  115. package/lib/programmers/internal/check_number.js.map +1 -1
  116. package/lib/programmers/internal/check_number.mjs +2 -6
  117. package/lib/programmers/internal/check_object.js +2 -6
  118. package/lib/programmers/internal/check_object.js.map +1 -1
  119. package/lib/programmers/internal/check_object.mjs +2 -6
  120. package/lib/programmers/internal/check_string.js +2 -6
  121. package/lib/programmers/internal/check_string.js.map +1 -1
  122. package/lib/programmers/internal/check_string.mjs +2 -6
  123. package/lib/programmers/internal/check_template.js +1 -3
  124. package/lib/programmers/internal/check_template.js.map +1 -1
  125. package/lib/programmers/internal/check_template.mjs +1 -3
  126. package/lib/programmers/internal/check_union_array_like.js +1 -3
  127. package/lib/programmers/internal/check_union_array_like.js.map +1 -1
  128. package/lib/programmers/internal/check_union_array_like.mjs +1 -3
  129. package/lib/programmers/internal/decode_union_object.js +2 -6
  130. package/lib/programmers/internal/decode_union_object.js.map +1 -1
  131. package/lib/programmers/internal/decode_union_object.mjs +2 -6
  132. package/lib/programmers/internal/feature_object_entries.js +1 -3
  133. package/lib/programmers/internal/feature_object_entries.js.map +1 -1
  134. package/lib/programmers/internal/feature_object_entries.mjs +1 -3
  135. package/lib/programmers/internal/json_schema_escaped.js +2 -6
  136. package/lib/programmers/internal/json_schema_escaped.js.map +1 -1
  137. package/lib/programmers/internal/json_schema_escaped.mjs +2 -6
  138. package/lib/programmers/internal/json_schema_object.js +3 -9
  139. package/lib/programmers/internal/json_schema_object.js.map +1 -1
  140. package/lib/programmers/internal/json_schema_object.mjs +3 -9
  141. package/lib/programmers/internal/metadata_to_pattern.js +1 -3
  142. package/lib/programmers/internal/metadata_to_pattern.js.map +1 -1
  143. package/lib/programmers/internal/metadata_to_pattern.mjs +1 -3
  144. package/lib/programmers/internal/postfix_of_tuple.js +1 -3
  145. package/lib/programmers/internal/postfix_of_tuple.js.map +1 -1
  146. package/lib/programmers/internal/postfix_of_tuple.mjs +1 -3
  147. package/lib/programmers/internal/prune_object_properties.js +1 -3
  148. package/lib/programmers/internal/prune_object_properties.js.map +1 -1
  149. package/lib/programmers/internal/prune_object_properties.mjs +1 -3
  150. package/lib/programmers/internal/stringify_dynamic_properties.js +2 -6
  151. package/lib/programmers/internal/stringify_dynamic_properties.js.map +1 -1
  152. package/lib/programmers/internal/stringify_dynamic_properties.mjs +2 -6
  153. package/lib/programmers/internal/stringify_native.js +1 -3
  154. package/lib/programmers/internal/stringify_native.js.map +1 -1
  155. package/lib/programmers/internal/stringify_native.mjs +1 -3
  156. package/lib/programmers/internal/stringify_regular_properties.js +2 -6
  157. package/lib/programmers/internal/stringify_regular_properties.js.map +1 -1
  158. package/lib/programmers/internal/stringify_regular_properties.mjs +2 -6
  159. package/lib/programmers/internal/template_to_pattern.js +1 -3
  160. package/lib/programmers/internal/template_to_pattern.js.map +1 -1
  161. package/lib/programmers/internal/template_to_pattern.mjs +1 -3
  162. package/lib/programmers/internal/wrap_metadata_rest_tuple.js +1 -3
  163. package/lib/programmers/internal/wrap_metadata_rest_tuple.js.map +1 -1
  164. package/lib/programmers/internal/wrap_metadata_rest_tuple.mjs +1 -3
  165. package/lib/programmers/json/JsonStringifyProgrammer.js +2 -2
  166. package/lib/programmers/json/JsonStringifyProgrammer.js.map +1 -1
  167. package/lib/programmers/json/JsonStringifyProgrammer.mjs +2 -2
  168. package/lib/protobuf.d.mts +290 -297
  169. package/lib/protobuf.d.ts +290 -297
  170. package/lib/protobuf.js +17 -51
  171. package/lib/protobuf.js.map +1 -1
  172. package/lib/protobuf.mjs +17 -51
  173. package/lib/reflect.d.mts +2 -4
  174. package/lib/reflect.d.ts +2 -4
  175. package/lib/reflect.js +1 -3
  176. package/lib/reflect.js.map +1 -1
  177. package/lib/reflect.mjs +1 -3
  178. package/lib/schemas/json/IJsonApplication.d.mts +4 -4
  179. package/lib/schemas/json/IJsonApplication.d.ts +4 -4
  180. package/lib/schemas/json/IJsonSchemaCollection.d.mts +73 -56
  181. package/lib/schemas/json/IJsonSchemaCollection.d.ts +73 -56
  182. package/lib/schemas/json/IJsonSchemaUnit.d.mts +83 -70
  183. package/lib/schemas/json/IJsonSchemaUnit.d.ts +83 -70
  184. package/lib/schemas/metadata/Metadata.d.mts +1 -3
  185. package/lib/schemas/metadata/Metadata.d.ts +1 -3
  186. package/lib/schemas/metadata/Metadata.js +9 -27
  187. package/lib/schemas/metadata/Metadata.js.map +1 -1
  188. package/lib/schemas/metadata/Metadata.mjs +9 -27
  189. package/lib/schemas/metadata/MetadataAliasType.d.mts +1 -3
  190. package/lib/schemas/metadata/MetadataAliasType.d.ts +1 -3
  191. package/lib/schemas/metadata/MetadataAliasType.js +3 -9
  192. package/lib/schemas/metadata/MetadataAliasType.js.map +1 -1
  193. package/lib/schemas/metadata/MetadataAliasType.mjs +3 -9
  194. package/lib/schemas/metadata/MetadataApplication.d.mts +1 -3
  195. package/lib/schemas/metadata/MetadataApplication.d.ts +1 -3
  196. package/lib/schemas/metadata/MetadataApplication.js +2 -6
  197. package/lib/schemas/metadata/MetadataApplication.js.map +1 -1
  198. package/lib/schemas/metadata/MetadataApplication.mjs +2 -6
  199. package/lib/schemas/metadata/MetadataArray.d.mts +1 -3
  200. package/lib/schemas/metadata/MetadataArray.d.ts +1 -3
  201. package/lib/schemas/metadata/MetadataArray.js +1 -3
  202. package/lib/schemas/metadata/MetadataArray.js.map +1 -1
  203. package/lib/schemas/metadata/MetadataArray.mjs +1 -3
  204. package/lib/schemas/metadata/MetadataArrayType.d.mts +1 -3
  205. package/lib/schemas/metadata/MetadataArrayType.d.ts +1 -3
  206. package/lib/schemas/metadata/MetadataArrayType.js +3 -9
  207. package/lib/schemas/metadata/MetadataArrayType.js.map +1 -1
  208. package/lib/schemas/metadata/MetadataArrayType.mjs +3 -9
  209. package/lib/schemas/metadata/MetadataAtomic.js +1 -3
  210. package/lib/schemas/metadata/MetadataAtomic.js.map +1 -1
  211. package/lib/schemas/metadata/MetadataAtomic.mjs +1 -3
  212. package/lib/schemas/metadata/MetadataEscaped.d.mts +1 -3
  213. package/lib/schemas/metadata/MetadataEscaped.d.ts +1 -3
  214. package/lib/schemas/metadata/MetadataEscaped.js +3 -9
  215. package/lib/schemas/metadata/MetadataEscaped.js.map +1 -1
  216. package/lib/schemas/metadata/MetadataEscaped.mjs +3 -9
  217. package/lib/schemas/metadata/MetadataFunction.d.mts +1 -3
  218. package/lib/schemas/metadata/MetadataFunction.d.ts +1 -3
  219. package/lib/schemas/metadata/MetadataFunction.js +2 -6
  220. package/lib/schemas/metadata/MetadataFunction.js.map +1 -1
  221. package/lib/schemas/metadata/MetadataFunction.mjs +2 -6
  222. package/lib/schemas/metadata/MetadataObject.d.mts +1 -3
  223. package/lib/schemas/metadata/MetadataObject.d.ts +1 -3
  224. package/lib/schemas/metadata/MetadataObject.js +1 -3
  225. package/lib/schemas/metadata/MetadataObject.js.map +1 -1
  226. package/lib/schemas/metadata/MetadataObject.mjs +1 -3
  227. package/lib/schemas/metadata/MetadataObjectType.d.mts +1 -3
  228. package/lib/schemas/metadata/MetadataObjectType.d.ts +1 -3
  229. package/lib/schemas/metadata/MetadataObjectType.js +5 -15
  230. package/lib/schemas/metadata/MetadataObjectType.js.map +1 -1
  231. package/lib/schemas/metadata/MetadataObjectType.mjs +6 -18
  232. package/lib/schemas/metadata/MetadataParameter.js +1 -3
  233. package/lib/schemas/metadata/MetadataParameter.js.map +1 -1
  234. package/lib/schemas/metadata/MetadataParameter.mjs +1 -3
  235. package/lib/schemas/metadata/MetadataProperty.d.mts +1 -3
  236. package/lib/schemas/metadata/MetadataProperty.d.ts +1 -3
  237. package/lib/schemas/metadata/MetadataProperty.js +3 -9
  238. package/lib/schemas/metadata/MetadataProperty.js.map +1 -1
  239. package/lib/schemas/metadata/MetadataProperty.mjs +3 -9
  240. package/lib/schemas/metadata/MetadataTemplate.js +1 -3
  241. package/lib/schemas/metadata/MetadataTemplate.js.map +1 -1
  242. package/lib/schemas/metadata/MetadataTemplate.mjs +1 -3
  243. package/lib/schemas/metadata/MetadataTuple.d.mts +1 -3
  244. package/lib/schemas/metadata/MetadataTuple.d.ts +1 -3
  245. package/lib/schemas/metadata/MetadataTuple.js +2 -6
  246. package/lib/schemas/metadata/MetadataTuple.js.map +1 -1
  247. package/lib/schemas/metadata/MetadataTuple.mjs +2 -6
  248. package/lib/schemas/metadata/MetadataTupleType.js +2 -6
  249. package/lib/schemas/metadata/MetadataTupleType.js.map +1 -1
  250. package/lib/schemas/metadata/MetadataTupleType.mjs +3 -9
  251. package/lib/tags/Constant.d.mts +16 -16
  252. package/lib/tags/Constant.d.ts +16 -16
  253. package/lib/tags/ContentMediaType.d.mts +7 -7
  254. package/lib/tags/ContentMediaType.d.ts +7 -7
  255. package/lib/tags/Default.d.mts +19 -19
  256. package/lib/tags/Default.d.ts +19 -19
  257. package/lib/tags/Example.d.mts +18 -18
  258. package/lib/tags/Example.d.ts +18 -18
  259. package/lib/tags/Examples.d.mts +23 -23
  260. package/lib/tags/Examples.d.ts +23 -23
  261. package/lib/tags/ExclusiveMaximum.d.mts +8 -5
  262. package/lib/tags/ExclusiveMaximum.d.ts +8 -5
  263. package/lib/tags/ExclusiveMinimum.d.mts +8 -5
  264. package/lib/tags/ExclusiveMinimum.d.ts +8 -5
  265. package/lib/tags/Format.d.mts +12 -8
  266. package/lib/tags/Format.d.ts +12 -8
  267. package/lib/tags/JsonSchemaPlugin.d.mts +20 -18
  268. package/lib/tags/JsonSchemaPlugin.d.ts +20 -18
  269. package/lib/tags/MaxItems.d.mts +9 -9
  270. package/lib/tags/MaxItems.d.ts +9 -9
  271. package/lib/tags/MaxLength.d.mts +6 -5
  272. package/lib/tags/MaxLength.d.ts +6 -5
  273. package/lib/tags/Maximum.d.mts +9 -7
  274. package/lib/tags/Maximum.d.ts +9 -7
  275. package/lib/tags/MinItems.d.mts +9 -9
  276. package/lib/tags/MinItems.d.ts +9 -9
  277. package/lib/tags/MinLength.d.mts +6 -5
  278. package/lib/tags/MinLength.d.ts +6 -5
  279. package/lib/tags/Minimum.d.mts +9 -7
  280. package/lib/tags/Minimum.d.ts +9 -7
  281. package/lib/tags/MultipleOf.d.mts +10 -7
  282. package/lib/tags/MultipleOf.d.ts +10 -7
  283. package/lib/tags/Pattern.d.mts +7 -4
  284. package/lib/tags/Pattern.d.ts +7 -4
  285. package/lib/tags/Sequence.d.mts +19 -17
  286. package/lib/tags/Sequence.d.ts +19 -17
  287. package/lib/tags/TagBase.d.mts +21 -28
  288. package/lib/tags/TagBase.d.ts +21 -28
  289. package/lib/tags/Type.d.mts +12 -11
  290. package/lib/tags/Type.d.ts +12 -11
  291. package/lib/tags/UniqueItems.d.mts +10 -9
  292. package/lib/tags/UniqueItems.d.ts +10 -9
  293. package/lib/tags/internal/FormatCheatSheet.d.mts +1 -3
  294. package/lib/tags/internal/FormatCheatSheet.d.ts +1 -3
  295. package/lib/tags/internal/FormatCheatSheet.js +1 -3
  296. package/lib/tags/internal/FormatCheatSheet.js.map +1 -1
  297. package/lib/tags/internal/FormatCheatSheet.mjs +1 -3
  298. package/lib/transformers/ITransformOptions.d.mts +27 -19
  299. package/lib/transformers/ITransformOptions.d.ts +27 -19
  300. package/lib/transformers/ImportTransformer.js +5 -10
  301. package/lib/transformers/ImportTransformer.js.map +1 -1
  302. package/lib/transformers/ImportTransformer.mjs +5 -10
  303. package/lib/transformers/NoTransformConfigurationError.js +1 -3
  304. package/lib/transformers/NoTransformConfigurationError.js.map +1 -1
  305. package/lib/transformers/NoTransformConfigurationError.mjs +1 -3
  306. package/lib/transformers/features/llm/LlmApplicationTransformer.js +1 -3
  307. package/lib/transformers/features/llm/LlmApplicationTransformer.js.map +1 -1
  308. package/lib/transformers/features/llm/LlmApplicationTransformer.mjs +1 -3
  309. package/lib/typings/Equal.d.mts +6 -6
  310. package/lib/typings/Equal.d.ts +6 -6
  311. package/package.json +2 -1
  312. package/src/AssertionGuard.ts +27 -25
  313. package/src/CamelCase.ts +1 -1
  314. package/src/IRandomGenerator.ts +44 -42
  315. package/src/IReadableURLSearchParams.ts +2 -2
  316. package/src/PascalCase.ts +1 -1
  317. package/src/Primitive.ts +20 -22
  318. package/src/Resolved.ts +16 -18
  319. package/src/SnakeCase.ts +3 -2
  320. package/src/TypeGuardError.ts +101 -64
  321. package/src/factories/MetadataCollection.ts +4 -12
  322. package/src/factories/MetadataCommentTagFactory.ts +8 -24
  323. package/src/factories/MetadataFactory.ts +1 -3
  324. package/src/factories/ProtobufFactory.ts +1 -3
  325. package/src/functional.ts +214 -249
  326. package/src/http.ts +329 -397
  327. package/src/internal/_ProtobufReader.ts +3 -9
  328. package/src/internal/_ProtobufSizer.ts +4 -12
  329. package/src/internal/_ProtobufWriter.ts +5 -15
  330. package/src/internal/_jsonStringifyString.ts +4 -4
  331. package/src/json.ts +190 -243
  332. package/src/llm.ts +279 -204
  333. package/src/misc.ts +166 -223
  334. package/src/module.ts +281 -329
  335. package/src/notations.ts +177 -246
  336. package/src/programmers/FeatureProgrammer.ts +19 -41
  337. package/src/programmers/ImportProgrammer.ts +3 -9
  338. package/src/programmers/RandomProgrammer.ts +6 -1
  339. package/src/programmers/helpers/ProtobufWire.ts +13 -13
  340. package/src/programmers/internal/check_array_length.ts +2 -6
  341. package/src/programmers/internal/check_bigint.ts +2 -6
  342. package/src/programmers/internal/check_dynamic_key.ts +2 -6
  343. package/src/programmers/internal/check_dynamic_properties.ts +3 -9
  344. package/src/programmers/internal/check_everything.ts +1 -3
  345. package/src/programmers/internal/check_native.ts +2 -6
  346. package/src/programmers/internal/check_number.ts +2 -6
  347. package/src/programmers/internal/check_object.ts +3 -9
  348. package/src/programmers/internal/check_string.ts +2 -6
  349. package/src/programmers/internal/check_template.ts +1 -3
  350. package/src/programmers/internal/check_union_array_like.ts +2 -6
  351. package/src/programmers/internal/decode_union_object.ts +3 -9
  352. package/src/programmers/internal/feature_object_entries.ts +1 -3
  353. package/src/programmers/internal/json_schema_escaped.ts +2 -6
  354. package/src/programmers/internal/json_schema_object.ts +4 -12
  355. package/src/programmers/internal/metadata_to_pattern.ts +1 -3
  356. package/src/programmers/internal/postfix_of_tuple.ts +1 -3
  357. package/src/programmers/internal/prune_object_properties.ts +1 -3
  358. package/src/programmers/internal/stringify_dynamic_properties.ts +2 -6
  359. package/src/programmers/internal/stringify_native.ts +1 -3
  360. package/src/programmers/internal/stringify_regular_properties.ts +2 -6
  361. package/src/programmers/internal/template_to_pattern.ts +1 -3
  362. package/src/programmers/internal/wrap_metadata_rest_tuple.ts +1 -3
  363. package/src/programmers/json/JsonStringifyProgrammer.ts +2 -2
  364. package/src/protobuf.ts +307 -348
  365. package/src/reflect.ts +3 -7
  366. package/src/schemas/json/IJsonApplication.ts +4 -4
  367. package/src/schemas/json/IJsonSchemaCollection.ts +73 -56
  368. package/src/schemas/json/IJsonSchemaUnit.ts +83 -70
  369. package/src/schemas/metadata/IMetadataTypeTag.ts +1 -3
  370. package/src/schemas/metadata/Metadata.ts +9 -27
  371. package/src/schemas/metadata/MetadataAliasType.ts +3 -9
  372. package/src/schemas/metadata/MetadataApplication.ts +2 -6
  373. package/src/schemas/metadata/MetadataArray.ts +1 -3
  374. package/src/schemas/metadata/MetadataArrayType.ts +3 -9
  375. package/src/schemas/metadata/MetadataAtomic.ts +1 -3
  376. package/src/schemas/metadata/MetadataEscaped.ts +3 -9
  377. package/src/schemas/metadata/MetadataFunction.ts +2 -6
  378. package/src/schemas/metadata/MetadataObject.ts +1 -3
  379. package/src/schemas/metadata/MetadataObjectType.ts +6 -18
  380. package/src/schemas/metadata/MetadataParameter.ts +1 -3
  381. package/src/schemas/metadata/MetadataProperty.ts +3 -9
  382. package/src/schemas/metadata/MetadataTemplate.ts +1 -3
  383. package/src/schemas/metadata/MetadataTuple.ts +2 -6
  384. package/src/schemas/metadata/MetadataTupleType.ts +3 -9
  385. package/src/tags/Constant.ts +16 -16
  386. package/src/tags/ContentMediaType.ts +7 -7
  387. package/src/tags/Default.ts +19 -19
  388. package/src/tags/Example.ts +18 -18
  389. package/src/tags/Examples.ts +23 -23
  390. package/src/tags/ExclusiveMaximum.ts +8 -5
  391. package/src/tags/ExclusiveMinimum.ts +8 -5
  392. package/src/tags/Format.ts +12 -8
  393. package/src/tags/JsonSchemaPlugin.ts +20 -18
  394. package/src/tags/MaxItems.ts +9 -9
  395. package/src/tags/MaxLength.ts +6 -5
  396. package/src/tags/Maximum.ts +9 -7
  397. package/src/tags/MinItems.ts +9 -9
  398. package/src/tags/MinLength.ts +6 -5
  399. package/src/tags/Minimum.ts +9 -7
  400. package/src/tags/MultipleOf.ts +10 -7
  401. package/src/tags/Pattern.ts +7 -4
  402. package/src/tags/Sequence.ts +19 -17
  403. package/src/tags/TagBase.ts +21 -28
  404. package/src/tags/Type.ts +12 -11
  405. package/src/tags/UniqueItems.ts +10 -9
  406. package/src/tags/internal/FormatCheatSheet.ts +1 -3
  407. package/src/transformers/ITransformOptions.ts +27 -19
  408. package/src/transformers/ImportTransformer.ts +5 -10
  409. package/src/transformers/NoTransformConfigurationError.ts +1 -3
  410. package/src/transformers/features/llm/LlmApplicationTransformer.ts +1 -3
  411. package/src/typings/Equal.ts +6 -6
@@ -1,39 +1,41 @@
1
1
  /**
2
2
  * Type definition for assertion guard functions in `typia`.
3
3
  *
4
- * An assertion guard is a function that asserts an input value's type at runtime
5
- * and performs a TypeScript type assertion if validation passes. Unlike regular
6
- * assertion functions that return the validated value, assertion guards return
7
- * nothing but automatically cast the input parameter to the expected type `T`.
4
+ * An assertion guard is a function that asserts an input value's type at
5
+ * runtime and performs a TypeScript type assertion if validation passes. Unlike
6
+ * regular assertion functions that return the validated value, assertion guards
7
+ * return nothing but automatically cast the input parameter to the expected
8
+ * type `T`.
8
9
  *
9
- * This type is used by `typia.createAssertGuard<T>()` and `typia.createAssertGuardEquals<T>()`
10
- * to generate reusable assertion guard functions.
11
- *
12
- * @template T - The expected type to validate and assert against
13
- * @param input - The value to validate (type unknown)
14
- * @throws {TypeGuardError} When the input value doesn't match the expected type T
15
- * @returns void - Returns nothing, but asserts that input is type T
10
+ * This type is used by `typia.createAssertGuard<T>()` and
11
+ * `typia.createAssertGuardEquals<T>()` to generate reusable assertion guard
12
+ * functions.
16
13
  *
14
+ * @author Jeongho Nam - https://github.com/samchon
17
15
  * @example
18
- * ```typescript
19
- * interface IMember {
20
- * name: string;
21
- * age: number;
22
- * }
16
+ * ```typescript
17
+ * interface IMember {
18
+ * name: string;
19
+ * age: number;
20
+ * }
23
21
  *
24
- * // Create reusable assertion guard
25
- * const assertMember: AssertionGuard<IMember> = typia.createAssertGuard<IMember>();
22
+ * // Create reusable assertion guard
23
+ * const assertMember: AssertionGuard<IMember> = typia.createAssertGuard<IMember>();
26
24
  *
27
- * // Usage - input will be automatically cast to IMember if validation passes
28
- * const unknownData: unknown = { name: "John", age: 25 };
25
+ * // Usage - input will be automatically cast to IMember if validation passes
26
+ * const unknownData: unknown = { name: "John", age: 25 };
29
27
  *
30
- * assertMember(unknownData);
31
- * // After this line, unknownData is automatically treated as IMember type
32
- * console.log(unknownData.name); // TypeScript knows this is safe
33
- * ```
28
+ * assertMember(unknownData);
29
+ * // After this line, unknownData is automatically treated as IMember type
30
+ * console.log(unknownData.name); // TypeScript knows this is safe
31
+ * ```;
34
32
  *
33
+ * @template T - The expected type to validate and assert against
34
+ * @param input - The value to validate (type unknown)
35
+ * @returns Void - Returns nothing, but asserts that input is type T
36
+ * @throws {TypeGuardError} When the input value doesn't match the expected type
37
+ * T
35
38
  * @see {@link https://github.com/samchon/typia#assertguard-functions} Typia assertion guards documentation
36
39
  * @see {@link TypeGuardError} Error thrown when assertion fails
37
- * @author Jeongho Nam - https://github.com/samchon
38
40
  */
39
41
  export type AssertionGuard<T> = (input: unknown) => asserts input is T;
@@ -1,39 +1,41 @@
1
1
  /**
2
2
  * Type definition for assertion guard functions in `typia`.
3
3
  *
4
- * An assertion guard is a function that asserts an input value's type at runtime
5
- * and performs a TypeScript type assertion if validation passes. Unlike regular
6
- * assertion functions that return the validated value, assertion guards return
7
- * nothing but automatically cast the input parameter to the expected type `T`.
4
+ * An assertion guard is a function that asserts an input value's type at
5
+ * runtime and performs a TypeScript type assertion if validation passes. Unlike
6
+ * regular assertion functions that return the validated value, assertion guards
7
+ * return nothing but automatically cast the input parameter to the expected
8
+ * type `T`.
8
9
  *
9
- * This type is used by `typia.createAssertGuard<T>()` and `typia.createAssertGuardEquals<T>()`
10
- * to generate reusable assertion guard functions.
11
- *
12
- * @template T - The expected type to validate and assert against
13
- * @param input - The value to validate (type unknown)
14
- * @throws {TypeGuardError} When the input value doesn't match the expected type T
15
- * @returns void - Returns nothing, but asserts that input is type T
10
+ * This type is used by `typia.createAssertGuard<T>()` and
11
+ * `typia.createAssertGuardEquals<T>()` to generate reusable assertion guard
12
+ * functions.
16
13
  *
14
+ * @author Jeongho Nam - https://github.com/samchon
17
15
  * @example
18
- * ```typescript
19
- * interface IMember {
20
- * name: string;
21
- * age: number;
22
- * }
16
+ * ```typescript
17
+ * interface IMember {
18
+ * name: string;
19
+ * age: number;
20
+ * }
23
21
  *
24
- * // Create reusable assertion guard
25
- * const assertMember: AssertionGuard<IMember> = typia.createAssertGuard<IMember>();
22
+ * // Create reusable assertion guard
23
+ * const assertMember: AssertionGuard<IMember> = typia.createAssertGuard<IMember>();
26
24
  *
27
- * // Usage - input will be automatically cast to IMember if validation passes
28
- * const unknownData: unknown = { name: "John", age: 25 };
25
+ * // Usage - input will be automatically cast to IMember if validation passes
26
+ * const unknownData: unknown = { name: "John", age: 25 };
29
27
  *
30
- * assertMember(unknownData);
31
- * // After this line, unknownData is automatically treated as IMember type
32
- * console.log(unknownData.name); // TypeScript knows this is safe
33
- * ```
28
+ * assertMember(unknownData);
29
+ * // After this line, unknownData is automatically treated as IMember type
30
+ * console.log(unknownData.name); // TypeScript knows this is safe
31
+ * ```;
34
32
  *
33
+ * @template T - The expected type to validate and assert against
34
+ * @param input - The value to validate (type unknown)
35
+ * @returns Void - Returns nothing, but asserts that input is type T
36
+ * @throws {TypeGuardError} When the input value doesn't match the expected type
37
+ * T
35
38
  * @see {@link https://github.com/samchon/typia#assertguard-functions} Typia assertion guards documentation
36
39
  * @see {@link TypeGuardError} Error thrown when assertion fails
37
- * @author Jeongho Nam - https://github.com/samchon
38
40
  */
39
41
  export type AssertionGuard<T> = (input: unknown) => asserts input is T;
@@ -9,8 +9,8 @@ import { ValueOf } from "./typings/ValueOf";
9
9
  *
10
10
  * It also erases every method property like {@link Resolved} type.
11
11
  *
12
- * @template T Target type to be camelized
13
12
  * @author Jeongho Nam - https://github.com/samchon
13
+ * @template T Target type to be camelized
14
14
  */
15
15
  export type CamelCase<T> = Equal<T, CamelizeMain<T>> extends true ? T : CamelizeMain<T>;
16
16
  type CamelizeMain<T> = T extends [never] ? never : T extends {
@@ -9,8 +9,8 @@ import { ValueOf } from "./typings/ValueOf";
9
9
  *
10
10
  * It also erases every method property like {@link Resolved} type.
11
11
  *
12
- * @template T Target type to be camelized
13
12
  * @author Jeongho Nam - https://github.com/samchon
13
+ * @template T Target type to be camelized
14
14
  */
15
15
  export type CamelCase<T> = Equal<T, CamelizeMain<T>> extends true ? T : CamelizeMain<T>;
16
16
  type CamelizeMain<T> = T extends [never] ? never : T extends {
@@ -2,28 +2,28 @@ import { OpenApi } from "@samchon/openapi";
2
2
  /**
3
3
  * Interface for generating random values for various data types.
4
4
  *
5
- * `IRandomGenerator` defines the contract for generating random values
6
- * that can be used by typia for creating mock data, testing scenarios,
7
- * and random value generation based on JSON schema constraints.
5
+ * `IRandomGenerator` defines the contract for generating random values that can
6
+ * be used by typia for creating mock data, testing scenarios, and random value
7
+ * generation based on JSON schema constraints.
8
8
  *
9
9
  * This interface supports generating random values for:
10
+ *
10
11
  * - Basic types (boolean, number, integer, bigint, string, array)
11
12
  * - String format patterns (email, URL, UUID, etc.)
12
13
  * - Date and time formats
13
14
  * - Various address and identifier formats
14
15
  *
15
- * @example
16
- * ```typescript
17
- * const generator: IRandomGenerator = {
18
- * boolean: () => Math.random() > 0.5,
19
- * number: (schema) => Math.random() * (schema.maximum ?? 100),
20
- * string: (schema) => "example-string",
21
- * email: () => "test@example.com",
22
- * // ... implement other methods
23
- * };
24
- * ```
25
- *
26
16
  * @author Jeongho Nam - https://github.com/samchon
17
+ * @example
18
+ * ```typescript
19
+ * const generator: IRandomGenerator = {
20
+ * boolean: () => Math.random() > 0.5,
21
+ * number: (schema) => Math.random() * (schema.maximum ?? 100),
22
+ * string: (schema) => "example-string",
23
+ * email: () => "test@example.com",
24
+ * // ... implement other methods
25
+ * };
26
+ * ```;
27
27
  */
28
28
  export interface IRandomGenerator {
29
29
  /**
@@ -56,12 +56,14 @@ export interface IRandomGenerator {
56
56
  /**
57
57
  * Generates a random string based on JSON schema constraints.
58
58
  *
59
- * @param schema JSON schema with string constraints (minLength, maxLength, pattern, etc.)
59
+ * @param schema JSON schema with string constraints (minLength, maxLength,
60
+ * pattern, etc.)
60
61
  * @returns Random string matching the specified constraints
61
62
  */
62
63
  string(schema: OpenApi.IJsonSchema.IString): string;
63
64
  /**
64
- * Generates a random array with elements created by the provided generator function.
65
+ * Generates a random array with elements created by the provided generator
66
+ * function.
65
67
  *
66
68
  * @param schema Array schema with element generator function
67
69
  * @returns Random array with generated elements
@@ -221,37 +223,37 @@ export declare namespace IRandomGenerator {
221
223
  /**
222
224
  * Map of custom generators for different data types.
223
225
  *
224
- * This interface allows customization of random generation for specific
225
- * types when they have certain schema properties or constraints.
226
+ * This interface allows customization of random generation for specific types
227
+ * when they have certain schema properties or constraints.
226
228
  *
227
229
  * @example
228
- * ```typescript
229
- * const generator: Partial<IRandomGenerator> = {
230
- * string: (schema) => {
231
- * if ((schema as any)["x-typia-monetary"] === "dollar") {
232
- * return "$" + Math.floor(Math.random() * 1000);
233
- * }
234
- * return "default-string";
235
- * },
236
- * number: (schema) => {
237
- * if ((schema as any)["x-typia-powerOf"] !== undefined) {
238
- * const powerOf = (schema as any)["x-typia-powerOf"];
239
- * return Math.pow(powerOf, Math.random() * 10 + 1);
230
+ * ```typescript
231
+ * const generator: Partial<IRandomGenerator> = {
232
+ * string: (schema) => {
233
+ * if ((schema as any)["x-typia-monetary"] === "dollar") {
234
+ * return "$" + Math.floor(Math.random() * 1000);
235
+ * }
236
+ * return "default-string";
237
+ * },
238
+ * number: (schema) => {
239
+ * if ((schema as any)["x-typia-powerOf"] !== undefined) {
240
+ * const powerOf = (schema as any)["x-typia-powerOf"];
241
+ * return Math.pow(powerOf, Math.random() * 10 + 1);
242
+ * }
243
+ * return Math.random() * 100;
240
244
  * }
241
- * return Math.random() * 100;
242
- * }
243
- * };
244
- * ```
245
+ * };
246
+ * ```;
245
247
  */
246
248
  interface CustomMap {
247
249
  /**
248
- * Custom string generator that can handle special string formats
249
- * based on schema properties.
250
+ * Custom string generator that can handle special string formats based on
251
+ * schema properties.
250
252
  */
251
253
  string?: (schema: OpenApi.IJsonSchema.IString & Record<string, any>) => string;
252
254
  /**
253
- * Custom number generator that can handle special number constraints
254
- * based on schema properties.
255
+ * Custom number generator that can handle special number constraints based
256
+ * on schema properties.
255
257
  */
256
258
  number?: (schema: OpenApi.IJsonSchema.INumber & Record<string, any>) => number;
257
259
  /**
@@ -260,8 +262,8 @@ export declare namespace IRandomGenerator {
260
262
  */
261
263
  integer?: (schema: OpenApi.IJsonSchema.IInteger & Record<string, any>) => number;
262
264
  /**
263
- * Custom bigint generator that can handle special bigint constraints
264
- * based on schema properties.
265
+ * Custom bigint generator that can handle special bigint constraints based
266
+ * on schema properties.
265
267
  */
266
268
  bigint?: (schema: OpenApi.IJsonSchema.IInteger & Record<string, any>) => bigint;
267
269
  /**
@@ -270,8 +272,8 @@ export declare namespace IRandomGenerator {
270
272
  */
271
273
  boolean?: (schema: Record<string, any>) => boolean | undefined;
272
274
  /**
273
- * Custom array generator that can handle special array constraints
274
- * based on schema properties.
275
+ * Custom array generator that can handle special array constraints based on
276
+ * schema properties.
275
277
  */
276
278
  array?: <T>(schema: Omit<OpenApi.IJsonSchema.IArray, "items"> & {
277
279
  element: (index: number, count: number) => T;
@@ -2,28 +2,28 @@ import { OpenApi } from "@samchon/openapi";
2
2
  /**
3
3
  * Interface for generating random values for various data types.
4
4
  *
5
- * `IRandomGenerator` defines the contract for generating random values
6
- * that can be used by typia for creating mock data, testing scenarios,
7
- * and random value generation based on JSON schema constraints.
5
+ * `IRandomGenerator` defines the contract for generating random values that can
6
+ * be used by typia for creating mock data, testing scenarios, and random value
7
+ * generation based on JSON schema constraints.
8
8
  *
9
9
  * This interface supports generating random values for:
10
+ *
10
11
  * - Basic types (boolean, number, integer, bigint, string, array)
11
12
  * - String format patterns (email, URL, UUID, etc.)
12
13
  * - Date and time formats
13
14
  * - Various address and identifier formats
14
15
  *
15
- * @example
16
- * ```typescript
17
- * const generator: IRandomGenerator = {
18
- * boolean: () => Math.random() > 0.5,
19
- * number: (schema) => Math.random() * (schema.maximum ?? 100),
20
- * string: (schema) => "example-string",
21
- * email: () => "test@example.com",
22
- * // ... implement other methods
23
- * };
24
- * ```
25
- *
26
16
  * @author Jeongho Nam - https://github.com/samchon
17
+ * @example
18
+ * ```typescript
19
+ * const generator: IRandomGenerator = {
20
+ * boolean: () => Math.random() > 0.5,
21
+ * number: (schema) => Math.random() * (schema.maximum ?? 100),
22
+ * string: (schema) => "example-string",
23
+ * email: () => "test@example.com",
24
+ * // ... implement other methods
25
+ * };
26
+ * ```;
27
27
  */
28
28
  export interface IRandomGenerator {
29
29
  /**
@@ -56,12 +56,14 @@ export interface IRandomGenerator {
56
56
  /**
57
57
  * Generates a random string based on JSON schema constraints.
58
58
  *
59
- * @param schema JSON schema with string constraints (minLength, maxLength, pattern, etc.)
59
+ * @param schema JSON schema with string constraints (minLength, maxLength,
60
+ * pattern, etc.)
60
61
  * @returns Random string matching the specified constraints
61
62
  */
62
63
  string(schema: OpenApi.IJsonSchema.IString): string;
63
64
  /**
64
- * Generates a random array with elements created by the provided generator function.
65
+ * Generates a random array with elements created by the provided generator
66
+ * function.
65
67
  *
66
68
  * @param schema Array schema with element generator function
67
69
  * @returns Random array with generated elements
@@ -221,37 +223,37 @@ export declare namespace IRandomGenerator {
221
223
  /**
222
224
  * Map of custom generators for different data types.
223
225
  *
224
- * This interface allows customization of random generation for specific
225
- * types when they have certain schema properties or constraints.
226
+ * This interface allows customization of random generation for specific types
227
+ * when they have certain schema properties or constraints.
226
228
  *
227
229
  * @example
228
- * ```typescript
229
- * const generator: Partial<IRandomGenerator> = {
230
- * string: (schema) => {
231
- * if ((schema as any)["x-typia-monetary"] === "dollar") {
232
- * return "$" + Math.floor(Math.random() * 1000);
233
- * }
234
- * return "default-string";
235
- * },
236
- * number: (schema) => {
237
- * if ((schema as any)["x-typia-powerOf"] !== undefined) {
238
- * const powerOf = (schema as any)["x-typia-powerOf"];
239
- * return Math.pow(powerOf, Math.random() * 10 + 1);
230
+ * ```typescript
231
+ * const generator: Partial<IRandomGenerator> = {
232
+ * string: (schema) => {
233
+ * if ((schema as any)["x-typia-monetary"] === "dollar") {
234
+ * return "$" + Math.floor(Math.random() * 1000);
235
+ * }
236
+ * return "default-string";
237
+ * },
238
+ * number: (schema) => {
239
+ * if ((schema as any)["x-typia-powerOf"] !== undefined) {
240
+ * const powerOf = (schema as any)["x-typia-powerOf"];
241
+ * return Math.pow(powerOf, Math.random() * 10 + 1);
242
+ * }
243
+ * return Math.random() * 100;
240
244
  * }
241
- * return Math.random() * 100;
242
- * }
243
- * };
244
- * ```
245
+ * };
246
+ * ```;
245
247
  */
246
248
  interface CustomMap {
247
249
  /**
248
- * Custom string generator that can handle special string formats
249
- * based on schema properties.
250
+ * Custom string generator that can handle special string formats based on
251
+ * schema properties.
250
252
  */
251
253
  string?: (schema: OpenApi.IJsonSchema.IString & Record<string, any>) => string;
252
254
  /**
253
- * Custom number generator that can handle special number constraints
254
- * based on schema properties.
255
+ * Custom number generator that can handle special number constraints based
256
+ * on schema properties.
255
257
  */
256
258
  number?: (schema: OpenApi.IJsonSchema.INumber & Record<string, any>) => number;
257
259
  /**
@@ -260,8 +262,8 @@ export declare namespace IRandomGenerator {
260
262
  */
261
263
  integer?: (schema: OpenApi.IJsonSchema.IInteger & Record<string, any>) => number;
262
264
  /**
263
- * Custom bigint generator that can handle special bigint constraints
264
- * based on schema properties.
265
+ * Custom bigint generator that can handle special bigint constraints based
266
+ * on schema properties.
265
267
  */
266
268
  bigint?: (schema: OpenApi.IJsonSchema.IInteger & Record<string, any>) => bigint;
267
269
  /**
@@ -270,8 +272,8 @@ export declare namespace IRandomGenerator {
270
272
  */
271
273
  boolean?: (schema: Record<string, any>) => boolean | undefined;
272
274
  /**
273
- * Custom array generator that can handle special array constraints
274
- * based on schema properties.
275
+ * Custom array generator that can handle special array constraints based on
276
+ * schema properties.
275
277
  */
276
278
  array?: <T>(schema: Omit<OpenApi.IJsonSchema.IArray, "items"> & {
277
279
  element: (index: number, count: number) => T;
@@ -1,8 +1,8 @@
1
1
  /**
2
2
  * Interface for a readable URLSearchParams object.
3
3
  *
4
- * This interface is a subset of the {@link URLSearchParams} interface,
5
- * designed especially for the [Hono.JS](https://hono.dev/) library.
4
+ * This interface is a subset of the {@link URLSearchParams} interface, designed
5
+ * especially for the [Hono.JS](https://hono.dev/) library.
6
6
  *
7
7
  * @author https://github.com/miyaji255
8
8
  */
@@ -1,8 +1,8 @@
1
1
  /**
2
2
  * Interface for a readable URLSearchParams object.
3
3
  *
4
- * This interface is a subset of the {@link URLSearchParams} interface,
5
- * designed especially for the [Hono.JS](https://hono.dev/) library.
4
+ * This interface is a subset of the {@link URLSearchParams} interface, designed
5
+ * especially for the [Hono.JS](https://hono.dev/) library.
6
6
  *
7
7
  * @author https://github.com/miyaji255
8
8
  */
@@ -9,8 +9,8 @@ import { ValueOf } from "./typings/ValueOf";
9
9
  *
10
10
  * It also erases every method property like {@link Resolved} type.
11
11
  *
12
- * @template T Target type to be pascalized
13
12
  * @author Jeongho Nam - https://github.com/samchon
13
+ * @template T Target type to be pascalized
14
14
  */
15
15
  export type PascalCase<T> = Equal<T, PascalizeMain<T>> extends true ? T : PascalizeMain<T>;
16
16
  type PascalizeMain<T> = T extends [never] ? never : T extends {
@@ -9,8 +9,8 @@ import { ValueOf } from "./typings/ValueOf";
9
9
  *
10
10
  * It also erases every method property like {@link Resolved} type.
11
11
  *
12
- * @template T Target type to be pascalized
13
12
  * @author Jeongho Nam - https://github.com/samchon
13
+ * @template T Target type to be pascalized
14
14
  */
15
15
  export type PascalCase<T> = Equal<T, PascalizeMain<T>> extends true ? T : PascalizeMain<T>;
16
16
  type PascalizeMain<T> = T extends [never] ? never : T extends {
@@ -6,36 +6,34 @@ import { Format } from "./tags";
6
6
  /**
7
7
  * Primitive type of JSON.
8
8
  *
9
- * `Primitive<T>` is a TMP (Type Meta Programming) type which converts
10
- * its argument as a primitive type within the framework JSON.
9
+ * `Primitive<T>` is a TMP (Type Meta Programming) type which converts its
10
+ * argument as a primitive type within the framework JSON.
11
11
  *
12
- * If the target argument is a built-in class which returns its origin primitive type
13
- * through the `valueOf()` method like the `String` or `Number`, its return type will
14
- * be the `string` or `number`. Otherwise, if the built-in class does not have the
15
- * `valueOf()` method, the return type will be an empty object (`{}`).
12
+ * If the target argument is a built-in class which returns its origin primitive
13
+ * type through the `valueOf()` method like the `String` or `Number`, its return
14
+ * type will be the `string` or `number`. Otherwise, if the built-in class does
15
+ * not have the `valueOf()` method, the return type will be an empty object
16
+ * (`{}`).
16
17
  *
17
- * Otherwise, if the target argument is a type of custom class, all of its custom methods
18
- * will be erased and its prototype will be changed to the primitive `object`.
19
- * Therefore, the return type of the TMP type will finally be the primitive object.
18
+ * Otherwise, if the target argument is a type of custom class, all of its
19
+ * custom methods will be erased and its prototype will be changed to the
20
+ * primitive `object`. Therefore, the return type of the TMP type will finally
21
+ * be the primitive object.
20
22
  *
21
- * In addition, if the target argument is a type of custom class and it has a special
22
- * method `toJSON()`, the return type of this `Primitive` will be not `Primitive<Instance>`
23
- * but `Primitive<ReturnType<Instance.toJSON>>`.
23
+ * In addition, if the target argument is a type of custom class and it has a
24
+ * special method `toJSON()`, the return type of this `Primitive` will be not
25
+ * `Primitive<Instance>` but `Primitive<ReturnType<Instance.toJSON>>`.
24
26
  *
25
- * Before | After
26
- * ------------------------|----------------------------------------
27
- * `Boolean` | `boolean`
28
- * `Number` | `number`
29
- * `String` | `string`
30
- * `Class` | `object`
31
- * `Class` with `toJSON()` | `Primitive<ReturnType<Class.toJSON>>`
32
- * Native Class | never
33
- * Others | No change
27
+ * Before | After
28
+ * ------------------------|---------------------------------------- `Boolean` |
29
+ * `boolean` `Number` | `number` `String` | `string` `Class` | `object` `Class`
30
+ * with `toJSON()` | `Primitive<ReturnType<Class.toJSON>>` Native Class | never
31
+ * Others | No change
34
32
  *
35
- * @template T Target argument type.
36
33
  * @author Jeongho Nam - https://github.com/samchon
37
34
  * @author Kyungsu Kang - https://github.com/kakasoo
38
35
  * @author Michael - https://github.com/8471919
36
+ * @template T Target argument type.
39
37
  */
40
38
  export type Primitive<T> = Equal<T, PrimitiveMain<T>> extends true ? T : PrimitiveMain<T>;
41
39
  type PrimitiveMain<Instance> = Instance extends [never] ? never : ValueOf<Instance> extends bigint ? never : ValueOf<Instance> extends boolean | number | string ? ValueOf<Instance> : Instance extends Function ? never : ValueOf<Instance> extends object ? Instance extends object ? Instance extends Date ? string & Format<"date-time"> : Instance extends IJsonable<infer Raw> ? ValueOf<Raw> extends object ? Raw extends object ? PrimitiveObject<Raw> : never : ValueOf<Raw> : Instance extends Exclude<NativeClass, Date> ? never : PrimitiveObject<Instance> : never : ValueOf<Instance>;
@@ -6,36 +6,34 @@ import { Format } from "./tags";
6
6
  /**
7
7
  * Primitive type of JSON.
8
8
  *
9
- * `Primitive<T>` is a TMP (Type Meta Programming) type which converts
10
- * its argument as a primitive type within the framework JSON.
9
+ * `Primitive<T>` is a TMP (Type Meta Programming) type which converts its
10
+ * argument as a primitive type within the framework JSON.
11
11
  *
12
- * If the target argument is a built-in class which returns its origin primitive type
13
- * through the `valueOf()` method like the `String` or `Number`, its return type will
14
- * be the `string` or `number`. Otherwise, if the built-in class does not have the
15
- * `valueOf()` method, the return type will be an empty object (`{}`).
12
+ * If the target argument is a built-in class which returns its origin primitive
13
+ * type through the `valueOf()` method like the `String` or `Number`, its return
14
+ * type will be the `string` or `number`. Otherwise, if the built-in class does
15
+ * not have the `valueOf()` method, the return type will be an empty object
16
+ * (`{}`).
16
17
  *
17
- * Otherwise, if the target argument is a type of custom class, all of its custom methods
18
- * will be erased and its prototype will be changed to the primitive `object`.
19
- * Therefore, the return type of the TMP type will finally be the primitive object.
18
+ * Otherwise, if the target argument is a type of custom class, all of its
19
+ * custom methods will be erased and its prototype will be changed to the
20
+ * primitive `object`. Therefore, the return type of the TMP type will finally
21
+ * be the primitive object.
20
22
  *
21
- * In addition, if the target argument is a type of custom class and it has a special
22
- * method `toJSON()`, the return type of this `Primitive` will be not `Primitive<Instance>`
23
- * but `Primitive<ReturnType<Instance.toJSON>>`.
23
+ * In addition, if the target argument is a type of custom class and it has a
24
+ * special method `toJSON()`, the return type of this `Primitive` will be not
25
+ * `Primitive<Instance>` but `Primitive<ReturnType<Instance.toJSON>>`.
24
26
  *
25
- * Before | After
26
- * ------------------------|----------------------------------------
27
- * `Boolean` | `boolean`
28
- * `Number` | `number`
29
- * `String` | `string`
30
- * `Class` | `object`
31
- * `Class` with `toJSON()` | `Primitive<ReturnType<Class.toJSON>>`
32
- * Native Class | never
33
- * Others | No change
27
+ * Before | After
28
+ * ------------------------|---------------------------------------- `Boolean` |
29
+ * `boolean` `Number` | `number` `String` | `string` `Class` | `object` `Class`
30
+ * with `toJSON()` | `Primitive<ReturnType<Class.toJSON>>` Native Class | never
31
+ * Others | No change
34
32
  *
35
- * @template T Target argument type.
36
33
  * @author Jeongho Nam - https://github.com/samchon
37
34
  * @author Kyungsu Kang - https://github.com/kakasoo
38
35
  * @author Michael - https://github.com/8471919
36
+ * @template T Target argument type.
39
37
  */
40
38
  export type Primitive<T> = Equal<T, PrimitiveMain<T>> extends true ? T : PrimitiveMain<T>;
41
39
  type PrimitiveMain<Instance> = Instance extends [never] ? never : ValueOf<Instance> extends bigint ? never : ValueOf<Instance> extends boolean | number | string ? ValueOf<Instance> : Instance extends Function ? never : ValueOf<Instance> extends object ? Instance extends object ? Instance extends Date ? string & Format<"date-time"> : Instance extends IJsonable<infer Raw> ? ValueOf<Raw> extends object ? Raw extends object ? PrimitiveObject<Raw> : never : ValueOf<Raw> : Instance extends Exclude<NativeClass, Date> ? never : PrimitiveObject<Instance> : never : ValueOf<Instance>;
@@ -5,30 +5,28 @@ import { ValueOf } from "./typings/ValueOf";
5
5
  /**
6
6
  * Resolved type that erases every method.
7
7
  *
8
- * `Resolved` is a TMP (Type Meta Programming) type which converts
9
- * its argument as a resolved type that erases every method property.
8
+ * `Resolved` is a TMP (Type Meta Programming) type which converts its argument
9
+ * as a resolved type that erases every method property.
10
10
  *
11
- * If the target argument is a built-in class which returns its origin primitive type
12
- * through the `valueOf()` method like the `String` or `Number`, its return type will
13
- * be the `string` or `number`. Otherwise, if the built-in class does not have the
14
- * `valueOf()` method, the return type will be the same as the target argument.
11
+ * If the target argument is a built-in class which returns its origin primitive
12
+ * type through the `valueOf()` method like the `String` or `Number`, its return
13
+ * type will be the `string` or `number`. Otherwise, if the built-in class does
14
+ * not have the `valueOf()` method, the return type will be the same as the
15
+ * target argument.
15
16
  *
16
- * Otherwise, if the target argument is a type of custom class, all of its custom methods
17
- * will be erased and its prototype will be changed to the primitive `object`.
18
- * Therefore, the return type of the TMP type will finally be the resolved object.
17
+ * Otherwise, if the target argument is a type of custom class, all of its
18
+ * custom methods will be erased and its prototype will be changed to the
19
+ * primitive `object`. Therefore, the return type of the TMP type will finally
20
+ * be the resolved object.
19
21
  *
20
- * Before | After
21
- * ------------------------|----------------------------------------
22
- * `Boolean` | `boolean`
23
- * `Number` | `number`
24
- * `BigInt` | `bigint`
25
- * `String` | `string`
26
- * `Class` | `interface`
27
- * Native Class or Others | No change
22
+ * Before | After
23
+ * ------------------------|---------------------------------------- `Boolean` |
24
+ * `boolean` `Number` | `number` `BigInt` | `bigint` `String` | `string` `Class`
25
+ * | `interface` Native Class or Others | No change
28
26
  *
29
- * @template T Target argument type.
30
27
  * @author Jeongho Nam - https://github.com/samchon
31
28
  * @author Kyungsu Kang - https://github.com/kakasoo
29
+ * @template T Target argument type.
32
30
  */
33
31
  export type Resolved<T> = Equal<T, ResolvedMain<T>> extends true ? T : ResolvedMain<T>;
34
32
  type ResolvedMain<T> = T extends [never] ? never : ValueOf<T> extends boolean | number | bigint | string ? ValueOf<T> : T extends Function ? never : T extends object ? ResolvedObject<T> : ValueOf<T>;