typia 3.6.3 → 3.6.4

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 (138) hide show
  1. package/lib/functional/$is_uuid.js +1 -1
  2. package/lib/functional/$is_uuid.js.map +1 -1
  3. package/package.json +1 -1
  4. package/src/IRandomGenerator.ts +16 -16
  5. package/src/IValidation.ts +21 -21
  6. package/src/Primitive.ts +104 -104
  7. package/src/TypeGuardError.ts +36 -36
  8. package/src/executable/TypiaGenerateWizard.ts +87 -87
  9. package/src/executable/TypiaSetupWizard.ts +142 -142
  10. package/src/executable/setup/CommandExecutor.ts +8 -8
  11. package/src/executable/typia.ts +38 -38
  12. package/src/factories/CommentFactory.ts +10 -10
  13. package/src/factories/ExpressionFactory.ts +77 -77
  14. package/src/factories/IdentifierFactory.ts +73 -73
  15. package/src/factories/LiteralFactory.ts +44 -44
  16. package/src/factories/MetadataCollection.ts +122 -122
  17. package/src/factories/MetadataFactory.ts +51 -51
  18. package/src/factories/MetadataTagFactory.ts +265 -265
  19. package/src/factories/StatementFactory.ts +60 -60
  20. package/src/factories/TemplateFactory.ts +56 -56
  21. package/src/factories/TypeFactory.ts +129 -129
  22. package/src/factories/TypiaFileFactory.ts +117 -117
  23. package/src/factories/ValueFactory.ts +12 -12
  24. package/src/factories/internal/metadata/MetadataHelper.ts +12 -12
  25. package/src/factories/internal/metadata/explore_metadata.ts +92 -92
  26. package/src/factories/internal/metadata/iterate_metadata.ts +80 -80
  27. package/src/factories/internal/metadata/iterate_metadata_array.ts +29 -29
  28. package/src/factories/internal/metadata/iterate_metadata_atomic.ts +59 -59
  29. package/src/factories/internal/metadata/iterate_metadata_coalesce.ts +33 -33
  30. package/src/factories/internal/metadata/iterate_metadata_constant.ts +58 -58
  31. package/src/factories/internal/metadata/iterate_metadata_map.ts +41 -41
  32. package/src/factories/internal/metadata/iterate_metadata_native.ts +222 -222
  33. package/src/factories/internal/metadata/iterate_metadata_object.ts +48 -48
  34. package/src/factories/internal/metadata/iterate_metadata_resolve.ts +27 -27
  35. package/src/factories/internal/metadata/iterate_metadata_set.ts +33 -33
  36. package/src/factories/internal/metadata/iterate_metadata_template.ts +38 -38
  37. package/src/factories/internal/metadata/iterate_metadata_tuple.ts +45 -45
  38. package/src/factories/internal/metadata/iterate_metadata_union.ts +59 -59
  39. package/src/functional/$any.ts +3 -3
  40. package/src/functional/$every.ts +11 -11
  41. package/src/functional/$guard.ts +35 -35
  42. package/src/functional/$is_between.ts +7 -7
  43. package/src/functional/$is_email.ts +5 -5
  44. package/src/functional/$is_ipv4.ts +5 -5
  45. package/src/functional/$is_ipv6.ts +5 -5
  46. package/src/functional/$is_url.ts +5 -5
  47. package/src/functional/$is_uuid.ts +4 -5
  48. package/src/functional/$join.ts +50 -50
  49. package/src/functional/$number.ts +12 -12
  50. package/src/functional/$report.ts +15 -15
  51. package/src/functional/$rest.ts +3 -3
  52. package/src/functional/$string.ts +37 -37
  53. package/src/functional/$tail.ts +6 -6
  54. package/src/functional/Namespace.ts +121 -121
  55. package/src/index.ts +4 -4
  56. package/src/metadata/IJsDocTagInfo.ts +10 -10
  57. package/src/metadata/IMetadata.ts +25 -25
  58. package/src/metadata/IMetadataApplication.ts +7 -7
  59. package/src/metadata/IMetadataConstant.ts +16 -16
  60. package/src/metadata/IMetadataEntry.ts +6 -6
  61. package/src/metadata/IMetadataObject.ts +29 -29
  62. package/src/metadata/IMetadataProperty.ts +11 -11
  63. package/src/metadata/IMetadataTag.ts +113 -113
  64. package/src/metadata/Metadata.ts +534 -534
  65. package/src/metadata/MetadataConstant.ts +3 -3
  66. package/src/metadata/MetadataObject.ts +131 -131
  67. package/src/metadata/MetadataProperty.ts +64 -64
  68. package/src/programmers/ApplicationProgrammer.ts +55 -55
  69. package/src/programmers/IsProgrammer.ts +200 -200
  70. package/src/programmers/helpers/AtomicPredicator.ts +31 -31
  71. package/src/programmers/helpers/CloneJoiner.ts +134 -134
  72. package/src/programmers/helpers/FunctionImporeter.ts +55 -55
  73. package/src/programmers/helpers/IExpressionEntry.ts +12 -12
  74. package/src/programmers/helpers/OptionPredicator.ts +19 -19
  75. package/src/programmers/helpers/PruneJoiner.ts +52 -52
  76. package/src/programmers/helpers/RandomJoiner.ts +149 -149
  77. package/src/programmers/helpers/RandomRanger.ts +216 -216
  78. package/src/programmers/helpers/StringifyJoinder.ts +114 -114
  79. package/src/programmers/helpers/StringifyPredicator.ts +18 -18
  80. package/src/programmers/helpers/UnionExplorer.ts +274 -274
  81. package/src/programmers/helpers/UnionPredicator.ts +81 -81
  82. package/src/programmers/internal/application_array.ts +37 -37
  83. package/src/programmers/internal/application_boolean.ts +17 -17
  84. package/src/programmers/internal/application_constant.ts +29 -29
  85. package/src/programmers/internal/application_default.ts +17 -17
  86. package/src/programmers/internal/application_default_string.ts +32 -32
  87. package/src/programmers/internal/application_native.ts +29 -29
  88. package/src/programmers/internal/application_number.ts +70 -70
  89. package/src/programmers/internal/application_object.ts +153 -153
  90. package/src/programmers/internal/application_schema.ts +184 -184
  91. package/src/programmers/internal/application_string.ts +41 -41
  92. package/src/programmers/internal/application_templates.ts +27 -27
  93. package/src/programmers/internal/application_tuple.ts +29 -29
  94. package/src/programmers/internal/check_array.ts +22 -22
  95. package/src/programmers/internal/check_array_length.ts +44 -44
  96. package/src/programmers/internal/check_bigint.ts +64 -64
  97. package/src/programmers/internal/check_dynamic_properties.ts +197 -197
  98. package/src/programmers/internal/check_everything.ts +28 -28
  99. package/src/programmers/internal/check_native.ts +21 -21
  100. package/src/programmers/internal/check_number.ts +145 -145
  101. package/src/programmers/internal/check_object.ts +48 -48
  102. package/src/programmers/internal/check_string.ts +24 -24
  103. package/src/programmers/internal/check_string_tags.ts +63 -63
  104. package/src/programmers/internal/check_template.ts +50 -50
  105. package/src/programmers/internal/check_union_array_like.ts +260 -260
  106. package/src/programmers/internal/check_union_tuple.ts +33 -33
  107. package/src/programmers/internal/decode_union_object.ts +73 -73
  108. package/src/programmers/internal/feature_object_entries.ts +59 -59
  109. package/src/programmers/internal/metadata_to_pattern.ts +31 -31
  110. package/src/programmers/internal/prune_object_properties.ts +60 -60
  111. package/src/programmers/internal/stringify_dynamic_properties.ts +165 -165
  112. package/src/programmers/internal/stringify_native.ts +8 -8
  113. package/src/programmers/internal/stringify_regular_properties.ts +81 -81
  114. package/src/programmers/internal/template_to_pattern.ts +15 -15
  115. package/src/schemas/IJsonApplication.ts +9 -9
  116. package/src/schemas/IJsonComponents.ts +26 -26
  117. package/src/schemas/IJsonSchema.ts +127 -127
  118. package/src/transform.ts +21 -21
  119. package/src/transformers/CallExpressionTransformer.ts +172 -172
  120. package/src/transformers/ExpressionWithArgumentTransformer.ts +66 -66
  121. package/src/transformers/FileTransformer.ts +49 -49
  122. package/src/transformers/IProject.ts +11 -11
  123. package/src/transformers/ITransformOptions.ts +62 -62
  124. package/src/transformers/ImportTransformer.ts +60 -60
  125. package/src/transformers/NodeTransformer.ts +19 -19
  126. package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +120 -120
  127. package/src/transformers/features/miscellaneous/MetadataTransformer.ts +55 -55
  128. package/src/typings/Atomic.ts +17 -17
  129. package/src/typings/ClassProperties.ts +5 -5
  130. package/src/typings/OmitNever.ts +3 -3
  131. package/src/typings/SpecialFields.ts +3 -3
  132. package/src/typings/Writable.ts +11 -11
  133. package/src/utils/ArrayUtil.ts +49 -49
  134. package/src/utils/Escaper.ts +50 -50
  135. package/src/utils/MapUtil.ts +14 -14
  136. package/src/utils/PatternUtil.ts +30 -30
  137. package/src/utils/RandomGenerator.ts +90 -90
  138. package/src/utils/Singleton.ts +17 -17
