@hey-api/codegen-core 0.2.0 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -1,2 +1,2 @@
1
- 'use strict';var h=require('path');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var h__default=/*#__PURE__*/_interopDefault(h);var I=({file:l,modulePath:e,symbol:t,symbolFile:r})=>{let i=[],s=[],n={aliases:{},from:e};if(t.meta?.importKind&&(t.meta.importKind==="default"?(n.defaultBinding=t.placeholder,t.meta.kind==="type"&&(n.typeDefaultBinding=true)):t.meta.importKind==="namespace"&&(n.namespaceBinding=t.placeholder,t.meta.kind==="type"&&(n.typeNamespaceBinding=true))),t.meta?.importKind==="named"||!i.length&&!n.defaultBinding&&!n.namespaceBinding){let o=t.placeholder,d=l.resolvedNames.get(t.id);if(d){let m=r.resolvedNames.get(t.id);m?m!==d&&(o=m,n.aliases[o]=d):t.name&&d!==t.name&&(o=t.name,n.aliases[o]=t.placeholder);}i.push(o),t.meta?.kind==="type"&&s.push(o);}for(let o of s)i.includes(o)||i.push(o);return n.names=i,n.typeNames=s,n},g=(l,e)=>{l.aliases={...l.aliases,...e.aliases},e.defaultBinding!==void 0&&(l.defaultBinding=e.defaultBinding),l.names=[...new Set([...l.names??[],...e.names??[]])],e.namespaceBinding!==void 0&&(l.namespaceBinding=e.namespaceBinding),e.typeDefaultBinding!==void 0&&(l.typeDefaultBinding=e.typeDefaultBinding),l.typeNames=[...new Set([...l.typeNames??[],...e.typeNames??[]])],e.typeNamespaceBinding!==void 0&&(l.typeNamespaceBinding=e.typeNamespaceBinding);};var a=class{map=new Map;reverse=new Map;delete(e){let t=this.map.get(e);return t!==void 0&&this.reverse.delete(t),this.map.delete(e)}deleteValue(e){let t=this.reverse.get(e);return t!==void 0&&this.map.delete(t),this.reverse.delete(e)}entries(){return this.map.entries()}get(e){return this.map.get(e)}getKey(e){return this.reverse.get(e)}hasKey(e){return this.map.has(e)}hasValue(e){return this.reverse.has(e)}keys(){return this.map.keys()}set(e,t){let r=this.map.get(e);r!==void 0&&r!==t&&this.reverse.delete(r);let i=this.reverse.get(t);return i!==void 0&&i!==e&&this.map.delete(i),this.map.set(e,t),this.reverse.set(t,e),this}get size(){return this.map.size}values(){return this.map.values()}[Symbol.iterator](){return this.map[Symbol.iterator]()}};var p=class{_id=0;referenceOrder=new Set;registerOrder=new Set;selectorToId=new Map;values=new Map;get(e){let t=this.idOrSelector(e);if(t.id!==void 0)return this.values.get(t.id);let r=t.selector!==void 0?JSON.stringify(t.selector):void 0;if(r){let i=this.selectorToId.get(r);if(i!==void 0)return this.values.get(i)}}get id(){return this._id++}idOrSelector(e){return typeof e=="number"?{id:e}:{selector:e}}reference(e){let t=this.idOrSelector(e);return this.register(t)}*referenced(){for(let e of this.referenceOrder.values())yield this.values.get(e);}register(e){if(e.id!==void 0){let n=this.values.get(e.id);if(!n)throw new Error(`File with ID ${e.id} not found. To register a new file, leave the ID undefined.`);return n}let t=Object.keys(e).some(n=>!["id","selector"].includes(n)),r,i=e.selector!==void 0?JSON.stringify(e.selector):void 0;if(i){let n=this.selectorToId.get(i);if(n!==void 0){if(r=this.values.get(n),!r)throw new Error(`File with ID ${n} not found. The selector ${i} matched an ID, but there was no result. This is likely an issue with the application logic.`);if(!t)return r}}let s=r?.id!==void 0?r.id:this.id;return r={...r,...e,id:s,resolvedNames:r?.resolvedNames??new a,symbols:r?.symbols??{body:[],exports:[],imports:[]}},this.values.set(s,r),t?this.registerOrder.add(s):this.referenceOrder.add(s),i&&this.selectorToId.set(i,s),r}*registered(){for(let e of this.registerOrder.values())yield this.values.get(e);}};var f=l=>`_heyapi_${l}_`,b=l=>l.slice(8,-1),S=()=>new RegExp(f("\\d+"),"g"),v=(l,e)=>l.replace(S(),t=>{let r=Number.parseInt(b(t),10);return e(r)||t});var u=class{_id=0;nodes=new Map;registerOrder=new Set;selectorToId=new Map;values=new Map;get(e){let t=this.idOrSelector(e);if(t.id!==void 0)return this.values.get(t.id);let r=t.selector!==void 0?JSON.stringify(t.selector):void 0;if(r){let i=this.selectorToId.get(r);if(i!==void 0)return this.values.get(i)}}getValue(e){return this.nodes.get(e)}hasValue(e){return this.nodes.has(e)}get id(){return this._id++}idOrSelector(e){return typeof e=="number"?{id:e}:{selector:e}}reference(e){let t=this.idOrSelector(e);return this.register(t)}register(e){if(e.id!==void 0){let o=this.values.get(e.id);if(!o)throw new Error(`Symbol with ID ${e.id} not found. To register a new symbol, leave the ID undefined.`);return o}let t=Object.keys(e).some(o=>!["id","selector"].includes(o)),r,i=e.selector!==void 0?JSON.stringify(e.selector):void 0;if(i){let o=this.selectorToId.get(i);if(o!==void 0){if(r=this.values.get(o),!r)throw new Error(`Symbol with ID ${o} not found. The selector ${i} matched an ID, but there was no result. This is likely an issue with the application logic.`);if(!t)return r}}let s=r?.id!==void 0?r.id:this.id,n=r?.exportFrom?[...r.exportFrom]:[];return e.exportFrom&&n.push(...e.exportFrom),r={...r,...e,exportFrom:n,id:s,placeholder:r?.placeholder??e.placeholder??f(String(s))},this.values.set(s,r),t&&this.registerOrder.add(s),i&&this.selectorToId.set(i,s),r}*registered(){for(let e of this.registerOrder.values())yield this.values.get(e);}setValue(e,t){return this.nodes.set(e,t)}};var y="@",c=class{symbolIdToFileIds=new Map;defaultFileName;files=new p;fileName;renderers={};root;symbols=new u;constructor({defaultFileName:e,fileName:t,renderers:r,root:i}){this.defaultFileName=e??"main",this.fileName=typeof t=="string"?()=>t:t,this.renderers=r,this.root=i;}getRenderer(e){return e.extension?this.renderers[e.extension]:void 0}prepareFiles(){for(let t of this.symbols.registered()){let r=this.symbolToFileSelector(t),i=this.files.reference(r);i.symbols.body.push(t.id);let s=this.symbolIdToFileIds.get(t.id)??new Set;s.add(i.id),this.symbolIdToFileIds.set(t.id,s);for(let n of t.exportFrom){let o=[n],d=this.files.reference(o);d.id!==i.id&&d.symbols.exports.push(t.id);}}for(let t of this.files.referenced()){if(!t.selector)continue;if(t.selector[0]===y){let s=t.selector[1];if(!s){this.files.register({external:true,selector:t.selector});continue}let n=h__default.default.extname(s);if(!n){this.files.register({external:true,path:s,selector:t.selector});continue}this.files.register({extension:n,external:true,path:s,selector:t.selector});continue}let r=t.selector.slice(0,-1),i=t.selector[t.selector.length-1];i=this.fileName?.(i)||i,this.files.register({extension:".ts",name:i,path:h__default.default.resolve(this.root,...r,`${i}.ts`),selector:t.selector});}}render(e){this.prepareFiles();let t=new Map;for(let r of this.files.registered()){if(r.external||!r.path)continue;let i=this.getRenderer(r);i&&t.set(r.id,{content:i.renderSymbols(r,this,e),path:r.path});}for(let[r,i]of t.entries()){let s=this.files.get(r),o=this.getRenderer(s).renderFile(i.content,s,this,e);o?t.set(s.id,{...i,content:o}):t.delete(s.id);}return Array.from(t.values())}symbolIdToFiles(e){let t=this.symbolIdToFileIds.get(e);return Array.from(t??[]).map(r=>this.files.get(r))}symbolToFileSelector(e){if(e.external)return [y,e.external];let t=e.getFilePath?.(e);return t?t.split("/"):[this.defaultFileName]}};exports.Project=c;exports.createBinding=I;exports.mergeBindings=g;exports.renderIds=v;//# sourceMappingURL=index.cjs.map
1
+ var e=Object.create,t=Object.defineProperty,n=Object.getOwnPropertyDescriptor,r=Object.getOwnPropertyNames,i=Object.getPrototypeOf,a=Object.prototype.hasOwnProperty,o=(e,i,o,s)=>{if(i&&typeof i==`object`||typeof i==`function`)for(var c=r(i),l=0,u=c.length,d;l<u;l++)d=c[l],!a.call(e,d)&&d!==o&&t(e,d,{get:(e=>i[e]).bind(null,d),enumerable:!(s=n(i,d))||s.enumerable});return e},s=(n,r,a)=>(a=n==null?{}:e(i(n)),o(r||!n||!n.__esModule?t(a,`default`,{value:n,enumerable:!0}):a,n));let c=require(`node:path`);c=s(c);const l=({file:e,modulePath:t,symbol:n,symbolFile:r})=>{let i=[],a=[],o={aliases:{},from:t};if(n.meta?.importKind&&(n.meta.importKind===`default`?(o.defaultBinding=n.placeholder,n.meta.kind===`type`&&(o.typeDefaultBinding=!0)):n.meta.importKind===`namespace`&&(o.namespaceBinding=n.placeholder,n.meta.kind===`type`&&(o.typeNamespaceBinding=!0))),n.meta?.importKind===`named`||!i.length&&!o.defaultBinding&&!o.namespaceBinding){let t=n.placeholder,s=e.resolvedNames.get(n.id);if(s){let e=r.resolvedNames.get(n.id);e?e!==s&&(t=e,o.aliases[t]=s):n.name&&s!==n.name&&(t=n.name,o.aliases[t]=n.placeholder)}i.push(t),n.meta?.kind===`type`&&a.push(t)}for(let e of a)i.includes(e)||i.push(e);return o.names=i,o.typeNames=a,o},u=(e,t)=>{e.aliases={...e.aliases,...t.aliases},t.defaultBinding!==void 0&&(e.defaultBinding=t.defaultBinding),e.names=[...new Set([...e.names??[],...t.names??[]])],t.namespaceBinding!==void 0&&(e.namespaceBinding=t.namespaceBinding),t.typeDefaultBinding!==void 0&&(e.typeDefaultBinding=t.typeDefaultBinding),e.typeNames=[...new Set([...e.typeNames??[],...t.typeNames??[]])],t.typeNamespaceBinding!==void 0&&(e.typeNamespaceBinding=t.typeNamespaceBinding)};var d=class{map=new Map;reverse=new Map;delete(e){let t=this.map.get(e);return t!==void 0&&this.reverse.delete(t),this.map.delete(e)}deleteValue(e){let t=this.reverse.get(e);return t!==void 0&&this.map.delete(t),this.reverse.delete(e)}entries(){return this.map.entries()}get(e){return this.map.get(e)}getKey(e){return this.reverse.get(e)}hasKey(e){return this.map.has(e)}hasValue(e){return this.reverse.has(e)}keys(){return this.map.keys()}set(e,t){let n=this.map.get(e);n!==void 0&&n!==t&&this.reverse.delete(n);let r=this.reverse.get(t);return r!==void 0&&r!==e&&this.map.delete(r),this.map.set(e,t),this.reverse.set(t,e),this}get size(){return this.map.size}values(){return this.map.values()}[Symbol.iterator](){return this.map[Symbol.iterator]()}},f=class{_id=0;referenceOrder=new Set;registerOrder=new Set;selectorToId=new Map;values=new Map;get(e){let t=this.idOrSelector(e);if(t.id!==void 0)return this.values.get(t.id);let n=t.selector===void 0?void 0:JSON.stringify(t.selector);if(n){let e=this.selectorToId.get(n);if(e!==void 0)return this.values.get(e)}}get id(){return this._id++}idOrSelector(e){return typeof e==`number`?{id:e}:{selector:e}}reference(e){let t=this.idOrSelector(e);return this.register(t)}*referenced(){for(let e of this.referenceOrder.values())yield this.values.get(e)}register(e){if(e.id!==void 0){let t=this.values.get(e.id);if(!t)throw Error(`File with ID ${e.id} not found. To register a new file, leave the ID undefined.`);return t}let t=Object.keys(e).some(e=>![`id`,`selector`].includes(e)),n,r=e.selector===void 0?void 0:JSON.stringify(e.selector);if(r){let e=this.selectorToId.get(r);if(e!==void 0){if(n=this.values.get(e),!n)throw Error(`File with ID ${e} not found. The selector ${r} matched an ID, but there was no result. This is likely an issue with the application logic.`);if(!t)return n}}let i=n?.id===void 0?this.id:n.id;return n={...n,...e,id:i,resolvedNames:n?.resolvedNames??new d,symbols:n?.symbols??{body:[],exports:[],imports:[]}},this.values.set(i,n),t?this.registerOrder.add(i):this.referenceOrder.add(i),r&&this.selectorToId.set(r,i),n}*registered(){for(let e of this.registerOrder.values())yield this.values.get(e)}};const p=e=>`_heyapi_${e}_`,m=e=>e.slice(8,-1),h=()=>new RegExp(p(`\\d+`),`g`),g=(e,t)=>e.replace(h(),e=>t(Number.parseInt(m(e),10))||e);var _=class{_id=0;nodes=new Map;registerOrder=new Set;selectorToId=new Map;values=new Map;get(e){let t=this.idOrSelector(e);if(t.id!==void 0)return this.values.get(t.id);let n=t.selector===void 0?void 0:JSON.stringify(t.selector);if(n){let e=this.selectorToId.get(n);if(e!==void 0)return this.values.get(e)}}getValue(e){return this.nodes.get(e)}hasValue(e){return this.nodes.has(e)}get id(){return this._id++}idOrSelector(e){return typeof e==`number`?{id:e}:{selector:e}}reference(e){let t=this.idOrSelector(e);return this.register(t)}register(e){if(e.id!==void 0){let t=this.values.get(e.id);if(!t)throw Error(`Symbol with ID ${e.id} not found. To register a new symbol, leave the ID undefined.`);return t}let t=Object.keys(e).some(e=>![`id`,`selector`].includes(e)),n,r=e.selector===void 0?void 0:JSON.stringify(e.selector);if(r){let e=this.selectorToId.get(r);if(e!==void 0){if(n=this.values.get(e),!n)throw Error(`Symbol with ID ${e} not found. The selector ${r} matched an ID, but there was no result. This is likely an issue with the application logic.`);if(!t)return n}}let i=n?.id===void 0?this.id:n.id,a=n?.exportFrom?[...n.exportFrom]:[];return e.exportFrom&&a.push(...e.exportFrom),n={...n,...e,exportFrom:a,id:i,placeholder:n?.placeholder??e.placeholder??p(String(i))},this.values.set(i,n),t&&this.registerOrder.add(i),r&&this.selectorToId.set(r,i),n}*registered(){for(let e of this.registerOrder.values())yield this.values.get(e)}setValue(e,t){return this.nodes.set(e,t)}};const v=`@`;var y=class{symbolIdToFileIds=new Map;defaultFileName;files=new f;fileName;renderers={};root;symbols=new _;constructor({defaultFileName:e,fileName:t,renderers:n,root:r}){this.defaultFileName=e??`main`,this.fileName=typeof t==`string`?()=>t:t,this.renderers=n,this.root=r}getRenderer(e){return e.extension?this.renderers[e.extension]:void 0}prepareFiles(){for(let e of this.symbols.registered()){let t=this.symbolToFileSelector(e),n=this.files.reference(t);n.symbols.body.push(e.id);let r=this.symbolIdToFileIds.get(e.id)??new Set;r.add(n.id),this.symbolIdToFileIds.set(e.id,r);for(let t of e.exportFrom){let r=[t],i=this.files.reference(r);i.id!==n.id&&i.symbols.exports.push(e.id)}}for(let e of this.files.referenced()){if(!e.selector)continue;if(e.selector[0]===`@`){let t=e.selector[1];if(!t){this.files.register({external:!0,selector:e.selector});continue}let n=c.default.extname(t);if(!n){this.files.register({external:!0,path:t,selector:e.selector});continue}this.files.register({extension:n,external:!0,path:t,selector:e.selector});continue}let t=e.selector.slice(0,-1),n=e.selector[e.selector.length-1];n=this.fileName?.(n)||n,this.files.register({extension:`.ts`,name:n,path:c.default.resolve(this.root,...t,`${n}.ts`),selector:e.selector})}}render(e){this.prepareFiles();let t=new Map;for(let n of this.files.registered()){if(n.external||!n.path)continue;let r=this.getRenderer(n);r&&t.set(n.id,{content:r.renderSymbols(n,this,e),path:n.path})}for(let[n,r]of t.entries()){let i=this.files.get(n),a=this.getRenderer(i).renderFile(r.content,i,this,e);a?t.set(i.id,{...r,content:a}):t.delete(i.id)}return Array.from(t.values())}symbolIdToFiles(e){let t=this.symbolIdToFileIds.get(e);return Array.from(t??[]).map(e=>this.files.get(e))}symbolToFileSelector(e){if(e.external)return[`@`,e.external];let t=e.getFilePath?.(e);return t?t.split(`/`):[this.defaultFileName]}};exports.Project=y,exports.createBinding=l,exports.mergeBindings=u,exports.renderIds=g;
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/bindings/utils.ts","../src/bimap/bimap.ts","../src/files/registry.ts","../src/renderer/utils.ts","../src/symbols/registry.ts","../src/project/project.ts"],"names":["createBinding","file","modulePath","symbol","symbolFile","names","typeNames","binding","name","fileResolvedName","symbolFileResolvedName","typeName","mergeBindings","target","source","BiMap","key","value","oldValue","oldKey","FileRegistry","fileIdOrSelector","selector","id","symbolIdOrSelector","result","hasOtherKeys","wrapId","symbolId","unwrapId","wrappedId","createPlaceholderRegExp","renderIds","replacerFn","match","SymbolRegistry","exportFrom","externalSourceSymbol","Project","defaultFileName","fileName","renderers","root","symbolIdToFileIds","exportSelector","exportFile","filePath","extension","path","dirs","meta","files","renderer","fileId","content","fileIds"],"mappings":"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","file":"index.cjs","sourcesContent":["import type { IFileOut } from '../files/types';\nimport type { ISymbolOut } from '../symbols/types';\nimport type { IBinding } from './types';\n\nexport const createBinding = ({\n file,\n modulePath,\n symbol,\n symbolFile,\n}: {\n file: IFileOut;\n modulePath: string;\n symbol: ISymbolOut;\n symbolFile: IFileOut;\n}): IBinding => {\n const names: Array<string> = [];\n const typeNames: Array<string> = [];\n const binding: IBinding & Pick<Required<IBinding>, 'aliases' | 'from'> = {\n aliases: {},\n from: modulePath,\n };\n if (symbol.meta?.importKind) {\n if (symbol.meta.importKind === 'default') {\n binding.defaultBinding = symbol.placeholder;\n if (symbol.meta.kind === 'type') {\n binding.typeDefaultBinding = true;\n }\n } else if (symbol.meta.importKind === 'namespace') {\n binding.namespaceBinding = symbol.placeholder;\n if (symbol.meta.kind === 'type') {\n binding.typeNamespaceBinding = true;\n }\n }\n }\n // default to named binding\n if (\n symbol.meta?.importKind === 'named' ||\n (!names.length && !binding.defaultBinding && !binding.namespaceBinding)\n ) {\n let name = symbol.placeholder;\n const fileResolvedName = file.resolvedNames.get(symbol.id);\n if (fileResolvedName) {\n const symbolFileResolvedName = symbolFile.resolvedNames.get(symbol.id);\n if (symbolFileResolvedName) {\n if (symbolFileResolvedName !== fileResolvedName) {\n name = symbolFileResolvedName;\n binding.aliases[name] = fileResolvedName;\n }\n } else if (symbol.name && fileResolvedName !== symbol.name) {\n name = symbol.name;\n binding.aliases[name] = symbol.placeholder;\n }\n }\n names.push(name);\n if (symbol.meta?.kind === 'type') {\n typeNames.push(name);\n }\n }\n // cast type names to names to allow for cleaner API,\n // otherwise users would have to define the same values twice\n for (const typeName of typeNames) {\n if (!names.includes(typeName)) {\n names.push(typeName);\n }\n }\n binding.names = names;\n binding.typeNames = typeNames;\n return binding;\n};\n\nexport const mergeBindings = (target: IBinding, source: IBinding): void => {\n target.aliases = { ...target.aliases, ...source.aliases };\n if (source.defaultBinding !== undefined) {\n target.defaultBinding = source.defaultBinding;\n }\n target.names = [\n ...new Set([...(target.names ?? []), ...(source.names ?? [])]),\n ];\n if (source.namespaceBinding !== undefined) {\n target.namespaceBinding = source.namespaceBinding;\n }\n if (source.typeDefaultBinding !== undefined) {\n target.typeDefaultBinding = source.typeDefaultBinding;\n }\n target.typeNames = [\n ...new Set([...(target.typeNames ?? []), ...(source.typeNames ?? [])]),\n ];\n if (source.typeNamespaceBinding !== undefined) {\n target.typeNamespaceBinding = source.typeNamespaceBinding;\n }\n};\n","import type { IBiMap } from './types';\n\nexport class BiMap<Key, Value> implements IBiMap<Key, Value> {\n private map = new Map<Key, Value>();\n private reverse = new Map<Value, Key>();\n\n delete(key: Key): boolean {\n const value = this.map.get(key);\n if (value !== undefined) {\n this.reverse.delete(value);\n }\n return this.map.delete(key);\n }\n\n deleteValue(value: Value): boolean {\n const key = this.reverse.get(value);\n if (key !== undefined) {\n this.map.delete(key);\n }\n return this.reverse.delete(value);\n }\n\n entries(): IterableIterator<[Key, Value]> {\n return this.map.entries();\n }\n\n get(key: Key): Value | undefined {\n return this.map.get(key);\n }\n\n getKey(value: Value): Key | undefined {\n return this.reverse.get(value);\n }\n\n hasKey(key: Key): boolean {\n return this.map.has(key);\n }\n\n hasValue(value: Value): boolean {\n return this.reverse.has(value);\n }\n\n keys(): IterableIterator<Key> {\n return this.map.keys();\n }\n\n set(key: Key, value: Value): this {\n const oldValue = this.map.get(key);\n if (oldValue !== undefined && oldValue !== value) {\n this.reverse.delete(oldValue);\n }\n const oldKey = this.reverse.get(value);\n if (oldKey !== undefined && oldKey !== key) {\n this.map.delete(oldKey);\n }\n this.map.set(key, value);\n this.reverse.set(value, key);\n return this;\n }\n\n get size(): number {\n return this.map.size;\n }\n\n values(): IterableIterator<Value> {\n return this.map.values();\n }\n\n [Symbol.iterator](): IterableIterator<[Key, Value]> {\n return this.map[Symbol.iterator]();\n }\n}\n","import { BiMap } from '../bimap/bimap';\nimport type { ISelector } from '../selectors/types';\nimport type { IFileIn, IFileOut, IFileRegistry } from './types';\n\nexport class FileRegistry implements IFileRegistry {\n private _id: number = 0;\n private referenceOrder: Set<number> = new Set();\n private registerOrder: Set<number> = new Set();\n private selectorToId: Map<string, number> = new Map();\n private values: Map<number, IFileOut> = new Map();\n\n get(fileIdOrSelector: number | ISelector): IFileOut | undefined {\n const symbol = this.idOrSelector(fileIdOrSelector);\n\n if (symbol.id !== undefined) {\n return this.values.get(symbol.id);\n }\n\n const selector =\n symbol.selector !== undefined\n ? JSON.stringify(symbol.selector)\n : undefined;\n\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n return this.values.get(id);\n }\n }\n\n return;\n }\n\n get id(): number {\n return this._id++;\n }\n\n private idOrSelector(\n symbolIdOrSelector: number | ISelector,\n ): Pick<IFileIn, 'id' | 'selector'> {\n return typeof symbolIdOrSelector === 'number'\n ? { id: symbolIdOrSelector }\n : { selector: symbolIdOrSelector };\n }\n\n reference(fileIdOrSelector: number | ISelector): IFileOut {\n const file = this.idOrSelector(fileIdOrSelector);\n return this.register(file);\n }\n\n *referenced(): IterableIterator<IFileOut> {\n for (const id of this.referenceOrder.values()) {\n yield this.values.get(id)!;\n }\n }\n\n register(file: IFileIn): IFileOut {\n if (file.id !== undefined) {\n const result = this.values.get(file.id);\n if (!result) {\n throw new Error(\n `File with ID ${file.id} not found. To register a new file, leave the ID undefined.`,\n );\n }\n return result;\n }\n\n const hasOtherKeys = Object.keys(file).some(\n (key) => !['id', 'selector'].includes(key),\n );\n\n let result: IFileOut | undefined;\n\n const selector =\n file.selector !== undefined ? JSON.stringify(file.selector) : undefined;\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n result = this.values.get(id);\n if (!result) {\n throw new Error(\n `File with ID ${id} not found. The selector ${selector} matched an ID, but there was no result. This is likely an issue with the application logic.`,\n );\n }\n if (!hasOtherKeys) {\n return result;\n }\n }\n }\n\n const id = result?.id !== undefined ? result.id : this.id;\n result = {\n ...result,\n ...file, // clone to avoid mutation\n id,\n resolvedNames: result?.resolvedNames ?? new BiMap(),\n symbols: result?.symbols ?? {\n body: [],\n exports: [],\n imports: [],\n },\n };\n this.values.set(id, result);\n\n if (hasOtherKeys) {\n this.registerOrder.add(id);\n } else {\n this.referenceOrder.add(id);\n }\n\n if (selector) {\n this.selectorToId.set(selector, id);\n }\n\n return result;\n }\n\n *registered(): IterableIterator<IFileOut> {\n for (const id of this.registerOrder.values()) {\n yield this.values.get(id)!;\n }\n }\n}\n","/**\n * Wraps an ID in namespace to avoid collisions when replacing it.\n *\n * @param symbolId Stringified symbol ID to use.\n * @returns The wrapped placeholder ID.\n */\nexport const wrapId = (symbolId: string): string => `_heyapi_${symbolId}_`;\n\n/**\n * Unwraps an ID from namespace.\n *\n * @param wrappedId The wrapped placeholder ID.\n * @returns Stringified ID to use.\n */\nconst unwrapId = (wrappedId: string): string =>\n wrappedId.slice('_heyapi_'.length, -1);\n\n/**\n * Returns a RegExp instance to match ID placeholders.\n *\n * @returns RegExp instance to match ID placeholders.\n */\nconst createPlaceholderRegExp = (): RegExp => new RegExp(wrapId('\\\\d+'), 'g');\n\n/**\n *\n * @param source The source string to replace.\n * @param replacerFn Accepts a symbol ID, returns resolved symbol name.\n * @returns The replaced source string.\n */\nexport const renderIds = (\n source: string,\n replacerFn: (symbolId: number) => string | undefined,\n): string =>\n source.replace(createPlaceholderRegExp(), (match) => {\n const symbolId = Number.parseInt(unwrapId(match), 10);\n return replacerFn(symbolId) || match;\n });\n","import { wrapId } from '../renderer/utils';\nimport type { ISelector } from '../selectors/types';\nimport type { ISymbolIn, ISymbolOut, ISymbolRegistry } from './types';\n\nexport class SymbolRegistry implements ISymbolRegistry {\n private _id: number = 0;\n private nodes: Map<number, unknown> = new Map();\n private registerOrder: Set<number> = new Set();\n private selectorToId: Map<string, number> = new Map();\n private values: Map<number, ISymbolOut> = new Map();\n\n get(symbolIdOrSelector: number | ISelector): ISymbolOut | undefined {\n const symbol = this.idOrSelector(symbolIdOrSelector);\n\n if (symbol.id !== undefined) {\n return this.values.get(symbol.id);\n }\n\n const selector =\n symbol.selector !== undefined\n ? JSON.stringify(symbol.selector)\n : undefined;\n\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n return this.values.get(id);\n }\n }\n\n return;\n }\n\n getValue(symbolId: number): unknown {\n return this.nodes.get(symbolId);\n }\n\n hasValue(symbolId: number): boolean {\n return this.nodes.has(symbolId);\n }\n\n get id(): number {\n return this._id++;\n }\n\n private idOrSelector(\n symbolIdOrSelector: number | ISelector,\n ): Pick<ISymbolIn, 'id' | 'selector'> {\n return typeof symbolIdOrSelector === 'number'\n ? { id: symbolIdOrSelector }\n : { selector: symbolIdOrSelector };\n }\n\n reference(symbolIdOrSelector: number | ISelector): ISymbolOut {\n const symbol = this.idOrSelector(symbolIdOrSelector);\n return this.register(symbol);\n }\n\n register(symbol: ISymbolIn): ISymbolOut {\n if (symbol.id !== undefined) {\n const result = this.values.get(symbol.id);\n if (!result) {\n throw new Error(\n `Symbol with ID ${symbol.id} not found. To register a new symbol, leave the ID undefined.`,\n );\n }\n return result;\n }\n\n const hasOtherKeys = Object.keys(symbol).some(\n (key) => !['id', 'selector'].includes(key),\n );\n\n let result: ISymbolOut | undefined;\n\n const selector =\n symbol.selector !== undefined\n ? JSON.stringify(symbol.selector)\n : undefined;\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n result = this.values.get(id);\n if (!result) {\n throw new Error(\n `Symbol with ID ${id} not found. The selector ${selector} matched an ID, but there was no result. This is likely an issue with the application logic.`,\n );\n }\n if (!hasOtherKeys) {\n return result;\n }\n }\n }\n\n const id = result?.id !== undefined ? result.id : this.id;\n const exportFrom: Array<string> = result?.exportFrom\n ? [...result.exportFrom]\n : [];\n if (symbol.exportFrom) {\n exportFrom.push(...symbol.exportFrom);\n }\n result = {\n ...result,\n ...symbol, // clone to avoid mutation\n exportFrom,\n id,\n placeholder:\n result?.placeholder ?? symbol.placeholder ?? wrapId(String(id)),\n };\n this.values.set(id, result);\n\n if (hasOtherKeys) {\n this.registerOrder.add(id);\n }\n\n if (selector) {\n this.selectorToId.set(selector, id);\n }\n\n return result;\n }\n\n *registered(): IterableIterator<ISymbolOut> {\n for (const id of this.registerOrder.values()) {\n yield this.values.get(id)!;\n }\n }\n\n setValue(symbolId: number, value: unknown): Map<number, unknown> {\n return this.nodes.set(symbolId, value);\n }\n}\n","import path from 'node:path';\n\nimport type { IProjectRenderMeta } from '../extensions/types';\nimport { FileRegistry } from '../files/registry';\nimport type { IFileOut } from '../files/types';\nimport type { IOutput } from '../output/types';\nimport type { IRenderer } from '../renderer/types';\nimport type { ISelector } from '../selectors/types';\nimport { SymbolRegistry } from '../symbols/registry';\nimport type { ISymbolOut } from '../symbols/types';\nimport type { IProject } from './types';\n\nconst externalSourceSymbol = '@';\n\nexport class Project implements IProject {\n private symbolIdToFileIds: Map<number, Set<number>> = new Map();\n\n readonly defaultFileName: string;\n readonly files = new FileRegistry();\n readonly fileName?: (name: string) => string;\n readonly renderers: Record<string, IRenderer> = {};\n readonly root: string;\n readonly symbols = new SymbolRegistry();\n\n constructor({\n defaultFileName,\n fileName,\n renderers,\n root,\n }: Pick<IProject, 'defaultFileName' | 'fileName' | 'renderers' | 'root'>) {\n this.defaultFileName = defaultFileName ?? 'main';\n this.fileName = typeof fileName === 'string' ? () => fileName : fileName;\n this.renderers = renderers;\n this.root = root;\n }\n\n private getRenderer(file: IFileOut): IRenderer | undefined {\n return file.extension ? this.renderers[file.extension] : undefined;\n }\n\n private prepareFiles(): void {\n // TODO: infer extension from symbols\n const extension = '.ts';\n for (const symbol of this.symbols.registered()) {\n const selector = this.symbolToFileSelector(symbol);\n const file = this.files.reference(selector);\n file.symbols.body.push(symbol.id);\n // update symbol->files map\n const symbolIdToFileIds =\n this.symbolIdToFileIds.get(symbol.id) ?? new Set();\n symbolIdToFileIds.add(file.id);\n this.symbolIdToFileIds.set(symbol.id, symbolIdToFileIds);\n // update re-exports\n for (const exportFrom of symbol.exportFrom) {\n const exportSelector = [exportFrom];\n const exportFile = this.files.reference(exportSelector);\n if (exportFile.id !== file.id) {\n exportFile.symbols.exports.push(symbol.id);\n }\n }\n }\n for (const file of this.files.referenced()) {\n if (!file.selector) continue;\n if (file.selector[0] === externalSourceSymbol) {\n const filePath = file.selector[1];\n if (!filePath) {\n this.files.register({\n external: true,\n selector: file.selector,\n });\n continue;\n }\n const extension = path.extname(filePath);\n if (!extension) {\n this.files.register({\n external: true,\n path: filePath,\n selector: file.selector,\n });\n continue;\n }\n this.files.register({\n extension,\n external: true,\n path: filePath,\n selector: file.selector,\n });\n continue;\n }\n const dirs = file.selector.slice(0, -1);\n let name = file.selector[file.selector.length - 1]!;\n name = this.fileName?.(name) || name;\n this.files.register({\n extension,\n name,\n path: path.resolve(this.root, ...dirs, `${name}${extension}`),\n selector: file.selector,\n });\n }\n\n // TODO: track symbol dependencies and inject imports into files\n // based on symbol references so the render step can just render\n }\n\n render(meta?: IProjectRenderMeta): ReadonlyArray<IOutput> {\n this.prepareFiles();\n const files: Map<number, IOutput> = new Map();\n for (const file of this.files.registered()) {\n if (file.external || !file.path) continue;\n const renderer = this.getRenderer(file);\n if (!renderer) continue;\n files.set(file.id, {\n content: renderer.renderSymbols(file, this, meta),\n path: file.path,\n });\n }\n for (const [fileId, value] of files.entries()) {\n const file = this.files.get(fileId)!;\n const renderer = this.getRenderer(file)!;\n const content = renderer.renderFile(value.content, file, this, meta);\n if (content) {\n files.set(file.id, { ...value, content });\n } else {\n files.delete(file.id);\n }\n }\n return Array.from(files.values());\n }\n\n symbolIdToFiles(symbolId: number): ReadonlyArray<IFileOut> {\n const fileIds = this.symbolIdToFileIds.get(symbolId);\n return Array.from(fileIds ?? []).map((fileId) => this.files.get(fileId)!);\n }\n\n private symbolToFileSelector(symbol: ISymbolOut): ISelector {\n if (symbol.external) {\n return [externalSourceSymbol, symbol.external];\n }\n const filePath = symbol.getFilePath?.(symbol);\n if (filePath) {\n return filePath.split('/');\n }\n return [this.defaultFileName];\n }\n}\n"]}
1
+ {"version":3,"file":"index.cjs","names":["names: Array<string>","typeNames: Array<string>","binding: IBinding & Pick<Required<IBinding>, 'aliases' | 'from'>","result","result: IFileOut | undefined","id","result","result: ISymbolOut | undefined","id","exportFrom: Array<string>","extension","path","files: Map<number, IOutput>"],"sources":["../src/bindings/utils.ts","../src/bimap/bimap.ts","../src/files/registry.ts","../src/renderer/utils.ts","../src/symbols/registry.ts","../src/project/project.ts"],"sourcesContent":["import type { IFileOut } from '../files/types';\nimport type { ISymbolOut } from '../symbols/types';\nimport type { IBinding } from './types';\n\nexport const createBinding = ({\n file,\n modulePath,\n symbol,\n symbolFile,\n}: {\n file: IFileOut;\n modulePath: string;\n symbol: ISymbolOut;\n symbolFile: IFileOut;\n}): IBinding => {\n const names: Array<string> = [];\n const typeNames: Array<string> = [];\n const binding: IBinding & Pick<Required<IBinding>, 'aliases' | 'from'> = {\n aliases: {},\n from: modulePath,\n };\n if (symbol.meta?.importKind) {\n if (symbol.meta.importKind === 'default') {\n binding.defaultBinding = symbol.placeholder;\n if (symbol.meta.kind === 'type') {\n binding.typeDefaultBinding = true;\n }\n } else if (symbol.meta.importKind === 'namespace') {\n binding.namespaceBinding = symbol.placeholder;\n if (symbol.meta.kind === 'type') {\n binding.typeNamespaceBinding = true;\n }\n }\n }\n // default to named binding\n if (\n symbol.meta?.importKind === 'named' ||\n (!names.length && !binding.defaultBinding && !binding.namespaceBinding)\n ) {\n let name = symbol.placeholder;\n const fileResolvedName = file.resolvedNames.get(symbol.id);\n if (fileResolvedName) {\n const symbolFileResolvedName = symbolFile.resolvedNames.get(symbol.id);\n if (symbolFileResolvedName) {\n if (symbolFileResolvedName !== fileResolvedName) {\n name = symbolFileResolvedName;\n binding.aliases[name] = fileResolvedName;\n }\n } else if (symbol.name && fileResolvedName !== symbol.name) {\n name = symbol.name;\n binding.aliases[name] = symbol.placeholder;\n }\n }\n names.push(name);\n if (symbol.meta?.kind === 'type') {\n typeNames.push(name);\n }\n }\n // cast type names to names to allow for cleaner API,\n // otherwise users would have to define the same values twice\n for (const typeName of typeNames) {\n if (!names.includes(typeName)) {\n names.push(typeName);\n }\n }\n binding.names = names;\n binding.typeNames = typeNames;\n return binding;\n};\n\nexport const mergeBindings = (target: IBinding, source: IBinding): void => {\n target.aliases = { ...target.aliases, ...source.aliases };\n if (source.defaultBinding !== undefined) {\n target.defaultBinding = source.defaultBinding;\n }\n target.names = [\n ...new Set([...(target.names ?? []), ...(source.names ?? [])]),\n ];\n if (source.namespaceBinding !== undefined) {\n target.namespaceBinding = source.namespaceBinding;\n }\n if (source.typeDefaultBinding !== undefined) {\n target.typeDefaultBinding = source.typeDefaultBinding;\n }\n target.typeNames = [\n ...new Set([...(target.typeNames ?? []), ...(source.typeNames ?? [])]),\n ];\n if (source.typeNamespaceBinding !== undefined) {\n target.typeNamespaceBinding = source.typeNamespaceBinding;\n }\n};\n","import type { IBiMap } from './types';\n\nexport class BiMap<Key, Value> implements IBiMap<Key, Value> {\n private map = new Map<Key, Value>();\n private reverse = new Map<Value, Key>();\n\n delete(key: Key): boolean {\n const value = this.map.get(key);\n if (value !== undefined) {\n this.reverse.delete(value);\n }\n return this.map.delete(key);\n }\n\n deleteValue(value: Value): boolean {\n const key = this.reverse.get(value);\n if (key !== undefined) {\n this.map.delete(key);\n }\n return this.reverse.delete(value);\n }\n\n entries(): IterableIterator<[Key, Value]> {\n return this.map.entries();\n }\n\n get(key: Key): Value | undefined {\n return this.map.get(key);\n }\n\n getKey(value: Value): Key | undefined {\n return this.reverse.get(value);\n }\n\n hasKey(key: Key): boolean {\n return this.map.has(key);\n }\n\n hasValue(value: Value): boolean {\n return this.reverse.has(value);\n }\n\n keys(): IterableIterator<Key> {\n return this.map.keys();\n }\n\n set(key: Key, value: Value): this {\n const oldValue = this.map.get(key);\n if (oldValue !== undefined && oldValue !== value) {\n this.reverse.delete(oldValue);\n }\n const oldKey = this.reverse.get(value);\n if (oldKey !== undefined && oldKey !== key) {\n this.map.delete(oldKey);\n }\n this.map.set(key, value);\n this.reverse.set(value, key);\n return this;\n }\n\n get size(): number {\n return this.map.size;\n }\n\n values(): IterableIterator<Value> {\n return this.map.values();\n }\n\n [Symbol.iterator](): IterableIterator<[Key, Value]> {\n return this.map[Symbol.iterator]();\n }\n}\n","import { BiMap } from '../bimap/bimap';\nimport type { ISelector } from '../selectors/types';\nimport type { IFileIn, IFileOut, IFileRegistry } from './types';\n\nexport class FileRegistry implements IFileRegistry {\n private _id: number = 0;\n private referenceOrder: Set<number> = new Set();\n private registerOrder: Set<number> = new Set();\n private selectorToId: Map<string, number> = new Map();\n private values: Map<number, IFileOut> = new Map();\n\n get(fileIdOrSelector: number | ISelector): IFileOut | undefined {\n const symbol = this.idOrSelector(fileIdOrSelector);\n\n if (symbol.id !== undefined) {\n return this.values.get(symbol.id);\n }\n\n const selector =\n symbol.selector !== undefined\n ? JSON.stringify(symbol.selector)\n : undefined;\n\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n return this.values.get(id);\n }\n }\n\n return;\n }\n\n get id(): number {\n return this._id++;\n }\n\n private idOrSelector(\n symbolIdOrSelector: number | ISelector,\n ): Pick<IFileIn, 'id' | 'selector'> {\n return typeof symbolIdOrSelector === 'number'\n ? { id: symbolIdOrSelector }\n : { selector: symbolIdOrSelector };\n }\n\n reference(fileIdOrSelector: number | ISelector): IFileOut {\n const file = this.idOrSelector(fileIdOrSelector);\n return this.register(file);\n }\n\n *referenced(): IterableIterator<IFileOut> {\n for (const id of this.referenceOrder.values()) {\n yield this.values.get(id)!;\n }\n }\n\n register(file: IFileIn): IFileOut {\n if (file.id !== undefined) {\n const result = this.values.get(file.id);\n if (!result) {\n throw new Error(\n `File with ID ${file.id} not found. To register a new file, leave the ID undefined.`,\n );\n }\n return result;\n }\n\n const hasOtherKeys = Object.keys(file).some(\n (key) => !['id', 'selector'].includes(key),\n );\n\n let result: IFileOut | undefined;\n\n const selector =\n file.selector !== undefined ? JSON.stringify(file.selector) : undefined;\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n result = this.values.get(id);\n if (!result) {\n throw new Error(\n `File with ID ${id} not found. The selector ${selector} matched an ID, but there was no result. This is likely an issue with the application logic.`,\n );\n }\n if (!hasOtherKeys) {\n return result;\n }\n }\n }\n\n const id = result?.id !== undefined ? result.id : this.id;\n result = {\n ...result,\n ...file, // clone to avoid mutation\n id,\n resolvedNames: result?.resolvedNames ?? new BiMap(),\n symbols: result?.symbols ?? {\n body: [],\n exports: [],\n imports: [],\n },\n };\n this.values.set(id, result);\n\n if (hasOtherKeys) {\n this.registerOrder.add(id);\n } else {\n this.referenceOrder.add(id);\n }\n\n if (selector) {\n this.selectorToId.set(selector, id);\n }\n\n return result;\n }\n\n *registered(): IterableIterator<IFileOut> {\n for (const id of this.registerOrder.values()) {\n yield this.values.get(id)!;\n }\n }\n}\n","/**\n * Wraps an ID in namespace to avoid collisions when replacing it.\n *\n * @param symbolId Stringified symbol ID to use.\n * @returns The wrapped placeholder ID.\n */\nexport const wrapId = (symbolId: string): string => `_heyapi_${symbolId}_`;\n\n/**\n * Unwraps an ID from namespace.\n *\n * @param wrappedId The wrapped placeholder ID.\n * @returns Stringified ID to use.\n */\nconst unwrapId = (wrappedId: string): string =>\n wrappedId.slice('_heyapi_'.length, -1);\n\n/**\n * Returns a RegExp instance to match ID placeholders.\n *\n * @returns RegExp instance to match ID placeholders.\n */\nconst createPlaceholderRegExp = (): RegExp => new RegExp(wrapId('\\\\d+'), 'g');\n\n/**\n *\n * @param source The source string to replace.\n * @param replacerFn Accepts a symbol ID, returns resolved symbol name.\n * @returns The replaced source string.\n */\nexport const renderIds = (\n source: string,\n replacerFn: (symbolId: number) => string | undefined,\n): string =>\n source.replace(createPlaceholderRegExp(), (match) => {\n const symbolId = Number.parseInt(unwrapId(match), 10);\n return replacerFn(symbolId) || match;\n });\n","import { wrapId } from '../renderer/utils';\nimport type { ISelector } from '../selectors/types';\nimport type { ISymbolIn, ISymbolOut, ISymbolRegistry } from './types';\n\nexport class SymbolRegistry implements ISymbolRegistry {\n private _id: number = 0;\n private nodes: Map<number, unknown> = new Map();\n private registerOrder: Set<number> = new Set();\n private selectorToId: Map<string, number> = new Map();\n private values: Map<number, ISymbolOut> = new Map();\n\n get(symbolIdOrSelector: number | ISelector): ISymbolOut | undefined {\n const symbol = this.idOrSelector(symbolIdOrSelector);\n\n if (symbol.id !== undefined) {\n return this.values.get(symbol.id);\n }\n\n const selector =\n symbol.selector !== undefined\n ? JSON.stringify(symbol.selector)\n : undefined;\n\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n return this.values.get(id);\n }\n }\n\n return;\n }\n\n getValue(symbolId: number): unknown {\n return this.nodes.get(symbolId);\n }\n\n hasValue(symbolId: number): boolean {\n return this.nodes.has(symbolId);\n }\n\n get id(): number {\n return this._id++;\n }\n\n private idOrSelector(\n symbolIdOrSelector: number | ISelector,\n ): Pick<ISymbolIn, 'id' | 'selector'> {\n return typeof symbolIdOrSelector === 'number'\n ? { id: symbolIdOrSelector }\n : { selector: symbolIdOrSelector };\n }\n\n reference(symbolIdOrSelector: number | ISelector): ISymbolOut {\n const symbol = this.idOrSelector(symbolIdOrSelector);\n return this.register(symbol);\n }\n\n register(symbol: ISymbolIn): ISymbolOut {\n if (symbol.id !== undefined) {\n const result = this.values.get(symbol.id);\n if (!result) {\n throw new Error(\n `Symbol with ID ${symbol.id} not found. To register a new symbol, leave the ID undefined.`,\n );\n }\n return result;\n }\n\n const hasOtherKeys = Object.keys(symbol).some(\n (key) => !['id', 'selector'].includes(key),\n );\n\n let result: ISymbolOut | undefined;\n\n const selector =\n symbol.selector !== undefined\n ? JSON.stringify(symbol.selector)\n : undefined;\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n result = this.values.get(id);\n if (!result) {\n throw new Error(\n `Symbol with ID ${id} not found. The selector ${selector} matched an ID, but there was no result. This is likely an issue with the application logic.`,\n );\n }\n if (!hasOtherKeys) {\n return result;\n }\n }\n }\n\n const id = result?.id !== undefined ? result.id : this.id;\n const exportFrom: Array<string> = result?.exportFrom\n ? [...result.exportFrom]\n : [];\n if (symbol.exportFrom) {\n exportFrom.push(...symbol.exportFrom);\n }\n result = {\n ...result,\n ...symbol, // clone to avoid mutation\n exportFrom,\n id,\n placeholder:\n result?.placeholder ?? symbol.placeholder ?? wrapId(String(id)),\n };\n this.values.set(id, result);\n\n if (hasOtherKeys) {\n this.registerOrder.add(id);\n }\n\n if (selector) {\n this.selectorToId.set(selector, id);\n }\n\n return result;\n }\n\n *registered(): IterableIterator<ISymbolOut> {\n for (const id of this.registerOrder.values()) {\n yield this.values.get(id)!;\n }\n }\n\n setValue(symbolId: number, value: unknown): Map<number, unknown> {\n return this.nodes.set(symbolId, value);\n }\n}\n","import path from 'node:path';\n\nimport type { IProjectRenderMeta } from '../extensions/types';\nimport { FileRegistry } from '../files/registry';\nimport type { IFileOut } from '../files/types';\nimport type { IOutput } from '../output/types';\nimport type { IRenderer } from '../renderer/types';\nimport type { ISelector } from '../selectors/types';\nimport { SymbolRegistry } from '../symbols/registry';\nimport type { ISymbolOut } from '../symbols/types';\nimport type { IProject } from './types';\n\nconst externalSourceSymbol = '@';\n\nexport class Project implements IProject {\n private symbolIdToFileIds: Map<number, Set<number>> = new Map();\n\n readonly defaultFileName: string;\n readonly files = new FileRegistry();\n readonly fileName?: (name: string) => string;\n readonly renderers: Record<string, IRenderer> = {};\n readonly root: string;\n readonly symbols = new SymbolRegistry();\n\n constructor({\n defaultFileName,\n fileName,\n renderers,\n root,\n }: Pick<IProject, 'defaultFileName' | 'fileName' | 'renderers' | 'root'>) {\n this.defaultFileName = defaultFileName ?? 'main';\n this.fileName = typeof fileName === 'string' ? () => fileName : fileName;\n this.renderers = renderers;\n this.root = root;\n }\n\n private getRenderer(file: IFileOut): IRenderer | undefined {\n return file.extension ? this.renderers[file.extension] : undefined;\n }\n\n private prepareFiles(): void {\n // TODO: infer extension from symbols\n const extension = '.ts';\n for (const symbol of this.symbols.registered()) {\n const selector = this.symbolToFileSelector(symbol);\n const file = this.files.reference(selector);\n file.symbols.body.push(symbol.id);\n // update symbol->files map\n const symbolIdToFileIds =\n this.symbolIdToFileIds.get(symbol.id) ?? new Set();\n symbolIdToFileIds.add(file.id);\n this.symbolIdToFileIds.set(symbol.id, symbolIdToFileIds);\n // update re-exports\n for (const exportFrom of symbol.exportFrom) {\n const exportSelector = [exportFrom];\n const exportFile = this.files.reference(exportSelector);\n if (exportFile.id !== file.id) {\n exportFile.symbols.exports.push(symbol.id);\n }\n }\n }\n for (const file of this.files.referenced()) {\n if (!file.selector) continue;\n if (file.selector[0] === externalSourceSymbol) {\n const filePath = file.selector[1];\n if (!filePath) {\n this.files.register({\n external: true,\n selector: file.selector,\n });\n continue;\n }\n const extension = path.extname(filePath);\n if (!extension) {\n this.files.register({\n external: true,\n path: filePath,\n selector: file.selector,\n });\n continue;\n }\n this.files.register({\n extension,\n external: true,\n path: filePath,\n selector: file.selector,\n });\n continue;\n }\n const dirs = file.selector.slice(0, -1);\n let name = file.selector[file.selector.length - 1]!;\n name = this.fileName?.(name) || name;\n this.files.register({\n extension,\n name,\n path: path.resolve(this.root, ...dirs, `${name}${extension}`),\n selector: file.selector,\n });\n }\n\n // TODO: track symbol dependencies and inject imports into files\n // based on symbol references so the render step can just render\n }\n\n render(meta?: IProjectRenderMeta): ReadonlyArray<IOutput> {\n this.prepareFiles();\n const files: Map<number, IOutput> = new Map();\n for (const file of this.files.registered()) {\n if (file.external || !file.path) continue;\n const renderer = this.getRenderer(file);\n if (!renderer) continue;\n files.set(file.id, {\n content: renderer.renderSymbols(file, this, meta),\n path: file.path,\n });\n }\n for (const [fileId, value] of files.entries()) {\n const file = this.files.get(fileId)!;\n const renderer = this.getRenderer(file)!;\n const content = renderer.renderFile(value.content, file, this, meta);\n if (content) {\n files.set(file.id, { ...value, content });\n } else {\n files.delete(file.id);\n }\n }\n return Array.from(files.values());\n }\n\n symbolIdToFiles(symbolId: number): ReadonlyArray<IFileOut> {\n const fileIds = this.symbolIdToFileIds.get(symbolId);\n return Array.from(fileIds ?? []).map((fileId) => this.files.get(fileId)!);\n }\n\n private symbolToFileSelector(symbol: ISymbolOut): ISelector {\n if (symbol.external) {\n return [externalSourceSymbol, symbol.external];\n }\n const filePath = symbol.getFilePath?.(symbol);\n if (filePath) {\n return filePath.split('/');\n }\n return [this.defaultFileName];\n }\n}\n"],"mappings":"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"}
package/dist/index.d.cts CHANGED
@@ -1,3 +1,4 @@
1
+ //#region src/bimap/types.d.ts
1
2
  /**
2
3
  * Bi-directional map interface.
3
4
  *
@@ -72,7 +73,8 @@ interface IBiMap<Key, Value> {
72
73
  */
73
74
  [Symbol.iterator](): IterableIterator<[Key, Value]>;
74
75
  }
