lombok-typescript 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +98 -0
  3. package/dist/backend-CkLBcDd8.d.cts +59 -0
  4. package/dist/backend-CkLBcDd8.d.ts +59 -0
  5. package/dist/cli/index.cjs +585 -0
  6. package/dist/cli/index.cjs.map +1 -0
  7. package/dist/cli/index.d.cts +14 -0
  8. package/dist/cli/index.d.ts +14 -0
  9. package/dist/cli/index.js +579 -0
  10. package/dist/cli/index.js.map +1 -0
  11. package/dist/codegen/index.cjs +450 -0
  12. package/dist/codegen/index.cjs.map +1 -0
  13. package/dist/codegen/index.d.cts +109 -0
  14. package/dist/codegen/index.d.ts +109 -0
  15. package/dist/codegen/index.js +443 -0
  16. package/dist/codegen/index.js.map +1 -0
  17. package/dist/core/index.cjs +132 -0
  18. package/dist/core/index.cjs.map +1 -0
  19. package/dist/core/index.d.cts +73 -0
  20. package/dist/core/index.d.ts +73 -0
  21. package/dist/core/index.js +128 -0
  22. package/dist/core/index.js.map +1 -0
  23. package/dist/index.cjs +142 -0
  24. package/dist/index.cjs.map +1 -0
  25. package/dist/index.d.cts +93 -0
  26. package/dist/index.d.ts +93 -0
  27. package/dist/index.js +136 -0
  28. package/dist/index.js.map +1 -0
  29. package/dist/legacy/index.cjs +271 -0
  30. package/dist/legacy/index.cjs.map +1 -0
  31. package/dist/legacy/index.d.cts +32 -0
  32. package/dist/legacy/index.d.ts +32 -0
  33. package/dist/legacy/index.js +252 -0
  34. package/dist/legacy/index.js.map +1 -0
  35. package/dist/memoize-Bj9pm_cK.d.cts +48 -0
  36. package/dist/memoize-DvelzGDl.d.ts +48 -0
  37. package/dist/stage3/index.cjs +275 -0
  38. package/dist/stage3/index.cjs.map +1 -0
  39. package/dist/stage3/index.d.cts +97 -0
  40. package/dist/stage3/index.d.ts +97 -0
  41. package/dist/stage3/index.js +255 -0
  42. package/dist/stage3/index.js.map +1 -0
  43. package/package.json +120 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/codegen/analyzer.ts","../../src/codegen/emitters/helpers.ts","../../src/codegen/emitters/builder.ts","../../src/codegen/emitters/declaration.ts","../../src/codegen/emitters/index.ts","../../src/codegen/generator.ts","../../src/codegen/transformer.ts"],"names":["Project","SyntaxKind","relative","dirname","ts","resolve","existsSync","mkdirSync","writeFileSync"],"mappings":"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","file":"index.cjs","sourcesContent":["import {\n type ClassDeclaration,\n type Decorator,\n type MethodDeclaration,\n type ParameterDeclaration,\n Project,\n type PropertyDeclaration,\n type SourceFile,\n SyntaxKind,\n} from 'ts-morph';\nimport type { ClassInfo, DecoratorInfo, FieldInfo, MethodInfo, ParameterInfo } from './types.js';\n\n/**\n * Walk every class in `sourceFile` and return their decorator/field/method\n * shapes as plain data. No ts-morph references leak out.\n */\nexport function analyzeFile(sourceFile: SourceFile): ClassInfo[] {\n return sourceFile.getClasses().map((cls) => analyzeClassDeclaration(cls));\n}\n\n/** Find one class by name in the source file. Returns `undefined` if missing. */\nexport function analyzeClassByName(\n sourceFile: SourceFile,\n className: string,\n): ClassInfo | undefined {\n const cls = sourceFile.getClass(className);\n return cls ? analyzeClassDeclaration(cls) : undefined;\n}\n\n/** Parse a source string in an in-memory project and analyze every class in it. */\nexport function analyzeSourceString(sourceCode: string, fileName = 'analyze.ts'): ClassInfo[] {\n const project = new Project({ useInMemoryFileSystem: true });\n const sourceFile = project.createSourceFile(fileName, sourceCode);\n return analyzeFile(sourceFile);\n}\n\n/** Analyze a single named class in a source string. Throws if not found. */\nexport function analyzeClass(sourceCode: string, className: string): ClassInfo {\n const project = new Project({ useInMemoryFileSystem: true });\n const sourceFile = project.createSourceFile('analyze.ts', sourceCode);\n const result = analyzeClassByName(sourceFile, className);\n if (!result) {\n throw new Error(`No class named \"${className}\" found in source`);\n }\n return result;\n}\n\n// Internal walkers\n\nfunction analyzeClassDeclaration(cls: ClassDeclaration): ClassInfo {\n const name = cls.getName() ?? '<anonymous>';\n return {\n name,\n decorators: cls.getDecorators().map(toDecoratorInfo),\n fields: cls.getProperties().map(toFieldInfo),\n methods: cls.getMethods().map(toMethodInfo),\n };\n}\n\nfunction toDecoratorInfo(decorator: Decorator): DecoratorInfo {\n return {\n name: decorator.getName(),\n arguments: decorator.getArguments().map((arg) => arg.getText()),\n };\n}\n\nfunction toFieldInfo(prop: PropertyDeclaration): FieldInfo {\n const initializer = prop.getInitializer();\n return {\n name: prop.getName(),\n type: prop.getType().getText(prop),\n isOptional: prop.hasQuestionToken(),\n isReadonly: prop.isReadonly(),\n hasDefault: initializer !== undefined,\n defaultValue: initializer?.getText(),\n decorators: prop.getDecorators().map(toDecoratorInfo),\n };\n}\n\nfunction toMethodInfo(method: MethodDeclaration): MethodInfo {\n return {\n name: method.getName(),\n returnType: method.getReturnType().getText(method),\n parameters: method.getParameters().map(toParameterInfo),\n decorators: method.getDecorators().map(toDecoratorInfo),\n isAsync: method.isAsync(),\n isStatic: method.isStatic(),\n };\n}\n\nfunction toParameterInfo(param: ParameterDeclaration): ParameterInfo {\n return {\n name: param.getName(),\n type: param.getType().getText(param),\n isOptional:\n param.hasQuestionToken() ||\n param.hasInitializer() ||\n param.getDotDotDotToken()?.getKind() === SyntaxKind.DotDotDotToken,\n decorators: param.getDecorators().map(toDecoratorInfo),\n };\n}\n","import { relative } from 'node:path';\nimport type { ClassInfo, FieldInfo } from '../types.js';\n\n/** ESM import path from `fromDir` to `sourcePath` (NodeNext requires a `.js` extension). */\nexport function toImportPath(sourcePath: string, fromDir: string): string {\n let rel = relative(fromDir, sourcePath).replace(/\\\\/g, '/');\n if (!rel.startsWith('.')) rel = './' + rel;\n return rel.replace(/\\.tsx?$/u, '.js');\n}\n\nexport function hasCodegenClassDecorator(info: ClassInfo): boolean {\n return (\n hasClassDecorator(info, 'Builder') ||\n hasClassDecorator(info, 'Data') ||\n hasClassDecorator(info, 'ToString')\n );\n}\n\nexport function hasClassDecorator(info: ClassInfo, name: string): boolean {\n return info.decorators.some((d) => d.name === name);\n}\n\nexport function fieldExcludesToString(field: FieldInfo): boolean {\n return field.decorators.some(\n (d) => d.name === 'ToStringExclude' || d.name === 'ToString.Exclude',\n );\n}\n\nexport function visibleFields(info: ClassInfo): FieldInfo[] {\n if (hasClassDecorator(info, 'ToString')) {\n return info.fields.filter((f) => !fieldExcludesToString(f));\n }\n return info.fields;\n}\n\nexport function getterName(fieldName: string): string {\n return `get${fieldName.charAt(0).toUpperCase()}${fieldName.slice(1)}`;\n}\n\nexport function setterName(fieldName: string): string {\n return `set${fieldName.charAt(0).toUpperCase()}${fieldName.slice(1)}`;\n}\n\nexport function builderClassName(className: string): string {\n return `${className}Builder`;\n}\n","import type { ClassInfo } from '../types.js';\nimport { builderClassName, hasClassDecorator } from './helpers.js';\n\nexport function emitBuilderClass(info: ClassInfo): string {\n if (!hasClassDecorator(info, 'Builder')) {\n return '';\n }\n\n const builderName = builderClassName(info.name);\n const fieldLines = info.fields.map((f) => {\n if (f.isOptional) {\n return ` private _${f.name}?: ${f.type};`;\n }\n return ` private _${f.name}!: ${f.type};`;\n });\n\n const setterMethods = info.fields.map((f) =>\n `\n ${f.name}(value: ${f.type}): ${builderName} {\n this._${f.name} = value;\n return this;\n }`.trim(),\n );\n\n return `\nexport class ${builderName} {\n${fieldLines.join('\\n')}\n\n static builder(): ${builderName} {\n return new ${builderName}();\n }\n\n${setterMethods.join('\\n\\n')}\n\n build(): ${info.name} {\n const instance = new ${info.name}();\n${info.fields.map((f) => ` instance.${f.name} = this._${f.name}${f.isOptional ? '' : '!'};`).join('\\n')}\n return instance;\n }\n}`.trim();\n}\n\nexport function emitBuilderStaticMethod(info: ClassInfo): string {\n if (!hasClassDecorator(info, 'Builder')) return '';\n const builderName = builderClassName(info.name);\n return `\n static builder(): ${builderName} {\n return ${builderName}.builder();\n }`.trim();\n}\n","import { dirname } from 'node:path';\nimport type { ClassInfo } from '../types.js';\nimport { builderClassName, hasClassDecorator, toImportPath } from './helpers.js';\n\nexport function emitDeclarationShim(\n sourcePath: string,\n companionOutputPath: string,\n classes: readonly ClassInfo[],\n): string {\n const relSource = toImportPath(sourcePath, dirname(companionOutputPath));\n const lines: string[] = [\n '// Auto-generated type augmentation by lombok-typescript.',\n '// Do not edit. Regenerate via `lombok-ts generate`.',\n '',\n 'export {};',\n '',\n `declare module '${relSource}' {`,\n ];\n\n for (const info of classes) {\n if (hasClassDecorator(info, 'Builder')) {\n const builderName = builderClassName(info.name);\n lines.push(` export class ${builderName} {`);\n lines.push(` static builder(): ${builderName};`);\n for (const f of info.fields) {\n lines.push(` ${f.name}(value: ${f.type}): ${builderName};`);\n }\n lines.push(` build(): ${info.name};`);\n lines.push(' }');\n lines.push('');\n }\n\n if (hasClassDecorator(info, 'Builder')) {\n const builderName = builderClassName(info.name);\n lines.push(` export class ${info.name} {`);\n lines.push(` static builder(): ${builderName};`);\n lines.push(' }');\n lines.push('');\n }\n\n const augments: string[] = [];\n if (hasClassDecorator(info, 'Data')) {\n for (const f of info.fields) {\n const g = `get${f.name.charAt(0).toUpperCase()}${f.name.slice(1)}`;\n augments.push(` ${g}(): ${f.type};`);\n if (!f.isReadonly) {\n const s = `set${f.name.charAt(0).toUpperCase()}${f.name.slice(1)}`;\n augments.push(` ${s}(value: ${f.type}): void;`);\n }\n }\n augments.push(` equals(other: ${info.name} | null | undefined): boolean;`);\n augments.push(` toString(): string;`);\n } else if (hasClassDecorator(info, 'ToString')) {\n augments.push(' toString(): string;');\n }\n\n if (augments.length > 0) {\n lines.push(` interface ${info.name} {`);\n lines.push(...augments);\n lines.push(' }');\n }\n }\n\n lines.push('}');\n lines.push('');\n return lines.join('\\n');\n}\n","import { dirname, relative } from 'node:path';\nimport type { ClassInfo } from '../types.js';\nimport { emitBuilderClass } from './builder.js';\nimport { emitDeclarationShim } from './declaration.js';\nimport {\n builderClassName,\n hasClassDecorator,\n hasCodegenClassDecorator,\n toImportPath,\n visibleFields,\n} from './helpers.js';\n\nfunction emitImports(classes: readonly ClassInfo[], importPath: string): string {\n const names = classes.filter(hasCodegenClassDecorator).map((c) => c.name);\n if (names.length === 0) return '';\n return `import { ${names.join(', ')} } from '${importPath}';\\n\\n`;\n}\n\nfunction emitToStringFn(info: ClassInfo): string {\n if (!hasClassDecorator(info, 'ToString') && !hasClassDecorator(info, 'Data')) return '';\n const fields = visibleFields(info);\n const parts = fields.map((f) => `${f.name}=\\${String(this.${f.name})}`).join(', ');\n return `\nfunction ${info.name}_toString(this: ${info.name}): string {\n return \\`${info.name}(${parts})\\`;\n}`.trim();\n}\n\nfunction emitApplyMixin(info: ClassInfo): string {\n const assignments: string[] = [];\n\n if (hasClassDecorator(info, 'Data')) {\n for (const f of info.fields) {\n const g = `get${f.name.charAt(0).toUpperCase()}${f.name.slice(1)}`;\n assignments.push(`prototype.${g} = ${info.name}_${g};`);\n if (!f.isReadonly) {\n const s = `set${f.name.charAt(0).toUpperCase()}${f.name.slice(1)}`;\n assignments.push(`prototype.${s} = ${info.name}_${s};`);\n }\n }\n assignments.push(`prototype.equals = ${info.name}_equals;`);\n assignments.push(`prototype.toString = ${info.name}_toString;`);\n } else if (hasClassDecorator(info, 'ToString')) {\n assignments.push(`prototype.toString = ${info.name}_toString;`);\n }\n\n if (hasClassDecorator(info, 'Builder')) {\n const bName = builderClassName(info.name);\n assignments.push(\n `(ctor as typeof ${info.name} & { builder(): ${bName} }).builder = ${info.name}_builder;`,\n );\n }\n\n if (assignments.length === 0) return '';\n\n return `\nexport function apply${info.name}Generated(ctor: typeof ${info.name}): void {\n const prototype = ctor.prototype as unknown as Record<string, unknown>;\n ${assignments.join('\\n ')}\n}`.trim();\n}\n\nfunction emitDataFns(info: ClassInfo): string {\n if (!hasClassDecorator(info, 'Data')) return '';\n\n const fns: string[] = [];\n\n for (const f of info.fields) {\n const g = `get${f.name.charAt(0).toUpperCase()}${f.name.slice(1)}`;\n fns.push(\n `\nfunction ${info.name}_${g}(this: ${info.name}): ${f.type} {\n return this.${f.name};\n}`.trim(),\n );\n if (!f.isReadonly) {\n const s = `set${f.name.charAt(0).toUpperCase()}${f.name.slice(1)}`;\n fns.push(\n `\nfunction ${info.name}_${s}(this: ${info.name}, value: ${f.type}): void {\n this.${f.name} = value;\n}`.trim(),\n );\n }\n }\n\n const equalsBody = info.fields.map((f) => `this.${f.name} === other.${f.name}`).join(' &&\\n ');\n\n fns.push(\n `\nfunction ${info.name}_equals(this: ${info.name}, other: ${info.name} | null | undefined): boolean {\n if (other === null || other === undefined) return false;\n if (!(other instanceof (this.constructor as typeof ${info.name}))) return false;\n return ${equalsBody || 'true'};\n}`.trim(),\n );\n\n fns.push(emitToStringFn(info));\n\n return fns.filter(Boolean).join('\\n\\n');\n}\n\nfunction emitBuilderFn(info: ClassInfo): string {\n if (!hasClassDecorator(info, 'Builder')) return '';\n const bName = builderClassName(info.name);\n return `\nfunction ${info.name}_builder(): ${bName} {\n return ${bName}.builder();\n}`.trim();\n}\n\nexport function emitCompanionFile(\n sourcePath: string,\n companionOutputPath: string,\n classes: readonly ClassInfo[],\n cwd: string,\n): { ts: string; dts: string } {\n const header = [\n '// Auto-generated by lombok-typescript.',\n '// Source: ' + relative(cwd, sourcePath).replace(/\\\\/g, '/'),\n '// Do not edit. Regenerate via `lombok-ts generate`.',\n '',\n ].join('\\n');\n\n const importPath = toImportPath(sourcePath, dirname(companionOutputPath));\n\n const blocks: string[] = [];\n\n for (const info of classes) {\n const builder = emitBuilderClass(info);\n if (builder) blocks.push(builder);\n\n if (hasClassDecorator(info, 'Data')) {\n blocks.push(emitDataFns(info));\n } else {\n const ts = emitToStringFn(info);\n if (ts) blocks.push(ts);\n }\n\n const builderFn = emitBuilderFn(info);\n if (builderFn) blocks.push(builderFn);\n\n const apply = emitApplyMixin(info);\n if (apply) blocks.push(apply);\n }\n\n const applyAll =\n classes.filter((c) => emitApplyMixin(c)).length > 0\n ? `\\n\\nexport function applyAllGenerated(handlers: {\\n${classes\n .filter((c) => emitApplyMixin(c))\n .map((c) => ` ${c.name}: typeof ${c.name};`)\n .join('\\n')}\\n}): void {\\n${classes\n .filter((c) => emitApplyMixin(c))\n .map((c) => ` apply${c.name}Generated(handlers.${c.name});`)\n .join('\\n')}\\n}\\n`\n : '\\nexport {};\\n';\n\n const imports = emitImports(classes, importPath);\n const ts = header + imports + blocks.join('\\n\\n') + applyAll;\n const dts = emitDeclarationShim(sourcePath, companionOutputPath, classes);\n\n return { ts, dts };\n}\n\nexport { emitDeclarationShim };\n","import { existsSync, mkdirSync, writeFileSync } from 'node:fs';\nimport { dirname, relative, resolve } from 'node:path';\nimport { Project } from 'ts-morph';\nimport { analyzeFile } from './analyzer.js';\nimport { emitCompanionFile } from './emitters/index.js';\nimport type { ClassInfo, GeneratedFile, GeneratorOptions } from './types.js';\n\nconst DEFAULT_OPTIONS: GeneratorOptions = {\n outputDir: '.lombok',\n watch: false,\n include: ['src/**/*.ts'],\n exclude: ['node_modules', '**/*.test.ts', '**/*.spec.ts', 'dist', '.lombok'],\n tsConfigPath: 'tsconfig.json',\n};\n\n/**\n * Codegen entry point.\n *\n * Walks the user's source files, finds decorated classes, and writes a\n * companion stub file per source. The stub today is just a comment-form\n * summary of each class. Once real decorators land, this is where their\n * generated TypeScript output will go.\n */\nexport class CodeGenerator {\n readonly options: GeneratorOptions;\n\n constructor(options: Partial<GeneratorOptions> = {}) {\n this.options = { ...DEFAULT_OPTIONS, ...options };\n }\n\n /**\n * Run codegen against all matching source files.\n *\n * Uses the project's `tsConfigPath` if it exists, otherwise an in-memory\n * project that processes the configured globs. For each file with at least\n * one class, writes a companion stub to `<outputDir>/<rel-path>.lombok.ts`.\n */\n async generate(): Promise<GeneratedFile[]> {\n const project = this.createProject();\n const sourceFiles = project.getSourceFiles();\n const generated: GeneratedFile[] = [];\n\n for (const sourceFile of sourceFiles) {\n if (!this.shouldProcess(sourceFile.getFilePath())) continue;\n\n const classes = analyzeFile(sourceFile);\n if (classes.length === 0) continue;\n\n const sourcePath = sourceFile.getFilePath();\n const outputPath = this.computeOutputPath(sourcePath);\n const { ts, dts } = emitCompanionFile(sourcePath, outputPath, classes, process.cwd());\n const content = ts;\n\n this.writeOutput(outputPath, content);\n this.writeOutput(outputPath.replace(/\\.lombok\\.ts$/u, '.lombok.d.ts'), dts);\n\n generated.push({\n sourcePath,\n outputPath,\n content,\n processedClasses: classes.map((c) => c.name),\n });\n }\n\n return generated;\n }\n\n /** Generate code for a single source file path. */\n async generateForFile(filePath: string): Promise<GeneratedFile | null> {\n const project = new Project({\n useInMemoryFileSystem: false,\n compilerOptions: { allowJs: false },\n });\n const sourceFile = project.addSourceFileAtPath(filePath);\n const classes = analyzeFile(sourceFile);\n if (classes.length === 0) return null;\n\n const outputPath = this.computeOutputPath(filePath);\n const { ts, dts } = emitCompanionFile(filePath, outputPath, classes, process.cwd());\n const content = ts;\n this.writeOutput(outputPath, content);\n this.writeOutput(outputPath.replace(/\\.lombok\\.ts$/u, '.lombok.d.ts'), dts);\n\n return {\n sourcePath: filePath,\n outputPath,\n content,\n processedClasses: classes.map((c) => c.name),\n };\n }\n\n /** Watch mode is not implemented yet. Re-run `lombok-ts generate` for now. */\n async watch(): Promise<void> {\n throw new Error(\n 'Watch mode is not implemented yet. Re-run `lombok-ts generate` after changes.',\n );\n }\n\n // Internal helpers\n\n protected createProject(): Project {\n const tsConfig = resolve(this.options.tsConfigPath);\n if (existsSync(tsConfig)) {\n return new Project({ tsConfigFilePath: tsConfig });\n }\n const project = new Project({\n compilerOptions: { allowJs: false, target: 99 /* ESNext */ },\n });\n if (this.options.include.length > 0) {\n project.addSourceFilesAtPaths(this.options.include);\n }\n return project;\n }\n\n protected shouldProcess(filePath: string): boolean {\n const abs = filePath.replace(/\\\\/g, '/');\n const rel = relative(process.cwd(), filePath).replace(/\\\\/g, '/');\n\n const excluded = this.options.exclude.some(\n (pat) => matchesGlob(rel, pat) || matchesGlob(abs, pat),\n );\n if (excluded) return false;\n\n if (this.options.include.length === 0) return true;\n return this.options.include.some((pat) => matchesGlob(rel, pat) || matchesGlob(abs, pat));\n }\n\n protected computeOutputPath(sourcePath: string): string {\n const cwd = process.cwd();\n const rel = relative(cwd, sourcePath);\n const base = rel.replace(/\\.ts$/u, '.lombok.ts');\n return resolve(cwd, this.options.outputDir, base);\n }\n\n protected renderCompanion(_sourcePath: string, _classes: readonly ClassInfo[]): string {\n return 'export {};\\n';\n }\n\n protected writeOutput(outputPath: string, content: string): void {\n mkdirSync(dirname(outputPath), { recursive: true });\n writeFileSync(outputPath, content, 'utf8');\n }\n}\n\n/**\n * Minimal glob match. Handles `**`, `*`, no brace expansion. If we need more\n * we'd pull in `picomatch`, but this keeps the dep tree small.\n */\nfunction matchesGlob(filePath: string, pattern: string): boolean {\n const norm = filePath.replace(/\\\\/g, '/');\n const regex = new RegExp(\n '^' +\n pattern\n .replace(/[.+^$()|[\\]{}]/g, '\\\\$&')\n .replace(/\\*\\*\\//g, '__GLOBSTAR_SLASH__')\n .replace(/\\*\\*/g, '__GLOBSTAR__')\n .replace(/\\*/g, '[^/]*')\n .replace(/__GLOBSTAR_SLASH__/g, '(?:.*/)?')\n .replace(/__GLOBSTAR__/g, '.*') +\n '$',\n 'u',\n );\n return regex.test(norm);\n}\n","/**\n * Placeholder for a TypeScript compiler transformer that would run codegen as\n * part of `tsc` itself (via `ts-patch` or `ttypescript`).\n *\n * For now the standalone `lombok-ts` CLI is the only codegen path. This file\n * exists so importing a transformer gives a clear \"not yet\" rather than a\n * module-not-found.\n */\nexport class LombokTransformer {\n constructor() {\n throw new Error('LombokTransformer is not implemented yet. Use `lombok-ts generate` for now.');\n }\n}\n"]}
