typia 3.8.3 → 3.8.4-dev.20230502

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 (157) hide show
  1. package/lib/functional/$dictionary.js +3 -2
  2. package/lib/functional/$dictionary.js.map +1 -1
  3. package/package.json +1 -1
  4. package/src/Primitive.ts +123 -123
  5. package/src/executable/TypiaGenerateWizard.ts +85 -85
  6. package/src/executable/TypiaSetupWizard.ts +133 -133
  7. package/src/executable/setup/CommandExecutor.ts +8 -8
  8. package/src/executable/setup/PackageManager.ts +71 -71
  9. package/src/executable/setup/PluginConfigurator.ts +70 -70
  10. package/src/executable/typia.ts +52 -52
  11. package/src/factories/CommentFactory.ts +14 -14
  12. package/src/factories/ExpressionFactory.ts +70 -70
  13. package/src/factories/IdentifierFactory.ts +63 -63
  14. package/src/factories/LiteralFactory.ts +39 -39
  15. package/src/factories/MetadataCollection.ts +121 -121
  16. package/src/factories/MetadataFactory.ts +62 -62
  17. package/src/factories/MetadataTagFactory.ts +297 -297
  18. package/src/factories/StatementFactory.ts +24 -24
  19. package/src/factories/TemplateFactory.ts +58 -58
  20. package/src/factories/TypeFactory.ts +124 -124
  21. package/src/factories/internal/metadata/MetadataHelper.ts +12 -12
  22. package/src/factories/internal/metadata/emplace_metadata_object.ts +143 -143
  23. package/src/factories/internal/metadata/iterate_metadata.ts +67 -67
  24. package/src/factories/internal/metadata/iterate_metadata_map.ts +41 -41
  25. package/src/factories/internal/metadata/iterate_metadata_native.ts +219 -219
  26. package/src/factories/internal/metadata/iterate_metadata_resolve.ts +27 -27
  27. package/src/factories/internal/metadata/iterate_metadata_set.ts +33 -33
  28. package/src/factories/internal/metadata/iterate_metadata_tuple.ts +48 -48
  29. package/src/factories/internal/metadata/iterate_metadata_union.ts +57 -57
  30. package/src/functional/$any.ts +2 -2
  31. package/src/functional/$dictionary.ts +25 -20
  32. package/src/functional/$is_between.ts +2 -2
  33. package/src/functional/$is_custom.ts +14 -14
  34. package/src/functional/$is_date.ts +3 -3
  35. package/src/functional/$is_datetime.ts +2 -2
  36. package/src/functional/$is_email.ts +4 -4
  37. package/src/functional/$is_ipv4.ts +4 -4
  38. package/src/functional/$is_ipv6.ts +4 -4
  39. package/src/functional/$is_url.ts +4 -4
  40. package/src/functional/$is_uuid.ts +4 -4
  41. package/src/functional/$join.ts +46 -46
  42. package/src/functional/$number.ts +12 -12
  43. package/src/functional/$rest.ts +3 -3
  44. package/src/functional/$string.ts +37 -37
  45. package/src/functional/$tail.ts +5 -5
  46. package/src/metadata/IMetadata.ts +26 -26
  47. package/src/metadata/Metadata.ts +539 -539
  48. package/src/metadata/MetadataConstant.ts +3 -3
  49. package/src/metadata/MetadataObject.ts +127 -127
  50. package/src/module.ts +2043 -2043
  51. package/src/programmers/ApplicationProgrammer.ts +62 -62
  52. package/src/programmers/AssertCloneProgrammer.ts +79 -79
  53. package/src/programmers/AssertParseProgrammer.ts +74 -74
  54. package/src/programmers/AssertProgrammer.ts +285 -285
  55. package/src/programmers/AssertPruneProgrammer.ts +76 -76
  56. package/src/programmers/AssertStringifyProgrammer.ts +74 -74
  57. package/src/programmers/CheckerProgrammer.ts +901 -901
  58. package/src/programmers/CloneProgrammer.ts +389 -389
  59. package/src/programmers/FeatureProgrammer.ts +500 -500
  60. package/src/programmers/IsCloneProgrammer.ts +86 -86
  61. package/src/programmers/IsParseProgrammer.ts +80 -80
  62. package/src/programmers/IsProgrammer.ts +212 -212
  63. package/src/programmers/IsPruneProgrammer.ts +81 -81
  64. package/src/programmers/IsStringifyProgrammer.ts +84 -84
  65. package/src/programmers/LiteralsProgrammer.ts +65 -65
  66. package/src/programmers/PruneProgrammer.ts +347 -347
  67. package/src/programmers/RandomProgrammer.ts +423 -423
  68. package/src/programmers/StringifyProgrammer.ts +798 -798
  69. package/src/programmers/TypiaProgrammer.ts +129 -129
  70. package/src/programmers/ValidateCloneProgrammer.ts +93 -93
  71. package/src/programmers/ValidateParseProgrammer.ts +78 -78
  72. package/src/programmers/ValidateProgrammer.ts +316 -316
  73. package/src/programmers/ValidatePruneProgrammer.ts +86 -86
  74. package/src/programmers/ValidateStringifyProgrammer.ts +92 -92
  75. package/src/programmers/helpers/CloneJoiner.ts +131 -131
  76. package/src/programmers/helpers/FunctionImporeter.ts +54 -54
  77. package/src/programmers/helpers/OptionPredicator.ts +15 -15
  78. package/src/programmers/helpers/PruneJoiner.ts +144 -144
  79. package/src/programmers/helpers/StringifyJoinder.ts +113 -113
  80. package/src/programmers/helpers/StringifyPredicator.ts +12 -12
  81. package/src/programmers/helpers/UnionExplorer.ts +275 -275
  82. package/src/programmers/helpers/UnionPredicator.ts +81 -81
  83. package/src/programmers/internal/application_array.ts +36 -36
  84. package/src/programmers/internal/application_boolean.ts +17 -17
  85. package/src/programmers/internal/application_constant.ts +30 -30
  86. package/src/programmers/internal/application_default_string.ts +33 -33
  87. package/src/programmers/internal/application_native.ts +32 -32
  88. package/src/programmers/internal/application_number.ts +73 -73
  89. package/src/programmers/internal/application_object.ts +155 -155
  90. package/src/programmers/internal/application_schema.ts +213 -213
  91. package/src/programmers/internal/application_string.ts +45 -45
  92. package/src/programmers/internal/application_templates.ts +26 -26
  93. package/src/programmers/internal/application_tuple.ts +31 -31
  94. package/src/programmers/internal/check_array.ts +30 -30
  95. package/src/programmers/internal/check_custom.ts +31 -31
  96. package/src/programmers/internal/check_dynamic_properties.ts +194 -194
  97. package/src/programmers/internal/check_everything.ts +28 -28
  98. package/src/programmers/internal/check_native.ts +21 -21
  99. package/src/programmers/internal/check_string_tags.ts +67 -67
  100. package/src/programmers/internal/check_union_array_like.ts +271 -271
  101. package/src/programmers/internal/check_union_tuple.ts +33 -33
  102. package/src/programmers/internal/random_custom.ts +29 -29
  103. package/src/programmers/internal/stringify_dynamic_properties.ts +167 -167
  104. package/src/programmers/internal/stringify_native.ts +7 -7
  105. package/src/programmers/internal/stringify_regular_properties.ts +83 -83
  106. package/src/schemas/IJsonSchema.ts +130 -130
  107. package/src/transform.ts +17 -17
  108. package/src/transformers/CallExpressionTransformer.ts +177 -177
  109. package/src/transformers/FileTransformer.ts +47 -47
  110. package/src/transformers/NodeTransformer.ts +13 -13
  111. package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +114 -114
  112. package/src/transformers/features/miscellaneous/AssertCloneTransformer.ts +9 -9
  113. package/src/transformers/features/miscellaneous/AssertPruneTransformer.ts +9 -9
  114. package/src/transformers/features/miscellaneous/CloneTransformer.ts +9 -9
  115. package/src/transformers/features/miscellaneous/CreateAssertCloneTransformer.ts +9 -9
  116. package/src/transformers/features/miscellaneous/CreateAssertPruneTransformer.ts +9 -9
  117. package/src/transformers/features/miscellaneous/CreateCloneTransformer.ts +9 -9
  118. package/src/transformers/features/miscellaneous/CreateIsCloneTransformer.ts +9 -9
  119. package/src/transformers/features/miscellaneous/CreateIsPruneTransformer.ts +9 -9
  120. package/src/transformers/features/miscellaneous/CreatePruneTransformer.ts +9 -9
  121. package/src/transformers/features/miscellaneous/CreateRandomTransformer.ts +39 -39
  122. package/src/transformers/features/miscellaneous/CreateValidateCloneTransformer.ts +9 -9
  123. package/src/transformers/features/miscellaneous/CreateValidatePruneTransformer.ts +9 -9
  124. package/src/transformers/features/miscellaneous/IsCloneTransformer.ts +9 -9
  125. package/src/transformers/features/miscellaneous/IsPruneTransformer.ts +9 -9
  126. package/src/transformers/features/miscellaneous/LiteralsTransformer.ts +28 -28
  127. package/src/transformers/features/miscellaneous/MetadataTransformer.ts +52 -52
  128. package/src/transformers/features/miscellaneous/PruneTransformer.ts +9 -9
  129. package/src/transformers/features/miscellaneous/RandomTransformer.ts +42 -42
  130. package/src/transformers/features/miscellaneous/ValidateCloneTransformer.ts +9 -9
  131. package/src/transformers/features/miscellaneous/ValidatePruneTransformer.ts +9 -9
  132. package/src/transformers/features/parsers/AssertParseTransformer.ts +9 -9
  133. package/src/transformers/features/parsers/CreateAssertParseTransformer.ts +9 -9
  134. package/src/transformers/features/parsers/CreateIsParseTransformer.ts +9 -9
  135. package/src/transformers/features/parsers/CreateValidateParseTransformer.ts +9 -9
  136. package/src/transformers/features/parsers/IsParseTransformer.ts +9 -9
  137. package/src/transformers/features/parsers/ValidateParseTransformer.ts +9 -9
  138. package/src/transformers/features/stringifiers/AssertStringifyTransformer.ts +10 -10
  139. package/src/transformers/features/stringifiers/CreateAssertStringifyTransformer.ts +12 -12
  140. package/src/transformers/features/stringifiers/CreateIsStringifyTransformer.ts +9 -9
  141. package/src/transformers/features/stringifiers/CreateStringifyTransformer.ts +9 -9
  142. package/src/transformers/features/stringifiers/CreateValidateStringifyProgrammer.ts +12 -12
  143. package/src/transformers/features/stringifiers/IsStringifyTransformer.ts +9 -9
  144. package/src/transformers/features/stringifiers/StringifyTransformer.ts +9 -9
  145. package/src/transformers/features/stringifiers/ValidateStringifyTransformer.ts +10 -10
  146. package/src/transformers/features/validators/AssertTransformer.ts +11 -11
  147. package/src/transformers/features/validators/CreateAssertTransformer.ts +13 -13
  148. package/src/transformers/features/validators/CreateIsTransformer.ts +11 -11
  149. package/src/transformers/features/validators/CreateValidateTransformer.ts +13 -13
  150. package/src/transformers/features/validators/IsTransformer.ts +11 -11
  151. package/src/transformers/features/validators/ValidateTransformer.ts +11 -11
  152. package/src/transformers/internal/GenericTransformer.ts +97 -97
  153. package/src/utils/ArrayUtil.ts +44 -44
  154. package/src/utils/Escaper.ts +45 -45
  155. package/src/utils/MapUtil.ts +12 -12
  156. package/src/utils/PatternUtil.ts +30 -30
  157. package/src/utils/RandomGenerator.ts +81 -81
