typia 3.8.0-dev.20230417 → 3.8.0-dev.20230418

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 (51) hide show
  1. package/README.md +1 -1
  2. package/lib/executable/setup/PackageManager.d.ts +1 -1
  3. package/lib/metadata/Metadata.js +1 -1
  4. package/lib/metadata/Metadata.js.map +1 -1
  5. package/lib/programmers/CheckerProgrammer.js +1 -1
  6. package/lib/programmers/CheckerProgrammer.js.map +1 -1
  7. package/lib/typings/Customizable.d.ts +2 -2
  8. package/lib/utils/RandomGenerator.d.ts +1 -17
  9. package/lib/utils/RandomGenerator.js.map +1 -1
  10. package/package.json +2 -2
  11. package/src/IRandomGenerator.ts +33 -33
  12. package/src/executable/TypiaGenerateWizard.ts +85 -85
  13. package/src/executable/setup/ArgumentParser.ts +45 -45
  14. package/src/executable/setup/CommandExecutor.ts +8 -8
  15. package/src/executable/setup/FileRetriever.ts +22 -22
  16. package/src/executable/setup/PackageManager.ts +1 -1
  17. package/src/executable/setup/PluginConfigurator.ts +59 -59
  18. package/src/factories/MetadataTagFactory.ts +302 -302
  19. package/src/factories/TypiaFileFactory.ts +129 -129
  20. package/src/metadata/ICommentTag.ts +4 -4
  21. package/src/metadata/Metadata.ts +1 -1
  22. package/src/module.ts +2043 -2043
  23. package/src/programmers/AssertProgrammer.ts +284 -284
  24. package/src/programmers/CheckerProgrammer.ts +1 -1
  25. package/src/programmers/LiteralsProgrammer.ts +65 -65
  26. package/src/programmers/RandomProgrammer.ts +413 -413
  27. package/src/programmers/ValidateProgrammer.ts +317 -317
  28. package/src/programmers/helpers/RandomJoiner.ts +161 -161
  29. package/src/programmers/helpers/RandomRanger.ts +216 -216
  30. package/src/programmers/internal/application_native.ts +32 -32
  31. package/src/programmers/internal/check_array.ts +30 -30
  32. package/src/programmers/internal/check_array_length.ts +35 -35
  33. package/src/programmers/internal/check_custom.ts +33 -33
  34. package/src/programmers/internal/check_number.ts +177 -177
  35. package/src/programmers/internal/check_object.ts +55 -55
  36. package/src/programmers/internal/check_union_array_like.ts +272 -272
  37. package/src/programmers/internal/feature_object_entries.ts +63 -63
  38. package/src/programmers/internal/get_comment_tags.ts +23 -23
  39. package/src/programmers/internal/metadata_to_pattern.ts +34 -34
  40. package/src/programmers/internal/random_custom.ts +30 -30
  41. package/src/programmers/internal/stringify_dynamic_properties.ts +168 -168
  42. package/src/programmers/internal/stringify_regular_properties.ts +84 -84
  43. package/src/transformers/CallExpressionTransformer.ts +174 -174
  44. package/src/transformers/ImportTransformer.ts +66 -66
  45. package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +119 -119
  46. package/src/transformers/features/miscellaneous/CreateRandomTransformer.ts +41 -41
  47. package/src/transformers/features/miscellaneous/LiteralsTransformer.ts +30 -30
  48. package/src/transformers/features/miscellaneous/MetadataTransformer.ts +54 -54
  49. package/src/transformers/features/miscellaneous/RandomTransformer.ts +46 -46
  50. package/src/typings/Customizable.ts +2 -2
  51. package/src/utils/RandomGenerator.ts +3 -0
