typia 3.8.0-dev.20230416 → 3.8.0-dev.20230417

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 (50) hide show
  1. package/README.md +35 -228
  2. package/lib/factories/TypiaFileFactory.js +9 -4
  3. package/lib/factories/TypiaFileFactory.js.map +1 -1
  4. package/package.json +1 -1
  5. package/src/IRandomGenerator.ts +33 -33
  6. package/src/executable/TypiaGenerateWizard.ts +85 -85
  7. package/src/executable/TypiaSetupWizard.ts +118 -118
  8. package/src/executable/setup/ArgumentParser.ts +45 -45
  9. package/src/executable/setup/CommandExecutor.ts +8 -8
  10. package/src/executable/setup/FileRetriever.ts +22 -22
  11. package/src/executable/setup/PackageManager.ts +71 -71
  12. package/src/executable/setup/PluginConfigurator.ts +59 -59
  13. package/src/executable/typia.ts +52 -52
  14. package/src/factories/IdentifierFactory.ts +59 -59
  15. package/src/factories/MetadataTagFactory.ts +302 -302
  16. package/src/factories/TypiaFileFactory.ts +12 -3
  17. package/src/metadata/ICommentTag.ts +4 -4
  18. package/src/metadata/Metadata.ts +533 -533
  19. package/src/module.ts +2043 -2043
  20. package/src/programmers/AssertProgrammer.ts +284 -284
  21. package/src/programmers/CheckerProgrammer.ts +920 -920
  22. package/src/programmers/LiteralsProgrammer.ts +65 -65
  23. package/src/programmers/RandomProgrammer.ts +413 -413
  24. package/src/programmers/ValidateProgrammer.ts +317 -317
  25. package/src/programmers/helpers/RandomJoiner.ts +161 -161
  26. package/src/programmers/helpers/RandomRanger.ts +216 -216
  27. package/src/programmers/internal/application_native.ts +32 -32
  28. package/src/programmers/internal/check_array.ts +30 -30
  29. package/src/programmers/internal/check_array_length.ts +35 -35
  30. package/src/programmers/internal/check_custom.ts +33 -33
  31. package/src/programmers/internal/check_number.ts +177 -177
  32. package/src/programmers/internal/check_object.ts +55 -55
  33. package/src/programmers/internal/check_string_tags.ts +67 -67
  34. package/src/programmers/internal/check_template.ts +56 -56
  35. package/src/programmers/internal/check_union_array_like.ts +272 -272
  36. package/src/programmers/internal/feature_object_entries.ts +63 -63
  37. package/src/programmers/internal/get_comment_tags.ts +23 -23
  38. package/src/programmers/internal/metadata_to_pattern.ts +34 -34
  39. package/src/programmers/internal/random_custom.ts +30 -30
  40. package/src/programmers/internal/stringify_dynamic_properties.ts +168 -168
  41. package/src/programmers/internal/stringify_regular_properties.ts +84 -84
  42. package/src/transformers/CallExpressionTransformer.ts +174 -174
  43. package/src/transformers/ImportTransformer.ts +66 -66
  44. package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +119 -119
  45. package/src/transformers/features/miscellaneous/CreateRandomTransformer.ts +41 -41
  46. package/src/transformers/features/miscellaneous/LiteralsTransformer.ts +30 -30
  47. package/src/transformers/features/miscellaneous/MetadataTransformer.ts +54 -54
  48. package/src/transformers/features/miscellaneous/RandomTransformer.ts +46 -46
  49. package/src/typings/Customizable.ts +5 -5
  50. package/src/utils/RandomGenerator.ts +93 -93