75
-
76
+ //#endregion
77
+ //#region src/bindings/types.d.ts
76
78
  interface IBinding {
77
79
  /**
78
80
  * Optional aliasing map for named symbols.
@@ -132,7 +134,8 @@ interface IBinding {
132
134
  */
133
135
  typeNamespaceBinding?: boolean;
134
136
  }
135
-
137
+ //#endregion
138
+ //#region src/selectors/types.d.ts
136
139
  /**
137
140
  * Selector array used to reference resources. We don't enforce
138
141
  * uniqueness, but in practice it's desirable.
@@ -140,7 +143,8 @@ interface IBinding {
140
143
  * @example ["zod", "#/components/schemas/Foo"]
141
144
  */
142
145
  type ISelector = ReadonlyArray<string>;
143
-
146
+ //#endregion
147
+ //#region src/files/types.d.ts
144
148
  interface IFileIn {
145
149
  /**
146
150
  * File extension, if any.
@@ -179,7 +183,6 @@ interface IFileIn {
179
183
  */
180
184
  readonly selector?: ISelector;
181
185
  }
182
-
183
186
  interface IFileOut extends IFileIn {
184
187
  /**
185
188
  * Unique file ID.
@@ -207,7 +210,6 @@ interface IFileOut extends IFileIn {
207
210
  imports: Array<number>;
208
211
  };
209
212
  }
210
-
211
213
  interface IFileRegistry {
212
214
  /**
213
215
  * Get a file by its ID.
@@ -251,7 +253,8 @@ interface IFileRegistry {
251
253
  */
252
254
  registered(): IterableIterator<IFileOut>;
253
255
  }
