typia 3.6.9 → 3.6.10

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 (205) hide show
  1. package/lib/factories/TypiaFileFactory.js +61 -54
  2. package/lib/factories/TypiaFileFactory.js.map +1 -1
  3. package/package.json +10 -8
  4. package/src/IRandomGenerator.ts +17 -17
  5. package/src/IValidation.ts +21 -21
  6. package/src/Primitive.ts +104 -104
  7. package/src/TypeGuardError.ts +36 -36
  8. package/src/executable/TypiaGenerateWizard.ts +87 -87
  9. package/src/executable/TypiaSetupWizard.ts +152 -152
  10. package/src/executable/setup/ArgumentParser.ts +91 -91
  11. package/src/executable/setup/CommandExecutor.ts +8 -8
  12. package/src/executable/setup/FileRetriever.ts +33 -33
  13. package/src/executable/setup/PackageManager.ts +92 -92
  14. package/src/executable/setup/PluginConfigurator.ts +99 -99
  15. package/src/executable/typia.ts +38 -38
  16. package/src/factories/CommentFactory.ts +10 -10
  17. package/src/factories/ExpressionFactory.ts +77 -77
  18. package/src/factories/IdentifierFactory.ts +73 -73
  19. package/src/factories/LiteralFactory.ts +44 -44
  20. package/src/factories/MetadataCollection.ts +122 -122
  21. package/src/factories/MetadataFactory.ts +51 -51
  22. package/src/factories/MetadataTagFactory.ts +276 -276
  23. package/src/factories/StatementFactory.ts +60 -60
  24. package/src/factories/TemplateFactory.ts +56 -56
  25. package/src/factories/TypeFactory.ts +129 -129
  26. package/src/factories/TypiaFileFactory.ts +120 -117
  27. package/src/factories/ValueFactory.ts +12 -12
  28. package/src/factories/internal/metadata/MetadataHelper.ts +12 -12
  29. package/src/factories/internal/metadata/emplace_metadata_object.ts +142 -142
  30. package/src/factories/internal/metadata/explore_metadata.ts +92 -92
  31. package/src/factories/internal/metadata/iterate_metadata.ts +80 -80
  32. package/src/factories/internal/metadata/iterate_metadata_array.ts +29 -29
  33. package/src/factories/internal/metadata/iterate_metadata_atomic.ts +59 -59
  34. package/src/factories/internal/metadata/iterate_metadata_coalesce.ts +33 -33
  35. package/src/factories/internal/metadata/iterate_metadata_constant.ts +58 -58
  36. package/src/factories/internal/metadata/iterate_metadata_map.ts +41 -41
  37. package/src/factories/internal/metadata/iterate_metadata_native.ts +222 -222
  38. package/src/factories/internal/metadata/iterate_metadata_object.ts +48 -48
  39. package/src/factories/internal/metadata/iterate_metadata_resolve.ts +27 -27
  40. package/src/factories/internal/metadata/iterate_metadata_set.ts +33 -33
  41. package/src/factories/internal/metadata/iterate_metadata_template.ts +38 -38
  42. package/src/factories/internal/metadata/iterate_metadata_tuple.ts +45 -45
  43. package/src/factories/internal/metadata/iterate_metadata_union.ts +59 -59
  44. package/src/functional/$any.ts +3 -3
  45. package/src/functional/$every.ts +11 -11
  46. package/src/functional/$guard.ts +35 -35
  47. package/src/functional/$is_between.ts +7 -7
  48. package/src/functional/$is_date.ts +4 -4
  49. package/src/functional/$is_datetime.ts +3 -3
  50. package/src/functional/$is_email.ts +5 -5
  51. package/src/functional/$is_ipv4.ts +5 -5
  52. package/src/functional/$is_ipv6.ts +5 -5
  53. package/src/functional/$is_url.ts +5 -5
  54. package/src/functional/$is_uuid.ts +5 -5
  55. package/src/functional/$join.ts +50 -50
  56. package/src/functional/$number.ts +12 -12
  57. package/src/functional/$report.ts +15 -15
  58. package/src/functional/$rest.ts +3 -3
  59. package/src/functional/$string.ts +37 -37
  60. package/src/functional/$tail.ts +6 -6
  61. package/src/functional/Namespace.ts +125 -125
  62. package/src/index.ts +4 -4
  63. package/src/metadata/IJsDocTagInfo.ts +10 -10
  64. package/src/metadata/IMetadata.ts +25 -25
  65. package/src/metadata/IMetadataApplication.ts +7 -7
  66. package/src/metadata/IMetadataConstant.ts +16 -16
  67. package/src/metadata/IMetadataEntry.ts +6 -6
  68. package/src/metadata/IMetadataObject.ts +29 -29
  69. package/src/metadata/IMetadataProperty.ts +11 -11
  70. package/src/metadata/IMetadataTag.ts +105 -105
  71. package/src/metadata/Metadata.ts +534 -534
  72. package/src/metadata/MetadataConstant.ts +3 -3
  73. package/src/metadata/MetadataObject.ts +131 -131
  74. package/src/metadata/MetadataProperty.ts +64 -64
  75. package/src/module.ts +1946 -1946
  76. package/src/programmers/ApplicationProgrammer.ts +55 -55
  77. package/src/programmers/AssertCloneProgrammer.ts +70 -70
  78. package/src/programmers/AssertParseProgrammer.ts +65 -65
  79. package/src/programmers/AssertProgrammer.ts +232 -232
  80. package/src/programmers/AssertPruneProgrammer.ts +67 -67
  81. package/src/programmers/AssertStringifyProgrammer.ts +71 -71
  82. package/src/programmers/CheckerProgrammer.ts +893 -893
  83. package/src/programmers/CloneProgrammer.ts +386 -386
  84. package/src/programmers/FeatureProgrammer.ts +505 -505
  85. package/src/programmers/IsCloneProgrammer.ts +80 -80
  86. package/src/programmers/IsParseProgrammer.ts +74 -74
  87. package/src/programmers/IsProgrammer.ts +200 -200
  88. package/src/programmers/IsPruneProgrammer.ts +75 -75
  89. package/src/programmers/IsStringifyProgrammer.ts +81 -81
  90. package/src/programmers/PruneProgrammer.ts +341 -341
  91. package/src/programmers/RandomProgrammer.ts +388 -388
  92. package/src/programmers/StringifyProgrammer.ts +795 -795
  93. package/src/programmers/ValidateCloneProgrammer.ts +90 -90
  94. package/src/programmers/ValidateParseProgrammer.ts +69 -69
  95. package/src/programmers/ValidateProgrammer.ts +266 -266
  96. package/src/programmers/ValidatePruneProgrammer.ts +83 -83
  97. package/src/programmers/ValidateStringifyProgrammer.ts +89 -89
  98. package/src/programmers/helpers/AtomicPredicator.ts +31 -31
  99. package/src/programmers/helpers/CloneJoiner.ts +134 -134
  100. package/src/programmers/helpers/FunctionImporeter.ts +55 -55
  101. package/src/programmers/helpers/IExpressionEntry.ts +12 -12
  102. package/src/programmers/helpers/OptionPredicator.ts +19 -19
  103. package/src/programmers/helpers/PruneJoiner.ts +52 -52
  104. package/src/programmers/helpers/RandomJoiner.ts +149 -149
  105. package/src/programmers/helpers/RandomRanger.ts +216 -216
  106. package/src/programmers/helpers/StringifyJoinder.ts +114 -114
  107. package/src/programmers/helpers/StringifyPredicator.ts +18 -18
  108. package/src/programmers/helpers/UnionExplorer.ts +274 -274
  109. package/src/programmers/helpers/UnionPredicator.ts +81 -81
  110. package/src/programmers/internal/application_array.ts +37 -37
  111. package/src/programmers/internal/application_boolean.ts +17 -17
  112. package/src/programmers/internal/application_constant.ts +29 -29
  113. package/src/programmers/internal/application_default.ts +17 -17
  114. package/src/programmers/internal/application_default_string.ts +32 -32
  115. package/src/programmers/internal/application_native.ts +29 -29
  116. package/src/programmers/internal/application_number.ts +73 -73
  117. package/src/programmers/internal/application_object.ts +153 -153
  118. package/src/programmers/internal/application_schema.ts +184 -184
  119. package/src/programmers/internal/application_string.ts +45 -45
  120. package/src/programmers/internal/application_templates.ts +27 -27
  121. package/src/programmers/internal/application_tuple.ts +29 -29
  122. package/src/programmers/internal/check_array.ts +22 -22
  123. package/src/programmers/internal/check_array_length.ts +44 -44
  124. package/src/programmers/internal/check_bigint.ts +64 -64
  125. package/src/programmers/internal/check_dynamic_properties.ts +197 -197
  126. package/src/programmers/internal/check_everything.ts +28 -28
  127. package/src/programmers/internal/check_native.ts +21 -21
  128. package/src/programmers/internal/check_number.ts +145 -145
  129. package/src/programmers/internal/check_object.ts +48 -48
  130. package/src/programmers/internal/check_string.ts +24 -24
  131. package/src/programmers/internal/check_string_tags.ts +63 -63
  132. package/src/programmers/internal/check_template.ts +50 -50
  133. package/src/programmers/internal/check_union_array_like.ts +260 -260
  134. package/src/programmers/internal/check_union_tuple.ts +33 -33
  135. package/src/programmers/internal/decode_union_object.ts +73 -73
  136. package/src/programmers/internal/feature_object_entries.ts +59 -59
  137. package/src/programmers/internal/metadata_to_pattern.ts +31 -31
  138. package/src/programmers/internal/prune_object_properties.ts +60 -60
  139. package/src/programmers/internal/stringify_dynamic_properties.ts +165 -165
  140. package/src/programmers/internal/stringify_native.ts +8 -8
  141. package/src/programmers/internal/stringify_regular_properties.ts +81 -81
  142. package/src/programmers/internal/template_to_pattern.ts +15 -15
  143. package/src/schemas/IJsonApplication.ts +9 -9
  144. package/src/schemas/IJsonComponents.ts +26 -26
  145. package/src/schemas/IJsonSchema.ts +121 -121
  146. package/src/transform.ts +21 -21
  147. package/src/transformers/CallExpressionTransformer.ts +172 -172
  148. package/src/transformers/ExpressionWithArgumentTransformer.ts +66 -66
  149. package/src/transformers/FileTransformer.ts +49 -49
  150. package/src/transformers/IProject.ts +11 -11
  151. package/src/transformers/ITransformOptions.ts +62 -62
  152. package/src/transformers/ImportTransformer.ts +60 -60
  153. package/src/transformers/NodeTransformer.ts +19 -19
  154. package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +120 -120
  155. package/src/transformers/features/miscellaneous/AssertCloneTransformer.ts +9 -9
  156. package/src/transformers/features/miscellaneous/AssertPruneTransformer.ts +9 -9
  157. package/src/transformers/features/miscellaneous/CloneTransformer.ts +9 -9
  158. package/src/transformers/features/miscellaneous/CreateAssertCloneTransformer.ts +9 -9
  159. package/src/transformers/features/miscellaneous/CreateAssertPruneTransformer.ts +9 -9
  160. package/src/transformers/features/miscellaneous/CreateCloneTransformer.ts +9 -9
  161. package/src/transformers/features/miscellaneous/CreateIsCloneTransformer.ts +9 -9
  162. package/src/transformers/features/miscellaneous/CreateIsPruneTransformer.ts +9 -9
  163. package/src/transformers/features/miscellaneous/CreatePruneTransformer.ts +9 -9
  164. package/src/transformers/features/miscellaneous/CreateRandomGenerator.ts +42 -42
  165. package/src/transformers/features/miscellaneous/CreateValidateCloneTransformer.ts +9 -9
  166. package/src/transformers/features/miscellaneous/CreateValidatePruneTransformer.ts +9 -9
  167. package/src/transformers/features/miscellaneous/IsCloneTransformer.ts +9 -9
  168. package/src/transformers/features/miscellaneous/IsPruneTransformer.ts +9 -9
  169. package/src/transformers/features/miscellaneous/MetadataTransformer.ts +55 -55
  170. package/src/transformers/features/miscellaneous/PruneTransformer.ts +9 -9
  171. package/src/transformers/features/miscellaneous/RandomTransformer.ts +48 -48
  172. package/src/transformers/features/miscellaneous/ValidateCloneTransformer.ts +9 -9
  173. package/src/transformers/features/miscellaneous/ValidatePruneTransformer.ts +9 -9
  174. package/src/transformers/features/parsers/AssertParseTransformer.ts +9 -9
  175. package/src/transformers/features/parsers/CreateAssertParseTransformer.ts +9 -9
  176. package/src/transformers/features/parsers/CreateIsParseTransformer.ts +9 -9
  177. package/src/transformers/features/parsers/CreateValidateParseTransformer.ts +9 -9
  178. package/src/transformers/features/parsers/IsParseTransformer.ts +9 -9
  179. package/src/transformers/features/parsers/ValidateParseTransformer.ts +9 -9
  180. package/src/transformers/features/stringifiers/AssertStringifyTransformer.ts +10 -10
  181. package/src/transformers/features/stringifiers/CreateAssertStringifyTransformer.ts +9 -9
  182. package/src/transformers/features/stringifiers/CreateIsStringifyTransformer.ts +9 -9
  183. package/src/transformers/features/stringifiers/CreateStringifyTransformer.ts +9 -9
  184. package/src/transformers/features/stringifiers/CreateValidateStringifyProgrammer.ts +11 -11
  185. package/src/transformers/features/stringifiers/IsStringifyTransformer.ts +9 -9
  186. package/src/transformers/features/stringifiers/StringifyTransformer.ts +9 -9
  187. package/src/transformers/features/stringifiers/ValidateStringifyTransformer.ts +10 -10
  188. package/src/transformers/features/validators/AssertTransformer.ts +11 -11
  189. package/src/transformers/features/validators/CreateAssertTransformer.ts +12 -12
  190. package/src/transformers/features/validators/CreateIsTransformer.ts +10 -10
  191. package/src/transformers/features/validators/CreateValidateTransformer.ts +12 -12
  192. package/src/transformers/features/validators/IsTransformer.ts +10 -10
  193. package/src/transformers/features/validators/ValidateTransformer.ts +11 -11
  194. package/src/transformers/internal/GenericTransformer.ts +99 -99
  195. package/src/typings/Atomic.ts +17 -17
  196. package/src/typings/ClassProperties.ts +5 -5
  197. package/src/typings/OmitNever.ts +3 -3
  198. package/src/typings/SpecialFields.ts +3 -3
  199. package/src/typings/Writable.ts +11 -11
  200. package/src/utils/ArrayUtil.ts +49 -49
  201. package/src/utils/Escaper.ts +50 -50
  202. package/src/utils/MapUtil.ts +14 -14
  203. package/src/utils/PatternUtil.ts +30 -30
  204. package/src/utils/RandomGenerator.ts +96 -96
  205. package/src/utils/Singleton.ts +17 -17
