typia 5.2.2 → 5.2.3

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 (74) hide show
  1. package/lib/Primitive.d.ts +1 -1
  2. package/lib/executable/setup/CommandExecutor.js +2 -2
  3. package/lib/executable/setup/CommandExecutor.js.map +1 -1
  4. package/package.json +1 -2
  5. package/src/CamelCase.ts +116 -116
  6. package/src/PascalCase.ts +116 -116
  7. package/src/Primitive.ts +135 -135
  8. package/src/Resolved.ts +116 -116
  9. package/src/SnakeCase.ts +156 -156
  10. package/src/executable/TypiaSetupWizard.ts +142 -142
  11. package/src/executable/setup/CommandExecutor.ts +2 -2
  12. package/src/factories/JsonMetadataFactory.ts +50 -50
  13. package/src/factories/MetadataCollection.ts +282 -282
  14. package/src/functional/$convention.ts +40 -40
  15. package/src/functional/Namespace.ts +164 -164
  16. package/src/module.ts +662 -662
  17. package/src/notations.ts +855 -855
  18. package/src/programmers/helpers/AtomicPredicator.ts +31 -31
  19. package/src/programmers/helpers/NotationJoiner.ts +146 -146
  20. package/src/programmers/misc/MiscCloneProgrammer.ts +790 -790
  21. package/src/programmers/misc/MiscPruneProgrammer.ts +552 -552
  22. package/src/programmers/notations/NotationAssertGeneralProgrammer.ts +72 -72
  23. package/src/programmers/notations/NotationGeneralProgrammer.ts +720 -720
  24. package/src/programmers/notations/NotationIsGeneralProgrammer.ts +79 -79
  25. package/src/programmers/notations/NotationValidateGeneralProgrammer.ts +88 -88
  26. package/src/transformers/CallExpressionTransformer.ts +380 -380
  27. package/src/transformers/features/json/JsonAssertParseTransformer.ts +10 -10
  28. package/src/transformers/features/json/JsonAssertStringifyTransformer.ts +10 -10
  29. package/src/transformers/features/json/JsonCreateAssertParseTransformer.ts +12 -12
  30. package/src/transformers/features/json/JsonCreateAssertStringifyTransformer.ts +12 -12
  31. package/src/transformers/features/json/JsonCreateIsParseTransformer.ts +9 -9
  32. package/src/transformers/features/json/JsonCreateIsStringifyTransformer.ts +12 -12
  33. package/src/transformers/features/json/JsonCreateStringifyTransformer.ts +9 -9
  34. package/src/transformers/features/json/JsonCreateValidateParseTransformer.ts +12 -12
  35. package/src/transformers/features/json/JsonCreateValidateStringifyProgrammer.ts +12 -12
  36. package/src/transformers/features/json/JsonIsParseTransformer.ts +9 -9
  37. package/src/transformers/features/json/JsonIsStringifyTransformer.ts +10 -10
  38. package/src/transformers/features/json/JsonStringifyTransformer.ts +9 -9
  39. package/src/transformers/features/json/JsonValidateParseTransformer.ts +10 -10
  40. package/src/transformers/features/json/JsonValidateStringifyTransformer.ts +10 -10
  41. package/src/transformers/features/misc/MiscAssertCloneTransformer.ts +10 -10
  42. package/src/transformers/features/misc/MiscAssertPruneTransformer.ts +10 -10
  43. package/src/transformers/features/misc/MiscCloneTransformer.ts +9 -9
  44. package/src/transformers/features/misc/MiscCreateAssertCloneTransformer.ts +12 -12
  45. package/src/transformers/features/misc/MiscCreateAssertPruneTransformer.ts +12 -12
  46. package/src/transformers/features/misc/MiscCreateCloneTransformer.ts +9 -9
  47. package/src/transformers/features/misc/MiscCreateIsCloneTransformer.ts +9 -9
  48. package/src/transformers/features/misc/MiscCreateIsPruneTransformer.ts +9 -9
  49. package/src/transformers/features/misc/MiscCreatePruneTransformer.ts +9 -9
  50. package/src/transformers/features/misc/MiscCreateValidateCloneTransformer.ts +12 -12
  51. package/src/transformers/features/misc/MiscCreateValidatePruneTransformer.ts +12 -12
  52. package/src/transformers/features/misc/MiscIsCloneTransformer.ts +9 -9
  53. package/src/transformers/features/misc/MiscIsPruneTransformer.ts +9 -9
  54. package/src/transformers/features/misc/MiscPruneTransformer.ts +9 -9
  55. package/src/transformers/features/misc/MiscValidateCloneTransformer.ts +10 -10
  56. package/src/transformers/features/misc/MiscValidatePruneTransformer.ts +10 -10
  57. package/src/transformers/features/notations/NotationAssertGeneralTransformer.ts +15 -15
  58. package/src/transformers/features/notations/NotationCreateAssertGeneralTransformer.ts +15 -15
  59. package/src/transformers/features/notations/NotationCreateGeneralTransformer.ts +15 -15
  60. package/src/transformers/features/notations/NotationCreateIsGeneralTransformer.ts +15 -15
  61. package/src/transformers/features/notations/NotationCreateValidateGeneralTransformer.ts +17 -17
  62. package/src/transformers/features/notations/NotationGeneralTransformer.ts +11 -11
  63. package/src/transformers/features/notations/NotationIsGeneralTransformer.ts +15 -15
  64. package/src/transformers/features/notations/NotationValidateGeneralTransformer.ts +17 -17
  65. package/src/transformers/features/protobuf/ProtobufCreateAssertDecodeTransformer.ts +12 -12
  66. package/src/transformers/features/protobuf/ProtobufCreateAssertEncodeTransformer.ts +12 -12
  67. package/src/transformers/features/protobuf/ProtobufCreateDecodeTransformer.ts +9 -9
  68. package/src/transformers/features/protobuf/ProtobufCreateEncodeTransformer.ts +9 -9
  69. package/src/transformers/features/protobuf/ProtobufCreateIsDecodeTransformer.ts +12 -12
  70. package/src/transformers/features/protobuf/ProtobufCreateIsEncodeTransformer.ts +12 -12
  71. package/src/transformers/features/protobuf/ProtobufCreateValidateDecodeTransformer.ts +12 -12
  72. package/src/transformers/features/protobuf/ProtobufCreateValidateEncodeTransformer.ts +12 -12
  73. package/src/utils/NamingConvention.ts +91 -91
  74. package/src/utils/StringUtil.ts +4 -4
