typia 3.4.13 → 3.4.14

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 (157) hide show
  1. package/README.md +9 -8
  2. package/lib/factories/internal/iterate_metadata_object.js +4 -2
  3. package/lib/factories/internal/iterate_metadata_object.js.map +1 -1
  4. package/package.json +1 -1
  5. package/src/IValidation.ts +21 -21
  6. package/src/Primitive.ts +82 -82
  7. package/src/TypeGuardError.ts +36 -36
  8. package/src/executable/internal/CommandParser.ts +15 -15
  9. package/src/executable/internal/TypiaSetupWizard.ts +175 -175
  10. package/src/executable/typia.ts +46 -46
  11. package/src/factories/CommentFactory.ts +10 -10
  12. package/src/factories/ExpressionFactory.ts +66 -66
  13. package/src/factories/IdentifierFactory.ts +72 -72
  14. package/src/factories/LiteralFactory.ts +44 -44
  15. package/src/factories/MetadataCollection.ts +122 -122
  16. package/src/factories/MetadataFactory.ts +46 -46
  17. package/src/factories/MetadataTagFactory.ts +347 -347
  18. package/src/factories/StatementFactory.ts +60 -60
  19. package/src/factories/TemplateFactory.ts +56 -56
  20. package/src/factories/TypeFactory.ts +101 -101
  21. package/src/factories/ValueFactory.ts +12 -12
  22. package/src/factories/internal/MetadataHelper.ts +12 -12
  23. package/src/factories/internal/emplace_metadata_object.ts +140 -140
  24. package/src/factories/internal/explore_metadata.ts +91 -91
  25. package/src/factories/internal/iterate_metadata.ts +80 -80
  26. package/src/factories/internal/iterate_metadata_array.ts +29 -29
  27. package/src/factories/internal/iterate_metadata_atomic.ts +59 -59
  28. package/src/factories/internal/iterate_metadata_coalesce.ts +33 -33
  29. package/src/factories/internal/iterate_metadata_constant.ts +58 -58
  30. package/src/factories/internal/iterate_metadata_map.ts +41 -41
  31. package/src/factories/internal/iterate_metadata_native.ts +227 -227
  32. package/src/factories/internal/iterate_metadata_object.ts +48 -45
  33. package/src/factories/internal/iterate_metadata_resolve.ts +27 -27
  34. package/src/factories/internal/iterate_metadata_set.ts +33 -33
  35. package/src/factories/internal/iterate_metadata_template.ts +38 -38
  36. package/src/factories/internal/iterate_metadata_tuple.ts +45 -45
  37. package/src/factories/internal/iterate_metadata_union.ts +59 -59
  38. package/src/functional/$every.ts +11 -11
  39. package/src/functional/$guard.ts +35 -35
  40. package/src/functional/$is_email.ts +5 -5
  41. package/src/functional/$is_ipv4.ts +5 -5
  42. package/src/functional/$is_ipv6.ts +5 -5
  43. package/src/functional/$is_url.ts +5 -5
  44. package/src/functional/$is_uuid.ts +5 -5
  45. package/src/functional/$join.ts +50 -50
  46. package/src/functional/$number.ts +19 -19
  47. package/src/functional/$report.ts +15 -15
  48. package/src/functional/$rest.ts +3 -3
  49. package/src/functional/$string.ts +37 -37
  50. package/src/functional/$tail.ts +6 -6
  51. package/src/index.ts +4 -4
  52. package/src/metadata/IJsDocTagInfo.ts +10 -10
  53. package/src/metadata/IMetadata.ts +25 -25
  54. package/src/metadata/IMetadataApplication.ts +7 -7
  55. package/src/metadata/IMetadataConstant.ts +16 -16
  56. package/src/metadata/IMetadataEntry.ts +6 -6
  57. package/src/metadata/IMetadataObject.ts +29 -29
  58. package/src/metadata/IMetadataProperty.ts +11 -11
  59. package/src/metadata/IMetadataTag.ts +122 -122
  60. package/src/metadata/Metadata.ts +477 -477
  61. package/src/metadata/MetadataConstant.ts +3 -3
  62. package/src/metadata/MetadataObject.ts +131 -131
  63. package/src/metadata/MetadataProperty.ts +64 -64
  64. package/src/module.ts +1535 -1535
  65. package/src/programmers/ApplicationProgrammer.ts +55 -55
  66. package/src/programmers/AssertParseProgrammer.ts +45 -45
  67. package/src/programmers/AssertProgrammer.ts +444 -444
  68. package/src/programmers/AssertStringifyProgrammer.ts +45 -45
  69. package/src/programmers/CheckerProgrammer.ts +804 -804
  70. package/src/programmers/FeatureProgrammer.ts +327 -327
  71. package/src/programmers/IsParseProgrammer.ts +51 -51
  72. package/src/programmers/IsProgrammer.ts +172 -172
  73. package/src/programmers/IsStringifyProgrammer.ts +49 -49
  74. package/src/programmers/StringifyProgrammer.ts +756 -756
  75. package/src/programmers/ValidateParseProgrammer.ts +49 -49
  76. package/src/programmers/ValidateProgrammer.ts +236 -236
  77. package/src/programmers/ValidateStringifyProgrammer.ts +60 -60
  78. package/src/programmers/helpers/AtomicPredicator.ts +15 -15
  79. package/src/programmers/helpers/FunctionImporeter.ts +31 -31
  80. package/src/programmers/helpers/IExpressionEntry.ts +10 -10
  81. package/src/programmers/helpers/OptionPredicator.ts +11 -11
  82. package/src/programmers/helpers/StringifyJoinder.ts +111 -111
  83. package/src/programmers/helpers/StringifyPredicator.ts +18 -18
  84. package/src/programmers/helpers/UnionExplorer.ts +437 -437
  85. package/src/programmers/helpers/UnionPredicator.ts +81 -81
  86. package/src/programmers/internal/application_array.ts +45 -45
  87. package/src/programmers/internal/application_boolean.ts +17 -17
  88. package/src/programmers/internal/application_constant.ts +29 -29
  89. package/src/programmers/internal/application_default.ts +17 -17
  90. package/src/programmers/internal/application_default_string.ts +32 -32
  91. package/src/programmers/internal/application_native.ts +29 -29
  92. package/src/programmers/internal/application_number.ts +76 -76
  93. package/src/programmers/internal/application_object.ts +103 -103
  94. package/src/programmers/internal/application_schema.ts +221 -221
  95. package/src/programmers/internal/application_string.ts +49 -49
  96. package/src/programmers/internal/application_templates.ts +27 -27
  97. package/src/programmers/internal/application_tuple.ts +25 -25
  98. package/src/programmers/internal/check_array.ts +44 -44
  99. package/src/programmers/internal/check_dynamic_properties.ts +146 -146
  100. package/src/programmers/internal/check_everything.ts +25 -25
  101. package/src/programmers/internal/check_length.ts +46 -46
  102. package/src/programmers/internal/check_native.ts +9 -9
  103. package/src/programmers/internal/check_number.ts +178 -178
  104. package/src/programmers/internal/check_object.ts +42 -42
  105. package/src/programmers/internal/check_string.ts +24 -24
  106. package/src/programmers/internal/check_string_tags.ts +63 -63
  107. package/src/programmers/internal/check_template.ts +50 -50
  108. package/src/programmers/internal/decode_union_object.ts +73 -73
  109. package/src/programmers/internal/feature_object_entries.ts +49 -49
  110. package/src/programmers/internal/metadata_to_pattern.ts +31 -31
  111. package/src/programmers/internal/stringify_dynamic_properties.ts +164 -164
  112. package/src/programmers/internal/stringify_native.ts +8 -8
  113. package/src/programmers/internal/stringify_regular_properties.ts +81 -81
  114. package/src/programmers/internal/template_to_pattern.ts +15 -15
  115. package/src/schemas/IJsonApplication.ts +9 -9
  116. package/src/schemas/IJsonComponents.ts +24 -24
  117. package/src/schemas/IJsonSchema.ts +92 -92
  118. package/src/transform.ts +20 -20
  119. package/src/transformers/CallExpressionTransformer.ts +124 -124
  120. package/src/transformers/ExpressionWithArgumentTransformer.ts +66 -66
  121. package/src/transformers/FileTransformer.ts +49 -49
  122. package/src/transformers/IProject.ts +11 -11
  123. package/src/transformers/ITransformOptions.ts +4 -4
  124. package/src/transformers/NodeTransformer.ts +19 -19
  125. package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +114 -114
  126. package/src/transformers/features/miscellaneous/CreateInstanceTransformer.ts +41 -41
  127. package/src/transformers/features/miscellaneous/MetadataTransformer.ts +55 -55
  128. package/src/transformers/features/parsers/AssertParseTransformer.ts +36 -36
  129. package/src/transformers/features/parsers/CreateAssertParseTransformer.ts +32 -32
  130. package/src/transformers/features/parsers/CreateIsParseTransformer.ts +32 -32
  131. package/src/transformers/features/parsers/CreateValidateParseTransformer.ts +32 -32
  132. package/src/transformers/features/parsers/IsParseTransformer.ts +36 -36
  133. package/src/transformers/features/parsers/ValidateParseTransformer.ts +36 -36
  134. package/src/transformers/features/stringifiers/AssertStringifyTransformer.ts +38 -38
  135. package/src/transformers/features/stringifiers/CreateAssertStringifyTransformer.ts +32 -32
  136. package/src/transformers/features/stringifiers/CreateIsStringifyTransformer.ts +32 -32
  137. package/src/transformers/features/stringifiers/CreateStringifyTransformer.ts +31 -31
  138. package/src/transformers/features/stringifiers/CreateValidateStringifyProgrammer.ts +32 -32
  139. package/src/transformers/features/stringifiers/IsStringifyTransformer.ts +38 -38
  140. package/src/transformers/features/stringifiers/StringifyTransformer.ts +36 -36
  141. package/src/transformers/features/stringifiers/ValidateStringifyTransformer.ts +38 -38
  142. package/src/transformers/features/validators/AssertTransformer.ts +43 -43
  143. package/src/transformers/features/validators/CreateAssertTransformer.ts +35 -35
  144. package/src/transformers/features/validators/CreateIsTransformer.ts +35 -35
  145. package/src/transformers/features/validators/CreateValidateTransformer.ts +35 -35
  146. package/src/transformers/features/validators/IsTransformer.ts +43 -43
  147. package/src/transformers/features/validators/ValidateTransformer.ts +43 -43
  148. package/src/typings/Atomic.ts +17 -17
  149. package/src/typings/ClassProperties.ts +5 -5
  150. package/src/typings/OmitNever.ts +3 -3
  151. package/src/typings/SpecialFields.ts +3 -3
  152. package/src/typings/Writable.ts +11 -11
  153. package/src/utils/ArrayUtil.ts +49 -49
  154. package/src/utils/Escaper.ts +50 -50
  155. package/src/utils/MapUtil.ts +14 -14
  156. package/src/utils/PatternUtil.ts +30 -30
  157. package/src/utils/Singleton.ts +17 -17