254
-
256
+ //#endregion
257
+ //#region src/extensions/types.d.ts
255
258
  /**
256
259
  * Arbitrary metadata passed to the project's render function.
257
260
  *
@@ -260,7 +263,6 @@ interface IFileRegistry {
260
263
  interface IProjectRenderMeta {
261
264
  [key: string]: unknown;
262
265
  }
263
-
264
266
  /**
265
267
  * Additional metadata about the symbol.
266
268
  *
@@ -269,7 +271,8 @@ interface IProjectRenderMeta {
269
271
  interface ISymbolMeta {
270
272
  [key: string]: unknown;
271
273
  }
272
-
274
+ //#endregion
275
+ //#region src/symbols/types.d.ts
273
276
  interface ISymbolIn {
274
277
  /**
275
278
  * Array of file names (without extensions) from which this symbol is re-exported.
@@ -336,7 +339,6 @@ interface ISymbolIn {
336
339
  */
337
340
  readonly selector?: ISelector;
338
341
  }
339
-
340
342
  interface ISymbolOut extends ISymbolIn {
341
343
  /**
342
344
  * Array of file names (without extensions) from which this symbol is re-exported.
@@ -353,7 +355,6 @@ interface ISymbolOut extends ISymbolIn {
353
355
  */
354
356
  readonly placeholder: string;
355
357
  }
