@wener/utils 1.1.48 → 1.1.49

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 (145) hide show
  1. package/lib/asyncs/Promises.js +9 -1
  2. package/lib/asyncs/Promises.js.map +1 -1
  3. package/lib/asyncs/createLazyPromise.js +52 -51
  4. package/lib/asyncs/createLazyPromise.js.map +1 -1
  5. package/lib/asyncs/firstOfAsyncIterator.js.map +1 -1
  6. package/lib/asyncs/nextOfAsyncIterator.js.map +1 -1
  7. package/lib/asyncs/timeout.js +4 -4
  8. package/lib/asyncs/timeout.js.map +1 -1
  9. package/lib/cn/types.js +3 -0
  10. package/lib/cn/types.js.map +1 -0
  11. package/lib/crypto/getNodeCrypto.js +1 -0
  12. package/lib/crypto/getNodeCrypto.js.map +1 -1
  13. package/lib/fetch/createFetchWith.js.map +1 -1
  14. package/lib/fetch/createFetchWithRetry.js.map +1 -1
  15. package/lib/index.js +2 -0
  16. package/lib/index.js.map +1 -1
  17. package/lib/io/ArrayBuffers.js.map +1 -1
  18. package/lib/io/ByteBuffer.js +233 -34
  19. package/lib/io/ByteBuffer.js.map +1 -1
  20. package/lib/langs/getGlobalStates.js +17 -0
  21. package/lib/langs/getGlobalStates.js.map +1 -0
  22. package/lib/langs/getObjectId.js +18 -0
  23. package/lib/langs/getObjectId.js.map +1 -0
  24. package/lib/langs/isNullish.js +5 -0
  25. package/lib/langs/isNullish.js.map +1 -0
  26. package/lib/logging/slog.js.map +1 -1
  27. package/lib/maths/clamp.js +7 -6
  28. package/lib/maths/clamp.js.map +1 -1
  29. package/lib/schema/typebox/typebox.js.map +1 -1
  30. package/lib/server/fetch/createFetchWithProxyByUndici.js.map +1 -1
  31. package/package.json +3 -3
  32. package/src/asyncs/Promises.ts +12 -2
  33. package/src/asyncs/createLazyPromise.test.ts +52 -13
  34. package/src/asyncs/createLazyPromise.ts +66 -61
  35. package/src/asyncs/firstOfAsyncIterator.ts +1 -1
  36. package/src/asyncs/nextOfAsyncIterator.ts +1 -1
  37. package/src/asyncs/timeout.ts +4 -4
  38. package/src/cn/types.ts +11 -0
  39. package/src/crypto/getNodeCrypto.ts +1 -0
  40. package/src/fetch/createFetchWith.ts +1 -1
  41. package/src/fetch/createFetchWithRetry.ts +1 -1
  42. package/src/index.ts +2 -0
  43. package/src/io/ArrayBuffers.ts +7 -3
  44. package/src/io/ByteBuffer.test.ts +26 -14
  45. package/src/io/ByteBuffer.ts +270 -38
  46. package/src/langs/getGlobalStates.ts +21 -0
  47. package/src/langs/getObjectId.ts +20 -0
  48. package/src/langs/isNullish.ts +3 -0
  49. package/src/langs/mixin.test.ts +4 -0
  50. package/src/logging/slog.ts +1 -1
  51. package/src/maths/clamp.test.ts +5 -1
  52. package/src/maths/clamp.ts +7 -7
  53. package/src/objects/merge/merge.test.ts +1 -1
  54. package/src/schema/typebox/typebox.ts +1 -1
  55. package/src/server/fetch/createFetchWithProxyByUndici.ts +2 -2
  56. package/tsconfig.json +4 -1
  57. package/lib/schema/typebox/gen/codegen/common/encoder.js +0 -94
  58. package/lib/schema/typebox/gen/codegen/common/encoder.js.map +0 -1
  59. package/lib/schema/typebox/gen/codegen/common/formatter.js +0 -33
  60. package/lib/schema/typebox/gen/codegen/common/formatter.js.map +0 -1
  61. package/lib/schema/typebox/gen/codegen/common/index.js +0 -29
  62. package/lib/schema/typebox/gen/codegen/common/index.js.map +0 -1
  63. package/lib/schema/typebox/gen/codegen/common/jsdoc.js +0 -117
  64. package/lib/schema/typebox/gen/codegen/common/jsdoc.js.map +0 -1
  65. package/lib/schema/typebox/gen/codegen/expression/compiler.js +0 -364
  66. package/lib/schema/typebox/gen/codegen/expression/compiler.js.map +0 -1
  67. package/lib/schema/typebox/gen/codegen/expression/errors.js +0 -259
  68. package/lib/schema/typebox/gen/codegen/expression/errors.js.map +0 -1
  69. package/lib/schema/typebox/gen/codegen/expression/evaluator.js +0 -254
  70. package/lib/schema/typebox/gen/codegen/expression/evaluator.js.map +0 -1
  71. package/lib/schema/typebox/gen/codegen/expression/expression.js +0 -381
  72. package/lib/schema/typebox/gen/codegen/expression/expression.js.map +0 -1
  73. package/lib/schema/typebox/gen/codegen/expression/index.js +0 -32
  74. package/lib/schema/typebox/gen/codegen/expression/index.js.map +0 -1
  75. package/lib/schema/typebox/gen/codegen/index.js +0 -29
  76. package/lib/schema/typebox/gen/codegen/index.js.map +0 -1
  77. package/lib/schema/typebox/gen/codegen/model/index.js +0 -40
  78. package/lib/schema/typebox/gen/codegen/model/index.js.map +0 -1
  79. package/lib/schema/typebox/gen/codegen/model/model-to-arktype.js +0 -260
  80. package/lib/schema/typebox/gen/codegen/model/model-to-arktype.js.map +0 -1
  81. package/lib/schema/typebox/gen/codegen/model/model-to-expression.js +0 -383
  82. package/lib/schema/typebox/gen/codegen/model/model-to-expression.js.map +0 -1
  83. package/lib/schema/typebox/gen/codegen/model/model-to-grpc.js +0 -238
  84. package/lib/schema/typebox/gen/codegen/model/model-to-grpc.js.map +0 -1
  85. package/lib/schema/typebox/gen/codegen/model/model-to-io-ts.js +0 -274
  86. package/lib/schema/typebox/gen/codegen/model/model-to-io-ts.js.map +0 -1
  87. package/lib/schema/typebox/gen/codegen/model/model-to-javascript.js +0 -47
  88. package/lib/schema/typebox/gen/codegen/model/model-to-javascript.js.map +0 -1
  89. package/lib/schema/typebox/gen/codegen/model/model-to-json-schema.js +0 -192
  90. package/lib/schema/typebox/gen/codegen/model/model-to-json-schema.js.map +0 -1
  91. package/lib/schema/typebox/gen/codegen/model/model-to-typebox.js +0 -33
  92. package/lib/schema/typebox/gen/codegen/model/model-to-typebox.js.map +0 -1
  93. package/lib/schema/typebox/gen/codegen/model/model-to-typescript.js +0 -188
  94. package/lib/schema/typebox/gen/codegen/model/model-to-typescript.js.map +0 -1
  95. package/lib/schema/typebox/gen/codegen/model/model-to-valibot.js +0 -239
  96. package/lib/schema/typebox/gen/codegen/model/model-to-valibot.js.map +0 -1
  97. package/lib/schema/typebox/gen/codegen/model/model-to-value.js +0 -43
  98. package/lib/schema/typebox/gen/codegen/model/model-to-value.js.map +0 -1
  99. package/lib/schema/typebox/gen/codegen/model/model-to-yrel.js +0 -227
  100. package/lib/schema/typebox/gen/codegen/model/model-to-yrel.js.map +0 -1
  101. package/lib/schema/typebox/gen/codegen/model/model-to-yup.js +0 -225
  102. package/lib/schema/typebox/gen/codegen/model/model-to-yup.js.map +0 -1
  103. package/lib/schema/typebox/gen/codegen/model/model-to-zod.js +0 -248
  104. package/lib/schema/typebox/gen/codegen/model/model-to-zod.js.map +0 -1
  105. package/lib/schema/typebox/gen/codegen/model/model.js +0 -27
  106. package/lib/schema/typebox/gen/codegen/model/model.js.map +0 -1
  107. package/lib/schema/typebox/gen/codegen/typescript/index.js +0 -28
  108. package/lib/schema/typebox/gen/codegen/typescript/index.js.map +0 -1
  109. package/lib/schema/typebox/gen/codegen/typescript/typescript-to-model.js +0 -72
  110. package/lib/schema/typebox/gen/codegen/typescript/typescript-to-model.js.map +0 -1
  111. package/lib/schema/typebox/gen/codegen/typescript/typescript-to-typebox.js +0 -620
  112. package/lib/schema/typebox/gen/codegen/typescript/typescript-to-typebox.js.map +0 -1
  113. package/lib/schema/typebox/gen/index.js +0 -3
  114. package/lib/schema/typebox/gen/index.js.map +0 -1
  115. package/src/schema/typebox/gen/codegen/common/encoder.ts +0 -99
  116. package/src/schema/typebox/gen/codegen/common/formatter.ts +0 -31
  117. package/src/schema/typebox/gen/codegen/common/index.ts +0 -29
  118. package/src/schema/typebox/gen/codegen/common/jsdoc.ts +0 -93
  119. package/src/schema/typebox/gen/codegen/expression/compiler.ts +0 -377
  120. package/src/schema/typebox/gen/codegen/expression/errors.ts +0 -302
  121. package/src/schema/typebox/gen/codegen/expression/evaluator.ts +0 -268
  122. package/src/schema/typebox/gen/codegen/expression/expression.ts +0 -538
  123. package/src/schema/typebox/gen/codegen/expression/index.ts +0 -32
  124. package/src/schema/typebox/gen/codegen/index.ts +0 -29
  125. package/src/schema/typebox/gen/codegen/model/index.ts +0 -40
  126. package/src/schema/typebox/gen/codegen/model/model-to-arktype.ts +0 -266
  127. package/src/schema/typebox/gen/codegen/model/model-to-expression.ts +0 -378
  128. package/src/schema/typebox/gen/codegen/model/model-to-grpc.ts +0 -244
  129. package/src/schema/typebox/gen/codegen/model/model-to-io-ts.ts +0 -294
  130. package/src/schema/typebox/gen/codegen/model/model-to-javascript.ts +0 -42
  131. package/src/schema/typebox/gen/codegen/model/model-to-json-schema.ts +0 -166
  132. package/src/schema/typebox/gen/codegen/model/model-to-typebox.ts +0 -32
  133. package/src/schema/typebox/gen/codegen/model/model-to-typescript.ts +0 -189
  134. package/src/schema/typebox/gen/codegen/model/model-to-valibot.ts +0 -236
  135. package/src/schema/typebox/gen/codegen/model/model-to-value.ts +0 -42
  136. package/src/schema/typebox/gen/codegen/model/model-to-yrel.ts +0 -232
  137. package/src/schema/typebox/gen/codegen/model/model-to-yup.ts +0 -226
  138. package/src/schema/typebox/gen/codegen/model/model-to-zod.ts +0 -251
  139. package/src/schema/typebox/gen/codegen/model/model.ts +0 -33
  140. package/src/schema/typebox/gen/codegen/typescript/index.ts +0 -28
  141. package/src/schema/typebox/gen/codegen/typescript/typescript-to-model.ts +0 -61
  142. package/src/schema/typebox/gen/codegen/typescript/typescript-to-typebox.ts +0 -647
  143. package/src/schema/typebox/gen/gen.test.ts +0 -12
  144. package/src/schema/typebox/gen/index.ts +0 -1
  145. /package/src/schema/{typebox/gen/README.md → README.md} +0 -0