@@ -0,0 +1,109 @@
1
+ import { Project, SourceFile } from 'ts-morph';
2
+
3
+ interface GeneratorOptions {
4
+ /** Where generated files go. Default `.lombok`. */
5
+ outputDir: string;
6
+ /** Watch mode (not implemented yet). Default `false`. */
7
+ watch: boolean;
8
+ /** Glob patterns for files to process. Default `['src/** /*.ts']`. */
9
+ include: string[];
10
+ /** Glob patterns for files to skip. Default excludes test files and `dist`. */
11
+ exclude: string[];
12
+ /** Path to the project's tsconfig. Default `tsconfig.json`. */
13
+ tsConfigPath: string;
14
+ }
15
+ interface GeneratedFile {
16
+ sourcePath: string;
17
+ outputPath: string;
18
+ content: string;
19
+ processedClasses: string[];
20
+ }
21
+ interface FieldInfo {
22
+ name: string;
23
+ type: string;
24
+ isOptional: boolean;
25
+ isReadonly: boolean;
26
+ hasDefault: boolean;
27
+ defaultValue?: string;
28
+ decorators: DecoratorInfo[];
29
+ }
30
+ interface DecoratorInfo {
31
+ name: string;
32
+ arguments: unknown[];
33
+ }
34
+ interface ClassInfo {
35
+ name: string;
36
+ fields: FieldInfo[];
37
+ decorators: DecoratorInfo[];
38
+ methods: MethodInfo[];
39
+ }
40
+ interface MethodInfo {
41
+ name: string;
42
+ returnType: string;
43
+ parameters: ParameterInfo[];
44
+ decorators: DecoratorInfo[];
45
+ isAsync: boolean;
46
+ isStatic: boolean;
47
+ }
48
+ interface ParameterInfo {
49
+ name: string;
50
+ type: string;
51
+ isOptional: boolean;
52
+ decorators: DecoratorInfo[];
53
+ }
54
+
55
+ /**
56
+ * Codegen entry point.
57
+ *
58
+ * Walks the user's source files, finds decorated classes, and writes a
59
+ * companion stub file per source. The stub today is just a comment-form
60
+ * summary of each class. Once real decorators land, this is where their
61
+ * generated TypeScript output will go.
62
+ */
63
+ declare class CodeGenerator {
64
+ readonly options: GeneratorOptions;
65
+ constructor(options?: Partial<GeneratorOptions>);
66
+ /**
67
+ * Run codegen against all matching source files.
68
+ *
69
+ * Uses the project's `tsConfigPath` if it exists, otherwise an in-memory
70
+ * project that processes the configured globs. For each file with at least
71
+ * one class, writes a companion stub to `<outputDir>/<rel-path>.lombok.ts`.
72
+ */
73
+ generate(): Promise<GeneratedFile[]>;
74
+ /** Generate code for a single source file path. */
75
+ generateForFile(filePath: string): Promise<GeneratedFile | null>;
76
+ /** Watch mode is not implemented yet. Re-run `lombok-ts generate` for now. */
77
+ watch(): Promise<void>;
78
+ protected createProject(): Project;
79
+ protected shouldProcess(filePath: string): boolean;
80
+ protected computeOutputPath(sourcePath: string): string;
81
+ protected renderCompanion(_sourcePath: string, _classes: readonly ClassInfo[]): string;
82
+ protected writeOutput(outputPath: string, content: string): void;
83
+ }
84
+
85
+ /**
86
+ * Placeholder for a TypeScript compiler transformer that would run codegen as
87
+ * part of `tsc` itself (via `ts-patch` or `ttypescript`).
88
+ *
89
+ * For now the standalone `lombok-ts` CLI is the only codegen path. This file
90
+ * exists so importing a transformer gives a clear "not yet" rather than a
91
+ * module-not-found.
92
+ */
93
+ declare class LombokTransformer {
94
+ constructor();
95
+ }
96
+
97
+ /**
98
+ * Walk every class in `sourceFile` and return their decorator/field/method
99
+ * shapes as plain data. No ts-morph references leak out.
100
+ */
101
+ declare function analyzeFile(sourceFile: SourceFile): ClassInfo[];
102
+ /** Find one class by name in the source file. Returns `undefined` if missing. */
103
+ declare function analyzeClassByName(sourceFile: SourceFile, className: string): ClassInfo | undefined;
104
+ /** Parse a source string in an in-memory project and analyze every class in it. */
105
+ declare function analyzeSourceString(sourceCode: string, fileName?: string): ClassInfo[];
106
+ /** Analyze a single named class in a source string. Throws if not found. */
107
+ declare function analyzeClass(sourceCode: string, className: string): ClassInfo;
108
+
109
+ export { type ClassInfo, CodeGenerator, type DecoratorInfo, type FieldInfo, type GeneratedFile, type GeneratorOptions, LombokTransformer, type MethodInfo, type ParameterInfo, analyzeClass, analyzeClassByName, analyzeFile, analyzeSourceString };
@@ -0,0 +1,109 @@
1
+ import { Project, SourceFile } from 'ts-morph';
2
+
3
+ interface GeneratorOptions {
4
+ /** Where generated files go. Default `.lombok`. */
5
+ outputDir: string;
6
+ /** Watch mode (not implemented yet). Default `false`. */
7
+ watch: boolean;
8
+ /** Glob patterns for files to process. Default `['src/** /*.ts']`. */
9
+ include: string[];
10
+ /** Glob patterns for files to skip. Default excludes test files and `dist`. */
11
+ exclude: string[];
12
+ /** Path to the project's tsconfig. Default `tsconfig.json`. */
13
+ tsConfigPath: string;
14
+ }
15
+ interface GeneratedFile {
16
+ sourcePath: string;
17
+ outputPath: string;
18
+ content: string;
19
+ processedClasses: string[];
20
+ }
21
+ interface FieldInfo {
22
+ name: string;
23
+ type: string;
24
+ isOptional: boolean;
25
+ isReadonly: boolean;
26
+ hasDefault: boolean;
27
+ defaultValue?: string;
28
+ decorators: DecoratorInfo[];
29
+ }
30
+ interface DecoratorInfo {
31
+ name: string;
32
+ arguments: unknown[];
33
+ }
34
+ interface ClassInfo {
35
+ name: string;
36
+ fields: FieldInfo[];
37
+ decorators: DecoratorInfo[];
38
+ methods: MethodInfo[];
39
+ }
40
+ interface MethodInfo {
41
+ name: string;
42
+ returnType: string;
43
+ parameters: ParameterInfo[];
44
+ decorators: DecoratorInfo[];
45
+ isAsync: boolean;
46
+ isStatic: boolean;
47
+ }
48
+ interface ParameterInfo {
49
+ name: string;
50
+ type: string;
51
+ isOptional: boolean;
52
+ decorators: DecoratorInfo[];
53
+ }
54
+
55
+ /**
56
+ * Codegen entry point.
57
+ *
58
+ * Walks the user's source files, finds decorated classes, and writes a
59
+ * companion stub file per source. The stub today is just a comment-form
60
+ * summary of each class. Once real decorators land, this is where their
61
+ * generated TypeScript output will go.
62
+ */
63
+ declare class CodeGenerator {
64
+ readonly options: GeneratorOptions;
65
+ constructor(options?: Partial<GeneratorOptions>);
66
+ /**
67
+ * Run codegen against all matching source files.
68
+ *
69
+ * Uses the project's `tsConfigPath` if it exists, otherwise an in-memory
70
+ * project that processes the configured globs. For each file with at least
71
+ * one class, writes a companion stub to `<outputDir>/<rel-path>.lombok.ts`.
72
+ */
73
+ generate(): Promise<GeneratedFile[]>;
74
+ /** Generate code for a single source file path. */
75
+ generateForFile(filePath: string): Promise<GeneratedFile | null>;
76
+ /** Watch mode is not implemented yet. Re-run `lombok-ts generate` for now. */
77
+ watch(): Promise<void>;
78
+ protected createProject(): Project;
79
+ protected shouldProcess(filePath: string): boolean;
80
+ protected computeOutputPath(sourcePath: string): string;
81
+ protected renderCompanion(_sourcePath: string, _classes: readonly ClassInfo[]): string;
82
+ protected writeOutput(outputPath: string, content: string): void;
83
+ }
84
+
85
+ /**
86
+ * Placeholder for a TypeScript compiler transformer that would run codegen as
87
+ * part of `tsc` itself (via `ts-patch` or `ttypescript`).
88
+ *
89
+ * For now the standalone `lombok-ts` CLI is the only codegen path. This file
90
+ * exists so importing a transformer gives a clear "not yet" rather than a
91
+ * module-not-found.
92
+ */
93
+ declare class LombokTransformer {
94
+ constructor();
95
+ }
96
+
97
+ /**
98
+ * Walk every class in `sourceFile` and return their decorator/field/method
99
+ * shapes as plain data. No ts-morph references leak out.
100
+ */
101
+ declare function analyzeFile(sourceFile: SourceFile): ClassInfo[];
102
+ /** Find one class by name in the source file. Returns `undefined` if missing. */
103
+ declare function analyzeClassByName(sourceFile: SourceFile, className: string): ClassInfo | undefined;
104
+ /** Parse a source string in an in-memory project and analyze every class in it. */
105
+ declare function analyzeSourceString(sourceCode: string, fileName?: string): ClassInfo[];
106
+ /** Analyze a single named class in a source string. Throws if not found. */
107
+ declare function analyzeClass(sourceCode: string, className: string): ClassInfo;
108
+
109
+ export { type ClassInfo, CodeGenerator, type DecoratorInfo, type FieldInfo, type GeneratedFile, type GeneratorOptions, LombokTransformer, type MethodInfo, type ParameterInfo, analyzeClass, analyzeClassByName, analyzeFile, analyzeSourceString };