356
-
357
358
  interface ISymbolRegistry {
358
359
  /**
359
360
  * Get a symbol by its ID.
@@ -413,15 +414,22 @@ interface ISymbolRegistry {
413
414
  */
414
415
  setValue(symbolId: number, value: unknown): Map<number, unknown>;
415
416
  }
416
-
417
- declare const createBinding: ({ file, modulePath, symbol, symbolFile, }: {
418
- file: IFileOut;
419
- modulePath: string;
420
- symbol: ISymbolOut;
421
- symbolFile: IFileOut;
417
+ //#endregion
418
+ //#region src/bindings/utils.d.ts
419
+ declare const createBinding: ({
420
+ file,
421
+ modulePath,
422
+ symbol,
423
+ symbolFile
424
+ }: {
425
+ file: IFileOut;
426
+ modulePath: string;
427
+ symbol: ISymbolOut;
428
+ symbolFile: IFileOut;
422
429
  }) => IBinding;
423
430
  declare const mergeBindings: (target: IBinding, source: IBinding) => void;
424
-
431
+ //#endregion
432
+ //#region src/output/types.d.ts
425
433
  interface IOutput {
426
434
  /**
427
435
  * The main content of the file to output.
@@ -438,22 +446,24 @@ interface IOutput {
438
446
  */
439
447
  path: string;
440
448
  }
441
-
449
+ //#endregion
450
+ //#region src/files/registry.d.ts
442
451
  declare class FileRegistry implements IFileRegistry {
443
- private _id;
444
- private referenceOrder;
445
- private registerOrder;
446
- private selectorToId;
447
- private values;
448
- get(fileIdOrSelector: number | ISelector): IFileOut | undefined;
449
- get id(): number;
450
- private idOrSelector;
451
- reference(fileIdOrSelector: number | ISelector): IFileOut;
452
- referenced(): IterableIterator<IFileOut>;
453
- register(file: IFileIn): IFileOut;
454
- registered(): IterableIterator<IFileOut>;
452
+ private _id;
453
+ private referenceOrder;
454
+ private registerOrder;
455
+ private selectorToId;
456
+ private values;
457
+ get(fileIdOrSelector: number | ISelector): IFileOut | undefined;
458
+ get id(): number;
459
+ private idOrSelector;
460
+ reference(fileIdOrSelector: number | ISelector): IFileOut;
461
+ referenced(): IterableIterator<IFileOut>;
462
+ register(file: IFileIn): IFileOut;
463
+ registered(): IterableIterator<IFileOut>;
455
464
  }
456
-
465
+ //#endregion
466
+ //#region src/project/types.d.ts
457
467
  /**
458
468
  * Represents a code generation project consisting of multiple codegen files.
459
469
  * Manages imports, symbols, and output generation across the project.
@@ -517,7 +527,8 @@ interface IProject {
517
527
  */
518
528
  readonly symbols: ISymbolRegistry;
519
529
  }
520
-
530
+ //#endregion
531
+ //#region src/renderer/types.d.ts
521
532
  interface IRenderer {
522
533
  /**
523
534
  * Renders content with replaced symbols.
@@ -527,12 +538,7 @@ interface IRenderer {
527
538
  * @param project The parent project the file belongs to.
528
539
  * @returns Rendered content.
529
540
  */
530
- renderFile(
531
- content: string,
532
- file: IFile,
533
- project: IProject,
534
- meta?: IProjectRenderMeta,
535
- ): string;
541
+ renderFile(content: string, file: IFile, project: IProject, meta?: IProjectRenderMeta): string;
536
542
  /**
537
543
  * Returns printable data containing symbols and exports.
538
544
  *
@@ -541,46 +547,50 @@ interface IRenderer {
541
547
  * @param meta Arbitrary metadata.
542
548
  * @returns Printable string containing symbols and exports.
543
549
  */
544
- renderSymbols(
545
- file: IFileOut,
546
- project: IProject,
547
- meta?: IProjectRenderMeta,
548
- ): string;
550
+ renderSymbols(file: IFileOut, project: IProject, meta?: IProjectRenderMeta): string;
549
551
  }
550
-
552
+ //#endregion
553
+ //#region src/symbols/registry.d.ts
551
554
  declare class SymbolRegistry implements ISymbolRegistry {
552
- private _id;
553
- private nodes;
554
- private registerOrder;
555
- private selectorToId;
556
- private values;
557
- get(symbolIdOrSelector: number | ISelector): ISymbolOut | undefined;
558
- getValue(symbolId: number): unknown;
559
- hasValue(symbolId: number): boolean;
560
- get id(): number;
561
- private idOrSelector;
562
- reference(symbolIdOrSelector: number | ISelector): ISymbolOut;
563
- register(symbol: ISymbolIn): ISymbolOut;
564
- registered(): IterableIterator<ISymbolOut>;
565
- setValue(symbolId: number, value: unknown): Map<number, unknown>;
555
+ private _id;
556
+ private nodes;
557
+ private registerOrder;
558
+ private selectorToId;
559
+ private values;
560
+ get(symbolIdOrSelector: number | ISelector): ISymbolOut | undefined;
561
+ getValue(symbolId: number): unknown;
562
+ hasValue(symbolId: number): boolean;
563
+ get id(): number;
564
+ private idOrSelector;
565
+ reference(symbolIdOrSelector: number | ISelector): ISymbolOut;
566
+ register(symbol: ISymbolIn): ISymbolOut;
567
+ registered(): IterableIterator<ISymbolOut>;
568
+ setValue(symbolId: number, value: unknown): Map<number, unknown>;
566
569
  }
567
-
570
+ //#endregion
571
+ //#region src/project/project.d.ts
568
572
  declare class Project implements IProject {
569
- private symbolIdToFileIds;
570
- readonly defaultFileName: string;
571
- readonly files: FileRegistry;
572
- readonly fileName?: (name: string) => string;
573
- readonly renderers: Record<string, IRenderer>;
574
- readonly root: string;
575
- readonly symbols: SymbolRegistry;
576
- constructor({ defaultFileName, fileName, renderers, root, }: Pick<IProject, 'defaultFileName' | 'fileName' | 'renderers' | 'root'>);
577
- private getRenderer;
578
- private prepareFiles;
579
- render(meta?: IProjectRenderMeta): ReadonlyArray<IOutput>;
580
- symbolIdToFiles(symbolId: number): ReadonlyArray<IFileOut>;
581
- private symbolToFileSelector;
573
+ private symbolIdToFileIds;
574
+ readonly defaultFileName: string;
575
+ readonly files: FileRegistry;
576
+ readonly fileName?: (name: string) => string;
577
+ readonly renderers: Record<string, IRenderer>;
578
+ readonly root: string;
579
+ readonly symbols: SymbolRegistry;
580
+ constructor({
581
+ defaultFileName,
582
+ fileName,
583
+ renderers,
584
+ root
585
+ }: Pick<IProject, 'defaultFileName' | 'fileName' | 'renderers' | 'root'>);
586
+ private getRenderer;
587
+ private prepareFiles;
588
+ render(meta?: IProjectRenderMeta): ReadonlyArray<IOutput>;
589
+ symbolIdToFiles(symbolId: number): ReadonlyArray<IFileOut>;
590
+ private symbolToFileSelector;
582
591
  }
583
-
592
+ //#endregion
593
+ //#region src/renderer/utils.d.ts
584
594
  /**
585
595
  *
586
596
  * @param source The source string to replace.
@@ -588,5 +598,6 @@ declare class Project implements IProject {
588
598
  * @returns The replaced source string.
589
599
  */
590
600
  declare const renderIds: (source: string, replacerFn: (symbolId: number) => string | undefined) => string;
591
-
601
+ //#endregion
592
602
  export { type IBiMap as BiMap, type IBinding as Binding, type IFileOut as File, type IFileIn as FileIn, type IProject, type IOutput as Output, Project, type IProjectRenderMeta as ProjectRenderMeta, type IRenderer as Renderer, type ISelector as Selector, type ISymbolOut as Symbol, type ISymbolIn as SymbolIn, type ISymbolMeta as SymbolMeta, createBinding, mergeBindings, renderIds };
603
+ //# sourceMappingURL=index.d.cts.map
package/dist/index.d.ts CHANGED
@@ -1,3 +1,4 @@
1
+ //#region src/bimap/types.d.ts
1
2
  /**
2
3
  * Bi-directional map interface.
3
4
  *
@@ -72,7 +73,8 @@ interface IBiMap<Key, Value> {
72
73
  */
73
74
  [Symbol.iterator](): IterableIterator<[Key, Value]>;
74
75
  }
