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

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 { LiteralFactory } from "@typia/core";
2
- import ts from "typescript";
3
-
4
- import { ITransformProps } from "../../ITransformProps";
5
- import { TransformerError } from "../../TransformerError";
6
- import { LlmApplicationTransformer } from "./LlmApplicationTransformer";
7
-
8
- export namespace LlmControllerTransformer {
9
- export const transform = (props: ITransformProps): ts.Expression => {
10
- const dec = LlmApplicationTransformer.decompose("application", props);
11
- if (dec === null) return props.expression;
12
- else if (props.expression.arguments[0] === undefined)
13
- throw new TransformerError({
14
- code: `typia.llm.controller`,
15
- message: `no identifier name.`,
16
- });
17
- else if (props.expression.arguments[1] === undefined)
18
- throw new TransformerError({
19
- code: `typia.llm.controller`,
20
- message: `no executor.`,
21
- });
22
-
23
- const typeNode: ts.ImportTypeNode = props.context.importer.type({
24
- file: "typia",
25
- name: "ILlmController",
26
- arguments: [dec.node],
27
- });
28
- const primitiveTypeNode: ts.ImportTypeNode = props.context.importer.type({
29
- file: "typia",
30
- name: "ILlmApplication.__IPrimitive",
31
- arguments: [dec.node],
32
- });
33
- const value: ts.ObjectLiteralExpression =
34
- ts.factory.createObjectLiteralExpression(
35
- [
36
- ts.factory.createPropertyAssignment(
37
- "protocol",
38
- ts.factory.createStringLiteral("class"),
39
- ),
40
- ts.factory.createPropertyAssignment(
41
- "name",
42
- props.expression.arguments[0],
43
- ),
44
- ts.factory.createPropertyAssignment(
45
- "execute",
46
- props.expression.arguments[1],
47
- ),
48
- ts.factory.createPropertyAssignment(
49
- "application",
50
- ts.factory.createCallExpression(
51
- props.context.importer.internal("llmApplicationFinalize"),
52
- undefined,
53
- [
54
- ts.factory.createAsExpression(
55
- ts.factory.createSatisfiesExpression(
56
- LiteralFactory.write(dec.application),
57
- primitiveTypeNode,
58
- ),
59
- primitiveTypeNode,
60
- ),
61
- ...(props.expression.arguments?.[2] !== undefined
62
- ? [
63
- LlmApplicationTransformer.getConfigArgument({
64
- context: props.context,
65
- argument: props.expression.arguments[2],
66
- equals: dec.config?.equals,
67
- }),
68
- ]
69
- : []),
70
- ],
71
- ),
72
- ),
73
- ],
74
- true,
75
- );
76
- return ts.factory.createAsExpression(
77
- ts.factory.createSatisfiesExpression(value, typeNode),
78
- typeNode,
79
- );
80
- };
81
- }
1
+ import { LiteralFactory } from "@typia/core";
2
+ import ts from "typescript";
3
+
4
+ import { ITransformProps } from "../../ITransformProps";
5
+ import { TransformerError } from "../../TransformerError";
6
+ import { LlmApplicationTransformer } from "./LlmApplicationTransformer";
7
+
8
+ export namespace LlmControllerTransformer {
9
+ export const transform = (props: ITransformProps): ts.Expression => {
10
+ const dec = LlmApplicationTransformer.decompose("application", props);
11
+ if (dec === null) return props.expression;
12
+ else if (props.expression.arguments[0] === undefined)
13
+ throw new TransformerError({
14
+ code: `typia.llm.controller`,
15
+ message: `no identifier name.`,
16
+ });
17
+ else if (props.expression.arguments[1] === undefined)
18
+ throw new TransformerError({
19
+ code: `typia.llm.controller`,
20
+ message: `no executor.`,
21
+ });
22
+
23
+ const typeNode: ts.ImportTypeNode = props.context.importer.type({
24
+ file: "typia",
25
+ name: "ILlmController",
26
+ arguments: [dec.node],
27
+ });
28
+ const primitiveTypeNode: ts.ImportTypeNode = props.context.importer.type({
29
+ file: "typia",
30
+ name: "ILlmApplication.__IPrimitive",
31
+ arguments: [dec.node],
32
+ });
33
+ const value: ts.ObjectLiteralExpression =
34
+ ts.factory.createObjectLiteralExpression(
35
+ [
36
+ ts.factory.createPropertyAssignment(
37
+ "protocol",
38
+ ts.factory.createStringLiteral("class"),
39
+ ),
40
+ ts.factory.createPropertyAssignment(
41
+ "name",
42
+ props.expression.arguments[0],
43
+ ),
44
+ ts.factory.createPropertyAssignment(
45
+ "execute",
46
+ props.expression.arguments[1],
47
+ ),
48
+ ts.factory.createPropertyAssignment(
49
+ "application",
50
+ ts.factory.createCallExpression(
51
+ props.context.importer.internal("llmApplicationFinalize"),
52
+ undefined,
53
+ [
54
+ ts.factory.createAsExpression(
55
+ ts.factory.createSatisfiesExpression(
56
+ LiteralFactory.write(dec.application),
57
+ primitiveTypeNode,
58
+ ),
59
+ primitiveTypeNode,
60
+ ),
61
+ ...(props.expression.arguments?.[2] !== undefined
62
+ ? [
63
+ LlmApplicationTransformer.getConfigArgument({
64
+ context: props.context,
65
+ argument: props.expression.arguments[2],
66
+ equals: dec.config?.equals,
67
+ }),
68
+ ]
69
+ : []),
70
+ ],
71
+ ),
72
+ ),
73
+ ],
74
+ true,
75
+ );
76
+ return ts.factory.createAsExpression(
77
+ ts.factory.createSatisfiesExpression(value, typeNode),
78
+ typeNode,
79
+ );
80
+ };
81
+ }
@@ -1,84 +1,84 @@
1
- import {
2
- LlmCoerceProgrammer,
3
- LlmMetadataFactory,
4
- MetadataCollection,
5
- MetadataFactory,
6
- MetadataSchema,
7
- } from "@typia/core";
8
- import { ILlmSchema, ValidationPipe } from "@typia/interface";
9
- import ts from "typescript";
10
-
11
- import { ITransformProps } from "../../ITransformProps";
12
- import { TransformerError } from "../../TransformerError";
13
-
14
- export namespace LlmCreateCoerceTransformer {
15
- export const transform = (props: ITransformProps): ts.Expression => {
16
- // GET GENERIC ARGUMENT
17
- if (!props.expression.typeArguments?.length)
18
- throw new TransformerError({
19
- code: "typia.llm.createCoerce",
20
- message: "no generic argument.",
21
- });
22
-
23
- const top: ts.Node = props.expression.typeArguments[0]!;
24
- if (ts.isTypeNode(top) === false) return props.expression;
25
-
26
- // GET TYPE AND CONFIG
27
- const config: Partial<ILlmSchema.IConfig> = LlmMetadataFactory.getConfig({
28
- context: props.context,
29
- method: "createCoerce",
30
- node: props.expression.typeArguments[1],
31
- }) as Partial<ILlmSchema.IConfig>;
32
-
33
- const type: ts.Type = props.context.checker.getTypeFromTypeNode(top);
34
-
35
- if (type.isTypeParameter())
36
- throw new TransformerError({
37
- code: "typia.llm.createCoerce",
38
- message: "non-specified generic argument.",
39
- });
40
-
41
- // VALIDATE TYPE
42
- const analyze = (validate: boolean): MetadataSchema => {
43
- const result: ValidationPipe<MetadataSchema, MetadataFactory.IError> =
44
- MetadataFactory.analyze({
45
- checker: props.context.checker,
46
- transformer: props.context.transformer,
47
- options: {
48
- absorb: validate,
49
- escape: true,
50
- constant: true,
51
- validate:
52
- validate === true
53
- ? (metadata, explore) =>
54
- LlmCoerceProgrammer.validate({
55
- config,
56
- metadata,
57
- explore,
58
- })
59
- : undefined,
60
- },
61
- components: new MetadataCollection({
62
- replace: MetadataCollection.replace,
63
- }),
64
- type,
65
- });
66
- if (result.success === false)
67
- throw TransformerError.from({
68
- code: "typia.llm.createCoerce",
69
- errors: result.errors,
70
- });
71
- return result.data;
72
- };
73
- analyze(true);
74
-
75
- // GENERATE CODE (factory returns the function directly)
76
- return LlmCoerceProgrammer.write({
77
- context: props.context,
78
- modulo: props.modulo,
79
- metadata: analyze(false),
80
- name: (top as ts.TypeNode).getFullText().trim(),
81
- config,
82
- });
83
- };
84
- }
1
+ import {
2
+ LlmCoerceProgrammer,
3
+ LlmMetadataFactory,
4
+ MetadataCollection,
5
+ MetadataFactory,
6
+ MetadataSchema,
7
+ } from "@typia/core";
8
+ import { ILlmSchema, ValidationPipe } from "@typia/interface";
9
+ import ts from "typescript";
10
+
11
+ import { ITransformProps } from "../../ITransformProps";
12
+ import { TransformerError } from "../../TransformerError";
13
+
14
+ export namespace LlmCreateCoerceTransformer {
15
+ export const transform = (props: ITransformProps): ts.Expression => {
16
+ // GET GENERIC ARGUMENT
17
+ if (!props.expression.typeArguments?.length)
18
+ throw new TransformerError({
19
+ code: "typia.llm.createCoerce",
20
+ message: "no generic argument.",
21
+ });
22
+
23
+ const top: ts.Node = props.expression.typeArguments[0]!;
24
+ if (ts.isTypeNode(top) === false) return props.expression;
25
+
26
+ // GET TYPE AND CONFIG
27
+ const config: Partial<ILlmSchema.IConfig> = LlmMetadataFactory.getConfig({
28
+ context: props.context,
29
+ method: "createCoerce",
30
+ node: props.expression.typeArguments[1],
31
+ }) as Partial<ILlmSchema.IConfig>;
32
+
33
+ const type: ts.Type = props.context.checker.getTypeFromTypeNode(top);
34
+
35
+ if (type.isTypeParameter())
36
+ throw new TransformerError({
37
+ code: "typia.llm.createCoerce",
38
+ message: "non-specified generic argument.",
39
+ });
40
+
41
+ // VALIDATE TYPE
42
+ const analyze = (validate: boolean): MetadataSchema => {
43
+ const result: ValidationPipe<MetadataSchema, MetadataFactory.IError> =
44
+ MetadataFactory.analyze({
45
+ checker: props.context.checker,
46
+ transformer: props.context.transformer,
47
+ options: {
48
+ absorb: validate,
49
+ escape: true,
50
+ constant: true,
51
+ validate:
52
+ validate === true
53
+ ? (metadata, explore) =>
54
+ LlmCoerceProgrammer.validate({
55
+ config,
56
+ metadata,
57
+ explore,
58
+ })
59
+ : undefined,
60
+ },
61
+ components: new MetadataCollection({
62
+ replace: MetadataCollection.replace,
63
+ }),
64
+ type,
65
+ });
66
+ if (result.success === false)
67
+ throw TransformerError.from({
68
+ code: "typia.llm.createCoerce",
69
+ errors: result.errors,
70
+ });
71
+ return result.data;
72
+ };
73
+ analyze(true);
74
+
75
+ // GENERATE CODE (factory returns the function directly)
76
+ return LlmCoerceProgrammer.write({
77
+ context: props.context,
78
+ modulo: props.modulo,
79
+ metadata: analyze(false),
80
+ name: (top as ts.TypeNode).getFullText().trim(),
81
+ config,
82
+ });
83
+ };
84
+ }
@@ -1,84 +1,84 @@
1
- import {
2
- LlmMetadataFactory,
3
- LlmParseProgrammer,
4
- MetadataCollection,
5
- MetadataFactory,
6
- MetadataSchema,
7
- } from "@typia/core";
8
- import { ILlmSchema, ValidationPipe } from "@typia/interface";
9
- import ts from "typescript";
10
-
11
- import { ITransformProps } from "../../ITransformProps";
12
- import { TransformerError } from "../../TransformerError";
13
-
14
- export namespace LlmCreateParseTransformer {
15
- export const transform = (props: ITransformProps): ts.Expression => {
16
- // GET GENERIC ARGUMENT
17
- if (!props.expression.typeArguments?.length)
18
- throw new TransformerError({
19
- code: "typia.llm.createParse",
20
- message: "no generic argument.",
21
- });
22
-
23
- const top: ts.Node = props.expression.typeArguments[0]!;
24
- if (ts.isTypeNode(top) === false) return props.expression;
25
-
26
- // GET TYPE AND CONFIG
27
- const config: Partial<ILlmSchema.IConfig> = LlmMetadataFactory.getConfig({
28
- context: props.context,
29
- method: "createParse",
30
- node: props.expression.typeArguments[1],
31
- }) as Partial<ILlmSchema.IConfig>;
32
-
33
- const type: ts.Type = props.context.checker.getTypeFromTypeNode(top);
34
-
35
- if (type.isTypeParameter())
36
- throw new TransformerError({
37
- code: "typia.llm.createParse",
38
- message: "non-specified generic argument.",
39
- });
40
-
41
- // VALIDATE TYPE
42
- const analyze = (validate: boolean): MetadataSchema => {
43
- const result: ValidationPipe<MetadataSchema, MetadataFactory.IError> =
44
- MetadataFactory.analyze({
45
- checker: props.context.checker,
46
- transformer: props.context.transformer,
47
- options: {
48
- absorb: validate,
49
- escape: true,
50
- constant: true,
51
- validate:
52
- validate === true
53
- ? (metadata, explore) =>
54
- LlmParseProgrammer.validate({
55
- config,
56
- metadata,
57
- explore,
58
- })
59
- : undefined,
60
- },
61
- components: new MetadataCollection({
62
- replace: MetadataCollection.replace,
63
- }),
64
- type,
65
- });
66
- if (result.success === false)
67
- throw TransformerError.from({
68
- code: "typia.llm.createParse",
69
- errors: result.errors,
70
- });
71
- return result.data;
72
- };
73
- analyze(true);
74
-
75
- // GENERATE CODE (factory returns the function directly)
76
- return LlmParseProgrammer.write({
77
- context: props.context,
78
- modulo: props.modulo,
79
- metadata: analyze(false),
80
- name: (top as ts.TypeNode).getFullText().trim(),
81
- config,
82
- });
83
- };
84
- }
1
+ import {
2
+ LlmMetadataFactory,
3
+ LlmParseProgrammer,
4
+ MetadataCollection,
5
+ MetadataFactory,
6
+ MetadataSchema,
7
+ } from "@typia/core";
8
+ import { ILlmSchema, ValidationPipe } from "@typia/interface";
9
+ import ts from "typescript";
10
+
11
+ import { ITransformProps } from "../../ITransformProps";
12
+ import { TransformerError } from "../../TransformerError";
13
+
14
+ export namespace LlmCreateParseTransformer {
15
+ export const transform = (props: ITransformProps): ts.Expression => {
16
+ // GET GENERIC ARGUMENT
17
+ if (!props.expression.typeArguments?.length)
18
+ throw new TransformerError({
19
+ code: "typia.llm.createParse",
20
+ message: "no generic argument.",
21
+ });
22
+
23
+ const top: ts.Node = props.expression.typeArguments[0]!;
24
+ if (ts.isTypeNode(top) === false) return props.expression;
25
+
26
+ // GET TYPE AND CONFIG
27
+ const config: Partial<ILlmSchema.IConfig> = LlmMetadataFactory.getConfig({
28
+ context: props.context,
29
+ method: "createParse",
30
+ node: props.expression.typeArguments[1],
31
+ }) as Partial<ILlmSchema.IConfig>;
32
+
33
+ const type: ts.Type = props.context.checker.getTypeFromTypeNode(top);
34
+
35
+ if (type.isTypeParameter())
36
+ throw new TransformerError({
37
+ code: "typia.llm.createParse",
38
+ message: "non-specified generic argument.",
39
+ });
40
+
41
+ // VALIDATE TYPE
42
+ const analyze = (validate: boolean): MetadataSchema => {
43
+ const result: ValidationPipe<MetadataSchema, MetadataFactory.IError> =
44
+ MetadataFactory.analyze({
45
+ checker: props.context.checker,
46
+ transformer: props.context.transformer,
47
+ options: {
48
+ absorb: validate,
49
+ escape: true,
50
+ constant: true,
51
+ validate:
52
+ validate === true
53
+ ? (metadata, explore) =>
54
+ LlmParseProgrammer.validate({
55
+ config,
56
+ metadata,
57
+ explore,
58
+ })
59
+ : undefined,
60
+ },
61
+ components: new MetadataCollection({
62
+ replace: MetadataCollection.replace,
63
+ }),
64
+ type,
65
+ });
66
+ if (result.success === false)
67
+ throw TransformerError.from({
68
+ code: "typia.llm.createParse",
69
+ errors: result.errors,
70
+ });
71
+ return result.data;
72
+ };
73
+ analyze(true);
74
+
75
+ // GENERATE CODE (factory returns the function directly)
76
+ return LlmParseProgrammer.write({
77
+ context: props.context,
78
+ modulo: props.modulo,
79
+ metadata: analyze(false),
80
+ name: (top as ts.TypeNode).getFullText().trim(),
81
+ config,
82
+ });
83
+ };
84
+ }
@@ -1,76 +1,76 @@
1
- import {
2
- LlmMetadataFactory,
3
- LlmParametersProgrammer,
4
- MetadataCollection,
5
- MetadataFactory,
6
- MetadataSchema,
7
- } from "@typia/core";
8
- import { ILlmSchema, ValidationPipe } from "@typia/interface";
9
- import ts from "typescript";
10
-
11
- import { ITransformProps } from "../../ITransformProps";
12
- import { TransformerError } from "../../TransformerError";
13
-
14
- export namespace LlmParametersTransformer {
15
- export const transform = (props: ITransformProps): ts.Expression => {
16
- // GET GENERIC ARGUMENT
17
- if (!props.expression.typeArguments?.length)
18
- throw new TransformerError({
19
- code: "typia.llm.parameters",
20
- message: "no generic argument.",
21
- });
22
-
23
- const top: ts.Node = props.expression.typeArguments[0]!;
24
- if (ts.isTypeNode(top) === false) return props.expression;
25
-
26
- // GET TYPE
27
- const config: Partial<ILlmSchema.IConfig> = LlmMetadataFactory.getConfig({
28
- context: props.context,
29
- method: "parameters",
30
- node: props.expression.typeArguments[1],
31
- }) as Partial<ILlmSchema.IConfig>;
32
-
33
- const type: ts.Type = props.context.checker.getTypeFromTypeNode(top);
34
-
35
- // VALIDATE TYPE
36
- const analyze = (validate: boolean): MetadataSchema => {
37
- const result: ValidationPipe<MetadataSchema, MetadataFactory.IError> =
38
- MetadataFactory.analyze({
39
- checker: props.context.checker,
40
- transformer: props.context.transformer,
41
- options: {
42
- absorb: validate,
43
- escape: true,
44
- constant: true,
45
- validate:
46
- validate === true
47
- ? (metadata, explore) =>
48
- LlmParametersProgrammer.validate({
49
- config,
50
- metadata,
51
- explore,
52
- })
53
- : undefined,
54
- },
55
- components: new MetadataCollection({
56
- replace: MetadataCollection.replace,
57
- }),
58
- type,
59
- });
60
- if (result.success === false)
61
- throw TransformerError.from({
62
- code: "typia.llm.parameters",
63
- errors: result.errors,
64
- });
65
- return result.data;
66
- };
67
- analyze(true);
68
-
69
- // GENERATE LLM PARAMETERS SCHEMA
70
- return LlmParametersProgrammer.write({
71
- context: props.context,
72
- metadata: analyze(false),
73
- config,
74
- });
75
- };
76
- }
1
+ import {
2
+ LlmMetadataFactory,
3
+ LlmParametersProgrammer,
4
+ MetadataCollection,
5
+ MetadataFactory,
6
+ MetadataSchema,
7
+ } from "@typia/core";
8
+ import { ILlmSchema, ValidationPipe } from "@typia/interface";
9
+ import ts from "typescript";
10
+
11
+ import { ITransformProps } from "../../ITransformProps";
12
+ import { TransformerError } from "../../TransformerError";
13
+
14
+ export namespace LlmParametersTransformer {
15
+ export const transform = (props: ITransformProps): ts.Expression => {
16
+ // GET GENERIC ARGUMENT
17
+ if (!props.expression.typeArguments?.length)
18
+ throw new TransformerError({
19
+ code: "typia.llm.parameters",
20
+ message: "no generic argument.",
21
+ });
22
+
23
+ const top: ts.Node = props.expression.typeArguments[0]!;
24
+ if (ts.isTypeNode(top) === false) return props.expression;
25
+
26
+ // GET TYPE
27
+ const config: Partial<ILlmSchema.IConfig> = LlmMetadataFactory.getConfig({
28
+ context: props.context,
29
+ method: "parameters",
30
+ node: props.expression.typeArguments[1],
31
+ }) as Partial<ILlmSchema.IConfig>;
32
+
33
+ const type: ts.Type = props.context.checker.getTypeFromTypeNode(top);
34
+
35
+ // VALIDATE TYPE
36
+ const analyze = (validate: boolean): MetadataSchema => {
37
+ const result: ValidationPipe<MetadataSchema, MetadataFactory.IError> =
38
+ MetadataFactory.analyze({
39
+ checker: props.context.checker,
40
+ transformer: props.context.transformer,
41
+ options: {
42
+ absorb: validate,
43
+ escape: true,
44
+ constant: true,
45
+ validate:
46
+ validate === true
47
+ ? (metadata, explore) =>
48
+ LlmParametersProgrammer.validate({
49
+ config,
50
+ metadata,
51
+ explore,
52
+ })
53
+ : undefined,
54
+ },
55
+ components: new MetadataCollection({
56
+ replace: MetadataCollection.replace,
57
+ }),
58
+ type,
59
+ });
60
+ if (result.success === false)
61
+ throw TransformerError.from({
62
+ code: "typia.llm.parameters",
63
+ errors: result.errors,
64
+ });
65
+ return result.data;
66
+ };
67
+ analyze(true);
68
+
69
+ // GENERATE LLM PARAMETERS SCHEMA
70
+ return LlmParametersProgrammer.write({
71
+ context: props.context,
72
+ metadata: analyze(false),
73
+ config,
74
+ });
75
+ };
76
+ }