@typia/transform 12.0.0-dev.20260309 → 12.0.0-dev.20260310

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 (117) hide show
  1. package/package.json +4 -4
  2. package/src/CallExpressionTransformer.ts +579 -579
  3. package/src/FileTransformer.ts +143 -143
  4. package/src/ITransformProps.ts +20 -20
  5. package/src/ImportTransformer.ts +262 -262
  6. package/src/NodeTransformer.ts +25 -25
  7. package/src/TransformerError.ts +85 -85
  8. package/src/TypiaGenerator.ts +172 -172
  9. package/src/features/AssertTransformer.ts +24 -24
  10. package/src/features/CreateAssertTransformer.ts +24 -24
  11. package/src/features/CreateIsTransformer.ts +18 -18
  12. package/src/features/CreateRandomTransformer.ts +42 -42
  13. package/src/features/CreateValidateTransformer.ts +18 -18
  14. package/src/features/IsTransformer.ts +18 -18
  15. package/src/features/RandomTransformer.ts +40 -40
  16. package/src/features/ValidateTransformer.ts +18 -18
  17. package/src/features/functional/FunctionalGenericTransformer.ts +55 -55
  18. package/src/features/http/CreateHttpAssertFormDataTransformer.ts +13 -13
  19. package/src/features/http/CreateHttpAssertHeadersTransformer.ts +13 -13
  20. package/src/features/http/CreateHttpAssertQueryTransformer.ts +13 -13
  21. package/src/features/http/CreateHttpFormDataTransformer.ts +13 -13
  22. package/src/features/http/CreateHttpHeadersTransformer.ts +13 -13
  23. package/src/features/http/CreateHttpIsFormDataTransformer.ts +13 -13
  24. package/src/features/http/CreateHttpIsHeadersTransformer.ts +13 -13
  25. package/src/features/http/CreateHttpIsQueryTransformer.ts +13 -13
  26. package/src/features/http/CreateHttpParameterTransformer.ts +13 -13
  27. package/src/features/http/CreateHttpQueryTransformer.ts +13 -13
  28. package/src/features/http/CreateHttpValidateFormDataTransformer.ts +13 -13
  29. package/src/features/http/CreateHttpValidateHeadersTransformer.ts +13 -13
  30. package/src/features/http/CreateHttpValidateQueryTransformer.ts +13 -13
  31. package/src/features/http/HttpAssertFormDataTransformer.ts +13 -13
  32. package/src/features/http/HttpAssertHeadersTransformer.ts +13 -13
  33. package/src/features/http/HttpAssertQueryTransformer.ts +13 -13
  34. package/src/features/http/HttpFormDataTransformer.ts +13 -13
  35. package/src/features/http/HttpHeadersTransformer.ts +13 -13
  36. package/src/features/http/HttpIsFormDataTransformer.ts +13 -13
  37. package/src/features/http/HttpIsHeadersTransformer.ts +13 -13
  38. package/src/features/http/HttpIsQueryTransformer.ts +13 -13
  39. package/src/features/http/HttpParameterTransformer.ts +13 -13
  40. package/src/features/http/HttpQueryTransformer.ts +13 -13
  41. package/src/features/http/HttpValidateFormDataTransformer.ts +13 -13
  42. package/src/features/http/HttpValidateHeadersTransformer.ts +13 -13
  43. package/src/features/http/HttpValidateQueryTransformer.ts +13 -13
  44. package/src/features/json/JsonApplicationTransformer.ts +99 -99
  45. package/src/features/json/JsonAssertParseTransformer.ts +13 -13
  46. package/src/features/json/JsonAssertStringifyTransformer.ts +13 -13
  47. package/src/features/json/JsonCreateAssertParseTransformer.ts +13 -13
  48. package/src/features/json/JsonCreateAssertStringifyTransformer.ts +13 -13
  49. package/src/features/json/JsonCreateIsParseTransformer.ts +13 -13
  50. package/src/features/json/JsonCreateIsStringifyTransformer.ts +13 -13
  51. package/src/features/json/JsonCreateStringifyTransformer.ts +13 -13
  52. package/src/features/json/JsonCreateValidateParseTransformer.ts +13 -13
  53. package/src/features/json/JsonCreateValidateStringifyProgrammer.ts +13 -13
  54. package/src/features/json/JsonIsParseTransformer.ts +13 -13
  55. package/src/features/json/JsonIsStringifyTransformer.ts +13 -13
  56. package/src/features/json/JsonSchemaTransformer.ts +120 -120
  57. package/src/features/json/JsonSchemasTransformer.ts +130 -130
  58. package/src/features/json/JsonStringifyTransformer.ts +13 -13
  59. package/src/features/json/JsonValidateParseTransformer.ts +13 -13
  60. package/src/features/json/JsonValidateStringifyTransformer.ts +13 -13
  61. package/src/features/llm/LlmApplicationTransformer.ts +224 -224
  62. package/src/features/llm/LlmCoerceTransformer.ts +95 -95
  63. package/src/features/llm/LlmControllerTransformer.ts +81 -81
  64. package/src/features/llm/LlmCreateCoerceTransformer.ts +84 -84
  65. package/src/features/llm/LlmCreateParseTransformer.ts +84 -84
  66. package/src/features/llm/LlmParametersTransformer.ts +76 -76
  67. package/src/features/llm/LlmParseTransformer.ts +95 -95
  68. package/src/features/llm/LlmSchemaTransformer.ts +87 -87
  69. package/src/features/misc/MiscAssertCloneTransformer.ts +13 -13
  70. package/src/features/misc/MiscAssertPruneTransformer.ts +13 -13
  71. package/src/features/misc/MiscCloneTransformer.ts +13 -13
  72. package/src/features/misc/MiscCreateAssertCloneTransformer.ts +13 -13
  73. package/src/features/misc/MiscCreateAssertPruneTransformer.ts +13 -13
  74. package/src/features/misc/MiscCreateCloneTransformer.ts +13 -13
  75. package/src/features/misc/MiscCreateIsCloneTransformer.ts +13 -13
  76. package/src/features/misc/MiscCreateIsPruneTransformer.ts +13 -13
  77. package/src/features/misc/MiscCreatePruneTransformer.ts +13 -13
  78. package/src/features/misc/MiscCreateValidateCloneTransformer.ts +13 -13
  79. package/src/features/misc/MiscCreateValidatePruneTransformer.ts +13 -13
  80. package/src/features/misc/MiscIsCloneTransformer.ts +13 -13
  81. package/src/features/misc/MiscIsPruneTransformer.ts +13 -13
  82. package/src/features/misc/MiscLiteralsTransformer.ts +34 -34
  83. package/src/features/misc/MiscPruneTransformer.ts +13 -13
  84. package/src/features/misc/MiscValidateCloneTransformer.ts +13 -13
  85. package/src/features/misc/MiscValidatePruneTransformer.ts +13 -13
  86. package/src/features/notations/NotationAssertGeneralTransformer.ts +19 -19
  87. package/src/features/notations/NotationCreateAssertGeneralTransformer.ts +19 -19
  88. package/src/features/notations/NotationCreateGeneralTransformer.ts +19 -19
  89. package/src/features/notations/NotationCreateIsGeneralTransformer.ts +19 -19
  90. package/src/features/notations/NotationCreateValidateGeneralTransformer.ts +19 -19
  91. package/src/features/notations/NotationGeneralTransformer.ts +18 -18
  92. package/src/features/notations/NotationIsGeneralTransformer.ts +19 -19
  93. package/src/features/notations/NotationValidateGeneralTransformer.ts +19 -19
  94. package/src/features/protobuf/ProtobufAssertDecodeTransformer.ts +13 -13
  95. package/src/features/protobuf/ProtobufAssertEncodeTransformer.ts +13 -13
  96. package/src/features/protobuf/ProtobufCreateAssertDecodeTransformer.ts +13 -13
  97. package/src/features/protobuf/ProtobufCreateAssertEncodeTransformer.ts +13 -13
  98. package/src/features/protobuf/ProtobufCreateDecodeTransformer.ts +13 -13
  99. package/src/features/protobuf/ProtobufCreateEncodeTransformer.ts +13 -13
  100. package/src/features/protobuf/ProtobufCreateIsDecodeTransformer.ts +13 -13
  101. package/src/features/protobuf/ProtobufCreateIsEncodeTransformer.ts +13 -13
  102. package/src/features/protobuf/ProtobufCreateValidateDecodeTransformer.ts +13 -13
  103. package/src/features/protobuf/ProtobufCreateValidateEncodeTransformer.ts +13 -13
  104. package/src/features/protobuf/ProtobufDecodeTransformer.ts +13 -13
  105. package/src/features/protobuf/ProtobufEncodeTransformer.ts +13 -13
  106. package/src/features/protobuf/ProtobufIsDecodeTransformer.ts +13 -13
  107. package/src/features/protobuf/ProtobufIsEncodeTransformer.ts +13 -13
  108. package/src/features/protobuf/ProtobufMessageTransformer.ts +34 -34
  109. package/src/features/protobuf/ProtobufValidateDecodeTransformer.ts +13 -13
  110. package/src/features/protobuf/ProtobufValidateEncodeTransformer.ts +13 -13
  111. package/src/features/reflect/ReflectMetadataTransformer.ts +69 -69
  112. package/src/features/reflect/ReflectNameTransformer.ts +81 -81
  113. package/src/features/reflect/ReflectSchemaTransformer.ts +65 -65
  114. package/src/features/reflect/ReflectSchemasTransformer.ts +69 -69
  115. package/src/index.ts +7 -7
  116. package/src/internal/GenericTransformer.ts +101 -101
  117. package/src/transform.ts +68 -68
