typia 3.8.4-dev.20230502 → 3.8.5-dev.20230510

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 (170) hide show
  1. package/lib/factories/MetadataTagFactory.js +5 -5
  2. package/lib/factories/MetadataTagFactory.js.map +1 -1
  3. package/lib/factories/internal/metadata/emplace_metadata_object.js +17 -15
  4. package/lib/factories/internal/metadata/emplace_metadata_object.js.map +1 -1
  5. package/lib/programmers/AssertProgrammer.js +1 -1
  6. package/lib/programmers/AssertProgrammer.js.map +1 -1
  7. package/lib/programmers/IsProgrammer.d.ts +1 -1
  8. package/lib/programmers/IsProgrammer.js +5 -2
  9. package/lib/programmers/IsProgrammer.js.map +1 -1
  10. package/lib/programmers/ValidateProgrammer.js +1 -1
  11. package/lib/programmers/ValidateProgrammer.js.map +1 -1
  12. package/lib/programmers/helpers/disable_function_importer_declare.d.ts +2 -0
  13. package/lib/programmers/helpers/disable_function_importer_declare.js +15 -0
  14. package/lib/programmers/helpers/disable_function_importer_declare.js.map +1 -0
  15. package/package.json +1 -1
  16. package/src/Primitive.ts +123 -123
  17. package/src/executable/TypiaGenerateWizard.ts +85 -85
  18. package/src/executable/TypiaSetupWizard.ts +133 -133
  19. package/src/executable/setup/CommandExecutor.ts +8 -8
  20. package/src/executable/setup/PackageManager.ts +71 -71
  21. package/src/executable/setup/PluginConfigurator.ts +70 -70
  22. package/src/executable/typia.ts +52 -52
  23. package/src/factories/CommentFactory.ts +14 -14
  24. package/src/factories/ExpressionFactory.ts +70 -70
  25. package/src/factories/IdentifierFactory.ts +63 -63
  26. package/src/factories/LiteralFactory.ts +39 -39
  27. package/src/factories/MetadataCollection.ts +121 -121
  28. package/src/factories/MetadataFactory.ts +62 -62
  29. package/src/factories/MetadataTagFactory.ts +295 -297
  30. package/src/factories/StatementFactory.ts +24 -24
  31. package/src/factories/TemplateFactory.ts +58 -58
  32. package/src/factories/TypeFactory.ts +124 -124
  33. package/src/factories/internal/metadata/MetadataHelper.ts +12 -12
  34. package/src/factories/internal/metadata/emplace_metadata_object.ts +143 -143
  35. package/src/factories/internal/metadata/iterate_metadata.ts +67 -67
  36. package/src/factories/internal/metadata/iterate_metadata_map.ts +41 -41
  37. package/src/factories/internal/metadata/iterate_metadata_native.ts +219 -219
  38. package/src/factories/internal/metadata/iterate_metadata_resolve.ts +27 -27
  39. package/src/factories/internal/metadata/iterate_metadata_set.ts +33 -33
  40. package/src/factories/internal/metadata/iterate_metadata_tuple.ts +48 -48
  41. package/src/factories/internal/metadata/iterate_metadata_union.ts +57 -57
  42. package/src/functional/$any.ts +2 -2
  43. package/src/functional/$dictionary.ts +25 -25
  44. package/src/functional/$is_between.ts +2 -2
  45. package/src/functional/$is_custom.ts +14 -14
  46. package/src/functional/$is_date.ts +3 -3
  47. package/src/functional/$is_datetime.ts +2 -2
  48. package/src/functional/$is_email.ts +4 -4
  49. package/src/functional/$is_ipv4.ts +4 -4
  50. package/src/functional/$is_ipv6.ts +4 -4
  51. package/src/functional/$is_url.ts +4 -4
  52. package/src/functional/$is_uuid.ts +4 -4
  53. package/src/functional/$join.ts +46 -46
  54. package/src/functional/$number.ts +12 -12
  55. package/src/functional/$rest.ts +3 -3
  56. package/src/functional/$string.ts +37 -37
  57. package/src/functional/$tail.ts +5 -5
  58. package/src/metadata/IMetadata.ts +26 -26
  59. package/src/metadata/Metadata.ts +539 -539
  60. package/src/metadata/MetadataConstant.ts +3 -3
  61. package/src/metadata/MetadataObject.ts +127 -127
  62. package/src/module.ts +2043 -2043
  63. package/src/programmers/ApplicationProgrammer.ts +62 -62
  64. package/src/programmers/AssertCloneProgrammer.ts +79 -79
  65. package/src/programmers/AssertParseProgrammer.ts +74 -74
  66. package/src/programmers/AssertProgrammer.ts +285 -285
  67. package/src/programmers/AssertPruneProgrammer.ts +76 -76
  68. package/src/programmers/AssertStringifyProgrammer.ts +74 -74
  69. package/src/programmers/CheckerProgrammer.ts +901 -901
  70. package/src/programmers/CloneProgrammer.ts +389 -389
  71. package/src/programmers/FeatureProgrammer.ts +500 -500
  72. package/src/programmers/IsCloneProgrammer.ts +86 -86
  73. package/src/programmers/IsParseProgrammer.ts +80 -80
  74. package/src/programmers/IsProgrammer.ts +216 -212
  75. package/src/programmers/IsPruneProgrammer.ts +81 -81
  76. package/src/programmers/IsStringifyProgrammer.ts +84 -84
  77. package/src/programmers/LiteralsProgrammer.ts +65 -65
  78. package/src/programmers/PruneProgrammer.ts +347 -347
  79. package/src/programmers/RandomProgrammer.ts +423 -423
  80. package/src/programmers/StringifyProgrammer.ts +798 -798
  81. package/src/programmers/TypiaProgrammer.ts +129 -129
  82. package/src/programmers/ValidateCloneProgrammer.ts +93 -93
  83. package/src/programmers/ValidateParseProgrammer.ts +78 -78
  84. package/src/programmers/ValidateProgrammer.ts +316 -316
  85. package/src/programmers/ValidatePruneProgrammer.ts +86 -86
  86. package/src/programmers/ValidateStringifyProgrammer.ts +92 -92
  87. package/src/programmers/helpers/CloneJoiner.ts +131 -131
  88. package/src/programmers/helpers/FunctionImporeter.ts +54 -54
  89. package/src/programmers/helpers/OptionPredicator.ts +15 -15
  90. package/src/programmers/helpers/PruneJoiner.ts +144 -144
  91. package/src/programmers/helpers/StringifyJoinder.ts +113 -113
  92. package/src/programmers/helpers/StringifyPredicator.ts +12 -12
  93. package/src/programmers/helpers/UnionExplorer.ts +275 -275
  94. package/src/programmers/helpers/UnionPredicator.ts +81 -81
  95. package/src/programmers/helpers/disable_function_importer_declare.ts +21 -0
  96. package/src/programmers/internal/application_array.ts +36 -36
  97. package/src/programmers/internal/application_boolean.ts +17 -17
  98. package/src/programmers/internal/application_constant.ts +30 -30
  99. package/src/programmers/internal/application_default_string.ts +33 -33
  100. package/src/programmers/internal/application_native.ts +32 -32
  101. package/src/programmers/internal/application_number.ts +73 -73
  102. package/src/programmers/internal/application_object.ts +155 -155
  103. package/src/programmers/internal/application_schema.ts +213 -213
  104. package/src/programmers/internal/application_string.ts +45 -45
  105. package/src/programmers/internal/application_templates.ts +26 -26
  106. package/src/programmers/internal/application_tuple.ts +31 -31
  107. package/src/programmers/internal/check_array.ts +30 -30
  108. package/src/programmers/internal/check_custom.ts +31 -31
  109. package/src/programmers/internal/check_dynamic_properties.ts +194 -194
  110. package/src/programmers/internal/check_everything.ts +28 -28
  111. package/src/programmers/internal/check_native.ts +21 -21
  112. package/src/programmers/internal/check_string_tags.ts +67 -67
  113. package/src/programmers/internal/check_union_array_like.ts +271 -271
  114. package/src/programmers/internal/check_union_tuple.ts +33 -33
  115. package/src/programmers/internal/random_custom.ts +29 -29
  116. package/src/programmers/internal/stringify_dynamic_properties.ts +167 -167
  117. package/src/programmers/internal/stringify_native.ts +7 -7
  118. package/src/programmers/internal/stringify_regular_properties.ts +83 -83
  119. package/src/schemas/IJsonSchema.ts +130 -130
  120. package/src/transform.ts +17 -17
  121. package/src/transformers/CallExpressionTransformer.ts +177 -177
  122. package/src/transformers/FileTransformer.ts +47 -47
  123. package/src/transformers/NodeTransformer.ts +13 -13
  124. package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +114 -114
  125. package/src/transformers/features/miscellaneous/AssertCloneTransformer.ts +9 -9
  126. package/src/transformers/features/miscellaneous/AssertPruneTransformer.ts +9 -9
  127. package/src/transformers/features/miscellaneous/CloneTransformer.ts +9 -9
  128. package/src/transformers/features/miscellaneous/CreateAssertCloneTransformer.ts +9 -9
  129. package/src/transformers/features/miscellaneous/CreateAssertPruneTransformer.ts +9 -9
  130. package/src/transformers/features/miscellaneous/CreateCloneTransformer.ts +9 -9
  131. package/src/transformers/features/miscellaneous/CreateIsCloneTransformer.ts +9 -9
  132. package/src/transformers/features/miscellaneous/CreateIsPruneTransformer.ts +9 -9
  133. package/src/transformers/features/miscellaneous/CreatePruneTransformer.ts +9 -9
  134. package/src/transformers/features/miscellaneous/CreateRandomTransformer.ts +39 -39
  135. package/src/transformers/features/miscellaneous/CreateValidateCloneTransformer.ts +9 -9
  136. package/src/transformers/features/miscellaneous/CreateValidatePruneTransformer.ts +9 -9
  137. package/src/transformers/features/miscellaneous/IsCloneTransformer.ts +9 -9
  138. package/src/transformers/features/miscellaneous/IsPruneTransformer.ts +9 -9
  139. package/src/transformers/features/miscellaneous/LiteralsTransformer.ts +28 -28
  140. package/src/transformers/features/miscellaneous/MetadataTransformer.ts +52 -52
  141. package/src/transformers/features/miscellaneous/PruneTransformer.ts +9 -9
  142. package/src/transformers/features/miscellaneous/RandomTransformer.ts +42 -42
  143. package/src/transformers/features/miscellaneous/ValidateCloneTransformer.ts +9 -9
  144. package/src/transformers/features/miscellaneous/ValidatePruneTransformer.ts +9 -9
  145. package/src/transformers/features/parsers/AssertParseTransformer.ts +9 -9
  146. package/src/transformers/features/parsers/CreateAssertParseTransformer.ts +9 -9
  147. package/src/transformers/features/parsers/CreateIsParseTransformer.ts +9 -9
  148. package/src/transformers/features/parsers/CreateValidateParseTransformer.ts +9 -9
  149. package/src/transformers/features/parsers/IsParseTransformer.ts +9 -9
  150. package/src/transformers/features/parsers/ValidateParseTransformer.ts +9 -9
  151. package/src/transformers/features/stringifiers/AssertStringifyTransformer.ts +10 -10
  152. package/src/transformers/features/stringifiers/CreateAssertStringifyTransformer.ts +12 -12
  153. package/src/transformers/features/stringifiers/CreateIsStringifyTransformer.ts +9 -9
  154. package/src/transformers/features/stringifiers/CreateStringifyTransformer.ts +9 -9
  155. package/src/transformers/features/stringifiers/CreateValidateStringifyProgrammer.ts +12 -12
  156. package/src/transformers/features/stringifiers/IsStringifyTransformer.ts +9 -9
  157. package/src/transformers/features/stringifiers/StringifyTransformer.ts +9 -9
  158. package/src/transformers/features/stringifiers/ValidateStringifyTransformer.ts +10 -10
  159. package/src/transformers/features/validators/AssertTransformer.ts +11 -11
  160. package/src/transformers/features/validators/CreateAssertTransformer.ts +13 -13
  161. package/src/transformers/features/validators/CreateIsTransformer.ts +11 -11
  162. package/src/transformers/features/validators/CreateValidateTransformer.ts +13 -13
  163. package/src/transformers/features/validators/IsTransformer.ts +11 -11
  164. package/src/transformers/features/validators/ValidateTransformer.ts +11 -11
  165. package/src/transformers/internal/GenericTransformer.ts +97 -97
  166. package/src/utils/ArrayUtil.ts +44 -44
  167. package/src/utils/Escaper.ts +45 -45
  168. package/src/utils/MapUtil.ts +12 -12
  169. package/src/utils/PatternUtil.ts +30 -30
  170. package/src/utils/RandomGenerator.ts +81 -81
