@kubb/core 2.0.0-canary.20231030T124958 → 2.0.1
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/README.md +1 -1
- package/dist/chunk-4A7WG6IA.js +128 -0
- package/dist/chunk-4A7WG6IA.js.map +1 -0
- package/dist/chunk-54P4AWHI.js +71 -0
- package/dist/chunk-54P4AWHI.js.map +1 -0
- package/dist/chunk-5TK7TMV6.cjs +131 -0
- package/dist/chunk-5TK7TMV6.cjs.map +1 -0
- package/dist/chunk-7S67BJXQ.js +85 -0
- package/dist/chunk-7S67BJXQ.js.map +1 -0
- package/dist/chunk-E3ANGQ5N.cjs +2290 -0
- package/dist/chunk-E3ANGQ5N.cjs.map +1 -0
- package/dist/chunk-H47IKRXJ.cjs +129 -0
- package/dist/chunk-H47IKRXJ.cjs.map +1 -0
- package/dist/chunk-HIE46T3F.js +129 -0
- package/dist/chunk-HIE46T3F.js.map +1 -0
- package/dist/chunk-K2H7BYQB.js +155 -0
- package/dist/chunk-K2H7BYQB.js.map +1 -0
- package/dist/chunk-NAWI7UXW.js +67 -0
- package/dist/chunk-NAWI7UXW.js.map +1 -0
- package/dist/chunk-PLVKILIY.cjs +162 -0
- package/dist/chunk-PLVKILIY.cjs.map +1 -0
- package/dist/chunk-W2FP7ZWW.cjs +71 -0
- package/dist/chunk-W2FP7ZWW.cjs.map +1 -0
- package/dist/chunk-WZQO3EPM.cjs +91 -0
- package/dist/chunk-WZQO3EPM.cjs.map +1 -0
- package/dist/chunk-XDHI63G7.cjs +104 -0
- package/dist/chunk-XDHI63G7.cjs.map +1 -0
- package/dist/chunk-XPOF4D5N.js +18 -0
- package/dist/chunk-XPOF4D5N.js.map +1 -0
- package/dist/fs.cjs +31 -0
- package/dist/fs.cjs.map +1 -0
- package/dist/fs.d.cts +5 -0
- package/dist/fs.d.ts +5 -0
- package/dist/fs.js +11 -0
- package/dist/fs.js.map +1 -0
- package/dist/index.cjs +1866 -977
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +302 -319
- package/dist/index.d.ts +302 -319
- package/dist/index.js +1071 -846
- package/dist/index.js.map +1 -1
- package/dist/logger.cjs +26 -0
- package/dist/logger.cjs.map +1 -0
- package/dist/logger.d.cts +32 -0
- package/dist/logger.d.ts +32 -0
- package/dist/logger.js +8 -0
- package/dist/logger.js.map +1 -0
- package/dist/transformers.cjs +124 -0
- package/dist/transformers.cjs.map +1 -0
- package/dist/transformers.d.cts +55 -0
- package/dist/transformers.d.ts +55 -0
- package/dist/transformers.js +95 -0
- package/dist/transformers.js.map +1 -0
- package/dist/utils.cjs +23 -1163
- package/dist/utils.cjs.map +1 -1
- package/dist/utils.d.cts +2 -143
- package/dist/utils.d.ts +2 -143
- package/dist/utils.js +15 -1118
- package/dist/utils.js.map +1 -1
- package/dist/write-A6VgHkYA.d.cts +10 -0
- package/dist/write-A6VgHkYA.d.ts +10 -0
- package/package.json +40 -23
- package/src/BarrelManager.ts +113 -0
- package/src/FileManager.ts +581 -0
- package/src/Generator.ts +34 -0
- package/src/PackageManager.ts +178 -0
- package/src/PluginManager.ts +645 -0
- package/src/PromiseManager.ts +51 -0
- package/src/build.ts +221 -0
- package/src/config.ts +22 -0
- package/src/errors.ts +12 -0
- package/src/fs/clean.ts +5 -0
- package/src/fs/index.ts +3 -0
- package/src/fs/read.ts +68 -0
- package/src/fs/write.ts +79 -0
- package/src/index.ts +27 -0
- package/src/logger.ts +121 -0
- package/src/plugin.ts +80 -0
- package/src/transformers/casing.ts +9 -0
- package/src/transformers/combineCodes.ts +3 -0
- package/src/transformers/createJSDocBlockText.ts +9 -0
- package/src/transformers/escape.ts +31 -0
- package/src/transformers/indent.ts +3 -0
- package/src/transformers/index.ts +36 -0
- package/src/transformers/nameSorter.ts +9 -0
- package/src/transformers/searchAndReplace.ts +25 -0
- package/src/transformers/transformReservedWord.ts +97 -0
- package/src/transformers/trim.ts +7 -0
- package/src/types.ts +334 -0
- package/src/utils/EventEmitter.ts +24 -0
- package/src/utils/FunctionParams.ts +86 -0
- package/src/utils/TreeNode.ts +125 -0
- package/src/utils/URLPath.ts +133 -0
- package/src/utils/cache.ts +35 -0
- package/src/utils/executeStrategies.ts +83 -0
- package/src/utils/index.ts +8 -0
- package/src/utils/promise.ts +13 -0
- package/src/utils/renderTemplate.ts +31 -0
- package/src/utils/timeout.ts +7 -0
- package/src/utils/uniqueName.ts +20 -0
package/README.md
CHANGED
|
@@ -18,7 +18,7 @@
|
|
|
18
18
|
</p>
|
|
19
19
|
|
|
20
20
|
<h4>
|
|
21
|
-
<a href="https://codesandbox.io/s/github/kubb-project/kubb/tree/
|
|
21
|
+
<a href="https://codesandbox.io/s/github/kubb-project/kubb/tree/alpha/examples/typescript" target="_blank">View Demo</a>
|
|
22
22
|
<span> · </span>
|
|
23
23
|
<a href="https://kubb.dev/" target="_blank">Documentation</a>
|
|
24
24
|
<span> · </span>
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { createRequire } from 'module';
|
|
2
|
+
import { camelCase } from './chunk-XPOF4D5N.js';
|
|
3
|
+
import { init_esm_shims } from './chunk-54P4AWHI.js';
|
|
4
|
+
|
|
5
|
+
createRequire(import.meta.url);
|
|
6
|
+
|
|
7
|
+
// src/utils/URLPath.ts
|
|
8
|
+
init_esm_shims();
|
|
9
|
+
var URLPath = class {
|
|
10
|
+
constructor(path) {
|
|
11
|
+
this.path = path;
|
|
12
|
+
return this;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Convert Swagger path to URLPath(syntax of Express)
|
|
16
|
+
* @example /pet/{petId} => /pet/:petId
|
|
17
|
+
*/
|
|
18
|
+
get URL() {
|
|
19
|
+
return this.toURLPath();
|
|
20
|
+
}
|
|
21
|
+
get isURL() {
|
|
22
|
+
try {
|
|
23
|
+
const url = new URL(this.path);
|
|
24
|
+
if (url?.href) {
|
|
25
|
+
return true;
|
|
26
|
+
}
|
|
27
|
+
} catch (error) {
|
|
28
|
+
return false;
|
|
29
|
+
}
|
|
30
|
+
return false;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Convert Swagger path to template literals/ template strings(camelcase)
|
|
34
|
+
* @example /pet/{petId} => `/pet/${petId}`
|
|
35
|
+
* @example /account/monetary-accountID => `/account/${monetaryAccountId}`
|
|
36
|
+
* @example /account/userID => `/account/${userId}`
|
|
37
|
+
*/
|
|
38
|
+
get template() {
|
|
39
|
+
return this.toTemplateString();
|
|
40
|
+
}
|
|
41
|
+
get object() {
|
|
42
|
+
return this.toObject();
|
|
43
|
+
}
|
|
44
|
+
get params() {
|
|
45
|
+
return this.getParams();
|
|
46
|
+
}
|
|
47
|
+
toObject({ type = "path", replacer, stringify } = {}) {
|
|
48
|
+
const object = {
|
|
49
|
+
url: type === "path" ? this.toURLPath() : this.toTemplateString(replacer),
|
|
50
|
+
params: this.getParams()
|
|
51
|
+
};
|
|
52
|
+
if (stringify) {
|
|
53
|
+
if (type === "template") {
|
|
54
|
+
return JSON.stringify(object).replaceAll("'", "").replaceAll(`"`, "");
|
|
55
|
+
}
|
|
56
|
+
if (object.params) {
|
|
57
|
+
return `{ url: '${object.url}', params: ${JSON.stringify(object.params).replaceAll("'", "").replaceAll(`"`, "")} }`;
|
|
58
|
+
}
|
|
59
|
+
return `{ url: '${object.url}' }`;
|
|
60
|
+
}
|
|
61
|
+
return object;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Convert Swagger path to template literals/ template strings(camelcase)
|
|
65
|
+
* @example /pet/{petId} => `/pet/${petId}`
|
|
66
|
+
* @example /account/monetary-accountID => `/account/${monetaryAccountId}`
|
|
67
|
+
* @example /account/userID => `/account/${userId}`
|
|
68
|
+
*/
|
|
69
|
+
toTemplateString(replacer) {
|
|
70
|
+
const regex = /{(\w|-)*}/g;
|
|
71
|
+
const found = this.path.match(regex);
|
|
72
|
+
let newPath = this.path.replaceAll("{", "${");
|
|
73
|
+
if (found) {
|
|
74
|
+
newPath = found.reduce((prev, curr) => {
|
|
75
|
+
const pathParam = replacer ? replacer(camelCase(curr)) : camelCase(curr);
|
|
76
|
+
const replacement = `\${${pathParam}}`;
|
|
77
|
+
return prev.replace(curr, replacement);
|
|
78
|
+
}, this.path);
|
|
79
|
+
}
|
|
80
|
+
return `\`${newPath}\``;
|
|
81
|
+
}
|
|
82
|
+
getParams(replacer) {
|
|
83
|
+
const regex = /{(\w|-)*}/g;
|
|
84
|
+
const found = this.path.match(regex);
|
|
85
|
+
if (!found) {
|
|
86
|
+
return void 0;
|
|
87
|
+
}
|
|
88
|
+
const params = {};
|
|
89
|
+
found.forEach((item) => {
|
|
90
|
+
item = item.replaceAll("{", "").replaceAll("}", "");
|
|
91
|
+
const pathParam = replacer ? replacer(camelCase(item)) : camelCase(item);
|
|
92
|
+
params[pathParam] = pathParam;
|
|
93
|
+
}, this.path);
|
|
94
|
+
return params;
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Convert Swagger path to URLPath(syntax of Express)
|
|
98
|
+
* @example /pet/{petId} => /pet/:petId
|
|
99
|
+
*/
|
|
100
|
+
toURLPath() {
|
|
101
|
+
return this.path.replaceAll("{", ":").replaceAll("}", "");
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
// src/utils/uniqueName.ts
|
|
106
|
+
init_esm_shims();
|
|
107
|
+
function getUniqueName(originalName, data) {
|
|
108
|
+
let used = data[originalName] || 0;
|
|
109
|
+
if (used) {
|
|
110
|
+
data[originalName] = ++used;
|
|
111
|
+
originalName += used;
|
|
112
|
+
}
|
|
113
|
+
data[originalName] = 1;
|
|
114
|
+
return originalName;
|
|
115
|
+
}
|
|
116
|
+
function setUniqueName(originalName, data) {
|
|
117
|
+
let used = data[originalName] || 0;
|
|
118
|
+
if (used) {
|
|
119
|
+
data[originalName] = ++used;
|
|
120
|
+
return originalName;
|
|
121
|
+
}
|
|
122
|
+
data[originalName] = 1;
|
|
123
|
+
return originalName;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
export { URLPath, getUniqueName, setUniqueName };
|
|
127
|
+
//# sourceMappingURL=out.js.map
|
|
128
|
+
//# sourceMappingURL=chunk-4A7WG6IA.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/utils/URLPath.ts","../src/utils/uniqueName.ts"],"names":[],"mappings":"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","sourcesContent":["import { camelCase } from '../transformers/casing.ts'\n\nexport type URLObject = {\n url: string\n params?: Record<string, string>\n}\n\ntype ObjectOptions = {\n type?: 'path' | 'template'\n replacer?: (pathParam: string) => string\n stringify?: boolean\n}\n\nexport class URLPath {\n path: string\n\n constructor(path: string) {\n this.path = path\n\n return this\n }\n\n /**\n * Convert Swagger path to URLPath(syntax of Express)\n * @example /pet/{petId} => /pet/:petId\n */\n get URL(): string {\n return this.toURLPath()\n }\n get isURL(): boolean {\n try {\n const url = new URL(this.path)\n if (url?.href) {\n return true\n }\n } catch (error) {\n return false\n }\n return false\n }\n\n /**\n * Convert Swagger path to template literals/ template strings(camelcase)\n * @example /pet/{petId} => `/pet/${petId}`\n * @example /account/monetary-accountID => `/account/${monetaryAccountId}`\n * @example /account/userID => `/account/${userId}`\n */\n get template(): string {\n return this.toTemplateString()\n }\n get object(): URLObject | string {\n return this.toObject()\n }\n get params(): Record<string, string> | undefined {\n return this.getParams()\n }\n\n toObject({ type = 'path', replacer, stringify }: ObjectOptions = {}): URLObject | string {\n const object = {\n url: type === 'path' ? this.toURLPath() : this.toTemplateString(replacer),\n params: this.getParams(),\n }\n\n if (stringify) {\n if (type === 'template') {\n return JSON.stringify(object).replaceAll(\"'\", '').replaceAll(`\"`, '')\n }\n\n if (object.params) {\n return `{ url: '${object.url}', params: ${JSON.stringify(object.params).replaceAll(\"'\", '').replaceAll(`\"`, '')} }`\n }\n\n return `{ url: '${object.url}' }`\n }\n\n return object\n }\n\n /**\n * Convert Swagger path to template literals/ template strings(camelcase)\n * @example /pet/{petId} => `/pet/${petId}`\n * @example /account/monetary-accountID => `/account/${monetaryAccountId}`\n * @example /account/userID => `/account/${userId}`\n */\n toTemplateString(replacer?: (pathParam: string) => string): string {\n const regex = /{(\\w|-)*}/g\n const found = this.path.match(regex)\n let newPath = this.path.replaceAll('{', '${')\n\n if (found) {\n newPath = found.reduce((prev, curr) => {\n const pathParam = replacer\n ? replacer(camelCase(curr))\n : camelCase(curr)\n const replacement = `\\${${pathParam}}`\n\n return prev.replace(curr, replacement)\n }, this.path)\n }\n\n return `\\`${newPath}\\``\n }\n\n getParams(replacer?: (pathParam: string) => string): Record<string, string> | undefined {\n const regex = /{(\\w|-)*}/g\n const found = this.path.match(regex)\n\n if (!found) {\n return undefined\n }\n\n const params: Record<string, string> = {}\n found.forEach((item) => {\n item = item.replaceAll('{', '').replaceAll('}', '')\n\n const pathParam = replacer\n ? replacer(camelCase(item))\n : camelCase(item)\n\n params[pathParam] = pathParam\n }, this.path)\n\n return params\n }\n\n /**\n * Convert Swagger path to URLPath(syntax of Express)\n * @example /pet/{petId} => /pet/:petId\n */\n toURLPath(): string {\n return this.path.replaceAll('{', ':').replaceAll('}', '')\n }\n}\n","export function getUniqueName(originalName: string, data: Record<string, number>): string {\n let used = data[originalName] || 0\n if (used) {\n data[originalName] = ++used\n originalName += used\n }\n data[originalName] = 1\n return originalName\n}\n\nexport function setUniqueName(originalName: string, data: Record<string, number>): string {\n let used = data[originalName] || 0\n if (used) {\n data[originalName] = ++used\n\n return originalName\n }\n data[originalName] = 1\n return originalName\n}\n"]}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { createRequire } from 'module';
|
|
2
|
+
|
|
3
|
+
const require = createRequire(import.meta.url);
|
|
4
|
+
|
|
5
|
+
var __create = Object.create;
|
|
6
|
+
var __defProp = Object.defineProperty;
|
|
7
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
8
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
9
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
10
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
11
|
+
var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
|
|
12
|
+
get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
|
|
13
|
+
}) : x)(function(x) {
|
|
14
|
+
if (typeof require !== "undefined")
|
|
15
|
+
return require.apply(this, arguments);
|
|
16
|
+
throw Error('Dynamic require of "' + x + '" is not supported');
|
|
17
|
+
});
|
|
18
|
+
var __esm = (fn, res) => function __init() {
|
|
19
|
+
return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
|
|
20
|
+
};
|
|
21
|
+
var __commonJS = (cb, mod) => function __require2() {
|
|
22
|
+
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
|
|
23
|
+
};
|
|
24
|
+
var __copyProps = (to, from, except, desc) => {
|
|
25
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
26
|
+
for (let key of __getOwnPropNames(from))
|
|
27
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
28
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
29
|
+
}
|
|
30
|
+
return to;
|
|
31
|
+
};
|
|
32
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
33
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
34
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
35
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
36
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
37
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
38
|
+
mod
|
|
39
|
+
));
|
|
40
|
+
var __accessCheck = (obj, member, msg) => {
|
|
41
|
+
if (!member.has(obj))
|
|
42
|
+
throw TypeError("Cannot " + msg);
|
|
43
|
+
};
|
|
44
|
+
var __privateGet = (obj, member, getter) => {
|
|
45
|
+
__accessCheck(obj, member, "read from private field");
|
|
46
|
+
return getter ? getter.call(obj) : member.get(obj);
|
|
47
|
+
};
|
|
48
|
+
var __privateAdd = (obj, member, value) => {
|
|
49
|
+
if (member.has(obj))
|
|
50
|
+
throw TypeError("Cannot add the same private member more than once");
|
|
51
|
+
member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
52
|
+
};
|
|
53
|
+
var __privateSet = (obj, member, value, setter) => {
|
|
54
|
+
__accessCheck(obj, member, "write to private field");
|
|
55
|
+
setter ? setter.call(obj, value) : member.set(obj, value);
|
|
56
|
+
return value;
|
|
57
|
+
};
|
|
58
|
+
var __privateMethod = (obj, member, method) => {
|
|
59
|
+
__accessCheck(obj, member, "access private method");
|
|
60
|
+
return method;
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
// ../../node_modules/.pnpm/tsup@8.0.1_@microsoft+api-extractor@7.38.5_ts-node@10.9.2_typescript@5.3.3/node_modules/tsup/assets/esm_shims.js
|
|
64
|
+
var init_esm_shims = __esm({
|
|
65
|
+
"../../node_modules/.pnpm/tsup@8.0.1_@microsoft+api-extractor@7.38.5_ts-node@10.9.2_typescript@5.3.3/node_modules/tsup/assets/esm_shims.js"() {
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
export { __commonJS, __privateAdd, __privateGet, __privateMethod, __privateSet, __require, __toESM, init_esm_shims };
|
|
70
|
+
//# sourceMappingURL=out.js.map
|
|
71
|
+
//# sourceMappingURL=chunk-54P4AWHI.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../node_modules/.pnpm/tsup@8.0.1_@microsoft+api-extractor@7.38.5_ts-node@10.9.2_typescript@5.3.3/node_modules/tsup/assets/esm_shims.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA","sourcesContent":["// Shim globals in esm bundle\nimport { fileURLToPath } from 'url'\nimport path from 'path'\n\nconst getFilename = () => fileURLToPath(import.meta.url)\nconst getDirname = () => path.dirname(getFilename())\n\nexport const __dirname = /* @__PURE__ */ getDirname()\nexport const __filename = /* @__PURE__ */ getFilename()\n"]}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunkWZQO3EPM_cjs = require('./chunk-WZQO3EPM.cjs');
|
|
4
|
+
|
|
5
|
+
// src/transformers/searchAndReplace.ts
|
|
6
|
+
chunkWZQO3EPM_cjs.init_cjs_shims();
|
|
7
|
+
function searchAndReplace(options) {
|
|
8
|
+
const { text, replaceBy, prefix = "", key } = options;
|
|
9
|
+
const searchValues = options.searchValues?.(prefix, key) || [
|
|
10
|
+
`${prefix}["${key}"]`,
|
|
11
|
+
`${prefix}['${key}']`,
|
|
12
|
+
`${prefix}[\`${key}\`]`,
|
|
13
|
+
`${prefix}"${key}"`,
|
|
14
|
+
`${prefix}'${key}'`,
|
|
15
|
+
`${prefix}\`${key}\``,
|
|
16
|
+
new RegExp(`${prefix}${key}`, "g")
|
|
17
|
+
];
|
|
18
|
+
return searchValues.reduce((prev, searchValue) => {
|
|
19
|
+
return prev.toString().replaceAll(searchValue, replaceBy);
|
|
20
|
+
}, text);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
// src/transformers/trim.ts
|
|
24
|
+
chunkWZQO3EPM_cjs.init_cjs_shims();
|
|
25
|
+
function trim(text) {
|
|
26
|
+
return text.replaceAll(/\n/g, "").trim();
|
|
27
|
+
}
|
|
28
|
+
function trimExtName(text) {
|
|
29
|
+
return text.replace(/\.[^/.]+$/, "");
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
// src/transformers/transformReservedWord.ts
|
|
33
|
+
chunkWZQO3EPM_cjs.init_cjs_shims();
|
|
34
|
+
var reservedWords = [
|
|
35
|
+
"abstract",
|
|
36
|
+
"arguments",
|
|
37
|
+
"boolean",
|
|
38
|
+
"break",
|
|
39
|
+
"byte",
|
|
40
|
+
"case",
|
|
41
|
+
"catch",
|
|
42
|
+
"char",
|
|
43
|
+
"class",
|
|
44
|
+
"const",
|
|
45
|
+
"continue",
|
|
46
|
+
"debugger",
|
|
47
|
+
"default",
|
|
48
|
+
"delete",
|
|
49
|
+
"do",
|
|
50
|
+
"double",
|
|
51
|
+
"else",
|
|
52
|
+
"enum",
|
|
53
|
+
"eval",
|
|
54
|
+
"export",
|
|
55
|
+
"extends",
|
|
56
|
+
"false",
|
|
57
|
+
"final",
|
|
58
|
+
"finally",
|
|
59
|
+
"float",
|
|
60
|
+
"for",
|
|
61
|
+
"function",
|
|
62
|
+
"goto",
|
|
63
|
+
"if",
|
|
64
|
+
"implements",
|
|
65
|
+
"import",
|
|
66
|
+
"in",
|
|
67
|
+
"instanceof",
|
|
68
|
+
"int",
|
|
69
|
+
"interface",
|
|
70
|
+
"let",
|
|
71
|
+
"long",
|
|
72
|
+
"native",
|
|
73
|
+
"new",
|
|
74
|
+
"null",
|
|
75
|
+
"package",
|
|
76
|
+
"private",
|
|
77
|
+
"protected",
|
|
78
|
+
"public",
|
|
79
|
+
"return",
|
|
80
|
+
"short",
|
|
81
|
+
"static",
|
|
82
|
+
"super",
|
|
83
|
+
"switch",
|
|
84
|
+
"synchronized",
|
|
85
|
+
"this",
|
|
86
|
+
"throw",
|
|
87
|
+
"throws",
|
|
88
|
+
"transient",
|
|
89
|
+
"true",
|
|
90
|
+
"try",
|
|
91
|
+
"typeof",
|
|
92
|
+
"var",
|
|
93
|
+
"void",
|
|
94
|
+
"volatile",
|
|
95
|
+
"while",
|
|
96
|
+
"with",
|
|
97
|
+
"yield",
|
|
98
|
+
"Array",
|
|
99
|
+
"Date",
|
|
100
|
+
"eval",
|
|
101
|
+
"function",
|
|
102
|
+
"hasOwnProperty",
|
|
103
|
+
"Infinity",
|
|
104
|
+
"isFinite",
|
|
105
|
+
"isNaN",
|
|
106
|
+
"isPrototypeOf",
|
|
107
|
+
"length",
|
|
108
|
+
"Math",
|
|
109
|
+
"name",
|
|
110
|
+
"NaN",
|
|
111
|
+
"Number",
|
|
112
|
+
"Object",
|
|
113
|
+
"prototype",
|
|
114
|
+
"String",
|
|
115
|
+
"toString",
|
|
116
|
+
"undefined",
|
|
117
|
+
"valueOf"
|
|
118
|
+
];
|
|
119
|
+
function transformReservedWord(word) {
|
|
120
|
+
if (word && reservedWords.includes(word) || word?.match(/^\d/)) {
|
|
121
|
+
return `_${word}`;
|
|
122
|
+
}
|
|
123
|
+
return word;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
exports.searchAndReplace = searchAndReplace;
|
|
127
|
+
exports.transformReservedWord = transformReservedWord;
|
|
128
|
+
exports.trim = trim;
|
|
129
|
+
exports.trimExtName = trimExtName;
|
|
130
|
+
//# sourceMappingURL=out.js.map
|
|
131
|
+
//# sourceMappingURL=chunk-5TK7TMV6.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/transformers/searchAndReplace.ts","../src/transformers/trim.ts","../src/transformers/transformReservedWord.ts"],"names":[],"mappings":";;;;;AAAA;AAQO,SAAS,iBAAiB,SAA0B;AACzD,QAAM,EAAE,MAAM,WAAW,SAAS,IAAI,IAAI,IAAI;AAE9C,QAAM,eAAe,QAAQ,eAAe,QAAQ,GAAG,KAAK;AAAA,IAC1D,GAAG,MAAM,KAAK,GAAG;AAAA,IACjB,GAAG,MAAM,KAAK,GAAG;AAAA,IACjB,GAAG,MAAM,MAAM,GAAG;AAAA,IAClB,GAAG,MAAM,IAAI,GAAG;AAAA,IAChB,GAAG,MAAM,IAAI,GAAG;AAAA,IAChB,GAAG,MAAM,KAAK,GAAG;AAAA,IACjB,IAAI,OAAO,GAAG,MAAM,GAAG,GAAG,IAAI,GAAG;AAAA,EACnC;AAEA,SAAO,aAAa,OAAO,CAAC,MAAM,gBAAgB;AAChD,WAAO,KAAK,SAAS,EAAE,WAAW,aAAa,SAAS;AAAA,EAC1D,GAAG,IAAI;AACT;;;ACxBA;AAAO,SAAS,KAAK,MAAsB;AACzC,SAAO,KAAK,WAAW,OAAO,EAAE,EAAE,KAAK;AACzC;AAEO,SAAS,YAAY,MAAsB;AAChD,SAAO,KAAK,QAAQ,aAAa,EAAE;AACrC;;;ACNA;AAGA,IAAM,gBAAgB;AAAA,EACpB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAEA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAEO,SAAS,sBAAsB,MAAsB;AAC1D,MAAK,QAAQ,cAAc,SAAS,IAAI,KAAM,MAAM,MAAM,KAAK,GAAG;AAChE,WAAO,IAAI,IAAI;AAAA,EACjB;AAEA,SAAO;AACT","sourcesContent":["type Options = {\n text: string\n replaceBy: string\n prefix?: string\n key: string\n searchValues?: (prefix: string, key: string) => Array<RegExp | string>\n}\n\nexport function searchAndReplace(options: Options): string {\n const { text, replaceBy, prefix = '', key } = options\n\n const searchValues = options.searchValues?.(prefix, key) || [\n `${prefix}[\"${key}\"]`,\n `${prefix}['${key}']`,\n `${prefix}[\\`${key}\\`]`,\n `${prefix}\"${key}\"`,\n `${prefix}'${key}'`,\n `${prefix}\\`${key}\\``,\n new RegExp(`${prefix}${key}`, 'g'),\n ]\n\n return searchValues.reduce((prev, searchValue) => {\n return prev.toString().replaceAll(searchValue, replaceBy)\n }, text) as string\n}\n","export function trim(text: string): string {\n return text.replaceAll(/\\n/g, '').trim()\n}\n\nexport function trimExtName(text: string): string {\n return text.replace(/\\.[^/.]+$/, '')\n}\n","/**\n * @link https://github.com/jonschlinkert/reserved/blob/master/index.js\n */\nconst reservedWords = [\n 'abstract',\n 'arguments',\n 'boolean',\n 'break',\n 'byte',\n 'case',\n 'catch',\n 'char',\n 'class',\n 'const',\n 'continue',\n 'debugger',\n 'default',\n 'delete',\n 'do',\n 'double',\n 'else',\n 'enum',\n 'eval',\n 'export',\n 'extends',\n 'false',\n 'final',\n 'finally',\n 'float',\n 'for',\n 'function',\n 'goto',\n 'if',\n 'implements',\n 'import',\n 'in',\n 'instanceof',\n 'int',\n 'interface',\n 'let',\n 'long',\n 'native',\n 'new',\n 'null',\n 'package',\n 'private',\n 'protected',\n 'public',\n 'return',\n 'short',\n 'static',\n 'super',\n 'switch',\n 'synchronized',\n 'this',\n 'throw',\n 'throws',\n 'transient',\n 'true',\n 'try',\n 'typeof',\n 'var',\n 'void',\n 'volatile',\n 'while',\n 'with',\n 'yield',\n\n 'Array',\n 'Date',\n 'eval',\n 'function',\n 'hasOwnProperty',\n 'Infinity',\n 'isFinite',\n 'isNaN',\n 'isPrototypeOf',\n 'length',\n 'Math',\n 'name',\n 'NaN',\n 'Number',\n 'Object',\n 'prototype',\n 'String',\n 'toString',\n 'undefined',\n 'valueOf',\n]\n\nexport function transformReservedWord(word: string): string {\n if ((word && reservedWords.includes(word)) || word?.match(/^\\d/)) {\n return `_${word}`\n }\n\n return word\n}\n"]}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { createRequire } from 'module';
|
|
2
|
+
import { init_esm_shims } from './chunk-54P4AWHI.js';
|
|
3
|
+
import { resolve } from 'path';
|
|
4
|
+
import fs from 'fs-extra';
|
|
5
|
+
import { switcher } from 'js-runtime';
|
|
6
|
+
|
|
7
|
+
createRequire(import.meta.url);
|
|
8
|
+
|
|
9
|
+
// src/fs/write.ts
|
|
10
|
+
init_esm_shims();
|
|
11
|
+
var writer = switcher(
|
|
12
|
+
{
|
|
13
|
+
node: async (path, data, { sanity }) => {
|
|
14
|
+
try {
|
|
15
|
+
const oldContent = await fs.readFile(resolve(path), { encoding: "utf-8" });
|
|
16
|
+
if (oldContent?.toString() === data?.toString()) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
} catch (_err) {
|
|
20
|
+
}
|
|
21
|
+
await fs.outputFile(resolve(path), data, { encoding: "utf-8" });
|
|
22
|
+
if (sanity) {
|
|
23
|
+
const savedData = await fs.readFile(resolve(path), { encoding: "utf-8" });
|
|
24
|
+
if (savedData?.toString() !== data?.toString()) {
|
|
25
|
+
throw new Error(`Sanity check failed for ${path}
|
|
26
|
+
|
|
27
|
+
Data[${data.length}]:
|
|
28
|
+
${data}
|
|
29
|
+
|
|
30
|
+
Saved[${savedData.length}]:
|
|
31
|
+
${savedData}
|
|
32
|
+
`);
|
|
33
|
+
}
|
|
34
|
+
return savedData;
|
|
35
|
+
}
|
|
36
|
+
return data;
|
|
37
|
+
},
|
|
38
|
+
bun: async (path, data, { sanity }) => {
|
|
39
|
+
try {
|
|
40
|
+
await Bun.write(resolve(path), data);
|
|
41
|
+
if (sanity) {
|
|
42
|
+
const file = Bun.file(resolve(path));
|
|
43
|
+
const savedData = await file.text();
|
|
44
|
+
if (savedData?.toString() !== data?.toString()) {
|
|
45
|
+
throw new Error(`Sanity check failed for ${path}
|
|
46
|
+
|
|
47
|
+
Data[${data.length}]:
|
|
48
|
+
${data}
|
|
49
|
+
|
|
50
|
+
Saved[${savedData.length}]:
|
|
51
|
+
${savedData}
|
|
52
|
+
`);
|
|
53
|
+
}
|
|
54
|
+
return savedData;
|
|
55
|
+
}
|
|
56
|
+
return data;
|
|
57
|
+
} catch (e) {
|
|
58
|
+
console.log(e, resolve(path));
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
"node"
|
|
63
|
+
);
|
|
64
|
+
async function write(data, path, options = {}) {
|
|
65
|
+
if (data.trim() === "") {
|
|
66
|
+
return void 0;
|
|
67
|
+
}
|
|
68
|
+
return writer(path, data.trim(), options);
|
|
69
|
+
}
|
|
70
|
+
async function writeLog(data) {
|
|
71
|
+
if (data.trim() === "") {
|
|
72
|
+
return void 0;
|
|
73
|
+
}
|
|
74
|
+
const path = resolve(process.cwd(), "kubb-log.log");
|
|
75
|
+
let previousLogs = "";
|
|
76
|
+
try {
|
|
77
|
+
previousLogs = await fs.readFile(resolve(path), { encoding: "utf-8" });
|
|
78
|
+
} catch (_err) {
|
|
79
|
+
}
|
|
80
|
+
return writer(path, [previousLogs, data.trim()].filter(Boolean).join("\n\n\n"), { sanity: false });
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
export { write, writeLog };
|
|
84
|
+
//# sourceMappingURL=out.js.map
|
|
85
|
+
//# sourceMappingURL=chunk-7S67BJXQ.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/fs/write.ts"],"names":[],"mappings":";;;;;;;;;AAAA;AAAA,SAAS,eAAe;AAExB,OAAO,QAAQ;AACf,SAAS,gBAAgB;AAIzB,IAAM,SAAS;AAAA,EACb;AAAA,IACE,MAAM,OAAO,MAAc,MAAc,EAAE,OAAO,MAAe;AAC/D,UAAI;AACF,cAAM,aAAa,MAAM,GAAG,SAAS,QAAQ,IAAI,GAAG,EAAE,UAAU,QAAQ,CAAC;AACzE,YAAI,YAAY,SAAS,MAAM,MAAM,SAAS,GAAG;AAC/C;AAAA,QACF;AAAA,MACF,SAAS,MAAM;AAAA,MAEf;AAEA,YAAM,GAAG,WAAW,QAAQ,IAAI,GAAG,MAAM,EAAE,UAAU,QAAQ,CAAC;AAE9D,UAAI,QAAQ;AACV,cAAM,YAAY,MAAM,GAAG,SAAS,QAAQ,IAAI,GAAG,EAAE,UAAU,QAAQ,CAAC;AAExE,YAAI,WAAW,SAAS,MAAM,MAAM,SAAS,GAAG;AAC9C,gBAAM,IAAI,MAAM,2BAA2B,IAAI;AAAA;AAAA,OAAY,KAAK,MAAM;AAAA,EAAO,IAAI;AAAA;AAAA,QAAa,UAAU,MAAM;AAAA,EAAO,SAAS;AAAA,CAAI;AAAA,QACpI;AAEA,eAAO;AAAA,MACT;AAEA,aAAO;AAAA,IACT;AAAA,IACA,KAAK,OAAO,MAAc,MAAc,EAAE,OAAO,MAAe;AAC9D,UAAI;AACF,cAAM,IAAI,MAAM,QAAQ,IAAI,GAAG,IAAI;AAEnC,YAAI,QAAQ;AACV,gBAAM,OAAO,IAAI,KAAK,QAAQ,IAAI,CAAC;AACnC,gBAAM,YAAY,MAAM,KAAK,KAAK;AAElC,cAAI,WAAW,SAAS,MAAM,MAAM,SAAS,GAAG;AAC9C,kBAAM,IAAI,MAAM,2BAA2B,IAAI;AAAA;AAAA,OAAY,KAAK,MAAM;AAAA,EAAO,IAAI;AAAA;AAAA,QAAa,UAAU,MAAM;AAAA,EAAO,SAAS;AAAA,CAAI;AAAA,UACpI;AAEA,iBAAO;AAAA,QACT;AAEA,eAAO;AAAA,MACT,SAAS,GAAG;AACV,gBAAQ,IAAI,GAAG,QAAQ,IAAI,CAAC;AAAA,MAC9B;AAAA,IACF;AAAA,EACF;AAAA,EACA;AACF;AAEA,eAAsB,MAAM,MAAc,MAAc,UAAmB,CAAC,GAAgC;AAC1G,MAAI,KAAK,KAAK,MAAM,IAAI;AACtB,WAAO;AAAA,EACT;AACA,SAAO,OAAO,MAAM,KAAK,KAAK,GAAG,OAAO;AAC1C;AAEA,eAAsB,SAAS,MAA2C;AACxE,MAAI,KAAK,KAAK,MAAM,IAAI;AACtB,WAAO;AAAA,EACT;AACA,QAAM,OAAO,QAAQ,QAAQ,IAAI,GAAG,cAAc;AAClD,MAAI,eAAe;AAEnB,MAAI;AACF,mBAAe,MAAM,GAAG,SAAS,QAAQ,IAAI,GAAG,EAAE,UAAU,QAAQ,CAAC;AAAA,EACvE,SAAS,MAAM;AAAA,EAEf;AAEA,SAAO,OAAO,MAAM,CAAC,cAAc,KAAK,KAAK,CAAC,EAAE,OAAO,OAAO,EAAE,KAAK,QAAQ,GAAG,EAAE,QAAQ,MAAM,CAAC;AACnG","sourcesContent":["import { resolve } from 'node:path'\n\nimport fs from 'fs-extra'\nimport { switcher } from 'js-runtime'\n\ntype Options = { sanity?: boolean }\n\nconst writer = switcher(\n {\n node: async (path: string, data: string, { sanity }: Options) => {\n try {\n const oldContent = await fs.readFile(resolve(path), { encoding: 'utf-8' })\n if (oldContent?.toString() === data?.toString()) {\n return\n }\n } catch (_err) {\n /* empty */\n }\n\n await fs.outputFile(resolve(path), data, { encoding: 'utf-8' })\n\n if (sanity) {\n const savedData = await fs.readFile(resolve(path), { encoding: 'utf-8' })\n\n if (savedData?.toString() !== data?.toString()) {\n throw new Error(`Sanity check failed for ${path}\\n\\nData[${data.length}]:\\n${data}\\n\\nSaved[${savedData.length}]:\\n${savedData}\\n`)\n }\n\n return savedData\n }\n\n return data\n },\n bun: async (path: string, data: string, { sanity }: Options) => {\n try {\n await Bun.write(resolve(path), data)\n\n if (sanity) {\n const file = Bun.file(resolve(path))\n const savedData = await file.text()\n\n if (savedData?.toString() !== data?.toString()) {\n throw new Error(`Sanity check failed for ${path}\\n\\nData[${data.length}]:\\n${data}\\n\\nSaved[${savedData.length}]:\\n${savedData}\\n`)\n }\n\n return savedData\n }\n\n return data\n } catch (e) {\n console.log(e, resolve(path))\n }\n },\n },\n 'node',\n)\n\nexport async function write(data: string, path: string, options: Options = {}): Promise<string | undefined> {\n if (data.trim() === '') {\n return undefined\n }\n return writer(path, data.trim(), options)\n}\n\nexport async function writeLog(data: string): Promise<string | undefined> {\n if (data.trim() === '') {\n return undefined\n }\n const path = resolve(process.cwd(), 'kubb-log.log')\n let previousLogs = ''\n\n try {\n previousLogs = await fs.readFile(resolve(path), { encoding: 'utf-8' })\n } catch (_err) {\n /* empty */\n }\n\n return writer(path, [previousLogs, data.trim()].filter(Boolean).join('\\n\\n\\n'), { sanity: false })\n}\n"]}
|