@@ -1,65 +1,65 @@
1
- import ts from "typescript";
2
-
3
- import { MetadataCollection } from "../factories/MetadataCollection";
4
- import { MetadataFactory } from "../factories/MetadataFactory";
5
-
6
- import { Metadata } from "../metadata/Metadata";
7
-
8
- import { IProject } from "../transformers/IProject";
9
-
10
- import { Atomic } from "../typings/Atomic";
11
-
12
- import { ArrayUtil } from "../utils/ArrayUtil";
13
-
14
- export namespace LiteralsProgrammer {
15
- export const generate = (project: IProject) => (type: ts.Type) => {
16
- const meta: Metadata = MetadataFactory.generate(
17
- project.checker,
18
- new MetadataCollection(),
19
- type,
20
- {
21
- resolve: true,
22
- constant: true,
23
- validate: (meta) => {
24
- const length: number =
25
- meta.constants
26
- .map((c) => c.values.length)
27
- .reduce((a, b) => a + b, 0) +
28
- meta.atomics.filter((type) => type === "boolean")
29
- .length;
30
- if (0 === length) throw new Error(ErrorMessages.NO);
31
- else if (meta.size() !== length)
32
- throw new Error(ErrorMessages.ONLY);
33
- },
34
- },
35
- );
36
- const values: Set<Atomic.Type> = new Set([
37
- ...ArrayUtil.flat<Atomic.Type>(meta.constants.map((c) => c.values)),
38
- ...(meta.atomics.filter((type) => type === "boolean").length
39
- ? [true, false]
40
- : []),
41
- ]);
42
- return ts.factory.createAsExpression(
43
- ts.factory.createArrayLiteralExpression(
44
- [...values].map((v) =>
45
- typeof v === "boolean"
46
- ? v
47
- ? ts.factory.createTrue()
48
- : ts.factory.createFalse()
49
- : typeof v === "number"
50
- ? ts.factory.createNumericLiteral(v)
51
- : typeof v === "bigint"
52
- ? ts.factory.createBigIntLiteral(v.toString())
53
- : ts.factory.createStringLiteral(v),
54
- ),
55
- true,
56
- ),
57
- ts.factory.createTypeReferenceNode("const"),
58
- );
59
- };
60
- }
61
-
62
- enum ErrorMessages {
63
- NO = "Error on typia.literals(): no literal type found.",
64
- ONLY = "Error on typia.literals(): only literal type allowed.",
65
- }
1
+ import ts from "typescript";
2
+
3
+ import { MetadataCollection } from "../factories/MetadataCollection";
4
+ import { MetadataFactory } from "../factories/MetadataFactory";
5
+
6
+ import { Metadata } from "../metadata/Metadata";
7
+
8
+ import { IProject } from "../transformers/IProject";
9
+
10
+ import { Atomic } from "../typings/Atomic";
11
+
12
+ import { ArrayUtil } from "../utils/ArrayUtil";
13
+
14
+ export namespace LiteralsProgrammer {
15
+ export const generate = (project: IProject) => (type: ts.Type) => {
16
+ const meta: Metadata = MetadataFactory.generate(
17
+ project.checker,
18
+ new MetadataCollection(),
19
+ type,
20
+ {
21
+ resolve: true,
22
+ constant: true,
23
+ validate: (meta) => {
24
+ const length: number =
25
+ meta.constants
26
+ .map((c) => c.values.length)
27
+ .reduce((a, b) => a + b, 0) +
28
+ meta.atomics.filter((type) => type === "boolean")
29
+ .length;
30
+ if (0 === length) throw new Error(ErrorMessages.NO);
31
+ else if (meta.size() !== length)
32
+ throw new Error(ErrorMessages.ONLY);
33
+ },
34
+ },
35
+ );
36
+ const values: Set<Atomic.Type> = new Set([
37
+ ...ArrayUtil.flat<Atomic.Type>(meta.constants.map((c) => c.values)),
38
+ ...(meta.atomics.filter((type) => type === "boolean").length
39
+ ? [true, false]
40
+ : []),
41
+ ]);
42
+ return ts.factory.createAsExpression(
43
+ ts.factory.createArrayLiteralExpression(
44
+ [...values].map((v) =>
45
+ typeof v === "boolean"
46
+ ? v
47
+ ? ts.factory.createTrue()
48
+ : ts.factory.createFalse()
49
+ : typeof v === "number"
50
+ ? ts.factory.createNumericLiteral(v)
51
+ : typeof v === "bigint"
52
+ ? ts.factory.createBigIntLiteral(v.toString())
53
+ : ts.factory.createStringLiteral(v),
54
+ ),
55
+ true,
56
+ ),
57
+ ts.factory.createTypeReferenceNode("const"),
58
+ );
59
+ };
60
+ }
61
+
62
+ enum ErrorMessages {
63
+ NO = "Error on typia.literals(): no literal type found.",
64
+ ONLY = "Error on typia.literals(): only literal type allowed.",
65
+ }