@@ -1,31 +1,31 @@
1
- import ts from "typescript";
2
-
3
- import { StringifyProgrammer } from "../../../programmers/StringifyProgrammer";
4
-
5
- import { IProject } from "../../IProject";
6
-
7
- export namespace CreateStringifyTransformer {
8
- export function transform(
9
- project: IProject,
10
- modulo: ts.LeftHandSideExpression,
11
- expression: ts.CallExpression,
12
- ): ts.Expression {
13
- // CHECK GENERIC ARGUMENT EXISTENCE
14
- if (!expression.typeArguments || !expression.typeArguments[0])
15
- throw new Error(ErrorMessages.NOT_SPECIFIED);
16
-
17
- // GET TYPE INFO
18
- const type: ts.Type = project.checker.getTypeFromTypeNode(
19
- expression.typeArguments[0],
20
- );
21
- if (type.isTypeParameter())
22
- throw new Error(ErrorMessages.GENERIC_ARGUMENT);
23
-
24
- return StringifyProgrammer.generate(project, modulo)(type);
25
- }
26
- }
27
-
28
- const enum ErrorMessages {
29
- NOT_SPECIFIED = "Error on typia.stringify(): generic argument is not specified.",
30
- GENERIC_ARGUMENT = "Error on typia.stringify(): non-specified generic argument.",
31
- }
1
+ import ts from "typescript";
2
+
3
+ import { StringifyProgrammer } from "../../../programmers/StringifyProgrammer";
4
+
5
+ import { IProject } from "../../IProject";
6
+
7
+ export namespace CreateStringifyTransformer {
8
+ export function transform(
9
+ project: IProject,
10
+ modulo: ts.LeftHandSideExpression,
11
+ expression: ts.CallExpression,
12
+ ): ts.Expression {
13
+ // CHECK GENERIC ARGUMENT EXISTENCE
14
+ if (!expression.typeArguments || !expression.typeArguments[0])
15
+ throw new Error(ErrorMessages.NOT_SPECIFIED);
16
+
17
+ // GET TYPE INFO
18
+ const type: ts.Type = project.checker.getTypeFromTypeNode(
19
+ expression.typeArguments[0],
20
+ );
21
+ if (type.isTypeParameter())
22
+ throw new Error(ErrorMessages.GENERIC_ARGUMENT);
23
+
24
+ return StringifyProgrammer.generate(project, modulo)(type);
25
+ }
26
+ }
27
+
28
+ const enum ErrorMessages {
29
+ NOT_SPECIFIED = "Error on typia.stringify(): generic argument is not specified.",
30
+ GENERIC_ARGUMENT = "Error on typia.stringify(): non-specified generic argument.",
31
+ }
@@ -1,32 +1,32 @@
1
- import ts from "typescript";
2
-
3
- import { ValidateStringifyProgrammer } from "../../../programmers/ValidateStringifyProgrammer";
4
-
5
- import { IProject } from "../../IProject";
6
-
7
- export namespace CreateValidateStringifyTransformer {
8
- export function transform(
9
- project: IProject,
10
- modulo: ts.LeftHandSideExpression,
11
- expression: ts.CallExpression,
12
- ): ts.Expression {
13
- // CHECK GENERIC ARGUMENT EXISTENCE
14
- if (!expression.typeArguments || !expression.typeArguments[0])
15
- throw new Error(ErrorMessages.NOT_SPECIFIED);
16
-
17
- // GET TYPE INFO
18
- const type: ts.Type = project.checker.getTypeFromTypeNode(
19
- expression.typeArguments[0],
20
- );
21
- if (type.isTypeParameter())
22
- throw new Error(ErrorMessages.GENERIC_ARGUMENT);
23
-
24
- // DO TRANSFORM
25
- return ValidateStringifyProgrammer.generate(project, modulo)(type);
26
- }
27
- }
28
-
29
- const enum ErrorMessages {
30
- NOT_SPECIFIED = "Error on typia.validateStringify(): generic argument is not specified.",
31
- GENERIC_ARGUMENT = "Error on typia.validateStringify(): non-specified generic argument.",
32
- }
1
+ import ts from "typescript";
2
+
3
+ import { ValidateStringifyProgrammer } from "../../../programmers/ValidateStringifyProgrammer";
4
+
5
+ import { IProject } from "../../IProject";
6
+
7
+ export namespace CreateValidateStringifyTransformer {
8
+ export function transform(
9
+ project: IProject,
10
+ modulo: ts.LeftHandSideExpression,
11
+ expression: ts.CallExpression,
12
+ ): ts.Expression {
13
+ // CHECK GENERIC ARGUMENT EXISTENCE
14
+ if (!expression.typeArguments || !expression.typeArguments[0])
15
+ throw new Error(ErrorMessages.NOT_SPECIFIED);
16
+
17
+ // GET TYPE INFO
18
+ const type: ts.Type = project.checker.getTypeFromTypeNode(
19
+ expression.typeArguments[0],
20
+ );
21
+ if (type.isTypeParameter())
22
+ throw new Error(ErrorMessages.GENERIC_ARGUMENT);
23
+
24
+ // DO TRANSFORM
25
+ return ValidateStringifyProgrammer.generate(project, modulo)(type);
26
+ }
27
+ }
28
+
29
+ const enum ErrorMessages {
30
+ NOT_SPECIFIED = "Error on typia.validateStringify(): generic argument is not specified.",
31
+ GENERIC_ARGUMENT = "Error on typia.validateStringify(): non-specified generic argument.",
32
+ }
@@ -1,38 +1,38 @@
1
- import ts from "typescript";
2
-
3
- import { IsStringifyProgrammer } from "../../../programmers/IsStringifyProgrammer";
4
-
5
- import { IProject } from "../../IProject";
6
-
7
- export namespace IsStringifyTransformer {
8
- export function transform(
9
- project: IProject,
10
- modulo: ts.LeftHandSideExpression,
11
- expression: ts.CallExpression,
12
- ): ts.Expression {
13
- if (expression.arguments.length !== 1)
14
- throw new Error(ErrorMessages.NO_INPUT_VALUE);
15
-
16
- // GET TYPE INFO
17
- const type: ts.Type =
18
- expression.typeArguments && expression.typeArguments[0]
19
- ? project.checker.getTypeFromTypeNode(
20
- expression.typeArguments[0],
21
- )
22
- : project.checker.getTypeAtLocation(expression.arguments[0]!);
23
- if (type.isTypeParameter())
24
- throw new Error(ErrorMessages.GENERIC_ARGUMENT);
25
-
26
- // DO TRANSFORM
27
- return ts.factory.createCallExpression(
28
- IsStringifyProgrammer.generate(project, modulo)(type),
29
- undefined,
30
- [expression.arguments[0]!],
31
- );
32
- }
33
- }
34
-
35
- const enum ErrorMessages {
36
- NO_INPUT_VALUE = "Error on typia.isStringify(): no input value.",
37
- GENERIC_ARGUMENT = "Error on typia.isStringify(): non-specified generic argument.",
38
- }
1
+ import ts from "typescript";
2
+
3
+ import { IsStringifyProgrammer } from "../../../programmers/IsStringifyProgrammer";
4
+
5
+ import { IProject } from "../../IProject";
6
+
7
+ export namespace IsStringifyTransformer {
8
+ export function transform(
9
+ project: IProject,
10
+ modulo: ts.LeftHandSideExpression,
11
+ expression: ts.CallExpression,
12
+ ): ts.Expression {
13
+ if (expression.arguments.length !== 1)
14
+ throw new Error(ErrorMessages.NO_INPUT_VALUE);
15
+
16
+ // GET TYPE INFO
17
+ const type: ts.Type =
18
+ expression.typeArguments && expression.typeArguments[0]
19
+ ? project.checker.getTypeFromTypeNode(
20
+ expression.typeArguments[0],
21
+ )
22
+ : project.checker.getTypeAtLocation(expression.arguments[0]!);
23
+ if (type.isTypeParameter())
24
+ throw new Error(ErrorMessages.GENERIC_ARGUMENT);
25
+
26
+ // DO TRANSFORM
27
+ return ts.factory.createCallExpression(
28
+ IsStringifyProgrammer.generate(project, modulo)(type),
29
+ undefined,
30
+ [expression.arguments[0]!],
31
+ );
32
+ }
33
+ }
34
+
35
+ const enum ErrorMessages {
36
+ NO_INPUT_VALUE = "Error on typia.isStringify(): no input value.",
37
+ GENERIC_ARGUMENT = "Error on typia.isStringify(): non-specified generic argument.",
38
+ }
@@ -1,36 +1,36 @@
1
- import ts from "typescript";
2
-
3
- import { StringifyProgrammer } from "../../../programmers/StringifyProgrammer";
4
-
5
- import { IProject } from "../../IProject";
6
-
7
- export namespace StringifyTransformer {
8
- export function transform(
9
- project: IProject,
10
- modulo: ts.LeftHandSideExpression,
11
- expression: ts.CallExpression,
12
- ): ts.Expression {
13
- if (expression.arguments.length !== 1)
14
- throw new Error(ErrorMessages.NO_INPUT_VALUE);
15
-
16
- const type: ts.Type =
17
- expression.typeArguments && expression.typeArguments[0]
18
- ? project.checker.getTypeFromTypeNode(
19
- expression.typeArguments[0],
20
- )
21
- : project.checker.getTypeAtLocation(expression.arguments[0]!);
22
- if (type.isTypeParameter())
23
- throw new Error(ErrorMessages.GENERIC_ARGUMENT);
24
-
25
- return ts.factory.createCallExpression(
26
- StringifyProgrammer.generate(project, modulo)(type),
27
- undefined,
28
- [expression.arguments[0]!],
29
- );
30
- }
31
- }
32
-
33
- const enum ErrorMessages {
34
- NO_INPUT_VALUE = "Error on typia.stringify(): no input value.",
35
- GENERIC_ARGUMENT = "Error on typia.stringify(): non-specified generic argument.",
36
- }
1
+ import ts from "typescript";
2
+
3
+ import { StringifyProgrammer } from "../../../programmers/StringifyProgrammer";
4
+
5
+ import { IProject } from "../../IProject";
6
+
7
+ export namespace StringifyTransformer {
8
+ export function transform(
9
+ project: IProject,
10
+ modulo: ts.LeftHandSideExpression,
11
+ expression: ts.CallExpression,
12
+ ): ts.Expression {
13
+ if (expression.arguments.length !== 1)
14
+ throw new Error(ErrorMessages.NO_INPUT_VALUE);
15
+
16
+ const type: ts.Type =
17
+ expression.typeArguments && expression.typeArguments[0]
18
+ ? project.checker.getTypeFromTypeNode(
19
+ expression.typeArguments[0],
20
+ )
21
+ : project.checker.getTypeAtLocation(expression.arguments[0]!);
22
+ if (type.isTypeParameter())
23
+ throw new Error(ErrorMessages.GENERIC_ARGUMENT);
24
+
25
+ return ts.factory.createCallExpression(
26
+ StringifyProgrammer.generate(project, modulo)(type),
27
+ undefined,
28
+ [expression.arguments[0]!],
29
+ );
30
+ }
31
+ }
32
+
33
+ const enum ErrorMessages {
34
+ NO_INPUT_VALUE = "Error on typia.stringify(): no input value.",
35
+ GENERIC_ARGUMENT = "Error on typia.stringify(): non-specified generic argument.",
36
+ }
@@ -1,38 +1,38 @@
1
- import ts from "typescript";
2
-
3
- import { ValidateStringifyProgrammer } from "../../../programmers/ValidateStringifyProgrammer";
4
-
5
- import { IProject } from "../../IProject";
6
-
7
- export namespace ValidateStringifyTransformer {
8
- export function transform(
9
- project: IProject,
10
- modulo: ts.LeftHandSideExpression,
11
- expression: ts.CallExpression,
12
- ): ts.Expression {
13
- if (expression.arguments.length !== 1)
14
- throw new Error(ErrorMessages.NO_INPUT_VALUE);
15
-
16
- // GET TYPE INFO
17
- const type: ts.Type =
18
- expression.typeArguments && expression.typeArguments[0]
19
- ? project.checker.getTypeFromTypeNode(
20
- expression.typeArguments[0],
21
- )
22
- : project.checker.getTypeAtLocation(expression.arguments[0]!);
23
- if (type.isTypeParameter())
24
- throw new Error(ErrorMessages.GENERIC_ARGUMENT);
25
-
26
- // DO TRANSFORM
27
- return ts.factory.createCallExpression(
28
- ValidateStringifyProgrammer.generate(project, modulo)(type),
29
- undefined,
30
- [expression.arguments[0]!],
31
- );
32
- }
33
- }
34
-
35
- const enum ErrorMessages {
36
- NO_INPUT_VALUE = "Error on typia.validateStringify(): no input value.",
37
- GENERIC_ARGUMENT = "Error on typia.validateStringify(): non-specified generic argument.",
38
- }
1
+ import ts from "typescript";
2
+
3
+ import { ValidateStringifyProgrammer } from "../../../programmers/ValidateStringifyProgrammer";
4
+
5
+ import { IProject } from "../../IProject";
6
+
7
+ export namespace ValidateStringifyTransformer {
8
+ export function transform(
9
+ project: IProject,
10
+ modulo: ts.LeftHandSideExpression,
11
+ expression: ts.CallExpression,
12
+ ): ts.Expression {
13
+ if (expression.arguments.length !== 1)
14
+ throw new Error(ErrorMessages.NO_INPUT_VALUE);
15
+
16
+ // GET TYPE INFO
17
+ const type: ts.Type =
18
+ expression.typeArguments && expression.typeArguments[0]
19
+ ? project.checker.getTypeFromTypeNode(
20
+ expression.typeArguments[0],
21
+ )
22
+ : project.checker.getTypeAtLocation(expression.arguments[0]!);
23
+ if (type.isTypeParameter())
24
+ throw new Error(ErrorMessages.GENERIC_ARGUMENT);
25
+
26
+ // DO TRANSFORM
27
+ return ts.factory.createCallExpression(
28
+ ValidateStringifyProgrammer.generate(project, modulo)(type),
29
+ undefined,
30
+ [expression.arguments[0]!],
31
+ );
32
+ }
33
+ }
34
+
35
+ const enum ErrorMessages {
36
+ NO_INPUT_VALUE = "Error on typia.validateStringify(): no input value.",
37
+ GENERIC_ARGUMENT = "Error on typia.validateStringify(): non-specified generic argument.",
38
+ }
@@ -1,43 +1,43 @@
1
- import ts from "typescript";
2
-
3
- import { AssertProgrammer } from "../../../programmers/AssertProgrammer";
4
-
5
- import { IProject } from "../../IProject";
6
-
7
- export namespace AssertTransformer {
8
- export function transform(equals: boolean) {
9
- const SYMBOL = equals ? "assertEquals" : "assert";
10
- const MESSAGES = {
11
- NO_INPUT_VALUE: `Error on typia.${SYMBOL}(): no input value.`,
12
- GENERIC_ARGUMENT: `Error on typia.${SYMBOL}(): non-specified generic argument.`,
13
- };
14
-
15
- return function (
16
- project: IProject,
17
- modulo: ts.LeftHandSideExpression,
18
- expression: ts.CallExpression,
19
- ): ts.Expression {
20
- if (expression.arguments.length !== 1)
21
- throw new Error(MESSAGES.NO_INPUT_VALUE);
22
-
23
- // GET TYPE INFO
24
- const type: ts.Type =
25
- expression.typeArguments && expression.typeArguments[0]
26
- ? project.checker.getTypeFromTypeNode(
27
- expression.typeArguments[0],
28
- )
29
- : project.checker.getTypeAtLocation(
30
- expression.arguments[0]!,
31
- );
32
- if (type.isTypeParameter())
33
- throw new Error(MESSAGES.GENERIC_ARGUMENT);
34
-
35
- // DO TRANSFORM
36
- return ts.factory.createCallExpression(
37
- AssertProgrammer.generate(project, modulo, equals)(type),
38
- undefined,
39
- [expression.arguments[0]!],
40
- );
41
- };
42
- }
43
- }
1
+ import ts from "typescript";
2
+
3
+ import { AssertProgrammer } from "../../../programmers/AssertProgrammer";
4
+
5
+ import { IProject } from "../../IProject";
6
+
7
+ export namespace AssertTransformer {
8
+ export function transform(equals: boolean) {
9
+ const SYMBOL = equals ? "assertEquals" : "assert";
10
+ const MESSAGES = {
11
+ NO_INPUT_VALUE: `Error on typia.${SYMBOL}(): no input value.`,
12
+ GENERIC_ARGUMENT: `Error on typia.${SYMBOL}(): non-specified generic argument.`,
13
+ };
14
+
15
+ return function (
16
+ project: IProject,
17
+ modulo: ts.LeftHandSideExpression,
18
+ expression: ts.CallExpression,
19
+ ): ts.Expression {
20
+ if (expression.arguments.length !== 1)
21
+ throw new Error(MESSAGES.NO_INPUT_VALUE);
22
+
23
+ // GET TYPE INFO
24
+ const type: ts.Type =
25
+ expression.typeArguments && expression.typeArguments[0]
26
+ ? project.checker.getTypeFromTypeNode(
27
+ expression.typeArguments[0],
28
+ )
29
+ : project.checker.getTypeAtLocation(
30
+ expression.arguments[0]!,
31
+ );
32
+ if (type.isTypeParameter())
33
+ throw new Error(MESSAGES.GENERIC_ARGUMENT);
34
+
35
+ // DO TRANSFORM
36
+ return ts.factory.createCallExpression(
37
+ AssertProgrammer.generate(project, modulo, equals)(type),
38
+ undefined,
39
+ [expression.arguments[0]!],
40
+ );
41
+ };
42
+ }
43
+ }
@@ -1,35 +1,35 @@
1
- import ts from "typescript";
2
-
3
- import { AssertProgrammer } from "../../../programmers/AssertProgrammer";
4
-
5
- import { IProject } from "../../IProject";
6
-
7
- export namespace CreateAssertTransformer {
8
- export function transform(equals: boolean) {
9
- const SYMBOL = equals ? "createAssertEquals" : "createAssert";
10
- const MESSAGES = {
11
- NOT_SPECIFIED: `Error on typia.${SYMBOL}(): generic argument is not specified.`,
12
- GENERIC_ARGUMENT: `Error on typia.${SYMBOL}(): non-specified generic argument.`,
13
- };
14
-
15
- return function (
16
- project: IProject,
17
- modulo: ts.LeftHandSideExpression,
18
- expression: ts.CallExpression,
19
- ): ts.Expression {
20
- // CHECK GENERIC ARGUMENT EXISTENCE
21
- if (!expression.typeArguments || !expression.typeArguments[0])
22
- throw new Error(MESSAGES.NOT_SPECIFIED);
23
-
24
- // GET TYPE INFO
25
- const type: ts.Type = project.checker.getTypeFromTypeNode(
26
- expression.typeArguments[0],
27
- );
28
- if (type.isTypeParameter())
29
- throw new Error(MESSAGES.GENERIC_ARGUMENT);
30
-
31
- // DO TRANSFORM
32
- return AssertProgrammer.generate(project, modulo, equals)(type);
33
- };
34
- }
35
- }
1
+ import ts from "typescript";
2
+
3
+ import { AssertProgrammer } from "../../../programmers/AssertProgrammer";
4
+
5
+ import { IProject } from "../../IProject";
6
+
7
+ export namespace CreateAssertTransformer {
8
+ export function transform(equals: boolean) {
9
+ const SYMBOL = equals ? "createAssertEquals" : "createAssert";
10
+ const MESSAGES = {
11
+ NOT_SPECIFIED: `Error on typia.${SYMBOL}(): generic argument is not specified.`,
12
+ GENERIC_ARGUMENT: `Error on typia.${SYMBOL}(): non-specified generic argument.`,
13
+ };
14
+
15
+ return function (
16
+ project: IProject,
17
+ modulo: ts.LeftHandSideExpression,
18
+ expression: ts.CallExpression,
19
+ ): ts.Expression {
20
+ // CHECK GENERIC ARGUMENT EXISTENCE
21
+ if (!expression.typeArguments || !expression.typeArguments[0])
22
+ throw new Error(MESSAGES.NOT_SPECIFIED);
23
+
24
+ // GET TYPE INFO
25
+ const type: ts.Type = project.checker.getTypeFromTypeNode(
26
+ expression.typeArguments[0],
27
+ );
28
+ if (type.isTypeParameter())
29
+ throw new Error(MESSAGES.GENERIC_ARGUMENT);
30
+
31
+ // DO TRANSFORM
32
+ return AssertProgrammer.generate(project, modulo, equals)(type);
33
+ };
34
+ }
35
+ }
@@ -1,35 +1,35 @@
1
- import ts from "typescript";
2
-
3
- import { IsProgrammer } from "../../../programmers/IsProgrammer";
4
-
5
- import { IProject } from "../../IProject";
6
-
7
- export namespace CreateIsTransformer {
8
- export function transform(equals: boolean) {
9
- const SYMBOL = equals ? "createEquals" : "createIs";
10
- const MESSAGES = {
11
- NOT_SPECIFIED: `Error on typia.${SYMBOL}(): generic argument is not specified.`,
12
- GENERIC_ARGUMENT: `Error on typia.${SYMBOL}(): non-specified generic argument.`,
13
- };
14
-
15
- return function (
16
- project: IProject,
17
- modulo: ts.LeftHandSideExpression,
18
- expression: ts.CallExpression,
19
- ): ts.Expression {
20
- // CHECK GENERIC ARGUMENT EXISTENCE
21
- if (!expression.typeArguments || !expression.typeArguments[0])
22
- throw new Error(MESSAGES.NOT_SPECIFIED);
23
-
24
- // GET TYPE INFO
25
- const type: ts.Type = project.checker.getTypeFromTypeNode(
26
- expression.typeArguments[0],
27
- );
28
- if (type.isTypeParameter())
29
- throw new Error(MESSAGES.GENERIC_ARGUMENT);
30
-
31
- // DO TRANSFORM
32
- return IsProgrammer.generate(project, modulo, equals)(type);
33
- };
34
- }
35
- }
1
+ import ts from "typescript";
2
+
3
+ import { IsProgrammer } from "../../../programmers/IsProgrammer";
4
+
5
+ import { IProject } from "../../IProject";
6
+
7
+ export namespace CreateIsTransformer {
8
+ export function transform(equals: boolean) {
9
+ const SYMBOL = equals ? "createEquals" : "createIs";
10
+ const MESSAGES = {
11
+ NOT_SPECIFIED: `Error on typia.${SYMBOL}(): generic argument is not specified.`,
12
+ GENERIC_ARGUMENT: `Error on typia.${SYMBOL}(): non-specified generic argument.`,
13
+ };
14
+
15
+ return function (
16
+ project: IProject,
17
+ modulo: ts.LeftHandSideExpression,
18
+ expression: ts.CallExpression,
19
+ ): ts.Expression {
20
+ // CHECK GENERIC ARGUMENT EXISTENCE
21
+ if (!expression.typeArguments || !expression.typeArguments[0])
22
+ throw new Error(MESSAGES.NOT_SPECIFIED);
23
+
24
+ // GET TYPE INFO
25
+ const type: ts.Type = project.checker.getTypeFromTypeNode(
26
+ expression.typeArguments[0],
27
+ );
28
+ if (type.isTypeParameter())
29
+ throw new Error(MESSAGES.GENERIC_ARGUMENT);
30
+
31
+ // DO TRANSFORM
32
+ return IsProgrammer.generate(project, modulo, equals)(type);
33
+ };
34
+ }
35
+ }
@@ -1,35 +1,35 @@
1
- import ts from "typescript";
2
-
3
- import { ValidateProgrammer } from "../../../programmers/ValidateProgrammer";
4
-
5
- import { IProject } from "../../IProject";
6
-
7
- export namespace CreateValidateTransformer {
8
- export function transform(equals: boolean) {
9
- const SYMBOL = equals ? "createValidateEquals" : "createValidate";
10
- const MESSAGES = {
11
- NOT_SPECIFIED: `Error on typia.${SYMBOL}(): generic argument is not specified.`,
12
- GENERIC_ARGUMENT: `Error on typia.${SYMBOL}(): non-specified generic argument.`,
13
- };
14
-
15
- return function (
16
- project: IProject,
17
- modulo: ts.LeftHandSideExpression,
18
- expression: ts.CallExpression,
19
- ): ts.Expression {
20
- // CHECK GENERIC ARGUMENT EXISTENCE
21
- if (!expression.typeArguments || !expression.typeArguments[0])
22
- throw new Error(MESSAGES.NOT_SPECIFIED);
23
-
24
- // GET TYPE INFO
25
- const type: ts.Type = project.checker.getTypeFromTypeNode(
26
- expression.typeArguments[0],
27
- );
28
- if (type.isTypeParameter())
29
- throw new Error(MESSAGES.GENERIC_ARGUMENT);
30
-
31
- // DO TRANSFORM
32
- return ValidateProgrammer.generate(project, modulo, equals)(type);
33
- };
34
- }
35
- }
1
+ import ts from "typescript";
2
+
3
+ import { ValidateProgrammer } from "../../../programmers/ValidateProgrammer";
4
+
5
+ import { IProject } from "../../IProject";
6
+
7
+ export namespace CreateValidateTransformer {
8
+ export function transform(equals: boolean) {
9
+ const SYMBOL = equals ? "createValidateEquals" : "createValidate";
10
+ const MESSAGES = {
11
+ NOT_SPECIFIED: `Error on typia.${SYMBOL}(): generic argument is not specified.`,
12
+ GENERIC_ARGUMENT: `Error on typia.${SYMBOL}(): non-specified generic argument.`,
13
+ };
14
+
15
+ return function (
16
+ project: IProject,
17
+ modulo: ts.LeftHandSideExpression,
18
+ expression: ts.CallExpression,
19
+ ): ts.Expression {
20
+ // CHECK GENERIC ARGUMENT EXISTENCE
21
+ if (!expression.typeArguments || !expression.typeArguments[0])
22
+ throw new Error(MESSAGES.NOT_SPECIFIED);
23
+
24
+ // GET TYPE INFO
25
+ const type: ts.Type = project.checker.getTypeFromTypeNode(
26
+ expression.typeArguments[0],
27
+ );
28
+ if (type.isTypeParameter())
29
+ throw new Error(MESSAGES.GENERIC_ARGUMENT);
30
+
31
+ // DO TRANSFORM
32
+ return ValidateProgrammer.generate(project, modulo, equals)(type);
33
+ };
34
+ }
35
+ }