@sinclair/typebox 0.29.6 → 0.30.0-dev-1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/value/convert.js CHANGED
@@ -27,13 +27,14 @@ THE SOFTWARE.
27
27
 
28
28
  ---------------------------------------------------------------------------*/
29
29
  Object.defineProperty(exports, "__esModule", { value: true });
30
- exports.ValueConvert = exports.ValueConvertDereferenceError = exports.ValueConvertUnknownTypeError = void 0;
30
+ exports.Convert = exports.Visit = exports.ValueConvertDereferenceError = exports.ValueConvertUnknownTypeError = void 0;
31
31
  const Types = require("../typebox");
32
- const clone_1 = require("./clone");
33
- const check_1 = require("./check");
34
- // ----------------------------------------------------------------------------------------------
32
+ const ValueClone = require("./clone");
33
+ const ValueCheck = require("./check");
34
+ const ValueGuard = require("./guard");
35
+ // --------------------------------------------------------------------------
35
36
  // Errors
36
- // ----------------------------------------------------------------------------------------------
37
+ // --------------------------------------------------------------------------
37
38
  class ValueConvertUnknownTypeError extends Error {
38
39
  constructor(schema) {
39
40
  super('ValueConvert: Unknown type');
@@ -48,325 +49,311 @@ class ValueConvertDereferenceError extends Error {
48
49
  }
49
50
  }
50
51
  exports.ValueConvertDereferenceError = ValueConvertDereferenceError;
51
- var ValueConvert;
52
- (function (ValueConvert) {
53
- // ----------------------------------------------------------------------------------------------
54
- // Guards
55
- // ----------------------------------------------------------------------------------------------
56
- function IsObject(value) {
57
- return typeof value === 'object' && value !== null && !globalThis.Array.isArray(value);
58
- }
59
- function IsArray(value) {
60
- return typeof value === 'object' && globalThis.Array.isArray(value);
61
- }
62
- function IsDate(value) {
63
- return typeof value === 'object' && value instanceof globalThis.Date;
64
- }
65
- function IsSymbol(value) {
66
- return typeof value === 'symbol';
67
- }
68
- function IsString(value) {
69
- return typeof value === 'string';
70
- }
71
- function IsBoolean(value) {
72
- return typeof value === 'boolean';
73
- }
74
- function IsBigInt(value) {
75
- return typeof value === 'bigint';
76
- }
77
- function IsNumber(value) {
78
- return typeof value === 'number' && !isNaN(value);
79
- }
80
- function IsStringNumeric(value) {
81
- return IsString(value) && !isNaN(value) && !isNaN(parseFloat(value));
82
- }
83
- function IsValueToString(value) {
84
- return IsBigInt(value) || IsBoolean(value) || IsNumber(value);
85
- }
86
- function IsValueTrue(value) {
87
- return value === true || (IsNumber(value) && value === 1) || (IsBigInt(value) && value === globalThis.BigInt('1')) || (IsString(value) && (value.toLowerCase() === 'true' || value === '1'));
88
- }
89
- function IsValueFalse(value) {
90
- return value === false || (IsNumber(value) && value === 0) || (IsBigInt(value) && value === globalThis.BigInt('0')) || (IsString(value) && (value.toLowerCase() === 'false' || value === '0'));
91
- }
92
- function IsTimeStringWithTimeZone(value) {
93
- return IsString(value) && /^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)$/i.test(value);
94
- }
95
- function IsTimeStringWithoutTimeZone(value) {
96
- return IsString(value) && /^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)?$/i.test(value);
97
- }
98
- function IsDateTimeStringWithTimeZone(value) {
99
- return IsString(value) && /^\d\d\d\d-[0-1]\d-[0-3]\dt(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)$/i.test(value);
100
- }
101
- function IsDateTimeStringWithoutTimeZone(value) {
102
- return IsString(value) && /^\d\d\d\d-[0-1]\d-[0-3]\dt(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)?$/i.test(value);
103
- }
104
- function IsDateString(value) {
105
- return IsString(value) && /^\d\d\d\d-[0-1]\d-[0-3]\d$/i.test(value);
106
- }
107
- // ----------------------------------------------------------------------------------------------
108
- // Convert
109
- // ----------------------------------------------------------------------------------------------
110
- function TryConvertLiteralString(value, target) {
111
- const conversion = TryConvertString(value);
112
- return conversion === target ? conversion : value;
113
- }
114
- function TryConvertLiteralNumber(value, target) {
115
- const conversion = TryConvertNumber(value);
116
- return conversion === target ? conversion : value;
117
- }
118
- function TryConvertLiteralBoolean(value, target) {
119
- const conversion = TryConvertBoolean(value);
120
- return conversion === target ? conversion : value;
121
- }
122
- function TryConvertLiteral(schema, value) {
123
- if (typeof schema.const === 'string') {
124
- return TryConvertLiteralString(value, schema.const);
125
- }
126
- else if (typeof schema.const === 'number') {
127
- return TryConvertLiteralNumber(value, schema.const);
128
- }
129
- else if (typeof schema.const === 'boolean') {
130
- return TryConvertLiteralBoolean(value, schema.const);
131
- }
132
- else {
133
- return clone_1.ValueClone.Clone(value);
134
- }
135
- }
136
- function TryConvertBoolean(value) {
137
- return IsValueTrue(value) ? true : IsValueFalse(value) ? false : value;
138
- }
139
- function TryConvertBigInt(value) {
140
- return IsStringNumeric(value) ? globalThis.BigInt(parseInt(value)) : IsNumber(value) ? globalThis.BigInt(value | 0) : IsValueFalse(value) ? 0 : IsValueTrue(value) ? 1 : value;
141
- }
142
- function TryConvertString(value) {
143
- return IsValueToString(value) ? value.toString() : IsSymbol(value) && value.description !== undefined ? value.description.toString() : value;
144
- }
145
- function TryConvertNumber(value) {
146
- return IsStringNumeric(value) ? parseFloat(value) : IsValueTrue(value) ? 1 : IsValueFalse(value) ? 0 : value;
147
- }
148
- function TryConvertInteger(value) {
149
- return IsStringNumeric(value) ? parseInt(value) : IsNumber(value) ? value | 0 : IsValueTrue(value) ? 1 : IsValueFalse(value) ? 0 : value;
150
- }
151
- function TryConvertNull(value) {
152
- return IsString(value) && value.toLowerCase() === 'null' ? null : value;
153
- }
154
- function TryConvertUndefined(value) {
155
- return IsString(value) && value === 'undefined' ? undefined : value;
156
- }
157
- function TryConvertDate(value) {
158
- // note: this function may return an invalid dates for the regex tests
159
- // above. Invalid dates will however be checked during the casting
160
- // function and will return a epoch date if invalid. Consider better
161
- // string parsing for the iso dates in future revisions.
162
- return IsDate(value)
163
- ? value
164
- : IsNumber(value)
165
- ? new globalThis.Date(value)
166
- : IsValueTrue(value)
167
- ? new globalThis.Date(1)
168
- : IsValueFalse(value)
169
- ? new globalThis.Date(0)
170
- : IsStringNumeric(value)
171
- ? new globalThis.Date(parseInt(value))
172
- : IsTimeStringWithoutTimeZone(value)
173
- ? new globalThis.Date(`1970-01-01T${value}.000Z`)
174
- : IsTimeStringWithTimeZone(value)
175
- ? new globalThis.Date(`1970-01-01T${value}`)
176
- : IsDateTimeStringWithoutTimeZone(value)
177
- ? new globalThis.Date(`${value}.000Z`)
178
- : IsDateTimeStringWithTimeZone(value)
179
- ? new globalThis.Date(value)
180
- : IsDateString(value)
181
- ? new globalThis.Date(`${value}T00:00:00.000Z`)
182
- : value;
183
- }
184
- // ----------------------------------------------------------------------------------------------
185
- // Cast
186
- // ----------------------------------------------------------------------------------------------
187
- function Any(schema, references, value) {
188
- return value;
189
- }
190
- function Array(schema, references, value) {
191
- if (IsArray(value)) {
192
- return value.map((value) => Visit(schema.items, references, value));
193
- }
194
- return value;
195
- }
196
- function BigInt(schema, references, value) {
197
- return TryConvertBigInt(value);
198
- }
199
- function Boolean(schema, references, value) {
200
- return TryConvertBoolean(value);
201
- }
202
- function Constructor(schema, references, value) {
203
- return clone_1.ValueClone.Clone(value);
204
- }
205
- function Date(schema, references, value) {
206
- return TryConvertDate(value);
207
- }
208
- function Function(schema, references, value) {
209
- return value;
210
- }
211
- function Integer(schema, references, value) {
212
- return TryConvertInteger(value);
213
- }
214
- function Intersect(schema, references, value) {
215
- return value;
216
- }
217
- function Literal(schema, references, value) {
218
- return TryConvertLiteral(schema, value);
219
- }
220
- function Never(schema, references, value) {
221
- return value;
222
- }
223
- function Null(schema, references, value) {
224
- return TryConvertNull(value);
225
- }
226
- function Number(schema, references, value) {
227
- return TryConvertNumber(value);
228
- }
229
- function Object(schema, references, value) {
230
- if (IsObject(value))
231
- return globalThis.Object.keys(schema.properties).reduce((acc, key) => {
232
- return value[key] !== undefined ? { ...acc, [key]: Visit(schema.properties[key], references, value[key]) } : { ...acc };
233
- }, value);
234
- return value;
235
- }
236
- function Promise(schema, references, value) {
237
- return value;
238
- }
239
- function Record(schema, references, value) {
240
- const propertyKey = globalThis.Object.getOwnPropertyNames(schema.patternProperties)[0];
241
- const property = schema.patternProperties[propertyKey];
242
- const result = {};
243
- for (const [propKey, propValue] of globalThis.Object.entries(value)) {
244
- result[propKey] = Visit(property, references, propValue);
245
- }
246
- return result;
247
- }
248
- function Ref(schema, references, value) {
249
- const index = references.findIndex((foreign) => foreign.$id === schema.$ref);
250
- if (index === -1)
251
- throw new ValueConvertDereferenceError(schema);
252
- const target = references[index];
253
- return Visit(target, references, value);
254
- }
255
- function String(schema, references, value) {
256
- return TryConvertString(value);
257
- }
258
- function Symbol(schema, references, value) {
259
- return value;
260
- }
261
- function TemplateLiteral(schema, references, value) {
262
- return value;
263
- }
264
- function This(schema, references, value) {
265
- const index = references.findIndex((foreign) => foreign.$id === schema.$ref);
266
- if (index === -1)
267
- throw new ValueConvertDereferenceError(schema);
268
- const target = references[index];
269
- return Visit(target, references, value);
270
- }
271
- function Tuple(schema, references, value) {
272
- if (IsArray(value) && schema.items !== undefined) {
273
- return value.map((value, index) => {
274
- return index < schema.items.length ? Visit(schema.items[index], references, value) : value;
275
- });
276
- }
277
- return value;
278
- }
279
- function Undefined(schema, references, value) {
280
- return TryConvertUndefined(value);
52
+ // --------------------------------------------------------------------------
53
+ // Conversions
54
+ // --------------------------------------------------------------------------
55
+ function IsStringNumeric(value) {
56
+ return ValueGuard.IsString(value) && !isNaN(value) && !isNaN(parseFloat(value));
57
+ }
58
+ function IsValueToString(value) {
59
+ return ValueGuard.IsBigInt(value) || ValueGuard.IsBoolean(value) || ValueGuard.IsNumber(value);
60
+ }
61
+ function IsValueTrue(value) {
62
+ return value === true || (ValueGuard.IsNumber(value) && value === 1) || (ValueGuard.IsBigInt(value) && value === BigInt('1')) || (ValueGuard.IsString(value) && (value.toLowerCase() === 'true' || value === '1'));
63
+ }
64
+ function IsValueFalse(value) {
65
+ return value === false || (ValueGuard.IsNumber(value) && value === 0) || (ValueGuard.IsBigInt(value) && value === BigInt('0')) || (ValueGuard.IsString(value) && (value.toLowerCase() === 'false' || value === '0'));
66
+ }
67
+ function IsTimeStringWithTimeZone(value) {
68
+ return ValueGuard.IsString(value) && /^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)$/i.test(value);
69
+ }
70
+ function IsTimeStringWithoutTimeZone(value) {
71
+ return ValueGuard.IsString(value) && /^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)?$/i.test(value);
72
+ }
73
+ function IsDateTimeStringWithTimeZone(value) {
74
+ return ValueGuard.IsString(value) && /^\d\d\d\d-[0-1]\d-[0-3]\dt(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)$/i.test(value);
75
+ }
76
+ function IsDateTimeStringWithoutTimeZone(value) {
77
+ return ValueGuard.IsString(value) && /^\d\d\d\d-[0-1]\d-[0-3]\dt(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)?$/i.test(value);
78
+ }
79
+ function IsDateString(value) {
80
+ return ValueGuard.IsString(value) && /^\d\d\d\d-[0-1]\d-[0-3]\d$/i.test(value);
81
+ }
82
+ // --------------------------------------------------------------------------
83
+ // Convert
84
+ // --------------------------------------------------------------------------
85
+ function TryConvertLiteralString(value, target) {
86
+ const conversion = TryConvertString(value);
87
+ return conversion === target ? conversion : value;
88
+ }
89
+ function TryConvertLiteralNumber(value, target) {
90
+ const conversion = TryConvertNumber(value);
91
+ return conversion === target ? conversion : value;
92
+ }
93
+ function TryConvertLiteralBoolean(value, target) {
94
+ const conversion = TryConvertBoolean(value);
95
+ return conversion === target ? conversion : value;
96
+ }
97
+ function TryConvertLiteral(schema, value) {
98
+ if (typeof schema.const === 'string') {
99
+ return TryConvertLiteralString(value, schema.const);
281
100
  }
282
- function Union(schema, references, value) {
283
- for (const subschema of schema.anyOf) {
284
- const converted = Visit(subschema, references, value);
285
- if (check_1.ValueCheck.Check(subschema, references, converted)) {
286
- return converted;
287
- }
288
- }
289
- return value;
101
+ else if (typeof schema.const === 'number') {
102
+ return TryConvertLiteralNumber(value, schema.const);
290
103
  }
291
- function Uint8Array(schema, references, value) {
292
- return value;
104
+ else if (typeof schema.const === 'boolean') {
105
+ return TryConvertLiteralBoolean(value, schema.const);
293
106
  }
294
- function Unknown(schema, references, value) {
295
- return value;
107
+ else {
108
+ return ValueClone.Clone(value);
296
109
  }
297
- function Void(schema, references, value) {
298
- return value;
110
+ }
111
+ function TryConvertBoolean(value) {
112
+ return IsValueTrue(value) ? true : IsValueFalse(value) ? false : value;
113
+ }
114
+ function TryConvertBigInt(value) {
115
+ return IsStringNumeric(value) ? BigInt(parseInt(value)) : ValueGuard.IsNumber(value) ? BigInt(value | 0) : IsValueFalse(value) ? 0 : IsValueTrue(value) ? 1 : value;
116
+ }
117
+ function TryConvertString(value) {
118
+ return IsValueToString(value) ? value.toString() : ValueGuard.IsSymbol(value) && value.description !== undefined ? value.description.toString() : value;
119
+ }
120
+ function TryConvertNumber(value) {
121
+ return IsStringNumeric(value) ? parseFloat(value) : IsValueTrue(value) ? 1 : IsValueFalse(value) ? 0 : value;
122
+ }
123
+ function TryConvertInteger(value) {
124
+ return IsStringNumeric(value) ? parseInt(value) : ValueGuard.IsNumber(value) ? value | 0 : IsValueTrue(value) ? 1 : IsValueFalse(value) ? 0 : value;
125
+ }
126
+ function TryConvertNull(value) {
127
+ return ValueGuard.IsString(value) && value.toLowerCase() === 'null' ? null : value;
128
+ }
129
+ function TryConvertUndefined(value) {
130
+ return ValueGuard.IsString(value) && value === 'undefined' ? undefined : value;
131
+ }
132
+ function TryConvertDate(value) {
133
+ // --------------------------------------------------------------------------
134
+ // note: this function may return an invalid dates for the regex tests
135
+ // above. Invalid dates will however be checked during the casting function
136
+ // and will return a epoch date if invalid. Consider better string parsing
137
+ // for the iso dates in future revisions.
138
+ // --------------------------------------------------------------------------
139
+ return ValueGuard.IsDate(value)
140
+ ? value
141
+ : ValueGuard.IsNumber(value)
142
+ ? new Date(value)
143
+ : IsValueTrue(value)
144
+ ? new Date(1)
145
+ : IsValueFalse(value)
146
+ ? new Date(0)
147
+ : IsStringNumeric(value)
148
+ ? new Date(parseInt(value))
149
+ : IsTimeStringWithoutTimeZone(value)
150
+ ? new Date(`1970-01-01T${value}.000Z`)
151
+ : IsTimeStringWithTimeZone(value)
152
+ ? new Date(`1970-01-01T${value}`)
153
+ : IsDateTimeStringWithoutTimeZone(value)
154
+ ? new Date(`${value}.000Z`)
155
+ : IsDateTimeStringWithTimeZone(value)
156
+ ? new Date(value)
157
+ : IsDateString(value)
158
+ ? new Date(`${value}T00:00:00.000Z`)
159
+ : value;
160
+ }
161
+ // --------------------------------------------------------------------------
162
+ // Cast
163
+ // --------------------------------------------------------------------------
164
+ function TAny(schema, references, value) {
165
+ return value;
166
+ }
167
+ function TArray(schema, references, value) {
168
+ if (ValueGuard.IsArray(value)) {
169
+ return value.map((value) => Visit(schema.items, references, value));
299
170
  }
300
- function UserDefined(schema, references, value) {
301
- return value;
171
+ return value;
172
+ }
173
+ function TAsyncIterator(schema, references, value) {
174
+ return value;
175
+ }
176
+ function TBigInt(schema, references, value) {
177
+ return TryConvertBigInt(value);
178
+ }
179
+ function TBoolean(schema, references, value) {
180
+ return TryConvertBoolean(value);
181
+ }
182
+ function TConstructor(schema, references, value) {
183
+ return ValueClone.Clone(value);
184
+ }
185
+ function TDate(schema, references, value) {
186
+ return TryConvertDate(value);
187
+ }
188
+ function TFunction(schema, references, value) {
189
+ return value;
190
+ }
191
+ function TInteger(schema, references, value) {
192
+ return TryConvertInteger(value);
193
+ }
194
+ function TIntersect(schema, references, value) {
195
+ return value;
196
+ }
197
+ function TIterator(schema, references, value) {
198
+ return value;
199
+ }
200
+ function TLiteral(schema, references, value) {
201
+ return TryConvertLiteral(schema, value);
202
+ }
203
+ function TNever(schema, references, value) {
204
+ return value;
205
+ }
206
+ function TNull(schema, references, value) {
207
+ return TryConvertNull(value);
208
+ }
209
+ function TNumber(schema, references, value) {
210
+ return TryConvertNumber(value);
211
+ }
212
+ function TObject(schema, references, value) {
213
+ if (ValueGuard.IsObject(value))
214
+ return Object.getOwnPropertyNames(schema.properties).reduce((acc, key) => {
215
+ return value[key] !== undefined ? { ...acc, [key]: Visit(schema.properties[key], references, value[key]) } : { ...acc };
216
+ }, value);
217
+ return value;
218
+ }
219
+ function TPromise(schema, references, value) {
220
+ return value;
221
+ }
222
+ function TRecord(schema, references, value) {
223
+ const propertyKey = Object.getOwnPropertyNames(schema.patternProperties)[0];
224
+ const property = schema.patternProperties[propertyKey];
225
+ const result = {};
226
+ for (const [propKey, propValue] of Object.entries(value)) {
227
+ result[propKey] = Visit(property, references, propValue);
228
+ }
229
+ return result;
230
+ }
231
+ function TRef(schema, references, value) {
232
+ const index = references.findIndex((foreign) => foreign.$id === schema.$ref);
233
+ if (index === -1)
234
+ throw new ValueConvertDereferenceError(schema);
235
+ const target = references[index];
236
+ return Visit(target, references, value);
237
+ }
238
+ function TString(schema, references, value) {
239
+ return TryConvertString(value);
240
+ }
241
+ function TSymbol(schema, references, value) {
242
+ return value;
243
+ }
244
+ function TTemplateLiteral(schema, references, value) {
245
+ return value;
246
+ }
247
+ function TThis(schema, references, value) {
248
+ const index = references.findIndex((foreign) => foreign.$id === schema.$ref);
249
+ if (index === -1)
250
+ throw new ValueConvertDereferenceError(schema);
251
+ const target = references[index];
252
+ return Visit(target, references, value);
253
+ }
254
+ function TTuple(schema, references, value) {
255
+ if (ValueGuard.IsArray(value) && !ValueGuard.IsUndefined(schema.items)) {
256
+ return value.map((value, index) => {
257
+ return index < schema.items.length ? Visit(schema.items[index], references, value) : value;
258
+ });
302
259
  }
303
- function Visit(schema, references, value) {
304
- const references_ = IsString(schema.$id) ? [...references, schema] : references;
305
- const schema_ = schema;
306
- switch (schema[Types.Kind]) {
307
- case 'Any':
308
- return Any(schema_, references_, value);
309
- case 'Array':
310
- return Array(schema_, references_, value);
311
- case 'BigInt':
312
- return BigInt(schema_, references_, value);
313
- case 'Boolean':
314
- return Boolean(schema_, references_, value);
315
- case 'Constructor':
316
- return Constructor(schema_, references_, value);
317
- case 'Date':
318
- return Date(schema_, references_, value);
319
- case 'Function':
320
- return Function(schema_, references_, value);
321
- case 'Integer':
322
- return Integer(schema_, references_, value);
323
- case 'Intersect':
324
- return Intersect(schema_, references_, value);
325
- case 'Literal':
326
- return Literal(schema_, references_, value);
327
- case 'Never':
328
- return Never(schema_, references_, value);
329
- case 'Null':
330
- return Null(schema_, references_, value);
331
- case 'Number':
332
- return Number(schema_, references_, value);
333
- case 'Object':
334
- return Object(schema_, references_, value);
335
- case 'Promise':
336
- return Promise(schema_, references_, value);
337
- case 'Record':
338
- return Record(schema_, references_, value);
339
- case 'Ref':
340
- return Ref(schema_, references_, value);
341
- case 'String':
342
- return String(schema_, references_, value);
343
- case 'Symbol':
344
- return Symbol(schema_, references_, value);
345
- case 'TemplateLiteral':
346
- return TemplateLiteral(schema_, references_, value);
347
- case 'This':
348
- return This(schema_, references_, value);
349
- case 'Tuple':
350
- return Tuple(schema_, references_, value);
351
- case 'Undefined':
352
- return Undefined(schema_, references_, value);
353
- case 'Union':
354
- return Union(schema_, references_, value);
355
- case 'Uint8Array':
356
- return Uint8Array(schema_, references_, value);
357
- case 'Unknown':
358
- return Unknown(schema_, references_, value);
359
- case 'Void':
360
- return Void(schema_, references_, value);
361
- default:
362
- if (!Types.TypeRegistry.Has(schema_[Types.Kind]))
363
- throw new ValueConvertUnknownTypeError(schema_);
364
- return UserDefined(schema_, references_, value);
260
+ return value;
261
+ }
262
+ function TUndefined(schema, references, value) {
263
+ return TryConvertUndefined(value);
264
+ }
265
+ function TUnion(schema, references, value) {
266
+ for (const subschema of schema.anyOf) {
267
+ const converted = Visit(subschema, references, value);
268
+ if (ValueCheck.Check(subschema, references, converted)) {
269
+ return converted;
365
270
  }
366
271
  }
367
- ValueConvert.Visit = Visit;
368
- function Convert(schema, references, value) {
369
- return Visit(schema, references, clone_1.ValueClone.Clone(value));
272
+ return value;
273
+ }
274
+ function TUint8Array(schema, references, value) {
275
+ return value;
276
+ }
277
+ function TUnknown(schema, references, value) {
278
+ return value;
279
+ }
280
+ function TVoid(schema, references, value) {
281
+ return value;
282
+ }
283
+ function TUserDefined(schema, references, value) {
284
+ return value;
285
+ }
286
+ function Visit(schema, references, value) {
287
+ const references_ = ValueGuard.IsString(schema.$id) ? [...references, schema] : references;
288
+ const schema_ = schema;
289
+ switch (schema[Types.Kind]) {
290
+ case 'Any':
291
+ return TAny(schema_, references_, value);
292
+ case 'Array':
293
+ return TArray(schema_, references_, value);
294
+ case 'AsyncIterator':
295
+ return TAsyncIterator(schema_, references_, value);
296
+ case 'BigInt':
297
+ return TBigInt(schema_, references_, value);
298
+ case 'Boolean':
299
+ return TBoolean(schema_, references_, value);
300
+ case 'Constructor':
301
+ return TConstructor(schema_, references_, value);
302
+ case 'Date':
303
+ return TDate(schema_, references_, value);
304
+ case 'Function':
305
+ return TFunction(schema_, references_, value);
306
+ case 'Integer':
307
+ return TInteger(schema_, references_, value);
308
+ case 'Intersect':
309
+ return TIntersect(schema_, references_, value);
310
+ case 'Iterator':
311
+ return TIterator(schema_, references_, value);
312
+ case 'Literal':
313
+ return TLiteral(schema_, references_, value);
314
+ case 'Never':
315
+ return TNever(schema_, references_, value);
316
+ case 'Null':
317
+ return TNull(schema_, references_, value);
318
+ case 'Number':
319
+ return TNumber(schema_, references_, value);
320
+ case 'Object':
321
+ return TObject(schema_, references_, value);
322
+ case 'Promise':
323
+ return TPromise(schema_, references_, value);
324
+ case 'Record':
325
+ return TRecord(schema_, references_, value);
326
+ case 'Ref':
327
+ return TRef(schema_, references_, value);
328
+ case 'String':
329
+ return TString(schema_, references_, value);
330
+ case 'Symbol':
331
+ return TSymbol(schema_, references_, value);
332
+ case 'TemplateLiteral':
333
+ return TTemplateLiteral(schema_, references_, value);
334
+ case 'This':
335
+ return TThis(schema_, references_, value);
336
+ case 'Tuple':
337
+ return TTuple(schema_, references_, value);
338
+ case 'Undefined':
339
+ return TUndefined(schema_, references_, value);
340
+ case 'Union':
341
+ return TUnion(schema_, references_, value);
342
+ case 'Uint8Array':
343
+ return TUint8Array(schema_, references_, value);
344
+ case 'Unknown':
345
+ return TUnknown(schema_, references_, value);
346
+ case 'Void':
347
+ return TVoid(schema_, references_, value);
348
+ default:
349
+ if (!Types.TypeRegistry.Has(schema_[Types.Kind]))
350
+ throw new ValueConvertUnknownTypeError(schema_);
351
+ return TUserDefined(schema_, references_, value);
370
352
  }
371
- ValueConvert.Convert = Convert;
372
- })(ValueConvert || (exports.ValueConvert = ValueConvert = {}));
353
+ }
354
+ exports.Visit = Visit;
355
+ /** Converts any type mismatched values to their target type if a conversion is possible. */
356
+ function Convert(...args) {
357
+ return args.length === 3 ? Visit(args[0], args[1], args[2]) : Visit(args[0], [], args[1]);
358
+ }
359
+ exports.Convert = Convert;
package/value/create.d.ts CHANGED
@@ -28,9 +28,9 @@ export declare class ValueCreateRecursiveInstantiationError extends Error {
28
28
  readonly recursiveMaxDepth: number;
29
29
  constructor(schema: Types.TSchema, recursiveMaxDepth: number);
30
30
  }
31
- export declare namespace ValueCreate {
32
- /** Creates a value from the given schema. If the schema specifies a default value, then that value is returned. */
33
- function Visit(schema: Types.TSchema, references: Types.TSchema[]): unknown;
34
- /** Creates a value from the given schema and references */
35
- function Create<T extends Types.TSchema>(schema: T, references: Types.TSchema[]): Types.Static<T>;
36
- }
31
+ /** Creates a value from the given schema. If the schema specifies a default value, then that value is returned. */
32
+ export declare function Visit(schema: Types.TSchema, references: Types.TSchema[]): unknown;
33
+ /** Creates a value from the given schema */
34
+ export declare function Create<T extends Types.TSchema>(schema: T, references: Types.TSchema[]): Types.Static<T>;
35
+ /** Creates a value from the given schema */
36
+ export declare function Create<T extends Types.TSchema>(schema: T, value: unknown): Types.Static<T>;