expand-my-type 0.1.0

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/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2024 Fardjad Davari
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,100 @@
1
+ # Expand My Type
2
+
3
+ <div class="paragraph">
4
+
5
+ <span class="image"><a href="https://www.npmjs.com/package/expand-my-type" class="image"><img src="https://img.shields.io/npm/v/expand-my-type" alt="NPM Version" /></a></span> <span class="image"><a href="https://www.npmjs.com/package/expand-my-type" class="image"><img src="https://img.shields.io/npm/dm/expand-my-type" alt="Monthly Downloads" /></a></span> <span class="image"><a href="https://github.com/fardjad/node-expand-my-type/actions" class="image"><img src="https://img.shields.io/github/actions/workflow/status/fardjad/node-expand-my-type/test-and-release.yml?branch=main" alt="test-and-release Workflow Status" /></a></span>
6
+
7
+ </div>
8
+
9
+ In TypeScript, expanding a type (also known as computing, resolving,
10
+ simplifying, unpacking, or unwrapping) refers to converting a type expression
11
+ into a flattened type that doesn't reference other types. That can be achieved
12
+ by defining [a utility type][compute-type]:
13
+
14
+ ```typescript
15
+ type Compute<A> = { [K in keyof A]: Compute<A[K]> } & {};
16
+ ```
17
+
18
+ And wrapping the type expression with it:
19
+
20
+ ```typescript
21
+ type ExpandedType = Compute<SomeType>;
22
+ ```
23
+
24
+ This is mostly done to improve the readability of type hints shown in editors/IDEs.
25
+
26
+ **Expand My Type** provides a programmatic way to do the same. It gets the
27
+ source code as input, along with a type expression and returns the expanded
28
+ form as a string. That can be useful for code-generation, testing, and debugging
29
+ complex type errors.
30
+
31
+ Under the hood, it uses the [TypeScript Compiler API][ts-compiler-api] to expand
32
+ the type expression and optionally formats the output using
33
+ [Prettier][prettier].
34
+
35
+ # Usage
36
+
37
+ This package exports a function named `expandMyType` that can be used in one of
38
+ the following ways:
39
+
40
+ 1. Expand the type expression in a source file:
41
+
42
+ Given a file named `example.ts` with the following content:
43
+
44
+ ```typescript
45
+ interface SomeInterface {
46
+ a: number;
47
+ b?: string;
48
+ c: number | undefined;
49
+ }
50
+
51
+ type SomeType = {
52
+ d: number;
53
+ e: SomeInterface;
54
+ f: () => void;
55
+ };
56
+ ```
57
+
58
+ Running the following code expands the type expression `SomeType`:
59
+
60
+ ```typescript
61
+ import { expandMyType } from "expand-my-type";
62
+
63
+ const expandedType = await expandMyType({
64
+ typeExpression: "SomeType",
65
+ sourceFileName: "./example.ts",
66
+ });
67
+
68
+ console.log(expandedType);
69
+ /* {
70
+ d: number
71
+ e: { a: number; b?: string; c: number }
72
+ f: {}
73
+ } */
74
+ ```
75
+
76
+ 2. Expand the type expression in a source text:
77
+
78
+ ```typescript
79
+ import { expandMyType } from "expand-my-type";
80
+
81
+ const expandedType = await expandMyType({
82
+ typeExpression: "A<number>",
83
+ sourceText: `
84
+ type A<T> = {
85
+ a: string;
86
+ } & B<T>;
87
+
88
+ type B<T> = {
89
+ b: T;
90
+ };
91
+ `,
92
+ });
93
+
94
+ console.log(expandedType);
95
+ /* { a: string; b: number } */
96
+ ```
97
+
98
+ [compute-type]: https://github.com/microsoft/TypeScript/blob/main/tests/cases/compiler/computedTypesKeyofNoIndexSignatureType.ts
99
+ [prettier]: https://prettier.io
100
+ [ts-compiler-api]: https://github.com/microsoft/TypeScript/wiki/Using-the-Compiler-API
package/dist/index.cjs ADDED
@@ -0,0 +1,150 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+
29
+ // src/index.ts
30
+ var src_exports = {};
31
+ __export(src_exports, {
32
+ expandMyType: () => expandMyType
33
+ });
34
+ module.exports = __toCommonJS(src_exports);
35
+
36
+ // src/create-expander-compiler-host.ts
37
+ var import_typescript = __toESM(require("typescript"), 1);
38
+ var createExpanderCompilerHost = (sourceFileName, typeExpression, compilerOptions, getSourceFileFunction) => {
39
+ const customCompilerHost = import_typescript.default.createCompilerHost(compilerOptions ?? {});
40
+ const originalGetSourceFile = customCompilerHost.getSourceFile;
41
+ customCompilerHost.getSourceFile = (fileName, ...args) => {
42
+ if (fileName === sourceFileName) {
43
+ const sourceFile = (getSourceFileFunction ?? originalGetSourceFile)(
44
+ fileName,
45
+ ...args
46
+ );
47
+ if (sourceFile === void 0) {
48
+ return void 0;
49
+ }
50
+ const sourceText = [
51
+ ...[
52
+ "type __TYPE_EXPANDER_RESULT__ = __TYPE_EXPANDER_EXPAND__<__TYPE_EXPANDER_EXPRESSION__>;",
53
+ `type __TYPE_EXPANDER_EXPRESSION__ = ${typeExpression};`,
54
+ "type __TYPE_EXPANDER_EXPAND__<T> = {",
55
+ " [K in keyof T]: __TYPE_EXPANDER_EXPAND__<T[K]>;",
56
+ "} & {};"
57
+ ],
58
+ sourceFile.getFullText()
59
+ ].join("\n");
60
+ return import_typescript.default.createSourceFile(
61
+ fileName,
62
+ sourceText,
63
+ sourceFile.languageVersion,
64
+ true
65
+ );
66
+ }
67
+ return originalGetSourceFile(fileName, ...args);
68
+ };
69
+ return customCompilerHost;
70
+ };
71
+
72
+ // src/index.ts
73
+ var import_prettier = require("prettier");
74
+ var import_typescript2 = __toESM(require("typescript"), 1);
75
+ var findTypeExpanderResultNode = (node) => {
76
+ if (node.getChildCount() == 0) {
77
+ if (!import_typescript2.default.isIdentifier(node)) {
78
+ return void 0;
79
+ }
80
+ return node;
81
+ }
82
+ return import_typescript2.default.forEachChild(node, findTypeExpanderResultNode);
83
+ };
84
+ async function expandMyType(options) {
85
+ if (options.typeExpression.trim() === "") {
86
+ return "never";
87
+ }
88
+ if ("sourceText" in options) {
89
+ const sourceFile2 = import_typescript2.default.createSourceFile(
90
+ "test.ts",
91
+ options.sourceText,
92
+ import_typescript2.default.ScriptTarget.Latest,
93
+ true
94
+ );
95
+ return expandMyType({
96
+ sourceFileName: "test.ts",
97
+ typeExpression: options.typeExpression,
98
+ getSourceFileFunction: () => sourceFile2,
99
+ tsCompilerOptions: options.tsCompilerOptions
100
+ });
101
+ }
102
+ const tsCompilerOptions = options.tsCompilerOptions ?? {
103
+ noEmit: true,
104
+ allowSyntheticDefaultImports: true,
105
+ allowArbitraryExtensions: true,
106
+ allowImportingTsExtensions: true,
107
+ allowJs: true
108
+ };
109
+ const compilerHost = createExpanderCompilerHost(
110
+ options.sourceFileName,
111
+ options.typeExpression,
112
+ tsCompilerOptions,
113
+ options.getSourceFileFunction
114
+ );
115
+ const program = import_typescript2.default.createProgram(
116
+ [options.sourceFileName],
117
+ tsCompilerOptions,
118
+ compilerHost
119
+ );
120
+ const sourceFile = program.getSourceFile(options.sourceFileName);
121
+ if (!sourceFile) {
122
+ throw new Error("Source file not found!");
123
+ }
124
+ const firstIdentifier = findTypeExpanderResultNode(sourceFile);
125
+ if (!firstIdentifier) {
126
+ throw new Error("No node found!");
127
+ }
128
+ const typeChecker = program.getTypeChecker();
129
+ const expandedType = typeChecker.typeToString(
130
+ typeChecker.getTypeAtLocation(firstIdentifier),
131
+ void 0,
132
+ import_typescript2.default.TypeFormatFlags.NodeBuilderFlagsMask
133
+ );
134
+ if (options.prettify && options.prettify.enabled === false) {
135
+ return expandedType;
136
+ }
137
+ const dummyTypeName = "__TYPE_EXPANDER_RESULT__";
138
+ return (await (0, import_prettier.format)(
139
+ `type ${dummyTypeName} = ${expandedType}`,
140
+ options.prettify?.options ?? {
141
+ parser: "typescript",
142
+ semi: false
143
+ }
144
+ )).trim().substring(`type ${dummyTypeName} = `.length);
145
+ }
146
+ // Annotate the CommonJS export names for ESM import in node:
147
+ 0 && (module.exports = {
148
+ expandMyType
149
+ });
150
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2luZGV4LnRzIiwgIi4uL3NyYy9jcmVhdGUtZXhwYW5kZXItY29tcGlsZXItaG9zdC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHsgY3JlYXRlRXhwYW5kZXJDb21waWxlckhvc3QgfSBmcm9tIFwiLi9jcmVhdGUtZXhwYW5kZXItY29tcGlsZXItaG9zdC50c1wiO1xuaW1wb3J0IHsgZm9ybWF0LCB0eXBlIE9wdGlvbnMgYXMgUHJldHRpZXJPcHRpb25zIH0gZnJvbSBcInByZXR0aWVyXCI7XG5pbXBvcnQgdHMgZnJvbSBcInR5cGVzY3JpcHRcIjtcblxuLyoqXG4gKiBGaW5kcyB0aGUgbm9kZSB0aGF0IHJlcHJlc2VudHMgdGhlIFRZUEVfRVhQQU5ERVJfUkVTVUxUIHR5cGUuXG4gKlxuICogQHBhcmFtIG5vZGUgTm9kZSBpbiB3aGljaCB0aGUgVFlQRV9FWFBBTkRFUl9SRVNVTFQgdHlwZSBzaG91bGQgYmUgc2VhcmNoZWQuXG4gKiBAcmV0dXJucyBUaGUgbm9kZSB0aGF0IHJlcHJlc2VudHMgdGhlIFRZUEVfRVhQQU5ERVJfUkVTVUxUIHR5cGUuXG4gKi9cbmNvbnN0IGZpbmRUeXBlRXhwYW5kZXJSZXN1bHROb2RlID0gKG5vZGU6IHRzLk5vZGUpOiB0cy5Ob2RlIHwgdW5kZWZpbmVkID0+IHtcbiAgaWYgKG5vZGUuZ2V0Q2hpbGRDb3VudCgpID09IDApIHtcbiAgICBpZiAoIXRzLmlzSWRlbnRpZmllcihub2RlKSkge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG5cbiAgICAvLyBTaW5jZSB3ZSBwdXQgdGhlIF9fVFlQRV9FWFBBTkRFUl9SRVNVTFRfXyB0eXBlIGF0IHRoZSBiZWdpbm5pbmcgb2YgdGhlXG4gICAgLy8gZmlsZSwgd2UgY2FuIHJldHVybiB0aGUgZmlyc3QgaWRlbnRpZmllciB3ZSBmaW5kLlxuICAgIHJldHVybiBub2RlO1xuICB9XG5cbiAgcmV0dXJuIHRzLmZvckVhY2hDaGlsZChub2RlLCBmaW5kVHlwZUV4cGFuZGVyUmVzdWx0Tm9kZSk7XG59O1xuXG5leHBvcnQgdHlwZSBFeHBhbmRUeXBlT3B0aW9uc0Jhc2UgPSB7XG4gIC8qKlxuICAgKiBUaGUgdHlwZSBleHByZXNzaW9uIHRvIGV4cGFuZC5cbiAgICogQGV4YW1wbGUgXCJSZXR1cm5UeXBlPHR5cGVvZiBteUZ1bmN0aW9uPlwiXG4gICAqL1xuICB0eXBlRXhwcmVzc2lvbjogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUeXBlU2NyaXB0IGNvbXBpbGVyIG9wdGlvbnMuXG4gICAqL1xuICB0c0NvbXBpbGVyT3B0aW9ucz86IHRzLkNvbXBpbGVyT3B0aW9ucztcblxuICAvKipcbiAgICogUHJldHRpZXIgb3B0aW9ucy5cbiAgICovXG4gIHByZXR0aWZ5Pzoge1xuICAgIC8qKlxuICAgICAqIFdoZXRoZXIgdG8gcHJldHRpZnkgdGhlIG91dHB1dC5cbiAgICAgKiBAZGVmYXVsdCB0cnVlXG4gICAgICovXG4gICAgZW5hYmxlZD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogUHJldHRpZXIgb3B0aW9ucy4gRG9uJ3QgZm9yZ2V0IHRvIHNldCB0aGUgcGFyc2VyIHRvIFwidHlwZXNjcmlwdFwiLlxuICAgICAqIEBkZWZhdWx0IHsgcGFyc2VyOiBcInR5cGVzY3JpcHRcIiwgc2VtaTogZmFsc2UgfVxuICAgICAqL1xuICAgIG9wdGlvbnM/OiBQcmV0dGllck9wdGlvbnM7XG4gIH07XG59O1xuZXhwb3J0IHR5cGUgRXhwYW5kVHlwZUZyb21Tb3VyY2VGaWxlT3B0aW9ucyA9IEV4cGFuZFR5cGVPcHRpb25zQmFzZSAmIHtcbiAgLyoqXG4gICAqIE5hbWUgb2YgdGhlIHNvdXJjZSBmaWxlIHRvIGV2YWx1YXRlIHRoZSB0eXBlIGV4cHJlc3Npb24gaW4uXG4gICAqL1xuICBzb3VyY2VGaWxlTmFtZTogc3RyaW5nO1xuICAvKipcbiAgICogRnVuY3Rpb24gdGhhdCByZXR1cm5zIHRoZSBzb3VyY2UgZmlsZS4gV2hlbiBub3Qgc3BlY2lmaWVkLCB0aGUgaW1wbGVtZW50YXRpb24gb2YgdGhlIGRlZmF1bHQgVHlwZVNjcmlwdCBjb21waWxlciBob3N0IGlzIHVzZWQuXG4gICAqL1xuICBnZXRTb3VyY2VGaWxlRnVuY3Rpb24/OiB0cy5Db21waWxlckhvc3RbXCJnZXRTb3VyY2VGaWxlXCJdO1xufTtcbmV4cG9ydCB0eXBlIEV4cGFuZFR5cGVGcm9tU291cmNlVGV4dE9wdGlvbnMgPSBFeHBhbmRUeXBlT3B0aW9uc0Jhc2UgJiB7XG4gIC8qKlxuICAgKiBUeXBlU2NyaXB0IHNvdXJjZSB0ZXh0IHRvIGV2YWx1YXRlIHRoZSB0eXBlIGV4cHJlc3Npb24gaW4uXG4gICAqL1xuICBzb3VyY2VUZXh0OiBzdHJpbmc7XG59O1xuZXhwb3J0IHR5cGUgRXhwYW5kTXlUeXBlT3B0aW9ucyA9XG4gIHwgRXhwYW5kVHlwZUZyb21Tb3VyY2VGaWxlT3B0aW9uc1xuICB8IEV4cGFuZFR5cGVGcm9tU291cmNlVGV4dE9wdGlvbnM7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBleHBhbmRNeVR5cGUoXG4gIG9wdGlvbnM6IEV4cGFuZFR5cGVGcm9tU291cmNlVGV4dE9wdGlvbnMsXG4pOiBQcm9taXNlPHN0cmluZz47XG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZXhwYW5kTXlUeXBlKFxuICBvcHRpb25zOiBFeHBhbmRUeXBlRnJvbVNvdXJjZUZpbGVPcHRpb25zLFxuKTogUHJvbWlzZTxzdHJpbmc+O1xuXG4vKipcbiAqIEV4cGFuZHMgYSBUeXBlU2NyaXB0IHR5cGUgZXhwcmVzc2lvbi5cbiAqXG4gKiBAcGFyYW0gb3B0aW9uc1xuICogQHJldHVybnMgVGhlIGV4cGFuZGVkIHR5cGUgZXhwcmVzc2lvbi5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGV4cGFuZE15VHlwZShvcHRpb25zOiBFeHBhbmRNeVR5cGVPcHRpb25zKSB7XG4gIGlmIChvcHRpb25zLnR5cGVFeHByZXNzaW9uLnRyaW0oKSA9PT0gXCJcIikge1xuICAgIHJldHVybiBcIm5ldmVyXCI7XG4gIH1cblxuICBpZiAoXCJzb3VyY2VUZXh0XCIgaW4gb3B0aW9ucykge1xuICAgIGNvbnN0IHNvdXJjZUZpbGUgPSB0cy5jcmVhdGVTb3VyY2VGaWxlKFxuICAgICAgXCJ0ZXN0LnRzXCIsXG4gICAgICBvcHRpb25zLnNvdXJjZVRleHQsXG4gICAgICB0cy5TY3JpcHRUYXJnZXQuTGF0ZXN0LFxuICAgICAgdHJ1ZSxcbiAgICApO1xuXG4gICAgcmV0dXJuIGV4cGFuZE15VHlwZSh7XG4gICAgICBzb3VyY2VGaWxlTmFtZTogXCJ0ZXN0LnRzXCIsXG4gICAgICB0eXBlRXhwcmVzc2lvbjogb3B0aW9ucy50eXBlRXhwcmVzc2lvbixcbiAgICAgIGdldFNvdXJjZUZpbGVGdW5jdGlvbjogKCkgPT4gc291cmNlRmlsZSxcbiAgICAgIHRzQ29tcGlsZXJPcHRpb25zOiBvcHRpb25zLnRzQ29tcGlsZXJPcHRpb25zLFxuICAgIH0pO1xuICB9XG5cbiAgY29uc3QgdHNDb21waWxlck9wdGlvbnMgPSBvcHRpb25zLnRzQ29tcGlsZXJPcHRpb25zID8/IHtcbiAgICBub0VtaXQ6IHRydWUsXG5cbiAgICBhbGxvd1N5bnRoZXRpY0RlZmF1bHRJbXBvcnRzOiB0cnVlLFxuICAgIGFsbG93QXJiaXRyYXJ5RXh0ZW5zaW9uczogdHJ1ZSxcbiAgICBhbGxvd0ltcG9ydGluZ1RzRXh0ZW5zaW9uczogdHJ1ZSxcbiAgICBhbGxvd0pzOiB0cnVlLFxuICB9O1xuXG4gIGNvbnN0IGNvbXBpbGVySG9zdCA9IGNyZWF0ZUV4cGFuZGVyQ29tcGlsZXJIb3N0KFxuICAgIG9wdGlvbnMuc291cmNlRmlsZU5hbWUsXG4gICAgb3B0aW9ucy50eXBlRXhwcmVzc2lvbixcbiAgICB0c0NvbXBpbGVyT3B0aW9ucyxcbiAgICBvcHRpb25zLmdldFNvdXJjZUZpbGVGdW5jdGlvbixcbiAgKTtcblxuICBjb25zdCBwcm9ncmFtID0gdHMuY3JlYXRlUHJvZ3JhbShcbiAgICBbb3B0aW9ucy5zb3VyY2VGaWxlTmFtZV0sXG4gICAgdHNDb21waWxlck9wdGlvbnMsXG4gICAgY29tcGlsZXJIb3N0LFxuICApO1xuXG4gIGNvbnN0IHNvdXJjZUZpbGUgPSBwcm9ncmFtLmdldFNvdXJjZUZpbGUob3B0aW9ucy5zb3VyY2VGaWxlTmFtZSk7XG4gIGlmICghc291cmNlRmlsZSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIlNvdXJjZSBmaWxlIG5vdCBmb3VuZCFcIik7XG4gIH1cblxuICBjb25zdCBmaXJzdElkZW50aWZpZXIgPSBmaW5kVHlwZUV4cGFuZGVyUmVzdWx0Tm9kZShzb3VyY2VGaWxlKTtcbiAgaWYgKCFmaXJzdElkZW50aWZpZXIpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXCJObyBub2RlIGZvdW5kIVwiKTtcbiAgfVxuXG4gIGNvbnN0IHR5cGVDaGVja2VyID0gcHJvZ3JhbS5nZXRUeXBlQ2hlY2tlcigpO1xuICBjb25zdCBleHBhbmRlZFR5cGUgPSB0eXBlQ2hlY2tlci50eXBlVG9TdHJpbmcoXG4gICAgdHlwZUNoZWNrZXIuZ2V0VHlwZUF0TG9jYXRpb24oZmlyc3RJZGVudGlmaWVyKSxcbiAgICB1bmRlZmluZWQsXG4gICAgdHMuVHlwZUZvcm1hdEZsYWdzLk5vZGVCdWlsZGVyRmxhZ3NNYXNrLFxuICApO1xuXG4gIGlmIChvcHRpb25zLnByZXR0aWZ5ICYmIG9wdGlvbnMucHJldHRpZnkuZW5hYmxlZCA9PT0gZmFsc2UpIHtcbiAgICByZXR1cm4gZXhwYW5kZWRUeXBlO1xuICB9XG5cbiAgY29uc3QgZHVtbXlUeXBlTmFtZSA9IFwiX19UWVBFX0VYUEFOREVSX1JFU1VMVF9fXCI7XG5cbiAgcmV0dXJuIChcbiAgICBhd2FpdCBmb3JtYXQoXG4gICAgICBgdHlwZSAke2R1bW15VHlwZU5hbWV9ID0gJHtleHBhbmRlZFR5cGV9YCxcbiAgICAgIG9wdGlvbnMucHJldHRpZnk/Lm9wdGlvbnMgPz8ge1xuICAgICAgICBwYXJzZXI6IFwidHlwZXNjcmlwdFwiLFxuICAgICAgICBzZW1pOiBmYWxzZSxcbiAgICAgIH0sXG4gICAgKVxuICApXG4gICAgLnRyaW0oKVxuICAgIC5zdWJzdHJpbmcoYHR5cGUgJHtkdW1teVR5cGVOYW1lfSA9IGAubGVuZ3RoKTtcbn1cbiIsICJpbXBvcnQgdHMgZnJvbSBcInR5cGVzY3JpcHRcIjtcblxuLyoqXG4gKiBDcmVhdGVzIGEgY3VzdG9tIGNvbXBpbGVyIGhvc3QgdGhhdCBhdWdtZW50cyB0aGUgc3BlY2lmaWVkIHNvdXJjZSBmaWxlIGZvciBleHBhbmRpbmcgYSB0eXBlIGV4cHJlc3Npb24uXG4gKlxuICogQHBhcmFtIHNvdXJjZUZpbGVOYW1lIE5hbWUgb2YgdGhlIHNvdXJjZSBmaWxlIHRvIGF1Z21lbnQuXG4gKiBAcGFyYW0gdHlwZUV4cHJlc3Npb24gVHlwZSBleHByZXNzaW9uLlxuICogQHBhcmFtIGNvbXBpbGVyT3B0aW9ucyBUeXBlU2NyaXB0IGNvbXBpbGVyIG9wdGlvbnMuXG4gKiBAcGFyYW0gZ2V0U291cmNlRmlsZUZ1bmN0aW9uIFRoZSBpbXBsZW1lbnRhdGlvbiBvZiB0aGUgYHRzLkNvbXBpbGVySG9zdFtcImdldFNvdXJjZUZpbGVcIl1gIGZ1bmN0aW9uLlxuICogQHJldHVybnMgQSBjdXN0b20gY29tcGlsZXIgaG9zdCB0aGF0IHJldHVybnMgYW4gYXVnbWVudGVkIHNvdXJjZSBmaWxlIHRoYXQgY2FuIGJlIHVzZWQgdG8gZXhwYW5kIHRoZSB0eXBlIGV4cHJlc3Npb24uXG4gKi9cbmV4cG9ydCBjb25zdCBjcmVhdGVFeHBhbmRlckNvbXBpbGVySG9zdCA9IChcbiAgc291cmNlRmlsZU5hbWU6IHN0cmluZyxcbiAgdHlwZUV4cHJlc3Npb246IHN0cmluZyxcbiAgY29tcGlsZXJPcHRpb25zPzogdHMuQ29tcGlsZXJPcHRpb25zLFxuICBnZXRTb3VyY2VGaWxlRnVuY3Rpb24/OiB0cy5Db21waWxlckhvc3RbXCJnZXRTb3VyY2VGaWxlXCJdLFxuKSA9PiB7XG4gIGNvbnN0IGN1c3RvbUNvbXBpbGVySG9zdCA9IHRzLmNyZWF0ZUNvbXBpbGVySG9zdChjb21waWxlck9wdGlvbnMgPz8ge30pO1xuICBjb25zdCBvcmlnaW5hbEdldFNvdXJjZUZpbGUgPSBjdXN0b21Db21waWxlckhvc3QuZ2V0U291cmNlRmlsZTtcblxuICBjdXN0b21Db21waWxlckhvc3QuZ2V0U291cmNlRmlsZSA9IChmaWxlTmFtZSwgLi4uYXJncykgPT4ge1xuICAgIGlmIChmaWxlTmFtZSA9PT0gc291cmNlRmlsZU5hbWUpIHtcbiAgICAgIGNvbnN0IHNvdXJjZUZpbGUgPSAoZ2V0U291cmNlRmlsZUZ1bmN0aW9uID8/IG9yaWdpbmFsR2V0U291cmNlRmlsZSkoXG4gICAgICAgIGZpbGVOYW1lLFxuICAgICAgICAuLi5hcmdzLFxuICAgICAgKTtcblxuICAgICAgaWYgKHNvdXJjZUZpbGUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBzb3VyY2VUZXh0ID0gW1xuICAgICAgICAuLi5bXG4gICAgICAgICAgXCJ0eXBlIF9fVFlQRV9FWFBBTkRFUl9SRVNVTFRfXyA9IF9fVFlQRV9FWFBBTkRFUl9FWFBBTkRfXzxfX1RZUEVfRVhQQU5ERVJfRVhQUkVTU0lPTl9fPjtcIixcbiAgICAgICAgICBgdHlwZSBfX1RZUEVfRVhQQU5ERVJfRVhQUkVTU0lPTl9fID0gJHt0eXBlRXhwcmVzc2lvbn07YCxcbiAgICAgICAgICBcInR5cGUgX19UWVBFX0VYUEFOREVSX0VYUEFORF9fPFQ+ID0ge1wiLFxuICAgICAgICAgIFwiICBbSyBpbiBrZXlvZiBUXTogX19UWVBFX0VYUEFOREVSX0VYUEFORF9fPFRbS10+O1wiLFxuICAgICAgICAgIFwifSAmIHt9O1wiLFxuICAgICAgICBdLFxuICAgICAgICBzb3VyY2VGaWxlLmdldEZ1bGxUZXh0KCksXG4gICAgICBdLmpvaW4oXCJcXG5cIik7XG5cbiAgICAgIHJldHVybiB0cy5jcmVhdGVTb3VyY2VGaWxlKFxuICAgICAgICBmaWxlTmFtZSxcbiAgICAgICAgc291cmNlVGV4dCxcbiAgICAgICAgc291cmNlRmlsZS5sYW5ndWFnZVZlcnNpb24sXG4gICAgICAgIHRydWUsXG4gICAgICApO1xuICAgIH1cblxuICAgIHJldHVybiBvcmlnaW5hbEdldFNvdXJjZUZpbGUoZmlsZU5hbWUsIC4uLmFyZ3MpO1xuICB9O1xuXG4gIHJldHVybiBjdXN0b21Db21waWxlckhvc3Q7XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOzs7QUNBQSx3QkFBZTtBQVdSLElBQU0sNkJBQTZCLENBQ3hDLGdCQUNBLGdCQUNBLGlCQUNBLDBCQUNHO0FBQ0gsUUFBTSxxQkFBcUIsa0JBQUFBLFFBQUcsbUJBQW1CLG1CQUFtQixDQUFDLENBQUM7QUFDdEUsUUFBTSx3QkFBd0IsbUJBQW1CO0FBRWpELHFCQUFtQixnQkFBZ0IsQ0FBQyxhQUFhLFNBQVM7QUFDeEQsUUFBSSxhQUFhLGdCQUFnQjtBQUMvQixZQUFNLGNBQWMseUJBQXlCO0FBQUEsUUFDM0M7QUFBQSxRQUNBLEdBQUc7QUFBQSxNQUNMO0FBRUEsVUFBSSxlQUFlLFFBQVc7QUFDNUIsZUFBTztBQUFBLE1BQ1Q7QUFFQSxZQUFNLGFBQWE7QUFBQSxRQUNqQixHQUFHO0FBQUEsVUFDRDtBQUFBLFVBQ0EsdUNBQXVDLGNBQWM7QUFBQSxVQUNyRDtBQUFBLFVBQ0E7QUFBQSxVQUNBO0FBQUEsUUFDRjtBQUFBLFFBQ0EsV0FBVyxZQUFZO0FBQUEsTUFDekIsRUFBRSxLQUFLLElBQUk7QUFFWCxhQUFPLGtCQUFBQSxRQUFHO0FBQUEsUUFDUjtBQUFBLFFBQ0E7QUFBQSxRQUNBLFdBQVc7QUFBQSxRQUNYO0FBQUEsTUFDRjtBQUFBLElBQ0Y7QUFFQSxXQUFPLHNCQUFzQixVQUFVLEdBQUcsSUFBSTtBQUFBLEVBQ2hEO0FBRUEsU0FBTztBQUNUOzs7QURyREEsc0JBQXdEO0FBQ3hELElBQUFDLHFCQUFlO0FBUWYsSUFBTSw2QkFBNkIsQ0FBQyxTQUF1QztBQUN6RSxNQUFJLEtBQUssY0FBYyxLQUFLLEdBQUc7QUFDN0IsUUFBSSxDQUFDLG1CQUFBQyxRQUFHLGFBQWEsSUFBSSxHQUFHO0FBQzFCLGFBQU87QUFBQSxJQUNUO0FBSUEsV0FBTztBQUFBLEVBQ1Q7QUFFQSxTQUFPLG1CQUFBQSxRQUFHLGFBQWEsTUFBTSwwQkFBMEI7QUFDekQ7QUErREEsZUFBc0IsYUFBYSxTQUE4QjtBQUMvRCxNQUFJLFFBQVEsZUFBZSxLQUFLLE1BQU0sSUFBSTtBQUN4QyxXQUFPO0FBQUEsRUFDVDtBQUVBLE1BQUksZ0JBQWdCLFNBQVM7QUFDM0IsVUFBTUMsY0FBYSxtQkFBQUQsUUFBRztBQUFBLE1BQ3BCO0FBQUEsTUFDQSxRQUFRO0FBQUEsTUFDUixtQkFBQUEsUUFBRyxhQUFhO0FBQUEsTUFDaEI7QUFBQSxJQUNGO0FBRUEsV0FBTyxhQUFhO0FBQUEsTUFDbEIsZ0JBQWdCO0FBQUEsTUFDaEIsZ0JBQWdCLFFBQVE7QUFBQSxNQUN4Qix1QkFBdUIsTUFBTUM7QUFBQSxNQUM3QixtQkFBbUIsUUFBUTtBQUFBLElBQzdCLENBQUM7QUFBQSxFQUNIO0FBRUEsUUFBTSxvQkFBb0IsUUFBUSxxQkFBcUI7QUFBQSxJQUNyRCxRQUFRO0FBQUEsSUFFUiw4QkFBOEI7QUFBQSxJQUM5QiwwQkFBMEI7QUFBQSxJQUMxQiw0QkFBNEI7QUFBQSxJQUM1QixTQUFTO0FBQUEsRUFDWDtBQUVBLFFBQU0sZUFBZTtBQUFBLElBQ25CLFFBQVE7QUFBQSxJQUNSLFFBQVE7QUFBQSxJQUNSO0FBQUEsSUFDQSxRQUFRO0FBQUEsRUFDVjtBQUVBLFFBQU0sVUFBVSxtQkFBQUQsUUFBRztBQUFBLElBQ2pCLENBQUMsUUFBUSxjQUFjO0FBQUEsSUFDdkI7QUFBQSxJQUNBO0FBQUEsRUFDRjtBQUVBLFFBQU0sYUFBYSxRQUFRLGNBQWMsUUFBUSxjQUFjO0FBQy9ELE1BQUksQ0FBQyxZQUFZO0FBQ2YsVUFBTSxJQUFJLE1BQU0sd0JBQXdCO0FBQUEsRUFDMUM7QUFFQSxRQUFNLGtCQUFrQiwyQkFBMkIsVUFBVTtBQUM3RCxNQUFJLENBQUMsaUJBQWlCO0FBQ3BCLFVBQU0sSUFBSSxNQUFNLGdCQUFnQjtBQUFBLEVBQ2xDO0FBRUEsUUFBTSxjQUFjLFFBQVEsZUFBZTtBQUMzQyxRQUFNLGVBQWUsWUFBWTtBQUFBLElBQy9CLFlBQVksa0JBQWtCLGVBQWU7QUFBQSxJQUM3QztBQUFBLElBQ0EsbUJBQUFBLFFBQUcsZ0JBQWdCO0FBQUEsRUFDckI7QUFFQSxNQUFJLFFBQVEsWUFBWSxRQUFRLFNBQVMsWUFBWSxPQUFPO0FBQzFELFdBQU87QUFBQSxFQUNUO0FBRUEsUUFBTSxnQkFBZ0I7QUFFdEIsVUFDRSxVQUFNO0FBQUEsSUFDSixRQUFRLGFBQWEsTUFBTSxZQUFZO0FBQUEsSUFDdkMsUUFBUSxVQUFVLFdBQVc7QUFBQSxNQUMzQixRQUFRO0FBQUEsTUFDUixNQUFNO0FBQUEsSUFDUjtBQUFBLEVBQ0YsR0FFQyxLQUFLLEVBQ0wsVUFBVSxRQUFRLGFBQWEsTUFBTSxNQUFNO0FBQ2hEOyIsCiAgIm5hbWVzIjogWyJ0cyIsICJpbXBvcnRfdHlwZXNjcmlwdCIsICJ0cyIsICJzb3VyY2VGaWxlIl0KfQo=
@@ -0,0 +1,50 @@
1
+ import { Options } from 'prettier';
2
+ import ts from 'typescript';
3
+
4
+ type ExpandTypeOptionsBase = {
5
+ /**
6
+ * The type expression to expand.
7
+ * @example "ReturnType<typeof myFunction>"
8
+ */
9
+ typeExpression: string;
10
+ /**
11
+ * TypeScript compiler options.
12
+ */
13
+ tsCompilerOptions?: ts.CompilerOptions;
14
+ /**
15
+ * Prettier options.
16
+ */
17
+ prettify?: {
18
+ /**
19
+ * Whether to prettify the output.
20
+ * @default true
21
+ */
22
+ enabled?: boolean;
23
+ /**
24
+ * Prettier options. Don't forget to set the parser to "typescript".
25
+ * @default { parser: "typescript", semi: false }
26
+ */
27
+ options?: Options;
28
+ };
29
+ };
30
+ type ExpandTypeFromSourceFileOptions = ExpandTypeOptionsBase & {
31
+ /**
32
+ * Name of the source file to evaluate the type expression in.
33
+ */
34
+ sourceFileName: string;
35
+ /**
36
+ * Function that returns the source file. When not specified, the implementation of the default TypeScript compiler host is used.
37
+ */
38
+ getSourceFileFunction?: ts.CompilerHost["getSourceFile"];
39
+ };
40
+ type ExpandTypeFromSourceTextOptions = ExpandTypeOptionsBase & {
41
+ /**
42
+ * TypeScript source text to evaluate the type expression in.
43
+ */
44
+ sourceText: string;
45
+ };
46
+ type ExpandMyTypeOptions = ExpandTypeFromSourceFileOptions | ExpandTypeFromSourceTextOptions;
47
+ declare function expandMyType(options: ExpandTypeFromSourceTextOptions): Promise<string>;
48
+ declare function expandMyType(options: ExpandTypeFromSourceFileOptions): Promise<string>;
49
+
50
+ export { type ExpandMyTypeOptions, type ExpandTypeFromSourceFileOptions, type ExpandTypeFromSourceTextOptions, type ExpandTypeOptionsBase, expandMyType };
@@ -0,0 +1,50 @@
1
+ import { Options } from 'prettier';
2
+ import ts from 'typescript';
3
+
4
+ type ExpandTypeOptionsBase = {
5
+ /**
6
+ * The type expression to expand.
7
+ * @example "ReturnType<typeof myFunction>"
8
+ */
9
+ typeExpression: string;
10
+ /**
11
+ * TypeScript compiler options.
12
+ */
13
+ tsCompilerOptions?: ts.CompilerOptions;
14
+ /**
15
+ * Prettier options.
16
+ */
17
+ prettify?: {
18
+ /**
19
+ * Whether to prettify the output.
20
+ * @default true
21
+ */
22
+ enabled?: boolean;
23
+ /**
24
+ * Prettier options. Don't forget to set the parser to "typescript".
25
+ * @default { parser: "typescript", semi: false }
26
+ */
27
+ options?: Options;
28
+ };
29
+ };
30
+ type ExpandTypeFromSourceFileOptions = ExpandTypeOptionsBase & {
31
+ /**
32
+ * Name of the source file to evaluate the type expression in.
33
+ */
34
+ sourceFileName: string;
35
+ /**
36
+ * Function that returns the source file. When not specified, the implementation of the default TypeScript compiler host is used.
37
+ */
38
+ getSourceFileFunction?: ts.CompilerHost["getSourceFile"];
39
+ };
40
+ type ExpandTypeFromSourceTextOptions = ExpandTypeOptionsBase & {
41
+ /**
42
+ * TypeScript source text to evaluate the type expression in.
43
+ */
44
+ sourceText: string;
45
+ };
46
+ type ExpandMyTypeOptions = ExpandTypeFromSourceFileOptions | ExpandTypeFromSourceTextOptions;
47
+ declare function expandMyType(options: ExpandTypeFromSourceTextOptions): Promise<string>;
48
+ declare function expandMyType(options: ExpandTypeFromSourceFileOptions): Promise<string>;
49
+
50
+ export { type ExpandMyTypeOptions, type ExpandTypeFromSourceFileOptions, type ExpandTypeFromSourceTextOptions, type ExpandTypeOptionsBase, expandMyType };
package/dist/index.js ADDED
@@ -0,0 +1,114 @@
1
+ // src/create-expander-compiler-host.ts
2
+ import ts from "typescript";
3
+ var createExpanderCompilerHost = (sourceFileName, typeExpression, compilerOptions, getSourceFileFunction) => {
4
+ const customCompilerHost = ts.createCompilerHost(compilerOptions ?? {});
5
+ const originalGetSourceFile = customCompilerHost.getSourceFile;
6
+ customCompilerHost.getSourceFile = (fileName, ...args) => {
7
+ if (fileName === sourceFileName) {
8
+ const sourceFile = (getSourceFileFunction ?? originalGetSourceFile)(
9
+ fileName,
10
+ ...args
11
+ );
12
+ if (sourceFile === void 0) {
13
+ return void 0;
14
+ }
15
+ const sourceText = [
16
+ ...[
17
+ "type __TYPE_EXPANDER_RESULT__ = __TYPE_EXPANDER_EXPAND__<__TYPE_EXPANDER_EXPRESSION__>;",
18
+ `type __TYPE_EXPANDER_EXPRESSION__ = ${typeExpression};`,
19
+ "type __TYPE_EXPANDER_EXPAND__<T> = {",
20
+ " [K in keyof T]: __TYPE_EXPANDER_EXPAND__<T[K]>;",
21
+ "} & {};"
22
+ ],
23
+ sourceFile.getFullText()
24
+ ].join("\n");
25
+ return ts.createSourceFile(
26
+ fileName,
27
+ sourceText,
28
+ sourceFile.languageVersion,
29
+ true
30
+ );
31
+ }
32
+ return originalGetSourceFile(fileName, ...args);
33
+ };
34
+ return customCompilerHost;
35
+ };
36
+
37
+ // src/index.ts
38
+ import { format } from "prettier";
39
+ import ts2 from "typescript";
40
+ var findTypeExpanderResultNode = (node) => {
41
+ if (node.getChildCount() == 0) {
42
+ if (!ts2.isIdentifier(node)) {
43
+ return void 0;
44
+ }
45
+ return node;
46
+ }
47
+ return ts2.forEachChild(node, findTypeExpanderResultNode);
48
+ };
49
+ async function expandMyType(options) {
50
+ if (options.typeExpression.trim() === "") {
51
+ return "never";
52
+ }
53
+ if ("sourceText" in options) {
54
+ const sourceFile2 = ts2.createSourceFile(
55
+ "test.ts",
56
+ options.sourceText,
57
+ ts2.ScriptTarget.Latest,
58
+ true
59
+ );
60
+ return expandMyType({
61
+ sourceFileName: "test.ts",
62
+ typeExpression: options.typeExpression,
63
+ getSourceFileFunction: () => sourceFile2,
64
+ tsCompilerOptions: options.tsCompilerOptions
65
+ });
66
+ }
67
+ const tsCompilerOptions = options.tsCompilerOptions ?? {
68
+ noEmit: true,
69
+ allowSyntheticDefaultImports: true,
70
+ allowArbitraryExtensions: true,
71
+ allowImportingTsExtensions: true,
72
+ allowJs: true
73
+ };
74
+ const compilerHost = createExpanderCompilerHost(
75
+ options.sourceFileName,
76
+ options.typeExpression,
77
+ tsCompilerOptions,
78
+ options.getSourceFileFunction
79
+ );
80
+ const program = ts2.createProgram(
81
+ [options.sourceFileName],
82
+ tsCompilerOptions,
83
+ compilerHost
84
+ );
85
+ const sourceFile = program.getSourceFile(options.sourceFileName);
86
+ if (!sourceFile) {
87
+ throw new Error("Source file not found!");
88
+ }
89
+ const firstIdentifier = findTypeExpanderResultNode(sourceFile);
90
+ if (!firstIdentifier) {
91
+ throw new Error("No node found!");
92
+ }
93
+ const typeChecker = program.getTypeChecker();
94
+ const expandedType = typeChecker.typeToString(
95
+ typeChecker.getTypeAtLocation(firstIdentifier),
96
+ void 0,
97
+ ts2.TypeFormatFlags.NodeBuilderFlagsMask
98
+ );
99
+ if (options.prettify && options.prettify.enabled === false) {
100
+ return expandedType;
101
+ }
102
+ const dummyTypeName = "__TYPE_EXPANDER_RESULT__";
103
+ return (await format(
104
+ `type ${dummyTypeName} = ${expandedType}`,
105
+ options.prettify?.options ?? {
106
+ parser: "typescript",
107
+ semi: false
108
+ }
109
+ )).trim().substring(`type ${dummyTypeName} = `.length);
110
+ }
111
+ export {
112
+ expandMyType
113
+ };
114
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2NyZWF0ZS1leHBhbmRlci1jb21waWxlci1ob3N0LnRzIiwgIi4uL3NyYy9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHRzIGZyb20gXCJ0eXBlc2NyaXB0XCI7XG5cbi8qKlxuICogQ3JlYXRlcyBhIGN1c3RvbSBjb21waWxlciBob3N0IHRoYXQgYXVnbWVudHMgdGhlIHNwZWNpZmllZCBzb3VyY2UgZmlsZSBmb3IgZXhwYW5kaW5nIGEgdHlwZSBleHByZXNzaW9uLlxuICpcbiAqIEBwYXJhbSBzb3VyY2VGaWxlTmFtZSBOYW1lIG9mIHRoZSBzb3VyY2UgZmlsZSB0byBhdWdtZW50LlxuICogQHBhcmFtIHR5cGVFeHByZXNzaW9uIFR5cGUgZXhwcmVzc2lvbi5cbiAqIEBwYXJhbSBjb21waWxlck9wdGlvbnMgVHlwZVNjcmlwdCBjb21waWxlciBvcHRpb25zLlxuICogQHBhcmFtIGdldFNvdXJjZUZpbGVGdW5jdGlvbiBUaGUgaW1wbGVtZW50YXRpb24gb2YgdGhlIGB0cy5Db21waWxlckhvc3RbXCJnZXRTb3VyY2VGaWxlXCJdYCBmdW5jdGlvbi5cbiAqIEByZXR1cm5zIEEgY3VzdG9tIGNvbXBpbGVyIGhvc3QgdGhhdCByZXR1cm5zIGFuIGF1Z21lbnRlZCBzb3VyY2UgZmlsZSB0aGF0IGNhbiBiZSB1c2VkIHRvIGV4cGFuZCB0aGUgdHlwZSBleHByZXNzaW9uLlxuICovXG5leHBvcnQgY29uc3QgY3JlYXRlRXhwYW5kZXJDb21waWxlckhvc3QgPSAoXG4gIHNvdXJjZUZpbGVOYW1lOiBzdHJpbmcsXG4gIHR5cGVFeHByZXNzaW9uOiBzdHJpbmcsXG4gIGNvbXBpbGVyT3B0aW9ucz86IHRzLkNvbXBpbGVyT3B0aW9ucyxcbiAgZ2V0U291cmNlRmlsZUZ1bmN0aW9uPzogdHMuQ29tcGlsZXJIb3N0W1wiZ2V0U291cmNlRmlsZVwiXSxcbikgPT4ge1xuICBjb25zdCBjdXN0b21Db21waWxlckhvc3QgPSB0cy5jcmVhdGVDb21waWxlckhvc3QoY29tcGlsZXJPcHRpb25zID8/IHt9KTtcbiAgY29uc3Qgb3JpZ2luYWxHZXRTb3VyY2VGaWxlID0gY3VzdG9tQ29tcGlsZXJIb3N0LmdldFNvdXJjZUZpbGU7XG5cbiAgY3VzdG9tQ29tcGlsZXJIb3N0LmdldFNvdXJjZUZpbGUgPSAoZmlsZU5hbWUsIC4uLmFyZ3MpID0+IHtcbiAgICBpZiAoZmlsZU5hbWUgPT09IHNvdXJjZUZpbGVOYW1lKSB7XG4gICAgICBjb25zdCBzb3VyY2VGaWxlID0gKGdldFNvdXJjZUZpbGVGdW5jdGlvbiA/PyBvcmlnaW5hbEdldFNvdXJjZUZpbGUpKFxuICAgICAgICBmaWxlTmFtZSxcbiAgICAgICAgLi4uYXJncyxcbiAgICAgICk7XG5cbiAgICAgIGlmIChzb3VyY2VGaWxlID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICAgIH1cblxuICAgICAgY29uc3Qgc291cmNlVGV4dCA9IFtcbiAgICAgICAgLi4uW1xuICAgICAgICAgIFwidHlwZSBfX1RZUEVfRVhQQU5ERVJfUkVTVUxUX18gPSBfX1RZUEVfRVhQQU5ERVJfRVhQQU5EX188X19UWVBFX0VYUEFOREVSX0VYUFJFU1NJT05fXz47XCIsXG4gICAgICAgICAgYHR5cGUgX19UWVBFX0VYUEFOREVSX0VYUFJFU1NJT05fXyA9ICR7dHlwZUV4cHJlc3Npb259O2AsXG4gICAgICAgICAgXCJ0eXBlIF9fVFlQRV9FWFBBTkRFUl9FWFBBTkRfXzxUPiA9IHtcIixcbiAgICAgICAgICBcIiAgW0sgaW4ga2V5b2YgVF06IF9fVFlQRV9FWFBBTkRFUl9FWFBBTkRfXzxUW0tdPjtcIixcbiAgICAgICAgICBcIn0gJiB7fTtcIixcbiAgICAgICAgXSxcbiAgICAgICAgc291cmNlRmlsZS5nZXRGdWxsVGV4dCgpLFxuICAgICAgXS5qb2luKFwiXFxuXCIpO1xuXG4gICAgICByZXR1cm4gdHMuY3JlYXRlU291cmNlRmlsZShcbiAgICAgICAgZmlsZU5hbWUsXG4gICAgICAgIHNvdXJjZVRleHQsXG4gICAgICAgIHNvdXJjZUZpbGUubGFuZ3VhZ2VWZXJzaW9uLFxuICAgICAgICB0cnVlLFxuICAgICAgKTtcbiAgICB9XG5cbiAgICByZXR1cm4gb3JpZ2luYWxHZXRTb3VyY2VGaWxlKGZpbGVOYW1lLCAuLi5hcmdzKTtcbiAgfTtcblxuICByZXR1cm4gY3VzdG9tQ29tcGlsZXJIb3N0O1xufTtcbiIsICJpbXBvcnQgeyBjcmVhdGVFeHBhbmRlckNvbXBpbGVySG9zdCB9IGZyb20gXCIuL2NyZWF0ZS1leHBhbmRlci1jb21waWxlci1ob3N0LnRzXCI7XG5pbXBvcnQgeyBmb3JtYXQsIHR5cGUgT3B0aW9ucyBhcyBQcmV0dGllck9wdGlvbnMgfSBmcm9tIFwicHJldHRpZXJcIjtcbmltcG9ydCB0cyBmcm9tIFwidHlwZXNjcmlwdFwiO1xuXG4vKipcbiAqIEZpbmRzIHRoZSBub2RlIHRoYXQgcmVwcmVzZW50cyB0aGUgVFlQRV9FWFBBTkRFUl9SRVNVTFQgdHlwZS5cbiAqXG4gKiBAcGFyYW0gbm9kZSBOb2RlIGluIHdoaWNoIHRoZSBUWVBFX0VYUEFOREVSX1JFU1VMVCB0eXBlIHNob3VsZCBiZSBzZWFyY2hlZC5cbiAqIEByZXR1cm5zIFRoZSBub2RlIHRoYXQgcmVwcmVzZW50cyB0aGUgVFlQRV9FWFBBTkRFUl9SRVNVTFQgdHlwZS5cbiAqL1xuY29uc3QgZmluZFR5cGVFeHBhbmRlclJlc3VsdE5vZGUgPSAobm9kZTogdHMuTm9kZSk6IHRzLk5vZGUgfCB1bmRlZmluZWQgPT4ge1xuICBpZiAobm9kZS5nZXRDaGlsZENvdW50KCkgPT0gMCkge1xuICAgIGlmICghdHMuaXNJZGVudGlmaWVyKG5vZGUpKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cblxuICAgIC8vIFNpbmNlIHdlIHB1dCB0aGUgX19UWVBFX0VYUEFOREVSX1JFU1VMVF9fIHR5cGUgYXQgdGhlIGJlZ2lubmluZyBvZiB0aGVcbiAgICAvLyBmaWxlLCB3ZSBjYW4gcmV0dXJuIHRoZSBmaXJzdCBpZGVudGlmaWVyIHdlIGZpbmQuXG4gICAgcmV0dXJuIG5vZGU7XG4gIH1cblxuICByZXR1cm4gdHMuZm9yRWFjaENoaWxkKG5vZGUsIGZpbmRUeXBlRXhwYW5kZXJSZXN1bHROb2RlKTtcbn07XG5cbmV4cG9ydCB0eXBlIEV4cGFuZFR5cGVPcHRpb25zQmFzZSA9IHtcbiAgLyoqXG4gICAqIFRoZSB0eXBlIGV4cHJlc3Npb24gdG8gZXhwYW5kLlxuICAgKiBAZXhhbXBsZSBcIlJldHVyblR5cGU8dHlwZW9mIG15RnVuY3Rpb24+XCJcbiAgICovXG4gIHR5cGVFeHByZXNzaW9uOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFR5cGVTY3JpcHQgY29tcGlsZXIgb3B0aW9ucy5cbiAgICovXG4gIHRzQ29tcGlsZXJPcHRpb25zPzogdHMuQ29tcGlsZXJPcHRpb25zO1xuXG4gIC8qKlxuICAgKiBQcmV0dGllciBvcHRpb25zLlxuICAgKi9cbiAgcHJldHRpZnk/OiB7XG4gICAgLyoqXG4gICAgICogV2hldGhlciB0byBwcmV0dGlmeSB0aGUgb3V0cHV0LlxuICAgICAqIEBkZWZhdWx0IHRydWVcbiAgICAgKi9cbiAgICBlbmFibGVkPzogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBQcmV0dGllciBvcHRpb25zLiBEb24ndCBmb3JnZXQgdG8gc2V0IHRoZSBwYXJzZXIgdG8gXCJ0eXBlc2NyaXB0XCIuXG4gICAgICogQGRlZmF1bHQgeyBwYXJzZXI6IFwidHlwZXNjcmlwdFwiLCBzZW1pOiBmYWxzZSB9XG4gICAgICovXG4gICAgb3B0aW9ucz86IFByZXR0aWVyT3B0aW9ucztcbiAgfTtcbn07XG5leHBvcnQgdHlwZSBFeHBhbmRUeXBlRnJvbVNvdXJjZUZpbGVPcHRpb25zID0gRXhwYW5kVHlwZU9wdGlvbnNCYXNlICYge1xuICAvKipcbiAgICogTmFtZSBvZiB0aGUgc291cmNlIGZpbGUgdG8gZXZhbHVhdGUgdGhlIHR5cGUgZXhwcmVzc2lvbiBpbi5cbiAgICovXG4gIHNvdXJjZUZpbGVOYW1lOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBGdW5jdGlvbiB0aGF0IHJldHVybnMgdGhlIHNvdXJjZSBmaWxlLiBXaGVuIG5vdCBzcGVjaWZpZWQsIHRoZSBpbXBsZW1lbnRhdGlvbiBvZiB0aGUgZGVmYXVsdCBUeXBlU2NyaXB0IGNvbXBpbGVyIGhvc3QgaXMgdXNlZC5cbiAgICovXG4gIGdldFNvdXJjZUZpbGVGdW5jdGlvbj86IHRzLkNvbXBpbGVySG9zdFtcImdldFNvdXJjZUZpbGVcIl07XG59O1xuZXhwb3J0IHR5cGUgRXhwYW5kVHlwZUZyb21Tb3VyY2VUZXh0T3B0aW9ucyA9IEV4cGFuZFR5cGVPcHRpb25zQmFzZSAmIHtcbiAgLyoqXG4gICAqIFR5cGVTY3JpcHQgc291cmNlIHRleHQgdG8gZXZhbHVhdGUgdGhlIHR5cGUgZXhwcmVzc2lvbiBpbi5cbiAgICovXG4gIHNvdXJjZVRleHQ6IHN0cmluZztcbn07XG5leHBvcnQgdHlwZSBFeHBhbmRNeVR5cGVPcHRpb25zID1cbiAgfCBFeHBhbmRUeXBlRnJvbVNvdXJjZUZpbGVPcHRpb25zXG4gIHwgRXhwYW5kVHlwZUZyb21Tb3VyY2VUZXh0T3B0aW9ucztcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGV4cGFuZE15VHlwZShcbiAgb3B0aW9uczogRXhwYW5kVHlwZUZyb21Tb3VyY2VUZXh0T3B0aW9ucyxcbik6IFByb21pc2U8c3RyaW5nPjtcbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBleHBhbmRNeVR5cGUoXG4gIG9wdGlvbnM6IEV4cGFuZFR5cGVGcm9tU291cmNlRmlsZU9wdGlvbnMsXG4pOiBQcm9taXNlPHN0cmluZz47XG5cbi8qKlxuICogRXhwYW5kcyBhIFR5cGVTY3JpcHQgdHlwZSBleHByZXNzaW9uLlxuICpcbiAqIEBwYXJhbSBvcHRpb25zXG4gKiBAcmV0dXJucyBUaGUgZXhwYW5kZWQgdHlwZSBleHByZXNzaW9uLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZXhwYW5kTXlUeXBlKG9wdGlvbnM6IEV4cGFuZE15VHlwZU9wdGlvbnMpIHtcbiAgaWYgKG9wdGlvbnMudHlwZUV4cHJlc3Npb24udHJpbSgpID09PSBcIlwiKSB7XG4gICAgcmV0dXJuIFwibmV2ZXJcIjtcbiAgfVxuXG4gIGlmIChcInNvdXJjZVRleHRcIiBpbiBvcHRpb25zKSB7XG4gICAgY29uc3Qgc291cmNlRmlsZSA9IHRzLmNyZWF0ZVNvdXJjZUZpbGUoXG4gICAgICBcInRlc3QudHNcIixcbiAgICAgIG9wdGlvbnMuc291cmNlVGV4dCxcbiAgICAgIHRzLlNjcmlwdFRhcmdldC5MYXRlc3QsXG4gICAgICB0cnVlLFxuICAgICk7XG5cbiAgICByZXR1cm4gZXhwYW5kTXlUeXBlKHtcbiAgICAgIHNvdXJjZUZpbGVOYW1lOiBcInRlc3QudHNcIixcbiAgICAgIHR5cGVFeHByZXNzaW9uOiBvcHRpb25zLnR5cGVFeHByZXNzaW9uLFxuICAgICAgZ2V0U291cmNlRmlsZUZ1bmN0aW9uOiAoKSA9PiBzb3VyY2VGaWxlLFxuICAgICAgdHNDb21waWxlck9wdGlvbnM6IG9wdGlvbnMudHNDb21waWxlck9wdGlvbnMsXG4gICAgfSk7XG4gIH1cblxuICBjb25zdCB0c0NvbXBpbGVyT3B0aW9ucyA9IG9wdGlvbnMudHNDb21waWxlck9wdGlvbnMgPz8ge1xuICAgIG5vRW1pdDogdHJ1ZSxcblxuICAgIGFsbG93U3ludGhldGljRGVmYXVsdEltcG9ydHM6IHRydWUsXG4gICAgYWxsb3dBcmJpdHJhcnlFeHRlbnNpb25zOiB0cnVlLFxuICAgIGFsbG93SW1wb3J0aW5nVHNFeHRlbnNpb25zOiB0cnVlLFxuICAgIGFsbG93SnM6IHRydWUsXG4gIH07XG5cbiAgY29uc3QgY29tcGlsZXJIb3N0ID0gY3JlYXRlRXhwYW5kZXJDb21waWxlckhvc3QoXG4gICAgb3B0aW9ucy5zb3VyY2VGaWxlTmFtZSxcbiAgICBvcHRpb25zLnR5cGVFeHByZXNzaW9uLFxuICAgIHRzQ29tcGlsZXJPcHRpb25zLFxuICAgIG9wdGlvbnMuZ2V0U291cmNlRmlsZUZ1bmN0aW9uLFxuICApO1xuXG4gIGNvbnN0IHByb2dyYW0gPSB0cy5jcmVhdGVQcm9ncmFtKFxuICAgIFtvcHRpb25zLnNvdXJjZUZpbGVOYW1lXSxcbiAgICB0c0NvbXBpbGVyT3B0aW9ucyxcbiAgICBjb21waWxlckhvc3QsXG4gICk7XG5cbiAgY29uc3Qgc291cmNlRmlsZSA9IHByb2dyYW0uZ2V0U291cmNlRmlsZShvcHRpb25zLnNvdXJjZUZpbGVOYW1lKTtcbiAgaWYgKCFzb3VyY2VGaWxlKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFwiU291cmNlIGZpbGUgbm90IGZvdW5kIVwiKTtcbiAgfVxuXG4gIGNvbnN0IGZpcnN0SWRlbnRpZmllciA9IGZpbmRUeXBlRXhwYW5kZXJSZXN1bHROb2RlKHNvdXJjZUZpbGUpO1xuICBpZiAoIWZpcnN0SWRlbnRpZmllcikge1xuICAgIHRocm93IG5ldyBFcnJvcihcIk5vIG5vZGUgZm91bmQhXCIpO1xuICB9XG5cbiAgY29uc3QgdHlwZUNoZWNrZXIgPSBwcm9ncmFtLmdldFR5cGVDaGVja2VyKCk7XG4gIGNvbnN0IGV4cGFuZGVkVHlwZSA9IHR5cGVDaGVja2VyLnR5cGVUb1N0cmluZyhcbiAgICB0eXBlQ2hlY2tlci5nZXRUeXBlQXRMb2NhdGlvbihmaXJzdElkZW50aWZpZXIpLFxuICAgIHVuZGVmaW5lZCxcbiAgICB0cy5UeXBlRm9ybWF0RmxhZ3MuTm9kZUJ1aWxkZXJGbGFnc01hc2ssXG4gICk7XG5cbiAgaWYgKG9wdGlvbnMucHJldHRpZnkgJiYgb3B0aW9ucy5wcmV0dGlmeS5lbmFibGVkID09PSBmYWxzZSkge1xuICAgIHJldHVybiBleHBhbmRlZFR5cGU7XG4gIH1cblxuICBjb25zdCBkdW1teVR5cGVOYW1lID0gXCJfX1RZUEVfRVhQQU5ERVJfUkVTVUxUX19cIjtcblxuICByZXR1cm4gKFxuICAgIGF3YWl0IGZvcm1hdChcbiAgICAgIGB0eXBlICR7ZHVtbXlUeXBlTmFtZX0gPSAke2V4cGFuZGVkVHlwZX1gLFxuICAgICAgb3B0aW9ucy5wcmV0dGlmeT8ub3B0aW9ucyA/PyB7XG4gICAgICAgIHBhcnNlcjogXCJ0eXBlc2NyaXB0XCIsXG4gICAgICAgIHNlbWk6IGZhbHNlLFxuICAgICAgfSxcbiAgICApXG4gIClcbiAgICAudHJpbSgpXG4gICAgLnN1YnN0cmluZyhgdHlwZSAke2R1bW15VHlwZU5hbWV9ID0gYC5sZW5ndGgpO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjtBQUFBLE9BQU8sUUFBUTtBQVdSLElBQU0sNkJBQTZCLENBQ3hDLGdCQUNBLGdCQUNBLGlCQUNBLDBCQUNHO0FBQ0gsUUFBTSxxQkFBcUIsR0FBRyxtQkFBbUIsbUJBQW1CLENBQUMsQ0FBQztBQUN0RSxRQUFNLHdCQUF3QixtQkFBbUI7QUFFakQscUJBQW1CLGdCQUFnQixDQUFDLGFBQWEsU0FBUztBQUN4RCxRQUFJLGFBQWEsZ0JBQWdCO0FBQy9CLFlBQU0sY0FBYyx5QkFBeUI7QUFBQSxRQUMzQztBQUFBLFFBQ0EsR0FBRztBQUFBLE1BQ0w7QUFFQSxVQUFJLGVBQWUsUUFBVztBQUM1QixlQUFPO0FBQUEsTUFDVDtBQUVBLFlBQU0sYUFBYTtBQUFBLFFBQ2pCLEdBQUc7QUFBQSxVQUNEO0FBQUEsVUFDQSx1Q0FBdUMsY0FBYztBQUFBLFVBQ3JEO0FBQUEsVUFDQTtBQUFBLFVBQ0E7QUFBQSxRQUNGO0FBQUEsUUFDQSxXQUFXLFlBQVk7QUFBQSxNQUN6QixFQUFFLEtBQUssSUFBSTtBQUVYLGFBQU8sR0FBRztBQUFBLFFBQ1I7QUFBQSxRQUNBO0FBQUEsUUFDQSxXQUFXO0FBQUEsUUFDWDtBQUFBLE1BQ0Y7QUFBQSxJQUNGO0FBRUEsV0FBTyxzQkFBc0IsVUFBVSxHQUFHLElBQUk7QUFBQSxFQUNoRDtBQUVBLFNBQU87QUFDVDs7O0FDckRBLFNBQVMsY0FBK0M7QUFDeEQsT0FBT0EsU0FBUTtBQVFmLElBQU0sNkJBQTZCLENBQUMsU0FBdUM7QUFDekUsTUFBSSxLQUFLLGNBQWMsS0FBSyxHQUFHO0FBQzdCLFFBQUksQ0FBQ0EsSUFBRyxhQUFhLElBQUksR0FBRztBQUMxQixhQUFPO0FBQUEsSUFDVDtBQUlBLFdBQU87QUFBQSxFQUNUO0FBRUEsU0FBT0EsSUFBRyxhQUFhLE1BQU0sMEJBQTBCO0FBQ3pEO0FBK0RBLGVBQXNCLGFBQWEsU0FBOEI7QUFDL0QsTUFBSSxRQUFRLGVBQWUsS0FBSyxNQUFNLElBQUk7QUFDeEMsV0FBTztBQUFBLEVBQ1Q7QUFFQSxNQUFJLGdCQUFnQixTQUFTO0FBQzNCLFVBQU1DLGNBQWFELElBQUc7QUFBQSxNQUNwQjtBQUFBLE1BQ0EsUUFBUTtBQUFBLE1BQ1JBLElBQUcsYUFBYTtBQUFBLE1BQ2hCO0FBQUEsSUFDRjtBQUVBLFdBQU8sYUFBYTtBQUFBLE1BQ2xCLGdCQUFnQjtBQUFBLE1BQ2hCLGdCQUFnQixRQUFRO0FBQUEsTUFDeEIsdUJBQXVCLE1BQU1DO0FBQUEsTUFDN0IsbUJBQW1CLFFBQVE7QUFBQSxJQUM3QixDQUFDO0FBQUEsRUFDSDtBQUVBLFFBQU0sb0JBQW9CLFFBQVEscUJBQXFCO0FBQUEsSUFDckQsUUFBUTtBQUFBLElBRVIsOEJBQThCO0FBQUEsSUFDOUIsMEJBQTBCO0FBQUEsSUFDMUIsNEJBQTRCO0FBQUEsSUFDNUIsU0FBUztBQUFBLEVBQ1g7QUFFQSxRQUFNLGVBQWU7QUFBQSxJQUNuQixRQUFRO0FBQUEsSUFDUixRQUFRO0FBQUEsSUFDUjtBQUFBLElBQ0EsUUFBUTtBQUFBLEVBQ1Y7QUFFQSxRQUFNLFVBQVVELElBQUc7QUFBQSxJQUNqQixDQUFDLFFBQVEsY0FBYztBQUFBLElBQ3ZCO0FBQUEsSUFDQTtBQUFBLEVBQ0Y7QUFFQSxRQUFNLGFBQWEsUUFBUSxjQUFjLFFBQVEsY0FBYztBQUMvRCxNQUFJLENBQUMsWUFBWTtBQUNmLFVBQU0sSUFBSSxNQUFNLHdCQUF3QjtBQUFBLEVBQzFDO0FBRUEsUUFBTSxrQkFBa0IsMkJBQTJCLFVBQVU7QUFDN0QsTUFBSSxDQUFDLGlCQUFpQjtBQUNwQixVQUFNLElBQUksTUFBTSxnQkFBZ0I7QUFBQSxFQUNsQztBQUVBLFFBQU0sY0FBYyxRQUFRLGVBQWU7QUFDM0MsUUFBTSxlQUFlLFlBQVk7QUFBQSxJQUMvQixZQUFZLGtCQUFrQixlQUFlO0FBQUEsSUFDN0M7QUFBQSxJQUNBQSxJQUFHLGdCQUFnQjtBQUFBLEVBQ3JCO0FBRUEsTUFBSSxRQUFRLFlBQVksUUFBUSxTQUFTLFlBQVksT0FBTztBQUMxRCxXQUFPO0FBQUEsRUFDVDtBQUVBLFFBQU0sZ0JBQWdCO0FBRXRCLFVBQ0UsTUFBTTtBQUFBLElBQ0osUUFBUSxhQUFhLE1BQU0sWUFBWTtBQUFBLElBQ3ZDLFFBQVEsVUFBVSxXQUFXO0FBQUEsTUFDM0IsUUFBUTtBQUFBLE1BQ1IsTUFBTTtBQUFBLElBQ1I7QUFBQSxFQUNGLEdBRUMsS0FBSyxFQUNMLFVBQVUsUUFBUSxhQUFhLE1BQU0sTUFBTTtBQUNoRDsiLAogICJuYW1lcyI6IFsidHMiLCAic291cmNlRmlsZSJdCn0K
package/package.json ADDED
@@ -0,0 +1,59 @@
1
+ {
2
+ "name": "expand-my-type",
3
+ "version": "0.1.0",
4
+ "description": "Expand TypeScript type expressions programmatically",
5
+ "keywords": [
6
+ "expand",
7
+ "typescript",
8
+ "types"
9
+ ],
10
+ "homepage": "https://github.com/fardjad/node-expand-my-type",
11
+ "bugs": {
12
+ "url": "https://github.com/fardjad/node-expand-my-type/issues"
13
+ },
14
+ "repository": {
15
+ "type": "git",
16
+ "url": "git+ssh://git@github.com/fardjad/node-expand-my-type.git"
17
+ },
18
+ "license": "MIT",
19
+ "author": "Fardjad Davari <public@fardjad.com>",
20
+ "type": "module",
21
+ "exports": {
22
+ ".": {
23
+ "require": {
24
+ "default": "./dist/index.cjs",
25
+ "types": "./dist/index.d.cts"
26
+ },
27
+ "import": {
28
+ "default": "./dist/index.js",
29
+ "types": "./dist/index.d.ts"
30
+ }
31
+ }
32
+ },
33
+ "main": "dist/index.cjs",
34
+ "types": "dist/index.d.ts",
35
+ "files": [
36
+ "dist/index.cjs",
37
+ "dist/index.d.cts",
38
+ "dist/index.d.ts",
39
+ "dist/index.js"
40
+ ],
41
+ "scripts": {
42
+ "format": "prettier --write .",
43
+ "prepare": "tsup ./src/index.ts --format esm,cjs --dts --clean --sourcemap inline --silent",
44
+ "pretest": "tsc",
45
+ "test": "tsx --test --test-reporter spec ./src/index.test.ts"
46
+ },
47
+ "dependencies": {
48
+ "prettier": "^3.2.5",
49
+ "typescript": "^5.4.5"
50
+ },
51
+ "devDependencies": {
52
+ "@trivago/prettier-plugin-sort-imports": "^4.3.0",
53
+ "@types/node": "^20.12.12",
54
+ "npm-check-updates": "^16.14.18",
55
+ "prettier-plugin-packagejson": "^2.4.14",
56
+ "tsup": "^8.0.2",
57
+ "tsx": "^4.10.5"
58
+ }
59
+ }