@sinclair/typebox 0.26.0-dev.2 → 0.26.0-dev.4

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
@@ -1,345 +1,345 @@
1
- "use strict";
2
- /*--------------------------------------------------------------------------
3
-
4
- @sinclair/typebox/value
5
-
6
- The MIT License (MIT)
7
-
8
- Copyright (c) 2017-2023 Haydn Paterson (sinclair) <haydn.developer@gmail.com>
9
-
10
- Permission is hereby granted, free of charge, to any person obtaining a copy
11
- of this software and associated documentation files (the "Software"), to deal
12
- in the Software without restriction, including without limitation the rights
13
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
14
- copies of the Software, and to permit persons to whom the Software is
15
- furnished to do so, subject to the following conditions:
16
-
17
- The above copyright notice and this permission notice shall be included in
18
- all copies or substantial portions of the Software.
19
-
20
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
21
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
22
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
23
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
24
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
25
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
26
- THE SOFTWARE.
27
-
28
- ---------------------------------------------------------------------------*/
29
- Object.defineProperty(exports, "__esModule", { value: true });
30
- exports.ValueConvert = exports.ValueConvertUnknownTypeError = exports.ValueConvertReferenceTypeError = void 0;
31
- const Types = require("../typebox");
32
- const clone_1 = require("./clone");
33
- // ----------------------------------------------------------------------------------------------
34
- // Errors
35
- // ----------------------------------------------------------------------------------------------
36
- class ValueConvertReferenceTypeError extends Error {
37
- constructor(schema) {
38
- super(`ValueConvert: Cannot locate referenced schema with $id '${schema.$ref}'`);
39
- this.schema = schema;
40
- }
41
- }
42
- exports.ValueConvertReferenceTypeError = ValueConvertReferenceTypeError;
43
- class ValueConvertUnknownTypeError extends Error {
44
- constructor(schema) {
45
- super('ValueConvert: Unknown type');
46
- this.schema = schema;
47
- }
48
- }
49
- exports.ValueConvertUnknownTypeError = ValueConvertUnknownTypeError;
50
- var ValueConvert;
51
- (function (ValueConvert) {
52
- // ----------------------------------------------------------------------------------------------
53
- // Guards
54
- // ----------------------------------------------------------------------------------------------
55
- function IsObject(value) {
56
- return typeof value === 'object' && value !== null && !globalThis.Array.isArray(value);
57
- }
58
- function IsArray(value) {
59
- return typeof value === 'object' && globalThis.Array.isArray(value);
60
- }
61
- function IsDate(value) {
62
- return typeof value === 'object' && value instanceof globalThis.Date;
63
- }
64
- function IsSymbol(value) {
65
- return typeof value === 'symbol';
66
- }
67
- function IsString(value) {
68
- return typeof value === 'string';
69
- }
70
- function IsBoolean(value) {
71
- return typeof value === 'boolean';
72
- }
73
- function IsBigInt(value) {
74
- return typeof value === 'bigint';
75
- }
76
- function IsNumber(value) {
77
- return typeof value === 'number' && !isNaN(value);
78
- }
79
- function IsStringNumeric(value) {
80
- return IsString(value) && !isNaN(value) && !isNaN(parseFloat(value));
81
- }
82
- function IsValueToString(value) {
83
- return IsBigInt(value) || IsBoolean(value) || IsNumber(value);
84
- }
85
- function IsValueTrue(value) {
86
- return value === true || (IsNumber(value) && value === 1) || (IsBigInt(value) && value === globalThis.BigInt('1')) || (IsString(value) && (value.toLowerCase() === 'true' || value === '1'));
87
- }
88
- function IsValueFalse(value) {
89
- return value === false || (IsNumber(value) && value === 0) || (IsBigInt(value) && value === globalThis.BigInt('0')) || (IsString(value) && (value.toLowerCase() === 'false' || value === '0'));
90
- }
91
- function IsTimeStringWithTimeZone(value) {
92
- return IsString(value) && /^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)$/i.test(value);
93
- }
94
- function IsTimeStringWithoutTimeZone(value) {
95
- return IsString(value) && /^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)?$/i.test(value);
96
- }
97
- function IsDateTimeStringWithTimeZone(value) {
98
- 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);
99
- }
100
- function IsDateTimeStringWithoutTimeZone(value) {
101
- 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);
102
- }
103
- function IsDateString(value) {
104
- return IsString(value) && /^\d\d\d\d-[0-1]\d-[0-3]\d$/i.test(value);
105
- }
106
- // ----------------------------------------------------------------------------------------------
107
- // Convert
108
- // ----------------------------------------------------------------------------------------------
109
- function TryConvertLiteralString(value, target) {
110
- const conversion = TryConvertString(value);
111
- return conversion === target ? conversion : value;
112
- }
113
- function TryConvertLiteralNumber(value, target) {
114
- const conversion = TryConvertNumber(value);
115
- return conversion === target ? conversion : value;
116
- }
117
- function TryConvertLiteralBoolean(value, target) {
118
- const conversion = TryConvertBoolean(value);
119
- return conversion === target ? conversion : value;
120
- }
121
- function TryConvertLiteral(schema, value) {
122
- if (typeof schema.const === 'string') {
123
- return TryConvertLiteralString(value, schema.const);
124
- }
125
- else if (typeof schema.const === 'number') {
126
- return TryConvertLiteralNumber(value, schema.const);
127
- }
128
- else if (typeof schema.const === 'boolean') {
129
- return TryConvertLiteralBoolean(value, schema.const);
130
- }
131
- else {
132
- return clone_1.ValueClone.Clone(value);
133
- }
134
- }
135
- function TryConvertBoolean(value) {
136
- return IsValueTrue(value) ? true : IsValueFalse(value) ? false : value;
137
- }
138
- function TryConvertBigInt(value) {
139
- return IsStringNumeric(value) ? globalThis.BigInt(parseInt(value)) : IsNumber(value) ? globalThis.BigInt(value | 0) : IsValueFalse(value) ? 0 : IsValueTrue(value) ? 1 : value;
140
- }
141
- function TryConvertString(value) {
142
- return IsValueToString(value) ? value.toString() : IsSymbol(value) && value.description !== undefined ? value.description.toString() : value;
143
- }
144
- function TryConvertNumber(value) {
145
- return IsStringNumeric(value) ? parseFloat(value) : IsValueTrue(value) ? 1 : IsValueFalse(value) ? 0 : value;
146
- }
147
- function TryConvertInteger(value) {
148
- return IsStringNumeric(value) ? parseInt(value) : IsNumber(value) ? value | 0 : IsValueTrue(value) ? 1 : IsValueFalse(value) ? 0 : value;
149
- }
150
- function TryConvertNull(value) {
151
- return IsString(value) && value.toLowerCase() === 'null' ? null : value;
152
- }
153
- function TryConvertUndefined(value) {
154
- return IsString(value) && value === 'undefined' ? undefined : value;
155
- }
156
- function TryConvertDate(value) {
157
- // note: this function may return an invalid dates for the regex tests
158
- // above. Invalid dates will however be checked during the casting
159
- // function and will return a epoch date if invalid. Consider better
160
- // string parsing for the iso dates in future revisions.
161
- return IsDate(value)
162
- ? value
163
- : IsNumber(value)
164
- ? new globalThis.Date(value)
165
- : IsValueTrue(value)
166
- ? new globalThis.Date(1)
167
- : IsValueFalse(value)
168
- ? new globalThis.Date(0)
169
- : IsStringNumeric(value)
170
- ? new globalThis.Date(parseInt(value))
171
- : IsTimeStringWithoutTimeZone(value)
172
- ? new globalThis.Date(`1970-01-01T${value}.000Z`)
173
- : IsTimeStringWithTimeZone(value)
174
- ? new globalThis.Date(`1970-01-01T${value}`)
175
- : IsDateTimeStringWithoutTimeZone(value)
176
- ? new globalThis.Date(`${value}.000Z`)
177
- : IsDateTimeStringWithTimeZone(value)
178
- ? new globalThis.Date(value)
179
- : IsDateString(value)
180
- ? new globalThis.Date(`${value}T00:00:00.000Z`)
181
- : value;
182
- }
183
- // ----------------------------------------------------------------------------------------------
184
- // Cast
185
- // ----------------------------------------------------------------------------------------------
186
- function Any(schema, value) {
187
- return value;
188
- }
189
- function Array(schema, value) {
190
- if (IsArray(value)) {
191
- return value.map((value) => Visit(schema.items, value));
192
- }
193
- return value;
194
- }
195
- function BigInt(schema, value) {
196
- return TryConvertBigInt(value);
197
- }
198
- function Boolean(schema, value) {
199
- return TryConvertBoolean(value);
200
- }
201
- function Constructor(schema, value) {
202
- return clone_1.ValueClone.Clone(value);
203
- }
204
- function Date(schema, value) {
205
- return TryConvertDate(value);
206
- }
207
- function Function(schema, value) {
208
- return value;
209
- }
210
- function Integer(schema, value) {
211
- return TryConvertInteger(value);
212
- }
213
- function Intersect(schema, value) {
214
- return value;
215
- }
216
- function Literal(schema, value) {
217
- return TryConvertLiteral(schema, value);
218
- }
219
- function Never(schema, value) {
220
- return value;
221
- }
222
- function Null(schema, value) {
223
- return TryConvertNull(value);
224
- }
225
- function Number(schema, value) {
226
- return TryConvertNumber(value);
227
- }
228
- function Object(schema, value) {
229
- if (IsObject(value))
230
- return globalThis.Object.keys(schema.properties).reduce((acc, key) => {
231
- return value[key] !== undefined ? { ...acc, [key]: Visit(schema.properties[key], value[key]) } : { ...acc };
232
- }, value);
233
- return value;
234
- }
235
- function Promise(schema, value) {
236
- return value;
237
- }
238
- function Record(schema, value) {
239
- return value;
240
- }
241
- function Ref(schema, value) {
242
- return Visit(Types.ReferenceRegistry.DerefOne(schema), value);
243
- }
244
- function Self(schema, value) {
245
- return Visit(Types.ReferenceRegistry.DerefOne(schema), value);
246
- }
247
- function String(schema, value) {
248
- return TryConvertString(value);
249
- }
250
- function Symbol(schema, value) {
251
- return value;
252
- }
253
- function Tuple(schema, value) {
254
- if (IsArray(value) && schema.items !== undefined) {
255
- return value.map((value, index) => {
256
- return index < schema.items.length ? Visit(schema.items[index], value) : value;
257
- });
258
- }
259
- return value;
260
- }
261
- function Undefined(schema, value) {
262
- return TryConvertUndefined(value);
263
- }
264
- function Union(schema, value) {
265
- return value;
266
- }
267
- function Uint8Array(schema, value) {
268
- return value;
269
- }
270
- function Unknown(schema, value) {
271
- return value;
272
- }
273
- function Void(schema, value) {
274
- return value;
275
- }
276
- function UserDefined(schema, value) {
277
- return value;
278
- }
279
- function Visit(schema, value) {
280
- const anySchema = schema;
281
- switch (schema[Types.Kind]) {
282
- case 'Any':
283
- return Any(anySchema, value);
284
- case 'Array':
285
- return Array(anySchema, value);
286
- case 'BigInt':
287
- return BigInt(anySchema, value);
288
- case 'Boolean':
289
- return Boolean(anySchema, value);
290
- case 'Constructor':
291
- return Constructor(anySchema, value);
292
- case 'Date':
293
- return Date(anySchema, value);
294
- case 'Function':
295
- return Function(anySchema, value);
296
- case 'Integer':
297
- return Integer(anySchema, value);
298
- case 'Intersect':
299
- return Intersect(anySchema, value);
300
- case 'Literal':
301
- return Literal(anySchema, value);
302
- case 'Never':
303
- return Never(anySchema, value);
304
- case 'Null':
305
- return Null(anySchema, value);
306
- case 'Number':
307
- return Number(anySchema, value);
308
- case 'Object':
309
- return Object(anySchema, value);
310
- case 'Promise':
311
- return Promise(anySchema, value);
312
- case 'Record':
313
- return Record(anySchema, value);
314
- case 'Ref':
315
- return Ref(anySchema, value);
316
- case 'Self':
317
- return Self(anySchema, value);
318
- case 'String':
319
- return String(anySchema, value);
320
- case 'Symbol':
321
- return Symbol(anySchema, value);
322
- case 'Tuple':
323
- return Tuple(anySchema, value);
324
- case 'Undefined':
325
- return Undefined(anySchema, value);
326
- case 'Union':
327
- return Union(anySchema, value);
328
- case 'Uint8Array':
329
- return Uint8Array(anySchema, value);
330
- case 'Unknown':
331
- return Unknown(anySchema, value);
332
- case 'Void':
333
- return Void(anySchema, value);
334
- default:
335
- if (!Types.TypeRegistry.Has(anySchema[Types.Kind]))
336
- throw new ValueConvertUnknownTypeError(anySchema);
337
- return UserDefined(anySchema, value);
338
- }
339
- }
340
- ValueConvert.Visit = Visit;
341
- function Convert(schema, value) {
342
- return Visit(schema, clone_1.ValueClone.Clone(value));
343
- }
344
- ValueConvert.Convert = Convert;
345
- })(ValueConvert = exports.ValueConvert || (exports.ValueConvert = {}));
1
+ "use strict";
2
+ /*--------------------------------------------------------------------------
3
+
4
+ @sinclair/typebox/value
5
+
6
+ The MIT License (MIT)
7
+
8
+ Copyright (c) 2017-2023 Haydn Paterson (sinclair) <haydn.developer@gmail.com>
9
+
10
+ Permission is hereby granted, free of charge, to any person obtaining a copy
11
+ of this software and associated documentation files (the "Software"), to deal
12
+ in the Software without restriction, including without limitation the rights
13
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
14
+ copies of the Software, and to permit persons to whom the Software is
15
+ furnished to do so, subject to the following conditions:
16
+
17
+ The above copyright notice and this permission notice shall be included in
18
+ all copies or substantial portions of the Software.
19
+
20
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
21
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
22
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
23
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
24
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
25
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
26
+ THE SOFTWARE.
27
+
28
+ ---------------------------------------------------------------------------*/
29
+ Object.defineProperty(exports, "__esModule", { value: true });
30
+ exports.ValueConvert = exports.ValueConvertUnknownTypeError = exports.ValueConvertReferenceTypeError = void 0;
31
+ const Types = require("../typebox");
32
+ const clone_1 = require("./clone");
33
+ // ----------------------------------------------------------------------------------------------
34
+ // Errors
35
+ // ----------------------------------------------------------------------------------------------
36
+ class ValueConvertReferenceTypeError extends Error {
37
+ constructor(schema) {
38
+ super(`ValueConvert: Cannot locate referenced schema with $id '${schema.$ref}'`);
39
+ this.schema = schema;
40
+ }
41
+ }
42
+ exports.ValueConvertReferenceTypeError = ValueConvertReferenceTypeError;
43
+ class ValueConvertUnknownTypeError extends Error {
44
+ constructor(schema) {
45
+ super('ValueConvert: Unknown type');
46
+ this.schema = schema;
47
+ }
48
+ }
49
+ exports.ValueConvertUnknownTypeError = ValueConvertUnknownTypeError;
50
+ var ValueConvert;
51
+ (function (ValueConvert) {
52
+ // ----------------------------------------------------------------------------------------------
53
+ // Guards
54
+ // ----------------------------------------------------------------------------------------------
55
+ function IsObject(value) {
56
+ return typeof value === 'object' && value !== null && !globalThis.Array.isArray(value);
57
+ }
58
+ function IsArray(value) {
59
+ return typeof value === 'object' && globalThis.Array.isArray(value);
60
+ }
61
+ function IsDate(value) {
62
+ return typeof value === 'object' && value instanceof globalThis.Date;
63
+ }
64
+ function IsSymbol(value) {
65
+ return typeof value === 'symbol';
66
+ }
67
+ function IsString(value) {
68
+ return typeof value === 'string';
69
+ }
70
+ function IsBoolean(value) {
71
+ return typeof value === 'boolean';
72
+ }
73
+ function IsBigInt(value) {
74
+ return typeof value === 'bigint';
75
+ }
76
+ function IsNumber(value) {
77
+ return typeof value === 'number' && !isNaN(value);
78
+ }
79
+ function IsStringNumeric(value) {
80
+ return IsString(value) && !isNaN(value) && !isNaN(parseFloat(value));
81
+ }
82
+ function IsValueToString(value) {
83
+ return IsBigInt(value) || IsBoolean(value) || IsNumber(value);
84
+ }
85
+ function IsValueTrue(value) {
86
+ return value === true || (IsNumber(value) && value === 1) || (IsBigInt(value) && value === globalThis.BigInt('1')) || (IsString(value) && (value.toLowerCase() === 'true' || value === '1'));
87
+ }
88
+ function IsValueFalse(value) {
89
+ return value === false || (IsNumber(value) && value === 0) || (IsBigInt(value) && value === globalThis.BigInt('0')) || (IsString(value) && (value.toLowerCase() === 'false' || value === '0'));
90
+ }
91
+ function IsTimeStringWithTimeZone(value) {
92
+ return IsString(value) && /^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)$/i.test(value);
93
+ }
94
+ function IsTimeStringWithoutTimeZone(value) {
95
+ return IsString(value) && /^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)?$/i.test(value);
96
+ }
97
+ function IsDateTimeStringWithTimeZone(value) {
98
+ 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);
99
+ }
100
+ function IsDateTimeStringWithoutTimeZone(value) {
101
+ 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);
102
+ }
103
+ function IsDateString(value) {
104
+ return IsString(value) && /^\d\d\d\d-[0-1]\d-[0-3]\d$/i.test(value);
105
+ }
106
+ // ----------------------------------------------------------------------------------------------
107
+ // Convert
108
+ // ----------------------------------------------------------------------------------------------
109
+ function TryConvertLiteralString(value, target) {
110
+ const conversion = TryConvertString(value);
111
+ return conversion === target ? conversion : value;
112
+ }
113
+ function TryConvertLiteralNumber(value, target) {
114
+ const conversion = TryConvertNumber(value);
115
+ return conversion === target ? conversion : value;
116
+ }
117
+ function TryConvertLiteralBoolean(value, target) {
118
+ const conversion = TryConvertBoolean(value);
119
+ return conversion === target ? conversion : value;
120
+ }
121
+ function TryConvertLiteral(schema, value) {
122
+ if (typeof schema.const === 'string') {
123
+ return TryConvertLiteralString(value, schema.const);
124
+ }
125
+ else if (typeof schema.const === 'number') {
126
+ return TryConvertLiteralNumber(value, schema.const);
127
+ }
128
+ else if (typeof schema.const === 'boolean') {
129
+ return TryConvertLiteralBoolean(value, schema.const);
130
+ }
131
+ else {
132
+ return clone_1.ValueClone.Clone(value);
133
+ }
134
+ }
135
+ function TryConvertBoolean(value) {
136
+ return IsValueTrue(value) ? true : IsValueFalse(value) ? false : value;
137
+ }
138
+ function TryConvertBigInt(value) {
139
+ return IsStringNumeric(value) ? globalThis.BigInt(parseInt(value)) : IsNumber(value) ? globalThis.BigInt(value | 0) : IsValueFalse(value) ? 0 : IsValueTrue(value) ? 1 : value;
140
+ }
141
+ function TryConvertString(value) {
142
+ return IsValueToString(value) ? value.toString() : IsSymbol(value) && value.description !== undefined ? value.description.toString() : value;
143
+ }
144
+ function TryConvertNumber(value) {
145
+ return IsStringNumeric(value) ? parseFloat(value) : IsValueTrue(value) ? 1 : IsValueFalse(value) ? 0 : value;
146
+ }
147
+ function TryConvertInteger(value) {
148
+ return IsStringNumeric(value) ? parseInt(value) : IsNumber(value) ? value | 0 : IsValueTrue(value) ? 1 : IsValueFalse(value) ? 0 : value;
149
+ }
150
+ function TryConvertNull(value) {
151
+ return IsString(value) && value.toLowerCase() === 'null' ? null : value;
152
+ }
153
+ function TryConvertUndefined(value) {
154
+ return IsString(value) && value === 'undefined' ? undefined : value;
155
+ }
156
+ function TryConvertDate(value) {
157
+ // note: this function may return an invalid dates for the regex tests
158
+ // above. Invalid dates will however be checked during the casting
159
+ // function and will return a epoch date if invalid. Consider better
160
+ // string parsing for the iso dates in future revisions.
161
+ return IsDate(value)
162
+ ? value
163
+ : IsNumber(value)
164
+ ? new globalThis.Date(value)
165
+ : IsValueTrue(value)
166
+ ? new globalThis.Date(1)
167
+ : IsValueFalse(value)
168
+ ? new globalThis.Date(0)
169
+ : IsStringNumeric(value)
170
+ ? new globalThis.Date(parseInt(value))
171
+ : IsTimeStringWithoutTimeZone(value)
172
+ ? new globalThis.Date(`1970-01-01T${value}.000Z`)
173
+ : IsTimeStringWithTimeZone(value)
174
+ ? new globalThis.Date(`1970-01-01T${value}`)
175
+ : IsDateTimeStringWithoutTimeZone(value)
176
+ ? new globalThis.Date(`${value}.000Z`)
177
+ : IsDateTimeStringWithTimeZone(value)
178
+ ? new globalThis.Date(value)
179
+ : IsDateString(value)
180
+ ? new globalThis.Date(`${value}T00:00:00.000Z`)
181
+ : value;
182
+ }
183
+ // ----------------------------------------------------------------------------------------------
184
+ // Cast
185
+ // ----------------------------------------------------------------------------------------------
186
+ function Any(schema, value) {
187
+ return value;
188
+ }
189
+ function Array(schema, value) {
190
+ if (IsArray(value)) {
191
+ return value.map((value) => Visit(schema.items, value));
192
+ }
193
+ return value;
194
+ }
195
+ function BigInt(schema, value) {
196
+ return TryConvertBigInt(value);
197
+ }
198
+ function Boolean(schema, value) {
199
+ return TryConvertBoolean(value);
200
+ }
201
+ function Constructor(schema, value) {
202
+ return clone_1.ValueClone.Clone(value);
203
+ }
204
+ function Date(schema, value) {
205
+ return TryConvertDate(value);
206
+ }
207
+ function Function(schema, value) {
208
+ return value;
209
+ }
210
+ function Integer(schema, value) {
211
+ return TryConvertInteger(value);
212
+ }
213
+ function Intersect(schema, value) {
214
+ return value;
215
+ }
216
+ function Literal(schema, value) {
217
+ return TryConvertLiteral(schema, value);
218
+ }
219
+ function Never(schema, value) {
220
+ return value;
221
+ }
222
+ function Null(schema, value) {
223
+ return TryConvertNull(value);
224
+ }
225
+ function Number(schema, value) {
226
+ return TryConvertNumber(value);
227
+ }
228
+ function Object(schema, value) {
229
+ if (IsObject(value))
230
+ return globalThis.Object.keys(schema.properties).reduce((acc, key) => {
231
+ return value[key] !== undefined ? { ...acc, [key]: Visit(schema.properties[key], value[key]) } : { ...acc };
232
+ }, value);
233
+ return value;
234
+ }
235
+ function Promise(schema, value) {
236
+ return value;
237
+ }
238
+ function Record(schema, value) {
239
+ return value;
240
+ }
241
+ function Ref(schema, value) {
242
+ return Visit(Types.ReferenceRegistry.DerefOne(schema), value);
243
+ }
244
+ function Self(schema, value) {
245
+ return Visit(Types.ReferenceRegistry.DerefOne(schema), value);
246
+ }
247
+ function String(schema, value) {
248
+ return TryConvertString(value);
249
+ }
250
+ function Symbol(schema, value) {
251
+ return value;
252
+ }
253
+ function Tuple(schema, value) {
254
+ if (IsArray(value) && schema.items !== undefined) {
255
+ return value.map((value, index) => {
256
+ return index < schema.items.length ? Visit(schema.items[index], value) : value;
257
+ });
258
+ }
259
+ return value;
260
+ }
261
+ function Undefined(schema, value) {
262
+ return TryConvertUndefined(value);
263
+ }
264
+ function Union(schema, value) {
265
+ return value;
266
+ }
267
+ function Uint8Array(schema, value) {
268
+ return value;
269
+ }
270
+ function Unknown(schema, value) {
271
+ return value;
272
+ }
273
+ function Void(schema, value) {
274
+ return value;
275
+ }
276
+ function UserDefined(schema, value) {
277
+ return value;
278
+ }
279
+ function Visit(schema, value) {
280
+ const anySchema = schema;
281
+ switch (schema[Types.Kind]) {
282
+ case 'Any':
283
+ return Any(anySchema, value);
284
+ case 'Array':
285
+ return Array(anySchema, value);
286
+ case 'BigInt':
287
+ return BigInt(anySchema, value);
288
+ case 'Boolean':
289
+ return Boolean(anySchema, value);
290
+ case 'Constructor':
291
+ return Constructor(anySchema, value);
292
+ case 'Date':
293
+ return Date(anySchema, value);
294
+ case 'Function':
295
+ return Function(anySchema, value);
296
+ case 'Integer':
297
+ return Integer(anySchema, value);
298
+ case 'Intersect':
299
+ return Intersect(anySchema, value);
300
+ case 'Literal':
301
+ return Literal(anySchema, value);
302
+ case 'Never':
303
+ return Never(anySchema, value);
304
+ case 'Null':
305
+ return Null(anySchema, value);
306
+ case 'Number':
307
+ return Number(anySchema, value);
308
+ case 'Object':
309
+ return Object(anySchema, value);
310
+ case 'Promise':
311
+ return Promise(anySchema, value);
312
+ case 'Record':
313
+ return Record(anySchema, value);
314
+ case 'Ref':
315
+ return Ref(anySchema, value);
316
+ case 'Self':
317
+ return Self(anySchema, value);
318
+ case 'String':
319
+ return String(anySchema, value);
320
+ case 'Symbol':
321
+ return Symbol(anySchema, value);
322
+ case 'Tuple':
323
+ return Tuple(anySchema, value);
324
+ case 'Undefined':
325
+ return Undefined(anySchema, value);
326
+ case 'Union':
327
+ return Union(anySchema, value);
328
+ case 'Uint8Array':
329
+ return Uint8Array(anySchema, value);
330
+ case 'Unknown':
331
+ return Unknown(anySchema, value);
332
+ case 'Void':
333
+ return Void(anySchema, value);
334
+ default:
335
+ if (!Types.TypeRegistry.Has(anySchema[Types.Kind]))
336
+ throw new ValueConvertUnknownTypeError(anySchema);
337
+ return UserDefined(anySchema, value);
338
+ }
339
+ }
340
+ ValueConvert.Visit = Visit;
341
+ function Convert(schema, value) {
342
+ return Visit(schema, clone_1.ValueClone.Clone(value));
343
+ }
344
+ ValueConvert.Convert = Convert;
345
+ })(ValueConvert = exports.ValueConvert || (exports.ValueConvert = {}));