typia 6.7.0 → 6.7.1

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 (85) hide show
  1. package/lib/programmers/AssertProgrammer.d.ts +0 -1
  2. package/lib/programmers/AssertProgrammer.js.map +1 -1
  3. package/lib/programmers/CheckerProgrammer.d.ts +1 -1
  4. package/lib/programmers/FeatureProgrammer.d.ts +1 -1
  5. package/lib/programmers/IsProgrammer.d.ts +1 -1
  6. package/lib/programmers/RandomProgrammer.d.ts +10 -1
  7. package/lib/programmers/RandomProgrammer.js +62 -37
  8. package/lib/programmers/RandomProgrammer.js.map +1 -1
  9. package/lib/programmers/ValidateProgrammer.d.ts +1 -1
  10. package/lib/programmers/json/JsonIsParseProgrammer.d.ts +1 -1
  11. package/lib/programmers/json/JsonIsStringifyProgrammer.d.ts +1 -1
  12. package/lib/programmers/json/JsonStringifyProgrammer.d.ts +1 -1
  13. package/lib/programmers/json/JsonStringifyProgrammer.js +1 -3
  14. package/lib/programmers/json/JsonStringifyProgrammer.js.map +1 -1
  15. package/lib/programmers/json/JsonValidateParseProgrammer.d.ts +1 -1
  16. package/lib/programmers/json/JsonValidateStringifyProgrammer.d.ts +1 -1
  17. package/lib/programmers/misc/MiscCloneProgrammer.d.ts +1 -1
  18. package/lib/programmers/misc/MiscCloneProgrammer.js +33 -14
  19. package/lib/programmers/misc/MiscCloneProgrammer.js.map +1 -1
  20. package/lib/programmers/misc/MiscIsCloneProgrammer.d.ts +1 -1
  21. package/lib/programmers/misc/MiscIsPruneProgrammer.d.ts +1 -1
  22. package/lib/programmers/misc/MiscPruneProgrammer.d.ts +1 -1
  23. package/lib/programmers/misc/MiscValidateCloneProgrammer.d.ts +1 -1
  24. package/lib/programmers/misc/MiscValidatePruneProgrammer.d.ts +1 -1
  25. package/lib/programmers/notations/NotationGeneralProgrammer.d.ts +1 -1
  26. package/lib/programmers/notations/NotationGeneralProgrammer.js +30 -11
  27. package/lib/programmers/notations/NotationGeneralProgrammer.js.map +1 -1
  28. package/lib/programmers/notations/NotationValidateGeneralProgrammer.d.ts +1 -1
  29. package/package.json +1 -1
  30. package/src/programmers/AssertProgrammer.ts +397 -398
  31. package/src/programmers/CheckerProgrammer.ts +1138 -1138
  32. package/src/programmers/FeatureProgrammer.ts +549 -549
  33. package/src/programmers/IsProgrammer.ts +1 -1
  34. package/src/programmers/RandomProgrammer.ts +112 -77
  35. package/src/programmers/ValidateProgrammer.ts +382 -382
  36. package/src/programmers/functional/FunctionalAssertFunctionProgrammer.ts +141 -141
  37. package/src/programmers/functional/FunctionalAssertParametersProgrammer.ts +108 -108
  38. package/src/programmers/functional/FunctionalAssertReturnProgrammer.ts +98 -98
  39. package/src/programmers/functional/FunctionalIsFunctionProgrammer.ts +72 -72
  40. package/src/programmers/functional/FunctionalIsParametersProgrammer.ts +101 -101
  41. package/src/programmers/functional/FunctionalIsReturnProgrammer.ts +106 -106
  42. package/src/programmers/functional/FunctionalValidateFunctionProgrammer.ts +123 -123
  43. package/src/programmers/functional/FunctionalValidateParametersProgrammer.ts +267 -267
  44. package/src/programmers/functional/FunctionalValidateReturnProgrammer.ts +126 -126
  45. package/src/programmers/helpers/FunctionImporter.ts +97 -97
  46. package/src/programmers/http/HttpAssertFormDataProgrammer.ts +91 -91
  47. package/src/programmers/http/HttpAssertHeadersProgrammer.ts +91 -91
  48. package/src/programmers/http/HttpAssertQueryProgrammer.ts +93 -93
  49. package/src/programmers/http/HttpFormDataProgrammer.ts +278 -278
  50. package/src/programmers/http/HttpHeadersProgrammer.ts +347 -347
  51. package/src/programmers/http/HttpIsFormDataProgrammer.ts +102 -102
  52. package/src/programmers/http/HttpIsHeadersProgrammer.ts +102 -102
  53. package/src/programmers/http/HttpIsQueryProgrammer.ts +104 -104
  54. package/src/programmers/http/HttpQueryProgrammer.ts +298 -298
  55. package/src/programmers/http/HttpValidateFormDataProgrammer.ts +85 -85
  56. package/src/programmers/http/HttpValidateHeadersProgrammer.ts +85 -85
  57. package/src/programmers/http/HttpValidateQueryProgrammer.ts +87 -87
  58. package/src/programmers/json/JsonAssertParseProgrammer.ts +96 -96
  59. package/src/programmers/json/JsonAssertStringifyProgrammer.ts +104 -104
  60. package/src/programmers/json/JsonIsParseProgrammer.ts +110 -110
  61. package/src/programmers/json/JsonIsStringifyProgrammer.ts +102 -102
  62. package/src/programmers/json/JsonStringifyProgrammer.ts +909 -910
  63. package/src/programmers/json/JsonValidateParseProgrammer.ts +87 -87
  64. package/src/programmers/json/JsonValidateStringifyProgrammer.ts +111 -111
  65. package/src/programmers/misc/MiscAssertCloneProgrammer.ts +87 -87
  66. package/src/programmers/misc/MiscAssertPruneProgrammer.ts +87 -87
  67. package/src/programmers/misc/MiscCloneProgrammer.ts +781 -759
  68. package/src/programmers/misc/MiscIsCloneProgrammer.ts +93 -93
  69. package/src/programmers/misc/MiscIsPruneProgrammer.ts +94 -94
  70. package/src/programmers/misc/MiscPruneProgrammer.ts +560 -560
  71. package/src/programmers/misc/MiscValidateCloneProgrammer.ts +104 -104
  72. package/src/programmers/misc/MiscValidatePruneProgrammer.ts +98 -98
  73. package/src/programmers/notations/NotationAssertGeneralProgrammer.ts +91 -91
  74. package/src/programmers/notations/NotationGeneralProgrammer.ts +709 -685
  75. package/src/programmers/notations/NotationIsGeneralProgrammer.ts +97 -97
  76. package/src/programmers/notations/NotationValidateGeneralProgrammer.ts +107 -107
  77. package/src/programmers/protobuf/ProtobufAssertDecodeProgrammer.ts +91 -91
  78. package/src/programmers/protobuf/ProtobufAssertEncodeProgrammer.ts +95 -95
  79. package/src/programmers/protobuf/ProtobufDecodeProgrammer.ts +646 -646
  80. package/src/programmers/protobuf/ProtobufEncodeProgrammer.ts +852 -852
  81. package/src/programmers/protobuf/ProtobufIsDecodeProgrammer.ts +104 -104
  82. package/src/programmers/protobuf/ProtobufIsEncodeProgrammer.ts +93 -93
  83. package/src/programmers/protobuf/ProtobufValidateDecodeProgrammer.ts +85 -85
  84. package/src/programmers/protobuf/ProtobufValidateEncodeProgrammer.ts +109 -109
  85. package/src/transformers/internal/GenericTransformer.ts +104 -104