@@ -1,52 +1,52 @@
1
- #!/usr/bin/env node
2
- const USAGE = `Wrong command has been detected. Use like below:
3
-
4
- npx typia setup \\
5
- --manager (npm|pnpm|yarn) \\
6
- --project {tsconfig.json file path}
7
-
8
- - npx typia setup
9
- - npx typia setup --manager pnpm
10
- - npx typia setup --project tsconfig.test.json
11
-
12
- npx typia generate
13
- --input {directory} \\
14
- --output {directory}
15
-
16
- --npx typia generate --input src/templates --output src/functinoal
17
- `;
18
-
19
- function halt(desc: string): never {
20
- console.error(desc);
21
- process.exit(-1);
22
- }
23
-
24
- async function main(): Promise<void> {
25
- try {
26
- await import("comment-json");
27
- await import("inquirer");
28
- await import("commander");
29
- } catch {
30
- halt(`typia has not been installed. Run "npm i typia" before.`);
31
- }
32
-
33
- const type: string | undefined = process.argv[2];
34
- if (type === "setup") {
35
- const { TypiaSetupWizard } = await import("./TypiaSetupWizard");
36
- await TypiaSetupWizard.setup();
37
- } else if (type === "generate") {
38
- try {
39
- await import("typescript");
40
- } catch {
41
- halt(
42
- `typescript has not been installed. Run "npm i -D typescript" before.`,
43
- );
44
- }
45
- const { TypiaGenerateWizard } = await import("./TypiaGenerateWizard");
46
- await TypiaGenerateWizard.generate();
47
- } else halt(USAGE);
48
- }
49
- main().catch((exp) => {
50
- console.error(exp);
51
- process.exit(-1);
52
- });
1
+ #!/usr/bin/env node
2
+ const USAGE = `Wrong command has been detected. Use like below:
3
+
4
+ npx typia setup \\
5
+ --manager (npm|pnpm|yarn) \\
6
+ --project {tsconfig.json file path}
7
+
8
+ - npx typia setup
9
+ - npx typia setup --manager pnpm
10
+ - npx typia setup --project tsconfig.test.json
11
+
12
+ npx typia generate
13
+ --input {directory} \\
14
+ --output {directory}
15
+
16
+ --npx typia generate --input src/templates --output src/functinoal
17
+ `;
18
+
19
+ function halt(desc: string): never {
20
+ console.error(desc);
21
+ process.exit(-1);
22
+ }
23
+
24
+ async function main(): Promise<void> {
25
+ try {
26
+ await import("comment-json");
27
+ await import("inquirer");
28
+ await import("commander");
29
+ } catch {
30
+ halt(`typia has not been installed. Run "npm i typia" before.`);
31
+ }
32
+
33
+ const type: string | undefined = process.argv[2];
34
+ if (type === "setup") {
35
+ const { TypiaSetupWizard } = await import("./TypiaSetupWizard");
36
+ await TypiaSetupWizard.setup();
37
+ } else if (type === "generate") {
38
+ try {
39
+ await import("typescript");
40
+ } catch {
41
+ halt(
42
+ `typescript has not been installed. Run "npm i -D typescript" before.`,
43
+ );
44
+ }
45
+ const { TypiaGenerateWizard } = await import("./TypiaGenerateWizard");
46
+ await TypiaGenerateWizard.generate();
47
+ } else halt(USAGE);
48
+ }
49
+ main().catch((exp) => {
50
+ console.error(exp);
51
+ process.exit(-1);
52
+ });
@@ -1,59 +1,59 @@
1
- import ts from "typescript";
2
-
3
- import { Escaper } from "../utils/Escaper";
4
-
5
- export namespace IdentifierFactory {
6
- export function generate(name: string) {
7
- return Escaper.variable(name)
8
- ? ts.factory.createIdentifier(name)
9
- : ts.factory.createStringLiteral(name);
10
- }
11
-
12
- export function join(prefix: ts.Expression, name: string) {
13
- const postfix = generate(name);
14
- return ts.isStringLiteral(postfix)
15
- ? ts.factory.createElementAccessExpression(prefix, postfix)
16
- : ts.factory.createPropertyAccessExpression(prefix, postfix);
17
- }
18
-
19
- export function postfix(str: string): string {
20
- return Escaper.variable(str)
21
- ? `".${str}"`
22
- : `"[${JSON.stringify(str).split('"').join('\\"')}]"`;
23
- }
24
-
25
- export function parameter(
26
- name: string | ts.BindingName,
27
- type?: ts.TypeNode,
28
- init?: ts.Expression | ts.PunctuationToken<ts.SyntaxKind.QuestionToken>,
29
- ) {
30
- // instead of ts.version >= "4.8"
31
- if (ts.getDecorators !== undefined)
32
- return ts.factory.createParameterDeclaration(
33
- undefined,
34
- undefined,
35
- name,
36
- init?.kind === ts.SyntaxKind.QuestionToken
37
- ? ts.factory.createToken(ts.SyntaxKind.QuestionToken)
38
- : undefined,
39
- type,
40
- init && init.kind !== ts.SyntaxKind.QuestionToken
41
- ? init
42
- : undefined,
43
- );
44
- // eslint-disable-next-line
45
- return (ts.factory.createParameterDeclaration as any)(
46
- undefined,
47
- undefined,
48
- undefined,
49
- name,
50
- init?.kind === ts.SyntaxKind.QuestionToken
51
- ? ts.factory.createToken(ts.SyntaxKind.QuestionToken)
52
- : undefined,
53
- type,
54
- init && init.kind !== ts.SyntaxKind.QuestionToken
55
- ? init
56
- : undefined,
57
- );
58
- }
59
- }
1
+ import ts from "typescript";
2
+
3
+ import { Escaper } from "../utils/Escaper";
4
+
5
+ export namespace IdentifierFactory {
6
+ export function generate(name: string) {
7
+ return Escaper.variable(name)
8
+ ? ts.factory.createIdentifier(name)
9
+ : ts.factory.createStringLiteral(name);
10
+ }
11
+
12
+ export function join(prefix: ts.Expression, name: string) {
13
+ const postfix = generate(name);
14
+ return ts.isStringLiteral(postfix)
15
+ ? ts.factory.createElementAccessExpression(prefix, postfix)
16
+ : ts.factory.createPropertyAccessExpression(prefix, postfix);
17
+ }
18
+
19
+ export function postfix(str: string): string {
20
+ return Escaper.variable(str)
21
+ ? `".${str}"`
22
+ : `"[${JSON.stringify(str).split('"').join('\\"')}]"`;
23
+ }
24
+
25
+ export function parameter(
26
+ name: string | ts.BindingName,
27
+ type?: ts.TypeNode,
28
+ init?: ts.Expression | ts.PunctuationToken<ts.SyntaxKind.QuestionToken>,
29
+ ) {
30
+ // instead of ts.version >= "4.8"
31
+ if (ts.getDecorators !== undefined)
32
+ return ts.factory.createParameterDeclaration(
33
+ undefined,
34
+ undefined,
35
+ name,
36
+ init?.kind === ts.SyntaxKind.QuestionToken
37
+ ? ts.factory.createToken(ts.SyntaxKind.QuestionToken)
38
+ : undefined,
39
+ type,
40
+ init && init.kind !== ts.SyntaxKind.QuestionToken
41
+ ? init
42
+ : undefined,
43
+ );
44
+ // eslint-disable-next-line
45
+ return (ts.factory.createParameterDeclaration as any)(
46
+ undefined,
47
+ undefined,
48
+ undefined,
49
+ name,
50
+ init?.kind === ts.SyntaxKind.QuestionToken
51
+ ? ts.factory.createToken(ts.SyntaxKind.QuestionToken)
52
+ : undefined,
53
+ type,
54
+ init && init.kind !== ts.SyntaxKind.QuestionToken
55
+ ? init
56
+ : undefined,
57
+ );
58
+ }
59
+ }