@@ -1,620 +0,0 @@
1
- /*--------------------------------------------------------------------------
2
-
3
- @sinclair/typebox-codegen
4
-
5
- The MIT License (MIT)
6
-
7
- Permission is hereby granted, free of charge, to any person obtaining a copy
8
- of this software and associated documentation files (the "Software"), to deal
9
- in the Software without restriction, including without limitation the rights
10
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11
- copies of the Software, and to permit persons to whom the Software is
12
- furnished to do so, subject to the following conditions:
13
-
14
- The above copyright notice and this permission notice shall be included in
15
- all copies or substantial portions of the Software.
16
-
17
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23
- THE SOFTWARE.
24
-
25
- ---------------------------------------------------------------------------*/ import * as ts from 'typescript';
26
- import { JsDoc } from '../common/jsdoc.js';
27
- export class TypeScriptToTypeBoxError extends Error {
28
- diagnostics;
29
- constructor(diagnostics){
30
- super('');
31
- this.diagnostics = diagnostics;
32
- }
33
- }
34
- export var TypeScriptToTypeBox;
35
- (function(TypeScriptToTypeBox) {
36
- // ------------------------------------------------------------------------------------------------------------
37
- // Transpile Options
38
- // ------------------------------------------------------------------------------------------------------------
39
- const transpilerOptions = {
40
- compilerOptions: {
41
- strict: true,
42
- target: ts.ScriptTarget.ES2022
43
- }
44
- };
45
- // ------------------------------------------------------------------------------------------------------------
46
- // Transpile States
47
- // ------------------------------------------------------------------------------------------------------------
48
- // (auto) tracked on calls to find type name
49
- const typenames = new Set();
50
- // (auto) tracked for recursive types and used to associate This type references
51
- let recursiveDeclaration = null;
52
- // (auto) tracked for scoped block level definitions and used to prevent `export` emit when not in global scope.
53
- let blockLevel = 0;
54
- // (auto) tracked for injecting typebox import statements
55
- let useImports = false;
56
- // (auto) tracked for injecting JSON schema optios
57
- let useOptions = false;
58
- // (auto) tracked for injecting TSchema import statements
59
- let useGenerics = false;
60
- // (auto) tracked for cases where composition requires deep clone
61
- let useCloneType = false;
62
- // (option) export override to ensure all schematics
63
- let useExportsEverything = false;
64
- // (option) inject identifiers
65
- let useIdentifiers = false;
66
- // (option) specifies if typebox imports should be included
67
- let useTypeBoxImport = true;
68
- // ------------------------------------------------------------------------------------------------------------
69
- // AST Query
70
- // ------------------------------------------------------------------------------------------------------------
71
- function FindRecursiveParent(decl, node) {
72
- return ts.isTypeReferenceNode(node) && decl.name.getText() === node.typeName.getText() || node.getChildren().some((node)=>FindRecursiveParent(decl, node));
73
- }
74
- function FindRecursiveThis(node) {
75
- return node.getChildren().some((node)=>ts.isThisTypeNode(node) || FindRecursiveThis(node));
76
- }
77
- function FindTypeName(node, name) {
78
- const found = typenames.has(name) || node.getChildren().some((node)=>{
79
- return (ts.isInterfaceDeclaration(node) || ts.isTypeAliasDeclaration(node)) && node.name.getText() === name || FindTypeName(node, name);
80
- });
81
- if (found) typenames.add(name);
82
- return found;
83
- }
84
- function IsRecursiveType(decl) {
85
- const check1 = ts.isTypeAliasDeclaration(decl) ? [
86
- decl.type
87
- ].some((node)=>FindRecursiveParent(decl, node)) : decl.members.some((node)=>FindRecursiveParent(decl, node));
88
- const check2 = ts.isInterfaceDeclaration(decl) && FindRecursiveThis(decl);
89
- return check1 || check2;
90
- }
91
- function IsReadonlyProperty(node) {
92
- return node.modifiers !== undefined && node.modifiers.find((modifier)=>modifier.getText() === 'readonly') !== undefined;
93
- }
94
- function IsOptionalProperty(node) {
95
- return node.questionToken !== undefined;
96
- }
97
- function IsExport(node) {
98
- return blockLevel === 0 && (useExportsEverything || node.modifiers !== undefined && node.modifiers.find((modifier)=>modifier.getText() === 'export') !== undefined);
99
- }
100
- function IsNamespace(node) {
101
- return node.flags === ts.NodeFlags.Namespace;
102
- }
103
- // ------------------------------------------------------------------------------------------------------------
104
- // Options
105
- // ------------------------------------------------------------------------------------------------------------
106
- function ResolveJsDocComment(node) {
107
- const content = node.getFullText().trim();
108
- if (node.kind === ts.SyntaxKind.LiteralType) {
109
- if (content.startsWith('/**')) {
110
- // add a new line for JsDoc to parse properly
111
- return content.slice(0, content.lastIndexOf('*/') + 2).replace(/\*+\/$/, '\n$0');
112
- } else {
113
- return '';
114
- }
115
- }
116
- const indices = [
117
- content.indexOf('/**'),
118
- content.indexOf('type'),
119
- content.indexOf('interface')
120
- ].map((n)=>n === -1 ? Infinity : n);
121
- if (indices[0] === -1 || indices[1] < indices[0] || indices[2] < indices[0]) return ''; // no comment or declaration before comment
122
- for(let i = indices[0]; i < content.length; i++){
123
- if (content[i] === '*' && content[i + 1] === '/') return content.slice(0, i + 2);
124
- }
125
- return '';
126
- }
127
- function ResolveOptions(node) {
128
- const content = ResolveJsDocComment(node);
129
- return JsDoc.Parse(content);
130
- }
131
- // ------------------------------------------------------------------------------------------------------------
132
- // Identifiers
133
- // ------------------------------------------------------------------------------------------------------------
134
- function ResolveIdentifier(node) {
135
- function* resolve(node) {
136
- if (node.parent) yield* resolve(node.parent);
137
- if (ts.isModuleDeclaration(node)) yield node.name.getText();
138
- }
139
- return [
140
- ...resolve(node),
141
- node.name.getText()
142
- ].join('.');
143
- }
144
- function UnwrapModifier(type) {
145
- for(let i = 0; i < type.length; i++)if (type[i] === '(') return type.slice(i + 1, type.length - 1);
146
- return type;
147
- }
148
- // Note: This function is only called when 'useIdentifiers' is true. What we're trying to achieve with
149
- // identifier injection is a referential type model over the default inline model. For the purposes of
150
- // code generation, we tend to prefer referential types as these can be both inlined or referenced in
151
- // the codegen target; and where different targets may have different referential requirements. It
152
- // should be possible to implement a more robust injection mechanism however. For review.
153
- // prettier-ignore
154
- function InjectOptions(type, options) {
155
- if (globalThis.Object.keys(options).length === 0) return type;
156
- // unwrap for modifiers
157
- if (type.indexOf('Type.ReadonlyOptional') === 0) return `Type.ReadonlyOptional( ${InjectOptions(UnwrapModifier(type), options)} )`;
158
- if (type.indexOf('Type.Readonly') === 0) return `Type.Readonly( ${InjectOptions(UnwrapModifier(type), options)} )`;
159
- if (type.indexOf('Type.Optional') === 0) return `Type.Optional( ${InjectOptions(UnwrapModifier(type), options)} )`;
160
- const encoded = JSON.stringify(options);
161
- // indexer type
162
- if (type.lastIndexOf(']') === type.length - 1) useCloneType = true;
163
- if (type.lastIndexOf(']') === type.length - 1) return `CloneType(${type}, ${encoded})`;
164
- // referenced type
165
- if (type.indexOf('(') === -1) {
166
- useCloneType = true;
167
- return `CloneType(${type}, ${encoded})`;
168
- }
169
- if (type.lastIndexOf('()') === type.length - 2) return type.slice(0, type.length - 1) + `${encoded})`;
170
- if (type.lastIndexOf('})') === type.length - 2) return type.slice(0, type.length - 1) + `, ${encoded})`;
171
- if (type.lastIndexOf('])') === type.length - 2) return type.slice(0, type.length - 1) + `, ${encoded})`;
172
- if (type.lastIndexOf(')') === type.length - 1) return type.slice(0, type.length - 1) + `, ${encoded})`;
173
- return type;
174
- }
175
- // ------------------------------------------------------------------------------------------------------------
176
- // Nodes
177
- // ------------------------------------------------------------------------------------------------------------
178
- function* SourceFile(node) {
179
- for (const next of node.getChildren()){
180
- yield* Visit(next);
181
- }
182
- }
183
- function* PropertySignature(node) {
184
- const [readonly, optional] = [
185
- IsReadonlyProperty(node),
186
- IsOptionalProperty(node)
187
- ];
188
- const options = ResolveOptions(node);
189
- const type_0 = Collect(node.type);
190
- const type_1 = InjectOptions(type_0, options);
191
- if (readonly && optional) {
192
- return yield `${node.name.getText()}: Type.ReadonlyOptional(${type_1})`;
193
- } else if (readonly) {
194
- return yield `${node.name.getText()}: Type.Readonly(${type_1})`;
195
- } else if (optional) {
196
- return yield `${node.name.getText()}: Type.Optional(${type_1})`;
197
- } else {
198
- return yield `${node.name.getText()}: ${type_1}`;
199
- }
200
- }
201
- function* ArrayTypeNode(node) {
202
- const type = Collect(node.elementType);
203
- yield `Type.Array(${type})`;
204
- }
205
- function* Block(node) {
206
- blockLevel += 1;
207
- const statments = node.statements.map((statement)=>Collect(statement)).join('\n\n');
208
- blockLevel -= 1;
209
- yield `{\n${statments}\n}`;
210
- }
211
- function* TupleTypeNode(node) {
212
- const types = node.elements.map((type)=>Collect(type)).join(',\n');
213
- yield `Type.Tuple([\n${types}\n])`;
214
- }
215
- function* UnionTypeNode(node) {
216
- const types = node.types.map((type)=>Collect(type)).join(',\n');
217
- yield `Type.Union([\n${types}\n])`;
218
- }
219
- function* MappedTypeNode(node) {
220
- const K = Collect(node.typeParameter);
221
- const T = Collect(node.type);
222
- const C = Collect(node.typeParameter.constraint);
223
- const readonly = node.readonlyToken !== undefined;
224
- const optional = node.questionToken !== undefined;
225
- const readonly_subtractive = readonly && ts.isMinusToken(node.readonlyToken);
226
- const optional_subtractive = optional && ts.isMinusToken(node.questionToken);
227
- // prettier-ignore
228
- return yield readonly && optional ? readonly_subtractive && optional_subtractive ? `Type.Mapped(${C}, ${K} => Type.Readonly(Type.Optional(${T}, false), false))` : readonly_subtractive ? `Type.Mapped(${C}, ${K} => Type.Readonly(Type.Optional(${T}), false))` : optional_subtractive ? `Type.Mapped(${C}, ${K} => Type.Readonly(Type.Optional(${T}, false)))` : `Type.Mapped(${C}, ${K} => Type.Readonly(Type.Optional(${T})))` : readonly ? readonly_subtractive ? `Type.Mapped(${C}, ${K} => Type.Readonly(${T}, false))` : `Type.Mapped(${C}, ${K} => Type.Readonly(${T}))` : optional ? optional_subtractive ? `Type.Mapped(${C}, ${K} => Type.Optional(${T}, false))` : `Type.Mapped(${C}, ${K} => Type.Optional(${T}))` : `Type.Mapped(${C}, ${K} => ${T})`;
229
- }
230
- function* MethodSignature(node) {
231
- const parameters = node.parameters.map((parameter)=>parameter.dotDotDotToken !== undefined ? `...Type.Rest(${Collect(parameter)})` : Collect(parameter)).join(', ');
232
- const returnType = node.type === undefined ? `Type.Unknown()` : Collect(node.type);
233
- yield `${node.name.getText()}: Type.Function([${parameters}], ${returnType})`;
234
- }
235
- // prettier-ignore
236
- function* TemplateLiteralTypeNode(node) {
237
- const collect = node.getChildren().map((node)=>Collect(node)).join('');
238
- yield `Type.TemplateLiteral([${collect.slice(0, collect.length - 2)}])` // can't remove trailing here
239
- ;
240
- }
241
- // prettier-ignore
242
- function* TemplateLiteralTypeSpan(node) {
243
- const collect = node.getChildren().map((node)=>Collect(node)).join(', ');
244
- if (collect.length > 0) yield `${collect}`;
245
- }
246
- function* TemplateHead(node) {
247
- if (node.text.length > 0) yield `Type.Literal('${node.text}'), `;
248
- }
249
- function* TemplateMiddle(node) {
250
- if (node.text.length > 0) yield `Type.Literal('${node.text}'), `;
251
- }
252
- function* TemplateTail(node) {
253
- if (node.text.length > 0) yield `Type.Literal('${node.text}'), `;
254
- }
255
- function* ThisTypeNode(node) {
256
- yield `This`;
257
- }
258
- function* IntersectionTypeNode(node) {
259
- const types = node.types.map((type)=>Collect(type)).join(',\n');
260
- yield `Type.Intersect([\n${types}\n])`;
261
- }
262
- function* TypeOperatorNode(node) {
263
- if (node.operator === ts.SyntaxKind.KeyOfKeyword) {
264
- const type = Collect(node.type);
265
- yield `Type.KeyOf(${type})`;
266
- }
267
- if (node.operator === ts.SyntaxKind.ReadonlyKeyword) {
268
- yield `Type.Readonly(${Collect(node.type)})`;
269
- }
270
- }
271
- function* Parameter(node) {
272
- yield Collect(node.type);
273
- }
274
- function* FunctionTypeNode(node) {
275
- const parameters = node.parameters.map((parameter)=>parameter.dotDotDotToken !== undefined ? `...Type.Rest(${Collect(parameter)})` : Collect(parameter)).join(', ');
276
- const returns = Collect(node.type);
277
- yield `Type.Function([${parameters}], ${returns})`;
278
- }
279
- function* ConstructorTypeNode(node) {
280
- const parameters = node.parameters.map((param)=>Collect(param)).join(', ');
281
- const returns = Collect(node.type);
282
- yield `Type.Constructor([${parameters}], ${returns})`;
283
- }
284
- function* EnumDeclaration(node) {
285
- useImports = true;
286
- const exports = IsExport(node) ? 'export ' : '';
287
- const members = node.members.map((member)=>member.getText()).join(', ');
288
- const enumType = `${exports}enum Enum${node.name.getText()} { ${members} }`;
289
- const staticType = `${exports}type ${node.name.getText()} = Static<typeof ${node.name.getText()}>`;
290
- const type = `${exports}const ${node.name.getText()} = Type.Enum(Enum${node.name.getText()})`;
291
- yield [
292
- enumType,
293
- '',
294
- staticType,
295
- type
296
- ].join('\n');
297
- }
298
- function PropertiesFromTypeElementArray(members) {
299
- const properties = members.filter((member)=>!ts.isIndexSignatureDeclaration(member));
300
- const indexers = members.filter((member)=>ts.isIndexSignatureDeclaration(member));
301
- const propertyCollect = properties.map((property)=>Collect(property)).join(',\n');
302
- const indexer = indexers.length > 0 ? Collect(indexers[indexers.length - 1]) : '';
303
- if (properties.length === 0 && indexer.length > 0) {
304
- return `{},\n{\nadditionalProperties: ${indexer}\n }`;
305
- } else if (properties.length > 0 && indexer.length > 0) {
306
- return `{\n${propertyCollect}\n},\n{\nadditionalProperties: ${indexer}\n }`;
307
- } else {
308
- return `{\n${propertyCollect}\n}`;
309
- }
310
- }
311
- function* TypeLiteralNode(node) {
312
- const members = PropertiesFromTypeElementArray(node.members);
313
- yield* `Type.Object(${members})`;
314
- }
315
- function* InterfaceDeclaration(node) {
316
- useImports = true;
317
- const isRecursiveType = IsRecursiveType(node);
318
- if (isRecursiveType) recursiveDeclaration = node;
319
- const heritage = node.heritageClauses !== undefined ? node.heritageClauses.flatMap((node)=>Collect(node)) : [];
320
- if (node.typeParameters) {
321
- useGenerics = true;
322
- const exports = IsExport(node) ? 'export ' : '';
323
- const identifier = ResolveIdentifier(node);
324
- const options = useIdentifiers ? {
325
- ...ResolveOptions(node),
326
- $id: identifier
327
- } : {
328
- ...ResolveOptions(node)
329
- };
330
- const constraints = node.typeParameters.map((param)=>`${Collect(param)} extends TSchema`).join(', ');
331
- const parameters = node.typeParameters.map((param)=>`${Collect(param)}: ${Collect(param)}`).join(', ');
332
- const members = PropertiesFromTypeElementArray(node.members);
333
- // const names = node.typeParameters.map((param) => `${Collect(param)}`).join(', ')
334
- // const staticDeclaration = `${exports}type ${node.name.getText()}<${constraints}> = Static<ReturnType<typeof ${node.name.getText()}<${names}>>>`
335
- const rawTypeExpression = IsRecursiveType(node) ? `Type.Recursive(This => Type.Object(${members}))` : `Type.Object(${members})`;
336
- const typeExpression = heritage.length === 0 ? rawTypeExpression : `Type.Composite([${heritage.join(', ')}, ${rawTypeExpression}])`;
337
- const type = InjectOptions(typeExpression, options);
338
- const typeDeclaration = `${exports}const ${node.name.getText()} = <${constraints}>(${parameters}) => ${type}`;
339
- yield `${typeDeclaration}`;
340
- } else {
341
- const exports = IsExport(node) ? 'export ' : '';
342
- const identifier = ResolveIdentifier(node);
343
- const options = useIdentifiers ? {
344
- ...ResolveOptions(node),
345
- $id: identifier
346
- } : {
347
- ...ResolveOptions(node)
348
- };
349
- const members = PropertiesFromTypeElementArray(node.members);
350
- const staticDeclaration = `${exports}type ${node.name.getText()} = Static<typeof ${node.name.getText()}>`;
351
- const rawTypeExpression = IsRecursiveType(node) ? `Type.Recursive(This => Type.Object(${members}))` : `Type.Object(${members})`;
352
- const typeExpression = heritage.length === 0 ? rawTypeExpression : `Type.Composite([${heritage.join(', ')}, ${rawTypeExpression}])`;
353
- const type = InjectOptions(typeExpression, options);
354
- const typeDeclaration = `${exports}const ${node.name.getText()} = ${type}`;
355
- yield `${staticDeclaration}\n${typeDeclaration}`;
356
- }
357
- recursiveDeclaration = null;
358
- }
359
- function* TypeAliasDeclaration(node) {
360
- useImports = true;
361
- const isRecursiveType = IsRecursiveType(node);
362
- if (isRecursiveType) recursiveDeclaration = node;
363
- // Generics case
364
- if (node.typeParameters) {
365
- useGenerics = true;
366
- const exports = IsExport(node) ? 'export ' : '';
367
- const options = useIdentifiers ? {
368
- $id: ResolveIdentifier(node)
369
- } : {};
370
- const constraints = node.typeParameters.map((param)=>`${Collect(param)} extends TSchema`).join(', ');
371
- const parameters = node.typeParameters.map((param)=>`${Collect(param)}: ${Collect(param)}`).join(', ');
372
- const type_0 = Collect(node.type);
373
- const type_1 = isRecursiveType ? `Type.Recursive(This => ${type_0})` : type_0;
374
- const type_2 = InjectOptions(type_1, options);
375
- // const names = node.typeParameters.map((param) => Collect(param)).join(', ')
376
- // const staticDeclaration = `${exports}type ${node.name.getText()}<${constraints}> = Static<ReturnType<typeof ${node.name.getText()}<${names}>>>`
377
- const typeDeclaration = `${exports}const ${node.name.getText()} = <${constraints}>(${parameters}) => ${type_2}`;
378
- yield `${typeDeclaration}`;
379
- } else {
380
- const exports = IsExport(node) ? 'export ' : '';
381
- const options = useIdentifiers ? {
382
- $id: ResolveIdentifier(node),
383
- ...ResolveOptions(node)
384
- } : {
385
- ...ResolveOptions(node)
386
- };
387
- const type_0 = Collect(node.type);
388
- const type_1 = isRecursiveType ? `Type.Recursive(This => ${type_0})` : type_0;
389
- const type_2 = InjectOptions(type_1, options);
390
- const staticDeclaration = `${exports}type ${node.name.getText()} = Static<typeof ${node.name.getText()}>`;
391
- const typeDeclaration = `${exports}const ${node.name.getText()} = ${type_2}`;
392
- yield `${staticDeclaration}\n${typeDeclaration}`;
393
- }
394
- recursiveDeclaration = null;
395
- }
396
- function* HeritageClause(node) {
397
- // Consideration: This may be better expressed as a heritage type (for review)
398
- const types = node.types.map((node)=>Collect(node));
399
- if (types.length === 1) return yield types[0];
400
- // yield `Type.Composite([${types.join(', ')}])`
401
- // Note: Heritage clauses are only used in extends cases, and where Composite
402
- // is the exterior type. These types will be prepended to the Composite array.
403
- yield types.join(', ');
404
- }
405
- function* IndexedAccessType(node) {
406
- const obj = node.objectType.getText();
407
- const key = Collect(node.indexType);
408
- yield `Type.Index(${obj}, ${key})`;
409
- }
410
- function* ExpressionWithTypeArguments(node) {
411
- const name = Collect(node.expression);
412
- const typeArguments = node.typeArguments === undefined ? [] : node.typeArguments.map((node)=>Collect(node));
413
- // todo: default type argument (resolve `= number` from `type Foo<T = number>`)
414
- return yield typeArguments.length === 0 ? `${name}` : `${name}(${typeArguments.join(', ')})`;
415
- }
416
- function* TypeParameterDeclaration(node) {
417
- yield node.name.getText();
418
- }
419
- function* ParenthesizedTypeNode(node) {
420
- yield Collect(node.type);
421
- }
422
- function* RestTypeNode(node) {
423
- yield `...Type.Rest(${node.type.getText()})`;
424
- }
425
- function* ConditionalTypeNode(node) {
426
- const checkType = Collect(node.checkType);
427
- const extendsType = Collect(node.extendsType);
428
- const trueType = Collect(node.trueType);
429
- const falseType = Collect(node.falseType);
430
- yield `Type.Extends(${checkType}, ${extendsType}, ${trueType}, ${falseType})`;
431
- }
432
- function* isIndexSignatureDeclaration(node) {
433
- // note: we ignore the key and just return the type. this is a mismatch between
434
- // object and record types. Address in TypeBox by unifying validation paths
435
- // for objects and record types.
436
- yield Collect(node.type);
437
- }
438
- function* TypeReferenceNode(node) {
439
- const name = node.typeName.getText();
440
- const args = node.typeArguments ? `(${node.typeArguments.map((type)=>Collect(type)).join(', ')})` : '';
441
- // --------------------------------------------------------------
442
- // Instance Types
443
- // --------------------------------------------------------------
444
- if (name === 'Date') return yield `Type.Date()`;
445
- if (name === 'Uint8Array') return yield `Type.Uint8Array()`;
446
- if (name === 'String') return yield `Type.String()`;
447
- if (name === 'Number') return yield `Type.Number()`;
448
- if (name === 'Boolean') return yield `Type.Boolean()`;
449
- if (name === 'Function') return yield `Type.Function([], Type.Unknown())`;
450
- // --------------------------------------------------------------
451
- // Types
452
- // --------------------------------------------------------------
453
- if (name === 'Array') return yield `Type.Array${args}`;
454
- if (name === 'Record') return yield `Type.Record${args}`;
455
- if (name === 'Partial') return yield `Type.Partial${args}`;
456
- if (name === 'Required') return yield `Type.Required${args}`;
457
- if (name === 'Omit') return yield `Type.Omit${args}`;
458
- if (name === 'Pick') return yield `Type.Pick${args}`;
459
- if (name === 'Promise') return yield `Type.Promise${args}`;
460
- if (name === 'ReturnType') return yield `Type.ReturnType${args}`;
461
- if (name === 'InstanceType') return yield `Type.InstanceType${args}`;
462
- if (name === 'Parameters') return yield `Type.Parameters${args}`;
463
- if (name === 'AsyncIterableIterator') return yield `Type.AsyncIterator${args}`;
464
- if (name === 'IterableIterator') return yield `Type.Iterator${args}`;
465
- if (name === 'ConstructorParameters') return yield `Type.ConstructorParameters${args}`;
466
- if (name === 'Exclude') return yield `Type.Exclude${args}`;
467
- if (name === 'Extract') return yield `Type.Extract${args}`;
468
- if (name === 'Awaited') return yield `Type.Awaited${args}`;
469
- if (name === 'Uppercase') return yield `Type.Uppercase${args}`;
470
- if (name === 'Lowercase') return yield `Type.Lowercase${args}`;
471
- if (name === 'Capitalize') return yield `Type.Capitalize${args}`;
472
- if (name === 'Uncapitalize') return yield `Type.Uncapitalize${args}`;
473
- if (recursiveDeclaration !== null && FindRecursiveParent(recursiveDeclaration, node)) return yield `This`;
474
- if (FindTypeName(node.getSourceFile(), name) && args.length === 0 /** non-resolvable */ ) {
475
- return yield `${name}${args}`;
476
- }
477
- if (name in globalThis) return yield `Type.Never()`;
478
- return yield `${name}${args}`;
479
- }
480
- function* LiteralTypeNode(node) {
481
- const text = node.getText();
482
- if (text === 'null') return yield `Type.Null()`;
483
- yield InjectOptions(`Type.Literal(${node.getText()})`, ResolveOptions(node));
484
- }
485
- function* ModuleDeclaration(node) {
486
- const export_specifier = IsExport(node) ? 'export ' : '';
487
- const module_specifier = IsNamespace(node) ? 'namespace' : 'module';
488
- yield `${export_specifier}${module_specifier} ${node.name.getText()} {`;
489
- yield* Visit(node.body);
490
- yield `}`;
491
- }
492
- function* ModuleBlock(node) {
493
- for (const statement of node.statements){
494
- yield* Visit(statement);
495
- }
496
- }
497
- function* FunctionDeclaration(node) {
498
- // ignore
499
- }
500
- function* ClassDeclaration(node) {
501
- // ignore
502
- }
503
- function Collect(node) {
504
- return `${[
505
- ...Visit(node)
506
- ].join('')}`;
507
- }
508
- function* Visit(node) {
509
- if (node === undefined) return;
510
- if (ts.isArrayTypeNode(node)) return yield* ArrayTypeNode(node);
511
- if (ts.isBlock(node)) return yield* Block(node);
512
- if (ts.isClassDeclaration(node)) return yield* ClassDeclaration(node);
513
- if (ts.isConditionalTypeNode(node)) return yield* ConditionalTypeNode(node);
514
- if (ts.isConstructorTypeNode(node)) return yield* ConstructorTypeNode(node);
515
- if (ts.isEnumDeclaration(node)) return yield* EnumDeclaration(node);
516
- if (ts.isExpressionWithTypeArguments(node)) return yield* ExpressionWithTypeArguments(node);
517
- if (ts.isFunctionDeclaration(node)) return yield* FunctionDeclaration(node);
518
- if (ts.isFunctionTypeNode(node)) return yield* FunctionTypeNode(node);
519
- if (ts.isHeritageClause(node)) return yield* HeritageClause(node);
520
- if (ts.isIndexedAccessTypeNode(node)) return yield* IndexedAccessType(node);
521
- if (ts.isIndexSignatureDeclaration(node)) return yield* isIndexSignatureDeclaration(node);
522
- if (ts.isInterfaceDeclaration(node)) return yield* InterfaceDeclaration(node);
523
- if (ts.isLiteralTypeNode(node)) return yield* LiteralTypeNode(node);
524
- if (ts.isPropertySignature(node)) return yield* PropertySignature(node);
525
- if (ts.isModuleDeclaration(node)) return yield* ModuleDeclaration(node);
526
- if (ts.isIdentifier(node)) return yield node.getText();
527
- if (ts.isIntersectionTypeNode(node)) return yield* IntersectionTypeNode(node);
528
- if (ts.isUnionTypeNode(node)) return yield* UnionTypeNode(node);
529
- if (ts.isMappedTypeNode(node)) return yield* MappedTypeNode(node);
530
- if (ts.isMethodSignature(node)) return yield* MethodSignature(node);
531
- if (ts.isModuleBlock(node)) return yield* ModuleBlock(node);
532
- if (ts.isParameter(node)) return yield* Parameter(node);
533
- if (ts.isParenthesizedTypeNode(node)) return yield* ParenthesizedTypeNode(node);
534
- if (ts.isRestTypeNode(node)) return yield* RestTypeNode(node);
535
- if (ts.isTupleTypeNode(node)) return yield* TupleTypeNode(node);
536
- if (ts.isTemplateLiteralTypeNode(node)) return yield* TemplateLiteralTypeNode(node);
537
- if (ts.isTemplateLiteralTypeSpan(node)) return yield* TemplateLiteralTypeSpan(node);
538
- if (ts.isTemplateHead(node)) return yield* TemplateHead(node);
539
- if (ts.isTemplateMiddle(node)) return yield* TemplateMiddle(node);
540
- if (ts.isTemplateTail(node)) return yield* TemplateTail(node);
541
- if (ts.isThisTypeNode(node)) return yield* ThisTypeNode(node);
542
- if (ts.isTypeAliasDeclaration(node)) return yield* TypeAliasDeclaration(node);
543
- if (ts.isTypeLiteralNode(node)) return yield* TypeLiteralNode(node);
544
- if (ts.isTypeOperatorNode(node)) return yield* TypeOperatorNode(node);
545
- if (ts.isTypeParameterDeclaration(node)) return yield* TypeParameterDeclaration(node);
546
- if (ts.isTypeReferenceNode(node)) return yield* TypeReferenceNode(node);
547
- if (ts.isSourceFile(node)) return yield* SourceFile(node);
548
- if (node.kind === ts.SyntaxKind.ExportKeyword) return yield `export`;
549
- if (node.kind === ts.SyntaxKind.KeyOfKeyword) return yield `Type.KeyOf()`;
550
- if (node.kind === ts.SyntaxKind.NumberKeyword) return yield `Type.Number()`;
551
- if (node.kind === ts.SyntaxKind.BigIntKeyword) return yield `Type.BigInt()`;
552
- if (node.kind === ts.SyntaxKind.StringKeyword) return yield `Type.String()`;
553
- if (node.kind === ts.SyntaxKind.SymbolKeyword) return yield `Type.Symbol()`;
554
- if (node.kind === ts.SyntaxKind.BooleanKeyword) return yield `Type.Boolean()`;
555
- if (node.kind === ts.SyntaxKind.UndefinedKeyword) return yield `Type.Undefined()`;
556
- if (node.kind === ts.SyntaxKind.UnknownKeyword) return yield `Type.Unknown()`;
557
- if (node.kind === ts.SyntaxKind.AnyKeyword) return yield `Type.Any()`;
558
- if (node.kind === ts.SyntaxKind.NeverKeyword) return yield `Type.Never()`;
559
- if (node.kind === ts.SyntaxKind.NullKeyword) return yield `Type.Null()`;
560
- if (node.kind === ts.SyntaxKind.VoidKeyword) return yield `Type.Void()`;
561
- if (node.kind === ts.SyntaxKind.EndOfFileToken) return;
562
- if (node.kind === ts.SyntaxKind.SyntaxList) {
563
- for (const child of node.getChildren()){
564
- yield* Visit(child);
565
- }
566
- return;
567
- }
568
- console.warn('Unhandled:', ts.SyntaxKind[node.kind], node.getText());
569
- }
570
- function ImportStatement() {
571
- if (!(useImports && useTypeBoxImport)) return '';
572
- const set = new Set([
573
- 'Type',
574
- 'Static'
575
- ]);
576
- if (useGenerics) {
577
- set.add('TSchema');
578
- }
579
- if (useOptions) {
580
- set.add('SchemaOptions');
581
- }
582
- if (useCloneType) {
583
- set.add('CloneType');
584
- }
585
- const imports = [
586
- ...set
587
- ].join(', ');
588
- return `import { ${imports} } from '@sinclair/typebox'`;
589
- }
590
- function Generate(typescriptCode, options) {
591
- useExportsEverything = options?.useExportEverything ?? false;
592
- useIdentifiers = options?.useIdentifiers ?? false;
593
- useTypeBoxImport = options?.useTypeBoxImport ?? true;
594
- typenames.clear();
595
- useImports = false;
596
- useOptions = false;
597
- useGenerics = false;
598
- useCloneType = false;
599
- blockLevel = 0;
600
- const source = ts.createSourceFile('types.ts', typescriptCode, ts.ScriptTarget.ESNext, true);
601
- const declarations = [
602
- ...Visit(source)
603
- ].join('\n\n');
604
- const imports = ImportStatement();
605
- const typescript = [
606
- imports,
607
- '',
608
- '',
609
- declarations
610
- ].join('\n');
611
- const assertion = ts.transpileModule(typescript, transpilerOptions);
612
- if (assertion.diagnostics && assertion.diagnostics.length > 0) {
613
- throw new TypeScriptToTypeBoxError(assertion.diagnostics);
614
- }
615
- return typescript;
616
- }
617
- /** Generates TypeBox types from TypeScript interface and type definitions */ TypeScriptToTypeBox.Generate = Generate;
618
- })(TypeScriptToTypeBox || (TypeScriptToTypeBox = {}));
619
-
620
- //# sourceMappingURL=typescript-to-typebox.js.map