@@ -1,142 +1,142 @@
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" });
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
- ).filter(
89
- (str) =>
90
- str.substring(0, 8) === "tsconfig" &&
91
- str.substring(str.length - 5) === ".json",
92
- );
93
- if (fileList.length === 0) {
94
- if (process.cwd() !== pack.directory)
95
- throw new Error(`Unable to find "tsconfig.json" file.`);
96
- return null;
97
- } else if (fileList.length === 1) return fileList[0];
98
- return select("tsconfig")("TS Config File")(fileList);
99
- };
100
-
101
- // DO CONSTRUCT
102
- return action(async (options) => {
103
- if (options.compiler === undefined) {
104
- console.log(COMPILER_DESCRIPTION);
105
- options.compiler = await select("compiler")(`Compiler`)(
106
- is_nest_cli(pack)
107
- ? ["ts-patch" as const, "ttypescript" as const]
108
- : ["ttypescript" as const, "ts-patch" as const],
109
- );
110
- }
111
- options.manager ??= await select("manager")("Package Manager")([
112
- "npm" as const,
113
- "pnpm" as const,
114
- "yarn" as const,
115
- ]);
116
- pack.manager = options.manager;
117
- options.project ??= await configure();
118
-
119
- if (questioned.value) console.log("");
120
- return options as IArguments;
121
- });
122
- };
123
-
124
- function is_nest_cli(pack: PackageManager): boolean {
125
- return (
126
- (typeof pack.data.scripts?.build === "string" &&
127
- pack.data.scripts.build.indexOf("nest build") !== -1) ||
128
- fs.existsSync(path.join(pack.directory, "nest-cli.json"))
129
- );
130
- }
131
- }
132
-
133
- const COMPILER_DESCRIPTION = [
134
- `About compiler, if you adapt "ttypescript", you should use "ttsc" instead.`,
135
- ``,
136
- `Otherwise, you choose "ts-patch", you can use the original "tsc" command.`,
137
- `However, the "ts-patch" hacks "node_modules/typescript" source code.`,
138
- `Also, whenever update "typescript", you've to run "npm run prepare" command.`,
139
- ``,
140
- `By the way, when using "@nest/cli", you must just choose "ts-patch".`,
141
- ``,
142
- ].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" });
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
+ ).filter(
89
+ (str) =>
90
+ str.substring(0, 8) === "tsconfig" &&
91
+ str.substring(str.length - 5) === ".json",
92
+ );
93
+ if (fileList.length === 0) {
94
+ if (process.cwd() !== pack.directory)
95
+ throw new Error(`Unable to find "tsconfig.json" file.`);
96
+ return null;
97
+ } else if (fileList.length === 1) return fileList[0];
98
+ return select("tsconfig")("TS Config File")(fileList);
99
+ };
100
+
101
+ // DO CONSTRUCT
102
+ return action(async (options) => {
103
+ if (options.compiler === undefined) {
104
+ console.log(COMPILER_DESCRIPTION);
105
+ options.compiler = await select("compiler")(`Compiler`)(
106
+ is_nest_cli(pack)
107
+ ? ["ts-patch" as const, "ttypescript" as const]
108
+ : ["ttypescript" as const, "ts-patch" as const],
109
+ );
110
+ }
111
+ options.manager ??= await select("manager")("Package Manager")([
112
+ "npm" as const,
113
+ "pnpm" as const,
114
+ "yarn" as const,
115
+ ]);
116
+ pack.manager = options.manager;
117
+ options.project ??= await configure();
118
+
119
+ if (questioned.value) console.log("");
120
+ return options as IArguments;
121
+ });
122
+ };
123
+
124
+ function is_nest_cli(pack: PackageManager): boolean {
125
+ return (
126
+ (typeof pack.data.scripts?.build === "string" &&
127
+ pack.data.scripts.build.indexOf("nest build") !== -1) ||
128
+ fs.existsSync(path.join(pack.directory, "nest-cli.json"))
129
+ );
130
+ }
131
+ }
132
+
133
+ const COMPILER_DESCRIPTION = [
134
+ `About compiler, if you adapt "ttypescript", you should use "ttsc" instead.`,
135
+ ``,
136
+ `Otherwise, you choose "ts-patch", you can use the original "tsc" command.`,
137
+ `However, the "ts-patch" hacks "node_modules/typescript" source code.`,
138
+ `Also, whenever update "typescript", you've to run "npm run prepare" command.`,
139
+ ``,
140
+ `By the way, when using "@nest/cli", you must just choose "ts-patch".`,
141
+ ``,
142
+ ].join("\n");
@@ -1,8 +1,8 @@
1
- import cp from "child_process";
2
-
3
- export namespace CommandExecutor {
4
- export function run(str: string, silent: boolean): void {
5
- if (silent === false) console.log(str);
6
- cp.execSync(str, { stdio: "ignore" });
7
- }
8
- }
1
+ import cp from "child_process";
2
+
3
+ export namespace CommandExecutor {
4
+ export function run(str: string, silent: boolean): void {
5
+ if (silent === false) console.log(str);
6
+ cp.execSync(str, { stdio: "ignore" });
7
+ }
8
+ }
@@ -1,38 +1,38 @@
1
- #!/usr/bin/env node
2
- import { TypiaGenerateWizard } from "./TypiaGenerateWizard";
3
- import { TypiaSetupWizard } from "./TypiaSetupWizard";
4
-
5
- const USAGE = `Wrong command has been detected. Use like below:
6
-
7
- npx typia setup \\
8
- --compiler (ttypescript|ts-patch) \\
9
- --manager (npm|pnpm|yarn) \\
10
- --project {tsconfig.json file path}
11
-
12
- - npx typia setup
13
- - npx typia setup --compiler ts-patch
14
- - npx typia setup --manager pnpm
15
- - npx typia setup --project tsconfig.test.json
16
-
17
- npx typia generate
18
- --input {directory} \\
19
- --output {directory}
20
-
21
- --npx typia generate --input src/templates --output src/functinoal
22
- `;
23
-
24
- function halt(desc: string): never {
25
- console.error(desc);
26
- process.exit(-1);
27
- }
28
-
29
- async function main(): Promise<void> {
30
- const type: string | undefined = process.argv[2];
31
- if (type === "setup") await TypiaSetupWizard.setup();
32
- else if (type === "generate") await TypiaGenerateWizard.generate();
33
- else halt(USAGE);
34
- }
35
- main().catch((exp) => {
36
- console.error(exp);
37
- process.exit(-1);
38
- });
1
+ #!/usr/bin/env node
2
+ import { TypiaGenerateWizard } from "./TypiaGenerateWizard";
3
+ import { TypiaSetupWizard } from "./TypiaSetupWizard";
4
+
5
+ const USAGE = `Wrong command has been detected. Use like below:
6
+
7
+ npx typia setup \\
8
+ --compiler (ttypescript|ts-patch) \\
9
+ --manager (npm|pnpm|yarn) \\
10
+ --project {tsconfig.json file path}
11
+
12
+ - npx typia setup
13
+ - npx typia setup --compiler ts-patch
14
+ - npx typia setup --manager pnpm
15
+ - npx typia setup --project tsconfig.test.json
16
+
17
+ npx typia generate
18
+ --input {directory} \\
19
+ --output {directory}
20
+
21
+ --npx typia generate --input src/templates --output src/functinoal
22
+ `;
23
+
24
+ function halt(desc: string): never {
25
+ console.error(desc);
26
+ process.exit(-1);
27
+ }
28
+
29
+ async function main(): Promise<void> {
30
+ const type: string | undefined = process.argv[2];
31
+ if (type === "setup") await TypiaSetupWizard.setup();
32
+ else if (type === "generate") await TypiaGenerateWizard.generate();
33
+ else halt(USAGE);
34
+ }
35
+ main().catch((exp) => {
36
+ console.error(exp);
37
+ process.exit(-1);
38
+ });
@@ -1,10 +1,10 @@
1
- import ts from "typescript";
2
-
3
- export namespace CommentFactory {
4
- export function generate(comments: ts.SymbolDisplayPart[]): string {
5
- return comments
6
- .map((part) => part.text)
7
- .map((str) => str.split("\r\n").join("\n"))
8
- .join("");
9
- }
10
- }
1
+ import ts from "typescript";
2
+
3
+ export namespace CommentFactory {
4
+ export function generate(comments: ts.SymbolDisplayPart[]): string {
5
+ return comments
6
+ .map((part) => part.text)
7
+ .map((str) => str.split("\r\n").join("\n"))
8
+ .join("");
9
+ }
10
+ }
@@ -1,77 +1,77 @@
1
- import ts from "typescript";
2
-
3
- export namespace ExpressionFactory {
4
- export function isRequired(input: ts.Expression): ts.Expression {
5
- return ts.factory.createStrictInequality(
6
- ts.factory.createIdentifier("undefined"),
7
- input,
8
- );
9
- }
10
-
11
- export function isArray(input: ts.Expression): ts.Expression {
12
- return ts.factory.createCallExpression(
13
- ts.factory.createIdentifier("Array.isArray"),
14
- undefined,
15
- [input],
16
- );
17
- }
18
-
19
- export function isObject(
20
- input: ts.Expression,
21
- options: {
22
- checkNull: boolean;
23
- checkArray: boolean;
24
- },
25
- ): ts.Expression {
26
- const conditions: ts.Expression[] = [
27
- ts.factory.createStrictEquality(
28
- ts.factory.createStringLiteral("object"),
29
- ts.factory.createTypeOfExpression(input),
30
- ),
31
- ];
32
- if (options.checkNull === true)
33
- conditions.push(
34
- ts.factory.createStrictInequality(
35
- ts.factory.createNull(),
36
- input,
37
- ),
38
- );
39
- if (options.checkArray === true)
40
- conditions.push(
41
- ts.factory.createStrictEquality(
42
- ts.factory.createFalse(),
43
- ts.factory.createCallExpression(
44
- ts.factory.createIdentifier("Array.isArray"),
45
- undefined,
46
- [input],
47
- ),
48
- ),
49
- );
50
-
51
- return conditions.length === 1
52
- ? conditions[0]!
53
- : conditions.reduce((x, y) => ts.factory.createLogicalAnd(x, y));
54
- }
55
-
56
- export function isInstanceOf(
57
- input: ts.Expression,
58
- type: string,
59
- ): ts.Expression {
60
- return ts.factory.createBinaryExpression(
61
- input,
62
- ts.factory.createToken(ts.SyntaxKind.InstanceOfKeyword),
63
- ts.factory.createIdentifier(type),
64
- );
65
- }
66
-
67
- export function coalesce(
68
- x: ts.Expression,
69
- y: ts.Expression,
70
- ): ts.Expression {
71
- return ts.factory.createBinaryExpression(
72
- x,
73
- ts.factory.createToken(ts.SyntaxKind.QuestionQuestionToken),
74
- y,
75
- );
76
- }
77
- }
1
+ import ts from "typescript";
2
+
3
+ export namespace ExpressionFactory {
4
+ export function isRequired(input: ts.Expression): ts.Expression {
5
+ return ts.factory.createStrictInequality(
6
+ ts.factory.createIdentifier("undefined"),
7
+ input,
8
+ );
9
+ }
10
+
11
+ export function isArray(input: ts.Expression): ts.Expression {
12
+ return ts.factory.createCallExpression(
13
+ ts.factory.createIdentifier("Array.isArray"),
14
+ undefined,
15
+ [input],
16
+ );
17
+ }
18
+
19
+ export function isObject(
20
+ input: ts.Expression,
21
+ options: {
22
+ checkNull: boolean;
23
+ checkArray: boolean;
24
+ },
25
+ ): ts.Expression {
26
+ const conditions: ts.Expression[] = [
27
+ ts.factory.createStrictEquality(
28
+ ts.factory.createStringLiteral("object"),
29
+ ts.factory.createTypeOfExpression(input),
30
+ ),
31
+ ];
32
+ if (options.checkNull === true)
33
+ conditions.push(
34
+ ts.factory.createStrictInequality(
35
+ ts.factory.createNull(),
36
+ input,
37
+ ),
38
+ );
39
+ if (options.checkArray === true)
40
+ conditions.push(
41
+ ts.factory.createStrictEquality(
42
+ ts.factory.createFalse(),
43
+ ts.factory.createCallExpression(
44
+ ts.factory.createIdentifier("Array.isArray"),
45
+ undefined,
46
+ [input],
47
+ ),
48
+ ),
49
+ );
50
+
51
+ return conditions.length === 1
52
+ ? conditions[0]!
53
+ : conditions.reduce((x, y) => ts.factory.createLogicalAnd(x, y));
54
+ }
55
+
56
+ export function isInstanceOf(
57
+ input: ts.Expression,
58
+ type: string,
59
+ ): ts.Expression {
60
+ return ts.factory.createBinaryExpression(
61
+ input,
62
+ ts.factory.createToken(ts.SyntaxKind.InstanceOfKeyword),
63
+ ts.factory.createIdentifier(type),
64
+ );
65
+ }
66
+
67
+ export function coalesce(
68
+ x: ts.Expression,
69
+ y: ts.Expression,
70
+ ): ts.Expression {
71
+ return ts.factory.createBinaryExpression(
72
+ x,
73
+ ts.factory.createToken(ts.SyntaxKind.QuestionQuestionToken),
74
+ y,
75
+ );
76
+ }
77
+ }