typia 3.8.0-dev.20230417 → 3.8.0-dev.20230418

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 (51) hide show
  1. package/README.md +1 -1
  2. package/lib/executable/setup/PackageManager.d.ts +1 -1
  3. package/lib/metadata/Metadata.js +1 -1
  4. package/lib/metadata/Metadata.js.map +1 -1
  5. package/lib/programmers/CheckerProgrammer.js +1 -1
  6. package/lib/programmers/CheckerProgrammer.js.map +1 -1
  7. package/lib/typings/Customizable.d.ts +2 -2
  8. package/lib/utils/RandomGenerator.d.ts +1 -17
  9. package/lib/utils/RandomGenerator.js.map +1 -1
  10. package/package.json +2 -2
  11. package/src/IRandomGenerator.ts +33 -33
  12. package/src/executable/TypiaGenerateWizard.ts +85 -85
  13. package/src/executable/setup/ArgumentParser.ts +45 -45
  14. package/src/executable/setup/CommandExecutor.ts +8 -8
  15. package/src/executable/setup/FileRetriever.ts +22 -22
  16. package/src/executable/setup/PackageManager.ts +1 -1
  17. package/src/executable/setup/PluginConfigurator.ts +59 -59
  18. package/src/factories/MetadataTagFactory.ts +302 -302
  19. package/src/factories/TypiaFileFactory.ts +129 -129
  20. package/src/metadata/ICommentTag.ts +4 -4
  21. package/src/metadata/Metadata.ts +1 -1
  22. package/src/module.ts +2043 -2043
  23. package/src/programmers/AssertProgrammer.ts +284 -284
  24. package/src/programmers/CheckerProgrammer.ts +1 -1
  25. package/src/programmers/LiteralsProgrammer.ts +65 -65
  26. package/src/programmers/RandomProgrammer.ts +413 -413
  27. package/src/programmers/ValidateProgrammer.ts +317 -317
  28. package/src/programmers/helpers/RandomJoiner.ts +161 -161
  29. package/src/programmers/helpers/RandomRanger.ts +216 -216
  30. package/src/programmers/internal/application_native.ts +32 -32
  31. package/src/programmers/internal/check_array.ts +30 -30
  32. package/src/programmers/internal/check_array_length.ts +35 -35
  33. package/src/programmers/internal/check_custom.ts +33 -33
  34. package/src/programmers/internal/check_number.ts +177 -177
  35. package/src/programmers/internal/check_object.ts +55 -55
  36. package/src/programmers/internal/check_union_array_like.ts +272 -272
  37. package/src/programmers/internal/feature_object_entries.ts +63 -63
  38. package/src/programmers/internal/get_comment_tags.ts +23 -23
  39. package/src/programmers/internal/metadata_to_pattern.ts +34 -34
  40. package/src/programmers/internal/random_custom.ts +30 -30
  41. package/src/programmers/internal/stringify_dynamic_properties.ts +168 -168
  42. package/src/programmers/internal/stringify_regular_properties.ts +84 -84
  43. package/src/transformers/CallExpressionTransformer.ts +174 -174
  44. package/src/transformers/ImportTransformer.ts +66 -66
  45. package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +119 -119
  46. package/src/transformers/features/miscellaneous/CreateRandomTransformer.ts +41 -41
  47. package/src/transformers/features/miscellaneous/LiteralsTransformer.ts +30 -30
  48. package/src/transformers/features/miscellaneous/MetadataTransformer.ts +54 -54
  49. package/src/transformers/features/miscellaneous/RandomTransformer.ts +46 -46
  50. package/src/typings/Customizable.ts +2 -2
  51. package/src/utils/RandomGenerator.ts +3 -0
@@ -1,22 +1,22 @@
1
- import fs from "fs";
2
- import path from "path";
3
-
4
- export namespace FileRetriever {
5
- export const directory =
6
- (name: string) =>
7
- (dir: string, depth: number = 0): string | null => {
8
- const location: string = path.join(dir, name);
9
- if (fs.existsSync(location)) return dir;
10
- else if (depth > 2) return null;
11
- return directory(name)(path.join(dir, ".."), depth + 1);
12
- };
13
-
14
- export const file =
15
- (name: string) =>
16
- (directory: string, depth: number = 0): string | null => {
17
- const location: string = path.join(directory, name);
18
- if (fs.existsSync(location)) return location;
19
- else if (depth > 2) return null;
20
- return file(name)(path.join(directory, ".."), depth + 1);
21
- };
22
- }
1
+ import fs from "fs";
2
+ import path from "path";
3
+
4
+ export namespace FileRetriever {
5
+ export const directory =
6
+ (name: string) =>
7
+ (dir: string, depth: number = 0): string | null => {
8
+ const location: string = path.join(dir, name);
9
+ if (fs.existsSync(location)) return dir;
10
+ else if (depth > 2) return null;
11
+ return directory(name)(path.join(dir, ".."), depth + 1);
12
+ };
13
+
14
+ export const file =
15
+ (name: string) =>
16
+ (directory: string, depth: number = 0): string | null => {
17
+ const location: string = path.join(directory, name);
18
+ if (fs.existsSync(location)) return location;
19
+ else if (depth > 2) return null;
20
+ return file(name)(path.join(directory, ".."), depth + 1);
21
+ };
22
+ }
@@ -38,7 +38,7 @@ export class PackageManager {
38
38
  public install(props: {
39
39
  dev: boolean;
40
40
  modulo: string;
41
- version?: string;
41
+ version: `latest` | `${number}.${number}.${number}`;
42
42
  }): boolean {
43
43
  const middle: string =
44
44
  this.manager === "yarn"
@@ -1,59 +1,59 @@
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 = compilerOptions.strict === true;
37
- const oldbie: comments.CommentObject | undefined = plugins.find(
38
- (p) =>
39
- typeof p === "object" &&
40
- p !== null &&
41
- p.transform === "typia/lib/transform",
42
- );
43
- if (strict === true && oldbie !== undefined) return;
44
-
45
- // DO CONFIGURE
46
- compilerOptions.strict = true;
47
- if (oldbie === undefined)
48
- plugins.push(
49
- comments.parse(`
50
- {
51
- "transform": "typia/lib/transform"
52
- }`) as comments.CommentObject,
53
- );
54
- await fs.promises.writeFile(
55
- args.project!,
56
- comments.stringify(config, null, 2),
57
- );
58
- }
59
- }
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 = compilerOptions.strict === true;
37
+ const oldbie: comments.CommentObject | undefined = plugins.find(
38
+ (p) =>
39
+ typeof p === "object" &&
40
+ p !== null &&
41
+ p.transform === "typia/lib/transform",
42
+ );
43
+ if (strict === true && oldbie !== undefined) return;
44
+
45
+ // DO CONFIGURE
46
+ compilerOptions.strict = true;
47
+ if (oldbie === undefined)
48
+ plugins.push(
49
+ comments.parse(`
50
+ {
51
+ "transform": "typia/lib/transform"
52
+ }`) as comments.CommentObject,
53
+ );
54
+ await fs.promises.writeFile(
55
+ args.project!,
56
+ comments.stringify(config, null, 2),
57
+ );
58
+ }
59
+ }