typia 3.8.0-dev.20230416 → 3.8.0-dev.20230417

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 (50) hide show
  1. package/README.md +35 -228
  2. package/lib/factories/TypiaFileFactory.js +9 -4
  3. package/lib/factories/TypiaFileFactory.js.map +1 -1
  4. package/package.json +1 -1
  5. package/src/IRandomGenerator.ts +33 -33
  6. package/src/executable/TypiaGenerateWizard.ts +85 -85
  7. package/src/executable/TypiaSetupWizard.ts +118 -118
  8. package/src/executable/setup/ArgumentParser.ts +45 -45
  9. package/src/executable/setup/CommandExecutor.ts +8 -8
  10. package/src/executable/setup/FileRetriever.ts +22 -22
  11. package/src/executable/setup/PackageManager.ts +71 -71
  12. package/src/executable/setup/PluginConfigurator.ts +59 -59
  13. package/src/executable/typia.ts +52 -52
  14. package/src/factories/IdentifierFactory.ts +59 -59
  15. package/src/factories/MetadataTagFactory.ts +302 -302
  16. package/src/factories/TypiaFileFactory.ts +12 -3
  17. package/src/metadata/ICommentTag.ts +4 -4
  18. package/src/metadata/Metadata.ts +533 -533
  19. package/src/module.ts +2043 -2043
  20. package/src/programmers/AssertProgrammer.ts +284 -284
  21. package/src/programmers/CheckerProgrammer.ts +920 -920
  22. package/src/programmers/LiteralsProgrammer.ts +65 -65
  23. package/src/programmers/RandomProgrammer.ts +413 -413
  24. package/src/programmers/ValidateProgrammer.ts +317 -317
  25. package/src/programmers/helpers/RandomJoiner.ts +161 -161
  26. package/src/programmers/helpers/RandomRanger.ts +216 -216
  27. package/src/programmers/internal/application_native.ts +32 -32
  28. package/src/programmers/internal/check_array.ts +30 -30
  29. package/src/programmers/internal/check_array_length.ts +35 -35
  30. package/src/programmers/internal/check_custom.ts +33 -33
  31. package/src/programmers/internal/check_number.ts +177 -177
  32. package/src/programmers/internal/check_object.ts +55 -55
  33. package/src/programmers/internal/check_string_tags.ts +67 -67
  34. package/src/programmers/internal/check_template.ts +56 -56
  35. package/src/programmers/internal/check_union_array_like.ts +272 -272
  36. package/src/programmers/internal/feature_object_entries.ts +63 -63
  37. package/src/programmers/internal/get_comment_tags.ts +23 -23
  38. package/src/programmers/internal/metadata_to_pattern.ts +34 -34
  39. package/src/programmers/internal/random_custom.ts +30 -30
  40. package/src/programmers/internal/stringify_dynamic_properties.ts +168 -168
  41. package/src/programmers/internal/stringify_regular_properties.ts +84 -84
  42. package/src/transformers/CallExpressionTransformer.ts +174 -174
  43. package/src/transformers/ImportTransformer.ts +66 -66
  44. package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +119 -119
  45. package/src/transformers/features/miscellaneous/CreateRandomTransformer.ts +41 -41
  46. package/src/transformers/features/miscellaneous/LiteralsTransformer.ts +30 -30
  47. package/src/transformers/features/miscellaneous/MetadataTransformer.ts +54 -54
  48. package/src/transformers/features/miscellaneous/RandomTransformer.ts +46 -46
  49. package/src/typings/Customizable.ts +5 -5
  50. package/src/utils/RandomGenerator.ts +93 -93
@@ -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
+ }