@kubb/core 3.0.0-alpha.7 → 3.0.0-alpha.9

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.
@@ -270,7 +270,7 @@ var URLPath = class {
270
270
 
271
271
  // src/utils/parser.ts
272
272
  import { extname as extname2 } from "node:path";
273
- import { getRelativePath as getRelativePath3 } from "@kubb/fs";
273
+ import { getRelativePath as getRelativePath2 } from "@kubb/fs";
274
274
  import hash from "object-hash";
275
275
 
276
276
  // src/FileManager.ts
@@ -465,7 +465,8 @@ var BarrelManager = class {
465
465
  }
466
466
  getFiles(generatedFiles, root) {
467
467
  const { logger } = this.#options;
468
- const files = TreeNode.build(generatedFiles, root)?.map((treeNode) => {
468
+ const files = /* @__PURE__ */ new Map();
469
+ TreeNode.build(generatedFiles, root)?.forEach((treeNode) => {
469
470
  if (!treeNode || !treeNode.children || !treeNode.parent?.data.path) {
470
471
  return void 0;
471
472
  }
@@ -476,15 +477,15 @@ var BarrelManager = class {
476
477
  return void 0;
477
478
  }
478
479
  const sources = item.data.file?.sources || [];
479
- if (!sources.some((source) => source.isExportable)) {
480
+ if (!sources.some((source) => source.isIndexable)) {
480
481
  logger?.emit(
481
482
  "warning",
482
- `No exportable source found(source should have a name and isExportable):
483
+ `No isIndexable source found(source should have a name and isIndexable):
483
484
  File: ${JSON.stringify(item.data.file, void 0, 2)}`
484
485
  );
485
486
  }
486
487
  return sources.map((source) => {
487
- if (!item.data.file?.path || !source.isExportable) {
488
+ if (!item.data.file?.path || !source.isIndexable) {
488
489
  return void 0;
489
490
  }
490
491
  const isSubExport = !!treeNode.parent?.data.path?.split?.("/")?.length;
@@ -502,12 +503,11 @@ File: ${JSON.stringify(item.data.file, void 0, 2)}`
502
503
  };
503
504
  });
504
505
  }).flat().filter(Boolean);
505
- const combinedExports = combineExports(exports);
506
506
  const barrelFile = {
507
507
  path: barrelPath,
508
508
  baseName: "index.ts",
509
- exports: combinedExports,
510
- sources: combinedExports.flatMap((item) => {
509
+ exports,
510
+ sources: exports.flatMap((item) => {
511
511
  if (Array.isArray(item.name)) {
512
512
  return item.name.map((name) => {
513
513
  return {
@@ -515,7 +515,8 @@ File: ${JSON.stringify(item.data.file, void 0, 2)}`
515
515
  isTypeOnly: item.isTypeOnly,
516
516
  //TODO use parser to generate import
517
517
  value: "",
518
- isExportable: false
518
+ isExportable: false,
519
+ isIndexable: false
519
520
  };
520
521
  });
521
522
  }
@@ -525,14 +526,25 @@ File: ${JSON.stringify(item.data.file, void 0, 2)}`
525
526
  isTypeOnly: item.isTypeOnly,
526
527
  //TODO use parser to generate import
527
528
  value: "",
528
- isExportable: false
529
+ isExportable: false,
530
+ isIndexable: false
529
531
  }
530
532
  ];
531
533
  })
532
534
  };
533
- return barrelFile;
534
- }).filter(Boolean);
535
- return files || [];
535
+ const previousBarrelFile = files.get(barrelFile.path);
536
+ if (previousBarrelFile) {
537
+ files.set(barrelFile.path, {
538
+ ...previousBarrelFile,
539
+ ...barrelFile,
540
+ exports: combineExports([...previousBarrelFile.exports || [], ...barrelFile.exports || []]),
541
+ sources: combineSources([...previousBarrelFile.sources || [], ...barrelFile.sources || []])
542
+ });
543
+ } else {
544
+ files.set(barrelFile.path, barrelFile);
545
+ }
546
+ });
547
+ return [...files.values()];
536
548
  }
537
549
  };
538
550
 
@@ -685,6 +697,7 @@ function combineSources(sources) {
685
697
  prevByName.value = curr.value;
686
698
  prevByName.isExportable = curr.isExportable;
687
699
  prevByName.isTypeOnly = curr.isTypeOnly;
700
+ prevByName.isIndexable = curr.isIndexable;
688
701
  return prev;
689
702
  }
690
703
  return [...prev, curr];
@@ -861,7 +874,7 @@ var typeScriptParser = createFileParser({
861
874
  async print(file) {
862
875
  const module = await import("@kubb/parser-ts");
863
876
  const importNodes = file.imports.map((item) => {
864
- const path = item.root ? getRelativePath3(item.root, item.path) : item.path;
877
+ const path = item.root ? getRelativePath2(item.root, item.path) : item.path;
865
878
  return module.factory.createImportDeclaration({
866
879
  name: item.name,
867
880
  path,
@@ -929,4 +942,4 @@ export {
929
942
  getSource,
930
943
  processFiles
931
944
  };
932
- //# sourceMappingURL=chunk-BHZAXMKP.js.map
945
+ //# sourceMappingURL=chunk-27CPVXAT.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../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/FileManager.ts","../src/BarrelManager.ts","../src/utils/TreeNode.ts"],"sourcesContent":["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) => this.#items.push(it))\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 '@kubb/types'\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 } from '../transformers/casing.ts'\n\nexport type URLObject = {\n url: string\n params?: Record<string, string>\n}\n\ntype ObjectOptions = {\n type?: 'path' | 'template'\n replacer?: (pathParam: string) => string\n stringify?: boolean\n}\n\nexport class URLPath {\n path: string\n\n constructor(path: string) {\n this.path = path\n\n return this\n }\n\n /**\n * Convert Swagger path to URLPath(syntax of Express)\n * @example /pet/{petId} => /pet/:petId\n */\n get URL(): string {\n return this.toURLPath()\n }\n get isURL(): boolean {\n try {\n const url = new URL(this.path)\n if (url?.href) {\n return true\n }\n } catch (error) {\n return false\n }\n return false\n }\n\n /**\n * Convert Swagger path to template literals/ template strings(camelcase)\n * @example /pet/{petId} => `/pet/${petId}`\n * @example /account/monetary-accountID => `/account/${monetaryAccountId}`\n * @example /account/userID => `/account/${userId}`\n */\n get template(): string {\n return this.toTemplateString()\n }\n get object(): URLObject | string {\n return this.toObject()\n }\n get params(): Record<string, string> | undefined {\n return this.getParams()\n }\n\n toObject({ type = 'path', replacer, stringify }: ObjectOptions = {}): URLObject | string {\n const object = {\n url: type === 'path' ? this.toURLPath() : this.toTemplateString(replacer),\n params: this.getParams(),\n }\n\n if (stringify) {\n if (type === 'template') {\n return JSON.stringify(object).replaceAll(\"'\", '').replaceAll(`\"`, '')\n }\n\n if (object.params) {\n return `{ url: '${object.url}', params: ${JSON.stringify(object.params).replaceAll(\"'\", '').replaceAll(`\"`, '')} }`\n }\n\n return `{ url: '${object.url}' }`\n }\n\n return object\n }\n\n /**\n * Convert Swagger path to template literals/ template strings(camelcase)\n * @example /pet/{petId} => `/pet/${petId}`\n * @example /account/monetary-accountID => `/account/${monetaryAccountId}`\n * @example /account/userID => `/account/${userId}`\n */\n toTemplateString(replacer?: (pathParam: string) => string): string {\n const regex = /{(\\w|-)*}/g\n const found = this.path.match(regex)\n let newPath = this.path.replaceAll('{', '${')\n\n if (found) {\n newPath = found.reduce((prev, curr) => {\n const pathParam = replacer ? replacer(camelCase(curr)) : camelCase(curr)\n const replacement = `\\${${pathParam}}`\n\n return prev.replace(curr, replacement)\n }, this.path)\n }\n\n return `\\`${newPath}\\``\n }\n\n getParams(replacer?: (pathParam: string) => string): Record<string, string> | undefined {\n const regex = /{(\\w|-)*}/g\n const found = this.path.match(regex)\n\n if (!found) {\n return undefined\n }\n\n const params: Record<string, string> = {}\n found.forEach((item) => {\n item = item.replaceAll('{', '').replaceAll('}', '')\n\n const pathParam = replacer ? replacer(camelCase(item)) : camelCase(item)\n\n params[pathParam] = pathParam\n }, this.path)\n\n return params\n }\n\n /**\n * Convert Swagger path to URLPath(syntax of Express)\n * @example /pet/{petId} => /pet/:petId\n */\n toURLPath(): string {\n return this.path.replaceAll('{', ':').replaceAll('}', '')\n }\n}\n","import { extname } from 'node:path'\nimport type * as KubbFile from '@kubb/fs/types'\n\nimport { getRelativePath } from '@kubb/fs'\nimport hash from 'object-hash'\nimport { combineExports, combineImports, combineSources } from '../FileManager.ts'\nimport type { Logger } from '../logger.ts'\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 = extname(file.baseName) as KubbFile.Extname\n\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 ? combineExports(file.exports) : []\n const imports = file.imports && source ? combineImports(file.imports, exports, source) : []\n const sources = file.sources ? 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((item) => createFileImport(item)),\n exports: exports.map((item) => createFileExport(item)),\n sources: sources.map((item) => createFileSource(item)),\n }\n}\n\n/**\n * Helper to create a fileImport with extName set\n */\nexport function 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 const extName = extname(imp.path) as KubbFile.Extname\n\n return {\n ...imp,\n extName: imp.extName ? imp.extName : extName,\n }\n}\n\n/**\n * Helper to create a fileExport with extName set\n */\nexport function createFileExport(exp: KubbFile.Export): KubbFile.ResolvedExport {\n const extName = extname(exp.path) as KubbFile.Extname\n\n return {\n ...exp,\n extName: exp.extName ? exp.extName : extName,\n }\n}\n\nexport type ParserModule<TMeta extends object = object> = {\n /**\n * By default @kubb/react is used\n */\n render: (item: any) => any\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 logger?: Logger\n}\n\nconst typeScriptParser = createFileParser({\n render() {\n return undefined\n },\n async print(file) {\n const module = await import('@kubb/parser-ts')\n\n const importNodes = file.imports\n .map((item) => {\n const path = item.root ? getRelativePath(item.root, item.path) : item.path\n\n return module.factory.createImportDeclaration({\n name: item.name,\n path,\n isTypeOnly: item.isTypeOnly,\n })\n })\n .filter(Boolean)\n\n const exportNodes = file.exports\n .map((item) => {\n return module.factory.createExportDeclaration({\n name: item.name,\n path: item.path,\n isTypeOnly: item.isTypeOnly,\n asAlias: item.asAlias,\n })\n })\n .filter(Boolean)\n\n const source = [module.print([...importNodes, ...exportNodes]), file.sources.map((item) => item.value).join('\\n\\n')].join('\\n')\n\n // do some basic linting with the ts compiler\n return module.print([], { source, noEmitHelpers: false })\n },\n})\n\nconst defaultParser = createFileParser({\n render() {\n return undefined\n },\n async print(file, { logger }) {\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': typeScriptParser,\n '.tsx': typeScriptParser,\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\nexport function trimExtName(text: string): string {\n const extName = text.split('.').pop()\n\n return text.replace(`.${extName}`, '')\n}\n","import { extname, join, relative } from 'node:path'\n\nimport { orderBy } from 'natural-orderby'\nimport { isDeepEqual } from 'remeda'\n\nimport { read, write } from '@kubb/fs'\nimport { BarrelManager } from './BarrelManager.ts'\n\nimport type * as KubbFile from '@kubb/fs/types'\n\nimport { trimExtName } from '@kubb/fs'\nimport type { ResolvedFile } from '@kubb/fs/types'\nimport type { GreaterThan } from '@kubb/types'\nimport PQueue from 'p-queue'\nimport type { Logger } from './logger.ts'\nimport type { Config, Plugin } from './types.ts'\nimport { createFile, getFileParser } from './utils'\nimport { type DirectoryTree, TreeNode, buildDirectoryTree } from './utils/TreeNode.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 /**\n * Root based on root and output.path specified in the config\n */\n root: string\n files: KubbFile.File[]\n /**\n * Output for plugin\n */\n output: {\n path: string\n extName?: KubbFile.Extname\n exportAs?: string\n exportType?: 'barrel' | 'barrelNamed' | false\n }\n group?: {\n output: string\n exportAs: string\n }\n logger?: Logger\n\n meta?: FileMetaBase\n}\n\nexport class FileManager {\n #filesByPath: Map<KubbFile.Path, KubbFile.ResolvedFile> = new Map()\n #files: Set<KubbFile.ResolvedFile> = new Set()\n constructor() {\n return this\n }\n\n get files(): Array<KubbFile.ResolvedFile> {\n return Array.from(this.#files)\n }\n\n get orderedFiles(): Array<KubbFile.ResolvedFile> {\n return orderBy(Array.from(this.#files), [\n (v) => v?.meta && 'pluginKey' in v.meta && !v.meta.pluginKey,\n (v) => v.path.length,\n (v) => trimExtName(v.path).endsWith('index'),\n (v) => trimExtName(v.baseName),\n (v) => v.path.split('.').pop(),\n ])\n }\n\n get groupedFiles(): DirectoryTree | null {\n return buildDirectoryTree(Array.from(this.#files))\n }\n\n get treeNode(): TreeNode | null {\n return TreeNode.build(Array.from(this.#files))\n }\n\n async add<T extends Array<KubbFile.File> = Array<KubbFile.File>>(...files: T): AddResult<T> {\n const promises = files.map((file) => {\n if (file.override) {\n return this.#add(file)\n }\n\n return this.#addOrAppend(file)\n })\n\n const resolvedFiles = await Promise.all(promises)\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 #add(file: KubbFile.File): Promise<ResolvedFile> {\n const resolvedFile = createFile(file)\n\n this.#filesByPath.set(resolvedFile.path, resolvedFile)\n this.#files.add(resolvedFile)\n\n return resolvedFile\n }\n\n clear() {\n this.#filesByPath.clear()\n this.#files.clear()\n }\n\n async #addOrAppend(file: KubbFile.File): Promise<ResolvedFile> {\n const previousFile = this.#filesByPath.get(file.path)\n\n if (previousFile) {\n this.#filesByPath.delete(previousFile.path)\n this.#files.delete(previousFile)\n\n return this.#add(mergeFile(previousFile, file))\n }\n return this.#add(file)\n }\n\n getCacheById(id: string): KubbFile.File | undefined {\n let cache: KubbFile.File | undefined\n\n this.#files.forEach((file) => {\n if (file.id === id) {\n cache = file\n }\n })\n return cache\n }\n\n getByPath(path: KubbFile.Path): KubbFile.ResolvedFile | undefined {\n return this.#filesByPath.get(path)\n }\n\n deleteByPath(path: KubbFile.Path): void {\n const cacheItem = this.getByPath(path)\n if (!cacheItem) {\n return\n }\n\n this.#filesByPath.delete(path)\n this.#files.delete(cacheItem)\n }\n\n async getBarrelFiles({ files, meta, root, output, logger }: AddIndexesProps): Promise<KubbFile.File[]> {\n const { exportType = 'barrelNamed' } = output\n const barrelManager = new BarrelManager({ logger })\n\n if (exportType === false) {\n return []\n }\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, pathToBuildFrom)\n\n if (exportType === 'barrel') {\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 async write(...params: Parameters<typeof write>): ReturnType<typeof write> {\n return write(...params)\n }\n\n async read(...params: Parameters<typeof read>): ReturnType<typeof read> {\n return read(...params)\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 logger?: Logger\n}\n\nexport async function getSource<TMeta extends FileMetaBase = FileMetaBase>(file: ResolvedFile<TMeta>, { logger }: GetSourceOptions = {}): Promise<string> {\n const parser = await getFileParser(file.extName)\n\n return parser.print(file, { logger })\n}\n\nexport function 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 sources.reduce(\n (prev, curr) => {\n const prevByName = prev.findLast((imp) => imp.name === curr.name)\n const prevByPathAndIsExportable = prev.findLast((imp) => imp.name === curr.name && imp.isExportable)\n\n if (prevByPathAndIsExportable) {\n // we already have an export that has the same name but uses `isExportable` (export type ...)\n return [...prev, curr]\n }\n\n if (prevByName) {\n prevByName.value = curr.value\n prevByName.isExportable = curr.isExportable\n prevByName.isTypeOnly = curr.isTypeOnly\n prevByName.isIndexable = curr.isIndexable\n\n return prev\n }\n\n return [...prev, curr]\n },\n [] as Array<KubbFile.Source>,\n )\n}\n\nexport function combineExports(exports: Array<KubbFile.Export>): Array<KubbFile.Export> {\n const combinedExports = exports.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 return orderBy(combinedExports, [\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 ])\n}\n\nexport function combineImports(imports: Array<KubbFile.Import>, exports: Array<KubbFile.Export>, source?: string): Array<KubbFile.Import> {\n const combinedImports = imports.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) => name && !!source.includes(name)\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 return orderBy(combinedImports, [\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 ])\n}\ntype WriteFilesProps = {\n config: Config\n files: Array<KubbFile.ResolvedFile>\n logger: Logger\n dryRun?: boolean\n}\n/**\n * Global queue\n */\nconst queue = new PQueue({ concurrency: 100 })\n\nexport async function processFiles({ dryRun, config, logger, files }: WriteFilesProps) {\n const orderedFiles = orderBy(files, [\n (v) => v?.meta && 'pluginKey' in v.meta && !v.meta.pluginKey,\n (v) => v.path.length,\n (v) => trimExtName(v.path).endsWith('index'),\n ])\n\n logger.emit('debug', {\n logs: [JSON.stringify({ files: orderedFiles }, null, 2)],\n fileName: 'kubb-files.json',\n override: true,\n })\n\n if (!dryRun) {\n const size = orderedFiles.length\n\n logger.emit('progress_start', { id: 'files', size })\n const promises = orderedFiles.map(async (file) => {\n await queue.add(async () => {\n const source = await getSource(file, { logger })\n\n await write(file.path, source, { sanity: false })\n\n logger.emit('progress', { id: 'files', data: file ? relative(config.root, file.path) : '' })\n })\n })\n\n await Promise.all(promises)\n\n logger.emit('progress_stop', { id: 'files' })\n }\n\n return files\n}\n","import { join } from 'node:path'\n\nimport { TreeNode } from './utils/TreeNode.ts'\n\nimport { getRelativePath } from '@kubb/fs'\nimport type * as KubbFile from '@kubb/fs/types'\nimport { combineExports, combineSources } from './FileManager.ts'\nimport type { Logger } from './logger.ts'\n\nexport type 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(generatedFiles: KubbFile.File[], root?: string): Array<KubbFile.File> {\n const { logger } = this.#options\n\n const files = 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 barrelPath: KubbFile.Path = join(treeNode.parent?.data.path, 'index.ts')\n\n const leaves = treeNode.leaves\n\n // biome-ignore lint/complexity/useFlatMap: we have a custom map in TreeNode\n const exports = leaves\n .map((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 return sources.map((source) => {\n if (!item.data.file?.path || !source.isIndexable) {\n return undefined\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 return {\n name: [source.name],\n path: getRelativePath(treeNode.parent?.data.path, item.data.path),\n isTypeOnly: source.isTypeOnly,\n } as KubbFile.Export\n }\n\n return {\n name: [source.name],\n path: `./${item.data.file.baseName}`,\n isTypeOnly: source.isTypeOnly,\n } as KubbFile.Export\n })\n })\n .flat()\n .filter(Boolean)\n\n const barrelFile: KubbFile.File = {\n path: barrelPath,\n baseName: 'index.ts',\n exports: exports,\n sources: exports.flatMap((item) => {\n if (Array.isArray(item.name)) {\n return item.name.map((name) => {\n return {\n name: name,\n isTypeOnly: item.isTypeOnly,\n //TODO use parser to generate import\n value: '',\n isExportable: false,\n isIndexable: false,\n } as KubbFile.Source\n })\n }\n return [\n {\n name: item.name,\n isTypeOnly: item.isTypeOnly,\n //TODO use parser to generate import\n value: '',\n isExportable: false,\n isIndexable: false,\n } as KubbFile.Source,\n ]\n }),\n }\n\n const previousBarrelFile = files.get(barrelFile.path)\n\n if (previousBarrelFile) {\n files.set(barrelFile.path, {\n ...previousBarrelFile,\n ...barrelFile,\n exports: combineExports([...(previousBarrelFile.exports || []), ...(barrelFile.exports || [])]),\n sources: combineSources([...(previousBarrelFile.sources || []), ...(barrelFile.sources || [])]),\n })\n } else {\n files.set(barrelFile.path, barrelFile)\n }\n })\n\n return [...files.values()]\n }\n}\n","import type * as KubbFile from '@kubb/fs/types'\nimport { FileManager } from '../FileManager.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 public data: BarrelData\n\n public parent?: TreeNode\n\n public children: Array<TreeNode> = []\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 find(data?: BarrelData): TreeNode | null {\n if (!data) {\n return null\n }\n\n if (data === this.data) {\n return this\n }\n\n if (this.children?.length) {\n for (let i = 0, { length } = this.children, target: TreeNode | null = null; i < length; i++) {\n target = this.children[i]!.find(data)\n if (target) {\n return target\n }\n }\n }\n\n return null\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 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 return leaves\n }\n\n get root(): TreeNode {\n if (!this.parent) {\n return this\n }\n return this.parent.root\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 filter(callback: (treeNode: TreeNode) => boolean): Array<TreeNode> {\n let data: Array<TreeNode> = []\n if (typeof callback !== 'function') {\n throw new TypeError('forEach() callback must be a function')\n }\n\n // run this node through function\n if (callback(this)) {\n data.push(this)\n }\n\n // do the same for all children\n if (this.children) {\n for (let i = 0, { length } = this.children; i < length; i++) {\n const childData = this.children[i]?.filter(callback).filter(Boolean) || []\n data = [...new Set([...data, ...childData])]\n }\n }\n\n return data\n }\n\n map<T>(callback: (treeNode: TreeNode) => T): Array<T> {\n let data: Array<T> = []\n if (typeof callback !== 'function') {\n throw new TypeError('forEach() callback must be a function')\n }\n\n // run this node through function\n data.push(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 const childData = this.children[i]?.map(callback).filter(Boolean) || []\n data = [...new Set([...data, ...childData])]\n }\n }\n\n return data\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) => recurse(treeNode, child))\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\nexport function buildDirectoryTree(files: Array<KubbFile.File>, rootFolder = ''): DirectoryTree | null {\n const rootPrefix = rootFolder.endsWith('/') ? rootFolder : `${rootFolder}/`\n const filteredFiles = files.filter((file) => (rootFolder ? file.path.startsWith(rootPrefix) && !file.path.endsWith('.json') : !file.path.endsWith('.json')))\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"],"mappings":"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","names":["item","extname","getRelativePath","join","join","name","extname","trimExtName","getRelativePath"]}
@@ -646,7 +646,8 @@ var BarrelManager = class {
646
646
  }
647
647
  getFiles(generatedFiles, root) {
648
648
  const { logger } = this.#options;
649
- const files = _optionalChain([TreeNode, 'access', _41 => _41.build, 'call', _42 => _42(generatedFiles, root), 'optionalAccess', _43 => _43.map, 'call', _44 => _44((treeNode) => {
649
+ const files = /* @__PURE__ */ new Map();
650
+ _optionalChain([TreeNode, 'access', _41 => _41.build, 'call', _42 => _42(generatedFiles, root), 'optionalAccess', _43 => _43.forEach, 'call', _44 => _44((treeNode) => {
650
651
  if (!treeNode || !treeNode.children || !_optionalChain([treeNode, 'access', _45 => _45.parent, 'optionalAccess', _46 => _46.data, 'access', _47 => _47.path])) {
651
652
  return void 0;
652
653
  }
@@ -657,15 +658,15 @@ var BarrelManager = class {
657
658
  return void 0;
658
659
  }
659
660
  const sources = _optionalChain([item, 'access', _51 => _51.data, 'access', _52 => _52.file, 'optionalAccess', _53 => _53.sources]) || [];
660
- if (!sources.some((source) => source.isExportable)) {
661
+ if (!sources.some((source) => source.isIndexable)) {
661
662
  _optionalChain([logger, 'optionalAccess', _54 => _54.emit, 'call', _55 => _55(
662
663
  "warning",
663
- `No exportable source found(source should have a name and isExportable):
664
+ `No isIndexable source found(source should have a name and isIndexable):
664
665
  File: ${JSON.stringify(item.data.file, void 0, 2)}`
665
666
  )]);
666
667
  }
667
668
  return sources.map((source) => {
668
- if (!_optionalChain([item, 'access', _56 => _56.data, 'access', _57 => _57.file, 'optionalAccess', _58 => _58.path]) || !source.isExportable) {
669
+ if (!_optionalChain([item, 'access', _56 => _56.data, 'access', _57 => _57.file, 'optionalAccess', _58 => _58.path]) || !source.isIndexable) {
669
670
  return void 0;
670
671
  }
671
672
  const isSubExport = !!_optionalChain([treeNode, 'access', _59 => _59.parent, 'optionalAccess', _60 => _60.data, 'access', _61 => _61.path, 'optionalAccess', _62 => _62.split, 'optionalCall', _63 => _63("/"), 'optionalAccess', _64 => _64.length]);
@@ -683,12 +684,11 @@ File: ${JSON.stringify(item.data.file, void 0, 2)}`
683
684
  };
684
685
  });
685
686
  }).flat().filter(Boolean);
686
- const combinedExports = combineExports(exports);
687
687
  const barrelFile = {
688
688
  path: barrelPath,
689
689
  baseName: "index.ts",
690
- exports: combinedExports,
691
- sources: combinedExports.flatMap((item) => {
690
+ exports,
691
+ sources: exports.flatMap((item) => {
692
692
  if (Array.isArray(item.name)) {
693
693
  return item.name.map((name) => {
694
694
  return {
@@ -696,7 +696,8 @@ File: ${JSON.stringify(item.data.file, void 0, 2)}`
696
696
  isTypeOnly: item.isTypeOnly,
697
697
  //TODO use parser to generate import
698
698
  value: "",
699
- isExportable: false
699
+ isExportable: false,
700
+ isIndexable: false
700
701
  };
701
702
  });
702
703
  }
@@ -706,14 +707,25 @@ File: ${JSON.stringify(item.data.file, void 0, 2)}`
706
707
  isTypeOnly: item.isTypeOnly,
707
708
  //TODO use parser to generate import
708
709
  value: "",
709
- isExportable: false
710
+ isExportable: false,
711
+ isIndexable: false
710
712
  }
711
713
  ];
712
714
  })
713
715
  };
714
- return barrelFile;
715
- }), 'access', _68 => _68.filter, 'call', _69 => _69(Boolean)]);
716
- return files || [];
716
+ const previousBarrelFile = files.get(barrelFile.path);
717
+ if (previousBarrelFile) {
718
+ files.set(barrelFile.path, {
719
+ ...previousBarrelFile,
720
+ ...barrelFile,
721
+ exports: combineExports([...previousBarrelFile.exports || [], ...barrelFile.exports || []]),
722
+ sources: combineSources([...previousBarrelFile.sources || [], ...barrelFile.sources || []])
723
+ });
724
+ } else {
725
+ files.set(barrelFile.path, barrelFile);
726
+ }
727
+ })]);
728
+ return [...files.values()];
717
729
  }
718
730
  };
719
731
 
@@ -854,7 +866,7 @@ var PriorityQueue = class {
854
866
  }
855
867
  dequeue() {
856
868
  const item = this.#queue.shift();
857
- return _optionalChain([item, 'optionalAccess', _70 => _70.run]);
869
+ return _optionalChain([item, 'optionalAccess', _68 => _68.run]);
858
870
  }
859
871
  filter(options) {
860
872
  return this.#queue.filter((element) => element.priority === options.priority).map((element) => element.run);
@@ -900,10 +912,10 @@ var PQueue = class extends import_index.default {
900
912
  ...options
901
913
  };
902
914
  if (!(typeof options.intervalCap === "number" && options.intervalCap >= 1)) {
903
- throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${_nullishCoalesce(_optionalChain([options, 'access', _71 => _71.intervalCap, 'optionalAccess', _72 => _72.toString, 'call', _73 => _73()]), () => ( ""))}\` (${typeof options.intervalCap})`);
915
+ throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${_nullishCoalesce(_optionalChain([options, 'access', _69 => _69.intervalCap, 'optionalAccess', _70 => _70.toString, 'call', _71 => _71()]), () => ( ""))}\` (${typeof options.intervalCap})`);
904
916
  }
905
917
  if (options.interval === void 0 || !(Number.isFinite(options.interval) && options.interval >= 0)) {
906
- throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${_nullishCoalesce(_optionalChain([options, 'access', _74 => _74.interval, 'optionalAccess', _75 => _75.toString, 'call', _76 => _76()]), () => ( ""))}\` (${typeof options.interval})`);
918
+ throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${_nullishCoalesce(_optionalChain([options, 'access', _72 => _72.interval, 'optionalAccess', _73 => _73.toString, 'call', _74 => _74()]), () => ( ""))}\` (${typeof options.interval})`);
907
919
  }
908
920
  this.#carryoverConcurrencyCount = options.carryoverConcurrencyCount;
909
921
  this.#isIntervalIgnored = options.intervalCap === Number.POSITIVE_INFINITY || options.interval === 0;
@@ -1030,7 +1042,7 @@ var PQueue = class extends import_index.default {
1030
1042
  this.#pending++;
1031
1043
  this.#intervalCount++;
1032
1044
  try {
1033
- _optionalChain([options, 'access', _77 => _77.signal, 'optionalAccess', _78 => _78.throwIfAborted, 'call', _79 => _79()]);
1045
+ _optionalChain([options, 'access', _75 => _75.signal, 'optionalAccess', _76 => _76.throwIfAborted, 'call', _77 => _77()]);
1034
1046
  let operation = function_({ signal: options.signal });
1035
1047
  if (options.timeout) {
1036
1048
  operation = pTimeout(Promise.resolve(operation), { milliseconds: options.timeout });
@@ -1169,7 +1181,7 @@ var FileManager = class {
1169
1181
  }
1170
1182
  get orderedFiles() {
1171
1183
  return _chunkA6PCLWEYcjs.orderBy.call(void 0, Array.from(this.#files), [
1172
- (v) => _optionalChain([v, 'optionalAccess', _80 => _80.meta]) && "pluginKey" in v.meta && !v.meta.pluginKey,
1184
+ (v) => _optionalChain([v, 'optionalAccess', _78 => _78.meta]) && "pluginKey" in v.meta && !v.meta.pluginKey,
1173
1185
  (v) => v.path.length,
1174
1186
  (v) => _fs.trimExtName.call(void 0, v.path).endsWith("index"),
1175
1187
  (v) => _fs.trimExtName.call(void 0, v.baseName),
@@ -1242,7 +1254,7 @@ var FileManager = class {
1242
1254
  }
1243
1255
  const pathToBuildFrom = _path.join.call(void 0, root, output.path);
1244
1256
  if (_fs.trimExtName.call(void 0, pathToBuildFrom).endsWith("index")) {
1245
- _optionalChain([logger, 'optionalAccess', _81 => _81.emit, 'call', _82 => _82("warning", "Output has the same fileName as the barrelFiles, please disable barrel generation")]);
1257
+ _optionalChain([logger, 'optionalAccess', _79 => _79.emit, 'call', _80 => _80("warning", "Output has the same fileName as the barrelFiles, please disable barrel generation")]);
1246
1258
  return [];
1247
1259
  }
1248
1260
  const barrelFiles = barrelManager.getFiles(files, pathToBuildFrom);
@@ -1250,7 +1262,7 @@ var FileManager = class {
1250
1262
  return barrelFiles.map((file) => {
1251
1263
  return {
1252
1264
  ...file,
1253
- exports: _optionalChain([file, 'access', _83 => _83.exports, 'optionalAccess', _84 => _84.map, 'call', _85 => _85((exportItem) => {
1265
+ exports: _optionalChain([file, 'access', _81 => _81.exports, 'optionalAccess', _82 => _82.map, 'call', _83 => _83((exportItem) => {
1254
1266
  return {
1255
1267
  ...exportItem,
1256
1268
  name: void 0
@@ -1304,6 +1316,7 @@ function combineSources(sources) {
1304
1316
  prevByName.value = curr.value;
1305
1317
  prevByName.isExportable = curr.isExportable;
1306
1318
  prevByName.isTypeOnly = curr.isTypeOnly;
1319
+ prevByName.isIndexable = curr.isIndexable;
1307
1320
  return prev;
1308
1321
  }
1309
1322
  return [...prev, curr];
@@ -1323,7 +1336,7 @@ function combineExports(exports) {
1323
1336
  const uniquePrev = prev.findLast(
1324
1337
  (imp) => imp.path === curr.path && _remeda.isDeepEqual.call(void 0, imp.name, name) && imp.isTypeOnly === curr.isTypeOnly && imp.asAlias === curr.asAlias
1325
1338
  );
1326
- if (uniquePrev || Array.isArray(name) && !name.length || _optionalChain([prevByPath, 'optionalAccess', _86 => _86.asAlias]) && !curr.asAlias) {
1339
+ if (uniquePrev || Array.isArray(name) && !name.length || _optionalChain([prevByPath, 'optionalAccess', _84 => _84.asAlias]) && !curr.asAlias) {
1327
1340
  return prev;
1328
1341
  }
1329
1342
  if (!prevByPath) {
@@ -1408,7 +1421,7 @@ function combineImports(imports, exports, source) {
1408
1421
  var queue = new PQueue({ concurrency: 100 });
1409
1422
  async function processFiles({ dryRun, config, logger, files }) {
1410
1423
  const orderedFiles = _chunkA6PCLWEYcjs.orderBy.call(void 0, files, [
1411
- (v) => _optionalChain([v, 'optionalAccess', _87 => _87.meta]) && "pluginKey" in v.meta && !v.meta.pluginKey,
1424
+ (v) => _optionalChain([v, 'optionalAccess', _85 => _85.meta]) && "pluginKey" in v.meta && !v.meta.pluginKey,
1412
1425
  (v) => v.path.length,
1413
1426
  (v) => _fs.trimExtName.call(void 0, v.path).endsWith("index")
1414
1427
  ]);
@@ -1548,4 +1561,4 @@ function trimExtName2(text) {
1548
1561
 
1549
1562
 
1550
1563
  exports.FunctionParams = FunctionParams; exports.isPromise = isPromise; exports.isPromiseFulfilledResult = isPromiseFulfilledResult; exports.isPromiseRejectedResult = isPromiseRejectedResult; exports.renderTemplate = renderTemplate; exports.timeout = timeout; exports.getUniqueName = getUniqueName; exports.setUniqueName = setUniqueName; exports.URLPath = URLPath; exports.createFile = createFile; exports.createFileImport = createFileImport; exports.createFileExport = createFileExport; exports.createFileParser = createFileParser; exports.getFileParser = getFileParser; exports.FileManager = FileManager; exports.getSource = getSource; exports.processFiles = processFiles;
1551
- //# sourceMappingURL=chunk-4SIOKKDJ.cjs.map
1564
+ //# sourceMappingURL=chunk-5IGANEGE.cjs.map