package/src/SnakeCase.ts CHANGED
@@ -1,156 +1,156 @@
1
- /**
2
- * Snake case type.
3
- *
4
- * `SnakeCase` type is a type that all keys of an object are converted to snake case.
5
- *
6
- * It also erase every method properties like {@link Resolved} type.
7
- *
8
- * @template T Target type to be snake cased
9
- * @author Jeongho Nam - https://github.com/samchon
10
- */
11
- export type SnakeCase<T> = Equal<T, SnakageMain<T>> extends true
12
- ? T
13
- : SnakageMain<T>;
14
-
15
- /* -----------------------------------------------------------
16
- OBJECT CONVERSION
17
- ----------------------------------------------------------- */
18
- type Equal<X, Y> = X extends Y ? (Y extends X ? true : false) : false;
19
-
20
- type SnakageMain<T> = T extends [never]
21
- ? never // special trick for (jsonable | null) type
22
- : T extends { valueOf(): boolean | bigint | number | string }
23
- ? ValueOf<T>
24
- : T extends Function
25
- ? never
26
- : T extends object
27
- ? SnakageObject<T>
28
- : T;
29
-
30
- type SnakageObject<T extends object> = T extends Array<infer U>
31
- ? IsTuple<T> extends true
32
- ? SnakageTuple<T>
33
- : SnakageMain<U>[]
34
- : T extends Set<infer U>
35
- ? Set<SnakageMain<U>>
36
- : T extends Map<infer K, infer V>
37
- ? Map<SnakageMain<K>, SnakageMain<V>>
38
- : T extends WeakSet<any> | WeakMap<any, any>
39
- ? never
40
- : T extends
41
- | Date
42
- | Uint8Array
43
- | Uint8ClampedArray
44
- | Uint16Array
45
- | Uint32Array
46
- | BigUint64Array
47
- | Int8Array
48
- | Int16Array
49
- | Int32Array
50
- | BigInt64Array
51
- | Float32Array
52
- | Float64Array
53
- | ArrayBuffer
54
- | SharedArrayBuffer
55
- | DataView
56
- ? T
57
- : {
58
- [Key in keyof T as SnakageString<Key & string>]: SnakageMain<T[Key]>;
59
- };
60
-
61
- /* -----------------------------------------------------------
62
- SPECIAL CASES
63
- ----------------------------------------------------------- */
64
- type IsTuple<T extends readonly any[] | { length: number }> = [T] extends [
65
- never,
66
- ]
67
- ? false
68
- : T extends readonly any[]
69
- ? number extends T["length"]
70
- ? false
71
- : true
72
- : false;
73
- type SnakageTuple<T extends readonly any[]> = T extends []
74
- ? []
75
- : T extends [infer F]
76
- ? [SnakageMain<F>]
77
- : T extends [infer F, ...infer Rest extends readonly any[]]
78
- ? [SnakageMain<F>, ...SnakageTuple<Rest>]
79
- : T extends [(infer F)?]
80
- ? [SnakageMain<F>?]
81
- : T extends [(infer F)?, ...infer Rest extends readonly any[]]
82
- ? [SnakageMain<F>?, ...SnakageTuple<Rest>]
83
- : [];
84
-
85
- type ValueOf<Instance> = IsValueOf<Instance, Boolean> extends true
86
- ? boolean
87
- : IsValueOf<Instance, Number> extends true
88
- ? number
89
- : IsValueOf<Instance, String> extends true
90
- ? string
91
- : Instance;
92
-
93
- type IsValueOf<Instance, Object extends IValueOf<any>> = Instance extends Object
94
- ? Object extends IValueOf<infer Primitive>
95
- ? Instance extends Primitive
96
- ? false
97
- : true // not Primitive, but Object
98
- : false // cannot be
99
- : false;
100
-
101
- interface IValueOf<T> {
102
- valueOf(): T;
103
- }
104
-
105
- /* -----------------------------------------------------------
106
- STRING CONVERTER
107
- ----------------------------------------------------------- */
108
- type SnakageString<Key extends string> = Key extends `${infer _}`
109
- ? SnakageStringRepeatedly<Key, "">
110
- : Key;
111
- type SnakageStringRepeatedly<
112
- S extends string,
113
- Previous extends string,
114
- > = S extends `${infer First}${infer Second}${infer Rest}`
115
- ? `${Underscore<Previous, First>}${Lowercase<First>}${Underscore<
116
- First,
117
- Second
118
- >}${Lowercase<Second>}${SnakageStringRepeatedly<Rest, Second>}`
119
- : S extends `${infer First}`
120
- ? `${Underscore<Previous, First>}${Lowercase<First>}`
121
- : "";
122
- type Underscore<First extends string, Second extends string> = First extends
123
- | UpperAlphabetic
124
- | ""
125
- | "_"
126
- ? ""
127
- : Second extends UpperAlphabetic
128
- ? "_"
129
- : "";
130
- type UpperAlphabetic =
131
- | "A"
132
- | "B"
133
- | "C"
134
- | "D"
135
- | "E"
136
- | "F"
137
- | "G"
138
- | "H"
139
- | "I"
140
- | "J"
141
- | "K"
142
- | "L"
143
- | "M"
144
- | "N"
145
- | "O"
146
- | "P"
147
- | "Q"
148
- | "R"
149
- | "S"
150
- | "T"
151
- | "U"
152
- | "V"
153
- | "W"
154
- | "X"
155
- | "Y"
156
- | "Z";
1
+ /**
2
+ * Snake case type.
3
+ *
4
+ * `SnakeCase` type is a type that all keys of an object are converted to snake case.
5
+ *
6
+ * It also erase every method properties like {@link Resolved} type.
7
+ *
8
+ * @template T Target type to be snake cased
9
+ * @author Jeongho Nam - https://github.com/samchon
10
+ */
11
+ export type SnakeCase<T> = Equal<T, SnakageMain<T>> extends true
12
+ ? T
13
+ : SnakageMain<T>;
14
+
15
+ /* -----------------------------------------------------------
16
+ OBJECT CONVERSION
17
+ ----------------------------------------------------------- */
18
+ type Equal<X, Y> = X extends Y ? (Y extends X ? true : false) : false;
19
+
20
+ type SnakageMain<T> = T extends [never]
21
+ ? never // special trick for (jsonable | null) type
22
+ : T extends { valueOf(): boolean | bigint | number | string }
23
+ ? ValueOf<T>
24
+ : T extends Function
25
+ ? never
26
+ : T extends object
27
+ ? SnakageObject<T>
28
+ : T;
29
+
30
+ type SnakageObject<T extends object> = T extends Array<infer U>
31
+ ? IsTuple<T> extends true
32
+ ? SnakageTuple<T>
33
+ : SnakageMain<U>[]
34
+ : T extends Set<infer U>
35
+ ? Set<SnakageMain<U>>
36
+ : T extends Map<infer K, infer V>
37
+ ? Map<SnakageMain<K>, SnakageMain<V>>
38
+ : T extends WeakSet<any> | WeakMap<any, any>
39
+ ? never
40
+ : T extends
41
+ | Date
42
+ | Uint8Array
43
+ | Uint8ClampedArray
44
+ | Uint16Array
45
+ | Uint32Array
46
+ | BigUint64Array
47
+ | Int8Array
48
+ | Int16Array
49
+ | Int32Array
50
+ | BigInt64Array
51
+ | Float32Array
52
+ | Float64Array
53
+ | ArrayBuffer
54
+ | SharedArrayBuffer
55
+ | DataView
56
+ ? T
57
+ : {
58
+ [Key in keyof T as SnakageString<Key & string>]: SnakageMain<T[Key]>;
59
+ };
60
+
61
+ /* -----------------------------------------------------------
62
+ SPECIAL CASES
63
+ ----------------------------------------------------------- */
64
+ type IsTuple<T extends readonly any[] | { length: number }> = [T] extends [
65
+ never,
66
+ ]
67
+ ? false
68
+ : T extends readonly any[]
69
+ ? number extends T["length"]
70
+ ? false
71
+ : true
72
+ : false;
73
+ type SnakageTuple<T extends readonly any[]> = T extends []
74
+ ? []
75
+ : T extends [infer F]
76
+ ? [SnakageMain<F>]
77
+ : T extends [infer F, ...infer Rest extends readonly any[]]
78
+ ? [SnakageMain<F>, ...SnakageTuple<Rest>]
79
+ : T extends [(infer F)?]
80
+ ? [SnakageMain<F>?]
81
+ : T extends [(infer F)?, ...infer Rest extends readonly any[]]
82
+ ? [SnakageMain<F>?, ...SnakageTuple<Rest>]
83
+ : [];
84
+
85
+ type ValueOf<Instance> = IsValueOf<Instance, Boolean> extends true
86
+ ? boolean
87
+ : IsValueOf<Instance, Number> extends true
88
+ ? number
89
+ : IsValueOf<Instance, String> extends true
90
+ ? string
91
+ : Instance;
92
+
93
+ type IsValueOf<Instance, Object extends IValueOf<any>> = Instance extends Object
94
+ ? Object extends IValueOf<infer Primitive>
95
+ ? Instance extends Primitive
96
+ ? false
97
+ : true // not Primitive, but Object
98
+ : false // cannot be
99
+ : false;
100
+
101
+ interface IValueOf<T> {
102
+ valueOf(): T;
103
+ }
104
+
105
+ /* -----------------------------------------------------------
106
+ STRING CONVERTER
107
+ ----------------------------------------------------------- */
108
+ type SnakageString<Key extends string> = Key extends `${infer _}`
109
+ ? SnakageStringRepeatedly<Key, "">
110
+ : Key;
111
+ type SnakageStringRepeatedly<
112
+ S extends string,
113
+ Previous extends string,
114
+ > = S extends `${infer First}${infer Second}${infer Rest}`
115
+ ? `${Underscore<Previous, First>}${Lowercase<First>}${Underscore<
116
+ First,
117
+ Second
118
+ >}${Lowercase<Second>}${SnakageStringRepeatedly<Rest, Second>}`
119
+ : S extends `${infer First}`
120
+ ? `${Underscore<Previous, First>}${Lowercase<First>}`
121
+ : "";
122
+ type Underscore<First extends string, Second extends string> = First extends
123
+ | UpperAlphabetic
124
+ | ""
125
+ | "_"
126
+ ? ""
127
+ : Second extends UpperAlphabetic
128
+ ? "_"
129
+ : "";
130
+ type UpperAlphabetic =
131
+ | "A"
132
+ | "B"
133
+ | "C"
134
+ | "D"
135
+ | "E"
136
+ | "F"
137
+ | "G"
138
+ | "H"
139
+ | "I"
140
+ | "J"
141
+ | "K"
142
+ | "L"
143
+ | "M"
144
+ | "N"
145
+ | "O"
146
+ | "P"
147
+ | "Q"
148
+ | "R"
149
+ | "S"
150
+ | "T"
151
+ | "U"
152
+ | "V"
153
+ | "W"
154
+ | "X"
155
+ | "Y"
156
+ | "Z";
@@ -1,142 +1,142 @@
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({ dev: true, modulo: "typescript", version: "latest" });
27
- args.project ??= (() => {
28
- const runner: string =
29
- pack.manager === "npm" ? "npx" : pack.manager;
30
- CommandExecutor.run(`${runner} tsc --init`);
31
- return (args.project = "tsconfig.json");
32
- })();
33
-
34
- // SETUP TRANSFORMER
35
- await pack.save((data) => {
36
- // COMPOSE PREPARE COMMAND
37
- data.scripts ??= {};
38
- if (
39
- typeof data.scripts.prepare === "string" &&
40
- data.scripts.prepare.trim().length
41
- ) {
42
- if (data.scripts.prepare.indexOf("ts-patch install") === -1)
43
- data.scripts.prepare =
44
- "ts-patch install && " + data.scripts.prepare;
45
- } else data.scripts.prepare = "ts-patch install";
46
-
47
- // FOR OLDER VERSIONS
48
- if (typeof data.scripts.postinstall === "string") {
49
- data.scripts.postinstall = data.scripts.postinstall
50
- .split("&&")
51
- .map((str) => str.trim())
52
- .filter((str) => str.indexOf("ts-patch install") === -1)
53
- .join(" && ");
54
- if (data.scripts.postinstall.length === 0)
55
- delete data.scripts.postinstall;
56
- }
57
- });
58
- CommandExecutor.run(`${pack.manager} run prepare`);
59
-
60
- // CONFIGURE TYPIA
61
- await PluginConfigurator.configure(args);
62
- }
63
-
64
- const inquiry: ArgumentParser.Inquiry<IArguments> = async (
65
- pack,
66
- command,
67
- prompt,
68
- action,
69
- ) => {
70
- // PREPARE ASSETS
71
- command.option("--manager [manager", "package manager");
72
- command.option("--project [project]", "tsconfig.json file location");
73
-
74
- // INTERNAL PROCEDURES
75
- const questioned = { value: false };
76
- const select =
77
- (name: string) =>
78
- (message: string) =>
79
- async <Choice extends string>(
80
- choices: Choice[],
81
- filter?: (choice: string) => 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
- ...(filter
91
- ? {
92
- filter,
93
- }
94
- : {}),
95
- })
96
- )[name];
97
- };
98
- const configure = async (): Promise<string | null> => {
99
- const fileList: string[] = await (
100
- await fs.promises.readdir(process.cwd())
101
- )
102
- .filter(
103
- (str) =>
104
- str.substring(0, 8) === "tsconfig" &&
105
- str.substring(str.length - 5) === ".json",
106
- )
107
- .sort((x, y) =>
108
- x === "tsconfig.json"
109
- ? -1
110
- : y === "tsconfig.json"
111
- ? 1
112
- : x < y
113
- ? -1
114
- : 1,
115
- );
116
- if (fileList.length === 0) {
117
- if (process.cwd() !== pack.directory)
118
- throw new URIError(`Unable to find "tsconfig.json" file.`);
119
- return null;
120
- } else if (fileList.length === 1) return fileList[0]!;
121
- return select("tsconfig")("TS Config File")(fileList);
122
- };
123
-
124
- // DO CONSTRUCT
125
- return action(async (options) => {
126
- pack.manager = options.manager ??= await select("manager")(
127
- "Package Manager",
128
- )(
129
- [
130
- "npm" as const,
131
- "pnpm" as const,
132
- "yarn (berry is not supported)" as "yarn",
133
- ],
134
- (value) => value.split(" ")[0] as "yarn",
135
- );
136
- options.project ??= await configure();
137
-
138
- if (questioned.value) console.log("");
139
- return options as IArguments;
140
- });
141
- };
142
- }
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({ dev: true, modulo: "typescript", version: "latest" });
27
+ args.project ??= (() => {
28
+ const runner: string =
29
+ pack.manager === "npm" ? "npx" : pack.manager;
30
+ CommandExecutor.run(`${runner} tsc --init`);
31
+ return (args.project = "tsconfig.json");
32
+ })();
33
+
34
+ // SETUP TRANSFORMER
35
+ await pack.save((data) => {
36
+ // COMPOSE PREPARE COMMAND
37
+ data.scripts ??= {};
38
+ if (
39
+ typeof data.scripts.prepare === "string" &&
40
+ data.scripts.prepare.trim().length
41
+ ) {
42
+ if (data.scripts.prepare.indexOf("ts-patch install") === -1)
43
+ data.scripts.prepare =
44
+ "ts-patch install && " + data.scripts.prepare;
45
+ } else data.scripts.prepare = "ts-patch install";
46
+
47
+ // FOR OLDER VERSIONS
48
+ if (typeof data.scripts.postinstall === "string") {
49
+ data.scripts.postinstall = data.scripts.postinstall
50
+ .split("&&")
51
+ .map((str) => str.trim())
52
+ .filter((str) => str.indexOf("ts-patch install") === -1)
53
+ .join(" && ");
54
+ if (data.scripts.postinstall.length === 0)
55
+ delete data.scripts.postinstall;
56
+ }
57
+ });
58
+ CommandExecutor.run(`${pack.manager} run prepare`);
59
+
60
+ // CONFIGURE TYPIA
61
+ await PluginConfigurator.configure(args);
62
+ }
63
+
64
+ const inquiry: ArgumentParser.Inquiry<IArguments> = async (
65
+ pack,
66
+ command,
67
+ prompt,
68
+ action,
69
+ ) => {
70
+ // PREPARE ASSETS
71
+ command.option("--manager [manager", "package manager");
72
+ command.option("--project [project]", "tsconfig.json file location");
73
+
74
+ // INTERNAL PROCEDURES
75
+ const questioned = { value: false };
76
+ const select =
77
+ (name: string) =>
78
+ (message: string) =>
79
+ async <Choice extends string>(
80
+ choices: Choice[],
81
+ filter?: (choice: string) => 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
+ ...(filter
91
+ ? {
92
+ filter,
93
+ }
94
+ : {}),
95
+ })
96
+ )[name];
97
+ };
98
+ const configure = async (): Promise<string | null> => {
99
+ const fileList: string[] = await (
100
+ await fs.promises.readdir(process.cwd())
101
+ )
102
+ .filter(
103
+ (str) =>
104
+ str.substring(0, 8) === "tsconfig" &&
105
+ str.substring(str.length - 5) === ".json",
106
+ )
107
+ .sort((x, y) =>
108
+ x === "tsconfig.json"
109
+ ? -1
110
+ : y === "tsconfig.json"
111
+ ? 1
112
+ : x < y
113
+ ? -1
114
+ : 1,
115
+ );
116
+ if (fileList.length === 0) {
117
+ if (process.cwd() !== pack.directory)
118
+ throw new URIError(`Unable to find "tsconfig.json" file.`);
119
+ return null;
120
+ } else if (fileList.length === 1) return fileList[0]!;
121
+ return select("tsconfig")("TS Config File")(fileList);
122
+ };
123
+
124
+ // DO CONSTRUCT
125
+ return action(async (options) => {
126
+ pack.manager = options.manager ??= await select("manager")(
127
+ "Package Manager",
128
+ )(
129
+ [
130
+ "npm" as const,
131
+ "pnpm" as const,
132
+ "yarn (berry is not supported)" as "yarn",
133
+ ],
134
+ (value) => value.split(" ")[0] as "yarn",
135
+ );
136
+ options.project ??= await configure();
137
+
138
+ if (questioned.value) console.log("");
139
+ return options as IArguments;
140
+ });
141
+ };
142
+ }
@@ -2,7 +2,7 @@ import cp from "child_process";
2
2
 
3
3
  export namespace CommandExecutor {
4
4
  export const run = (str: string): void => {
5
- console.log(str);
6
- cp.execSync(str, { stdio: "ignore" });
5
+ console.log(`\n$ ${str}`);
6
+ cp.execSync(str, { stdio: "inherit" });
7
7
  };
8
8
  }