@@ -1,87 +1,87 @@
1
- import fs from "fs";
2
-
3
- import { TypiaFileFactory } from "../factories/TypiaFileFactory";
4
-
5
- import { ArgumentParser } from "./setup/ArgumentParser";
6
- import { PackageManager } from "./setup/PackageManager";
7
-
8
- export namespace TypiaGenerateWizard {
9
- export async function generate(): Promise<void> {
10
- console.log("----------------------------------------");
11
- console.log(" Typia Generate Wizard");
12
- console.log("----------------------------------------");
13
-
14
- // LOAD PACKAGE.JSON INFO
15
- const pack: PackageManager = await PackageManager.mount();
16
- const options: IArguments = await ArgumentParser.parse(pack)(false)(
17
- inquiry,
18
- );
19
- await TypiaFileFactory.generate(options);
20
- }
21
-
22
- const inquiry: ArgumentParser.Inquiry<IArguments> = async (
23
- _pack,
24
- command,
25
- prompt,
26
- action,
27
- ) => {
28
- // PREPARE ASSETS
29
- command.option("--input [path]", "input directory");
30
- command.option("--output [directory]", "output directory");
31
- command.option("--project [project]", "tsconfig.json file location");
32
-
33
- const questioned = { value: false };
34
-
35
- const input = (name: string) => async (message: string) => {
36
- const result = await prompt()({
37
- type: "input",
38
- name,
39
- message,
40
- default: "",
41
- });
42
- return result[name] as string;
43
- };
44
- const select =
45
- (name: string) =>
46
- (message: string) =>
47
- async <Choice extends string>(
48
- choices: Choice[],
49
- ): Promise<Choice> => {
50
- questioned.value = true;
51
- return (
52
- await prompt()({
53
- type: "list",
54
- name: name,
55
- message: message,
56
- choices: choices,
57
- })
58
- )[name];
59
- };
60
- const configure = async () => {
61
- const fileList: string[] = await (
62
- await fs.promises.readdir(process.cwd())
63
- ).filter(
64
- (str) =>
65
- str.substring(0, 8) === "tsconfig" &&
66
- str.substring(str.length - 5) === ".json",
67
- );
68
- if (fileList.length === 0)
69
- throw new Error(`Unable to find "tsconfig.json" file.`);
70
- else if (fileList.length === 1) return fileList[0];
71
- return select("tsconfig")("TS Config File")(fileList);
72
- };
73
-
74
- return action(async (options) => {
75
- options.input ??= await input("input")("input directory");
76
- options.output ??= await input("output")("output directory");
77
- options.project ??= await configure();
78
- return options as IArguments;
79
- });
80
- };
81
-
82
- export interface IArguments {
83
- input: string;
84
- output: string;
85
- project: string;
86
- }
87
- }
1
+ import fs from "fs";
2
+
3
+ import { TypiaFileFactory } from "../factories/TypiaFileFactory";
4
+
5
+ import { ArgumentParser } from "./setup/ArgumentParser";
6
+ import { PackageManager } from "./setup/PackageManager";
7
+
8
+ export namespace TypiaGenerateWizard {
9
+ export async function generate(): Promise<void> {
10
+ console.log("----------------------------------------");
11
+ console.log(" Typia Generate Wizard");
12
+ console.log("----------------------------------------");
13
+
14
+ // LOAD PACKAGE.JSON INFO
15
+ const pack: PackageManager = await PackageManager.mount();
16
+ const options: IArguments = await ArgumentParser.parse(pack)(false)(
17
+ inquiry,
18
+ );
19
+ await TypiaFileFactory.generate(options);
20
+ }
21
+
22
+ const inquiry: ArgumentParser.Inquiry<IArguments> = async (
23
+ _pack,
24
+ command,
25
+ prompt,
26
+ action,
27
+ ) => {
28
+ // PREPARE ASSETS
29
+ command.option("--input [path]", "input directory");
30
+ command.option("--output [directory]", "output directory");
31
+ command.option("--project [project]", "tsconfig.json file location");
32
+
33
+ const questioned = { value: false };
34
+
35
+ const input = (name: string) => async (message: string) => {
36
+ const result = await prompt()({
37
+ type: "input",
38
+ name,
39
+ message,
40
+ default: "",
41
+ });
42
+ return result[name] as string;
43
+ };
44
+ const select =
45
+ (name: string) =>
46
+ (message: string) =>
47
+ async <Choice extends string>(
48
+ choices: Choice[],
49
+ ): Promise<Choice> => {
50
+ questioned.value = true;
51
+ return (
52
+ await prompt()({
53
+ type: "list",
54
+ name: name,
55
+ message: message,
56
+ choices: choices,
57
+ })
58
+ )[name];
59
+ };
60
+ const configure = async () => {
61
+ const fileList: string[] = await (
62
+ await fs.promises.readdir(process.cwd())
63
+ ).filter(
64
+ (str) =>
65
+ str.substring(0, 8) === "tsconfig" &&
66
+ str.substring(str.length - 5) === ".json",
67
+ );
68
+ if (fileList.length === 0)
69
+ throw new Error(`Unable to find "tsconfig.json" file.`);
70
+ else if (fileList.length === 1) return fileList[0];
71
+ return select("tsconfig")("TS Config File")(fileList);
72
+ };
73
+
74
+ return action(async (options) => {
75
+ options.input ??= await input("input")("input directory");
76
+ options.output ??= await input("output")("output directory");
77
+ options.project ??= await configure();
78
+ return options as IArguments;
79
+ });
80
+ };
81
+
82
+ export interface IArguments {
83
+ input: string;
84
+ output: string;
85
+ project: string;
86
+ }
87
+ }
@@ -1,152 +1,152 @@
1
- import fs from "fs";
2
- import path from "path";
3
-
4
- import { ArgumentParser } from "./setup/ArgumentParser";
5
- import { CommandExecutor } from "./setup/CommandExecutor";
6
- import { PackageManager } from "./setup/PackageManager";
7
- import { PluginConfigurator } from "./setup/PluginConfigurator";
8
-
9
- export namespace TypiaSetupWizard {
10
- export interface IArguments {
11
- compiler: "ts-patch" | "ttypescript";
12
- manager: "npm" | "pnpm" | "yarn";
13
- project: string | null;
14
- }
15
-
16
- export async function setup(): Promise<void> {
17
- console.log("----------------------------------------");
18
- console.log(" Typia Setup Wizard");
19
- console.log("----------------------------------------");
20
-
21
- // PREPARE ASSETS
22
- const pack: PackageManager = await PackageManager.mount();
23
- const args: IArguments = await ArgumentParser.parse(pack)(true)(
24
- inquiry,
25
- );
26
-
27
- // INSTALL TYPESCRIPT
28
- pack.install({ dev: true, modulo: "typescript", version: "4.9.5" });
29
- args.project ??= (() => {
30
- CommandExecutor.run("npx tsc --init", false);
31
- return (args.project = "tsconfig.json");
32
- })();
33
- pack.install({ dev: true, modulo: "ts-node" });
34
-
35
- // INSTALL COMPILER
36
- pack.install({ dev: true, modulo: args.compiler });
37
- if (args.compiler === "ts-patch") {
38
- await pack.save((data) => {
39
- data.scripts ??= {};
40
- if (
41
- typeof data.scripts.prepare === "string" &&
42
- data.scripts.prepare.indexOf("ts-patch install") === -1
43
- )
44
- data.scripts.prepare =
45
- "ts-patch install && " + data.scripts.prepare;
46
- else data.scripts.prepare = "ts-patch install";
47
- });
48
- CommandExecutor.run("npm run prepare", false);
49
- }
50
-
51
- // INSTALL AND CONFIGURE TYPIA
52
- pack.install({ dev: false, modulo: "typia" });
53
- await PluginConfigurator.configure(pack, args);
54
- }
55
-
56
- const inquiry: ArgumentParser.Inquiry<IArguments> = async (
57
- pack,
58
- command,
59
- prompt,
60
- action,
61
- ) => {
62
- // PREPARE ASSETS
63
- command.option("--compiler [compiler]", "compiler type");
64
- command.option("--manager [manager", "package manager");
65
- command.option("--project [project]", "tsconfig.json file location");
66
-
67
- // INTERNAL PROCEDURES
68
- const questioned = { value: false };
69
- const select =
70
- (name: string) =>
71
- (message: string) =>
72
- async <Choice extends string>(
73
- choices: Choice[],
74
- ): Promise<Choice> => {
75
- questioned.value = true;
76
- return (
77
- await prompt()({
78
- type: "list",
79
- name: name,
80
- message: message,
81
- choices: choices,
82
- })
83
- )[name];
84
- };
85
- const configure = async () => {
86
- const fileList: string[] = await (
87
- await fs.promises.readdir(process.cwd())
88
- )
89
- .filter(
90
- (str) =>
91
- str.substring(0, 8) === "tsconfig" &&
92
- str.substring(str.length - 5) === ".json",
93
- )
94
- .sort((x, y) =>
95
- x === "tsconfig.json"
96
- ? -1
97
- : y === "tsconfig.json"
98
- ? 1
99
- : x < y
100
- ? -1
101
- : 1,
102
- );
103
- if (fileList.length === 0) {
104
- if (process.cwd() !== pack.directory)
105
- throw new Error(`Unable to find "tsconfig.json" file.`);
106
- return null;
107
- } else if (fileList.length === 1) return fileList[0];
108
- return select("tsconfig")("TS Config File")(fileList);
109
- };
110
-
111
- // DO CONSTRUCT
112
- return action(async (options) => {
113
- if (options.compiler === undefined) {
114
- console.log(COMPILER_DESCRIPTION);
115
- options.compiler = await select("compiler")(`Compiler`)(
116
- is_nest_cli(pack)
117
- ? ["ts-patch" as const, "ttypescript" as const]
118
- : ["ttypescript" as const, "ts-patch" as const],
119
- );
120
- }
121
- options.manager ??= await select("manager")("Package Manager")([
122
- "npm" as const,
123
- "pnpm" as const,
124
- "yarn" as const,
125
- ]);
126
- pack.manager = options.manager;
127
- options.project ??= await configure();
128
-
129
- if (questioned.value) console.log("");
130
- return options as IArguments;
131
- });
132
- };
133
-
134
- function is_nest_cli(pack: PackageManager): boolean {
135
- return (
136
- (typeof pack.data.scripts?.build === "string" &&
137
- pack.data.scripts.build.indexOf("nest build") !== -1) ||
138
- fs.existsSync(path.join(pack.directory, "nest-cli.json"))
139
- );
140
- }
141
- }
142
-
143
- const COMPILER_DESCRIPTION = [
144
- `About compiler, if you adapt "ttypescript", you should use "ttsc" instead.`,
145
- ``,
146
- `Otherwise, you choose "ts-patch", you can use the original "tsc" command.`,
147
- `However, the "ts-patch" hacks "node_modules/typescript" source code.`,
148
- `Also, whenever update "typescript", you've to run "npm run prepare" command.`,
149
- ``,
150
- `By the way, when using "@nest/cli", you must just choose "ts-patch".`,
151
- ``,
152
- ].join("\n");
1
+ import fs from "fs";
2
+ import path from "path";
3
+
4
+ import { ArgumentParser } from "./setup/ArgumentParser";
5
+ import { CommandExecutor } from "./setup/CommandExecutor";
6
+ import { PackageManager } from "./setup/PackageManager";
7
+ import { PluginConfigurator } from "./setup/PluginConfigurator";
8
+
9
+ export namespace TypiaSetupWizard {
10
+ export interface IArguments {
11
+ compiler: "ts-patch" | "ttypescript";
12
+ manager: "npm" | "pnpm" | "yarn";
13
+ project: string | null;
14
+ }
15
+
16
+ export async function setup(): Promise<void> {
17
+ console.log("----------------------------------------");
18
+ console.log(" Typia Setup Wizard");
19
+ console.log("----------------------------------------");
20
+
21
+ // PREPARE ASSETS
22
+ const pack: PackageManager = await PackageManager.mount();
23
+ const args: IArguments = await ArgumentParser.parse(pack)(true)(
24
+ inquiry,
25
+ );
26
+
27
+ // INSTALL TYPESCRIPT
28
+ pack.install({ dev: true, modulo: "typescript", version: "4.9.5" });
29
+ args.project ??= (() => {
30
+ CommandExecutor.run("npx tsc --init", false);
31
+ return (args.project = "tsconfig.json");
32
+ })();
33
+ pack.install({ dev: true, modulo: "ts-node" });
34
+
35
+ // INSTALL COMPILER
36
+ pack.install({ dev: true, modulo: args.compiler });
37
+ if (args.compiler === "ts-patch") {
38
+ await pack.save((data) => {
39
+ data.scripts ??= {};
40
+ if (
41
+ typeof data.scripts.prepare === "string" &&
42
+ data.scripts.prepare.indexOf("ts-patch install") === -1
43
+ )
44
+ data.scripts.prepare =
45
+ "ts-patch install && " + data.scripts.prepare;
46
+ else data.scripts.prepare = "ts-patch install";
47
+ });
48
+ CommandExecutor.run("npm run prepare", false);
49
+ }
50
+
51
+ // INSTALL AND CONFIGURE TYPIA
52
+ pack.install({ dev: false, modulo: "typia" });
53
+ await PluginConfigurator.configure(pack, args);
54
+ }
55
+
56
+ const inquiry: ArgumentParser.Inquiry<IArguments> = async (
57
+ pack,
58
+ command,
59
+ prompt,
60
+ action,
61
+ ) => {
62
+ // PREPARE ASSETS
63
+ command.option("--compiler [compiler]", "compiler type");
64
+ command.option("--manager [manager", "package manager");
65
+ command.option("--project [project]", "tsconfig.json file location");
66
+
67
+ // INTERNAL PROCEDURES
68
+ const questioned = { value: false };
69
+ const select =
70
+ (name: string) =>
71
+ (message: string) =>
72
+ async <Choice extends string>(
73
+ choices: Choice[],
74
+ ): Promise<Choice> => {
75
+ questioned.value = true;
76
+ return (
77
+ await prompt()({
78
+ type: "list",
79
+ name: name,
80
+ message: message,
81
+ choices: choices,
82
+ })
83
+ )[name];
84
+ };
85
+ const configure = async () => {
86
+ const fileList: string[] = await (
87
+ await fs.promises.readdir(process.cwd())
88
+ )
89
+ .filter(
90
+ (str) =>
91
+ str.substring(0, 8) === "tsconfig" &&
92
+ str.substring(str.length - 5) === ".json",
93
+ )
94
+ .sort((x, y) =>
95
+ x === "tsconfig.json"
96
+ ? -1
97
+ : y === "tsconfig.json"
98
+ ? 1
99
+ : x < y
100
+ ? -1
101
+ : 1,
102
+ );
103
+ if (fileList.length === 0) {
104
+ if (process.cwd() !== pack.directory)
105
+ throw new Error(`Unable to find "tsconfig.json" file.`);
106
+ return null;
107
+ } else if (fileList.length === 1) return fileList[0];
108
+ return select("tsconfig")("TS Config File")(fileList);
109
+ };
110
+
111
+ // DO CONSTRUCT
112
+ return action(async (options) => {
113
+ if (options.compiler === undefined) {
114
+ console.log(COMPILER_DESCRIPTION);
115
+ options.compiler = await select("compiler")(`Compiler`)(
116
+ is_nest_cli(pack)
117
+ ? ["ts-patch" as const, "ttypescript" as const]
118
+ : ["ttypescript" as const, "ts-patch" as const],
119
+ );
120
+ }
121
+ options.manager ??= await select("manager")("Package Manager")([
122
+ "npm" as const,
123
+ "pnpm" as const,
124
+ "yarn" as const,
125
+ ]);
126
+ pack.manager = options.manager;
127
+ options.project ??= await configure();
128
+
129
+ if (questioned.value) console.log("");
130
+ return options as IArguments;
131
+ });
132
+ };
133
+
134
+ function is_nest_cli(pack: PackageManager): boolean {
135
+ return (
136
+ (typeof pack.data.scripts?.build === "string" &&
137
+ pack.data.scripts.build.indexOf("nest build") !== -1) ||
138
+ fs.existsSync(path.join(pack.directory, "nest-cli.json"))
139
+ );
140
+ }
141
+ }
142
+
143
+ const COMPILER_DESCRIPTION = [
144
+ `About compiler, if you adapt "ttypescript", you should use "ttsc" instead.`,
145
+ ``,
146
+ `Otherwise, you choose "ts-patch", you can use the original "tsc" command.`,
147
+ `However, the "ts-patch" hacks "node_modules/typescript" source code.`,
148
+ `Also, whenever update "typescript", you've to run "npm run prepare" command.`,
149
+ ``,
150
+ `By the way, when using "@nest/cli", you must just choose "ts-patch".`,
151
+ ``,
152
+ ].join("\n");
@@ -1,91 +1,91 @@
1
- import type CommanderModule from "commander";
2
- import type * as InquirerModule from "inquirer";
3
- import path from "path";
4
-
5
- import { FileRetriever } from "./FileRetriever";
6
- import { PackageManager } from "./PackageManager";
7
-
8
- export namespace ArgumentParser {
9
- export type Inquiry<T> = (
10
- pack: PackageManager,
11
- command: CommanderModule.Command,
12
- prompt: (
13
- opt?: InquirerModule.StreamOptions,
14
- ) => InquirerModule.PromptModule,
15
- action: (closure: (options: Partial<T>) => Promise<T>) => Promise<T>,
16
- ) => Promise<T>;
17
-
18
- export const parse =
19
- (pack: PackageManager) =>
20
- (erase: boolean) =>
21
- async <T>(
22
- inquiry: (
23
- pack: PackageManager,
24
- command: CommanderModule.Command,
25
- prompt: (
26
- opt?: InquirerModule.StreamOptions,
27
- ) => InquirerModule.PromptModule,
28
- action: (
29
- closure: (options: Partial<T>) => Promise<T>,
30
- ) => Promise<T>,
31
- ) => Promise<T>,
32
- ): Promise<T> => {
33
- // INSTALL TEMPORARY PACKAGES
34
- const newbie = {
35
- commander: pack.install({
36
- dev: true,
37
- modulo: "commander",
38
- version: "10.0.0",
39
- silent: true,
40
- }),
41
- inquirer: pack.install({
42
- dev: true,
43
- modulo: "inquirer",
44
- version: "8.2.5",
45
- silent: true,
46
- }),
47
- };
48
-
49
- // LOAD INSTALLED MODULES
50
- const { program: command }: typeof CommanderModule =
51
- await FileRetriever.require(
52
- path.join("node_modules", "commander"),
53
- )(pack.directory);
54
- const { createPromptModule: prompt }: typeof InquirerModule =
55
- await FileRetriever.require(
56
- path.join("node_modules", "inquirer"),
57
- )(pack.directory);
58
-
59
- // TAKE OPTIONS
60
- const action = (closure: (options: Partial<T>) => Promise<T>) =>
61
- new Promise<T>((resolve, reject) => {
62
- command.action(async (options) => {
63
- try {
64
- resolve(await closure(options));
65
- } catch (exp) {
66
- reject(exp);
67
- }
68
- });
69
- command.parseAsync().catch(reject);
70
- });
71
- const output: T | Error = await (async () => {
72
- try {
73
- return await inquiry(pack, command, prompt, action);
74
- } catch (error) {
75
- return error as Error;
76
- }
77
- })();
78
-
79
- // REMOVE TEMPORARY PACKAGES
80
- if (erase === true) {
81
- if (newbie.commander)
82
- pack.erase({ modulo: "commander", silent: true });
83
- if (newbie.inquirer)
84
- pack.erase({ modulo: "inquirer", silent: true });
85
- }
86
-
87
- // RETURNS
88
- if (output instanceof Error) throw output;
89
- return output;
90
- };
91
- }
1
+ import type CommanderModule from "commander";
2
+ import type * as InquirerModule from "inquirer";
3
+ import path from "path";
4
+
5
+ import { FileRetriever } from "./FileRetriever";
6
+ import { PackageManager } from "./PackageManager";
7
+
8
+ export namespace ArgumentParser {
9
+ export type Inquiry<T> = (
10
+ pack: PackageManager,
11
+ command: CommanderModule.Command,
12
+ prompt: (
13
+ opt?: InquirerModule.StreamOptions,
14
+ ) => InquirerModule.PromptModule,
15
+ action: (closure: (options: Partial<T>) => Promise<T>) => Promise<T>,
16
+ ) => Promise<T>;
17
+
18
+ export const parse =
19
+ (pack: PackageManager) =>
20
+ (erase: boolean) =>
21
+ async <T>(
22
+ inquiry: (
23
+ pack: PackageManager,
24
+ command: CommanderModule.Command,
25
+ prompt: (
26
+ opt?: InquirerModule.StreamOptions,
27
+ ) => InquirerModule.PromptModule,
28
+ action: (
29
+ closure: (options: Partial<T>) => Promise<T>,
30
+ ) => Promise<T>,
31
+ ) => Promise<T>,
32
+ ): Promise<T> => {
33
+ // INSTALL TEMPORARY PACKAGES
34
+ const newbie = {
35
+ commander: pack.install({
36
+ dev: true,
37
+ modulo: "commander",
38
+ version: "10.0.0",
39
+ silent: true,
40
+ }),
41
+ inquirer: pack.install({
42
+ dev: true,
43
+ modulo: "inquirer",
44
+ version: "8.2.5",
45
+ silent: true,
46
+ }),
47
+ };
48
+
49
+ // LOAD INSTALLED MODULES
50
+ const { program: command }: typeof CommanderModule =
51
+ await FileRetriever.require(
52
+ path.join("node_modules", "commander"),
53
+ )(pack.directory);
54
+ const { createPromptModule: prompt }: typeof InquirerModule =
55
+ await FileRetriever.require(
56
+ path.join("node_modules", "inquirer"),
57
+ )(pack.directory);
58
+
59
+ // TAKE OPTIONS
60
+ const action = (closure: (options: Partial<T>) => Promise<T>) =>
61
+ new Promise<T>((resolve, reject) => {
62
+ command.action(async (options) => {
63
+ try {
64
+ resolve(await closure(options));
65
+ } catch (exp) {
66
+ reject(exp);
67
+ }
68
+ });
69
+ command.parseAsync().catch(reject);
70
+ });
71
+ const output: T | Error = await (async () => {
72
+ try {
73
+ return await inquiry(pack, command, prompt, action);
74
+ } catch (error) {
75
+ return error as Error;
76
+ }
77
+ })();
78
+
79
+ // REMOVE TEMPORARY PACKAGES
80
+ if (erase === true) {
81
+ if (newbie.commander)
82
+ pack.erase({ modulo: "commander", silent: true });
83
+ if (newbie.inquirer)
84
+ pack.erase({ modulo: "inquirer", silent: true });
85
+ }
86
+
87
+ // RETURNS
88
+ if (output instanceof Error) throw output;
89
+ return output;
90
+ };
91
+ }