@@ -1,85 +1,85 @@
1
- import fs from "fs";
2
-
3
- import { TypiaProgrammer } from "../programmers/TypiaProgrammer";
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)(inquiry);
17
- await TypiaProgrammer.build(options);
18
- }
19
-
20
- const inquiry: ArgumentParser.Inquiry<IArguments> = async (
21
- _pack,
22
- command,
23
- prompt,
24
- action,
25
- ) => {
26
- // PREPARE ASSETS
27
- command.option("--input [path]", "input directory");
28
- command.option("--output [directory]", "output directory");
29
- command.option("--project [project]", "tsconfig.json file location");
30
-
31
- const questioned = { value: false };
32
-
33
- const input = (name: string) => async (message: string) => {
34
- const result = await prompt()({
35
- type: "input",
36
- name,
37
- message,
38
- default: "",
39
- });
40
- return result[name] as string;
41
- };
42
- const select =
43
- (name: string) =>
44
- (message: string) =>
45
- async <Choice extends string>(
46
- choices: Choice[],
47
- ): Promise<Choice> => {
48
- questioned.value = true;
49
- return (
50
- await prompt()({
51
- type: "list",
52
- name: name,
53
- message: message,
54
- choices: choices,
55
- })
56
- )[name];
57
- };
58
- const configure = async () => {
59
- const files: string[] = await (
60
- await fs.promises.readdir(process.cwd())
61
- ).filter(
62
- (str) =>
63
- str.substring(0, 8) === "tsconfig" &&
64
- str.substring(str.length - 5) === ".json",
65
- );
66
- if (files.length === 0)
67
- throw new Error(`Unable to find "tsconfig.json" file.`);
68
- else if (files.length === 1) return files[0];
69
- return select("tsconfig")("TS Config File")(files);
70
- };
71
-
72
- return action(async (options) => {
73
- options.input ??= await input("input")("input directory");
74
- options.output ??= await input("output")("output directory");
75
- options.project ??= await configure();
76
- return options as IArguments;
77
- });
78
- };
79
-
80
- export interface IArguments {
81
- input: string;
82
- output: string;
83
- project: string;
84
- }
85
- }
1
+ import fs from "fs";
2
+
3
+ import { TypiaProgrammer } from "../programmers/TypiaProgrammer";
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)(inquiry);
17
+ await TypiaProgrammer.build(options);
18
+ }
19
+
20
+ const inquiry: ArgumentParser.Inquiry<IArguments> = async (
21
+ _pack,
22
+ command,
23
+ prompt,
24
+ action,
25
+ ) => {
26
+ // PREPARE ASSETS
27
+ command.option("--input [path]", "input directory");
28
+ command.option("--output [directory]", "output directory");
29
+ command.option("--project [project]", "tsconfig.json file location");
30
+
31
+ const questioned = { value: false };
32
+
33
+ const input = (name: string) => async (message: string) => {
34
+ const result = await prompt()({
35
+ type: "input",
36
+ name,
37
+ message,
38
+ default: "",
39
+ });
40
+ return result[name] as string;
41
+ };
42
+ const select =
43
+ (name: string) =>
44
+ (message: string) =>
45
+ async <Choice extends string>(
46
+ choices: Choice[],
47
+ ): Promise<Choice> => {
48
+ questioned.value = true;
49
+ return (
50
+ await prompt()({
51
+ type: "list",
52
+ name: name,
53
+ message: message,
54
+ choices: choices,
55
+ })
56
+ )[name];
57
+ };
58
+ const configure = async () => {
59
+ const files: string[] = await (
60
+ await fs.promises.readdir(process.cwd())
61
+ ).filter(
62
+ (str) =>
63
+ str.substring(0, 8) === "tsconfig" &&
64
+ str.substring(str.length - 5) === ".json",
65
+ );
66
+ if (files.length === 0)
67
+ throw new Error(`Unable to find "tsconfig.json" file.`);
68
+ else if (files.length === 1) return files[0];
69
+ return select("tsconfig")("TS Config File")(files);
70
+ };
71
+
72
+ return action(async (options) => {
73
+ options.input ??= await input("input")("input directory");
74
+ options.output ??= await input("output")("output directory");
75
+ options.project ??= await configure();
76
+ return options as IArguments;
77
+ });
78
+ };
79
+
80
+ export interface IArguments {
81
+ input: string;
82
+ output: string;
83
+ project: string;
84
+ }
85
+ }
@@ -1,133 +1,133 @@
1
- import fs from "fs";
2
-
3
- import { ArgumentParser } from "./setup/ArgumentParser";
4
- import { CommandExecutor } from "./setup/CommandExecutor";
5
- import { PackageManager } from "./setup/PackageManager";
6
- import { PluginConfigurator } from "./setup/PluginConfigurator";
7
-
8
- export namespace TypiaSetupWizard {
9
- export interface IArguments {
10
- manager: "npm" | "pnpm" | "yarn";
11
- project: string | null;
12
- }
13
-
14
- export async function setup(): Promise<void> {
15
- console.log("----------------------------------------");
16
- console.log(" Typia Setup Wizard");
17
- console.log("----------------------------------------");
18
-
19
- // PREPARE ASSETS
20
- const pack: PackageManager = await PackageManager.mount();
21
- const args: IArguments = await ArgumentParser.parse(pack)(inquiry);
22
-
23
- // INSTALL TYPESCRIPT COMPILERS
24
- pack.install({ dev: true, modulo: "ts-patch", version: "latest" });
25
- pack.install({ dev: true, modulo: "ts-node", version: "latest" });
26
- pack.install({
27
- dev: true,
28
- modulo: "typescript",
29
- version: (() => {
30
- const version: string = (() => {
31
- try {
32
- return require("ts-patch/package.json")?.version ?? "";
33
- } catch {
34
- return "";
35
- }
36
- })();
37
- return Number(version.split(".")[0] ?? "") >= 3
38
- ? "latest"
39
- : "4.9.5";
40
- })(),
41
- });
42
- args.project ??= (() => {
43
- CommandExecutor.run("npx tsc --init");
44
- return (args.project = "tsconfig.json");
45
- })();
46
-
47
- // SETUP TRANSFORMER
48
- await pack.save((data) => {
49
- data.scripts ??= {};
50
- if (
51
- typeof data.scripts.prepare === "string" &&
52
- data.scripts.prepare.length
53
- ) {
54
- if (data.scripts.prepare.indexOf("ts-patch install") === -1)
55
- data.scripts.prepare =
56
- "ts-patch install && " + data.scripts.prepare;
57
- } else data.scripts.prepare = "ts-patch install";
58
- });
59
- CommandExecutor.run("npm run prepare");
60
-
61
- // CONFIGURE TYPIA
62
- await PluginConfigurator.configure(args);
63
- }
64
-
65
- const inquiry: ArgumentParser.Inquiry<IArguments> = async (
66
- pack,
67
- command,
68
- prompt,
69
- action,
70
- ) => {
71
- // PREPARE ASSETS
72
- command.option("--manager [manager", "package manager");
73
- command.option("--project [project]", "tsconfig.json file location");
74
-
75
- // INTERNAL PROCEDURES
76
- const questioned = { value: false };
77
- const select =
78
- (name: string) =>
79
- (message: string) =>
80
- async <Choice extends string>(
81
- choices: Choice[],
82
- ): Promise<Choice> => {
83
- questioned.value = true;
84
- return (
85
- await prompt()({
86
- type: "list",
87
- name: name,
88
- message: message,
89
- choices: choices,
90
- })
91
- )[name];
92
- };
93
- const configure = async () => {
94
- const fileList: string[] = await (
95
- await fs.promises.readdir(process.cwd())
96
- )
97
- .filter(
98
- (str) =>
99
- str.substring(0, 8) === "tsconfig" &&
100
- str.substring(str.length - 5) === ".json",
101
- )
102
- .sort((x, y) =>
103
- x === "tsconfig.json"
104
- ? -1
105
- : y === "tsconfig.json"
106
- ? 1
107
- : x < y
108
- ? -1
109
- : 1,
110
- );
111
- if (fileList.length === 0) {
112
- if (process.cwd() !== pack.directory)
113
- throw new Error(`Unable to find "tsconfig.json" file.`);
114
- return null;
115
- } else if (fileList.length === 1) return fileList[0];
116
- return select("tsconfig")("TS Config File")(fileList);
117
- };
118
-
119
- // DO CONSTRUCT
120
- return action(async (options) => {
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
- }
1
+ import fs from "fs";
2
+
3
+ import { ArgumentParser } from "./setup/ArgumentParser";
4
+ import { CommandExecutor } from "./setup/CommandExecutor";
5
+ import { PackageManager } from "./setup/PackageManager";
6
+ import { PluginConfigurator } from "./setup/PluginConfigurator";
7
+
8
+ export namespace TypiaSetupWizard {
9
+ export interface IArguments {
10
+ manager: "npm" | "pnpm" | "yarn";
11
+ project: string | null;
12
+ }
13
+
14
+ export async function setup(): Promise<void> {
15
+ console.log("----------------------------------------");
16
+ console.log(" Typia Setup Wizard");
17
+ console.log("----------------------------------------");
18
+
19
+ // PREPARE ASSETS
20
+ const pack: PackageManager = await PackageManager.mount();
21
+ const args: IArguments = await ArgumentParser.parse(pack)(inquiry);
22
+
23
+ // INSTALL TYPESCRIPT COMPILERS
24
+ pack.install({ dev: true, modulo: "ts-patch", version: "latest" });
25
+ pack.install({ dev: true, modulo: "ts-node", version: "latest" });
26
+ pack.install({
27
+ dev: true,
28
+ modulo: "typescript",
29
+ version: (() => {
30
+ const version: string = (() => {
31
+ try {
32
+ return require("ts-patch/package.json")?.version ?? "";
33
+ } catch {
34
+ return "";
35
+ }
36
+ })();
37
+ return Number(version.split(".")[0] ?? "") >= 3
38
+ ? "latest"
39
+ : "4.9.5";
40
+ })(),
41
+ });
42
+ args.project ??= (() => {
43
+ CommandExecutor.run("npx tsc --init");
44
+ return (args.project = "tsconfig.json");
45
+ })();
46
+
47
+ // SETUP TRANSFORMER
48
+ await pack.save((data) => {
49
+ data.scripts ??= {};
50
+ if (
51
+ typeof data.scripts.prepare === "string" &&
52
+ data.scripts.prepare.length
53
+ ) {
54
+ if (data.scripts.prepare.indexOf("ts-patch install") === -1)
55
+ data.scripts.prepare =
56
+ "ts-patch install && " + data.scripts.prepare;
57
+ } else data.scripts.prepare = "ts-patch install";
58
+ });
59
+ CommandExecutor.run("npm run prepare");
60
+
61
+ // CONFIGURE TYPIA
62
+ await PluginConfigurator.configure(args);
63
+ }
64
+
65
+ const inquiry: ArgumentParser.Inquiry<IArguments> = async (
66
+ pack,
67
+ command,
68
+ prompt,
69
+ action,
70
+ ) => {
71
+ // PREPARE ASSETS
72
+ command.option("--manager [manager", "package manager");
73
+ command.option("--project [project]", "tsconfig.json file location");
74
+
75
+ // INTERNAL PROCEDURES
76
+ const questioned = { value: false };
77
+ const select =
78
+ (name: string) =>
79
+ (message: string) =>
80
+ async <Choice extends string>(
81
+ choices: Choice[],
82
+ ): Promise<Choice> => {
83
+ questioned.value = true;
84
+ return (
85
+ await prompt()({
86
+ type: "list",
87
+ name: name,
88
+ message: message,
89
+ choices: choices,
90
+ })
91
+ )[name];
92
+ };
93
+ const configure = async () => {
94
+ const fileList: string[] = await (
95
+ await fs.promises.readdir(process.cwd())
96
+ )
97
+ .filter(
98
+ (str) =>
99
+ str.substring(0, 8) === "tsconfig" &&
100
+ str.substring(str.length - 5) === ".json",
101
+ )
102
+ .sort((x, y) =>
103
+ x === "tsconfig.json"
104
+ ? -1
105
+ : y === "tsconfig.json"
106
+ ? 1
107
+ : x < y
108
+ ? -1
109
+ : 1,
110
+ );
111
+ if (fileList.length === 0) {
112
+ if (process.cwd() !== pack.directory)
113
+ throw new Error(`Unable to find "tsconfig.json" file.`);
114
+ return null;
115
+ } else if (fileList.length === 1) return fileList[0];
116
+ return select("tsconfig")("TS Config File")(fileList);
117
+ };
118
+
119
+ // DO CONSTRUCT
120
+ return action(async (options) => {
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
+ }
@@ -1,8 +1,8 @@
1
- import cp from "child_process";
2
-
3
- export namespace CommandExecutor {
4
- export const run = (str: string): void => {
5
- console.log(str);
6
- cp.execSync(str, { stdio: "ignore" });
7
- };
8
- }
1
+ import cp from "child_process";
2
+
3
+ export namespace CommandExecutor {
4
+ export const run = (str: string): void => {
5
+ console.log(str);
6
+ cp.execSync(str, { stdio: "ignore" });
7
+ };
8
+ }
@@ -1,71 +1,71 @@
1
- import fs from "fs";
2
- import path from "path";
3
-
4
- import { CommandExecutor } from "./CommandExecutor";
5
- import { FileRetriever } from "./FileRetriever";
6
-
7
- export class PackageManager {
8
- public manager: string = "npm";
9
- public get file(): string {
10
- return path.join(this.directory, "package.json");
11
- }
12
-
13
- public static async mount(): Promise<PackageManager> {
14
- const location: string | null = await FileRetriever.directory(
15
- "package.json",
16
- )(process.cwd());
17
- if (location === null)
18
- throw new Error(`Unable to find "package.json" file`);
19
-
20
- return new PackageManager(
21
- location,
22
- await this.load(path.join(location, "package.json")),
23
- );
24
- }
25
-
26
- public async save(modifier: (data: Package.Data) => void): Promise<void> {
27
- const content: string = await fs.promises.readFile(this.file, "utf8");
28
- this.data = JSON.parse(content);
29
- modifier(this.data);
30
-
31
- return fs.promises.writeFile(
32
- this.file,
33
- JSON.stringify(this.data, null, 2),
34
- "utf8",
35
- );
36
- }
37
-
38
- public install(props: {
39
- dev: boolean;
40
- modulo: string;
41
- version: string;
42
- }): boolean {
43
- const middle: string =
44
- this.manager === "yarn"
45
- ? `add${props.dev ? " -D" : ""}`
46
- : `install ${props.dev ? "--save-dev" : "--save"}`;
47
- CommandExecutor.run(
48
- `${this.manager} ${middle} ${props.modulo}${
49
- props.version ? `@${props.version}` : ""
50
- }`,
51
- );
52
- return true;
53
- }
54
-
55
- private constructor(
56
- public readonly directory: string,
57
- public data: Package.Data,
58
- ) {}
59
-
60
- private static async load(file: string): Promise<Package.Data> {
61
- const content: string = await fs.promises.readFile(file, "utf8");
62
- return JSON.parse(content);
63
- }
64
- }
65
- export namespace Package {
66
- export interface Data {
67
- scripts?: Record<string, string>;
68
- dependencies?: Record<string, string>;
69
- devDependencies?: Record<string, string>;
70
- }
71
- }
1
+ import fs from "fs";
2
+ import path from "path";
3
+
4
+ import { CommandExecutor } from "./CommandExecutor";
5
+ import { FileRetriever } from "./FileRetriever";
6
+
7
+ export class PackageManager {
8
+ public manager: string = "npm";
9
+ public get file(): string {
10
+ return path.join(this.directory, "package.json");
11
+ }
12
+
13
+ public static async mount(): Promise<PackageManager> {
14
+ const location: string | null = await FileRetriever.directory(
15
+ "package.json",
16
+ )(process.cwd());
17
+ if (location === null)
18
+ throw new Error(`Unable to find "package.json" file`);
19
+
20
+ return new PackageManager(
21
+ location,
22
+ await this.load(path.join(location, "package.json")),
23
+ );
24
+ }
25
+
26
+ public async save(modifier: (data: Package.Data) => void): Promise<void> {
27
+ const content: string = await fs.promises.readFile(this.file, "utf8");
28
+ this.data = JSON.parse(content);
29
+ modifier(this.data);
30
+
31
+ return fs.promises.writeFile(
32
+ this.file,
33
+ JSON.stringify(this.data, null, 2),
34
+ "utf8",
35
+ );
36
+ }
37
+
38
+ public install(props: {
39
+ dev: boolean;
40
+ modulo: string;
41
+ version: string;
42
+ }): boolean {
43
+ const middle: string =
44
+ this.manager === "yarn"
45
+ ? `add${props.dev ? " -D" : ""}`
46
+ : `install ${props.dev ? "--save-dev" : "--save"}`;
47
+ CommandExecutor.run(
48
+ `${this.manager} ${middle} ${props.modulo}${
49
+ props.version ? `@${props.version}` : ""
50
+ }`,
51
+ );
52
+ return true;
53
+ }
54
+
55
+ private constructor(
56
+ public readonly directory: string,
57
+ public data: Package.Data,
58
+ ) {}
59
+
60
+ private static async load(file: string): Promise<Package.Data> {
61
+ const content: string = await fs.promises.readFile(file, "utf8");
62
+ return JSON.parse(content);
63
+ }
64
+ }
65
+ export namespace Package {
66
+ export interface Data {
67
+ scripts?: Record<string, string>;
68
+ dependencies?: Record<string, string>;
69
+ devDependencies?: Record<string, string>;
70
+ }
71
+ }