@@ -1,109 +1,109 @@
1
- import ts from "typescript";
2
-
3
- import { IdentifierFactory } from "../../factories/IdentifierFactory";
4
- import { StatementFactory } from "../../factories/StatementFactory";
5
- import { TypeFactory } from "../../factories/TypeFactory";
6
-
7
- import { IProject } from "../../transformers/IProject";
8
-
9
- import { FeatureProgrammer } from "../FeatureProgrammer";
10
- import { ValidateProgrammer } from "../ValidateProgrammer";
11
- import { FunctionImporter } from "../helpers/FunctionImporter";
12
- import { ProtobufEncodeProgrammer } from "./ProtobufEncodeProgrammer";
13
-
14
- export namespace ProtobufValidateEncodeProgrammer {
15
- export const decompose = (props: {
16
- project: IProject;
17
- modulo: ts.LeftHandSideExpression;
18
- importer: FunctionImporter;
19
- type: ts.Type;
20
- name: string | undefined;
21
- }): FeatureProgrammer.IDecomposed => {
22
- const validate = ValidateProgrammer.decompose({
23
- ...props,
24
- project: {
25
- ...props.project,
26
- options: {
27
- ...props.project.options,
28
- functional: false,
29
- numeric: true,
30
- },
31
- },
32
- equals: false,
33
- });
34
- const encode = ProtobufEncodeProgrammer.decompose(props);
35
- return {
36
- functions: {
37
- ...validate.functions,
38
- ...encode.functions,
39
- },
40
- statements: [
41
- ...validate.statements,
42
- ...encode.statements,
43
- StatementFactory.constant("__validate", validate.arrow),
44
- StatementFactory.constant("__encode", encode.arrow),
45
- ],
46
- arrow: ts.factory.createArrowFunction(
47
- undefined,
48
- undefined,
49
- [IdentifierFactory.parameter("input", TypeFactory.keyword("any"))],
50
- ts.factory.createTypeReferenceNode("typia.IValidation", [
51
- encode.arrow.type ?? ts.factory.createTypeReferenceNode("Uint8Array"),
52
- ]),
53
- undefined,
54
- ts.factory.createBlock(
55
- [
56
- StatementFactory.constant(
57
- "result",
58
- ts.factory.createAsExpression(
59
- ts.factory.createCallExpression(
60
- ts.factory.createIdentifier("__validate"),
61
- undefined,
62
- [ts.factory.createIdentifier("input")],
63
- ),
64
- TypeFactory.keyword("any"),
65
- ),
66
- ),
67
- ts.factory.createIfStatement(
68
- ts.factory.createIdentifier("result.success"),
69
- ts.factory.createExpressionStatement(
70
- ts.factory.createBinaryExpression(
71
- ts.factory.createIdentifier("result.data"),
72
- ts.SyntaxKind.EqualsToken,
73
- ts.factory.createCallExpression(
74
- ts.factory.createIdentifier("__encode"),
75
- undefined,
76
- [ts.factory.createIdentifier("input")],
77
- ),
78
- ),
79
- ),
80
- ),
81
- ts.factory.createReturnStatement(
82
- ts.factory.createIdentifier("result"),
83
- ),
84
- ],
85
- true,
86
- ),
87
- ),
88
- };
89
- };
90
-
91
- export const write =
92
- (project: IProject) =>
93
- (modulo: ts.LeftHandSideExpression) =>
94
- (type: ts.Type, name?: string): ts.CallExpression => {
95
- const importer: FunctionImporter = new FunctionImporter(modulo.getText());
96
- const result: FeatureProgrammer.IDecomposed = decompose({
97
- project,
98
- modulo,
99
- importer,
100
- type,
101
- name,
102
- });
103
- return FeatureProgrammer.writeDecomposed({
104
- modulo,
105
- importer,
106
- result,
107
- });
108
- };
109
- }
1
+ import ts from "typescript";
2
+
3
+ import { IdentifierFactory } from "../../factories/IdentifierFactory";
4
+ import { StatementFactory } from "../../factories/StatementFactory";
5
+ import { TypeFactory } from "../../factories/TypeFactory";
6
+
7
+ import { IProject } from "../../transformers/IProject";
8
+
9
+ import { FeatureProgrammer } from "../FeatureProgrammer";
10
+ import { ValidateProgrammer } from "../ValidateProgrammer";
11
+ import { FunctionImporter } from "../helpers/FunctionImporter";
12
+ import { ProtobufEncodeProgrammer } from "./ProtobufEncodeProgrammer";
13
+
14
+ export namespace ProtobufValidateEncodeProgrammer {
15
+ export const decompose = (props: {
16
+ project: IProject;
17
+ modulo: ts.LeftHandSideExpression;
18
+ importer: FunctionImporter;
19
+ type: ts.Type;
20
+ name: string | undefined;
21
+ }): FeatureProgrammer.IDecomposed => {
22
+ const validate = ValidateProgrammer.decompose({
23
+ ...props,
24
+ project: {
25
+ ...props.project,
26
+ options: {
27
+ ...props.project.options,
28
+ functional: false,
29
+ numeric: true,
30
+ },
31
+ },
32
+ equals: false,
33
+ });
34
+ const encode = ProtobufEncodeProgrammer.decompose(props);
35
+ return {
36
+ functions: {
37
+ ...validate.functions,
38
+ ...encode.functions,
39
+ },
40
+ statements: [
41
+ ...validate.statements,
42
+ ...encode.statements,
43
+ StatementFactory.constant("__validate", validate.arrow),
44
+ StatementFactory.constant("__encode", encode.arrow),
45
+ ],
46
+ arrow: ts.factory.createArrowFunction(
47
+ undefined,
48
+ undefined,
49
+ [IdentifierFactory.parameter("input", TypeFactory.keyword("any"))],
50
+ ts.factory.createTypeReferenceNode("typia.IValidation", [
51
+ encode.arrow.type ?? ts.factory.createTypeReferenceNode("Uint8Array"),
52
+ ]),
53
+ undefined,
54
+ ts.factory.createBlock(
55
+ [
56
+ StatementFactory.constant(
57
+ "result",
58
+ ts.factory.createAsExpression(
59
+ ts.factory.createCallExpression(
60
+ ts.factory.createIdentifier("__validate"),
61
+ undefined,
62
+ [ts.factory.createIdentifier("input")],
63
+ ),
64
+ TypeFactory.keyword("any"),
65
+ ),
66
+ ),
67
+ ts.factory.createIfStatement(
68
+ ts.factory.createIdentifier("result.success"),
69
+ ts.factory.createExpressionStatement(
70
+ ts.factory.createBinaryExpression(
71
+ ts.factory.createIdentifier("result.data"),
72
+ ts.SyntaxKind.EqualsToken,
73
+ ts.factory.createCallExpression(
74
+ ts.factory.createIdentifier("__encode"),
75
+ undefined,
76
+ [ts.factory.createIdentifier("input")],
77
+ ),
78
+ ),
79
+ ),
80
+ ),
81
+ ts.factory.createReturnStatement(
82
+ ts.factory.createIdentifier("result"),
83
+ ),
84
+ ],
85
+ true,
86
+ ),
87
+ ),
88
+ };
89
+ };
90
+
91
+ export const write =
92
+ (project: IProject) =>
93
+ (modulo: ts.LeftHandSideExpression) =>
94
+ (type: ts.Type, name?: string): ts.CallExpression => {
95
+ const importer: FunctionImporter = new FunctionImporter(modulo.getText());
96
+ const result: FeatureProgrammer.IDecomposed = decompose({
97
+ project,
98
+ modulo,
99
+ importer,
100
+ type,
101
+ name,
102
+ });
103
+ return FeatureProgrammer.writeDecomposed({
104
+ modulo,
105
+ importer,
106
+ result,
107
+ });
108
+ };
109
+ }
@@ -1,104 +1,104 @@
1
- import ts from "typescript";
2
-
3
- import { IProject } from "../IProject";
4
- import { TransformerError } from "../TransformerError";
5
-
6
- export namespace GenericTransformer {
7
- export const scalar =
8
- (method: string) =>
9
- (
10
- programmer: (
11
- project: IProject,
12
- ) => (
13
- modulo: ts.LeftHandSideExpression,
14
- ) => (type: ts.Type, name: string) => ts.Expression | ts.ArrowFunction,
15
- ) =>
16
- (project: IProject) =>
17
- (modulo: ts.LeftHandSideExpression) =>
18
- (expression: ts.CallExpression) => {
19
- // CHECK PARAMETER
20
- if (expression.arguments.length === 0)
21
- throw new TransformerError({
22
- code: `typia.${method}`,
23
- message: `no input value.`,
24
- });
25
-
26
- // GET TYPE INFO
27
- const [type, node, generic]: [ts.Type, ts.Node, boolean] =
28
- expression.typeArguments && expression.typeArguments[0]
29
- ? [
30
- project.checker.getTypeFromTypeNode(expression.typeArguments[0]),
31
- expression.typeArguments[0],
32
- true,
33
- ]
34
- : [
35
- project.checker.getTypeAtLocation(expression.arguments[0]!),
36
- expression.arguments[0]!,
37
- false,
38
- ];
39
- if (type.isTypeParameter())
40
- throw new TransformerError({
41
- code: `typia.${method}`,
42
- message: `non-specified generic argument.`,
43
- });
44
-
45
- // DO TRANSFORM
46
- return ts.factory.createCallExpression(
47
- programmer(project)(modulo)(
48
- type,
49
- generic
50
- ? node.getFullText().trim()
51
- : name(project.checker)(type)(node),
52
- ),
53
- undefined,
54
- expression.arguments,
55
- );
56
- };
57
-
58
- export const factory =
59
- (method: string) =>
60
- (
61
- programmer: (
62
- project: IProject,
63
- ) => (
64
- modulo: ts.LeftHandSideExpression,
65
- ) => (
66
- type: ts.Type,
67
- name: string,
68
- init?: ts.Expression,
69
- ) => ts.Expression | ts.ArrowFunction,
70
- ) =>
71
- (project: IProject) =>
72
- (modulo: ts.LeftHandSideExpression) =>
73
- (expression: ts.CallExpression) => {
74
- // CHECK GENERIC ARGUMENT EXISTENCE
75
- if (!expression.typeArguments?.[0])
76
- throw new TransformerError({
77
- code: `typia.${method}`,
78
- message: `generic argument is not specified.`,
79
- });
80
-
81
- // GET TYPE INFO
82
- const node: ts.TypeNode = expression.typeArguments[0];
83
- const type: ts.Type = project.checker.getTypeFromTypeNode(node);
84
-
85
- if (type.isTypeParameter())
86
- throw new TransformerError({
87
- code: `typia.${method}`,
88
- message: `non-specified generic argument.`,
89
- });
90
-
91
- // DO TRANSFORM
92
- return programmer(project)(modulo)(
93
- type,
94
- node.getFullText().trim(),
95
- expression.arguments[0],
96
- );
97
- };
98
-
99
- const name =
100
- (checker: ts.TypeChecker) =>
101
- (type: ts.Type) =>
102
- (node: ts.Node): string =>
103
- checker.typeToString(type, node, ts.TypeFormatFlags.NodeBuilderFlagsMask);
104
- }
1
+ import ts from "typescript";
2
+
3
+ import { IProject } from "../IProject";
4
+ import { TransformerError } from "../TransformerError";
5
+
6
+ export namespace GenericTransformer {
7
+ export const scalar =
8
+ (method: string) =>
9
+ (
10
+ programmer: (
11
+ project: IProject,
12
+ ) => (
13
+ modulo: ts.LeftHandSideExpression,
14
+ ) => (type: ts.Type, name: string) => ts.Expression | ts.ArrowFunction,
15
+ ) =>
16
+ (project: IProject) =>
17
+ (modulo: ts.LeftHandSideExpression) =>
18
+ (expression: ts.CallExpression) => {
19
+ // CHECK PARAMETER
20
+ if (expression.arguments.length === 0)
21
+ throw new TransformerError({
22
+ code: `typia.${method}`,
23
+ message: `no input value.`,
24
+ });
25
+
26
+ // GET TYPE INFO
27
+ const [type, node, generic]: [ts.Type, ts.Node, boolean] =
28
+ expression.typeArguments && expression.typeArguments[0]
29
+ ? [
30
+ project.checker.getTypeFromTypeNode(expression.typeArguments[0]),
31
+ expression.typeArguments[0],
32
+ true,
33
+ ]
34
+ : [
35
+ project.checker.getTypeAtLocation(expression.arguments[0]!),
36
+ expression.arguments[0]!,
37
+ false,
38
+ ];
39
+ if (type.isTypeParameter())
40
+ throw new TransformerError({
41
+ code: `typia.${method}`,
42
+ message: `non-specified generic argument.`,
43
+ });
44
+
45
+ // DO TRANSFORM
46
+ return ts.factory.createCallExpression(
47
+ programmer(project)(modulo)(
48
+ type,
49
+ generic
50
+ ? node.getFullText().trim()
51
+ : name(project.checker)(type)(node),
52
+ ),
53
+ undefined,
54
+ expression.arguments,
55
+ );
56
+ };
57
+
58
+ export const factory =
59
+ (method: string) =>
60
+ (
61
+ programmer: (
62
+ project: IProject,
63
+ ) => (
64
+ modulo: ts.LeftHandSideExpression,
65
+ ) => (
66
+ type: ts.Type,
67
+ name: string,
68
+ init?: ts.Expression,
69
+ ) => ts.Expression | ts.ArrowFunction,
70
+ ) =>
71
+ (project: IProject) =>
72
+ (modulo: ts.LeftHandSideExpression) =>
73
+ (expression: ts.CallExpression) => {
74
+ // CHECK GENERIC ARGUMENT EXISTENCE
75
+ if (!expression.typeArguments?.[0])
76
+ throw new TransformerError({
77
+ code: `typia.${method}`,
78
+ message: `generic argument is not specified.`,
79
+ });
80
+
81
+ // GET TYPE INFO
82
+ const node: ts.TypeNode = expression.typeArguments[0];
83
+ const type: ts.Type = project.checker.getTypeFromTypeNode(node);
84
+
85
+ if (type.isTypeParameter())
86
+ throw new TransformerError({
87
+ code: `typia.${method}`,
88
+ message: `non-specified generic argument.`,
89
+ });
90
+
91
+ // DO TRANSFORM
92
+ return programmer(project)(modulo)(
93
+ type,
94
+ node.getFullText().trim(),
95
+ expression.arguments[0],
96
+ );
97
+ };
98
+
99
+ const name =
100
+ (checker: ts.TypeChecker) =>
101
+ (type: ts.Type) =>
102
+ (node: ts.Node): string =>
103
+ checker.typeToString(type, node, ts.TypeFormatFlags.NodeBuilderFlagsMask);
104
+ }