typia 5.1.6 → 5.2.0

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 (223) hide show
  1. package/lib/CamelCase.d.ts +32 -0
  2. package/lib/CamelCase.js +3 -0
  3. package/lib/CamelCase.js.map +1 -0
  4. package/lib/PascalCase.d.ts +32 -0
  5. package/lib/PascalCase.js +3 -0
  6. package/lib/PascalCase.js.map +1 -0
  7. package/lib/Primitive.d.ts +1 -1
  8. package/lib/Resolved.d.ts +5 -5
  9. package/lib/SnakeCase.d.ts +34 -0
  10. package/lib/SnakeCase.js +3 -0
  11. package/lib/SnakeCase.js.map +1 -0
  12. package/lib/functional/$convention.d.ts +1 -0
  13. package/lib/functional/$convention.js +63 -0
  14. package/lib/functional/$convention.js.map +1 -0
  15. package/lib/functional/Namespace.js +9 -0
  16. package/lib/functional/Namespace.js.map +1 -1
  17. package/lib/module.d.ts +5 -1
  18. package/lib/module.js +6 -2
  19. package/lib/module.js.map +1 -1
  20. package/lib/notations.d.ts +538 -0
  21. package/lib/notations.js +146 -0
  22. package/lib/notations.js.map +1 -0
  23. package/lib/programmers/helpers/NotationJoiner.d.ts +7 -0
  24. package/lib/programmers/helpers/NotationJoiner.js +85 -0
  25. package/lib/programmers/helpers/NotationJoiner.js.map +1 -0
  26. package/lib/programmers/misc/MiscCloneProgrammer.js +12 -1
  27. package/lib/programmers/misc/MiscCloneProgrammer.js.map +1 -1
  28. package/lib/programmers/misc/MiscPruneProgrammer.js +2 -1
  29. package/lib/programmers/misc/MiscPruneProgrammer.js.map +1 -1
  30. package/lib/programmers/notations/NotationAssertGeneralProgrammer.d.ts +5 -0
  31. package/lib/programmers/notations/NotationAssertGeneralProgrammer.js +44 -0
  32. package/lib/programmers/notations/NotationAssertGeneralProgrammer.js.map +1 -0
  33. package/lib/programmers/notations/NotationGeneralProgrammer.d.ts +6 -0
  34. package/lib/programmers/notations/NotationGeneralProgrammer.js +490 -0
  35. package/lib/programmers/notations/NotationGeneralProgrammer.js.map +1 -0
  36. package/lib/programmers/notations/NotationIsGeneralProgrammer.d.ts +5 -0
  37. package/lib/programmers/notations/NotationIsGeneralProgrammer.js +47 -0
  38. package/lib/programmers/notations/NotationIsGeneralProgrammer.js.map +1 -0
  39. package/lib/programmers/notations/NotationValidateGeneralProgrammer.d.ts +5 -0
  40. package/lib/programmers/notations/NotationValidateGeneralProgrammer.js +44 -0
  41. package/lib/programmers/notations/NotationValidateGeneralProgrammer.js.map +1 -0
  42. package/lib/transformers/CallExpressionTransformer.js +99 -16
  43. package/lib/transformers/CallExpressionTransformer.js.map +1 -1
  44. package/lib/transformers/features/json/JsonAssertParseTransformer.js +1 -1
  45. package/lib/transformers/features/json/JsonAssertParseTransformer.js.map +1 -1
  46. package/lib/transformers/features/json/JsonAssertStringifyTransformer.js +1 -1
  47. package/lib/transformers/features/json/JsonAssertStringifyTransformer.js.map +1 -1
  48. package/lib/transformers/features/json/JsonCreateAssertParseTransformer.js +1 -1
  49. package/lib/transformers/features/json/JsonCreateAssertParseTransformer.js.map +1 -1
  50. package/lib/transformers/features/json/JsonCreateAssertStringifyTransformer.js +1 -1
  51. package/lib/transformers/features/json/JsonCreateAssertStringifyTransformer.js.map +1 -1
  52. package/lib/transformers/features/json/JsonCreateIsParseTransformer.js +1 -1
  53. package/lib/transformers/features/json/JsonCreateIsParseTransformer.js.map +1 -1
  54. package/lib/transformers/features/json/JsonCreateIsStringifyTransformer.js +1 -1
  55. package/lib/transformers/features/json/JsonCreateIsStringifyTransformer.js.map +1 -1
  56. package/lib/transformers/features/json/JsonCreateStringifyTransformer.js +1 -1
  57. package/lib/transformers/features/json/JsonCreateStringifyTransformer.js.map +1 -1
  58. package/lib/transformers/features/json/JsonCreateValidateParseTransformer.js +1 -1
  59. package/lib/transformers/features/json/JsonCreateValidateParseTransformer.js.map +1 -1
  60. package/lib/transformers/features/json/JsonCreateValidateStringifyProgrammer.js +1 -1
  61. package/lib/transformers/features/json/JsonCreateValidateStringifyProgrammer.js.map +1 -1
  62. package/lib/transformers/features/json/JsonIsParseTransformer.js +1 -1
  63. package/lib/transformers/features/json/JsonIsParseTransformer.js.map +1 -1
  64. package/lib/transformers/features/json/JsonIsStringifyTransformer.js +1 -1
  65. package/lib/transformers/features/json/JsonIsStringifyTransformer.js.map +1 -1
  66. package/lib/transformers/features/json/JsonStringifyTransformer.js +1 -1
  67. package/lib/transformers/features/json/JsonStringifyTransformer.js.map +1 -1
  68. package/lib/transformers/features/json/JsonValidateParseTransformer.js +1 -1
  69. package/lib/transformers/features/json/JsonValidateParseTransformer.js.map +1 -1
  70. package/lib/transformers/features/json/JsonValidateStringifyTransformer.js +1 -1
  71. package/lib/transformers/features/json/JsonValidateStringifyTransformer.js.map +1 -1
  72. package/lib/transformers/features/misc/MiscAssertCloneTransformer.js +1 -1
  73. package/lib/transformers/features/misc/MiscAssertCloneTransformer.js.map +1 -1
  74. package/lib/transformers/features/misc/MiscAssertPruneTransformer.js +1 -1
  75. package/lib/transformers/features/misc/MiscAssertPruneTransformer.js.map +1 -1
  76. package/lib/transformers/features/misc/MiscCloneTransformer.js +1 -1
  77. package/lib/transformers/features/misc/MiscCloneTransformer.js.map +1 -1
  78. package/lib/transformers/features/misc/MiscCreateAssertCloneTransformer.js +1 -1
  79. package/lib/transformers/features/misc/MiscCreateAssertCloneTransformer.js.map +1 -1
  80. package/lib/transformers/features/misc/MiscCreateAssertPruneTransformer.js +1 -1
  81. package/lib/transformers/features/misc/MiscCreateAssertPruneTransformer.js.map +1 -1
  82. package/lib/transformers/features/misc/MiscCreateCloneTransformer.js +1 -1
  83. package/lib/transformers/features/misc/MiscCreateCloneTransformer.js.map +1 -1
  84. package/lib/transformers/features/misc/MiscCreateIsCloneTransformer.js +1 -1
  85. package/lib/transformers/features/misc/MiscCreateIsCloneTransformer.js.map +1 -1
  86. package/lib/transformers/features/misc/MiscCreateIsPruneTransformer.js +1 -1
  87. package/lib/transformers/features/misc/MiscCreateIsPruneTransformer.js.map +1 -1
  88. package/lib/transformers/features/misc/MiscCreatePruneTransformer.js +1 -1
  89. package/lib/transformers/features/misc/MiscCreatePruneTransformer.js.map +1 -1
  90. package/lib/transformers/features/misc/MiscCreateValidateCloneTransformer.js +1 -1
  91. package/lib/transformers/features/misc/MiscCreateValidateCloneTransformer.js.map +1 -1
  92. package/lib/transformers/features/misc/MiscCreateValidatePruneTransformer.js +1 -1
  93. package/lib/transformers/features/misc/MiscCreateValidatePruneTransformer.js.map +1 -1
  94. package/lib/transformers/features/misc/MiscIsCloneTransformer.js +1 -1
  95. package/lib/transformers/features/misc/MiscIsCloneTransformer.js.map +1 -1
  96. package/lib/transformers/features/misc/MiscIsPruneTransformer.js +1 -1
  97. package/lib/transformers/features/misc/MiscIsPruneTransformer.js.map +1 -1
  98. package/lib/transformers/features/misc/MiscPruneTransformer.js +1 -1
  99. package/lib/transformers/features/misc/MiscPruneTransformer.js.map +1 -1
  100. package/lib/transformers/features/misc/MiscValidateCloneTransformer.js +1 -1
  101. package/lib/transformers/features/misc/MiscValidateCloneTransformer.js.map +1 -1
  102. package/lib/transformers/features/misc/MiscValidatePruneTransformer.js +1 -1
  103. package/lib/transformers/features/misc/MiscValidatePruneTransformer.js.map +1 -1
  104. package/lib/transformers/features/notations/NotationAssertGeneralTransformer.d.ts +4 -0
  105. package/lib/transformers/features/notations/NotationAssertGeneralTransformer.js +15 -0
  106. package/lib/transformers/features/notations/NotationAssertGeneralTransformer.js.map +1 -0
  107. package/lib/transformers/features/notations/NotationCreateAssertGeneralTransformer.d.ts +4 -0
  108. package/lib/transformers/features/notations/NotationCreateAssertGeneralTransformer.js +15 -0
  109. package/lib/transformers/features/notations/NotationCreateAssertGeneralTransformer.js.map +1 -0
  110. package/lib/transformers/features/notations/NotationCreateGeneralTransformer.d.ts +4 -0
  111. package/lib/transformers/features/notations/NotationCreateGeneralTransformer.js +15 -0
  112. package/lib/transformers/features/notations/NotationCreateGeneralTransformer.js.map +1 -0
  113. package/lib/transformers/features/notations/NotationCreateIsGeneralTransformer.d.ts +4 -0
  114. package/lib/transformers/features/notations/NotationCreateIsGeneralTransformer.js +15 -0
  115. package/lib/transformers/features/notations/NotationCreateIsGeneralTransformer.js.map +1 -0
  116. package/lib/transformers/features/notations/NotationCreateValidateGeneralTransformer.d.ts +4 -0
  117. package/lib/transformers/features/notations/NotationCreateValidateGeneralTransformer.js +15 -0
  118. package/lib/transformers/features/notations/NotationCreateValidateGeneralTransformer.js.map +1 -0
  119. package/lib/transformers/features/notations/NotationGeneralTransformer.d.ts +4 -0
  120. package/lib/transformers/features/notations/NotationGeneralTransformer.js +14 -0
  121. package/lib/transformers/features/notations/NotationGeneralTransformer.js.map +1 -0
  122. package/lib/transformers/features/notations/NotationIsGeneralTransformer.d.ts +4 -0
  123. package/lib/transformers/features/notations/NotationIsGeneralTransformer.js +15 -0
  124. package/lib/transformers/features/notations/NotationIsGeneralTransformer.js.map +1 -0
  125. package/lib/transformers/features/notations/NotationValidateGeneralTransformer.d.ts +4 -0
  126. package/lib/transformers/features/notations/NotationValidateGeneralTransformer.js +15 -0
  127. package/lib/transformers/features/notations/NotationValidateGeneralTransformer.js.map +1 -0
  128. package/lib/transformers/features/protobuf/{CreateProtobufAssertDecodeTransformer.d.ts → ProtobufCreateAssertDecodeTransformer.d.ts} +1 -1
  129. package/lib/transformers/features/protobuf/{CreateProtobufAssertDecodeTransformer.js → ProtobufCreateAssertDecodeTransformer.js} +6 -6
  130. package/lib/transformers/features/protobuf/{CreateProtobufAssertEncodeTransformer.js.map → ProtobufCreateAssertDecodeTransformer.js.map} +1 -1
  131. package/lib/transformers/features/protobuf/{CreateProtobufAssertEncodeTransformer.d.ts → ProtobufCreateAssertEncodeTransformer.d.ts} +1 -1
  132. package/lib/transformers/features/protobuf/{CreateProtobufAssertEncodeTransformer.js → ProtobufCreateAssertEncodeTransformer.js} +6 -6
  133. package/lib/transformers/features/protobuf/{CreateProtobufAssertDecodeTransformer.js.map → ProtobufCreateAssertEncodeTransformer.js.map} +1 -1
  134. package/lib/transformers/features/protobuf/{CreateProtobufDecodeTransformer.d.ts → ProtobufCreateDecodeTransformer.d.ts} +1 -1
  135. package/lib/transformers/features/protobuf/{CreateProtobufDecodeTransformer.js → ProtobufCreateDecodeTransformer.js} +6 -6
  136. package/lib/transformers/features/protobuf/{CreateProtobufDecodeTransformer.js.map → ProtobufCreateDecodeTransformer.js.map} +1 -1
  137. package/lib/transformers/features/protobuf/{CreateProtobufEncodeTransformer.d.ts → ProtobufCreateEncodeTransformer.d.ts} +1 -1
  138. package/lib/transformers/features/protobuf/{CreateProtobufEncodeTransformer.js → ProtobufCreateEncodeTransformer.js} +6 -6
  139. package/lib/transformers/features/protobuf/{CreateProtobufEncodeTransformer.js.map → ProtobufCreateEncodeTransformer.js.map} +1 -1
  140. package/lib/transformers/features/protobuf/{CreateProtobufIsDecodeTransformer.d.ts → ProtobufCreateIsDecodeTransformer.d.ts} +1 -1
  141. package/lib/transformers/features/protobuf/{CreateProtobufIsDecodeTransformer.js → ProtobufCreateIsDecodeTransformer.js} +6 -6
  142. package/lib/transformers/features/protobuf/{CreateProtobufIsDecodeTransformer.js.map → ProtobufCreateIsDecodeTransformer.js.map} +1 -1
  143. package/lib/transformers/features/protobuf/{CreateProtobufIsEncodeTransformer.d.ts → ProtobufCreateIsEncodeTransformer.d.ts} +1 -1
  144. package/lib/transformers/features/protobuf/{CreateProtobufIsEncodeTransformer.js → ProtobufCreateIsEncodeTransformer.js} +6 -6
  145. package/lib/transformers/features/protobuf/{CreateProtobufIsEncodeTransformer.js.map → ProtobufCreateIsEncodeTransformer.js.map} +1 -1
  146. package/lib/transformers/features/protobuf/{CreateProtobufValidateDecodeTransformer.d.ts → ProtobufCreateValidateDecodeTransformer.d.ts} +1 -1
  147. package/lib/transformers/features/protobuf/{CreateProtobufValidateDecodeTransformer.js → ProtobufCreateValidateDecodeTransformer.js} +6 -6
  148. package/lib/transformers/features/protobuf/{CreateProtobufValidateDecodeTransformer.js.map → ProtobufCreateValidateDecodeTransformer.js.map} +1 -1
  149. package/lib/transformers/features/protobuf/{CreateProtobufValidateEncodeTransformer.d.ts → ProtobufCreateValidateEncodeTransformer.d.ts} +1 -1
  150. package/lib/transformers/features/protobuf/{CreateProtobufValidateEncodeTransformer.js → ProtobufCreateValidateEncodeTransformer.js} +6 -6
  151. package/lib/transformers/features/protobuf/{CreateProtobufValidateEncodeTransformer.js.map → ProtobufCreateValidateEncodeTransformer.js.map} +1 -1
  152. package/lib/utils/NamingConvention.d.ts +5 -0
  153. package/lib/utils/NamingConvention.js +115 -0
  154. package/lib/utils/NamingConvention.js.map +1 -0
  155. package/lib/utils/StringUtil.d.ts +3 -0
  156. package/lib/utils/StringUtil.js +10 -0
  157. package/lib/utils/StringUtil.js.map +1 -0
  158. package/package.json +2 -1
  159. package/src/CamelCase.ts +116 -0
  160. package/src/PascalCase.ts +116 -0
  161. package/src/Primitive.ts +135 -135
  162. package/src/Resolved.ts +116 -116
  163. package/src/SnakeCase.ts +156 -0
  164. package/src/functional/$convention.ts +40 -0
  165. package/src/functional/Namespace.ts +164 -142
  166. package/src/module.ts +662 -657
  167. package/src/notations.ts +855 -0
  168. package/src/programmers/helpers/NotationJoiner.ts +146 -0
  169. package/src/programmers/misc/MiscCloneProgrammer.ts +790 -774
  170. package/src/programmers/misc/MiscPruneProgrammer.ts +552 -550
  171. package/src/programmers/notations/NotationAssertGeneralProgrammer.ts +72 -0
  172. package/src/programmers/notations/NotationGeneralProgrammer.ts +720 -0
  173. package/src/programmers/notations/NotationIsGeneralProgrammer.ts +79 -0
  174. package/src/programmers/notations/NotationValidateGeneralProgrammer.ts +88 -0
  175. package/src/transformers/CallExpressionTransformer.ts +380 -289
  176. package/src/transformers/features/json/JsonAssertParseTransformer.ts +10 -10
  177. package/src/transformers/features/json/JsonAssertStringifyTransformer.ts +10 -10
  178. package/src/transformers/features/json/JsonCreateAssertParseTransformer.ts +12 -10
  179. package/src/transformers/features/json/JsonCreateAssertStringifyTransformer.ts +12 -12
  180. package/src/transformers/features/json/JsonCreateIsParseTransformer.ts +9 -9
  181. package/src/transformers/features/json/JsonCreateIsStringifyTransformer.ts +12 -10
  182. package/src/transformers/features/json/JsonCreateStringifyTransformer.ts +9 -9
  183. package/src/transformers/features/json/JsonCreateValidateParseTransformer.ts +12 -10
  184. package/src/transformers/features/json/JsonCreateValidateStringifyProgrammer.ts +12 -12
  185. package/src/transformers/features/json/JsonIsParseTransformer.ts +9 -9
  186. package/src/transformers/features/json/JsonIsStringifyTransformer.ts +10 -10
  187. package/src/transformers/features/json/JsonStringifyTransformer.ts +9 -9
  188. package/src/transformers/features/json/JsonValidateParseTransformer.ts +10 -10
  189. package/src/transformers/features/json/JsonValidateStringifyTransformer.ts +10 -10
  190. package/src/transformers/features/misc/MiscAssertCloneTransformer.ts +10 -10
  191. package/src/transformers/features/misc/MiscAssertPruneTransformer.ts +10 -10
  192. package/src/transformers/features/misc/MiscCloneTransformer.ts +9 -9
  193. package/src/transformers/features/misc/MiscCreateAssertCloneTransformer.ts +12 -10
  194. package/src/transformers/features/misc/MiscCreateAssertPruneTransformer.ts +12 -10
  195. package/src/transformers/features/misc/MiscCreateCloneTransformer.ts +9 -9
  196. package/src/transformers/features/misc/MiscCreateIsCloneTransformer.ts +9 -9
  197. package/src/transformers/features/misc/MiscCreateIsPruneTransformer.ts +9 -9
  198. package/src/transformers/features/misc/MiscCreatePruneTransformer.ts +9 -9
  199. package/src/transformers/features/misc/MiscCreateValidateCloneTransformer.ts +12 -10
  200. package/src/transformers/features/misc/MiscCreateValidatePruneTransformer.ts +12 -10
  201. package/src/transformers/features/misc/MiscIsCloneTransformer.ts +9 -9
  202. package/src/transformers/features/misc/MiscIsPruneTransformer.ts +9 -9
  203. package/src/transformers/features/misc/MiscPruneTransformer.ts +9 -9
  204. package/src/transformers/features/misc/MiscValidateCloneTransformer.ts +10 -10
  205. package/src/transformers/features/misc/MiscValidatePruneTransformer.ts +10 -10
  206. package/src/transformers/features/notations/NotationAssertGeneralTransformer.ts +15 -0
  207. package/src/transformers/features/notations/NotationCreateAssertGeneralTransformer.ts +15 -0
  208. package/src/transformers/features/notations/NotationCreateGeneralTransformer.ts +15 -0
  209. package/src/transformers/features/notations/NotationCreateIsGeneralTransformer.ts +15 -0
  210. package/src/transformers/features/notations/NotationCreateValidateGeneralTransformer.ts +17 -0
  211. package/src/transformers/features/notations/NotationGeneralTransformer.ts +11 -0
  212. package/src/transformers/features/notations/NotationIsGeneralTransformer.ts +15 -0
  213. package/src/transformers/features/notations/NotationValidateGeneralTransformer.ts +17 -0
  214. package/src/transformers/features/protobuf/{CreateProtobufAssertDecodeTransformer.ts → ProtobufCreateAssertDecodeTransformer.ts} +12 -12
  215. package/src/transformers/features/protobuf/{CreateProtobufAssertEncodeTransformer.ts → ProtobufCreateAssertEncodeTransformer.ts} +12 -12
  216. package/src/transformers/features/protobuf/{CreateProtobufDecodeTransformer.ts → ProtobufCreateDecodeTransformer.ts} +9 -9
  217. package/src/transformers/features/protobuf/{CreateProtobufEncodeTransformer.ts → ProtobufCreateEncodeTransformer.ts} +9 -9
  218. package/src/transformers/features/protobuf/{CreateProtobufIsDecodeTransformer.ts → ProtobufCreateIsDecodeTransformer.ts} +12 -12
  219. package/src/transformers/features/protobuf/{CreateProtobufIsEncodeTransformer.ts → ProtobufCreateIsEncodeTransformer.ts} +12 -12
  220. package/src/transformers/features/protobuf/{CreateProtobufValidateDecodeTransformer.ts → ProtobufCreateValidateDecodeTransformer.ts} +12 -12
  221. package/src/transformers/features/protobuf/{CreateProtobufValidateEncodeTransformer.ts → ProtobufCreateValidateEncodeTransformer.ts} +12 -12
  222. package/src/utils/NamingConvention.ts +91 -0
  223. package/src/utils/StringUtil.ts +4 -0
