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.
- package/lib/factories/TypiaFileFactory.js +61 -54
- package/lib/factories/TypiaFileFactory.js.map +1 -1
- package/package.json +10 -8
- package/src/IRandomGenerator.ts +17 -17
- package/src/IValidation.ts +21 -21
- package/src/Primitive.ts +104 -104
- package/src/TypeGuardError.ts +36 -36
- package/src/executable/TypiaGenerateWizard.ts +87 -87
- package/src/executable/TypiaSetupWizard.ts +152 -152
- package/src/executable/setup/ArgumentParser.ts +91 -91
- package/src/executable/setup/CommandExecutor.ts +8 -8
- package/src/executable/setup/FileRetriever.ts +33 -33
- package/src/executable/setup/PackageManager.ts +92 -92
- package/src/executable/setup/PluginConfigurator.ts +99 -99
- package/src/executable/typia.ts +38 -38
- package/src/factories/CommentFactory.ts +10 -10
- package/src/factories/ExpressionFactory.ts +77 -77
- package/src/factories/IdentifierFactory.ts +73 -73
- package/src/factories/LiteralFactory.ts +44 -44
- package/src/factories/MetadataCollection.ts +122 -122
- package/src/factories/MetadataFactory.ts +51 -51
- package/src/factories/MetadataTagFactory.ts +276 -276
- package/src/factories/StatementFactory.ts +60 -60
- package/src/factories/TemplateFactory.ts +56 -56
- package/src/factories/TypeFactory.ts +129 -129
- package/src/factories/TypiaFileFactory.ts +120 -117
- package/src/factories/ValueFactory.ts +12 -12
- package/src/factories/internal/metadata/MetadataHelper.ts +12 -12
- package/src/factories/internal/metadata/emplace_metadata_object.ts +142 -142
- package/src/factories/internal/metadata/explore_metadata.ts +92 -92
- package/src/factories/internal/metadata/iterate_metadata.ts +80 -80
- package/src/factories/internal/metadata/iterate_metadata_array.ts +29 -29
- package/src/factories/internal/metadata/iterate_metadata_atomic.ts +59 -59
- package/src/factories/internal/metadata/iterate_metadata_coalesce.ts +33 -33
- package/src/factories/internal/metadata/iterate_metadata_constant.ts +58 -58
- package/src/factories/internal/metadata/iterate_metadata_map.ts +41 -41
- package/src/factories/internal/metadata/iterate_metadata_native.ts +222 -222
- package/src/factories/internal/metadata/iterate_metadata_object.ts +48 -48
- package/src/factories/internal/metadata/iterate_metadata_resolve.ts +27 -27
- package/src/factories/internal/metadata/iterate_metadata_set.ts +33 -33
- package/src/factories/internal/metadata/iterate_metadata_template.ts +38 -38
- package/src/factories/internal/metadata/iterate_metadata_tuple.ts +45 -45
- package/src/factories/internal/metadata/iterate_metadata_union.ts +59 -59
- package/src/functional/$any.ts +3 -3
- package/src/functional/$every.ts +11 -11
- package/src/functional/$guard.ts +35 -35
- package/src/functional/$is_between.ts +7 -7
- package/src/functional/$is_date.ts +4 -4
- package/src/functional/$is_datetime.ts +3 -3
- package/src/functional/$is_email.ts +5 -5
- package/src/functional/$is_ipv4.ts +5 -5
- package/src/functional/$is_ipv6.ts +5 -5
- package/src/functional/$is_url.ts +5 -5
- package/src/functional/$is_uuid.ts +5 -5
- package/src/functional/$join.ts +50 -50
- package/src/functional/$number.ts +12 -12
- package/src/functional/$report.ts +15 -15
- package/src/functional/$rest.ts +3 -3
- package/src/functional/$string.ts +37 -37
- package/src/functional/$tail.ts +6 -6
- package/src/functional/Namespace.ts +125 -125
- package/src/index.ts +4 -4
- package/src/metadata/IJsDocTagInfo.ts +10 -10
- package/src/metadata/IMetadata.ts +25 -25
- package/src/metadata/IMetadataApplication.ts +7 -7
- package/src/metadata/IMetadataConstant.ts +16 -16
- package/src/metadata/IMetadataEntry.ts +6 -6
- package/src/metadata/IMetadataObject.ts +29 -29
- package/src/metadata/IMetadataProperty.ts +11 -11
- package/src/metadata/IMetadataTag.ts +105 -105
- package/src/metadata/Metadata.ts +534 -534
- package/src/metadata/MetadataConstant.ts +3 -3
- package/src/metadata/MetadataObject.ts +131 -131
- package/src/metadata/MetadataProperty.ts +64 -64
- package/src/module.ts +1946 -1946
- package/src/programmers/ApplicationProgrammer.ts +55 -55
- package/src/programmers/AssertCloneProgrammer.ts +70 -70
- package/src/programmers/AssertParseProgrammer.ts +65 -65
- package/src/programmers/AssertProgrammer.ts +232 -232
- package/src/programmers/AssertPruneProgrammer.ts +67 -67
- package/src/programmers/AssertStringifyProgrammer.ts +71 -71
- package/src/programmers/CheckerProgrammer.ts +893 -893
- package/src/programmers/CloneProgrammer.ts +386 -386
- package/src/programmers/FeatureProgrammer.ts +505 -505
- package/src/programmers/IsCloneProgrammer.ts +80 -80
- package/src/programmers/IsParseProgrammer.ts +74 -74
- package/src/programmers/IsProgrammer.ts +200 -200
- package/src/programmers/IsPruneProgrammer.ts +75 -75
- package/src/programmers/IsStringifyProgrammer.ts +81 -81
- package/src/programmers/PruneProgrammer.ts +341 -341
- package/src/programmers/RandomProgrammer.ts +388 -388
- package/src/programmers/StringifyProgrammer.ts +795 -795
- package/src/programmers/ValidateCloneProgrammer.ts +90 -90
- package/src/programmers/ValidateParseProgrammer.ts +69 -69
- package/src/programmers/ValidateProgrammer.ts +266 -266
- package/src/programmers/ValidatePruneProgrammer.ts +83 -83
- package/src/programmers/ValidateStringifyProgrammer.ts +89 -89
- package/src/programmers/helpers/AtomicPredicator.ts +31 -31
- package/src/programmers/helpers/CloneJoiner.ts +134 -134
- package/src/programmers/helpers/FunctionImporeter.ts +55 -55
- package/src/programmers/helpers/IExpressionEntry.ts +12 -12
- package/src/programmers/helpers/OptionPredicator.ts +19 -19
- package/src/programmers/helpers/PruneJoiner.ts +52 -52
- package/src/programmers/helpers/RandomJoiner.ts +149 -149
- package/src/programmers/helpers/RandomRanger.ts +216 -216
- package/src/programmers/helpers/StringifyJoinder.ts +114 -114
- package/src/programmers/helpers/StringifyPredicator.ts +18 -18
- package/src/programmers/helpers/UnionExplorer.ts +274 -274
- package/src/programmers/helpers/UnionPredicator.ts +81 -81
- package/src/programmers/internal/application_array.ts +37 -37
- package/src/programmers/internal/application_boolean.ts +17 -17
- package/src/programmers/internal/application_constant.ts +29 -29
- package/src/programmers/internal/application_default.ts +17 -17
- package/src/programmers/internal/application_default_string.ts +32 -32
- package/src/programmers/internal/application_native.ts +29 -29
- package/src/programmers/internal/application_number.ts +73 -73
- package/src/programmers/internal/application_object.ts +153 -153
- package/src/programmers/internal/application_schema.ts +184 -184
- package/src/programmers/internal/application_string.ts +45 -45
- package/src/programmers/internal/application_templates.ts +27 -27
- package/src/programmers/internal/application_tuple.ts +29 -29
- package/src/programmers/internal/check_array.ts +22 -22
- package/src/programmers/internal/check_array_length.ts +44 -44
- package/src/programmers/internal/check_bigint.ts +64 -64
- package/src/programmers/internal/check_dynamic_properties.ts +197 -197
- package/src/programmers/internal/check_everything.ts +28 -28
- package/src/programmers/internal/check_native.ts +21 -21
- package/src/programmers/internal/check_number.ts +145 -145
- package/src/programmers/internal/check_object.ts +48 -48
- package/src/programmers/internal/check_string.ts +24 -24
- package/src/programmers/internal/check_string_tags.ts +63 -63
- package/src/programmers/internal/check_template.ts +50 -50
- package/src/programmers/internal/check_union_array_like.ts +260 -260
- package/src/programmers/internal/check_union_tuple.ts +33 -33
- package/src/programmers/internal/decode_union_object.ts +73 -73
- package/src/programmers/internal/feature_object_entries.ts +59 -59
- package/src/programmers/internal/metadata_to_pattern.ts +31 -31
- package/src/programmers/internal/prune_object_properties.ts +60 -60
- package/src/programmers/internal/stringify_dynamic_properties.ts +165 -165
- package/src/programmers/internal/stringify_native.ts +8 -8
- package/src/programmers/internal/stringify_regular_properties.ts +81 -81
- package/src/programmers/internal/template_to_pattern.ts +15 -15
- package/src/schemas/IJsonApplication.ts +9 -9
- package/src/schemas/IJsonComponents.ts +26 -26
- package/src/schemas/IJsonSchema.ts +121 -121
- package/src/transform.ts +21 -21
- package/src/transformers/CallExpressionTransformer.ts +172 -172
- package/src/transformers/ExpressionWithArgumentTransformer.ts +66 -66
- package/src/transformers/FileTransformer.ts +49 -49
- package/src/transformers/IProject.ts +11 -11
- package/src/transformers/ITransformOptions.ts +62 -62
- package/src/transformers/ImportTransformer.ts +60 -60
- package/src/transformers/NodeTransformer.ts +19 -19
- package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +120 -120
- package/src/transformers/features/miscellaneous/AssertCloneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/AssertPruneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/CloneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/CreateAssertCloneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/CreateAssertPruneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/CreateCloneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/CreateIsCloneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/CreateIsPruneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/CreatePruneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/CreateRandomGenerator.ts +42 -42
- package/src/transformers/features/miscellaneous/CreateValidateCloneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/CreateValidatePruneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/IsCloneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/IsPruneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/MetadataTransformer.ts +55 -55
- package/src/transformers/features/miscellaneous/PruneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/RandomTransformer.ts +48 -48
- package/src/transformers/features/miscellaneous/ValidateCloneTransformer.ts +9 -9
- package/src/transformers/features/miscellaneous/ValidatePruneTransformer.ts +9 -9
- package/src/transformers/features/parsers/AssertParseTransformer.ts +9 -9
- package/src/transformers/features/parsers/CreateAssertParseTransformer.ts +9 -9
- package/src/transformers/features/parsers/CreateIsParseTransformer.ts +9 -9
- package/src/transformers/features/parsers/CreateValidateParseTransformer.ts +9 -9
- package/src/transformers/features/parsers/IsParseTransformer.ts +9 -9
- package/src/transformers/features/parsers/ValidateParseTransformer.ts +9 -9
- package/src/transformers/features/stringifiers/AssertStringifyTransformer.ts +10 -10
- package/src/transformers/features/stringifiers/CreateAssertStringifyTransformer.ts +9 -9
- package/src/transformers/features/stringifiers/CreateIsStringifyTransformer.ts +9 -9
- package/src/transformers/features/stringifiers/CreateStringifyTransformer.ts +9 -9
- package/src/transformers/features/stringifiers/CreateValidateStringifyProgrammer.ts +11 -11
- package/src/transformers/features/stringifiers/IsStringifyTransformer.ts +9 -9
- package/src/transformers/features/stringifiers/StringifyTransformer.ts +9 -9
- package/src/transformers/features/stringifiers/ValidateStringifyTransformer.ts +10 -10
- package/src/transformers/features/validators/AssertTransformer.ts +11 -11
- package/src/transformers/features/validators/CreateAssertTransformer.ts +12 -12
- package/src/transformers/features/validators/CreateIsTransformer.ts +10 -10
- package/src/transformers/features/validators/CreateValidateTransformer.ts +12 -12
- package/src/transformers/features/validators/IsTransformer.ts +10 -10
- package/src/transformers/features/validators/ValidateTransformer.ts +11 -11
- package/src/transformers/internal/GenericTransformer.ts +99 -99
- package/src/typings/Atomic.ts +17 -17
- package/src/typings/ClassProperties.ts +5 -5
- package/src/typings/OmitNever.ts +3 -3
- package/src/typings/SpecialFields.ts +3 -3
- package/src/typings/Writable.ts +11 -11
- package/src/utils/ArrayUtil.ts +49 -49
- package/src/utils/Escaper.ts +50 -50
- package/src/utils/MapUtil.ts +14 -14
- package/src/utils/PatternUtil.ts +30 -30
- package/src/utils/RandomGenerator.ts +96 -96
- 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
|
+
}
|