@@ -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
+ }
@@ -1,70 +1,70 @@
1
- import comments from "comment-json";
2
- import fs from "fs";
3
-
4
- import { TypiaSetupWizard } from "../TypiaSetupWizard";
5
-
6
- export namespace PluginConfigurator {
7
- export async function configure(
8
- args: TypiaSetupWizard.IArguments,
9
- ): Promise<void> {
10
- // GET COMPILER-OPTIONS
11
- const config: comments.CommentObject = comments.parse(
12
- await fs.promises.readFile(args.project!, "utf8"),
13
- ) as comments.CommentObject;
14
- const compilerOptions = config.compilerOptions as
15
- | comments.CommentObject
16
- | undefined;
17
- if (compilerOptions === undefined)
18
- throw new Error(
19
- `${args.project} file does not have "compilerOptions" property.`,
20
- );
21
-
22
- // PREPARE PLUGINS
23
- const plugins: comments.CommentArray<comments.CommentObject> = (() => {
24
- const plugins = compilerOptions.plugins as
25
- | comments.CommentArray<comments.CommentObject>
26
- | undefined;
27
- if (plugins === undefined)
28
- return (compilerOptions.plugins = [] as any);
29
- else if (!Array.isArray(plugins))
30
- throw new Error(
31
- `"plugins" property of ${args.project} must be array type.`,
32
- );
33
- return plugins;
34
- })();
35
-
36
- const strict: boolean | undefined = compilerOptions.strict as
37
- | boolean
38
- | undefined;
39
- const strictNullChecks: boolean | undefined =
40
- compilerOptions.strictNullChecks as boolean | undefined;
41
- const oldbie: comments.CommentObject | undefined = plugins.find(
42
- (p) =>
43
- typeof p === "object" &&
44
- p !== null &&
45
- p.transform === "typia/lib/transform",
46
- );
47
- if (
48
- strictNullChecks !== false &&
49
- (strict === true || strictNullChecks === true) &&
50
- oldbie !== undefined
51
- )
52
- return;
53
-
54
- // DO CONFIGURE
55
- compilerOptions.strictNullChecks = true;
56
- if (strict === undefined && strictNullChecks === undefined)
57
- compilerOptions.strict = true;
58
- if (oldbie === undefined)
59
- plugins.push(
60
- comments.parse(`
61
- {
62
- "transform": "typia/lib/transform"
63
- }`) as comments.CommentObject,
64
- );
65
- await fs.promises.writeFile(
66
- args.project!,
67
- comments.stringify(config, null, 2),
68
- );
69
- }
70
- }
1
+ import comments from "comment-json";
2
+ import fs from "fs";
3
+
4
+ import { TypiaSetupWizard } from "../TypiaSetupWizard";
5
+
6
+ export namespace PluginConfigurator {
7
+ export async function configure(
8
+ args: TypiaSetupWizard.IArguments,
9
+ ): Promise<void> {
10
+ // GET COMPILER-OPTIONS
11
+ const config: comments.CommentObject = comments.parse(
12
+ await fs.promises.readFile(args.project!, "utf8"),
13
+ ) as comments.CommentObject;
14
+ const compilerOptions = config.compilerOptions as
15
+ | comments.CommentObject
16
+ | undefined;
17
+ if (compilerOptions === undefined)
18
+ throw new Error(
19
+ `${args.project} file does not have "compilerOptions" property.`,
20
+ );
21
+
22
+ // PREPARE PLUGINS
23
+ const plugins: comments.CommentArray<comments.CommentObject> = (() => {
24
+ const plugins = compilerOptions.plugins as
25
+ | comments.CommentArray<comments.CommentObject>
26
+ | undefined;
27
+ if (plugins === undefined)
28
+ return (compilerOptions.plugins = [] as any);
29
+ else if (!Array.isArray(plugins))
30
+ throw new Error(
31
+ `"plugins" property of ${args.project} must be array type.`,
32
+ );
33
+ return plugins;
34
+ })();
35
+
36
+ const strict: boolean | undefined = compilerOptions.strict as
37
+ | boolean
38
+ | undefined;
39
+ const strictNullChecks: boolean | undefined =
40
+ compilerOptions.strictNullChecks as boolean | undefined;
41
+ const oldbie: comments.CommentObject | undefined = plugins.find(
42
+ (p) =>
43
+ typeof p === "object" &&
44
+ p !== null &&
45
+ p.transform === "typia/lib/transform",
46
+ );
47
+ if (
48
+ strictNullChecks !== false &&
49
+ (strict === true || strictNullChecks === true) &&
50
+ oldbie !== undefined
51
+ )
52
+ return;
53
+
54
+ // DO CONFIGURE
55
+ compilerOptions.strictNullChecks = true;
56
+ if (strict === undefined && strictNullChecks === undefined)
57
+ compilerOptions.strict = true;
58
+ if (oldbie === undefined)
59
+ plugins.push(
60
+ comments.parse(`
61
+ {
62
+ "transform": "typia/lib/transform"
63
+ }`) as comments.CommentObject,
64
+ );
65
+ await fs.promises.writeFile(
66
+ args.project!,
67
+ comments.stringify(config, null, 2),
68
+ );
69
+ }
70
+ }