@kubb/core 3.17.1 → 3.18.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/dist/{FileManager-Cj9zsnb4.cjs → FileManager-CUd9_ZMA.cjs} +50 -64
- package/dist/FileManager-CUd9_ZMA.cjs.map +1 -0
- package/dist/{FileManager-BXXRjW30.js → FileManager-Cluah_Fl.js} +42 -62
- package/dist/FileManager-Cluah_Fl.js.map +1 -0
- package/dist/{PluginManager-Cvj5AlsU.d.cts → PluginManager-C62HGihR.d.cts} +23 -2
- package/dist/{PluginManager-1jPxuyQK.d.ts → PluginManager-H8G0i6KS.d.ts} +24 -3
- package/dist/acorn-3HQnxDj2.js +5106 -0
- package/dist/acorn-3HQnxDj2.js.map +1 -0
- package/dist/acorn-Biw1D1Ce.cjs +5108 -0
- package/dist/acorn-Biw1D1Ce.cjs.map +1 -0
- package/dist/angular-B3ddRl90.cjs +3637 -0
- package/dist/angular-B3ddRl90.cjs.map +1 -0
- package/dist/angular-n5qYWkcx.js +3635 -0
- package/dist/angular-n5qYWkcx.js.map +1 -0
- package/dist/babel-BrKqHp9Q.cjs +10056 -0
- package/dist/babel-BrKqHp9Q.cjs.map +1 -0
- package/dist/babel-mOBF3g2e.js +10054 -0
- package/dist/babel-mOBF3g2e.js.map +1 -0
- package/dist/{chunk-DWy1uDak.cjs → chunk-DoeelZqw.cjs} +12 -0
- package/dist/estree-D6ftINJ3.cjs +6948 -0
- package/dist/estree-D6ftINJ3.cjs.map +1 -0
- package/dist/estree-QGbwcVbp.js +6944 -0
- package/dist/estree-QGbwcVbp.js.map +1 -0
- package/dist/flow-BWEc100n.cjs +52419 -0
- package/dist/flow-BWEc100n.cjs.map +1 -0
- package/dist/flow-C1RsRESZ.js +52417 -0
- package/dist/flow-C1RsRESZ.js.map +1 -0
- package/dist/{fs-BazSaf2y.cjs → fs-CeOer54w.cjs} +27 -15
- package/dist/fs-CeOer54w.cjs.map +1 -0
- package/dist/{fs-BacxV1CO.js → fs-DkMVXz_s.js} +21 -15
- package/dist/fs-DkMVXz_s.js.map +1 -0
- package/dist/fs.cjs +3 -2
- package/dist/fs.d.cts +2 -2
- package/dist/fs.d.ts +2 -2
- package/dist/fs.js +2 -2
- package/dist/glimmer-CwkHq8v_.cjs +7307 -0
- package/dist/glimmer-CwkHq8v_.cjs.map +1 -0
- package/dist/glimmer-DZXQWVfc.js +7303 -0
- package/dist/glimmer-DZXQWVfc.js.map +1 -0
- package/dist/graphql-DWNpg5AH.js +1902 -0
- package/dist/graphql-DWNpg5AH.js.map +1 -0
- package/dist/graphql-ftPsRNd8.cjs +1907 -0
- package/dist/graphql-ftPsRNd8.cjs.map +1 -0
- package/dist/html-DMFSHL-z.cjs +6563 -0
- package/dist/html-DMFSHL-z.cjs.map +1 -0
- package/dist/html-Lx7YOmUI.js +6558 -0
- package/dist/html-Lx7YOmUI.js.map +1 -0
- package/dist/{index-BfD6z1P5.d.cts → index-3smcdUnJ.d.ts} +11 -9
- package/dist/{index-Cb4pChs8.d.ts → index-B428LQ0Z.d.ts} +4 -5
- package/dist/{index-BKHQGQVq.d.ts → index-Bglrijef.d.cts} +12 -8
- package/dist/{index-D2ptHzfn.d.cts → index-DERUIhQK.d.cts} +3 -4
- package/dist/index.cjs +7 -62
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +3 -3
- package/dist/index.d.ts +4 -4
- package/dist/index.js +3 -58
- package/dist/index.js.map +1 -1
- package/dist/{logger-xcdTETKy.d.ts → logger-B-4AXUmB.d.ts} +1 -1
- package/dist/{logger-Cs45J4yy.js → logger-M0gDQMDh.js} +2 -2
- package/dist/{logger-Cs45J4yy.js.map → logger-M0gDQMDh.js.map} +1 -1
- package/dist/{logger-BxvJpQMX.cjs → logger-OgWv9Jyy.cjs} +4 -4
- package/dist/{logger-BxvJpQMX.cjs.map → logger-OgWv9Jyy.cjs.map} +1 -1
- package/dist/logger.cjs +2 -2
- package/dist/logger.d.ts +1 -1
- package/dist/logger.js +1 -1
- package/dist/markdown-BYsFO1cu.cjs +6761 -0
- package/dist/markdown-BYsFO1cu.cjs.map +1 -0
- package/dist/markdown-Dt7fmgWb.js +6756 -0
- package/dist/markdown-Dt7fmgWb.js.map +1 -0
- package/dist/meriyah-BA-YCwVg.cjs +8940 -0
- package/dist/meriyah-BA-YCwVg.cjs.map +1 -0
- package/dist/meriyah-CEYm-XS7.js +8938 -0
- package/dist/meriyah-CEYm-XS7.js.map +1 -0
- package/dist/mocks.cjs +16962 -11
- package/dist/mocks.cjs.map +1 -1
- package/dist/mocks.d.cts +2 -2
- package/dist/mocks.d.ts +3 -3
- package/dist/mocks.js +16963 -8
- package/dist/mocks.js.map +1 -1
- package/dist/postcss-BQcSCAcI.cjs +6723 -0
- package/dist/postcss-BQcSCAcI.cjs.map +1 -0
- package/dist/postcss-CI4qZzdL.js +6718 -0
- package/dist/postcss-CI4qZzdL.js.map +1 -0
- package/dist/{prompt-DwEAzq0q.js → prompt-D3dP3KNu.js} +1 -1
- package/dist/{prompt-DwEAzq0q.js.map → prompt-D3dP3KNu.js.map} +1 -1
- package/dist/{prompt-qiwl6Be9.cjs → prompt-DslNpUPc.cjs} +2 -2
- package/dist/{prompt-qiwl6Be9.cjs.map → prompt-DslNpUPc.cjs.map} +1 -1
- package/dist/{transformers-C7XTcwrX.cjs → transformers-BUNfHgNe.cjs} +2 -2
- package/dist/{transformers-C7XTcwrX.cjs.map → transformers-BUNfHgNe.cjs.map} +1 -1
- package/dist/transformers.cjs +2 -2
- package/dist/typescript-Bq-hjiJ0.js +3 -0
- package/dist/typescript-DDBRxbn7.cjs +23121 -0
- package/dist/typescript-DDBRxbn7.cjs.map +1 -0
- package/dist/typescript-DvVkagAX.cjs +4 -0
- package/dist/typescript-eE7YJ2-c.js +23109 -0
- package/dist/typescript-eE7YJ2-c.js.map +1 -0
- package/dist/utils.cjs +4 -4
- package/dist/utils.d.cts +3 -3
- package/dist/utils.d.ts +4 -4
- package/dist/utils.js +2 -2
- package/dist/{write-l_NzIqyy.cjs → write-cvT4uBev.cjs} +2 -2
- package/dist/{write-l_NzIqyy.cjs.map → write-cvT4uBev.cjs.map} +1 -1
- package/dist/yaml-DZASOrDL.js +5304 -0
- package/dist/yaml-DZASOrDL.js.map +1 -0
- package/dist/yaml-v1i11ZlS.cjs +5310 -0
- package/dist/yaml-v1i11ZlS.cjs.map +1 -0
- package/package.json +4 -5
- package/src/FileManager.ts +3 -7
- package/src/fs/index.ts +3 -2
- package/src/fs/unlink.ts +5 -0
- package/src/mocks/index.ts +7 -1
- package/src/types.ts +24 -4
- package/src/utils/parser.ts +5 -18
- package/dist/FileManager-BXXRjW30.js.map +0 -1
- package/dist/FileManager-Cj9zsnb4.cjs.map +0 -1
- package/dist/fs-BacxV1CO.js.map +0 -1
- package/dist/fs-BazSaf2y.cjs.map +0 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kubb/core",
|
|
3
|
-
"version": "3.
|
|
3
|
+
"version": "3.18.1",
|
|
4
4
|
"description": "Core functionality for Kubb's plugin-based code generation system, providing the foundation for transforming OpenAPI specifications.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"typescript",
|
|
@@ -86,12 +86,12 @@
|
|
|
86
86
|
"js-runtime": "^0.0.8",
|
|
87
87
|
"natural-orderby": "^5.0.0",
|
|
88
88
|
"object-hash": "^3.0.0",
|
|
89
|
-
"p-limit": "^7.
|
|
89
|
+
"p-limit": "^7.1.0",
|
|
90
90
|
"picocolors": "^1.1.1",
|
|
91
91
|
"remeda": "^2.30.0",
|
|
92
92
|
"seedrandom": "^3.0.5",
|
|
93
93
|
"semver": "^7.7.2",
|
|
94
|
-
"@kubb/parser-ts": "3.
|
|
94
|
+
"@kubb/parser-ts": "3.18.1"
|
|
95
95
|
},
|
|
96
96
|
"devDependencies": {
|
|
97
97
|
"@types/fs-extra": "^11.0.4",
|
|
@@ -99,11 +99,10 @@
|
|
|
99
99
|
"@types/seedrandom": "^3.0.8",
|
|
100
100
|
"@types/semver": "^7.7.0",
|
|
101
101
|
"consola": "^3.4.2",
|
|
102
|
-
"prettier": "^3.6.2",
|
|
103
102
|
"tsdown": "^0.14.1",
|
|
104
103
|
"typescript": "^5.9.2",
|
|
105
104
|
"zod": "^4.0.17",
|
|
106
|
-
"@kubb/config-ts": "3.
|
|
105
|
+
"@kubb/config-ts": "3.18.1"
|
|
107
106
|
},
|
|
108
107
|
"engines": {
|
|
109
108
|
"node": ">=20"
|
package/src/FileManager.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { extname, join, relative } from 'node:path'
|
|
2
2
|
|
|
3
3
|
import { orderBy } from 'natural-orderby'
|
|
4
|
-
import { isDeepEqual, uniqueBy } from 'remeda'
|
|
5
4
|
import pLimit from 'p-limit'
|
|
5
|
+
import { isDeepEqual, uniqueBy } from 'remeda'
|
|
6
6
|
|
|
7
7
|
import { BarrelManager } from './BarrelManager.ts'
|
|
8
8
|
|
|
@@ -12,8 +12,8 @@ import type { ResolvedFile } from './fs/types.ts'
|
|
|
12
12
|
import type { Logger } from './logger.ts'
|
|
13
13
|
import type { BarrelType, Config, Plugin } from './types.ts'
|
|
14
14
|
import { createFile, getFileParser } from './utils'
|
|
15
|
-
import type { GreaterThan } from './utils/types.ts'
|
|
16
15
|
import { Cache } from './utils/Cache.ts'
|
|
16
|
+
import type { GreaterThan } from './utils/types.ts'
|
|
17
17
|
|
|
18
18
|
export type FileMetaBase = {
|
|
19
19
|
pluginKey?: Plugin['key']
|
|
@@ -204,12 +204,8 @@ export async function getSource<TMeta extends FileMetaBase = FileMetaBase>(
|
|
|
204
204
|
{ logger, extname }: GetSourceOptions = {},
|
|
205
205
|
): Promise<string> {
|
|
206
206
|
const parser = await getFileParser(file.extname)
|
|
207
|
-
const source = await parser.print(file, { logger, extname })
|
|
208
207
|
|
|
209
|
-
return parser.
|
|
210
|
-
console.warn(err)
|
|
211
|
-
return source
|
|
212
|
-
})
|
|
208
|
+
return parser.print(file, { logger, extname })
|
|
213
209
|
}
|
|
214
210
|
|
|
215
211
|
function mergeFile<TMeta extends FileMetaBase = FileMetaBase>(a: KubbFile.File<TMeta>, b: KubbFile.File<TMeta>): KubbFile.File<TMeta> {
|
package/src/fs/index.ts
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
export { clean } from './clean.ts'
|
|
2
|
-
export { read, readSync } from './read.ts'
|
|
3
|
-
export { write } from './write.ts'
|
|
4
2
|
export { exists } from './exists.ts'
|
|
3
|
+
export { read, readSync } from './read.ts'
|
|
4
|
+
export { unlink } from './unlink.ts'
|
|
5
5
|
export { getRelativePath } from './utils.ts'
|
|
6
|
+
export { write } from './write.ts'
|
|
6
7
|
|
|
7
8
|
export function trimExtName(text: string): string {
|
|
8
9
|
return text.replace(/\.[^/.]+$/, '')
|
package/src/fs/unlink.ts
ADDED
package/src/mocks/index.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import path from 'node:path'
|
|
2
|
+
import { format } from '../../mocks/format.ts'
|
|
2
3
|
import { getSource } from '../FileManager'
|
|
3
4
|
import type { File, ResolvedFile } from '../fs/types.ts'
|
|
4
5
|
import type { Logger } from '../logger'
|
|
@@ -68,6 +69,11 @@ export async function matchFiles(files: Array<ResolvedFile | File> | undefined,
|
|
|
68
69
|
|
|
69
70
|
for await (const file of files) {
|
|
70
71
|
const source = await getSource(createFile(file), { logger: mockedLogger })
|
|
71
|
-
|
|
72
|
+
let code = source
|
|
73
|
+
if (!file.baseName.endsWith('.json')) {
|
|
74
|
+
code = await format(source)
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
await expect(code).toMatchFileSnapshot(path.join(...['__snapshots__', pre, file.path].filter(Boolean)))
|
|
72
78
|
}
|
|
73
79
|
}
|
package/src/types.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import type { KubbFile } from './fs/index.ts'
|
|
2
|
-
import type { PossiblePromise } from './utils/types.ts'
|
|
3
1
|
import type { FileManager } from './FileManager.ts'
|
|
4
|
-
import type {
|
|
2
|
+
import type { KubbFile } from './fs/index.ts'
|
|
5
3
|
import type { Logger } from './logger.ts'
|
|
4
|
+
import type { PluginManager } from './PluginManager.ts'
|
|
5
|
+
import type { PossiblePromise } from './utils/types.ts'
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* Config used in `kubb.config.ts`
|
|
@@ -75,7 +75,27 @@ export type Config<TInput = Input> = {
|
|
|
75
75
|
* @default true
|
|
76
76
|
*/
|
|
77
77
|
write?: boolean
|
|
78
|
-
|
|
78
|
+
/**
|
|
79
|
+
* Specifies the formatting tool to be used.
|
|
80
|
+
* @default prettier
|
|
81
|
+
*
|
|
82
|
+
* Possible values:
|
|
83
|
+
* - 'prettier': Uses Prettier for code formatting.
|
|
84
|
+
* - 'biome': Uses Biome for code formatting.
|
|
85
|
+
*
|
|
86
|
+
*/
|
|
87
|
+
format?: 'prettier' | 'biome' | false
|
|
88
|
+
/**
|
|
89
|
+
* Specifies the linter that should be used to analyze the code.
|
|
90
|
+
* The accepted values indicate different linting tools.
|
|
91
|
+
*
|
|
92
|
+
* Possible values:
|
|
93
|
+
* - 'eslint': Represents the use of ESLint, a widely used JavaScript linter.
|
|
94
|
+
* - 'biome': Represents the Biome linter, a modern tool for code scanning.
|
|
95
|
+
* - 'oxlint': Represents the Oxlint tool for linting purposes.
|
|
96
|
+
*
|
|
97
|
+
*/
|
|
98
|
+
lint?: 'eslint' | 'biome' | 'oxlint' | false
|
|
79
99
|
/**
|
|
80
100
|
* Override the extension to the generated imports and exports, by default each plugin will add an extension
|
|
81
101
|
* @default { '.ts': '.ts'}
|
package/src/utils/parser.ts
CHANGED
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import path from 'node:path'
|
|
2
|
-
import type { KubbFile } from '../fs/index.ts'
|
|
3
|
-
|
|
4
|
-
import { getRelativePath } from '../fs/index.ts'
|
|
5
2
|
import hash from 'object-hash'
|
|
6
3
|
import { combineExports, combineImports, combineSources } from '../FileManager.ts'
|
|
4
|
+
import type { KubbFile } from '../fs/index.ts'
|
|
5
|
+
import { getRelativePath } from '../fs/index.ts'
|
|
7
6
|
import type { Logger } from '../logger.ts'
|
|
8
7
|
import type { Config } from '../types.ts'
|
|
9
8
|
|
|
@@ -104,7 +103,6 @@ export function createFileExport(exp: KubbFile.Export): KubbFile.ResolvedExport
|
|
|
104
103
|
}
|
|
105
104
|
|
|
106
105
|
export type ParserModule<TMeta extends object = object> = {
|
|
107
|
-
format: (source: string) => Promise<string>
|
|
108
106
|
/**
|
|
109
107
|
* Convert a file to string
|
|
110
108
|
*/
|
|
@@ -121,11 +119,6 @@ type PrintOptions = {
|
|
|
121
119
|
}
|
|
122
120
|
|
|
123
121
|
const typeScriptParser = createFileParser({
|
|
124
|
-
async format(source) {
|
|
125
|
-
const module = await import('@kubb/parser-ts')
|
|
126
|
-
|
|
127
|
-
return module.format(source)
|
|
128
|
-
},
|
|
129
122
|
async print(file, options = { extname: '.ts' }) {
|
|
130
123
|
const module = await import('@kubb/parser-ts')
|
|
131
124
|
|
|
@@ -159,25 +152,19 @@ const typeScriptParser = createFileParser({
|
|
|
159
152
|
})
|
|
160
153
|
.filter(Boolean)
|
|
161
154
|
|
|
162
|
-
|
|
155
|
+
const code = [file.banner, module.print([...importNodes, ...exportNodes]), source, file.footer].join('\n')
|
|
156
|
+
|
|
157
|
+
return module.format(code)
|
|
163
158
|
},
|
|
164
159
|
})
|
|
165
160
|
|
|
166
161
|
const tsxParser = createFileParser({
|
|
167
|
-
async format(source) {
|
|
168
|
-
const module = await import('@kubb/parser-ts')
|
|
169
|
-
//4 = tsx
|
|
170
|
-
return module.format(source)
|
|
171
|
-
},
|
|
172
162
|
async print(file, options = { extname: '.tsx' }) {
|
|
173
163
|
return typeScriptParser.print(file, options)
|
|
174
164
|
},
|
|
175
165
|
})
|
|
176
166
|
|
|
177
167
|
const defaultParser = createFileParser({
|
|
178
|
-
async format(source) {
|
|
179
|
-
return source
|
|
180
|
-
},
|
|
181
168
|
async print(file) {
|
|
182
169
|
return file.sources.map((item) => item.value).join('\n\n')
|
|
183
170
|
},
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"FileManager-BXXRjW30.js","names":["#head","#tail","#size","resolve","#cachedLeaves","leaves: TreeNode[]","root: DirectoryTree","path","currentLevel: DirectoryTree[]","#options","barrelFile: KubbFile.File","item","#items","#orderItems","#addParams","type: string[]","name: string[]","item","path","#options","params: Record<string, string>","extname","trimExtName","parsers: Record<KubbFile.Extname, ParserModule<any>>","#buffer","resolvedFiles: KubbFile.ResolvedFile[]","#cache","path","#limit","extname","name"],"sources":["../../../node_modules/.pnpm/yocto-queue@1.2.1/node_modules/yocto-queue/index.js","../../../node_modules/.pnpm/p-limit@7.0.0/node_modules/p-limit/index.js","../src/utils/TreeNode.ts","../src/BarrelManager.ts","../src/utils/FunctionParams.ts","../src/utils/promise.ts","../src/utils/renderTemplate.ts","../src/utils/timeout.ts","../src/utils/uniqueName.ts","../src/utils/URLPath.ts","../src/utils/parser.ts","../src/utils/Cache.ts","../src/FileManager.ts"],"sourcesContent":["/*\nHow it works:\n`this.#head` is an instance of `Node` which keeps track of its current value and nests another instance of `Node` that keeps the value that comes after it. When a value is provided to `.enqueue()`, the code needs to iterate through `this.#head`, going deeper and deeper to find the last value. However, iterating through every single item is slow. This problem is solved by saving a reference to the last value as `this.#tail` so that it can reference it to add a new value.\n*/\n\nclass Node {\n\tvalue;\n\tnext;\n\n\tconstructor(value) {\n\t\tthis.value = value;\n\t}\n}\n\nexport default class Queue {\n\t#head;\n\t#tail;\n\t#size;\n\n\tconstructor() {\n\t\tthis.clear();\n\t}\n\n\tenqueue(value) {\n\t\tconst node = new Node(value);\n\n\t\tif (this.#head) {\n\t\t\tthis.#tail.next = node;\n\t\t\tthis.#tail = node;\n\t\t} else {\n\t\t\tthis.#head = node;\n\t\t\tthis.#tail = node;\n\t\t}\n\n\t\tthis.#size++;\n\t}\n\n\tdequeue() {\n\t\tconst current = this.#head;\n\t\tif (!current) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.#head = this.#head.next;\n\t\tthis.#size--;\n\t\treturn current.value;\n\t}\n\n\tpeek() {\n\t\tif (!this.#head) {\n\t\t\treturn;\n\t\t}\n\n\t\treturn this.#head.value;\n\n\t\t// TODO: Node.js 18.\n\t\t// return this.#head?.value;\n\t}\n\n\tclear() {\n\t\tthis.#head = undefined;\n\t\tthis.#tail = undefined;\n\t\tthis.#size = 0;\n\t}\n\n\tget size() {\n\t\treturn this.#size;\n\t}\n\n\t* [Symbol.iterator]() {\n\t\tlet current = this.#head;\n\n\t\twhile (current) {\n\t\t\tyield current.value;\n\t\t\tcurrent = current.next;\n\t\t}\n\t}\n\n\t* drain() {\n\t\twhile (this.#head) {\n\t\t\tyield this.dequeue();\n\t\t}\n\t}\n}\n","import Queue from 'yocto-queue';\n\nexport default function pLimit(concurrency) {\n\tvalidateConcurrency(concurrency);\n\n\tconst queue = new Queue();\n\tlet activeCount = 0;\n\n\tconst resumeNext = () => {\n\t\t// Process the next queued function if we're under the concurrency limit\n\t\tif (activeCount < concurrency && queue.size > 0) {\n\t\t\tactiveCount++;\n\t\t\tqueue.dequeue()();\n\t\t}\n\t};\n\n\tconst next = () => {\n\t\tactiveCount--;\n\t\tresumeNext();\n\t};\n\n\tconst run = async (function_, resolve, arguments_) => {\n\t\t// Execute the function and capture the result promise\n\t\tconst result = (async () => function_(...arguments_))();\n\n\t\t// Resolve immediately with the promise (don't wait for completion)\n\t\tresolve(result);\n\n\t\t// Wait for the function to complete (success or failure)\n\t\t// We catch errors here to prevent unhandled rejections,\n\t\t// but the original promise rejection is preserved for the caller\n\t\ttry {\n\t\t\tawait result;\n\t\t} catch {}\n\n\t\t// Decrement active count and process next queued function\n\t\tnext();\n\t};\n\n\tconst enqueue = (function_, resolve, arguments_) => {\n\t\t// Queue the internal resolve function instead of the run function\n\t\t// to preserve the asynchronous execution context.\n\t\tnew Promise(internalResolve => { // eslint-disable-line promise/param-names\n\t\t\tqueue.enqueue(internalResolve);\n\t\t}).then(run.bind(undefined, function_, resolve, arguments_)); // eslint-disable-line promise/prefer-await-to-then\n\n\t\t// Start processing immediately if we haven't reached the concurrency limit\n\t\tif (activeCount < concurrency) {\n\t\t\tresumeNext();\n\t\t}\n\t};\n\n\tconst generator = (function_, ...arguments_) => new Promise(resolve => {\n\t\tenqueue(function_, resolve, arguments_);\n\t});\n\n\tObject.defineProperties(generator, {\n\t\tactiveCount: {\n\t\t\tget: () => activeCount,\n\t\t},\n\t\tpendingCount: {\n\t\t\tget: () => queue.size,\n\t\t},\n\t\tclearQueue: {\n\t\t\tvalue() {\n\t\t\t\tqueue.clear();\n\t\t\t},\n\t\t},\n\t\tconcurrency: {\n\t\t\tget: () => concurrency,\n\n\t\t\tset(newConcurrency) {\n\t\t\t\tvalidateConcurrency(newConcurrency);\n\t\t\t\tconcurrency = newConcurrency;\n\n\t\t\t\tqueueMicrotask(() => {\n\t\t\t\t\t// eslint-disable-next-line no-unmodified-loop-condition\n\t\t\t\t\twhile (activeCount < concurrency && queue.size > 0) {\n\t\t\t\t\t\tresumeNext();\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t},\n\t\t},\n\t\tmap: {\n\t\t\tasync value(array, function_) {\n\t\t\t\tconst promises = array.map(value => this(function_, value));\n\t\t\t\treturn Promise.all(promises);\n\t\t\t},\n\t\t},\n\t});\n\n\treturn generator;\n}\n\nexport function limitFunction(function_, options) {\n\tconst {concurrency} = options;\n\tconst limit = pLimit(concurrency);\n\n\treturn (...arguments_) => limit(() => function_(...arguments_));\n}\n\nfunction validateConcurrency(concurrency) {\n\tif (!((Number.isInteger(concurrency) || concurrency === Number.POSITIVE_INFINITY) && concurrency > 0)) {\n\t\tthrow new TypeError('Expected `concurrency` to be a number from 1 and up');\n\t}\n}\n","import { FileManager } from '../FileManager.ts'\nimport type { KubbFile } from '../fs/index.ts'\n\ntype BarrelData = {\n file?: KubbFile.File\n /**\n * @deprecated use file instead\n */\n type: KubbFile.Mode\n path: string\n name: string\n}\n\nexport class TreeNode {\n data: BarrelData\n parent?: TreeNode\n children: Array<TreeNode> = []\n #cachedLeaves?: Array<TreeNode> = undefined\n\n constructor(data: BarrelData, parent?: TreeNode) {\n this.data = data\n this.parent = parent\n return this\n }\n\n addChild(data: BarrelData): TreeNode {\n const child = new TreeNode(data, this)\n if (!this.children) {\n this.children = []\n }\n this.children.push(child)\n return child\n }\n\n get root(): TreeNode {\n if (!this.parent) {\n return this\n }\n return this.parent.root\n }\n\n get leaves(): Array<TreeNode> {\n if (!this.children || this.children.length === 0) {\n // this is a leaf\n return [this]\n }\n\n if (this.#cachedLeaves) {\n return this.#cachedLeaves\n }\n\n // if not a leaf, return all children's leaves recursively\n const leaves: TreeNode[] = []\n if (this.children) {\n for (let i = 0, { length } = this.children; i < length; i++) {\n leaves.push.apply(leaves, this.children[i]!.leaves)\n }\n }\n\n this.#cachedLeaves = leaves\n\n return leaves\n }\n\n forEach(callback: (treeNode: TreeNode) => void): this {\n if (typeof callback !== 'function') {\n throw new TypeError('forEach() callback must be a function')\n }\n\n // run this node through function\n callback(this)\n\n // do the same for all children\n if (this.children) {\n for (let i = 0, { length } = this.children; i < length; i++) {\n this.children[i]?.forEach(callback)\n }\n }\n\n return this\n }\n\n findDeep(predicate?: (value: TreeNode, index: number, obj: TreeNode[]) => boolean): TreeNode | undefined {\n if (typeof predicate !== 'function') {\n throw new TypeError('find() predicate must be a function')\n }\n\n return this.leaves.find(predicate)\n }\n\n forEachDeep(callback: (treeNode: TreeNode) => void): void {\n if (typeof callback !== 'function') {\n throw new TypeError('forEach() callback must be a function')\n }\n\n this.leaves.forEach(callback)\n }\n\n filterDeep(callback: (treeNode: TreeNode) => boolean): Array<TreeNode> {\n if (typeof callback !== 'function') {\n throw new TypeError('filter() callback must be a function')\n }\n\n return this.leaves.filter(callback)\n }\n\n mapDeep<T>(callback: (treeNode: TreeNode) => T): Array<T> {\n if (typeof callback !== 'function') {\n throw new TypeError('map() callback must be a function')\n }\n\n return this.leaves.map(callback)\n }\n\n public static build(files: KubbFile.File[], root?: string): TreeNode | null {\n try {\n const filteredTree = buildDirectoryTree(files, root)\n\n if (!filteredTree) {\n return null\n }\n\n const treeNode = new TreeNode({\n name: filteredTree.name,\n path: filteredTree.path,\n file: filteredTree.file,\n type: FileManager.getMode(filteredTree.path),\n })\n\n const recurse = (node: typeof treeNode, item: DirectoryTree) => {\n const subNode = node.addChild({\n name: item.name,\n path: item.path,\n file: item.file,\n type: FileManager.getMode(item.path),\n })\n\n if (item.children?.length) {\n item.children?.forEach((child) => {\n recurse(subNode, child)\n })\n }\n }\n\n filteredTree.children?.forEach((child) => {\n recurse(treeNode, child)\n })\n\n return treeNode\n } catch (e) {\n throw new Error('Something went wrong with creating barrel files with the TreeNode class', { cause: e })\n }\n }\n}\n\nexport type DirectoryTree = {\n name: string\n path: string\n file?: KubbFile.File\n children: Array<DirectoryTree>\n}\n\nconst normalizePath = (p: string): string => p.replace(/\\\\/g, '/')\n\nexport function buildDirectoryTree(files: Array<KubbFile.File>, rootFolder = ''): DirectoryTree | null {\n const normalizedRootFolder = normalizePath(rootFolder)\n const rootPrefix = normalizedRootFolder.endsWith('/') ? normalizedRootFolder : `${normalizedRootFolder}/`\n\n const filteredFiles = files.filter((file) => {\n const normalizedFilePath = normalizePath(file.path)\n return rootFolder ? normalizedFilePath.startsWith(rootPrefix) && !normalizedFilePath.endsWith('.json') : !normalizedFilePath.endsWith('.json')\n })\n\n if (filteredFiles.length === 0) {\n return null // No files match the root folder\n }\n\n const root: DirectoryTree = {\n name: rootFolder || '',\n path: rootFolder || '',\n children: [],\n }\n\n filteredFiles.forEach((file) => {\n const path = file.path.slice(rootFolder.length)\n const parts = path.split('/')\n let currentLevel: DirectoryTree[] = root.children\n let currentPath = rootFolder\n\n parts.forEach((part, index) => {\n if (index !== 0) {\n currentPath += `/${part}`\n } else {\n currentPath += `${part}`\n }\n\n let existingNode = currentLevel.find((node) => node.name === part)\n\n if (!existingNode) {\n if (index === parts.length - 1) {\n // If it's the last part, it's a file\n existingNode = {\n name: part,\n file,\n path: currentPath,\n } as DirectoryTree\n } else {\n // Otherwise, it's a folder\n existingNode = {\n name: part,\n path: currentPath,\n children: [],\n } as DirectoryTree\n }\n currentLevel.push(existingNode)\n }\n\n // Move to the next level if it's a folder\n if (!existingNode.file) {\n currentLevel = existingNode.children\n }\n })\n })\n\n return root\n}\n","/** biome-ignore-all lint/suspicious/useIterableCallbackReturn: not needed */\nimport { join } from 'node:path'\nimport type { FileMetaBase } from './FileManager.ts'\nimport type { KubbFile } from './fs/index.ts'\nimport { getRelativePath } from './fs/index.ts'\nimport type { Logger } from './logger.ts'\nimport { TreeNode } from './utils/TreeNode.ts'\n\ntype BarrelManagerOptions = {\n logger?: Logger\n}\n\nexport class BarrelManager {\n #options: BarrelManagerOptions\n\n constructor(options: BarrelManagerOptions = {}) {\n this.#options = options\n\n return this\n }\n\n getFiles({ files: generatedFiles, root }: { files: KubbFile.File[]; root?: string; meta?: FileMetaBase | undefined }): Array<KubbFile.File> {\n const { logger } = this.#options\n\n const cachedFiles = new Map<KubbFile.Path, KubbFile.File>()\n\n TreeNode.build(generatedFiles, root)?.forEach((treeNode) => {\n if (!treeNode || !treeNode.children || !treeNode.parent?.data.path) {\n return undefined\n }\n\n const barrelFile: KubbFile.File = {\n path: join(treeNode.parent?.data.path, 'index.ts') as KubbFile.Path,\n baseName: 'index.ts',\n exports: [],\n sources: [],\n }\n const previousBarrelFile = cachedFiles.get(barrelFile.path)\n const leaves = treeNode.leaves\n\n leaves.forEach((item) => {\n if (!item.data.name) {\n return undefined\n }\n\n const sources = item.data.file?.sources || []\n\n if (!sources.some((source) => source.isIndexable)) {\n logger?.emit(\n 'warning',\n `No isIndexable source found(source should have a name and isIndexable):\\nFile: ${JSON.stringify(item.data.file, undefined, 2)}`,\n )\n }\n\n sources.forEach((source) => {\n if (!item.data.file?.path || !source.isIndexable || !source.name) {\n return undefined\n }\n const alreadyContainInPreviousBarrelFile = previousBarrelFile?.sources.some(\n (item) => item.name === source.name && item.isTypeOnly === source.isTypeOnly,\n )\n\n if (alreadyContainInPreviousBarrelFile) {\n return undefined\n }\n\n if (!barrelFile.exports) {\n barrelFile.exports = []\n }\n\n // true when we have a subdirectory that also contains barrel files\n const isSubExport = !!treeNode.parent?.data.path?.split?.('/')?.length\n\n if (isSubExport) {\n barrelFile.exports.push({\n name: [source.name],\n path: getRelativePath(treeNode.parent?.data.path, item.data.path),\n isTypeOnly: source.isTypeOnly,\n })\n } else {\n barrelFile.exports.push({\n name: [source.name],\n path: `./${item.data.file.baseName}`,\n isTypeOnly: source.isTypeOnly,\n })\n }\n\n barrelFile.sources.push({\n name: source.name,\n isTypeOnly: source.isTypeOnly,\n //TODO use parser to generate import\n value: '',\n isExportable: false,\n isIndexable: false,\n })\n })\n })\n\n if (previousBarrelFile) {\n previousBarrelFile.sources.push(...barrelFile.sources)\n previousBarrelFile.exports?.push(...(barrelFile.exports || []))\n } else {\n cachedFiles.set(barrelFile.path, barrelFile)\n }\n })\n\n return [...cachedFiles.values()]\n }\n}\n","import { orderBy } from 'natural-orderby'\n\nimport { camelCase } from '../transformers/casing.ts'\n\ntype FunctionParamsASTWithoutType = {\n name?: string\n type?: string\n /**\n * @default true\n */\n required?: boolean\n /**\n * @default true\n */\n enabled?: boolean\n default?: string\n}\n\ntype FunctionParamsASTWithType = {\n name?: never\n type: string\n /**\n * @default true\n */\n required?: boolean\n /**\n * @default true\n */\n enabled?: boolean\n default?: string\n}\n/**\n * @deprecated\n */\nexport type FunctionParamsAST = FunctionParamsASTWithoutType | FunctionParamsASTWithType\n\n/**\n * @deprecated\n */\nexport class FunctionParams {\n #items: Array<FunctionParamsAST | FunctionParamsAST[]> = []\n constructor() {\n return this\n }\n\n get items(): FunctionParamsAST[] {\n return this.#items.flat()\n }\n\n add(item: FunctionParamsAST | Array<FunctionParamsAST | FunctionParamsAST[] | undefined> | undefined): FunctionParams {\n if (!item) {\n return this\n }\n\n if (Array.isArray(item)) {\n item.filter(Boolean).forEach((it) => {\n this.#items.push(it)\n })\n return this\n }\n this.#items.push(item)\n\n return this\n }\n static #orderItems(items: Array<FunctionParamsAST | FunctionParamsAST[]>) {\n return orderBy(\n items.filter(Boolean),\n [\n (v) => {\n if (Array.isArray(v)) {\n return undefined\n }\n return !v.default\n },\n (v) => {\n if (Array.isArray(v)) {\n return undefined\n }\n return v.required ?? true\n },\n ],\n ['desc', 'desc'],\n )\n }\n\n static #addParams(acc: string[], item: FunctionParamsAST) {\n const { enabled = true, name, type, required = true, ...rest } = item\n\n if (!enabled) {\n return acc\n }\n\n if (!name) {\n // when name is not se we will use TypeScript generics\n acc.push(`${type}${rest.default ? ` = ${rest.default}` : ''}`)\n\n return acc\n }\n // TODO check whey we still need the camelcase here\n const parameterName = name.startsWith('{') ? name : camelCase(name)\n\n if (type) {\n if (required) {\n acc.push(`${parameterName}: ${type}${rest.default ? ` = ${rest.default}` : ''}`)\n } else {\n acc.push(`${parameterName}?: ${type}`)\n }\n } else {\n acc.push(`${parameterName}`)\n }\n\n return acc\n }\n\n static toObject(items: FunctionParamsAST[]): FunctionParamsAST {\n let type: string[] = []\n let name: string[] = []\n\n const enabled = items.every((item) => item.enabled) ? items.at(0)?.enabled : true\n const required = items.every((item) => item.required) ?? true\n\n items.forEach((item) => {\n name = FunctionParams.#addParams(name, { ...item, type: undefined })\n if (items.some((item) => item.type)) {\n type = FunctionParams.#addParams(type, item)\n }\n })\n\n return {\n name: `{ ${name.join(', ')} }`,\n type: type.length ? `{ ${type.join('; ')} }` : undefined,\n enabled,\n required,\n }\n }\n\n static toString(items: (FunctionParamsAST | FunctionParamsAST[])[]): string {\n const sortedData = FunctionParams.#orderItems(items)\n\n return sortedData\n .reduce((acc, item) => {\n if (Array.isArray(item)) {\n if (item.length <= 0) {\n return acc\n }\n const subItems = FunctionParams.#orderItems(item) as FunctionParamsAST[]\n const objectItem = FunctionParams.toObject(subItems)\n\n return FunctionParams.#addParams(acc, objectItem)\n }\n\n return FunctionParams.#addParams(acc, item)\n }, [] as string[])\n .join(', ')\n }\n\n toObject(): FunctionParamsAST {\n const items = FunctionParams.#orderItems(this.#items).flat()\n\n return FunctionParams.toObject(items)\n }\n\n toString(): string {\n const items = FunctionParams.#orderItems(this.#items)\n\n return FunctionParams.toString(items)\n }\n}\n","import type { PossiblePromise } from './types.ts'\n\nexport function isPromise<T>(result: PossiblePromise<T>): result is Promise<T> {\n return !!result && typeof (result as Promise<unknown>)?.then === 'function'\n}\n\nexport function isPromiseFulfilledResult<T = unknown>(result: PromiseSettledResult<unknown>): result is PromiseFulfilledResult<T> {\n return result.status === 'fulfilled'\n}\n\nexport function isPromiseRejectedResult<T>(result: PromiseSettledResult<unknown>): result is Omit<PromiseRejectedResult, 'reason'> & { reason: T } {\n return result.status === 'rejected'\n}\n","export function renderTemplate<TData extends Record<string, unknown> = Record<string, unknown>>(template: string, data: TData | undefined = undefined): string {\n if (!data || !Object.keys(data).length) {\n return template.replace(/{{(.*?)}}/g, '')\n }\n\n const matches = template.match(/{{(.*?)}}/g)\n\n return (\n matches?.reduce((prev, curr) => {\n const index = curr.split(/{{|}}/).filter(Boolean)[0]?.trim()\n if (index === undefined) {\n return prev\n }\n const value = data[index]\n\n if (value === undefined) {\n return prev\n }\n\n return prev\n .replace(curr, () => {\n if (typeof value === 'boolean') {\n return `${value.toString()}` || 'false'\n }\n\n return (value as string) || ''\n })\n .trim()\n }, template) || ''\n )\n}\n","export async function timeout(ms: number): Promise<unknown> {\n return new Promise((resolve) => {\n setTimeout(() => {\n resolve(true)\n }, ms)\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","import { camelCase, isValidVarName } from '../transformers'\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\ntype Options = {\n casing?: 'camelcase'\n}\n\nexport class URLPath {\n path: string\n #options: Options\n\n constructor(path: string, options: Options = {}) {\n this.path = path\n this.#options = options\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({ prefix = '', replacer }: { prefix?: string; 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, path) => {\n const pathWithoutBrackets = path.replaceAll('{', '').replaceAll('}', '')\n\n let param = isValidVarName(pathWithoutBrackets) ? pathWithoutBrackets : camelCase(pathWithoutBrackets)\n\n if (this.#options.casing === 'camelcase') {\n param = camelCase(param)\n }\n\n return prev.replace(path, `\\${${replacer ? replacer(param) : param}}`)\n }, this.path)\n }\n\n return `\\`${prefix}${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 let param = isValidVarName(item) ? item : camelCase(item)\n\n if (this.#options.casing === 'camelcase') {\n param = camelCase(param)\n }\n\n const key = replacer ? replacer(param) : param\n\n params[key] = key\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","import path from 'node:path'\nimport type { KubbFile } from '../fs/index.ts'\n\nimport { getRelativePath } from '../fs/index.ts'\nimport hash from 'object-hash'\nimport { combineExports, combineImports, combineSources } from '../FileManager.ts'\nimport type { Logger } from '../logger.ts'\nimport type { Config } from '../types.ts'\n\n/**\n * Generate a default banner for files created by Kubb\n * @returns A string with the default banner\n */\nexport function getDefaultBanner({ title, description, version, config }: { title?: string; description?: string; version?: string; config: Config }): string {\n try {\n let source = ''\n if ('path' in config.input) {\n source = path.basename(config.input.path)\n } else if ('data' in config.input) {\n source = 'text content'\n }\n\n let banner = '/**\\n* Generated by Kubb (https://kubb.dev/).\\n* Do not edit manually.\\n'\n\n if (config.output.defaultBanner === 'simple') {\n banner += '*/\\n'\n return banner\n }\n\n if (source) {\n banner += `* Source: ${source}\\n`\n }\n\n if (title) {\n banner += `* Title: ${title}\\n`\n }\n\n if (description) {\n const formattedDescription = description.replace(/\\n/gm, '\\n* ')\n banner += `* Description: ${formattedDescription}\\n`\n }\n\n if (version) {\n banner += `* OpenAPI spec version: ${version}\\n`\n }\n\n banner += '*/\\n'\n return banner\n } catch (_error) {\n // If there's any error in parsing the Oas data, return a simpler banner\n return '/**\\n* Generated by Kubb (https://kubb.dev/).\\n* Do not edit manually.\\n*/'\n }\n}\n\n/**\n * Helper to create a file with name and id set\n */\nexport function createFile<TMeta extends object = object>(file: KubbFile.File<TMeta>): KubbFile.ResolvedFile<TMeta> {\n const extname = path.extname(file.baseName) as KubbFile.Extname\n if (!extname) {\n throw new Error(`No extname found for ${file.baseName}`)\n }\n\n const source = file.sources.map((item) => item.value).join('\\n\\n')\n const exports = file.exports?.length ? combineExports(file.exports) : []\n const imports = file.imports?.length && source ? combineImports(file.imports, exports, source) : []\n const sources = file.sources?.length ? combineSources(file.sources) : []\n\n return {\n ...file,\n id: hash({ path: file.path }),\n name: trimExtName(file.baseName),\n extname,\n imports: imports.map(createFileImport),\n exports: exports.map(createFileExport),\n sources: sources.map(createFileSource),\n meta: file.meta || ({} as TMeta),\n }\n}\n\n/**\n * Helper to create a fileImport with extname set\n */\nfunction createFileSource(source: KubbFile.Source): KubbFile.Source {\n return source\n}\n\n/**\n * Helper to create a fileImport with extname set\n */\nexport function createFileImport(imp: KubbFile.Import): KubbFile.ResolvedImport {\n return {\n ...imp,\n }\n}\n\n/**\n * Helper to create a fileExport with extname set\n */\nexport function createFileExport(exp: KubbFile.Export): KubbFile.ResolvedExport {\n return {\n ...exp,\n }\n}\n\nexport type ParserModule<TMeta extends object = object> = {\n format: (source: string) => Promise<string>\n /**\n * Convert a file to string\n */\n print: (file: KubbFile.ResolvedFile<TMeta>, options: PrintOptions) => Promise<string>\n}\n\nexport function createFileParser<TMeta extends object = object>(parser: ParserModule<TMeta>): ParserModule<TMeta> {\n return parser\n}\n\ntype PrintOptions = {\n extname?: KubbFile.Extname\n logger?: Logger\n}\n\nconst typeScriptParser = createFileParser({\n async format(source) {\n const module = await import('@kubb/parser-ts')\n\n return module.format(source)\n },\n async print(file, options = { extname: '.ts' }) {\n const module = await import('@kubb/parser-ts')\n\n const source = file.sources.map((item) => item.value).join('\\n\\n')\n\n const importNodes = file.imports\n .map((item) => {\n const importPath = item.root ? getRelativePath(item.root, item.path) : item.path\n const hasExtname = !!path.extname(importPath)\n\n return module.factory.createImportDeclaration({\n name: item.name,\n path: options.extname && hasExtname ? `${trimExtName(importPath)}${options.extname}` : item.root ? trimExtName(importPath) : importPath,\n isTypeOnly: item.isTypeOnly,\n })\n })\n .filter(Boolean)\n\n const exportNodes = file.exports\n .map((item) => {\n const exportPath = item.path\n\n const hasExtname = !!path.extname(exportPath)\n\n return module.factory.createExportDeclaration({\n name: item.name,\n path: options.extname && hasExtname ? `${trimExtName(item.path)}${options.extname}` : trimExtName(item.path),\n isTypeOnly: item.isTypeOnly,\n asAlias: item.asAlias,\n })\n })\n .filter(Boolean)\n\n return [file.banner, module.print([...importNodes, ...exportNodes]), source, file.footer].join('\\n')\n },\n})\n\nconst tsxParser = createFileParser({\n async format(source) {\n const module = await import('@kubb/parser-ts')\n //4 = tsx\n return module.format(source)\n },\n async print(file, options = { extname: '.tsx' }) {\n return typeScriptParser.print(file, options)\n },\n})\n\nconst defaultParser = createFileParser({\n async format(source) {\n return source\n },\n async print(file) {\n return file.sources.map((item) => item.value).join('\\n\\n')\n },\n})\n\nconst parsers: Record<KubbFile.Extname, ParserModule<any>> = {\n '.ts': typeScriptParser,\n '.js': typeScriptParser,\n '.jsx': tsxParser,\n '.tsx': tsxParser,\n '.json': defaultParser,\n}\n\nexport async function getFileParser<TMeta extends object = object>(extname: KubbFile.Extname | undefined): Promise<ParserModule<TMeta>> {\n if (!extname) {\n return defaultParser\n }\n\n const parser = parsers[extname]\n\n if (!parser) {\n console.warn(`[parser] No parser found for ${extname}, default parser will be used`)\n }\n\n return parser || defaultParser\n}\n\nfunction trimExtName(text: string): string {\n const extname = text.split('.').pop()\n\n return text.replace(`.${extname}`, '')\n}\n","export class Cache<T> {\n #buffer = new Map<string, T>()\n\n async get(key: string): Promise<T | null> {\n return this.#buffer.get(key) ?? null\n }\n\n async set(key: string, value: T): Promise<void> {\n this.#buffer.set(key, value)\n }\n\n async delete(key: string): Promise<void> {\n this.#buffer.delete(key)\n }\n\n async clear(): Promise<void> {\n this.#buffer.clear()\n }\n\n async keys(): Promise<string[]> {\n return [...this.#buffer.keys()]\n }\n\n async values(): Promise<T[]> {\n return [...this.#buffer.values()]\n }\n\n async flush(): Promise<void> {\n // No-op for base cache\n }\n}\n","import { extname, join, relative } from 'node:path'\n\nimport { orderBy } from 'natural-orderby'\nimport { isDeepEqual, uniqueBy } from 'remeda'\nimport pLimit from 'p-limit'\n\nimport { BarrelManager } from './BarrelManager.ts'\n\nimport type { KubbFile } from './fs/index.ts'\nimport { trimExtName, write } from './fs/index.ts'\nimport type { ResolvedFile } from './fs/types.ts'\nimport type { Logger } from './logger.ts'\nimport type { BarrelType, Config, Plugin } from './types.ts'\nimport { createFile, getFileParser } from './utils'\nimport type { GreaterThan } from './utils/types.ts'\nimport { Cache } from './utils/Cache.ts'\n\nexport type FileMetaBase = {\n pluginKey?: Plugin['key']\n}\n\ntype AddResult<T extends Array<KubbFile.File>> = Promise<Awaited<GreaterThan<T['length'], 1> extends true ? Promise<ResolvedFile[]> : Promise<ResolvedFile>>>\n\ntype AddIndexesProps = {\n type: BarrelType | false | undefined\n /**\n * Root based on root and output.path specified in the config\n */\n root: string\n /**\n * Output for plugin\n */\n output: {\n path: string\n }\n group?: {\n output: string\n exportAs: string\n }\n logger?: Logger\n\n meta?: FileMetaBase\n}\n\ntype WriteFilesProps = {\n root: Config['root']\n extension?: Record<KubbFile.Extname, KubbFile.Extname | ''>\n logger?: Logger\n dryRun?: boolean\n}\n\nexport class FileManager {\n #cache = new Cache<KubbFile.ResolvedFile>()\n #limit = pLimit(100)\n\n constructor() {\n return this\n }\n\n async add<T extends Array<KubbFile.File> = Array<KubbFile.File>>(...files: T): AddResult<T> {\n const resolvedFiles: KubbFile.ResolvedFile[] = []\n\n const mergedFiles = new Map<string, KubbFile.File>()\n\n files.forEach((file) => {\n const existing = mergedFiles.get(file.path)\n if (existing) {\n mergedFiles.set(file.path, mergeFile(existing, file))\n } else {\n mergedFiles.set(file.path, file)\n }\n })\n\n for (const file of mergedFiles.values()) {\n const existing = await this.#cache.get(file.path)\n\n const merged = existing ? mergeFile(existing, file) : file\n const resolvedFile = createFile(merged)\n\n await this.#cache.set(resolvedFile.path, resolvedFile)\n await this.#cache.flush()\n\n resolvedFiles.push(resolvedFile)\n }\n\n if (files.length > 1) {\n return resolvedFiles as unknown as AddResult<T>\n }\n\n return resolvedFiles[0] as unknown as AddResult<T>\n }\n\n async getByPath(path: KubbFile.Path): Promise<KubbFile.ResolvedFile | null> {\n return this.#cache.get(path)\n }\n\n async deleteByPath(path: KubbFile.Path): Promise<void> {\n await this.#cache.delete(path)\n }\n\n async clear(): Promise<void> {\n await this.#cache.clear()\n }\n\n async getFiles(): Promise<Array<KubbFile.ResolvedFile>> {\n const cachedKeys = await this.#cache.keys()\n\n // order by path length and if file is a barrel file\n const keys = orderBy(cachedKeys, [(v) => v.length, (v) => trimExtName(v).endsWith('index')])\n\n const filesTasks = keys.map((key) =>\n this.#limit(async () => {\n const file = await this.#cache.get(key)\n return file as KubbFile.ResolvedFile\n }),\n )\n\n const files = await Promise.all(filesTasks)\n\n return files.filter(Boolean)\n }\n\n async processFiles({ dryRun, root, extension, logger }: WriteFilesProps): Promise<Array<KubbFile.ResolvedFile>> {\n const files = await this.getFiles()\n\n logger?.emit('progress_start', { id: 'files', size: files.length, message: 'Writing files ...' })\n\n const promises = files.map((file) => {\n return this.#limit(async () => {\n const message = file ? `Writing ${relative(root, file.path)}` : ''\n const extname = extension?.[file.extname] || undefined\n\n if (!dryRun) {\n const source = await getSource(file, { logger, extname })\n await write(file.path, source, { sanity: false })\n }\n\n logger?.emit('progressed', { id: 'files', message })\n })\n })\n\n await Promise.all(promises)\n\n logger?.emit('progress_stop', { id: 'files' })\n\n return files\n }\n async getBarrelFiles({ type, meta = {}, root, output, logger }: AddIndexesProps): Promise<KubbFile.File[]> {\n if (!type || type === 'propagate') {\n return []\n }\n\n const barrelManager = new BarrelManager({ logger })\n const files = await this.getFiles()\n\n const pathToBuildFrom = join(root, output.path)\n\n if (trimExtName(pathToBuildFrom).endsWith('index')) {\n logger?.emit('warning', 'Output has the same fileName as the barrelFiles, please disable barrel generation')\n\n return []\n }\n\n const barrelFiles = barrelManager.getFiles({ files, root: pathToBuildFrom, meta })\n\n if (type === 'all') {\n return barrelFiles.map((file) => {\n return {\n ...file,\n exports: file.exports?.map((exportItem) => {\n return {\n ...exportItem,\n name: undefined,\n }\n }),\n }\n })\n }\n\n return barrelFiles.map((indexFile) => {\n return {\n ...indexFile,\n meta,\n }\n })\n }\n\n // statics\n static getMode(path: string | undefined | null): KubbFile.Mode {\n if (!path) {\n return 'split'\n }\n return extname(path) ? 'single' : 'split'\n }\n}\n\ntype GetSourceOptions = {\n extname?: KubbFile.Extname\n logger?: Logger\n}\n\nexport async function getSource<TMeta extends FileMetaBase = FileMetaBase>(\n file: ResolvedFile<TMeta>,\n { logger, extname }: GetSourceOptions = {},\n): Promise<string> {\n const parser = await getFileParser(file.extname)\n const source = await parser.print(file, { logger, extname })\n\n return parser.format(source).catch((err) => {\n console.warn(err)\n return source\n })\n}\n\nfunction mergeFile<TMeta extends FileMetaBase = FileMetaBase>(a: KubbFile.File<TMeta>, b: KubbFile.File<TMeta>): KubbFile.File<TMeta> {\n return {\n ...a,\n sources: [...(a.sources || []), ...(b.sources || [])],\n imports: [...(a.imports || []), ...(b.imports || [])],\n exports: [...(a.exports || []), ...(b.exports || [])],\n }\n}\n\nexport function combineSources(sources: Array<KubbFile.Source>): Array<KubbFile.Source> {\n return uniqueBy(sources, (obj) => [obj.name, obj.isExportable, obj.isTypeOnly] as const)\n}\n\nexport function combineExports(exports: Array<KubbFile.Export>): Array<KubbFile.Export> {\n return orderBy(exports, [\n (v) => !!Array.isArray(v.name),\n (v) => !v.isTypeOnly,\n (v) => v.path,\n (v) => !!v.name,\n (v) => (Array.isArray(v.name) ? orderBy(v.name) : v.name),\n ]).reduce(\n (prev, curr) => {\n const name = curr.name\n const prevByPath = prev.findLast((imp) => imp.path === curr.path)\n const prevByPathAndIsTypeOnly = prev.findLast((imp) => imp.path === curr.path && isDeepEqual(imp.name, name) && imp.isTypeOnly)\n\n if (prevByPathAndIsTypeOnly) {\n // we already have an export that has the same path but uses `isTypeOnly` (export type ...)\n return prev\n }\n\n const uniquePrev = prev.findLast(\n (imp) => imp.path === curr.path && isDeepEqual(imp.name, name) && imp.isTypeOnly === curr.isTypeOnly && imp.asAlias === curr.asAlias,\n )\n\n // we already have an item that was unique enough or name field is empty or prev asAlias is set but current has no changes\n if (uniquePrev || (Array.isArray(name) && !name.length) || (prevByPath?.asAlias && !curr.asAlias)) {\n return prev\n }\n\n if (!prevByPath) {\n return [\n ...prev,\n {\n ...curr,\n name: Array.isArray(name) ? [...new Set(name)] : name,\n },\n ]\n }\n\n // merge all names when prev and current both have the same isTypeOnly set\n if (prevByPath && Array.isArray(prevByPath.name) && Array.isArray(curr.name) && prevByPath.isTypeOnly === curr.isTypeOnly) {\n prevByPath.name = [...new Set([...prevByPath.name, ...curr.name])]\n\n return prev\n }\n\n return [...prev, curr]\n },\n [] as Array<KubbFile.Export>,\n )\n}\n\nexport function combineImports(imports: Array<KubbFile.Import>, exports: Array<KubbFile.Export>, source?: string): Array<KubbFile.Import> {\n return orderBy(imports, [\n (v) => !!Array.isArray(v.name),\n (v) => !v.isTypeOnly,\n (v) => v.path,\n (v) => !!v.name,\n (v) => (Array.isArray(v.name) ? orderBy(v.name) : v.name),\n ]).reduce(\n (prev, curr) => {\n let name = Array.isArray(curr.name) ? [...new Set(curr.name)] : curr.name\n\n const hasImportInSource = (importName: string) => {\n if (!source) {\n return true\n }\n\n const checker = (name?: string) => {\n return name && source.includes(name)\n }\n\n return checker(importName) || exports.some(({ name }) => (Array.isArray(name) ? name.some(checker) : checker(name)))\n }\n\n if (curr.path === curr.root) {\n // root and path are the same file, remove the \"./\" import\n return prev\n }\n\n // merge all names and check if the importName is being used in the generated source and if not filter those imports out\n if (Array.isArray(name)) {\n name = name.filter((item) => (typeof item === 'string' ? hasImportInSource(item) : hasImportInSource(item.propertyName)))\n }\n\n const prevByPath = prev.findLast((imp) => imp.path === curr.path && imp.isTypeOnly === curr.isTypeOnly)\n const uniquePrev = prev.findLast((imp) => imp.path === curr.path && isDeepEqual(imp.name, name) && imp.isTypeOnly === curr.isTypeOnly)\n const prevByPathNameAndIsTypeOnly = prev.findLast((imp) => imp.path === curr.path && isDeepEqual(imp.name, name) && imp.isTypeOnly)\n\n if (prevByPathNameAndIsTypeOnly) {\n // we already have an export that has the same path but uses `isTypeOnly` (import type ...)\n return prev\n }\n\n // already unique enough or name is empty\n if (uniquePrev || (Array.isArray(name) && !name.length)) {\n return prev\n }\n\n // new item, append name\n if (!prevByPath) {\n return [\n ...prev,\n {\n ...curr,\n name,\n },\n ]\n }\n\n // merge all names when prev and current both have the same isTypeOnly set\n if (prevByPath && Array.isArray(prevByPath.name) && Array.isArray(name) && prevByPath.isTypeOnly === curr.isTypeOnly) {\n prevByPath.name = [...new Set([...prevByPath.name, ...name])]\n\n return prev\n }\n\n // no import was found in the source, ignore import\n if (!Array.isArray(name) && name && !hasImportInSource(name)) {\n return prev\n }\n\n return [...prev, curr]\n },\n [] as Array<KubbFile.Import>,\n )\n}\n"],"x_google_ignoreList":[0,1],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"FileManager-Cj9zsnb4.cjs","names":["#head","#tail","#size","#cachedLeaves","leaves: TreeNode[]","root: DirectoryTree","path","currentLevel: DirectoryTree[]","#options","barrelFile: KubbFile.File","item","getRelativePath","#items","#orderItems","#addParams","camelCase","type: string[]","name: string[]","item","path","#options","isValidVarName","camelCase","params: Record<string, string>","path","extname","exports","trimExtName","module","getRelativePath","parsers: Record<KubbFile.Extname, ParserModule<any>>","#buffer","resolvedFiles: KubbFile.ResolvedFile[]","#cache","path","trimExtName","#limit","extname","write","exports","name"],"sources":["../../../node_modules/.pnpm/yocto-queue@1.2.1/node_modules/yocto-queue/index.js","../../../node_modules/.pnpm/p-limit@7.0.0/node_modules/p-limit/index.js","../src/utils/TreeNode.ts","../src/BarrelManager.ts","../src/utils/FunctionParams.ts","../src/utils/promise.ts","../src/utils/renderTemplate.ts","../src/utils/timeout.ts","../src/utils/uniqueName.ts","../src/utils/URLPath.ts","../src/utils/parser.ts","../src/utils/Cache.ts","../src/FileManager.ts"],"sourcesContent":["/*\nHow it works:\n`this.#head` is an instance of `Node` which keeps track of its current value and nests another instance of `Node` that keeps the value that comes after it. When a value is provided to `.enqueue()`, the code needs to iterate through `this.#head`, going deeper and deeper to find the last value. However, iterating through every single item is slow. This problem is solved by saving a reference to the last value as `this.#tail` so that it can reference it to add a new value.\n*/\n\nclass Node {\n\tvalue;\n\tnext;\n\n\tconstructor(value) {\n\t\tthis.value = value;\n\t}\n}\n\nexport default class Queue {\n\t#head;\n\t#tail;\n\t#size;\n\n\tconstructor() {\n\t\tthis.clear();\n\t}\n\n\tenqueue(value) {\n\t\tconst node = new Node(value);\n\n\t\tif (this.#head) {\n\t\t\tthis.#tail.next = node;\n\t\t\tthis.#tail = node;\n\t\t} else {\n\t\t\tthis.#head = node;\n\t\t\tthis.#tail = node;\n\t\t}\n\n\t\tthis.#size++;\n\t}\n\n\tdequeue() {\n\t\tconst current = this.#head;\n\t\tif (!current) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.#head = this.#head.next;\n\t\tthis.#size--;\n\t\treturn current.value;\n\t}\n\n\tpeek() {\n\t\tif (!this.#head) {\n\t\t\treturn;\n\t\t}\n\n\t\treturn this.#head.value;\n\n\t\t// TODO: Node.js 18.\n\t\t// return this.#head?.value;\n\t}\n\n\tclear() {\n\t\tthis.#head = undefined;\n\t\tthis.#tail = undefined;\n\t\tthis.#size = 0;\n\t}\n\n\tget size() {\n\t\treturn this.#size;\n\t}\n\n\t* [Symbol.iterator]() {\n\t\tlet current = this.#head;\n\n\t\twhile (current) {\n\t\t\tyield current.value;\n\t\t\tcurrent = current.next;\n\t\t}\n\t}\n\n\t* drain() {\n\t\twhile (this.#head) {\n\t\t\tyield this.dequeue();\n\t\t}\n\t}\n}\n","import Queue from 'yocto-queue';\n\nexport default function pLimit(concurrency) {\n\tvalidateConcurrency(concurrency);\n\n\tconst queue = new Queue();\n\tlet activeCount = 0;\n\n\tconst resumeNext = () => {\n\t\t// Process the next queued function if we're under the concurrency limit\n\t\tif (activeCount < concurrency && queue.size > 0) {\n\t\t\tactiveCount++;\n\t\t\tqueue.dequeue()();\n\t\t}\n\t};\n\n\tconst next = () => {\n\t\tactiveCount--;\n\t\tresumeNext();\n\t};\n\n\tconst run = async (function_, resolve, arguments_) => {\n\t\t// Execute the function and capture the result promise\n\t\tconst result = (async () => function_(...arguments_))();\n\n\t\t// Resolve immediately with the promise (don't wait for completion)\n\t\tresolve(result);\n\n\t\t// Wait for the function to complete (success or failure)\n\t\t// We catch errors here to prevent unhandled rejections,\n\t\t// but the original promise rejection is preserved for the caller\n\t\ttry {\n\t\t\tawait result;\n\t\t} catch {}\n\n\t\t// Decrement active count and process next queued function\n\t\tnext();\n\t};\n\n\tconst enqueue = (function_, resolve, arguments_) => {\n\t\t// Queue the internal resolve function instead of the run function\n\t\t// to preserve the asynchronous execution context.\n\t\tnew Promise(internalResolve => { // eslint-disable-line promise/param-names\n\t\t\tqueue.enqueue(internalResolve);\n\t\t}).then(run.bind(undefined, function_, resolve, arguments_)); // eslint-disable-line promise/prefer-await-to-then\n\n\t\t// Start processing immediately if we haven't reached the concurrency limit\n\t\tif (activeCount < concurrency) {\n\t\t\tresumeNext();\n\t\t}\n\t};\n\n\tconst generator = (function_, ...arguments_) => new Promise(resolve => {\n\t\tenqueue(function_, resolve, arguments_);\n\t});\n\n\tObject.defineProperties(generator, {\n\t\tactiveCount: {\n\t\t\tget: () => activeCount,\n\t\t},\n\t\tpendingCount: {\n\t\t\tget: () => queue.size,\n\t\t},\n\t\tclearQueue: {\n\t\t\tvalue() {\n\t\t\t\tqueue.clear();\n\t\t\t},\n\t\t},\n\t\tconcurrency: {\n\t\t\tget: () => concurrency,\n\n\t\t\tset(newConcurrency) {\n\t\t\t\tvalidateConcurrency(newConcurrency);\n\t\t\t\tconcurrency = newConcurrency;\n\n\t\t\t\tqueueMicrotask(() => {\n\t\t\t\t\t// eslint-disable-next-line no-unmodified-loop-condition\n\t\t\t\t\twhile (activeCount < concurrency && queue.size > 0) {\n\t\t\t\t\t\tresumeNext();\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t},\n\t\t},\n\t\tmap: {\n\t\t\tasync value(array, function_) {\n\t\t\t\tconst promises = array.map(value => this(function_, value));\n\t\t\t\treturn Promise.all(promises);\n\t\t\t},\n\t\t},\n\t});\n\n\treturn generator;\n}\n\nexport function limitFunction(function_, options) {\n\tconst {concurrency} = options;\n\tconst limit = pLimit(concurrency);\n\n\treturn (...arguments_) => limit(() => function_(...arguments_));\n}\n\nfunction validateConcurrency(concurrency) {\n\tif (!((Number.isInteger(concurrency) || concurrency === Number.POSITIVE_INFINITY) && concurrency > 0)) {\n\t\tthrow new TypeError('Expected `concurrency` to be a number from 1 and up');\n\t}\n}\n","import { FileManager } from '../FileManager.ts'\nimport type { KubbFile } from '../fs/index.ts'\n\ntype BarrelData = {\n file?: KubbFile.File\n /**\n * @deprecated use file instead\n */\n type: KubbFile.Mode\n path: string\n name: string\n}\n\nexport class TreeNode {\n data: BarrelData\n parent?: TreeNode\n children: Array<TreeNode> = []\n #cachedLeaves?: Array<TreeNode> = undefined\n\n constructor(data: BarrelData, parent?: TreeNode) {\n this.data = data\n this.parent = parent\n return this\n }\n\n addChild(data: BarrelData): TreeNode {\n const child = new TreeNode(data, this)\n if (!this.children) {\n this.children = []\n }\n this.children.push(child)\n return child\n }\n\n get root(): TreeNode {\n if (!this.parent) {\n return this\n }\n return this.parent.root\n }\n\n get leaves(): Array<TreeNode> {\n if (!this.children || this.children.length === 0) {\n // this is a leaf\n return [this]\n }\n\n if (this.#cachedLeaves) {\n return this.#cachedLeaves\n }\n\n // if not a leaf, return all children's leaves recursively\n const leaves: TreeNode[] = []\n if (this.children) {\n for (let i = 0, { length } = this.children; i < length; i++) {\n leaves.push.apply(leaves, this.children[i]!.leaves)\n }\n }\n\n this.#cachedLeaves = leaves\n\n return leaves\n }\n\n forEach(callback: (treeNode: TreeNode) => void): this {\n if (typeof callback !== 'function') {\n throw new TypeError('forEach() callback must be a function')\n }\n\n // run this node through function\n callback(this)\n\n // do the same for all children\n if (this.children) {\n for (let i = 0, { length } = this.children; i < length; i++) {\n this.children[i]?.forEach(callback)\n }\n }\n\n return this\n }\n\n findDeep(predicate?: (value: TreeNode, index: number, obj: TreeNode[]) => boolean): TreeNode | undefined {\n if (typeof predicate !== 'function') {\n throw new TypeError('find() predicate must be a function')\n }\n\n return this.leaves.find(predicate)\n }\n\n forEachDeep(callback: (treeNode: TreeNode) => void): void {\n if (typeof callback !== 'function') {\n throw new TypeError('forEach() callback must be a function')\n }\n\n this.leaves.forEach(callback)\n }\n\n filterDeep(callback: (treeNode: TreeNode) => boolean): Array<TreeNode> {\n if (typeof callback !== 'function') {\n throw new TypeError('filter() callback must be a function')\n }\n\n return this.leaves.filter(callback)\n }\n\n mapDeep<T>(callback: (treeNode: TreeNode) => T): Array<T> {\n if (typeof callback !== 'function') {\n throw new TypeError('map() callback must be a function')\n }\n\n return this.leaves.map(callback)\n }\n\n public static build(files: KubbFile.File[], root?: string): TreeNode | null {\n try {\n const filteredTree = buildDirectoryTree(files, root)\n\n if (!filteredTree) {\n return null\n }\n\n const treeNode = new TreeNode({\n name: filteredTree.name,\n path: filteredTree.path,\n file: filteredTree.file,\n type: FileManager.getMode(filteredTree.path),\n })\n\n const recurse = (node: typeof treeNode, item: DirectoryTree) => {\n const subNode = node.addChild({\n name: item.name,\n path: item.path,\n file: item.file,\n type: FileManager.getMode(item.path),\n })\n\n if (item.children?.length) {\n item.children?.forEach((child) => {\n recurse(subNode, child)\n })\n }\n }\n\n filteredTree.children?.forEach((child) => {\n recurse(treeNode, child)\n })\n\n return treeNode\n } catch (e) {\n throw new Error('Something went wrong with creating barrel files with the TreeNode class', { cause: e })\n }\n }\n}\n\nexport type DirectoryTree = {\n name: string\n path: string\n file?: KubbFile.File\n children: Array<DirectoryTree>\n}\n\nconst normalizePath = (p: string): string => p.replace(/\\\\/g, '/')\n\nexport function buildDirectoryTree(files: Array<KubbFile.File>, rootFolder = ''): DirectoryTree | null {\n const normalizedRootFolder = normalizePath(rootFolder)\n const rootPrefix = normalizedRootFolder.endsWith('/') ? normalizedRootFolder : `${normalizedRootFolder}/`\n\n const filteredFiles = files.filter((file) => {\n const normalizedFilePath = normalizePath(file.path)\n return rootFolder ? normalizedFilePath.startsWith(rootPrefix) && !normalizedFilePath.endsWith('.json') : !normalizedFilePath.endsWith('.json')\n })\n\n if (filteredFiles.length === 0) {\n return null // No files match the root folder\n }\n\n const root: DirectoryTree = {\n name: rootFolder || '',\n path: rootFolder || '',\n children: [],\n }\n\n filteredFiles.forEach((file) => {\n const path = file.path.slice(rootFolder.length)\n const parts = path.split('/')\n let currentLevel: DirectoryTree[] = root.children\n let currentPath = rootFolder\n\n parts.forEach((part, index) => {\n if (index !== 0) {\n currentPath += `/${part}`\n } else {\n currentPath += `${part}`\n }\n\n let existingNode = currentLevel.find((node) => node.name === part)\n\n if (!existingNode) {\n if (index === parts.length - 1) {\n // If it's the last part, it's a file\n existingNode = {\n name: part,\n file,\n path: currentPath,\n } as DirectoryTree\n } else {\n // Otherwise, it's a folder\n existingNode = {\n name: part,\n path: currentPath,\n children: [],\n } as DirectoryTree\n }\n currentLevel.push(existingNode)\n }\n\n // Move to the next level if it's a folder\n if (!existingNode.file) {\n currentLevel = existingNode.children\n }\n })\n })\n\n return root\n}\n","/** biome-ignore-all lint/suspicious/useIterableCallbackReturn: not needed */\nimport { join } from 'node:path'\nimport type { FileMetaBase } from './FileManager.ts'\nimport type { KubbFile } from './fs/index.ts'\nimport { getRelativePath } from './fs/index.ts'\nimport type { Logger } from './logger.ts'\nimport { TreeNode } from './utils/TreeNode.ts'\n\ntype BarrelManagerOptions = {\n logger?: Logger\n}\n\nexport class BarrelManager {\n #options: BarrelManagerOptions\n\n constructor(options: BarrelManagerOptions = {}) {\n this.#options = options\n\n return this\n }\n\n getFiles({ files: generatedFiles, root }: { files: KubbFile.File[]; root?: string; meta?: FileMetaBase | undefined }): Array<KubbFile.File> {\n const { logger } = this.#options\n\n const cachedFiles = new Map<KubbFile.Path, KubbFile.File>()\n\n TreeNode.build(generatedFiles, root)?.forEach((treeNode) => {\n if (!treeNode || !treeNode.children || !treeNode.parent?.data.path) {\n return undefined\n }\n\n const barrelFile: KubbFile.File = {\n path: join(treeNode.parent?.data.path, 'index.ts') as KubbFile.Path,\n baseName: 'index.ts',\n exports: [],\n sources: [],\n }\n const previousBarrelFile = cachedFiles.get(barrelFile.path)\n const leaves = treeNode.leaves\n\n leaves.forEach((item) => {\n if (!item.data.name) {\n return undefined\n }\n\n const sources = item.data.file?.sources || []\n\n if (!sources.some((source) => source.isIndexable)) {\n logger?.emit(\n 'warning',\n `No isIndexable source found(source should have a name and isIndexable):\\nFile: ${JSON.stringify(item.data.file, undefined, 2)}`,\n )\n }\n\n sources.forEach((source) => {\n if (!item.data.file?.path || !source.isIndexable || !source.name) {\n return undefined\n }\n const alreadyContainInPreviousBarrelFile = previousBarrelFile?.sources.some(\n (item) => item.name === source.name && item.isTypeOnly === source.isTypeOnly,\n )\n\n if (alreadyContainInPreviousBarrelFile) {\n return undefined\n }\n\n if (!barrelFile.exports) {\n barrelFile.exports = []\n }\n\n // true when we have a subdirectory that also contains barrel files\n const isSubExport = !!treeNode.parent?.data.path?.split?.('/')?.length\n\n if (isSubExport) {\n barrelFile.exports.push({\n name: [source.name],\n path: getRelativePath(treeNode.parent?.data.path, item.data.path),\n isTypeOnly: source.isTypeOnly,\n })\n } else {\n barrelFile.exports.push({\n name: [source.name],\n path: `./${item.data.file.baseName}`,\n isTypeOnly: source.isTypeOnly,\n })\n }\n\n barrelFile.sources.push({\n name: source.name,\n isTypeOnly: source.isTypeOnly,\n //TODO use parser to generate import\n value: '',\n isExportable: false,\n isIndexable: false,\n })\n })\n })\n\n if (previousBarrelFile) {\n previousBarrelFile.sources.push(...barrelFile.sources)\n previousBarrelFile.exports?.push(...(barrelFile.exports || []))\n } else {\n cachedFiles.set(barrelFile.path, barrelFile)\n }\n })\n\n return [...cachedFiles.values()]\n }\n}\n","import { orderBy } from 'natural-orderby'\n\nimport { camelCase } from '../transformers/casing.ts'\n\ntype FunctionParamsASTWithoutType = {\n name?: string\n type?: string\n /**\n * @default true\n */\n required?: boolean\n /**\n * @default true\n */\n enabled?: boolean\n default?: string\n}\n\ntype FunctionParamsASTWithType = {\n name?: never\n type: string\n /**\n * @default true\n */\n required?: boolean\n /**\n * @default true\n */\n enabled?: boolean\n default?: string\n}\n/**\n * @deprecated\n */\nexport type FunctionParamsAST = FunctionParamsASTWithoutType | FunctionParamsASTWithType\n\n/**\n * @deprecated\n */\nexport class FunctionParams {\n #items: Array<FunctionParamsAST | FunctionParamsAST[]> = []\n constructor() {\n return this\n }\n\n get items(): FunctionParamsAST[] {\n return this.#items.flat()\n }\n\n add(item: FunctionParamsAST | Array<FunctionParamsAST | FunctionParamsAST[] | undefined> | undefined): FunctionParams {\n if (!item) {\n return this\n }\n\n if (Array.isArray(item)) {\n item.filter(Boolean).forEach((it) => {\n this.#items.push(it)\n })\n return this\n }\n this.#items.push(item)\n\n return this\n }\n static #orderItems(items: Array<FunctionParamsAST | FunctionParamsAST[]>) {\n return orderBy(\n items.filter(Boolean),\n [\n (v) => {\n if (Array.isArray(v)) {\n return undefined\n }\n return !v.default\n },\n (v) => {\n if (Array.isArray(v)) {\n return undefined\n }\n return v.required ?? true\n },\n ],\n ['desc', 'desc'],\n )\n }\n\n static #addParams(acc: string[], item: FunctionParamsAST) {\n const { enabled = true, name, type, required = true, ...rest } = item\n\n if (!enabled) {\n return acc\n }\n\n if (!name) {\n // when name is not se we will use TypeScript generics\n acc.push(`${type}${rest.default ? ` = ${rest.default}` : ''}`)\n\n return acc\n }\n // TODO check whey we still need the camelcase here\n const parameterName = name.startsWith('{') ? name : camelCase(name)\n\n if (type) {\n if (required) {\n acc.push(`${parameterName}: ${type}${rest.default ? ` = ${rest.default}` : ''}`)\n } else {\n acc.push(`${parameterName}?: ${type}`)\n }\n } else {\n acc.push(`${parameterName}`)\n }\n\n return acc\n }\n\n static toObject(items: FunctionParamsAST[]): FunctionParamsAST {\n let type: string[] = []\n let name: string[] = []\n\n const enabled = items.every((item) => item.enabled) ? items.at(0)?.enabled : true\n const required = items.every((item) => item.required) ?? true\n\n items.forEach((item) => {\n name = FunctionParams.#addParams(name, { ...item, type: undefined })\n if (items.some((item) => item.type)) {\n type = FunctionParams.#addParams(type, item)\n }\n })\n\n return {\n name: `{ ${name.join(', ')} }`,\n type: type.length ? `{ ${type.join('; ')} }` : undefined,\n enabled,\n required,\n }\n }\n\n static toString(items: (FunctionParamsAST | FunctionParamsAST[])[]): string {\n const sortedData = FunctionParams.#orderItems(items)\n\n return sortedData\n .reduce((acc, item) => {\n if (Array.isArray(item)) {\n if (item.length <= 0) {\n return acc\n }\n const subItems = FunctionParams.#orderItems(item) as FunctionParamsAST[]\n const objectItem = FunctionParams.toObject(subItems)\n\n return FunctionParams.#addParams(acc, objectItem)\n }\n\n return FunctionParams.#addParams(acc, item)\n }, [] as string[])\n .join(', ')\n }\n\n toObject(): FunctionParamsAST {\n const items = FunctionParams.#orderItems(this.#items).flat()\n\n return FunctionParams.toObject(items)\n }\n\n toString(): string {\n const items = FunctionParams.#orderItems(this.#items)\n\n return FunctionParams.toString(items)\n }\n}\n","import type { PossiblePromise } from './types.ts'\n\nexport function isPromise<T>(result: PossiblePromise<T>): result is Promise<T> {\n return !!result && typeof (result as Promise<unknown>)?.then === 'function'\n}\n\nexport function isPromiseFulfilledResult<T = unknown>(result: PromiseSettledResult<unknown>): result is PromiseFulfilledResult<T> {\n return result.status === 'fulfilled'\n}\n\nexport function isPromiseRejectedResult<T>(result: PromiseSettledResult<unknown>): result is Omit<PromiseRejectedResult, 'reason'> & { reason: T } {\n return result.status === 'rejected'\n}\n","export function renderTemplate<TData extends Record<string, unknown> = Record<string, unknown>>(template: string, data: TData | undefined = undefined): string {\n if (!data || !Object.keys(data).length) {\n return template.replace(/{{(.*?)}}/g, '')\n }\n\n const matches = template.match(/{{(.*?)}}/g)\n\n return (\n matches?.reduce((prev, curr) => {\n const index = curr.split(/{{|}}/).filter(Boolean)[0]?.trim()\n if (index === undefined) {\n return prev\n }\n const value = data[index]\n\n if (value === undefined) {\n return prev\n }\n\n return prev\n .replace(curr, () => {\n if (typeof value === 'boolean') {\n return `${value.toString()}` || 'false'\n }\n\n return (value as string) || ''\n })\n .trim()\n }, template) || ''\n )\n}\n","export async function timeout(ms: number): Promise<unknown> {\n return new Promise((resolve) => {\n setTimeout(() => {\n resolve(true)\n }, ms)\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","import { camelCase, isValidVarName } from '../transformers'\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\ntype Options = {\n casing?: 'camelcase'\n}\n\nexport class URLPath {\n path: string\n #options: Options\n\n constructor(path: string, options: Options = {}) {\n this.path = path\n this.#options = options\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({ prefix = '', replacer }: { prefix?: string; 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, path) => {\n const pathWithoutBrackets = path.replaceAll('{', '').replaceAll('}', '')\n\n let param = isValidVarName(pathWithoutBrackets) ? pathWithoutBrackets : camelCase(pathWithoutBrackets)\n\n if (this.#options.casing === 'camelcase') {\n param = camelCase(param)\n }\n\n return prev.replace(path, `\\${${replacer ? replacer(param) : param}}`)\n }, this.path)\n }\n\n return `\\`${prefix}${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 let param = isValidVarName(item) ? item : camelCase(item)\n\n if (this.#options.casing === 'camelcase') {\n param = camelCase(param)\n }\n\n const key = replacer ? replacer(param) : param\n\n params[key] = key\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","import path from 'node:path'\nimport type { KubbFile } from '../fs/index.ts'\n\nimport { getRelativePath } from '../fs/index.ts'\nimport hash from 'object-hash'\nimport { combineExports, combineImports, combineSources } from '../FileManager.ts'\nimport type { Logger } from '../logger.ts'\nimport type { Config } from '../types.ts'\n\n/**\n * Generate a default banner for files created by Kubb\n * @returns A string with the default banner\n */\nexport function getDefaultBanner({ title, description, version, config }: { title?: string; description?: string; version?: string; config: Config }): string {\n try {\n let source = ''\n if ('path' in config.input) {\n source = path.basename(config.input.path)\n } else if ('data' in config.input) {\n source = 'text content'\n }\n\n let banner = '/**\\n* Generated by Kubb (https://kubb.dev/).\\n* Do not edit manually.\\n'\n\n if (config.output.defaultBanner === 'simple') {\n banner += '*/\\n'\n return banner\n }\n\n if (source) {\n banner += `* Source: ${source}\\n`\n }\n\n if (title) {\n banner += `* Title: ${title}\\n`\n }\n\n if (description) {\n const formattedDescription = description.replace(/\\n/gm, '\\n* ')\n banner += `* Description: ${formattedDescription}\\n`\n }\n\n if (version) {\n banner += `* OpenAPI spec version: ${version}\\n`\n }\n\n banner += '*/\\n'\n return banner\n } catch (_error) {\n // If there's any error in parsing the Oas data, return a simpler banner\n return '/**\\n* Generated by Kubb (https://kubb.dev/).\\n* Do not edit manually.\\n*/'\n }\n}\n\n/**\n * Helper to create a file with name and id set\n */\nexport function createFile<TMeta extends object = object>(file: KubbFile.File<TMeta>): KubbFile.ResolvedFile<TMeta> {\n const extname = path.extname(file.baseName) as KubbFile.Extname\n if (!extname) {\n throw new Error(`No extname found for ${file.baseName}`)\n }\n\n const source = file.sources.map((item) => item.value).join('\\n\\n')\n const exports = file.exports?.length ? combineExports(file.exports) : []\n const imports = file.imports?.length && source ? combineImports(file.imports, exports, source) : []\n const sources = file.sources?.length ? combineSources(file.sources) : []\n\n return {\n ...file,\n id: hash({ path: file.path }),\n name: trimExtName(file.baseName),\n extname,\n imports: imports.map(createFileImport),\n exports: exports.map(createFileExport),\n sources: sources.map(createFileSource),\n meta: file.meta || ({} as TMeta),\n }\n}\n\n/**\n * Helper to create a fileImport with extname set\n */\nfunction createFileSource(source: KubbFile.Source): KubbFile.Source {\n return source\n}\n\n/**\n * Helper to create a fileImport with extname set\n */\nexport function createFileImport(imp: KubbFile.Import): KubbFile.ResolvedImport {\n return {\n ...imp,\n }\n}\n\n/**\n * Helper to create a fileExport with extname set\n */\nexport function createFileExport(exp: KubbFile.Export): KubbFile.ResolvedExport {\n return {\n ...exp,\n }\n}\n\nexport type ParserModule<TMeta extends object = object> = {\n format: (source: string) => Promise<string>\n /**\n * Convert a file to string\n */\n print: (file: KubbFile.ResolvedFile<TMeta>, options: PrintOptions) => Promise<string>\n}\n\nexport function createFileParser<TMeta extends object = object>(parser: ParserModule<TMeta>): ParserModule<TMeta> {\n return parser\n}\n\ntype PrintOptions = {\n extname?: KubbFile.Extname\n logger?: Logger\n}\n\nconst typeScriptParser = createFileParser({\n async format(source) {\n const module = await import('@kubb/parser-ts')\n\n return module.format(source)\n },\n async print(file, options = { extname: '.ts' }) {\n const module = await import('@kubb/parser-ts')\n\n const source = file.sources.map((item) => item.value).join('\\n\\n')\n\n const importNodes = file.imports\n .map((item) => {\n const importPath = item.root ? getRelativePath(item.root, item.path) : item.path\n const hasExtname = !!path.extname(importPath)\n\n return module.factory.createImportDeclaration({\n name: item.name,\n path: options.extname && hasExtname ? `${trimExtName(importPath)}${options.extname}` : item.root ? trimExtName(importPath) : importPath,\n isTypeOnly: item.isTypeOnly,\n })\n })\n .filter(Boolean)\n\n const exportNodes = file.exports\n .map((item) => {\n const exportPath = item.path\n\n const hasExtname = !!path.extname(exportPath)\n\n return module.factory.createExportDeclaration({\n name: item.name,\n path: options.extname && hasExtname ? `${trimExtName(item.path)}${options.extname}` : trimExtName(item.path),\n isTypeOnly: item.isTypeOnly,\n asAlias: item.asAlias,\n })\n })\n .filter(Boolean)\n\n return [file.banner, module.print([...importNodes, ...exportNodes]), source, file.footer].join('\\n')\n },\n})\n\nconst tsxParser = createFileParser({\n async format(source) {\n const module = await import('@kubb/parser-ts')\n //4 = tsx\n return module.format(source)\n },\n async print(file, options = { extname: '.tsx' }) {\n return typeScriptParser.print(file, options)\n },\n})\n\nconst defaultParser = createFileParser({\n async format(source) {\n return source\n },\n async print(file) {\n return file.sources.map((item) => item.value).join('\\n\\n')\n },\n})\n\nconst parsers: Record<KubbFile.Extname, ParserModule<any>> = {\n '.ts': typeScriptParser,\n '.js': typeScriptParser,\n '.jsx': tsxParser,\n '.tsx': tsxParser,\n '.json': defaultParser,\n}\n\nexport async function getFileParser<TMeta extends object = object>(extname: KubbFile.Extname | undefined): Promise<ParserModule<TMeta>> {\n if (!extname) {\n return defaultParser\n }\n\n const parser = parsers[extname]\n\n if (!parser) {\n console.warn(`[parser] No parser found for ${extname}, default parser will be used`)\n }\n\n return parser || defaultParser\n}\n\nfunction trimExtName(text: string): string {\n const extname = text.split('.').pop()\n\n return text.replace(`.${extname}`, '')\n}\n","export class Cache<T> {\n #buffer = new Map<string, T>()\n\n async get(key: string): Promise<T | null> {\n return this.#buffer.get(key) ?? null\n }\n\n async set(key: string, value: T): Promise<void> {\n this.#buffer.set(key, value)\n }\n\n async delete(key: string): Promise<void> {\n this.#buffer.delete(key)\n }\n\n async clear(): Promise<void> {\n this.#buffer.clear()\n }\n\n async keys(): Promise<string[]> {\n return [...this.#buffer.keys()]\n }\n\n async values(): Promise<T[]> {\n return [...this.#buffer.values()]\n }\n\n async flush(): Promise<void> {\n // No-op for base cache\n }\n}\n","import { extname, join, relative } from 'node:path'\n\nimport { orderBy } from 'natural-orderby'\nimport { isDeepEqual, uniqueBy } from 'remeda'\nimport pLimit from 'p-limit'\n\nimport { BarrelManager } from './BarrelManager.ts'\n\nimport type { KubbFile } from './fs/index.ts'\nimport { trimExtName, write } from './fs/index.ts'\nimport type { ResolvedFile } from './fs/types.ts'\nimport type { Logger } from './logger.ts'\nimport type { BarrelType, Config, Plugin } from './types.ts'\nimport { createFile, getFileParser } from './utils'\nimport type { GreaterThan } from './utils/types.ts'\nimport { Cache } from './utils/Cache.ts'\n\nexport type FileMetaBase = {\n pluginKey?: Plugin['key']\n}\n\ntype AddResult<T extends Array<KubbFile.File>> = Promise<Awaited<GreaterThan<T['length'], 1> extends true ? Promise<ResolvedFile[]> : Promise<ResolvedFile>>>\n\ntype AddIndexesProps = {\n type: BarrelType | false | undefined\n /**\n * Root based on root and output.path specified in the config\n */\n root: string\n /**\n * Output for plugin\n */\n output: {\n path: string\n }\n group?: {\n output: string\n exportAs: string\n }\n logger?: Logger\n\n meta?: FileMetaBase\n}\n\ntype WriteFilesProps = {\n root: Config['root']\n extension?: Record<KubbFile.Extname, KubbFile.Extname | ''>\n logger?: Logger\n dryRun?: boolean\n}\n\nexport class FileManager {\n #cache = new Cache<KubbFile.ResolvedFile>()\n #limit = pLimit(100)\n\n constructor() {\n return this\n }\n\n async add<T extends Array<KubbFile.File> = Array<KubbFile.File>>(...files: T): AddResult<T> {\n const resolvedFiles: KubbFile.ResolvedFile[] = []\n\n const mergedFiles = new Map<string, KubbFile.File>()\n\n files.forEach((file) => {\n const existing = mergedFiles.get(file.path)\n if (existing) {\n mergedFiles.set(file.path, mergeFile(existing, file))\n } else {\n mergedFiles.set(file.path, file)\n }\n })\n\n for (const file of mergedFiles.values()) {\n const existing = await this.#cache.get(file.path)\n\n const merged = existing ? mergeFile(existing, file) : file\n const resolvedFile = createFile(merged)\n\n await this.#cache.set(resolvedFile.path, resolvedFile)\n await this.#cache.flush()\n\n resolvedFiles.push(resolvedFile)\n }\n\n if (files.length > 1) {\n return resolvedFiles as unknown as AddResult<T>\n }\n\n return resolvedFiles[0] as unknown as AddResult<T>\n }\n\n async getByPath(path: KubbFile.Path): Promise<KubbFile.ResolvedFile | null> {\n return this.#cache.get(path)\n }\n\n async deleteByPath(path: KubbFile.Path): Promise<void> {\n await this.#cache.delete(path)\n }\n\n async clear(): Promise<void> {\n await this.#cache.clear()\n }\n\n async getFiles(): Promise<Array<KubbFile.ResolvedFile>> {\n const cachedKeys = await this.#cache.keys()\n\n // order by path length and if file is a barrel file\n const keys = orderBy(cachedKeys, [(v) => v.length, (v) => trimExtName(v).endsWith('index')])\n\n const filesTasks = keys.map((key) =>\n this.#limit(async () => {\n const file = await this.#cache.get(key)\n return file as KubbFile.ResolvedFile\n }),\n )\n\n const files = await Promise.all(filesTasks)\n\n return files.filter(Boolean)\n }\n\n async processFiles({ dryRun, root, extension, logger }: WriteFilesProps): Promise<Array<KubbFile.ResolvedFile>> {\n const files = await this.getFiles()\n\n logger?.emit('progress_start', { id: 'files', size: files.length, message: 'Writing files ...' })\n\n const promises = files.map((file) => {\n return this.#limit(async () => {\n const message = file ? `Writing ${relative(root, file.path)}` : ''\n const extname = extension?.[file.extname] || undefined\n\n if (!dryRun) {\n const source = await getSource(file, { logger, extname })\n await write(file.path, source, { sanity: false })\n }\n\n logger?.emit('progressed', { id: 'files', message })\n })\n })\n\n await Promise.all(promises)\n\n logger?.emit('progress_stop', { id: 'files' })\n\n return files\n }\n async getBarrelFiles({ type, meta = {}, root, output, logger }: AddIndexesProps): Promise<KubbFile.File[]> {\n if (!type || type === 'propagate') {\n return []\n }\n\n const barrelManager = new BarrelManager({ logger })\n const files = await this.getFiles()\n\n const pathToBuildFrom = join(root, output.path)\n\n if (trimExtName(pathToBuildFrom).endsWith('index')) {\n logger?.emit('warning', 'Output has the same fileName as the barrelFiles, please disable barrel generation')\n\n return []\n }\n\n const barrelFiles = barrelManager.getFiles({ files, root: pathToBuildFrom, meta })\n\n if (type === 'all') {\n return barrelFiles.map((file) => {\n return {\n ...file,\n exports: file.exports?.map((exportItem) => {\n return {\n ...exportItem,\n name: undefined,\n }\n }),\n }\n })\n }\n\n return barrelFiles.map((indexFile) => {\n return {\n ...indexFile,\n meta,\n }\n })\n }\n\n // statics\n static getMode(path: string | undefined | null): KubbFile.Mode {\n if (!path) {\n return 'split'\n }\n return extname(path) ? 'single' : 'split'\n }\n}\n\ntype GetSourceOptions = {\n extname?: KubbFile.Extname\n logger?: Logger\n}\n\nexport async function getSource<TMeta extends FileMetaBase = FileMetaBase>(\n file: ResolvedFile<TMeta>,\n { logger, extname }: GetSourceOptions = {},\n): Promise<string> {\n const parser = await getFileParser(file.extname)\n const source = await parser.print(file, { logger, extname })\n\n return parser.format(source).catch((err) => {\n console.warn(err)\n return source\n })\n}\n\nfunction mergeFile<TMeta extends FileMetaBase = FileMetaBase>(a: KubbFile.File<TMeta>, b: KubbFile.File<TMeta>): KubbFile.File<TMeta> {\n return {\n ...a,\n sources: [...(a.sources || []), ...(b.sources || [])],\n imports: [...(a.imports || []), ...(b.imports || [])],\n exports: [...(a.exports || []), ...(b.exports || [])],\n }\n}\n\nexport function combineSources(sources: Array<KubbFile.Source>): Array<KubbFile.Source> {\n return uniqueBy(sources, (obj) => [obj.name, obj.isExportable, obj.isTypeOnly] as const)\n}\n\nexport function combineExports(exports: Array<KubbFile.Export>): Array<KubbFile.Export> {\n return orderBy(exports, [\n (v) => !!Array.isArray(v.name),\n (v) => !v.isTypeOnly,\n (v) => v.path,\n (v) => !!v.name,\n (v) => (Array.isArray(v.name) ? orderBy(v.name) : v.name),\n ]).reduce(\n (prev, curr) => {\n const name = curr.name\n const prevByPath = prev.findLast((imp) => imp.path === curr.path)\n const prevByPathAndIsTypeOnly = prev.findLast((imp) => imp.path === curr.path && isDeepEqual(imp.name, name) && imp.isTypeOnly)\n\n if (prevByPathAndIsTypeOnly) {\n // we already have an export that has the same path but uses `isTypeOnly` (export type ...)\n return prev\n }\n\n const uniquePrev = prev.findLast(\n (imp) => imp.path === curr.path && isDeepEqual(imp.name, name) && imp.isTypeOnly === curr.isTypeOnly && imp.asAlias === curr.asAlias,\n )\n\n // we already have an item that was unique enough or name field is empty or prev asAlias is set but current has no changes\n if (uniquePrev || (Array.isArray(name) && !name.length) || (prevByPath?.asAlias && !curr.asAlias)) {\n return prev\n }\n\n if (!prevByPath) {\n return [\n ...prev,\n {\n ...curr,\n name: Array.isArray(name) ? [...new Set(name)] : name,\n },\n ]\n }\n\n // merge all names when prev and current both have the same isTypeOnly set\n if (prevByPath && Array.isArray(prevByPath.name) && Array.isArray(curr.name) && prevByPath.isTypeOnly === curr.isTypeOnly) {\n prevByPath.name = [...new Set([...prevByPath.name, ...curr.name])]\n\n return prev\n }\n\n return [...prev, curr]\n },\n [] as Array<KubbFile.Export>,\n )\n}\n\nexport function combineImports(imports: Array<KubbFile.Import>, exports: Array<KubbFile.Export>, source?: string): Array<KubbFile.Import> {\n return orderBy(imports, [\n (v) => !!Array.isArray(v.name),\n (v) => !v.isTypeOnly,\n (v) => v.path,\n (v) => !!v.name,\n (v) => (Array.isArray(v.name) ? orderBy(v.name) : v.name),\n ]).reduce(\n (prev, curr) => {\n let name = Array.isArray(curr.name) ? [...new Set(curr.name)] : curr.name\n\n const hasImportInSource = (importName: string) => {\n if (!source) {\n return true\n }\n\n const checker = (name?: string) => {\n return name && source.includes(name)\n }\n\n return checker(importName) || exports.some(({ name }) => (Array.isArray(name) ? name.some(checker) : checker(name)))\n }\n\n if (curr.path === curr.root) {\n // root and path are the same file, remove the \"./\" import\n return prev\n }\n\n // merge all names and check if the importName is being used in the generated source and if not filter those imports out\n if (Array.isArray(name)) {\n name = name.filter((item) => (typeof item === 'string' ? hasImportInSource(item) : hasImportInSource(item.propertyName)))\n }\n\n const prevByPath = prev.findLast((imp) => imp.path === curr.path && imp.isTypeOnly === curr.isTypeOnly)\n const uniquePrev = prev.findLast((imp) => imp.path === curr.path && isDeepEqual(imp.name, name) && imp.isTypeOnly === curr.isTypeOnly)\n const prevByPathNameAndIsTypeOnly = prev.findLast((imp) => imp.path === curr.path && isDeepEqual(imp.name, name) && imp.isTypeOnly)\n\n if (prevByPathNameAndIsTypeOnly) {\n // we already have an export that has the same path but uses `isTypeOnly` (import type ...)\n return prev\n }\n\n // already unique enough or name is empty\n if (uniquePrev || (Array.isArray(name) && !name.length)) {\n return prev\n }\n\n // new item, append name\n if (!prevByPath) {\n return [\n ...prev,\n {\n ...curr,\n name,\n },\n ]\n }\n\n // merge all names when prev and current both have the same isTypeOnly set\n if (prevByPath && Array.isArray(prevByPath.name) && Array.isArray(name) && prevByPath.isTypeOnly === curr.isTypeOnly) {\n prevByPath.name = [...new Set([...prevByPath.name, ...name])]\n\n return prev\n }\n\n // no import was found in the source, ignore import\n if (!Array.isArray(name) && name && !hasImportInSource(name)) {\n return prev\n }\n\n return [...prev, curr]\n },\n [] as Array<KubbFile.Import>,\n )\n}\n"],"x_google_ignoreList":[0,1],"mappings":"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"}
|
package/dist/fs-BacxV1CO.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"fs-BacxV1CO.js","names":["path","reader","path","syncReader","path","path"],"sources":["../src/fs/clean.ts","../src/fs/read.ts","../src/fs/exists.ts","../src/fs/utils.ts","../src/fs/types.ts","../src/fs/index.ts"],"sourcesContent":["import fs from 'fs-extra'\n\nexport async function clean(path: string): Promise<void> {\n return fs.remove(path)\n}\n","import fs from 'fs-extra'\nimport { switcher } from 'js-runtime'\n\nconst reader = switcher(\n {\n node: async (path: string) => {\n return fs.readFile(path, { encoding: 'utf8' })\n },\n bun: async (path: string) => {\n const file = Bun.file(path)\n\n return file.text()\n },\n },\n 'node',\n)\n\nconst syncReader = switcher(\n {\n node: (path: string) => {\n return fs.readFileSync(path, { encoding: 'utf8' })\n },\n bun: () => {\n throw new Error('Bun cannot read sync')\n },\n },\n 'node',\n)\n\nexport async function read(path: string): Promise<string> {\n return reader(path)\n}\n\nexport function readSync(path: string): string {\n return syncReader(path)\n}\n","import fs from 'fs-extra'\nimport { switcher } from 'js-runtime'\n\nconst reader = switcher(\n {\n node: async (path: string) => {\n return fs.pathExists(path)\n },\n bun: async (path: string) => {\n const file = Bun.file(path)\n\n return file.exists()\n },\n },\n 'node',\n)\n\nconst syncReader = switcher(\n {\n node: (path: string) => {\n return fs.pathExistsSync(path)\n },\n bun: () => {\n throw new Error('Bun cannot read sync')\n },\n },\n 'node',\n)\n\nexport async function exists(path: string): Promise<boolean> {\n return reader(path)\n}\n\nexport function existsSync(path: string): boolean {\n return syncReader(path)\n}\n","import { normalize, relative } from 'node:path'\n\nfunction slash(path: string, platform: 'windows' | 'mac' | 'linux' = 'linux') {\n const isWindowsPath = /^\\\\\\\\\\?\\\\/.test(path)\n const normalizedPath = normalize(path)\n\n if (['linux', 'mac'].includes(platform) && !isWindowsPath) {\n // linux and mac\n return normalizedPath.replaceAll(/\\\\/g, '/').replace('../', '')\n }\n\n // windows\n return normalizedPath.replaceAll(/\\\\/g, '/').replace('../', '')\n}\n\nexport function getRelativePath(rootDir?: string | null, filePath?: string | null, platform: 'windows' | 'mac' | 'linux' = 'linux'): string {\n if (!rootDir || !filePath) {\n throw new Error(`Root and file should be filled in when retrieving the relativePath, ${rootDir || ''} ${filePath || ''}`)\n }\n\n const relativePath = relative(rootDir, filePath)\n\n // On Windows, paths are separated with a \"\\\"\n // However, web browsers use \"/\" no matter the platform\n const slashedPath = slash(relativePath, platform)\n\n if (slashedPath.startsWith('../')) {\n return slashedPath\n }\n\n return `./${slashedPath}`\n}\n","type BasePath<T extends string = string> = `${T}/`\n\nexport type Import = {\n /**\n * Import name to be used\n * @example [\"useState\"]\n * @example \"React\"\n */\n name:\n | string\n | Array<\n | string\n | {\n propertyName: string\n name?: string\n }\n >\n /**\n * Path for the import\n * @example '@kubb/core'\n */\n path: string\n /**\n * Add `type` prefix to the import, this will result in: `import type { Type } from './path'`.\n */\n isTypeOnly?: boolean\n\n isNameSpace?: boolean\n /**\n * When root is set it will get the path with relative getRelativePath(root, path).\n */\n root?: string\n}\n\nexport type Source = {\n name?: string\n value?: string\n isTypeOnly?: boolean\n /**\n * Has const or type 'export'\n * @default false\n */\n isExportable?: boolean\n /**\n * When set, barrel generation will add this\n * @default false\n */\n isIndexable?: boolean\n}\n\nexport type Export = {\n /**\n * Export name to be used.\n * @example [\"useState\"]\n * @example \"React\"\n */\n name?: string | Array<string>\n /**\n * Path for the import.\n * @example '@kubb/core'\n */\n path: string\n /**\n * Add `type` prefix to the export, this will result in: `export type { Type } from './path'`.\n */\n isTypeOnly?: boolean\n /**\n * Make it possible to override the name, this will result in: `export * as aliasName from './path'`.\n */\n asAlias?: boolean\n}\n\nexport type Extname = '.ts' | '.js' | '.tsx' | '.json' | `.${string}`\n\nexport type Mode = 'single' | 'split'\n\n/**\n * Name to be used to dynamicly create the baseName(based on input.path)\n * Based on UNIX basename\n * @link https://nodejs.org/api/path.html#pathbasenamepath-suffix\n */\nexport type BaseName = `${string}.${string}`\n\n/**\n * Path will be full qualified path to a specified file\n */\nexport type Path = string\n\nexport type AdvancedPath<T extends BaseName = BaseName> = `${BasePath}${T}`\n\nexport type OptionalPath = Path | undefined | null\n\nexport type File<TMeta extends object = object> = {\n /**\n * Name to be used to create the path\n * Based on UNIX basename, `${name}.extname`\n * @link https://nodejs.org/api/path.html#pathbasenamepath-suffix\n */\n baseName: BaseName\n /**\n * Path will be full qualified path to a specified file\n */\n path: AdvancedPath<BaseName> | Path\n sources: Array<Source>\n imports?: Array<Import>\n exports?: Array<Export>\n /**\n * Use extra meta, this is getting used to generate the barrel/index files.\n */\n meta?: TMeta\n banner?: string\n footer?: string\n}\n\nexport type ResolvedImport = Import\n\nexport type ResolvedExport = Export\n\nexport type ResolvedFile<TMeta extends object = object> = File<TMeta> & {\n /**\n * @default object-hash\n */\n id: string\n /**\n * Contains the first part of the baseName, generated based on baseName\n * @link https://nodejs.org/api/path.html#pathformatpathobject\n */\n name: string\n extname: Extname\n imports: Array<ResolvedImport>\n exports: Array<ResolvedExport>\n}\n","export { clean } from './clean.ts'\nexport { read, readSync } from './read.ts'\nexport { write } from './write.ts'\nexport { exists } from './exists.ts'\nexport { getRelativePath } from './utils.ts'\n\nexport function trimExtName(text: string): string {\n return text.replace(/\\.[^/.]+$/, '')\n}\n\nexport * as KubbFile from './types.ts'\n"],"mappings":";;;;;AAEA,eAAsB,MAAM,QAA6B;AACvD,QAAO,GAAG,OAAOA;AAClB;;;;ACDD,MAAMC,WAAS,SACb;CACE,MAAM,OAAO,WAAiB;AAC5B,SAAO,GAAG,SAASC,QAAM,EAAE,UAAU,QAAQ;CAC9C;CACD,KAAK,OAAO,WAAiB;EAC3B,MAAM,OAAO,IAAI,KAAKA;AAEtB,SAAO,KAAK;CACb;CACF,EACD;AAGF,MAAMC,eAAa,SACjB;CACE,OAAO,WAAiB;AACtB,SAAO,GAAG,aAAaD,QAAM,EAAE,UAAU,QAAQ;CAClD;CACD,WAAW;AACT,QAAM,IAAI,MAAM;CACjB;CACF,EACD;AAGF,eAAsB,KAAK,QAA+B;AACxD,QAAOD,SAAOC;AACf;AAED,SAAgB,SAAS,QAAsB;AAC7C,QAAOC,aAAWD;AACnB;;;;AChCD,MAAM,SAAS,SACb;CACE,MAAM,OAAO,WAAiB;AAC5B,SAAO,GAAG,WAAWE;CACtB;CACD,KAAK,OAAO,WAAiB;EAC3B,MAAM,OAAO,IAAI,KAAKA;AAEtB,SAAO,KAAK;CACb;CACF,EACD;AAGF,MAAM,aAAa,SACjB;CACE,OAAO,WAAiB;AACtB,SAAO,GAAG,eAAeA;CAC1B;CACD,WAAW;AACT,QAAM,IAAI,MAAM;CACjB;CACF,EACD;AAGF,eAAsB,OAAO,QAAgC;AAC3D,QAAO,OAAOA;AACf;;;;AC7BD,SAAS,MAAM,QAAc,WAAwC,SAAS;CAC5E,MAAM,gBAAgB,YAAY,KAAKC;CACvC,MAAM,iBAAiB,UAAUA;AAEjC,KAAI,CAAC,SAAS,MAAM,CAAC,SAAS,aAAa,CAAC,cAE1C,QAAO,eAAe,WAAW,OAAO,KAAK,QAAQ,OAAO;AAI9D,QAAO,eAAe,WAAW,OAAO,KAAK,QAAQ,OAAO;AAC7D;AAED,SAAgB,gBAAgB,SAAyB,UAA0B,WAAwC,SAAiB;AAC1I,KAAI,CAAC,WAAW,CAAC,SACf,OAAM,IAAI,MAAM,uEAAuE,WAAW,GAAG,GAAG,YAAY;CAGtH,MAAM,eAAe,SAAS,SAAS;CAIvC,MAAM,cAAc,MAAM,cAAc;AAExC,KAAI,YAAY,WAAW,OACzB,QAAO;AAGT,QAAO,KAAK;AACb;;;;;;;;AEzBD,SAAgB,YAAY,MAAsB;AAChD,QAAO,KAAK,QAAQ,aAAa;AAClC"}
|
package/dist/fs-BazSaf2y.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"fs-BazSaf2y.cjs","names":["fs","reader","fs","syncReader","fs"],"sources":["../src/fs/clean.ts","../src/fs/read.ts","../src/fs/exists.ts","../src/fs/utils.ts","../src/fs/types.ts","../src/fs/index.ts"],"sourcesContent":["import fs from 'fs-extra'\n\nexport async function clean(path: string): Promise<void> {\n return fs.remove(path)\n}\n","import fs from 'fs-extra'\nimport { switcher } from 'js-runtime'\n\nconst reader = switcher(\n {\n node: async (path: string) => {\n return fs.readFile(path, { encoding: 'utf8' })\n },\n bun: async (path: string) => {\n const file = Bun.file(path)\n\n return file.text()\n },\n },\n 'node',\n)\n\nconst syncReader = switcher(\n {\n node: (path: string) => {\n return fs.readFileSync(path, { encoding: 'utf8' })\n },\n bun: () => {\n throw new Error('Bun cannot read sync')\n },\n },\n 'node',\n)\n\nexport async function read(path: string): Promise<string> {\n return reader(path)\n}\n\nexport function readSync(path: string): string {\n return syncReader(path)\n}\n","import fs from 'fs-extra'\nimport { switcher } from 'js-runtime'\n\nconst reader = switcher(\n {\n node: async (path: string) => {\n return fs.pathExists(path)\n },\n bun: async (path: string) => {\n const file = Bun.file(path)\n\n return file.exists()\n },\n },\n 'node',\n)\n\nconst syncReader = switcher(\n {\n node: (path: string) => {\n return fs.pathExistsSync(path)\n },\n bun: () => {\n throw new Error('Bun cannot read sync')\n },\n },\n 'node',\n)\n\nexport async function exists(path: string): Promise<boolean> {\n return reader(path)\n}\n\nexport function existsSync(path: string): boolean {\n return syncReader(path)\n}\n","import { normalize, relative } from 'node:path'\n\nfunction slash(path: string, platform: 'windows' | 'mac' | 'linux' = 'linux') {\n const isWindowsPath = /^\\\\\\\\\\?\\\\/.test(path)\n const normalizedPath = normalize(path)\n\n if (['linux', 'mac'].includes(platform) && !isWindowsPath) {\n // linux and mac\n return normalizedPath.replaceAll(/\\\\/g, '/').replace('../', '')\n }\n\n // windows\n return normalizedPath.replaceAll(/\\\\/g, '/').replace('../', '')\n}\n\nexport function getRelativePath(rootDir?: string | null, filePath?: string | null, platform: 'windows' | 'mac' | 'linux' = 'linux'): string {\n if (!rootDir || !filePath) {\n throw new Error(`Root and file should be filled in when retrieving the relativePath, ${rootDir || ''} ${filePath || ''}`)\n }\n\n const relativePath = relative(rootDir, filePath)\n\n // On Windows, paths are separated with a \"\\\"\n // However, web browsers use \"/\" no matter the platform\n const slashedPath = slash(relativePath, platform)\n\n if (slashedPath.startsWith('../')) {\n return slashedPath\n }\n\n return `./${slashedPath}`\n}\n","type BasePath<T extends string = string> = `${T}/`\n\nexport type Import = {\n /**\n * Import name to be used\n * @example [\"useState\"]\n * @example \"React\"\n */\n name:\n | string\n | Array<\n | string\n | {\n propertyName: string\n name?: string\n }\n >\n /**\n * Path for the import\n * @example '@kubb/core'\n */\n path: string\n /**\n * Add `type` prefix to the import, this will result in: `import type { Type } from './path'`.\n */\n isTypeOnly?: boolean\n\n isNameSpace?: boolean\n /**\n * When root is set it will get the path with relative getRelativePath(root, path).\n */\n root?: string\n}\n\nexport type Source = {\n name?: string\n value?: string\n isTypeOnly?: boolean\n /**\n * Has const or type 'export'\n * @default false\n */\n isExportable?: boolean\n /**\n * When set, barrel generation will add this\n * @default false\n */\n isIndexable?: boolean\n}\n\nexport type Export = {\n /**\n * Export name to be used.\n * @example [\"useState\"]\n * @example \"React\"\n */\n name?: string | Array<string>\n /**\n * Path for the import.\n * @example '@kubb/core'\n */\n path: string\n /**\n * Add `type` prefix to the export, this will result in: `export type { Type } from './path'`.\n */\n isTypeOnly?: boolean\n /**\n * Make it possible to override the name, this will result in: `export * as aliasName from './path'`.\n */\n asAlias?: boolean\n}\n\nexport type Extname = '.ts' | '.js' | '.tsx' | '.json' | `.${string}`\n\nexport type Mode = 'single' | 'split'\n\n/**\n * Name to be used to dynamicly create the baseName(based on input.path)\n * Based on UNIX basename\n * @link https://nodejs.org/api/path.html#pathbasenamepath-suffix\n */\nexport type BaseName = `${string}.${string}`\n\n/**\n * Path will be full qualified path to a specified file\n */\nexport type Path = string\n\nexport type AdvancedPath<T extends BaseName = BaseName> = `${BasePath}${T}`\n\nexport type OptionalPath = Path | undefined | null\n\nexport type File<TMeta extends object = object> = {\n /**\n * Name to be used to create the path\n * Based on UNIX basename, `${name}.extname`\n * @link https://nodejs.org/api/path.html#pathbasenamepath-suffix\n */\n baseName: BaseName\n /**\n * Path will be full qualified path to a specified file\n */\n path: AdvancedPath<BaseName> | Path\n sources: Array<Source>\n imports?: Array<Import>\n exports?: Array<Export>\n /**\n * Use extra meta, this is getting used to generate the barrel/index files.\n */\n meta?: TMeta\n banner?: string\n footer?: string\n}\n\nexport type ResolvedImport = Import\n\nexport type ResolvedExport = Export\n\nexport type ResolvedFile<TMeta extends object = object> = File<TMeta> & {\n /**\n * @default object-hash\n */\n id: string\n /**\n * Contains the first part of the baseName, generated based on baseName\n * @link https://nodejs.org/api/path.html#pathformatpathobject\n */\n name: string\n extname: Extname\n imports: Array<ResolvedImport>\n exports: Array<ResolvedExport>\n}\n","export { clean } from './clean.ts'\nexport { read, readSync } from './read.ts'\nexport { write } from './write.ts'\nexport { exists } from './exists.ts'\nexport { getRelativePath } from './utils.ts'\n\nexport function trimExtName(text: string): string {\n return text.replace(/\\.[^/.]+$/, '')\n}\n\nexport * as KubbFile from './types.ts'\n"],"mappings":";;;;;;AAEA,eAAsB,MAAM,MAA6B;AACvD,QAAOA,iBAAG,OAAO;AAClB;;;;ACDD,MAAMC,oCACJ;CACE,MAAM,OAAO,SAAiB;AAC5B,SAAOC,iBAAG,SAAS,MAAM,EAAE,UAAU,QAAQ;CAC9C;CACD,KAAK,OAAO,SAAiB;EAC3B,MAAM,OAAO,IAAI,KAAK;AAEtB,SAAO,KAAK;CACb;CACF,EACD;AAGF,MAAMC,wCACJ;CACE,OAAO,SAAiB;AACtB,SAAOD,iBAAG,aAAa,MAAM,EAAE,UAAU,QAAQ;CAClD;CACD,WAAW;AACT,QAAM,IAAI,MAAM;CACjB;CACF,EACD;AAGF,eAAsB,KAAK,MAA+B;AACxD,QAAOD,SAAO;AACf;AAED,SAAgB,SAAS,MAAsB;AAC7C,QAAOE,aAAW;AACnB;;;;AChCD,MAAM,kCACJ;CACE,MAAM,OAAO,SAAiB;AAC5B,SAAOC,iBAAG,WAAW;CACtB;CACD,KAAK,OAAO,SAAiB;EAC3B,MAAM,OAAO,IAAI,KAAK;AAEtB,SAAO,KAAK;CACb;CACF,EACD;AAGF,MAAM,sCACJ;CACE,OAAO,SAAiB;AACtB,SAAOA,iBAAG,eAAe;CAC1B;CACD,WAAW;AACT,QAAM,IAAI,MAAM;CACjB;CACF,EACD;AAGF,eAAsB,OAAO,MAAgC;AAC3D,QAAO,OAAO;AACf;;;;AC7BD,SAAS,MAAM,MAAc,WAAwC,SAAS;CAC5E,MAAM,gBAAgB,YAAY,KAAK;CACvC,MAAM,0CAA2B;AAEjC,KAAI,CAAC,SAAS,MAAM,CAAC,SAAS,aAAa,CAAC,cAE1C,QAAO,eAAe,WAAW,OAAO,KAAK,QAAQ,OAAO;AAI9D,QAAO,eAAe,WAAW,OAAO,KAAK,QAAQ,OAAO;AAC7D;AAED,SAAgB,gBAAgB,SAAyB,UAA0B,WAAwC,SAAiB;AAC1I,KAAI,CAAC,WAAW,CAAC,SACf,OAAM,IAAI,MAAM,uEAAuE,WAAW,GAAG,GAAG,YAAY;CAGtH,MAAM,uCAAwB,SAAS;CAIvC,MAAM,cAAc,MAAM,cAAc;AAExC,KAAI,YAAY,WAAW,OACzB,QAAO;AAGT,QAAO,KAAK;AACb;;;;;;;;AEzBD,SAAgB,YAAY,MAAsB;AAChD,QAAO,KAAK,QAAQ,aAAa;AAClC"}
|