75
-
76
+ //#endregion
77
+ //#region src/bindings/types.d.ts
76
78
  interface IBinding {
77
79
  /**
78
80
  * Optional aliasing map for named symbols.
@@ -132,7 +134,8 @@ interface IBinding {
132
134
  */
133
135
  typeNamespaceBinding?: boolean;
134
136
  }
135
-
137
+ //#endregion
138
+ //#region src/selectors/types.d.ts
136
139
  /**
137
140
  * Selector array used to reference resources. We don't enforce
138
141
  * uniqueness, but in practice it's desirable.
@@ -140,7 +143,8 @@ interface IBinding {
140
143
  * @example ["zod", "#/components/schemas/Foo"]
141
144
  */
142
145
  type ISelector = ReadonlyArray<string>;
143
-
146
+ //#endregion
147
+ //#region src/files/types.d.ts
144
148
  interface IFileIn {
145
149
  /**
146
150
  * File extension, if any.
@@ -179,7 +183,6 @@ interface IFileIn {
179
183
  */
180
184
  readonly selector?: ISelector;
181
185
  }
182
-
183
186
  interface IFileOut extends IFileIn {
184
187
  /**
185
188
  * Unique file ID.
@@ -207,7 +210,6 @@ interface IFileOut extends IFileIn {
207
210
  imports: Array<number>;
208
211
  };
209
212
  }
210
-
211
213
  interface IFileRegistry {
212
214
  /**
213
215
  * Get a file by its ID.
@@ -251,7 +253,8 @@ interface IFileRegistry {
251
253
  */
252
254
  registered(): IterableIterator<IFileOut>;
253
255
  }
254
-
256
+ //#endregion
257
+ //#region src/extensions/types.d.ts
255
258
  /**
256
259
  * Arbitrary metadata passed to the project's render function.
257
260
  *
@@ -260,7 +263,6 @@ interface IFileRegistry {
260
263
  interface IProjectRenderMeta {
261
264
  [key: string]: unknown;
262
265
  }
263
-
264
266
  /**
265
267
  * Additional metadata about the symbol.
266
268
  *
@@ -269,7 +271,8 @@ interface IProjectRenderMeta {
269
271
  interface ISymbolMeta {
270
272
  [key: string]: unknown;
271
273
  }
272
-
274
+ //#endregion
275
+ //#region src/symbols/types.d.ts
273
276
  interface ISymbolIn {
274
277
  /**
275
278
  * Array of file names (without extensions) from which this symbol is re-exported.
@@ -336,7 +339,6 @@ interface ISymbolIn {
336
339
  */
337
340
  readonly selector?: ISelector;
338
341
  }
339
-
340
342
  interface ISymbolOut extends ISymbolIn {
341
343
  /**
342
344
  * Array of file names (without extensions) from which this symbol is re-exported.
@@ -353,7 +355,6 @@ interface ISymbolOut extends ISymbolIn {
353
355
  */
354
356
  readonly placeholder: string;
355
357
  }
356
-
357
358
  interface ISymbolRegistry {
358
359
  /**
359
360
  * Get a symbol by its ID.
@@ -413,15 +414,22 @@ interface ISymbolRegistry {
413
414
  */
414
415
  setValue(symbolId: number, value: unknown): Map<number, unknown>;
415
416
  }