package/src/Primitive.ts CHANGED
@@ -1,135 +1,135 @@
1
- /**
2
- * Primitive type of JSON.
3
- *
4
- * `Primitive<T>` is a TMP (Type Meta Programming) type which converts
5
- * its argument as a primitive type within framework JSON.
6
- *
7
- * If the target argument is a built-in class which returns its origin primitive type
8
- * through the `valueOf()` method like the `String` or `Number`, its return type would
9
- * be the `string` or `number`. Otherwise, the built-in class does not have the
10
- * `valueOf()` method, the return type would be an empty object (`{}`).
11
- *
12
- * Otherwise, the target argument is a type of custom class, all of its custom method
13
- * would be erased and its prototype would be changed to the primitive `object`.
14
- * Therefore, return type of the TMP type finally be the primitive object.
15
- *
16
- * In addition, if the target argument is a type of custom class and it has a special
17
- * method `toJSON()`, return type of this `Primitive` would be not `Primitive<Instance>`
18
- * but `Primitive<ReturnType<Instance.toJSON>>`.
19
- *
20
- * Before | After
21
- * ------------------------|----------------------------------------
22
- * `Boolean` | `boolean`
23
- * `Number` | `number`
24
- * `String` | `string`
25
- * `Class` | `object`
26
- * `Class` with `toJSON()` | `Primitive<ReturnType<Class.toJSON>>`
27
- * Native Class | `{}`
28
- * Others | No change
29
- *
30
- * @template Instance Target argument type.
31
- * @author Jeongho Nam - https://github.com/samchon
32
- * @author Kyungsu Kang - https://github.com/kakasoo
33
- * @author Michael - https://github.com/8471919
34
- */
35
- export type Primitive<T> = Equal<T, PrimitiveMain<T>> extends true
36
- ? T
37
- : PrimitiveMain<T>;
38
-
39
- type Equal<X, Y> = X extends Y ? (Y extends X ? true : false) : false;
40
-
41
- type PrimitiveMain<Instance> = Instance extends [never]
42
- ? never // (special trick for jsonable | null) type
43
- : ValueOf<Instance> extends bigint
44
- ? never
45
- : ValueOf<Instance> extends boolean | number | string
46
- ? ValueOf<Instance>
47
- : Instance extends Function
48
- ? never
49
- : ValueOf<Instance> extends object
50
- ? Instance extends object
51
- ? Instance extends NativeClass
52
- ? {}
53
- : Instance extends IJsonable<infer Raw>
54
- ? ValueOf<Raw> extends object
55
- ? Raw extends object
56
- ? PrimitiveObject<Raw> // object would be primitified
57
- : never // cannot be
58
- : ValueOf<Raw> // atomic value
59
- : PrimitiveObject<Instance> // object would be primitified
60
- : never // cannot be
61
- : ValueOf<Instance>;
62
-
63
- type PrimitiveObject<Instance extends object> = Instance extends Array<infer T>
64
- ? IsTuple<Instance> extends true
65
- ? PrimitiveTuple<Instance>
66
- : PrimitiveMain<T>[]
67
- : {
68
- [P in keyof Instance]: PrimitiveMain<Instance[P]>;
69
- };
70
-
71
- type PrimitiveTuple<T extends readonly any[]> = T extends []
72
- ? []
73
- : T extends [infer F]
74
- ? [PrimitiveMain<F>]
75
- : T extends [infer F, ...infer Rest extends readonly any[]]
76
- ? [PrimitiveMain<F>, ...PrimitiveTuple<Rest>]
77
- : T extends [(infer F)?]
78
- ? [PrimitiveMain<F>?]
79
- : T extends [(infer F)?, ...infer Rest extends readonly any[]]
80
- ? [PrimitiveMain<F>?, ...PrimitiveTuple<Rest>]
81
- : [];
82
-
83
- type ValueOf<Instance> = IsValueOf<Instance, Boolean> extends true
84
- ? boolean
85
- : IsValueOf<Instance, Number> extends true
86
- ? number
87
- : IsValueOf<Instance, String> extends true
88
- ? string
89
- : Instance;
90
-
91
- type NativeClass =
92
- | Set<any>
93
- | Map<any, any>
94
- | WeakSet<any>
95
- | WeakMap<any, any>
96
- | Uint8Array
97
- | Uint8ClampedArray
98
- | Uint16Array
99
- | Uint32Array
100
- | BigUint64Array
101
- | Int8Array
102
- | Int16Array
103
- | Int32Array
104
- | BigInt64Array
105
- | Float32Array
106
- | Float64Array
107
- | ArrayBuffer
108
- | SharedArrayBuffer
109
- | DataView;
110
-
111
- type IsTuple<T extends readonly any[] | { length: number }> = [T] extends [
112
- never,
113
- ]
114
- ? false
115
- : T extends readonly any[]
116
- ? number extends T["length"]
117
- ? false
118
- : true
119
- : false;
120
-
121
- type IsValueOf<Instance, Object extends IValueOf<any>> = Instance extends Object
122
- ? Object extends IValueOf<infer U>
123
- ? Instance extends U
124
- ? false
125
- : true // not Primitive, but Object
126
- : false // cannot be
127
- : false;
128
-
129
- interface IValueOf<T> {
130
- valueOf(): T;
131
- }
132
-
133
- interface IJsonable<T> {
134
- toJSON(): T;
135
- }
1
+ /**
2
+ * Primitive type of JSON.
3
+ *
4
+ * `Primitive<T>` is a TMP (Type Meta Programming) type which converts
5
+ * its argument as a primitive type within framework JSON.
6
+ *
7
+ * If the target argument is a built-in class which returns its origin primitive type
8
+ * through the `valueOf()` method like the `String` or `Number`, its return type would
9
+ * be the `string` or `number`. Otherwise, the built-in class does not have the
10
+ * `valueOf()` method, the return type would be an empty object (`{}`).
11
+ *
12
+ * Otherwise, the target argument is a type of custom class, all of its custom method
13
+ * would be erased and its prototype would be changed to the primitive `object`.
14
+ * Therefore, return type of the TMP type finally be the primitive object.
15
+ *
16
+ * In addition, if the target argument is a type of custom class and it has a special
17
+ * method `toJSON()`, return type of this `Primitive` would be not `Primitive<Instance>`
18
+ * but `Primitive<ReturnType<Instance.toJSON>>`.
19
+ *
20
+ * Before | After
21
+ * ------------------------|----------------------------------------
22
+ * `Boolean` | `boolean`
23
+ * `Number` | `number`
24
+ * `String` | `string`
25
+ * `Class` | `object`
26
+ * `Class` with `toJSON()` | `Primitive<ReturnType<Class.toJSON>>`
27
+ * Native Class | `{}`
28
+ * Others | No change
29
+ *
30
+ * @template T Target argument type.
31
+ * @author Jeongho Nam - https://github.com/samchon
32
+ * @author Kyungsu Kang - https://github.com/kakasoo
33
+ * @author Michael - https://github.com/8471919
34
+ */
35
+ export type Primitive<T> = Equal<T, PrimitiveMain<T>> extends true
36
+ ? T
37
+ : PrimitiveMain<T>;
38
+
39
+ type Equal<X, Y> = X extends Y ? (Y extends X ? true : false) : false;
40
+
41
+ type PrimitiveMain<Instance> = Instance extends [never]
42
+ ? never // (special trick for jsonable | null) type
43
+ : ValueOf<Instance> extends bigint
44
+ ? never
45
+ : ValueOf<Instance> extends boolean | number | string
46
+ ? ValueOf<Instance>
47
+ : Instance extends Function
48
+ ? never
49
+ : ValueOf<Instance> extends object
50
+ ? Instance extends object
51
+ ? Instance extends NativeClass
52
+ ? {}
53
+ : Instance extends IJsonable<infer Raw>
54
+ ? ValueOf<Raw> extends object
55
+ ? Raw extends object
56
+ ? PrimitiveObject<Raw> // object would be primitified
57
+ : never // cannot be
58
+ : ValueOf<Raw> // atomic value
59
+ : PrimitiveObject<Instance> // object would be primitified
60
+ : never // cannot be
61
+ : ValueOf<Instance>;
62
+
63
+ type PrimitiveObject<Instance extends object> = Instance extends Array<infer T>
64
+ ? IsTuple<Instance> extends true
65
+ ? PrimitiveTuple<Instance>
66
+ : PrimitiveMain<T>[]
67
+ : {
68
+ [P in keyof Instance]: PrimitiveMain<Instance[P]>;
69
+ };
70
+
71
+ type PrimitiveTuple<T extends readonly any[]> = T extends []
72
+ ? []
73
+ : T extends [infer F]
74
+ ? [PrimitiveMain<F>]
75
+ : T extends [infer F, ...infer Rest extends readonly any[]]
76
+ ? [PrimitiveMain<F>, ...PrimitiveTuple<Rest>]
77
+ : T extends [(infer F)?]
78
+ ? [PrimitiveMain<F>?]
79
+ : T extends [(infer F)?, ...infer Rest extends readonly any[]]
80
+ ? [PrimitiveMain<F>?, ...PrimitiveTuple<Rest>]
81
+ : [];
82
+
83
+ type ValueOf<Instance> = IsValueOf<Instance, Boolean> extends true
84
+ ? boolean
85
+ : IsValueOf<Instance, Number> extends true
86
+ ? number
87
+ : IsValueOf<Instance, String> extends true
88
+ ? string
89
+ : Instance;
90
+
91
+ type NativeClass =
92
+ | Set<any>
93
+ | Map<any, any>
94
+ | WeakSet<any>
95
+ | WeakMap<any, any>
96
+ | Uint8Array
97
+ | Uint8ClampedArray
98
+ | Uint16Array
99
+ | Uint32Array
100
+ | BigUint64Array
101
+ | Int8Array
102
+ | Int16Array
103
+ | Int32Array
104
+ | BigInt64Array
105
+ | Float32Array
106
+ | Float64Array
107
+ | ArrayBuffer
108
+ | SharedArrayBuffer
109
+ | DataView;
110
+
111
+ type IsTuple<T extends readonly any[] | { length: number }> = [T] extends [
112
+ never,
113
+ ]
114
+ ? false
115
+ : T extends readonly any[]
116
+ ? number extends T["length"]
117
+ ? false
118
+ : true
119
+ : false;
120
+
121
+ type IsValueOf<Instance, Object extends IValueOf<any>> = Instance extends Object
122
+ ? Object extends IValueOf<infer U>
123
+ ? Instance extends U
124
+ ? false
125
+ : true // not Primitive, but Object
126
+ : false // cannot be
127
+ : false;
128
+
129
+ interface IValueOf<T> {
130
+ valueOf(): T;
131
+ }
132
+
133
+ interface IJsonable<T> {
134
+ toJSON(): T;
135
+ }
package/src/Resolved.ts CHANGED
@@ -1,116 +1,116 @@
1
- /**
2
- * Resolved type erased every methods.
3
- *
4
- * `Resolved` is a type of TMP (Type Meta Programming) type which converts
5
- * its argument as a resolved type that erased every method properties.
6
- *
7
- * If the target argument is a built-in class which returns its origin primitive type
8
- * through the `valueOf()` method like the `String` or `Number`, its return type would
9
- * be the `string` or `number`. Otherwise, the built-in class does not have the
10
- * `valueOf()` method, the return type would be same with the target argument.
11
- *
12
- * Otherwise, the target argument is a type of custom class, all of its custom methods
13
- * would be erased and its prototype would be changed to the primitive `object`.
14
- * Therefore, return type of the TMP type finally be the resolved object.
15
- *
16
- * Before | After
17
- * ------------------------|----------------------------------------
18
- * `Boolean` | `boolean`
19
- * `Number` | `number`
20
- * `BigInt` | `bigint`
21
- * `String` | `string`
22
- * `Class` | `interface`
23
- * Native Class or Others | No change
24
- *
25
- * @template Instance Target argument type.
26
- * @author Jeongho Nam - https://github.com/samchon
27
- * @author Kyungsu Kang - https://github.com/kakasoo
28
- */
29
- export type Resolved<T> = Equal<T, ResolvedMain<T>> extends true
30
- ? T
31
- : ResolvedMain<T>;
32
-
33
- type Equal<X, Y> = X extends Y ? (Y extends X ? true : false) : false;
34
-
35
- type ResolvedMain<Instance> = Instance extends [never]
36
- ? never // (special trick for jsonable | null) type
37
- : ValueOf<Instance> extends boolean | number | bigint | string
38
- ? ValueOf<Instance>
39
- : Instance extends Function
40
- ? never
41
- : Instance extends object
42
- ? ResolvedObject<Instance>
43
- : ValueOf<Instance>;
44
-
45
- type ResolvedObject<Instance extends object> = Instance extends Array<infer T>
46
- ? IsTuple<Instance> extends true
47
- ? ResolvedTuple<Instance>
48
- : ResolvedMain<T>[]
49
- : Instance extends Set<infer U>
50
- ? Set<ResolvedMain<U>>
51
- : Instance extends Map<infer K, infer V>
52
- ? Map<ResolvedMain<K>, ResolvedMain<V>>
53
- : Instance extends WeakSet<any> | WeakMap<any, any>
54
- ? never
55
- : Instance extends
56
- | Date
57
- | Uint8Array
58
- | Uint8ClampedArray
59
- | Uint16Array
60
- | Uint32Array
61
- | BigUint64Array
62
- | Int8Array
63
- | Int16Array
64
- | Int32Array
65
- | BigInt64Array
66
- | Float32Array
67
- | Float64Array
68
- | ArrayBuffer
69
- | SharedArrayBuffer
70
- | DataView
71
- ? Instance
72
- : {
73
- [P in keyof Instance]: ResolvedMain<Instance[P]>;
74
- };
75
-
76
- type ResolvedTuple<T extends readonly any[]> = T extends []
77
- ? []
78
- : T extends [infer F]
79
- ? [ResolvedMain<F>]
80
- : T extends [infer F, ...infer Rest extends readonly any[]]
81
- ? [ResolvedMain<F>, ...ResolvedTuple<Rest>]
82
- : T extends [(infer F)?]
83
- ? [ResolvedMain<F>?]
84
- : T extends [(infer F)?, ...infer Rest extends readonly any[]]
85
- ? [ResolvedMain<F>?, ...ResolvedTuple<Rest>]
86
- : [];
87
-
88
- type ValueOf<Instance> = IsValueOf<Instance, Boolean> extends true
89
- ? boolean
90
- : IsValueOf<Instance, Number> extends true
91
- ? number
92
- : IsValueOf<Instance, String> extends true
93
- ? string
94
- : Instance;
95
-
96
- type IsTuple<T extends readonly any[] | { length: number }> = [T] extends [
97
- never,
98
- ]
99
- ? false
100
- : T extends readonly any[]
101
- ? number extends T["length"]
102
- ? false
103
- : true
104
- : false;
105
-
106
- type IsValueOf<Instance, Object extends IValueOf<any>> = Instance extends Object
107
- ? Object extends IValueOf<infer Primitive>
108
- ? Instance extends Primitive
109
- ? false
110
- : true // not Primitive, but Object
111
- : false // cannot be
112
- : false;
113
-
114
- interface IValueOf<T> {
115
- valueOf(): T;
116
- }
1
+ /**
2
+ * Resolved type erased every methods.
3
+ *
4
+ * `Resolved` is a type of TMP (Type Meta Programming) type which converts
5
+ * its argument as a resolved type that erased every method properties.
6
+ *
7
+ * If the target argument is a built-in class which returns its origin primitive type
8
+ * through the `valueOf()` method like the `String` or `Number`, its return type would
9
+ * be the `string` or `number`. Otherwise, the built-in class does not have the
10
+ * `valueOf()` method, the return type would be same with the target argument.
11
+ *
12
+ * Otherwise, the target argument is a type of custom class, all of its custom methods
13
+ * would be erased and its prototype would be changed to the primitive `object`.
14
+ * Therefore, return type of the TMP type finally be the resolved object.
15
+ *
16
+ * Before | After
17
+ * ------------------------|----------------------------------------
18
+ * `Boolean` | `boolean`
19
+ * `Number` | `number`
20
+ * `BigInt` | `bigint`
21
+ * `String` | `string`
22
+ * `Class` | `interface`
23
+ * Native Class or Others | No change
24
+ *
25
+ * @template T Target argument type.
26
+ * @author Jeongho Nam - https://github.com/samchon
27
+ * @author Kyungsu Kang - https://github.com/kakasoo
28
+ */
29
+ export type Resolved<T> = Equal<T, ResolvedMain<T>> extends true
30
+ ? T
31
+ : ResolvedMain<T>;
32
+
33
+ type Equal<X, Y> = X extends Y ? (Y extends X ? true : false) : false;
34
+
35
+ type ResolvedMain<T> = T extends [never]
36
+ ? never // (special trick for jsonable | null) type
37
+ : ValueOf<T> extends boolean | number | bigint | string
38
+ ? ValueOf<T>
39
+ : T extends Function
40
+ ? never
41
+ : T extends object
42
+ ? ResolvedObject<T>
43
+ : ValueOf<T>;
44
+
45
+ type ResolvedObject<T extends object> = T extends Array<infer U>
46
+ ? IsTuple<T> extends true
47
+ ? ResolvedTuple<T>
48
+ : ResolvedMain<U>[]
49
+ : T extends Set<infer U>
50
+ ? Set<ResolvedMain<U>>
51
+ : T extends Map<infer K, infer V>
52
+ ? Map<ResolvedMain<K>, ResolvedMain<V>>
53
+ : T extends WeakSet<any> | WeakMap<any, any>
54
+ ? never
55
+ : T extends
56
+ | Date
57
+ | Uint8Array
58
+ | Uint8ClampedArray
59
+ | Uint16Array
60
+ | Uint32Array
61
+ | BigUint64Array
62
+ | Int8Array
63
+ | Int16Array
64
+ | Int32Array
65
+ | BigInt64Array
66
+ | Float32Array
67
+ | Float64Array
68
+ | ArrayBuffer
69
+ | SharedArrayBuffer
70
+ | DataView
71
+ ? T
72
+ : {
73
+ [P in keyof T]: ResolvedMain<T[P]>;
74
+ };
75
+
76
+ type ResolvedTuple<T extends readonly any[]> = T extends []
77
+ ? []
78
+ : T extends [infer F]
79
+ ? [ResolvedMain<F>]
80
+ : T extends [infer F, ...infer Rest extends readonly any[]]
81
+ ? [ResolvedMain<F>, ...ResolvedTuple<Rest>]
82
+ : T extends [(infer F)?]
83
+ ? [ResolvedMain<F>?]
84
+ : T extends [(infer F)?, ...infer Rest extends readonly any[]]
85
+ ? [ResolvedMain<F>?, ...ResolvedTuple<Rest>]
86
+ : [];
87
+
88
+ type IsTuple<T extends readonly any[] | { length: number }> = [T] extends [
89
+ never,
90
+ ]
91
+ ? false
92
+ : T extends readonly any[]
93
+ ? number extends T["length"]
94
+ ? false
95
+ : true
96
+ : false;
97
+
98
+ type ValueOf<Instance> = IsValueOf<Instance, Boolean> extends true
99
+ ? boolean
100
+ : IsValueOf<Instance, Number> extends true
101
+ ? number
102
+ : IsValueOf<Instance, String> extends true
103
+ ? string
104
+ : Instance;
105
+
106
+ type IsValueOf<Instance, Object extends IValueOf<any>> = Instance extends Object
107
+ ? Object extends IValueOf<infer Primitive>
108
+ ? Instance extends Primitive
109
+ ? false
110
+ : true // not Primitive, but Object
111
+ : false // cannot be
112
+ : false;
113
+
114
+ interface IValueOf<T> {
115
+ valueOf(): T;
116
+ }
@@ -0,0 +1,156 @@
1
+ /**
2
+ * Snake case type.
3
+ *
4
+ * `SnakeCase` type is a type that all keys of an object are converted to snake case.
5
+ *
6
+ * It also erase every method properties like {@link Resolved} type.
7
+ *
8
+ * @template T Target type to be snake cased
9
+ * @author Jeongho Nam - https://github.com/samchon
10
+ */
11
+ export type SnakeCase<T> = Equal<T, SnakageMain<T>> extends true
12
+ ? T
13
+ : SnakageMain<T>;
14
+
15
+ /* -----------------------------------------------------------
16
+ OBJECT CONVERSION
17
+ ----------------------------------------------------------- */
18
+ type Equal<X, Y> = X extends Y ? (Y extends X ? true : false) : false;
19
+
20
+ type SnakageMain<T> = T extends [never]
21
+ ? never // special trick for (jsonable | null) type
22
+ : T extends { valueOf(): boolean | bigint | number | string }
23
+ ? ValueOf<T>
24
+ : T extends Function
25
+ ? never
26
+ : T extends object
27
+ ? SnakageObject<T>
28
+ : T;
29
+
30
+ type SnakageObject<T extends object> = T extends Array<infer U>
31
+ ? IsTuple<T> extends true
32
+ ? SnakageTuple<T>
33
+ : SnakageMain<U>[]
34
+ : T extends Set<infer U>
35
+ ? Set<SnakageMain<U>>
36
+ : T extends Map<infer K, infer V>
37
+ ? Map<SnakageMain<K>, SnakageMain<V>>
38
+ : T extends WeakSet<any> | WeakMap<any, any>
39
+ ? never
40
+ : T extends
41
+ | Date
42
+ | Uint8Array
43
+ | Uint8ClampedArray
44
+ | Uint16Array
45
+ | Uint32Array
46
+ | BigUint64Array
47
+ | Int8Array
48
+ | Int16Array
49
+ | Int32Array
50
+ | BigInt64Array
51
+ | Float32Array
52
+ | Float64Array
53
+ | ArrayBuffer
54
+ | SharedArrayBuffer
55
+ | DataView
56
+ ? T
57
+ : {
58
+ [Key in keyof T as SnakageString<Key & string>]: SnakageMain<T[Key]>;
59
+ };
60
+
61
+ /* -----------------------------------------------------------
62
+ SPECIAL CASES
63
+ ----------------------------------------------------------- */
64
+ type IsTuple<T extends readonly any[] | { length: number }> = [T] extends [
65
+ never,
66
+ ]
67
+ ? false
68
+ : T extends readonly any[]
69
+ ? number extends T["length"]
70
+ ? false
71
+ : true
72
+ : false;
73
+ type SnakageTuple<T extends readonly any[]> = T extends []
74
+ ? []
75
+ : T extends [infer F]
76
+ ? [SnakageMain<F>]
77
+ : T extends [infer F, ...infer Rest extends readonly any[]]
78
+ ? [SnakageMain<F>, ...SnakageTuple<Rest>]
79
+ : T extends [(infer F)?]
80
+ ? [SnakageMain<F>?]
81
+ : T extends [(infer F)?, ...infer Rest extends readonly any[]]
82
+ ? [SnakageMain<F>?, ...SnakageTuple<Rest>]
83
+ : [];
84
+
85
+ type ValueOf<Instance> = IsValueOf<Instance, Boolean> extends true
86
+ ? boolean
87
+ : IsValueOf<Instance, Number> extends true
88
+ ? number
89
+ : IsValueOf<Instance, String> extends true
90
+ ? string
91
+ : Instance;
92
+
93
+ type IsValueOf<Instance, Object extends IValueOf<any>> = Instance extends Object
94
+ ? Object extends IValueOf<infer Primitive>
95
+ ? Instance extends Primitive
96
+ ? false
97
+ : true // not Primitive, but Object
98
+ : false // cannot be
99
+ : false;
100
+
101
+ interface IValueOf<T> {
102
+ valueOf(): T;
103
+ }
104
+
105
+ /* -----------------------------------------------------------
106
+ STRING CONVERTER
107
+ ----------------------------------------------------------- */
108
+ type SnakageString<Key extends string> = Key extends `${infer _}`
109
+ ? SnakageStringRepeatedly<Key, "">
110
+ : Key;
111
+ type SnakageStringRepeatedly<
112
+ S extends string,
113
+ Previous extends string,
114
+ > = S extends `${infer First}${infer Second}${infer Rest}`
115
+ ? `${Underscore<Previous, First>}${Lowercase<First>}${Underscore<
116
+ First,
117
+ Second
118
+ >}${Lowercase<Second>}${SnakageStringRepeatedly<Rest, Second>}`
119
+ : S extends `${infer First}`
120
+ ? `${Underscore<Previous, First>}${Lowercase<First>}`
121
+ : "";
122
+ type Underscore<First extends string, Second extends string> = First extends
123
+ | UpperAlphabetic
124
+ | ""
125
+ | "_"
126
+ ? ""
127
+ : Second extends UpperAlphabetic
128
+ ? "_"
129
+ : "";
130
+ type UpperAlphabetic =
131
+ | "A"
132
+ | "B"
133
+ | "C"
134
+ | "D"
135
+ | "E"
136
+ | "F"
137
+ | "G"
138
+ | "H"
139
+ | "I"
140
+ | "J"
141
+ | "K"
142
+ | "L"
143
+ | "M"
144
+ | "N"
145
+ | "O"
146
+ | "P"
147
+ | "Q"
148
+ | "R"
149
+ | "S"
150
+ | "T"
151
+ | "U"
152
+ | "V"
153
+ | "W"
154
+ | "X"
155
+ | "Y"
156
+ | "Z";