@@ -1,81 +1,81 @@
1
- import {
2
- ITypiaContext,
3
- MetadataCollection,
4
- MetadataFactory,
5
- MetadataSchema,
6
- } from "@typia/core";
7
- import { ValidationPipe } from "@typia/interface";
8
- import ts from "typescript";
9
-
10
- import { ITransformProps } from "../../ITransformProps";
11
- import { TransformerError } from "../../TransformerError";
12
-
13
- export namespace ReflectNameTransformer {
14
- export const transform = (
15
- props: Pick<ITransformProps, "context" | "expression">,
16
- ): ts.Expression => {
17
- if (!props.expression.typeArguments?.length)
18
- throw new TransformerError({
19
- code: "typia.reflect.metadata",
20
- message: "no generic argument.",
21
- });
22
- const top: ts.Node = props.expression.typeArguments[0]!;
23
- const regular: boolean = (() => {
24
- // CHECK SECOND ARGUMENT EXISTENCE
25
- const second: ts.Node | undefined = props.expression.typeArguments[1]!;
26
- if (second === undefined) return false;
27
-
28
- // GET BOOLEAN VALUE
29
- const value: MetadataSchema = getMetadata({
30
- context: props.context,
31
- node: second,
32
- });
33
- return value.size() === 1 &&
34
- value.constants.length === 1 &&
35
- value.constants[0]!.type === "boolean" &&
36
- value.constants[0]!.values.length === 1
37
- ? (value.constants[0]!.values[0]!.value as boolean)
38
- : false;
39
- })();
40
-
41
- // RETURNS NAME
42
- return ts.factory.createStringLiteral(
43
- regular
44
- ? getMetadata({
45
- context: props.context,
46
- node: top,
47
- }).getName()
48
- : top.getFullText(),
49
- );
50
- };
51
- }
52
-
53
- const getMetadata = (props: {
54
- context: ITypiaContext;
55
- node: ts.Node;
56
- }): MetadataSchema => {
57
- const type: ts.Type = props.context.checker.getTypeFromTypeNode(
58
- props.node as ts.TypeNode,
59
- );
60
- const collection: MetadataCollection = new MetadataCollection({
61
- replace: MetadataCollection.replace,
62
- });
63
- const result: ValidationPipe<MetadataSchema, MetadataFactory.IError> =
64
- MetadataFactory.analyze({
65
- checker: props.context.checker,
66
- transformer: props.context.transformer,
67
- options: {
68
- absorb: false,
69
- constant: true,
70
- escape: false,
71
- },
72
- components: collection,
73
- type,
74
- });
75
- if (result.success === false)
76
- throw TransformerError.from({
77
- code: "typia.reflect.name",
78
- errors: result.errors,
79
- });
80
- return result.data;
81
- };
1
+ import {
2
+ ITypiaContext,
3
+ MetadataCollection,
4
+ MetadataFactory,
5
+ MetadataSchema,
6
+ } from "@typia/core";
7
+ import { ValidationPipe } from "@typia/interface";
8
+ import ts from "typescript";
9
+
10
+ import { ITransformProps } from "../../ITransformProps";
11
+ import { TransformerError } from "../../TransformerError";
12
+
13
+ export namespace ReflectNameTransformer {
14
+ export const transform = (
15
+ props: Pick<ITransformProps, "context" | "expression">,
16
+ ): ts.Expression => {
17
+ if (!props.expression.typeArguments?.length)
18
+ throw new TransformerError({
19
+ code: "typia.reflect.metadata",
20
+ message: "no generic argument.",
21
+ });
22
+ const top: ts.Node = props.expression.typeArguments[0]!;
23
+ const regular: boolean = (() => {
24
+ // CHECK SECOND ARGUMENT EXISTENCE
25
+ const second: ts.Node | undefined = props.expression.typeArguments[1]!;
26
+ if (second === undefined) return false;
27
+
28
+ // GET BOOLEAN VALUE
29
+ const value: MetadataSchema = getMetadata({
30
+ context: props.context,
31
+ node: second,
32
+ });
33
+ return value.size() === 1 &&
34
+ value.constants.length === 1 &&
35
+ value.constants[0]!.type === "boolean" &&
36
+ value.constants[0]!.values.length === 1
37
+ ? (value.constants[0]!.values[0]!.value as boolean)
38
+ : false;
39
+ })();
40
+
41
+ // RETURNS NAME
42
+ return ts.factory.createStringLiteral(
43
+ regular
44
+ ? getMetadata({
45
+ context: props.context,
46
+ node: top,
47
+ }).getName()
48
+ : top.getFullText(),
49
+ );
50
+ };
51
+ }
52
+
53
+ const getMetadata = (props: {
54
+ context: ITypiaContext;
55
+ node: ts.Node;
56
+ }): MetadataSchema => {
57
+ const type: ts.Type = props.context.checker.getTypeFromTypeNode(
58
+ props.node as ts.TypeNode,
59
+ );
60
+ const collection: MetadataCollection = new MetadataCollection({
61
+ replace: MetadataCollection.replace,
62
+ });
63
+ const result: ValidationPipe<MetadataSchema, MetadataFactory.IError> =
64
+ MetadataFactory.analyze({
65
+ checker: props.context.checker,
66
+ transformer: props.context.transformer,
67
+ options: {
68
+ absorb: false,
69
+ constant: true,
70
+ escape: false,
71
+ },
72
+ components: collection,
73
+ type,
74
+ });
75
+ if (result.success === false)
76
+ throw TransformerError.from({
77
+ code: "typia.reflect.name",
78
+ errors: result.errors,
79
+ });
80
+ return result.data;
81
+ };
@@ -1,65 +1,65 @@
1
- import {
2
- LiteralFactory,
3
- MetadataCollection,
4
- MetadataFactory,
5
- MetadataSchema,
6
- } from "@typia/core";
7
- import { IMetadataSchemaUnit } from "@typia/interface";
8
- import ts from "typescript";
9
-
10
- import { ITransformProps } from "../../ITransformProps";
11
- import { TransformerError } from "../../TransformerError";
12
-
13
- export namespace ReflectSchemaTransformer {
14
- export const transform = (
15
- props: Pick<ITransformProps, "context" | "expression">,
16
- ): ts.Expression => {
17
- if (!props.expression.typeArguments?.length)
18
- throw new TransformerError({
19
- code: "typia.reflect.schema",
20
- message: "no generic argument.",
21
- });
22
-
23
- // VALIDATE ARGUMENT
24
- const top: ts.Node | undefined = props.expression.typeArguments[0];
25
- if (top === undefined || ts.isTypeNode(top) === false)
26
- return props.expression;
27
-
28
- // GET TYPE
29
- const type: ts.Type = props.context.checker.getTypeFromTypeNode(top);
30
- if (type.isTypeParameter())
31
- throw new TransformerError({
32
- code: "typia.reflect.schema",
33
- message: "non-specified generic argument.",
34
- });
35
-
36
- // METADATA
37
- const components: MetadataCollection = new MetadataCollection();
38
- const result = MetadataFactory.analyze({
39
- checker: props.context.checker,
40
- transformer: props.context.transformer,
41
- options: {
42
- escape: true,
43
- constant: true,
44
- absorb: true,
45
- functional: true,
46
- },
47
- components: components,
48
- type,
49
- });
50
- if (result.success === false)
51
- throw TransformerError.from({
52
- code: "typia.reflect.schema",
53
- errors: result.errors,
54
- });
55
-
56
- const schema: MetadataSchema = result.data;
57
-
58
- // CONVERT TO PRIMITIVE TYPE
59
- const unit: IMetadataSchemaUnit = {
60
- schema: schema.toJSON(),
61
- components: components.toJSON(),
62
- };
63
- return LiteralFactory.write(unit);
64
- };
65
- }
1
+ import {
2
+ LiteralFactory,
3
+ MetadataCollection,
4
+ MetadataFactory,
5
+ MetadataSchema,
6
+ } from "@typia/core";
7
+ import { IMetadataSchemaUnit } from "@typia/interface";
8
+ import ts from "typescript";
9
+
10
+ import { ITransformProps } from "../../ITransformProps";
11
+ import { TransformerError } from "../../TransformerError";
12
+
13
+ export namespace ReflectSchemaTransformer {
14
+ export const transform = (
15
+ props: Pick<ITransformProps, "context" | "expression">,
16
+ ): ts.Expression => {
17
+ if (!props.expression.typeArguments?.length)
18
+ throw new TransformerError({
19
+ code: "typia.reflect.schema",
20
+ message: "no generic argument.",
21
+ });
22
+
23
+ // VALIDATE ARGUMENT
24
+ const top: ts.Node | undefined = props.expression.typeArguments[0];
25
+ if (top === undefined || ts.isTypeNode(top) === false)
26
+ return props.expression;
27
+
28
+ // GET TYPE
29
+ const type: ts.Type = props.context.checker.getTypeFromTypeNode(top);
30
+ if (type.isTypeParameter())
31
+ throw new TransformerError({
32
+ code: "typia.reflect.schema",
33
+ message: "non-specified generic argument.",
34
+ });
35
+
36
+ // METADATA
37
+ const components: MetadataCollection = new MetadataCollection();
38
+ const result = MetadataFactory.analyze({
39
+ checker: props.context.checker,
40
+ transformer: props.context.transformer,
41
+ options: {
42
+ escape: true,
43
+ constant: true,
44
+ absorb: true,
45
+ functional: true,
46
+ },
47
+ components: components,
48
+ type,
49
+ });
50
+ if (result.success === false)
51
+ throw TransformerError.from({
52
+ code: "typia.reflect.schema",
53
+ errors: result.errors,
54
+ });
55
+
56
+ const schema: MetadataSchema = result.data;
57
+
58
+ // CONVERT TO PRIMITIVE TYPE
59
+ const unit: IMetadataSchemaUnit = {
60
+ schema: schema.toJSON(),
61
+ components: components.toJSON(),
62
+ };
63
+ return LiteralFactory.write(unit);
64
+ };
65
+ }
@@ -1,69 +1,69 @@
1
- import {
2
- LiteralFactory,
3
- MetadataCollection,
4
- MetadataFactory,
5
- MetadataSchema,
6
- } from "@typia/core";
7
- import { IMetadataSchemaCollection } from "@typia/interface";
8
- import ts from "typescript";
9
-
10
- import { ITransformProps } from "../../ITransformProps";
11
- import { TransformerError } from "../../TransformerError";
12
-
13
- export namespace ReflectSchemasTransformer {
14
- export const transform = (
15
- props: Pick<ITransformProps, "context" | "expression">,
16
- ): ts.Expression => {
17
- if (!props.expression.typeArguments?.length)
18
- throw new TransformerError({
19
- code: "typia.reflect.schemas",
20
- message: "no generic argument.",
21
- });
22
-
23
- // VALIDATE TUPLE ARGUMENTS
24
- const top: ts.Node = props.expression.typeArguments[0]!;
25
- if (!ts.isTupleTypeNode(top)) return props.expression;
26
- else if (top.elements.some((child) => !ts.isTypeNode(child)))
27
- return props.expression;
28
-
29
- // GET TYPES
30
- const types: ts.Type[] = top.elements.map((child) =>
31
- props.context.checker.getTypeFromTypeNode(child as ts.TypeNode),
32
- );
33
- if (types.some((t) => t.isTypeParameter()))
34
- throw new TransformerError({
35
- code: "typia.reflect.schemas",
36
- message: "non-specified generic argument(s).",
37
- });
38
-
39
- // METADATA
40
- const components: MetadataCollection = new MetadataCollection();
41
- const schemas: Array<MetadataSchema> = types.map((type) => {
42
- const result = MetadataFactory.analyze({
43
- checker: props.context.checker,
44
- transformer: props.context.transformer,
45
- options: {
46
- escape: true,
47
- constant: true,
48
- absorb: true,
49
- functional: true,
50
- },
51
- components: components,
52
- type,
53
- });
54
- if (result.success === false)
55
- throw TransformerError.from({
56
- code: "typia.reflect.schemas",
57
- errors: result.errors,
58
- });
59
- return result.data;
60
- });
61
-
62
- // CONVERT TO PRIMITIVE TYPE
63
- const collection: IMetadataSchemaCollection = {
64
- schemas: schemas.map((s) => s.toJSON()),
65
- components: components.toJSON(),
66
- };
67
- return LiteralFactory.write(collection);
68
- };
69
- }
1
+ import {
2
+ LiteralFactory,
3
+ MetadataCollection,
4
+ MetadataFactory,
5
+ MetadataSchema,
6
+ } from "@typia/core";
7
+ import { IMetadataSchemaCollection } from "@typia/interface";
8
+ import ts from "typescript";
9
+
10
+ import { ITransformProps } from "../../ITransformProps";
11
+ import { TransformerError } from "../../TransformerError";
12
+
13
+ export namespace ReflectSchemasTransformer {
14
+ export const transform = (
15
+ props: Pick<ITransformProps, "context" | "expression">,
16
+ ): ts.Expression => {
17
+ if (!props.expression.typeArguments?.length)
18
+ throw new TransformerError({
19
+ code: "typia.reflect.schemas",
20
+ message: "no generic argument.",
21
+ });
22
+
23
+ // VALIDATE TUPLE ARGUMENTS
24
+ const top: ts.Node = props.expression.typeArguments[0]!;
25
+ if (!ts.isTupleTypeNode(top)) return props.expression;
26
+ else if (top.elements.some((child) => !ts.isTypeNode(child)))
27
+ return props.expression;
28
+
29
+ // GET TYPES
30
+ const types: ts.Type[] = top.elements.map((child) =>
31
+ props.context.checker.getTypeFromTypeNode(child as ts.TypeNode),
32
+ );
33
+ if (types.some((t) => t.isTypeParameter()))
34
+ throw new TransformerError({
35
+ code: "typia.reflect.schemas",
36
+ message: "non-specified generic argument(s).",
37
+ });
38
+
39
+ // METADATA
40
+ const components: MetadataCollection = new MetadataCollection();
41
+ const schemas: Array<MetadataSchema> = types.map((type) => {
42
+ const result = MetadataFactory.analyze({
43
+ checker: props.context.checker,
44
+ transformer: props.context.transformer,
45
+ options: {
46
+ escape: true,
47
+ constant: true,
48
+ absorb: true,
49
+ functional: true,
50
+ },
51
+ components: components,
52
+ type,
53
+ });
54
+ if (result.success === false)
55
+ throw TransformerError.from({
56
+ code: "typia.reflect.schemas",
57
+ errors: result.errors,
58
+ });
59
+ return result.data;
60
+ });
61
+
62
+ // CONVERT TO PRIMITIVE TYPE
63
+ const collection: IMetadataSchemaCollection = {
64
+ schemas: schemas.map((s) => s.toJSON()),
65
+ components: components.toJSON(),
66
+ };
67
+ return LiteralFactory.write(collection);
68
+ };
69
+ }
package/src/index.ts CHANGED
@@ -1,7 +1,7 @@
1
- import { transform } from "./transform";
2
-
3
- export default transform;
4
-
5
- export * from "./ImportTransformer";
6
- export * from "./TypiaGenerator";
7
- export * from "./transform";
1
+ import { transform } from "./transform";
2
+
3
+ export default transform;
4
+
5
+ export * from "./ImportTransformer";
6
+ export * from "./TypiaGenerator";
7
+ export * from "./transform";
@@ -1,101 +1,101 @@
1
- import { IProgrammerProps } from "@typia/core";
2
- import ts from "typescript";
3
-
4
- import { ITransformProps } from "../ITransformProps";
5
- import { TransformerError } from "../TransformerError";
6
-
7
- export namespace GenericTransformer {
8
- export interface IProps extends ITransformProps {
9
- method: string;
10
- write: (props: IProgrammerProps) => ts.Expression | ts.ArrowFunction;
11
- }
12
-
13
- export const scalar = (props: IProps) => {
14
- // CHECK PARAMETER
15
- if (props.expression.arguments.length === 0)
16
- throw new TransformerError({
17
- code: `typia.${props.method}`,
18
- message: `no input value.`,
19
- });
20
-
21
- // GET TYPE INFO
22
- const [type, node, generic]: [ts.Type, ts.Node, boolean] =
23
- props.expression.typeArguments && props.expression.typeArguments[0]
24
- ? [
25
- props.context.checker.getTypeFromTypeNode(
26
- props.expression.typeArguments[0],
27
- ),
28
- props.expression.typeArguments[0],
29
- true,
30
- ]
31
- : [
32
- props.context.checker.getTypeAtLocation(
33
- props.expression.arguments[0]!,
34
- ),
35
- props.expression.arguments[0]!,
36
- false,
37
- ];
38
- if (type.isTypeParameter())
39
- throw new TransformerError({
40
- code: `typia.${props.method}`,
41
- message: `non-specified generic argument.`,
42
- });
43
-
44
- // DO TRANSFORM
45
- return ts.factory.createCallExpression(
46
- props.write({
47
- context: props.context,
48
- modulo: props.modulo,
49
- type,
50
- name: generic
51
- ? node.getFullText().trim()
52
- : getTypeName({
53
- checker: props.context.checker,
54
- type,
55
- node,
56
- }),
57
- }),
58
- undefined,
59
- props.expression.arguments,
60
- );
61
- };
62
-
63
- export const factory = (props: IProps) => {
64
- // CHECK GENERIC ARGUMENT EXISTENCE
65
- if (!props.expression.typeArguments?.[0])
66
- throw new TransformerError({
67
- code: `typia.${props.method}`,
68
- message: `generic argument is not specified.`,
69
- });
70
-
71
- // GET TYPE INFO
72
- const node: ts.TypeNode = props.expression.typeArguments[0];
73
- const type: ts.Type = props.context.checker.getTypeFromTypeNode(node);
74
-
75
- if (type.isTypeParameter())
76
- throw new TransformerError({
77
- code: `typia.${props.method}`,
78
- message: `non-specified generic argument.`,
79
- });
80
-
81
- // DO TRANSFORM
82
- return props.write({
83
- context: props.context,
84
- modulo: props.modulo,
85
- type,
86
- name: node.getFullText().trim(),
87
- init: props.expression.arguments[0],
88
- });
89
- };
90
-
91
- const getTypeName = (props: {
92
- checker: ts.TypeChecker;
93
- type: ts.Type;
94
- node: ts.Node;
95
- }): string =>
96
- props.checker.typeToString(
97
- props.type,
98
- props.node,
99
- ts.TypeFormatFlags.NodeBuilderFlagsMask,
100
- );
101
- }
1
+ import { IProgrammerProps } from "@typia/core";
2
+ import ts from "typescript";
3
+
4
+ import { ITransformProps } from "../ITransformProps";
5
+ import { TransformerError } from "../TransformerError";
6
+
7
+ export namespace GenericTransformer {
8
+ export interface IProps extends ITransformProps {
9
+ method: string;
10
+ write: (props: IProgrammerProps) => ts.Expression | ts.ArrowFunction;
11
+ }
12
+
13
+ export const scalar = (props: IProps) => {
14
+ // CHECK PARAMETER
15
+ if (props.expression.arguments.length === 0)
16
+ throw new TransformerError({
17
+ code: `typia.${props.method}`,
18
+ message: `no input value.`,
19
+ });
20
+
21
+ // GET TYPE INFO
22
+ const [type, node, generic]: [ts.Type, ts.Node, boolean] =
23
+ props.expression.typeArguments && props.expression.typeArguments[0]
24
+ ? [
25
+ props.context.checker.getTypeFromTypeNode(
26
+ props.expression.typeArguments[0],
27
+ ),
28
+ props.expression.typeArguments[0],
29
+ true,
30
+ ]
31
+ : [
32
+ props.context.checker.getTypeAtLocation(
33
+ props.expression.arguments[0]!,
34
+ ),
35
+ props.expression.arguments[0]!,
36
+ false,
37
+ ];
38
+ if (type.isTypeParameter())
39
+ throw new TransformerError({
40
+ code: `typia.${props.method}`,
41
+ message: `non-specified generic argument.`,
42
+ });
43
+
44
+ // DO TRANSFORM
45
+ return ts.factory.createCallExpression(
46
+ props.write({
47
+ context: props.context,
48
+ modulo: props.modulo,
49
+ type,
50
+ name: generic
51
+ ? node.getFullText().trim()
52
+ : getTypeName({
53
+ checker: props.context.checker,
54
+ type,
55
+ node,
56
+ }),
57
+ }),
58
+ undefined,
59
+ props.expression.arguments,
60
+ );
61
+ };
62
+
63
+ export const factory = (props: IProps) => {
64
+ // CHECK GENERIC ARGUMENT EXISTENCE
65
+ if (!props.expression.typeArguments?.[0])
66
+ throw new TransformerError({
67
+ code: `typia.${props.method}`,
68
+ message: `generic argument is not specified.`,
69
+ });
70
+
71
+ // GET TYPE INFO
72
+ const node: ts.TypeNode = props.expression.typeArguments[0];
73
+ const type: ts.Type = props.context.checker.getTypeFromTypeNode(node);
74
+
75
+ if (type.isTypeParameter())
76
+ throw new TransformerError({
77
+ code: `typia.${props.method}`,
78
+ message: `non-specified generic argument.`,
79
+ });
80
+
81
+ // DO TRANSFORM
82
+ return props.write({
83
+ context: props.context,
84
+ modulo: props.modulo,
85
+ type,
86
+ name: node.getFullText().trim(),
87
+ init: props.expression.arguments[0],
88
+ });
89
+ };
90
+
91
+ const getTypeName = (props: {
92
+ checker: ts.TypeChecker;
93
+ type: ts.Type;
94
+ node: ts.Node;
95
+ }): string =>
96
+ props.checker.typeToString(
97
+ props.type,
98
+ props.node,
99
+ ts.TypeFormatFlags.NodeBuilderFlagsMask,
100
+ );
101
+ }