416
-
417
- declare const createBinding: ({ file, modulePath, symbol, symbolFile, }: {
418
- file: IFileOut;
419
- modulePath: string;
420
- symbol: ISymbolOut;
421
- symbolFile: IFileOut;
417
+ //#endregion
418
+ //#region src/bindings/utils.d.ts
419
+ declare const createBinding: ({
420
+ file,
421
+ modulePath,
422
+ symbol,
423
+ symbolFile
424
+ }: {
425
+ file: IFileOut;
426
+ modulePath: string;
427
+ symbol: ISymbolOut;
428
+ symbolFile: IFileOut;
422
429
  }) => IBinding;
423
430
  declare const mergeBindings: (target: IBinding, source: IBinding) => void;
424
-
431
+ //#endregion
432
+ //#region src/output/types.d.ts
425
433
  interface IOutput {
426
434
  /**
427
435
  * The main content of the file to output.
@@ -438,22 +446,24 @@ interface IOutput {
438
446
  */
439
447
  path: string;
440
448
  }
441
-
449
+ //#endregion
450
+ //#region src/files/registry.d.ts
442
451
  declare class FileRegistry implements IFileRegistry {
443
- private _id;
444
- private referenceOrder;
445
- private registerOrder;
446
- private selectorToId;
447
- private values;
448
- get(fileIdOrSelector: number | ISelector): IFileOut | undefined;
449
- get id(): number;
450
- private idOrSelector;
451
- reference(fileIdOrSelector: number | ISelector): IFileOut;
452
- referenced(): IterableIterator<IFileOut>;
453
- register(file: IFileIn): IFileOut;
454
- registered(): IterableIterator<IFileOut>;
452
+ private _id;
453
+ private referenceOrder;
454
+ private registerOrder;
455
+ private selectorToId;
456
+ private values;
457
+ get(fileIdOrSelector: number | ISelector): IFileOut | undefined;
458
+ get id(): number;
459
+ private idOrSelector;
460
+ reference(fileIdOrSelector: number | ISelector): IFileOut;
461
+ referenced(): IterableIterator<IFileOut>;
462
+ register(file: IFileIn): IFileOut;
463
+ registered(): IterableIterator<IFileOut>;
455
464
  }
456
-
465
+ //#endregion
466
+ //#region src/project/types.d.ts
457
467
  /**
458
468
  * Represents a code generation project consisting of multiple codegen files.
459
469
  * Manages imports, symbols, and output generation across the project.
@@ -517,7 +527,8 @@ interface IProject {
517
527
  */
518
528
  readonly symbols: ISymbolRegistry;
519
529
  }
520
-
530
+ //#endregion
531
+ //#region src/renderer/types.d.ts
521
532
  interface IRenderer {
522
533
  /**
523
534
  * Renders content with replaced symbols.
@@ -527,12 +538,7 @@ interface IRenderer {
527
538
  * @param project The parent project the file belongs to.
528
539
  * @returns Rendered content.
529
540
  */
530
- renderFile(
531
- content: string,
532
- file: IFile,
533
- project: IProject,
534
- meta?: IProjectRenderMeta,
535
- ): string;
541
+ renderFile(content: string, file: IFile, project: IProject, meta?: IProjectRenderMeta): string;
536
542
  /**
537
543
  * Returns printable data containing symbols and exports.
538
544
  *
@@ -541,46 +547,50 @@ interface IRenderer {
541
547
  * @param meta Arbitrary metadata.
542
548
  * @returns Printable string containing symbols and exports.
543
549
  */
544
- renderSymbols(
545
- file: IFileOut,
546
- project: IProject,
547
- meta?: IProjectRenderMeta,
548
- ): string;
550
+ renderSymbols(file: IFileOut, project: IProject, meta?: IProjectRenderMeta): string;
549
551
  }
550
-
552
+ //#endregion
553
+ //#region src/symbols/registry.d.ts
551
554
  declare class SymbolRegistry implements ISymbolRegistry {
552
- private _id;
553
- private nodes;
554
- private registerOrder;
555
- private selectorToId;
556
- private values;
557
- get(symbolIdOrSelector: number | ISelector): ISymbolOut | undefined;
558
- getValue(symbolId: number): unknown;
559
- hasValue(symbolId: number): boolean;
560
- get id(): number;
561
- private idOrSelector;
562
- reference(symbolIdOrSelector: number | ISelector): ISymbolOut;
563
- register(symbol: ISymbolIn): ISymbolOut;
564
- registered(): IterableIterator<ISymbolOut>;
565
- setValue(symbolId: number, value: unknown): Map<number, unknown>;
555
+ private _id;
556
+ private nodes;
557
+ private registerOrder;
558
+ private selectorToId;
559
+ private values;
560
+ get(symbolIdOrSelector: number | ISelector): ISymbolOut | undefined;
561
+ getValue(symbolId: number): unknown;
562
+ hasValue(symbolId: number): boolean;
563
+ get id(): number;
564
+ private idOrSelector;
565
+ reference(symbolIdOrSelector: number | ISelector): ISymbolOut;
566
+ register(symbol: ISymbolIn): ISymbolOut;
567
+ registered(): IterableIterator<ISymbolOut>;
568
+ setValue(symbolId: number, value: unknown): Map<number, unknown>;
566
569
  }
567
-
570
+ //#endregion
571
+ //#region src/project/project.d.ts
568
572
  declare class Project implements IProject {
569
- private symbolIdToFileIds;
570
- readonly defaultFileName: string;
571
- readonly files: FileRegistry;
572
- readonly fileName?: (name: string) => string;
573
- readonly renderers: Record<string, IRenderer>;
574
- readonly root: string;
575
- readonly symbols: SymbolRegistry;
576
- constructor({ defaultFileName, fileName, renderers, root, }: Pick<IProject, 'defaultFileName' | 'fileName' | 'renderers' | 'root'>);
577
- private getRenderer;
578
- private prepareFiles;
579
- render(meta?: IProjectRenderMeta): ReadonlyArray<IOutput>;
580
- symbolIdToFiles(symbolId: number): ReadonlyArray<IFileOut>;
581
- private symbolToFileSelector;
573
+ private symbolIdToFileIds;
574
+ readonly defaultFileName: string;
575
+ readonly files: FileRegistry;
576
+ readonly fileName?: (name: string) => string;
577
+ readonly renderers: Record<string, IRenderer>;
578
+ readonly root: string;
579
+ readonly symbols: SymbolRegistry;
580
+ constructor({
581
+ defaultFileName,
582
+ fileName,
583
+ renderers,
584
+ root
585
+ }: Pick<IProject, 'defaultFileName' | 'fileName' | 'renderers' | 'root'>);
586
+ private getRenderer;
587
+ private prepareFiles;
588
+ render(meta?: IProjectRenderMeta): ReadonlyArray<IOutput>;
589
+ symbolIdToFiles(symbolId: number): ReadonlyArray<IFileOut>;
590
+ private symbolToFileSelector;
582
591
  }
583
-
592
+ //#endregion
593
+ //#region src/renderer/utils.d.ts
584
594
  /**
585
595
  *
586
596
  * @param source The source string to replace.
@@ -588,5 +598,6 @@ declare class Project implements IProject {
588
598
  * @returns The replaced source string.
589
599
  */
590
600
  declare const renderIds: (source: string, replacerFn: (symbolId: number) => string | undefined) => string;
591
-
601
+ //#endregion
592
602
  export { type IBiMap as BiMap, type IBinding as Binding, type IFileOut as File, type IFileIn as FileIn, type IProject, type IOutput as Output, Project, type IProjectRenderMeta as ProjectRenderMeta, type IRenderer as Renderer, type ISelector as Selector, type ISymbolOut as Symbol, type ISymbolIn as SymbolIn, type ISymbolMeta as SymbolMeta, createBinding, mergeBindings, renderIds };
603
+ //# sourceMappingURL=index.d.ts.map
package/dist/index.js CHANGED
@@ -1,3 +1,2 @@
1
- import {createRequire}from'module';import h from'node:path';createRequire(import.meta.url);
2
- var I=({file:l,modulePath:e,symbol:t,symbolFile:r})=>{let i=[],s=[],n={aliases:{},from:e};if(t.meta?.importKind&&(t.meta.importKind==="default"?(n.defaultBinding=t.placeholder,t.meta.kind==="type"&&(n.typeDefaultBinding=true)):t.meta.importKind==="namespace"&&(n.namespaceBinding=t.placeholder,t.meta.kind==="type"&&(n.typeNamespaceBinding=true))),t.meta?.importKind==="named"||!i.length&&!n.defaultBinding&&!n.namespaceBinding){let o=t.placeholder,d=l.resolvedNames.get(t.id);if(d){let m=r.resolvedNames.get(t.id);m?m!==d&&(o=m,n.aliases[o]=d):t.name&&d!==t.name&&(o=t.name,n.aliases[o]=t.placeholder);}i.push(o),t.meta?.kind==="type"&&s.push(o);}for(let o of s)i.includes(o)||i.push(o);return n.names=i,n.typeNames=s,n},g=(l,e)=>{l.aliases={...l.aliases,...e.aliases},e.defaultBinding!==void 0&&(l.defaultBinding=e.defaultBinding),l.names=[...new Set([...l.names??[],...e.names??[]])],e.namespaceBinding!==void 0&&(l.namespaceBinding=e.namespaceBinding),e.typeDefaultBinding!==void 0&&(l.typeDefaultBinding=e.typeDefaultBinding),l.typeNames=[...new Set([...l.typeNames??[],...e.typeNames??[]])],e.typeNamespaceBinding!==void 0&&(l.typeNamespaceBinding=e.typeNamespaceBinding);};var a=class{map=new Map;reverse=new Map;delete(e){let t=this.map.get(e);return t!==void 0&&this.reverse.delete(t),this.map.delete(e)}deleteValue(e){let t=this.reverse.get(e);return t!==void 0&&this.map.delete(t),this.reverse.delete(e)}entries(){return this.map.entries()}get(e){return this.map.get(e)}getKey(e){return this.reverse.get(e)}hasKey(e){return this.map.has(e)}hasValue(e){return this.reverse.has(e)}keys(){return this.map.keys()}set(e,t){let r=this.map.get(e);r!==void 0&&r!==t&&this.reverse.delete(r);let i=this.reverse.get(t);return i!==void 0&&i!==e&&this.map.delete(i),this.map.set(e,t),this.reverse.set(t,e),this}get size(){return this.map.size}values(){return this.map.values()}[Symbol.iterator](){return this.map[Symbol.iterator]()}};var p=class{_id=0;referenceOrder=new Set;registerOrder=new Set;selectorToId=new Map;values=new Map;get(e){let t=this.idOrSelector(e);if(t.id!==void 0)return this.values.get(t.id);let r=t.selector!==void 0?JSON.stringify(t.selector):void 0;if(r){let i=this.selectorToId.get(r);if(i!==void 0)return this.values.get(i)}}get id(){return this._id++}idOrSelector(e){return typeof e=="number"?{id:e}:{selector:e}}reference(e){let t=this.idOrSelector(e);return this.register(t)}*referenced(){for(let e of this.referenceOrder.values())yield this.values.get(e);}register(e){if(e.id!==void 0){let n=this.values.get(e.id);if(!n)throw new Error(`File with ID ${e.id} not found. To register a new file, leave the ID undefined.`);return n}let t=Object.keys(e).some(n=>!["id","selector"].includes(n)),r,i=e.selector!==void 0?JSON.stringify(e.selector):void 0;if(i){let n=this.selectorToId.get(i);if(n!==void 0){if(r=this.values.get(n),!r)throw new Error(`File with ID ${n} not found. The selector ${i} matched an ID, but there was no result. This is likely an issue with the application logic.`);if(!t)return r}}let s=r?.id!==void 0?r.id:this.id;return r={...r,...e,id:s,resolvedNames:r?.resolvedNames??new a,symbols:r?.symbols??{body:[],exports:[],imports:[]}},this.values.set(s,r),t?this.registerOrder.add(s):this.referenceOrder.add(s),i&&this.selectorToId.set(i,s),r}*registered(){for(let e of this.registerOrder.values())yield this.values.get(e);}};var f=l=>`_heyapi_${l}_`,b=l=>l.slice(8,-1),S=()=>new RegExp(f("\\d+"),"g"),v=(l,e)=>l.replace(S(),t=>{let r=Number.parseInt(b(t),10);return e(r)||t});var u=class{_id=0;nodes=new Map;registerOrder=new Set;selectorToId=new Map;values=new Map;get(e){let t=this.idOrSelector(e);if(t.id!==void 0)return this.values.get(t.id);let r=t.selector!==void 0?JSON.stringify(t.selector):void 0;if(r){let i=this.selectorToId.get(r);if(i!==void 0)return this.values.get(i)}}getValue(e){return this.nodes.get(e)}hasValue(e){return this.nodes.has(e)}get id(){return this._id++}idOrSelector(e){return typeof e=="number"?{id:e}:{selector:e}}reference(e){let t=this.idOrSelector(e);return this.register(t)}register(e){if(e.id!==void 0){let o=this.values.get(e.id);if(!o)throw new Error(`Symbol with ID ${e.id} not found. To register a new symbol, leave the ID undefined.`);return o}let t=Object.keys(e).some(o=>!["id","selector"].includes(o)),r,i=e.selector!==void 0?JSON.stringify(e.selector):void 0;if(i){let o=this.selectorToId.get(i);if(o!==void 0){if(r=this.values.get(o),!r)throw new Error(`Symbol with ID ${o} not found. The selector ${i} matched an ID, but there was no result. This is likely an issue with the application logic.`);if(!t)return r}}let s=r?.id!==void 0?r.id:this.id,n=r?.exportFrom?[...r.exportFrom]:[];return e.exportFrom&&n.push(...e.exportFrom),r={...r,...e,exportFrom:n,id:s,placeholder:r?.placeholder??e.placeholder??f(String(s))},this.values.set(s,r),t&&this.registerOrder.add(s),i&&this.selectorToId.set(i,s),r}*registered(){for(let e of this.registerOrder.values())yield this.values.get(e);}setValue(e,t){return this.nodes.set(e,t)}};var y="@",c=class{symbolIdToFileIds=new Map;defaultFileName;files=new p;fileName;renderers={};root;symbols=new u;constructor({defaultFileName:e,fileName:t,renderers:r,root:i}){this.defaultFileName=e??"main",this.fileName=typeof t=="string"?()=>t:t,this.renderers=r,this.root=i;}getRenderer(e){return e.extension?this.renderers[e.extension]:void 0}prepareFiles(){for(let t of this.symbols.registered()){let r=this.symbolToFileSelector(t),i=this.files.reference(r);i.symbols.body.push(t.id);let s=this.symbolIdToFileIds.get(t.id)??new Set;s.add(i.id),this.symbolIdToFileIds.set(t.id,s);for(let n of t.exportFrom){let o=[n],d=this.files.reference(o);d.id!==i.id&&d.symbols.exports.push(t.id);}}for(let t of this.files.referenced()){if(!t.selector)continue;if(t.selector[0]===y){let s=t.selector[1];if(!s){this.files.register({external:true,selector:t.selector});continue}let n=h.extname(s);if(!n){this.files.register({external:true,path:s,selector:t.selector});continue}this.files.register({extension:n,external:true,path:s,selector:t.selector});continue}let r=t.selector.slice(0,-1),i=t.selector[t.selector.length-1];i=this.fileName?.(i)||i,this.files.register({extension:".ts",name:i,path:h.resolve(this.root,...r,`${i}.ts`),selector:t.selector});}}render(e){this.prepareFiles();let t=new Map;for(let r of this.files.registered()){if(r.external||!r.path)continue;let i=this.getRenderer(r);i&&t.set(r.id,{content:i.renderSymbols(r,this,e),path:r.path});}for(let[r,i]of t.entries()){let s=this.files.get(r),o=this.getRenderer(s).renderFile(i.content,s,this,e);o?t.set(s.id,{...i,content:o}):t.delete(s.id);}return Array.from(t.values())}symbolIdToFiles(e){let t=this.symbolIdToFileIds.get(e);return Array.from(t??[]).map(r=>this.files.get(r))}symbolToFileSelector(e){if(e.external)return [y,e.external];let t=e.getFilePath?.(e);return t?t.split("/"):[this.defaultFileName]}};export{c as Project,I as createBinding,g as mergeBindings,v as renderIds};//# sourceMappingURL=index.js.map
1
+ import e from"node:path";const t=({file:e,modulePath:t,symbol:n,symbolFile:r})=>{let i=[],a=[],o={aliases:{},from:t};if(n.meta?.importKind&&(n.meta.importKind===`default`?(o.defaultBinding=n.placeholder,n.meta.kind===`type`&&(o.typeDefaultBinding=!0)):n.meta.importKind===`namespace`&&(o.namespaceBinding=n.placeholder,n.meta.kind===`type`&&(o.typeNamespaceBinding=!0))),n.meta?.importKind===`named`||!i.length&&!o.defaultBinding&&!o.namespaceBinding){let t=n.placeholder,s=e.resolvedNames.get(n.id);if(s){let e=r.resolvedNames.get(n.id);e?e!==s&&(t=e,o.aliases[t]=s):n.name&&s!==n.name&&(t=n.name,o.aliases[t]=n.placeholder)}i.push(t),n.meta?.kind===`type`&&a.push(t)}for(let e of a)i.includes(e)||i.push(e);return o.names=i,o.typeNames=a,o},n=(e,t)=>{e.aliases={...e.aliases,...t.aliases},t.defaultBinding!==void 0&&(e.defaultBinding=t.defaultBinding),e.names=[...new Set([...e.names??[],...t.names??[]])],t.namespaceBinding!==void 0&&(e.namespaceBinding=t.namespaceBinding),t.typeDefaultBinding!==void 0&&(e.typeDefaultBinding=t.typeDefaultBinding),e.typeNames=[...new Set([...e.typeNames??[],...t.typeNames??[]])],t.typeNamespaceBinding!==void 0&&(e.typeNamespaceBinding=t.typeNamespaceBinding)};var r=class{map=new Map;reverse=new Map;delete(e){let t=this.map.get(e);return t!==void 0&&this.reverse.delete(t),this.map.delete(e)}deleteValue(e){let t=this.reverse.get(e);return t!==void 0&&this.map.delete(t),this.reverse.delete(e)}entries(){return this.map.entries()}get(e){return this.map.get(e)}getKey(e){return this.reverse.get(e)}hasKey(e){return this.map.has(e)}hasValue(e){return this.reverse.has(e)}keys(){return this.map.keys()}set(e,t){let n=this.map.get(e);n!==void 0&&n!==t&&this.reverse.delete(n);let r=this.reverse.get(t);return r!==void 0&&r!==e&&this.map.delete(r),this.map.set(e,t),this.reverse.set(t,e),this}get size(){return this.map.size}values(){return this.map.values()}[Symbol.iterator](){return this.map[Symbol.iterator]()}},i=class{_id=0;referenceOrder=new Set;registerOrder=new Set;selectorToId=new Map;values=new Map;get(e){let t=this.idOrSelector(e);if(t.id!==void 0)return this.values.get(t.id);let n=t.selector===void 0?void 0:JSON.stringify(t.selector);if(n){let e=this.selectorToId.get(n);if(e!==void 0)return this.values.get(e)}}get id(){return this._id++}idOrSelector(e){return typeof e==`number`?{id:e}:{selector:e}}reference(e){let t=this.idOrSelector(e);return this.register(t)}*referenced(){for(let e of this.referenceOrder.values())yield this.values.get(e)}register(e){if(e.id!==void 0){let t=this.values.get(e.id);if(!t)throw Error(`File with ID ${e.id} not found. To register a new file, leave the ID undefined.`);return t}let t=Object.keys(e).some(e=>![`id`,`selector`].includes(e)),n,i=e.selector===void 0?void 0:JSON.stringify(e.selector);if(i){let e=this.selectorToId.get(i);if(e!==void 0){if(n=this.values.get(e),!n)throw Error(`File with ID ${e} not found. The selector ${i} matched an ID, but there was no result. This is likely an issue with the application logic.`);if(!t)return n}}let a=n?.id===void 0?this.id:n.id;return n={...n,...e,id:a,resolvedNames:n?.resolvedNames??new r,symbols:n?.symbols??{body:[],exports:[],imports:[]}},this.values.set(a,n),t?this.registerOrder.add(a):this.referenceOrder.add(a),i&&this.selectorToId.set(i,a),n}*registered(){for(let e of this.registerOrder.values())yield this.values.get(e)}};const a=e=>`_heyapi_${e}_`,o=e=>e.slice(8,-1),s=()=>new RegExp(a(`\\d+`),`g`),c=(e,t)=>e.replace(s(),e=>t(Number.parseInt(o(e),10))||e);var l=class{_id=0;nodes=new Map;registerOrder=new Set;selectorToId=new Map;values=new Map;get(e){let t=this.idOrSelector(e);if(t.id!==void 0)return this.values.get(t.id);let n=t.selector===void 0?void 0:JSON.stringify(t.selector);if(n){let e=this.selectorToId.get(n);if(e!==void 0)return this.values.get(e)}}getValue(e){return this.nodes.get(e)}hasValue(e){return this.nodes.has(e)}get id(){return this._id++}idOrSelector(e){return typeof e==`number`?{id:e}:{selector:e}}reference(e){let t=this.idOrSelector(e);return this.register(t)}register(e){if(e.id!==void 0){let t=this.values.get(e.id);if(!t)throw Error(`Symbol with ID ${e.id} not found. To register a new symbol, leave the ID undefined.`);return t}let t=Object.keys(e).some(e=>![`id`,`selector`].includes(e)),n,r=e.selector===void 0?void 0:JSON.stringify(e.selector);if(r){let e=this.selectorToId.get(r);if(e!==void 0){if(n=this.values.get(e),!n)throw Error(`Symbol with ID ${e} not found. The selector ${r} matched an ID, but there was no result. This is likely an issue with the application logic.`);if(!t)return n}}let i=n?.id===void 0?this.id:n.id,o=n?.exportFrom?[...n.exportFrom]:[];return e.exportFrom&&o.push(...e.exportFrom),n={...n,...e,exportFrom:o,id:i,placeholder:n?.placeholder??e.placeholder??a(String(i))},this.values.set(i,n),t&&this.registerOrder.add(i),r&&this.selectorToId.set(r,i),n}*registered(){for(let e of this.registerOrder.values())yield this.values.get(e)}setValue(e,t){return this.nodes.set(e,t)}},u=class{symbolIdToFileIds=new Map;defaultFileName;files=new i;fileName;renderers={};root;symbols=new l;constructor({defaultFileName:e,fileName:t,renderers:n,root:r}){this.defaultFileName=e??`main`,this.fileName=typeof t==`string`?()=>t:t,this.renderers=n,this.root=r}getRenderer(e){return e.extension?this.renderers[e.extension]:void 0}prepareFiles(){for(let e of this.symbols.registered()){let t=this.symbolToFileSelector(e),n=this.files.reference(t);n.symbols.body.push(e.id);let r=this.symbolIdToFileIds.get(e.id)??new Set;r.add(n.id),this.symbolIdToFileIds.set(e.id,r);for(let t of e.exportFrom){let r=[t],i=this.files.reference(r);i.id!==n.id&&i.symbols.exports.push(e.id)}}for(let t of this.files.referenced()){if(!t.selector)continue;if(t.selector[0]===`@`){let n=t.selector[1];if(!n){this.files.register({external:!0,selector:t.selector});continue}let r=e.extname(n);if(!r){this.files.register({external:!0,path:n,selector:t.selector});continue}this.files.register({extension:r,external:!0,path:n,selector:t.selector});continue}let n=t.selector.slice(0,-1),r=t.selector[t.selector.length-1];r=this.fileName?.(r)||r,this.files.register({extension:`.ts`,name:r,path:e.resolve(this.root,...n,`${r}.ts`),selector:t.selector})}}render(e){this.prepareFiles();let t=new Map;for(let n of this.files.registered()){if(n.external||!n.path)continue;let r=this.getRenderer(n);r&&t.set(n.id,{content:r.renderSymbols(n,this,e),path:n.path})}for(let[n,r]of t.entries()){let i=this.files.get(n),a=this.getRenderer(i).renderFile(r.content,i,this,e);a?t.set(i.id,{...r,content:a}):t.delete(i.id)}return Array.from(t.values())}symbolIdToFiles(e){let t=this.symbolIdToFileIds.get(e);return Array.from(t??[]).map(e=>this.files.get(e))}symbolToFileSelector(e){if(e.external)return[`@`,e.external];let t=e.getFilePath?.(e);return t?t.split(`/`):[this.defaultFileName]}};export{u as Project,t as createBinding,n as mergeBindings,c as renderIds};
3
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/bindings/utils.ts","../src/bimap/bimap.ts","../src/files/registry.ts","../src/renderer/utils.ts","../src/symbols/registry.ts","../src/project/project.ts"],"names":["createBinding","file","modulePath","symbol","symbolFile","names","typeNames","binding","name","fileResolvedName","symbolFileResolvedName","typeName","mergeBindings","target","source","BiMap","key","value","oldValue","oldKey","FileRegistry","fileIdOrSelector","selector","id","symbolIdOrSelector","result","hasOtherKeys","wrapId","symbolId","unwrapId","wrappedId","createPlaceholderRegExp","renderIds","replacerFn","match","SymbolRegistry","exportFrom","externalSourceSymbol","Project","defaultFileName","fileName","renderers","root","symbolIdToFileIds","exportSelector","exportFile","filePath","extension","path","dirs","meta","files","renderer","fileId","content","fileIds"],"mappings":"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","file":"index.js","sourcesContent":["import type { IFileOut } from '../files/types';\nimport type { ISymbolOut } from '../symbols/types';\nimport type { IBinding } from './types';\n\nexport const createBinding = ({\n file,\n modulePath,\n symbol,\n symbolFile,\n}: {\n file: IFileOut;\n modulePath: string;\n symbol: ISymbolOut;\n symbolFile: IFileOut;\n}): IBinding => {\n const names: Array<string> = [];\n const typeNames: Array<string> = [];\n const binding: IBinding & Pick<Required<IBinding>, 'aliases' | 'from'> = {\n aliases: {},\n from: modulePath,\n };\n if (symbol.meta?.importKind) {\n if (symbol.meta.importKind === 'default') {\n binding.defaultBinding = symbol.placeholder;\n if (symbol.meta.kind === 'type') {\n binding.typeDefaultBinding = true;\n }\n } else if (symbol.meta.importKind === 'namespace') {\n binding.namespaceBinding = symbol.placeholder;\n if (symbol.meta.kind === 'type') {\n binding.typeNamespaceBinding = true;\n }\n }\n }\n // default to named binding\n if (\n symbol.meta?.importKind === 'named' ||\n (!names.length && !binding.defaultBinding && !binding.namespaceBinding)\n ) {\n let name = symbol.placeholder;\n const fileResolvedName = file.resolvedNames.get(symbol.id);\n if (fileResolvedName) {\n const symbolFileResolvedName = symbolFile.resolvedNames.get(symbol.id);\n if (symbolFileResolvedName) {\n if (symbolFileResolvedName !== fileResolvedName) {\n name = symbolFileResolvedName;\n binding.aliases[name] = fileResolvedName;\n }\n } else if (symbol.name && fileResolvedName !== symbol.name) {\n name = symbol.name;\n binding.aliases[name] = symbol.placeholder;\n }\n }\n names.push(name);\n if (symbol.meta?.kind === 'type') {\n typeNames.push(name);\n }\n }\n // cast type names to names to allow for cleaner API,\n // otherwise users would have to define the same values twice\n for (const typeName of typeNames) {\n if (!names.includes(typeName)) {\n names.push(typeName);\n }\n }\n binding.names = names;\n binding.typeNames = typeNames;\n return binding;\n};\n\nexport const mergeBindings = (target: IBinding, source: IBinding): void => {\n target.aliases = { ...target.aliases, ...source.aliases };\n if (source.defaultBinding !== undefined) {\n target.defaultBinding = source.defaultBinding;\n }\n target.names = [\n ...new Set([...(target.names ?? []), ...(source.names ?? [])]),\n ];\n if (source.namespaceBinding !== undefined) {\n target.namespaceBinding = source.namespaceBinding;\n }\n if (source.typeDefaultBinding !== undefined) {\n target.typeDefaultBinding = source.typeDefaultBinding;\n }\n target.typeNames = [\n ...new Set([...(target.typeNames ?? []), ...(source.typeNames ?? [])]),\n ];\n if (source.typeNamespaceBinding !== undefined) {\n target.typeNamespaceBinding = source.typeNamespaceBinding;\n }\n};\n","import type { IBiMap } from './types';\n\nexport class BiMap<Key, Value> implements IBiMap<Key, Value> {\n private map = new Map<Key, Value>();\n private reverse = new Map<Value, Key>();\n\n delete(key: Key): boolean {\n const value = this.map.get(key);\n if (value !== undefined) {\n this.reverse.delete(value);\n }\n return this.map.delete(key);\n }\n\n deleteValue(value: Value): boolean {\n const key = this.reverse.get(value);\n if (key !== undefined) {\n this.map.delete(key);\n }\n return this.reverse.delete(value);\n }\n\n entries(): IterableIterator<[Key, Value]> {\n return this.map.entries();\n }\n\n get(key: Key): Value | undefined {\n return this.map.get(key);\n }\n\n getKey(value: Value): Key | undefined {\n return this.reverse.get(value);\n }\n\n hasKey(key: Key): boolean {\n return this.map.has(key);\n }\n\n hasValue(value: Value): boolean {\n return this.reverse.has(value);\n }\n\n keys(): IterableIterator<Key> {\n return this.map.keys();\n }\n\n set(key: Key, value: Value): this {\n const oldValue = this.map.get(key);\n if (oldValue !== undefined && oldValue !== value) {\n this.reverse.delete(oldValue);\n }\n const oldKey = this.reverse.get(value);\n if (oldKey !== undefined && oldKey !== key) {\n this.map.delete(oldKey);\n }\n this.map.set(key, value);\n this.reverse.set(value, key);\n return this;\n }\n\n get size(): number {\n return this.map.size;\n }\n\n values(): IterableIterator<Value> {\n return this.map.values();\n }\n\n [Symbol.iterator](): IterableIterator<[Key, Value]> {\n return this.map[Symbol.iterator]();\n }\n}\n","import { BiMap } from '../bimap/bimap';\nimport type { ISelector } from '../selectors/types';\nimport type { IFileIn, IFileOut, IFileRegistry } from './types';\n\nexport class FileRegistry implements IFileRegistry {\n private _id: number = 0;\n private referenceOrder: Set<number> = new Set();\n private registerOrder: Set<number> = new Set();\n private selectorToId: Map<string, number> = new Map();\n private values: Map<number, IFileOut> = new Map();\n\n get(fileIdOrSelector: number | ISelector): IFileOut | undefined {\n const symbol = this.idOrSelector(fileIdOrSelector);\n\n if (symbol.id !== undefined) {\n return this.values.get(symbol.id);\n }\n\n const selector =\n symbol.selector !== undefined\n ? JSON.stringify(symbol.selector)\n : undefined;\n\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n return this.values.get(id);\n }\n }\n\n return;\n }\n\n get id(): number {\n return this._id++;\n }\n\n private idOrSelector(\n symbolIdOrSelector: number | ISelector,\n ): Pick<IFileIn, 'id' | 'selector'> {\n return typeof symbolIdOrSelector === 'number'\n ? { id: symbolIdOrSelector }\n : { selector: symbolIdOrSelector };\n }\n\n reference(fileIdOrSelector: number | ISelector): IFileOut {\n const file = this.idOrSelector(fileIdOrSelector);\n return this.register(file);\n }\n\n *referenced(): IterableIterator<IFileOut> {\n for (const id of this.referenceOrder.values()) {\n yield this.values.get(id)!;\n }\n }\n\n register(file: IFileIn): IFileOut {\n if (file.id !== undefined) {\n const result = this.values.get(file.id);\n if (!result) {\n throw new Error(\n `File with ID ${file.id} not found. To register a new file, leave the ID undefined.`,\n );\n }\n return result;\n }\n\n const hasOtherKeys = Object.keys(file).some(\n (key) => !['id', 'selector'].includes(key),\n );\n\n let result: IFileOut | undefined;\n\n const selector =\n file.selector !== undefined ? JSON.stringify(file.selector) : undefined;\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n result = this.values.get(id);\n if (!result) {\n throw new Error(\n `File with ID ${id} not found. The selector ${selector} matched an ID, but there was no result. This is likely an issue with the application logic.`,\n );\n }\n if (!hasOtherKeys) {\n return result;\n }\n }\n }\n\n const id = result?.id !== undefined ? result.id : this.id;\n result = {\n ...result,\n ...file, // clone to avoid mutation\n id,\n resolvedNames: result?.resolvedNames ?? new BiMap(),\n symbols: result?.symbols ?? {\n body: [],\n exports: [],\n imports: [],\n },\n };\n this.values.set(id, result);\n\n if (hasOtherKeys) {\n this.registerOrder.add(id);\n } else {\n this.referenceOrder.add(id);\n }\n\n if (selector) {\n this.selectorToId.set(selector, id);\n }\n\n return result;\n }\n\n *registered(): IterableIterator<IFileOut> {\n for (const id of this.registerOrder.values()) {\n yield this.values.get(id)!;\n }\n }\n}\n","/**\n * Wraps an ID in namespace to avoid collisions when replacing it.\n *\n * @param symbolId Stringified symbol ID to use.\n * @returns The wrapped placeholder ID.\n */\nexport const wrapId = (symbolId: string): string => `_heyapi_${symbolId}_`;\n\n/**\n * Unwraps an ID from namespace.\n *\n * @param wrappedId The wrapped placeholder ID.\n * @returns Stringified ID to use.\n */\nconst unwrapId = (wrappedId: string): string =>\n wrappedId.slice('_heyapi_'.length, -1);\n\n/**\n * Returns a RegExp instance to match ID placeholders.\n *\n * @returns RegExp instance to match ID placeholders.\n */\nconst createPlaceholderRegExp = (): RegExp => new RegExp(wrapId('\\\\d+'), 'g');\n\n/**\n *\n * @param source The source string to replace.\n * @param replacerFn Accepts a symbol ID, returns resolved symbol name.\n * @returns The replaced source string.\n */\nexport const renderIds = (\n source: string,\n replacerFn: (symbolId: number) => string | undefined,\n): string =>\n source.replace(createPlaceholderRegExp(), (match) => {\n const symbolId = Number.parseInt(unwrapId(match), 10);\n return replacerFn(symbolId) || match;\n });\n","import { wrapId } from '../renderer/utils';\nimport type { ISelector } from '../selectors/types';\nimport type { ISymbolIn, ISymbolOut, ISymbolRegistry } from './types';\n\nexport class SymbolRegistry implements ISymbolRegistry {\n private _id: number = 0;\n private nodes: Map<number, unknown> = new Map();\n private registerOrder: Set<number> = new Set();\n private selectorToId: Map<string, number> = new Map();\n private values: Map<number, ISymbolOut> = new Map();\n\n get(symbolIdOrSelector: number | ISelector): ISymbolOut | undefined {\n const symbol = this.idOrSelector(symbolIdOrSelector);\n\n if (symbol.id !== undefined) {\n return this.values.get(symbol.id);\n }\n\n const selector =\n symbol.selector !== undefined\n ? JSON.stringify(symbol.selector)\n : undefined;\n\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n return this.values.get(id);\n }\n }\n\n return;\n }\n\n getValue(symbolId: number): unknown {\n return this.nodes.get(symbolId);\n }\n\n hasValue(symbolId: number): boolean {\n return this.nodes.has(symbolId);\n }\n\n get id(): number {\n return this._id++;\n }\n\n private idOrSelector(\n symbolIdOrSelector: number | ISelector,\n ): Pick<ISymbolIn, 'id' | 'selector'> {\n return typeof symbolIdOrSelector === 'number'\n ? { id: symbolIdOrSelector }\n : { selector: symbolIdOrSelector };\n }\n\n reference(symbolIdOrSelector: number | ISelector): ISymbolOut {\n const symbol = this.idOrSelector(symbolIdOrSelector);\n return this.register(symbol);\n }\n\n register(symbol: ISymbolIn): ISymbolOut {\n if (symbol.id !== undefined) {\n const result = this.values.get(symbol.id);\n if (!result) {\n throw new Error(\n `Symbol with ID ${symbol.id} not found. To register a new symbol, leave the ID undefined.`,\n );\n }\n return result;\n }\n\n const hasOtherKeys = Object.keys(symbol).some(\n (key) => !['id', 'selector'].includes(key),\n );\n\n let result: ISymbolOut | undefined;\n\n const selector =\n symbol.selector !== undefined\n ? JSON.stringify(symbol.selector)\n : undefined;\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n result = this.values.get(id);\n if (!result) {\n throw new Error(\n `Symbol with ID ${id} not found. The selector ${selector} matched an ID, but there was no result. This is likely an issue with the application logic.`,\n );\n }\n if (!hasOtherKeys) {\n return result;\n }\n }\n }\n\n const id = result?.id !== undefined ? result.id : this.id;\n const exportFrom: Array<string> = result?.exportFrom\n ? [...result.exportFrom]\n : [];\n if (symbol.exportFrom) {\n exportFrom.push(...symbol.exportFrom);\n }\n result = {\n ...result,\n ...symbol, // clone to avoid mutation\n exportFrom,\n id,\n placeholder:\n result?.placeholder ?? symbol.placeholder ?? wrapId(String(id)),\n };\n this.values.set(id, result);\n\n if (hasOtherKeys) {\n this.registerOrder.add(id);\n }\n\n if (selector) {\n this.selectorToId.set(selector, id);\n }\n\n return result;\n }\n\n *registered(): IterableIterator<ISymbolOut> {\n for (const id of this.registerOrder.values()) {\n yield this.values.get(id)!;\n }\n }\n\n setValue(symbolId: number, value: unknown): Map<number, unknown> {\n return this.nodes.set(symbolId, value);\n }\n}\n","import path from 'node:path';\n\nimport type { IProjectRenderMeta } from '../extensions/types';\nimport { FileRegistry } from '../files/registry';\nimport type { IFileOut } from '../files/types';\nimport type { IOutput } from '../output/types';\nimport type { IRenderer } from '../renderer/types';\nimport type { ISelector } from '../selectors/types';\nimport { SymbolRegistry } from '../symbols/registry';\nimport type { ISymbolOut } from '../symbols/types';\nimport type { IProject } from './types';\n\nconst externalSourceSymbol = '@';\n\nexport class Project implements IProject {\n private symbolIdToFileIds: Map<number, Set<number>> = new Map();\n\n readonly defaultFileName: string;\n readonly files = new FileRegistry();\n readonly fileName?: (name: string) => string;\n readonly renderers: Record<string, IRenderer> = {};\n readonly root: string;\n readonly symbols = new SymbolRegistry();\n\n constructor({\n defaultFileName,\n fileName,\n renderers,\n root,\n }: Pick<IProject, 'defaultFileName' | 'fileName' | 'renderers' | 'root'>) {\n this.defaultFileName = defaultFileName ?? 'main';\n this.fileName = typeof fileName === 'string' ? () => fileName : fileName;\n this.renderers = renderers;\n this.root = root;\n }\n\n private getRenderer(file: IFileOut): IRenderer | undefined {\n return file.extension ? this.renderers[file.extension] : undefined;\n }\n\n private prepareFiles(): void {\n // TODO: infer extension from symbols\n const extension = '.ts';\n for (const symbol of this.symbols.registered()) {\n const selector = this.symbolToFileSelector(symbol);\n const file = this.files.reference(selector);\n file.symbols.body.push(symbol.id);\n // update symbol->files map\n const symbolIdToFileIds =\n this.symbolIdToFileIds.get(symbol.id) ?? new Set();\n symbolIdToFileIds.add(file.id);\n this.symbolIdToFileIds.set(symbol.id, symbolIdToFileIds);\n // update re-exports\n for (const exportFrom of symbol.exportFrom) {\n const exportSelector = [exportFrom];\n const exportFile = this.files.reference(exportSelector);\n if (exportFile.id !== file.id) {\n exportFile.symbols.exports.push(symbol.id);\n }\n }\n }\n for (const file of this.files.referenced()) {\n if (!file.selector) continue;\n if (file.selector[0] === externalSourceSymbol) {\n const filePath = file.selector[1];\n if (!filePath) {\n this.files.register({\n external: true,\n selector: file.selector,\n });\n continue;\n }\n const extension = path.extname(filePath);\n if (!extension) {\n this.files.register({\n external: true,\n path: filePath,\n selector: file.selector,\n });\n continue;\n }\n this.files.register({\n extension,\n external: true,\n path: filePath,\n selector: file.selector,\n });\n continue;\n }\n const dirs = file.selector.slice(0, -1);\n let name = file.selector[file.selector.length - 1]!;\n name = this.fileName?.(name) || name;\n this.files.register({\n extension,\n name,\n path: path.resolve(this.root, ...dirs, `${name}${extension}`),\n selector: file.selector,\n });\n }\n\n // TODO: track symbol dependencies and inject imports into files\n // based on symbol references so the render step can just render\n }\n\n render(meta?: IProjectRenderMeta): ReadonlyArray<IOutput> {\n this.prepareFiles();\n const files: Map<number, IOutput> = new Map();\n for (const file of this.files.registered()) {\n if (file.external || !file.path) continue;\n const renderer = this.getRenderer(file);\n if (!renderer) continue;\n files.set(file.id, {\n content: renderer.renderSymbols(file, this, meta),\n path: file.path,\n });\n }\n for (const [fileId, value] of files.entries()) {\n const file = this.files.get(fileId)!;\n const renderer = this.getRenderer(file)!;\n const content = renderer.renderFile(value.content, file, this, meta);\n if (content) {\n files.set(file.id, { ...value, content });\n } else {\n files.delete(file.id);\n }\n }\n return Array.from(files.values());\n }\n\n symbolIdToFiles(symbolId: number): ReadonlyArray<IFileOut> {\n const fileIds = this.symbolIdToFileIds.get(symbolId);\n return Array.from(fileIds ?? []).map((fileId) => this.files.get(fileId)!);\n }\n\n private symbolToFileSelector(symbol: ISymbolOut): ISelector {\n if (symbol.external) {\n return [externalSourceSymbol, symbol.external];\n }\n const filePath = symbol.getFilePath?.(symbol);\n if (filePath) {\n return filePath.split('/');\n }\n return [this.defaultFileName];\n }\n}\n"]}
1
+ {"version":3,"file":"index.js","names":["names: Array<string>","typeNames: Array<string>","binding: IBinding & Pick<Required<IBinding>, 'aliases' | 'from'>","result","result: IFileOut | undefined","id","result","result: ISymbolOut | undefined","id","exportFrom: Array<string>","extension","files: Map<number, IOutput>"],"sources":["../src/bindings/utils.ts","../src/bimap/bimap.ts","../src/files/registry.ts","../src/renderer/utils.ts","../src/symbols/registry.ts","../src/project/project.ts"],"sourcesContent":["import type { IFileOut } from '../files/types';\nimport type { ISymbolOut } from '../symbols/types';\nimport type { IBinding } from './types';\n\nexport const createBinding = ({\n file,\n modulePath,\n symbol,\n symbolFile,\n}: {\n file: IFileOut;\n modulePath: string;\n symbol: ISymbolOut;\n symbolFile: IFileOut;\n}): IBinding => {\n const names: Array<string> = [];\n const typeNames: Array<string> = [];\n const binding: IBinding & Pick<Required<IBinding>, 'aliases' | 'from'> = {\n aliases: {},\n from: modulePath,\n };\n if (symbol.meta?.importKind) {\n if (symbol.meta.importKind === 'default') {\n binding.defaultBinding = symbol.placeholder;\n if (symbol.meta.kind === 'type') {\n binding.typeDefaultBinding = true;\n }\n } else if (symbol.meta.importKind === 'namespace') {\n binding.namespaceBinding = symbol.placeholder;\n if (symbol.meta.kind === 'type') {\n binding.typeNamespaceBinding = true;\n }\n }\n }\n // default to named binding\n if (\n symbol.meta?.importKind === 'named' ||\n (!names.length && !binding.defaultBinding && !binding.namespaceBinding)\n ) {\n let name = symbol.placeholder;\n const fileResolvedName = file.resolvedNames.get(symbol.id);\n if (fileResolvedName) {\n const symbolFileResolvedName = symbolFile.resolvedNames.get(symbol.id);\n if (symbolFileResolvedName) {\n if (symbolFileResolvedName !== fileResolvedName) {\n name = symbolFileResolvedName;\n binding.aliases[name] = fileResolvedName;\n }\n } else if (symbol.name && fileResolvedName !== symbol.name) {\n name = symbol.name;\n binding.aliases[name] = symbol.placeholder;\n }\n }\n names.push(name);\n if (symbol.meta?.kind === 'type') {\n typeNames.push(name);\n }\n }\n // cast type names to names to allow for cleaner API,\n // otherwise users would have to define the same values twice\n for (const typeName of typeNames) {\n if (!names.includes(typeName)) {\n names.push(typeName);\n }\n }\n binding.names = names;\n binding.typeNames = typeNames;\n return binding;\n};\n\nexport const mergeBindings = (target: IBinding, source: IBinding): void => {\n target.aliases = { ...target.aliases, ...source.aliases };\n if (source.defaultBinding !== undefined) {\n target.defaultBinding = source.defaultBinding;\n }\n target.names = [\n ...new Set([...(target.names ?? []), ...(source.names ?? [])]),\n ];\n if (source.namespaceBinding !== undefined) {\n target.namespaceBinding = source.namespaceBinding;\n }\n if (source.typeDefaultBinding !== undefined) {\n target.typeDefaultBinding = source.typeDefaultBinding;\n }\n target.typeNames = [\n ...new Set([...(target.typeNames ?? []), ...(source.typeNames ?? [])]),\n ];\n if (source.typeNamespaceBinding !== undefined) {\n target.typeNamespaceBinding = source.typeNamespaceBinding;\n }\n};\n","import type { IBiMap } from './types';\n\nexport class BiMap<Key, Value> implements IBiMap<Key, Value> {\n private map = new Map<Key, Value>();\n private reverse = new Map<Value, Key>();\n\n delete(key: Key): boolean {\n const value = this.map.get(key);\n if (value !== undefined) {\n this.reverse.delete(value);\n }\n return this.map.delete(key);\n }\n\n deleteValue(value: Value): boolean {\n const key = this.reverse.get(value);\n if (key !== undefined) {\n this.map.delete(key);\n }\n return this.reverse.delete(value);\n }\n\n entries(): IterableIterator<[Key, Value]> {\n return this.map.entries();\n }\n\n get(key: Key): Value | undefined {\n return this.map.get(key);\n }\n\n getKey(value: Value): Key | undefined {\n return this.reverse.get(value);\n }\n\n hasKey(key: Key): boolean {\n return this.map.has(key);\n }\n\n hasValue(value: Value): boolean {\n return this.reverse.has(value);\n }\n\n keys(): IterableIterator<Key> {\n return this.map.keys();\n }\n\n set(key: Key, value: Value): this {\n const oldValue = this.map.get(key);\n if (oldValue !== undefined && oldValue !== value) {\n this.reverse.delete(oldValue);\n }\n const oldKey = this.reverse.get(value);\n if (oldKey !== undefined && oldKey !== key) {\n this.map.delete(oldKey);\n }\n this.map.set(key, value);\n this.reverse.set(value, key);\n return this;\n }\n\n get size(): number {\n return this.map.size;\n }\n\n values(): IterableIterator<Value> {\n return this.map.values();\n }\n\n [Symbol.iterator](): IterableIterator<[Key, Value]> {\n return this.map[Symbol.iterator]();\n }\n}\n","import { BiMap } from '../bimap/bimap';\nimport type { ISelector } from '../selectors/types';\nimport type { IFileIn, IFileOut, IFileRegistry } from './types';\n\nexport class FileRegistry implements IFileRegistry {\n private _id: number = 0;\n private referenceOrder: Set<number> = new Set();\n private registerOrder: Set<number> = new Set();\n private selectorToId: Map<string, number> = new Map();\n private values: Map<number, IFileOut> = new Map();\n\n get(fileIdOrSelector: number | ISelector): IFileOut | undefined {\n const symbol = this.idOrSelector(fileIdOrSelector);\n\n if (symbol.id !== undefined) {\n return this.values.get(symbol.id);\n }\n\n const selector =\n symbol.selector !== undefined\n ? JSON.stringify(symbol.selector)\n : undefined;\n\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n return this.values.get(id);\n }\n }\n\n return;\n }\n\n get id(): number {\n return this._id++;\n }\n\n private idOrSelector(\n symbolIdOrSelector: number | ISelector,\n ): Pick<IFileIn, 'id' | 'selector'> {\n return typeof symbolIdOrSelector === 'number'\n ? { id: symbolIdOrSelector }\n : { selector: symbolIdOrSelector };\n }\n\n reference(fileIdOrSelector: number | ISelector): IFileOut {\n const file = this.idOrSelector(fileIdOrSelector);\n return this.register(file);\n }\n\n *referenced(): IterableIterator<IFileOut> {\n for (const id of this.referenceOrder.values()) {\n yield this.values.get(id)!;\n }\n }\n\n register(file: IFileIn): IFileOut {\n if (file.id !== undefined) {\n const result = this.values.get(file.id);\n if (!result) {\n throw new Error(\n `File with ID ${file.id} not found. To register a new file, leave the ID undefined.`,\n );\n }\n return result;\n }\n\n const hasOtherKeys = Object.keys(file).some(\n (key) => !['id', 'selector'].includes(key),\n );\n\n let result: IFileOut | undefined;\n\n const selector =\n file.selector !== undefined ? JSON.stringify(file.selector) : undefined;\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n result = this.values.get(id);\n if (!result) {\n throw new Error(\n `File with ID ${id} not found. The selector ${selector} matched an ID, but there was no result. This is likely an issue with the application logic.`,\n );\n }\n if (!hasOtherKeys) {\n return result;\n }\n }\n }\n\n const id = result?.id !== undefined ? result.id : this.id;\n result = {\n ...result,\n ...file, // clone to avoid mutation\n id,\n resolvedNames: result?.resolvedNames ?? new BiMap(),\n symbols: result?.symbols ?? {\n body: [],\n exports: [],\n imports: [],\n },\n };\n this.values.set(id, result);\n\n if (hasOtherKeys) {\n this.registerOrder.add(id);\n } else {\n this.referenceOrder.add(id);\n }\n\n if (selector) {\n this.selectorToId.set(selector, id);\n }\n\n return result;\n }\n\n *registered(): IterableIterator<IFileOut> {\n for (const id of this.registerOrder.values()) {\n yield this.values.get(id)!;\n }\n }\n}\n","/**\n * Wraps an ID in namespace to avoid collisions when replacing it.\n *\n * @param symbolId Stringified symbol ID to use.\n * @returns The wrapped placeholder ID.\n */\nexport const wrapId = (symbolId: string): string => `_heyapi_${symbolId}_`;\n\n/**\n * Unwraps an ID from namespace.\n *\n * @param wrappedId The wrapped placeholder ID.\n * @returns Stringified ID to use.\n */\nconst unwrapId = (wrappedId: string): string =>\n wrappedId.slice('_heyapi_'.length, -1);\n\n/**\n * Returns a RegExp instance to match ID placeholders.\n *\n * @returns RegExp instance to match ID placeholders.\n */\nconst createPlaceholderRegExp = (): RegExp => new RegExp(wrapId('\\\\d+'), 'g');\n\n/**\n *\n * @param source The source string to replace.\n * @param replacerFn Accepts a symbol ID, returns resolved symbol name.\n * @returns The replaced source string.\n */\nexport const renderIds = (\n source: string,\n replacerFn: (symbolId: number) => string | undefined,\n): string =>\n source.replace(createPlaceholderRegExp(), (match) => {\n const symbolId = Number.parseInt(unwrapId(match), 10);\n return replacerFn(symbolId) || match;\n });\n","import { wrapId } from '../renderer/utils';\nimport type { ISelector } from '../selectors/types';\nimport type { ISymbolIn, ISymbolOut, ISymbolRegistry } from './types';\n\nexport class SymbolRegistry implements ISymbolRegistry {\n private _id: number = 0;\n private nodes: Map<number, unknown> = new Map();\n private registerOrder: Set<number> = new Set();\n private selectorToId: Map<string, number> = new Map();\n private values: Map<number, ISymbolOut> = new Map();\n\n get(symbolIdOrSelector: number | ISelector): ISymbolOut | undefined {\n const symbol = this.idOrSelector(symbolIdOrSelector);\n\n if (symbol.id !== undefined) {\n return this.values.get(symbol.id);\n }\n\n const selector =\n symbol.selector !== undefined\n ? JSON.stringify(symbol.selector)\n : undefined;\n\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n return this.values.get(id);\n }\n }\n\n return;\n }\n\n getValue(symbolId: number): unknown {\n return this.nodes.get(symbolId);\n }\n\n hasValue(symbolId: number): boolean {\n return this.nodes.has(symbolId);\n }\n\n get id(): number {\n return this._id++;\n }\n\n private idOrSelector(\n symbolIdOrSelector: number | ISelector,\n ): Pick<ISymbolIn, 'id' | 'selector'> {\n return typeof symbolIdOrSelector === 'number'\n ? { id: symbolIdOrSelector }\n : { selector: symbolIdOrSelector };\n }\n\n reference(symbolIdOrSelector: number | ISelector): ISymbolOut {\n const symbol = this.idOrSelector(symbolIdOrSelector);\n return this.register(symbol);\n }\n\n register(symbol: ISymbolIn): ISymbolOut {\n if (symbol.id !== undefined) {\n const result = this.values.get(symbol.id);\n if (!result) {\n throw new Error(\n `Symbol with ID ${symbol.id} not found. To register a new symbol, leave the ID undefined.`,\n );\n }\n return result;\n }\n\n const hasOtherKeys = Object.keys(symbol).some(\n (key) => !['id', 'selector'].includes(key),\n );\n\n let result: ISymbolOut | undefined;\n\n const selector =\n symbol.selector !== undefined\n ? JSON.stringify(symbol.selector)\n : undefined;\n if (selector) {\n const id = this.selectorToId.get(selector);\n if (id !== undefined) {\n result = this.values.get(id);\n if (!result) {\n throw new Error(\n `Symbol with ID ${id} not found. The selector ${selector} matched an ID, but there was no result. This is likely an issue with the application logic.`,\n );\n }\n if (!hasOtherKeys) {\n return result;\n }\n }\n }\n\n const id = result?.id !== undefined ? result.id : this.id;\n const exportFrom: Array<string> = result?.exportFrom\n ? [...result.exportFrom]\n : [];\n if (symbol.exportFrom) {\n exportFrom.push(...symbol.exportFrom);\n }\n result = {\n ...result,\n ...symbol, // clone to avoid mutation\n exportFrom,\n id,\n placeholder:\n result?.placeholder ?? symbol.placeholder ?? wrapId(String(id)),\n };\n this.values.set(id, result);\n\n if (hasOtherKeys) {\n this.registerOrder.add(id);\n }\n\n if (selector) {\n this.selectorToId.set(selector, id);\n }\n\n return result;\n }\n\n *registered(): IterableIterator<ISymbolOut> {\n for (const id of this.registerOrder.values()) {\n yield this.values.get(id)!;\n }\n }\n\n setValue(symbolId: number, value: unknown): Map<number, unknown> {\n return this.nodes.set(symbolId, value);\n }\n}\n","import path from 'node:path';\n\nimport type { IProjectRenderMeta } from '../extensions/types';\nimport { FileRegistry } from '../files/registry';\nimport type { IFileOut } from '../files/types';\nimport type { IOutput } from '../output/types';\nimport type { IRenderer } from '../renderer/types';\nimport type { ISelector } from '../selectors/types';\nimport { SymbolRegistry } from '../symbols/registry';\nimport type { ISymbolOut } from '../symbols/types';\nimport type { IProject } from './types';\n\nconst externalSourceSymbol = '@';\n\nexport class Project implements IProject {\n private symbolIdToFileIds: Map<number, Set<number>> = new Map();\n\n readonly defaultFileName: string;\n readonly files = new FileRegistry();\n readonly fileName?: (name: string) => string;\n readonly renderers: Record<string, IRenderer> = {};\n readonly root: string;\n readonly symbols = new SymbolRegistry();\n\n constructor({\n defaultFileName,\n fileName,\n renderers,\n root,\n }: Pick<IProject, 'defaultFileName' | 'fileName' | 'renderers' | 'root'>) {\n this.defaultFileName = defaultFileName ?? 'main';\n this.fileName = typeof fileName === 'string' ? () => fileName : fileName;\n this.renderers = renderers;\n this.root = root;\n }\n\n private getRenderer(file: IFileOut): IRenderer | undefined {\n return file.extension ? this.renderers[file.extension] : undefined;\n }\n\n private prepareFiles(): void {\n // TODO: infer extension from symbols\n const extension = '.ts';\n for (const symbol of this.symbols.registered()) {\n const selector = this.symbolToFileSelector(symbol);\n const file = this.files.reference(selector);\n file.symbols.body.push(symbol.id);\n // update symbol->files map\n const symbolIdToFileIds =\n this.symbolIdToFileIds.get(symbol.id) ?? new Set();\n symbolIdToFileIds.add(file.id);\n this.symbolIdToFileIds.set(symbol.id, symbolIdToFileIds);\n // update re-exports\n for (const exportFrom of symbol.exportFrom) {\n const exportSelector = [exportFrom];\n const exportFile = this.files.reference(exportSelector);\n if (exportFile.id !== file.id) {\n exportFile.symbols.exports.push(symbol.id);\n }\n }\n }\n for (const file of this.files.referenced()) {\n if (!file.selector) continue;\n if (file.selector[0] === externalSourceSymbol) {\n const filePath = file.selector[1];\n if (!filePath) {\n this.files.register({\n external: true,\n selector: file.selector,\n });\n continue;\n }\n const extension = path.extname(filePath);\n if (!extension) {\n this.files.register({\n external: true,\n path: filePath,\n selector: file.selector,\n });\n continue;\n }\n this.files.register({\n extension,\n external: true,\n path: filePath,\n selector: file.selector,\n });\n continue;\n }\n const dirs = file.selector.slice(0, -1);\n let name = file.selector[file.selector.length - 1]!;\n name = this.fileName?.(name) || name;\n this.files.register({\n extension,\n name,\n path: path.resolve(this.root, ...dirs, `${name}${extension}`),\n selector: file.selector,\n });\n }\n\n // TODO: track symbol dependencies and inject imports into files\n // based on symbol references so the render step can just render\n }\n\n render(meta?: IProjectRenderMeta): ReadonlyArray<IOutput> {\n this.prepareFiles();\n const files: Map<number, IOutput> = new Map();\n for (const file of this.files.registered()) {\n if (file.external || !file.path) continue;\n const renderer = this.getRenderer(file);\n if (!renderer) continue;\n files.set(file.id, {\n content: renderer.renderSymbols(file, this, meta),\n path: file.path,\n });\n }\n for (const [fileId, value] of files.entries()) {\n const file = this.files.get(fileId)!;\n const renderer = this.getRenderer(file)!;\n const content = renderer.renderFile(value.content, file, this, meta);\n if (content) {\n files.set(file.id, { ...value, content });\n } else {\n files.delete(file.id);\n }\n }\n return Array.from(files.values());\n }\n\n symbolIdToFiles(symbolId: number): ReadonlyArray<IFileOut> {\n const fileIds = this.symbolIdToFileIds.get(symbolId);\n return Array.from(fileIds ?? []).map((fileId) => this.files.get(fileId)!);\n }\n\n private symbolToFileSelector(symbol: ISymbolOut): ISelector {\n if (symbol.external) {\n return [externalSourceSymbol, symbol.external];\n }\n const filePath = symbol.getFilePath?.(symbol);\n if (filePath) {\n return filePath.split('/');\n }\n return [this.defaultFileName];\n }\n}\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hey-api/codegen-core",
3
- "version": "0.2.0",
3
+ "version": "0.3.0",
4
4
  "description": "🧱 TypeScript framework for generating structured, multi-file source code from abstract syntax trees.",
5
5
  "homepage": "https://heyapi.dev/",
6
6
  "repository": {
@@ -47,7 +47,7 @@
47
47
  "README.md"
48
48
  ],
49
49
  "engines": {
50
- "node": "^18.18.0 || ^20.9.0 || >=22.10.0"
50
+ "node": ">=20.19.0"
51
51
  },
52
52
  "peerDependencies": {
53
53
  "typescript": ">=5.5.3"
@@ -55,13 +55,13 @@
55
55
  "devDependencies": {
56
56
  "eslint": "9.17.0",
57
57
  "prettier": "3.4.2",
58
- "typescript": "5.8.3",
58
+ "typescript": "5.9.3",
59
59
  "@config/vite-base": "0.0.1"
60
60
  },
61
61
  "scripts": {
62
- "build": "tsup && pnpm check-exports",
62
+ "build": "tsdown && pnpm check-exports",
63
63
  "check-exports": "attw --pack . --profile node16",
64
- "dev": "tsup --watch",
64
+ "dev": "tsdown --watch",
65
65
  "test:coverage": "vitest run --coverage",
66
66
  "test:update": "vitest watch --update",
67
67
  "test:watch": "vitest watch",