forked from YousefED/typescript-json-schema
-
Notifications
You must be signed in to change notification settings - Fork 0
/
typescript-json-schema-cli.ts
75 lines (72 loc) · 4.06 KB
/
typescript-json-schema-cli.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
import { exec, getDefaultArgs } from "./typescript-json-schema";
export function run() {
var helpText = "Usage: typescript-json-schema <path-to-typescript-files-or-tsconfig> <type>";
const defaultArgs = getDefaultArgs();
var args = require("yargs")
.usage(helpText)
.demand(2)
.boolean("refs").default("refs", defaultArgs.ref)
.describe("refs", "Create shared ref definitions.")
.boolean("aliasRefs").default("aliasRefs", defaultArgs.aliasRef)
.describe("aliasRefs", "Create shared ref definitions for the type aliases.")
.boolean("topRef").default("topRef", defaultArgs.topRef)
.describe("topRef", "Create a top-level ref definition.")
.boolean("titles").default("titles", defaultArgs.titles)
.describe("titles", "Creates titles in the output schema.")
.boolean("defaultProps").default("defaultProps", defaultArgs.defaultProps)
.describe("defaultProps", "Create default properties definitions.")
.boolean("noExtraProps").default("noExtraProps", defaultArgs.noExtraProps)
.describe("noExtraProps", "Disable additional properties in objects by default.")
.boolean("propOrder").default("propOrder", defaultArgs.propOrder)
.describe("propOrder", "Create property order definitions.")
.boolean("typeOfKeyword").default("typeOfKeyword", defaultArgs.typeOfKeyword)
.describe("typeOfKeyword", "Use typeOf keyword (https://goo.gl/DC6sni) for functions.")
.boolean("required").default("required", defaultArgs.required)
.describe("required", "Create required array for non-optional properties.")
.boolean("strictNullChecks").default("strictNullChecks", defaultArgs.strictNullChecks)
.describe("strictNullChecks", "Make values non-nullable by default.")
.boolean("ignoreErrors").default("ignoreErrors", defaultArgs.ignoreErrors)
.describe("ignoreErrors", "Generate even if the program has errors.")
.alias("out", "o")
.describe("out", "The output file, defaults to using stdout")
.array("validationKeywords").default("validationKeywords", defaultArgs.validationKeywords)
.describe("validationKeywords", "Provide additional validation keywords to include.")
.boolean("excludePrivate").default("excludePrivate", defaultArgs.excludePrivate)
.describe("excludePrivate", "Exclude private members from the schema.")
.boolean("uniqueNames").default("uniqueNames", defaultArgs.uniqueNames)
.describe("uniqueNames", "Use unique names for type symbols.")
.array("include").default("*", defaultArgs.include)
.describe("include", "Further limit tsconfig to include only matching files.")
.boolean("rejectDateType").default("rejectDateType", defaultArgs.rejectDateType)
.describe("rejectDateType", "Rejects Date fields in type definitions.")
.string("id").default("id", defaultArgs.id)
.describe("id", "ID of schema.")
.option("defaultNumberType").choices("defaultNumberType", ["number", "integer"])
.default("defaultNumberType", defaultArgs.defaultNumberType)
.describe("defaultNumberType", "Default number type.")
.argv;
exec(args._[0], args._[1], {
ref: args.refs,
aliasRef: args.aliasRefs,
topRef: args.topRef,
titles: args.titles,
defaultProps: args.defaultProps,
noExtraProps: args.noExtraProps,
propOrder: args.propOrder,
typeOfKeyword: args.useTypeOfKeyword,
required: args.required,
strictNullChecks: args.strictNullChecks,
ignoreErrors: args.ignoreErrors,
out: args.out,
validationKeywords: args.validationKeywords,
include: args.include,
excludePrivate: args.excludePrivate,
uniqueNames: args.uniqueNames,
rejectDateType: args.rejectDateType,
id: args.id,
defaultNumberType: args.defaultNumberType,
});
}
if (typeof window === "undefined" && require.main === module) {
run();
}