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.
- package/LICENSE +21 -0
- package/README.md +98 -0
- package/dist/backend-CkLBcDd8.d.cts +59 -0
- package/dist/backend-CkLBcDd8.d.ts +59 -0
- package/dist/cli/index.cjs +585 -0
- package/dist/cli/index.cjs.map +1 -0
- package/dist/cli/index.d.cts +14 -0
- package/dist/cli/index.d.ts +14 -0
- package/dist/cli/index.js +579 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/codegen/index.cjs +450 -0
- package/dist/codegen/index.cjs.map +1 -0
- package/dist/codegen/index.d.cts +109 -0
- package/dist/codegen/index.d.ts +109 -0
- package/dist/codegen/index.js +443 -0
- package/dist/codegen/index.js.map +1 -0
- package/dist/core/index.cjs +132 -0
- package/dist/core/index.cjs.map +1 -0
- package/dist/core/index.d.cts +73 -0
- package/dist/core/index.d.ts +73 -0
- package/dist/core/index.js +128 -0
- package/dist/core/index.js.map +1 -0
- package/dist/index.cjs +142 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +93 -0
- package/dist/index.d.ts +93 -0
- package/dist/index.js +136 -0
- package/dist/index.js.map +1 -0
- package/dist/legacy/index.cjs +271 -0
- package/dist/legacy/index.cjs.map +1 -0
- package/dist/legacy/index.d.cts +32 -0
- package/dist/legacy/index.d.ts +32 -0
- package/dist/legacy/index.js +252 -0
- package/dist/legacy/index.js.map +1 -0
- package/dist/memoize-Bj9pm_cK.d.cts +48 -0
- package/dist/memoize-DvelzGDl.d.ts +48 -0
- package/dist/stage3/index.cjs +275 -0
- package/dist/stage3/index.cjs.map +1 -0
- package/dist/stage3/index.d.cts +97 -0
- package/dist/stage3/index.d.ts +97 -0
- package/dist/stage3/index.js +255 -0
- package/dist/stage3/index.js.map +1 -0
- package/package.json +120 -0
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
// src/core/metadata-store.ts
|
|
2
|
+
var WeakMapMetadataStore = class {
|
|
3
|
+
classScopes = /* @__PURE__ */ new WeakMap();
|
|
4
|
+
memberScopes = /* @__PURE__ */ new WeakMap();
|
|
5
|
+
set(key, target, propertyKey, value) {
|
|
6
|
+
const bucket = this.bucket(target, propertyKey, true);
|
|
7
|
+
bucket.set(key, value);
|
|
8
|
+
}
|
|
9
|
+
get(key, target, propertyKey) {
|
|
10
|
+
const bucket = this.bucket(target, propertyKey, false);
|
|
11
|
+
return bucket?.get(key);
|
|
12
|
+
}
|
|
13
|
+
has(key, target, propertyKey) {
|
|
14
|
+
const bucket = this.bucket(target, propertyKey, false);
|
|
15
|
+
return bucket?.has(key) ?? false;
|
|
16
|
+
}
|
|
17
|
+
delete(key, target, propertyKey) {
|
|
18
|
+
const bucket = this.bucket(target, propertyKey, false);
|
|
19
|
+
if (!bucket) return false;
|
|
20
|
+
return bucket.delete(key);
|
|
21
|
+
}
|
|
22
|
+
list(target, propertyKey) {
|
|
23
|
+
const bucket = this.bucket(target, propertyKey, false);
|
|
24
|
+
if (!bucket) return [];
|
|
25
|
+
return Array.from(bucket.keys());
|
|
26
|
+
}
|
|
27
|
+
bucket(target, propertyKey, createIfMissing) {
|
|
28
|
+
if (propertyKey === void 0) {
|
|
29
|
+
let bucket2 = this.classScopes.get(target);
|
|
30
|
+
if (!bucket2 && createIfMissing) {
|
|
31
|
+
bucket2 = /* @__PURE__ */ new Map();
|
|
32
|
+
this.classScopes.set(target, bucket2);
|
|
33
|
+
}
|
|
34
|
+
return bucket2;
|
|
35
|
+
}
|
|
36
|
+
let perTarget = this.memberScopes.get(target);
|
|
37
|
+
if (!perTarget) {
|
|
38
|
+
if (!createIfMissing) return void 0;
|
|
39
|
+
perTarget = /* @__PURE__ */ new Map();
|
|
40
|
+
this.memberScopes.set(target, perTarget);
|
|
41
|
+
}
|
|
42
|
+
let bucket = perTarget.get(propertyKey);
|
|
43
|
+
if (!bucket) {
|
|
44
|
+
if (!createIfMissing) return void 0;
|
|
45
|
+
bucket = /* @__PURE__ */ new Map();
|
|
46
|
+
perTarget.set(propertyKey, bucket);
|
|
47
|
+
}
|
|
48
|
+
return bucket;
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
// src/stage3/backend.ts
|
|
53
|
+
var Stage3Backend = class {
|
|
54
|
+
kind = "stage3";
|
|
55
|
+
metadata = new WeakMapMetadataStore();
|
|
56
|
+
};
|
|
57
|
+
var stage3Backend = new Stage3Backend();
|
|
58
|
+
|
|
59
|
+
// src/stage3/decorate.ts
|
|
60
|
+
function defineClassDecorator(logic) {
|
|
61
|
+
return function decorator(value, context) {
|
|
62
|
+
return logic(stage3Backend, value, context);
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
function defineFieldDecorator(logic) {
|
|
66
|
+
return function decorator(_value, context) {
|
|
67
|
+
return logic(stage3Backend, context);
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
function defineMethodDecorator(logic) {
|
|
71
|
+
return function decorator(value, context) {
|
|
72
|
+
return logic(stage3Backend, value, context);
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
function defineGetterDecorator(logic) {
|
|
76
|
+
return function decorator(value, context) {
|
|
77
|
+
return logic(stage3Backend, value, context);
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
function defineSetterDecorator(logic) {
|
|
81
|
+
return function decorator(value, context) {
|
|
82
|
+
return logic(stage3Backend, value, context);
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// src/core/metadata-keys.ts
|
|
87
|
+
var PREFIX = "lombok-ts:";
|
|
88
|
+
var MetadataKeys = {
|
|
89
|
+
// Class-level (Lombok)
|
|
90
|
+
DATA: `${PREFIX}data`,
|
|
91
|
+
BUILDER: `${PREFIX}builder`,
|
|
92
|
+
TO_STRING: `${PREFIX}toString`,
|
|
93
|
+
// Class-level (GoF)
|
|
94
|
+
SINGLETON: `${PREFIX}singleton`,
|
|
95
|
+
FACTORY: `${PREFIX}factory`,
|
|
96
|
+
PROTOTYPE: `${PREFIX}prototype`,
|
|
97
|
+
NON_NULL: `${PREFIX}nonNull`,
|
|
98
|
+
// Method-level
|
|
99
|
+
MEMOIZE: `${PREFIX}memoize`};
|
|
100
|
+
|
|
101
|
+
// src/decorators/shared/factory.ts
|
|
102
|
+
var factoryRegistry = /* @__PURE__ */ new Map();
|
|
103
|
+
function registerFactory(key, ctor) {
|
|
104
|
+
factoryRegistry.set(key, ctor);
|
|
105
|
+
}
|
|
106
|
+
function createFromFactory(key, ...args) {
|
|
107
|
+
const ctor = factoryRegistry.get(key);
|
|
108
|
+
if (!ctor) {
|
|
109
|
+
throw new Error(`No factory registered for key "${key}"`);
|
|
110
|
+
}
|
|
111
|
+
return new ctor(...args);
|
|
112
|
+
}
|
|
113
|
+
function getFactoryRegistry() {
|
|
114
|
+
return factoryRegistry;
|
|
115
|
+
}
|
|
116
|
+
function factoryClassStage3(backend, _value, context, key) {
|
|
117
|
+
backend.metadata.set(MetadataKeys.FACTORY, context.metadata, void 0, key);
|
|
118
|
+
registerFactory(key, _value);
|
|
119
|
+
}
|
|
120
|
+
function codegenClassMarkerStage3(backend, _value, context, metadataKey) {
|
|
121
|
+
backend.metadata.set(metadataKey, context.metadata, void 0, true);
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
// src/decorators/shared/non-null.ts
|
|
125
|
+
function assertNonNull(value, label) {
|
|
126
|
+
if (value === null || value === void 0) {
|
|
127
|
+
throw new TypeError(`${label} must not be null or undefined`);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
function nonNullFieldStage3(backend, context) {
|
|
131
|
+
backend.metadata.set(MetadataKeys.NON_NULL, context.metadata, context.name, true);
|
|
132
|
+
const name = String(context.name);
|
|
133
|
+
return function(initialValue) {
|
|
134
|
+
assertNonNull(initialValue, name);
|
|
135
|
+
return initialValue;
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
// src/decorators/shared/singleton.ts
|
|
140
|
+
function singletonClassStage3(backend, value, context) {
|
|
141
|
+
backend.metadata.set(MetadataKeys.SINGLETON, context.metadata, void 0, true);
|
|
142
|
+
const Singleton2 = class extends value {
|
|
143
|
+
static #instance;
|
|
144
|
+
constructor(...args) {
|
|
145
|
+
if (Singleton2.#instance) {
|
|
146
|
+
return Singleton2.#instance;
|
|
147
|
+
}
|
|
148
|
+
super(...args);
|
|
149
|
+
Singleton2.#instance = this;
|
|
150
|
+
}
|
|
151
|
+
};
|
|
152
|
+
return Singleton2;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
// src/utils/index.ts
|
|
156
|
+
function deepClone(obj) {
|
|
157
|
+
if (obj === null || typeof obj !== "object") {
|
|
158
|
+
return obj;
|
|
159
|
+
}
|
|
160
|
+
if (Array.isArray(obj)) {
|
|
161
|
+
return obj.map((item) => deepClone(item));
|
|
162
|
+
}
|
|
163
|
+
const cloned = {};
|
|
164
|
+
for (const key in obj) {
|
|
165
|
+
if (Object.prototype.hasOwnProperty.call(obj, key)) {
|
|
166
|
+
cloned[key] = deepClone(obj[key]);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
return cloned;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
// src/decorators/shared/prototype.ts
|
|
173
|
+
function prototypeClassStage3(backend, value, context) {
|
|
174
|
+
backend.metadata.set(MetadataKeys.PROTOTYPE, context.metadata, void 0, true);
|
|
175
|
+
const Prototype2 = class extends value {
|
|
176
|
+
constructor(...args) {
|
|
177
|
+
super(...args);
|
|
178
|
+
const clone = deepClone(this);
|
|
179
|
+
return clone;
|
|
180
|
+
}
|
|
181
|
+
};
|
|
182
|
+
return Prototype2;
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
// src/decorators/shared/memoize.ts
|
|
186
|
+
var CACHE_MISS = /* @__PURE__ */ Symbol("memoize-cache-miss");
|
|
187
|
+
function buildCacheKey(args) {
|
|
188
|
+
return JSON.stringify(args);
|
|
189
|
+
}
|
|
190
|
+
function getFromCache(cache, key, ttl) {
|
|
191
|
+
const entry = cache.get(key);
|
|
192
|
+
if (!entry) return CACHE_MISS;
|
|
193
|
+
if (ttl !== void 0 && entry.expiresAt !== void 0 && Date.now() > entry.expiresAt) {
|
|
194
|
+
cache.delete(key);
|
|
195
|
+
return CACHE_MISS;
|
|
196
|
+
}
|
|
197
|
+
return entry.value;
|
|
198
|
+
}
|
|
199
|
+
function memoizeMethod(original, options = {}) {
|
|
200
|
+
const cache = /* @__PURE__ */ new Map();
|
|
201
|
+
const ttl = options.ttl;
|
|
202
|
+
return function(...args) {
|
|
203
|
+
const key = buildCacheKey(args);
|
|
204
|
+
const cached = getFromCache(cache, key, ttl);
|
|
205
|
+
if (cached !== CACHE_MISS) {
|
|
206
|
+
return cached;
|
|
207
|
+
}
|
|
208
|
+
const result = original.apply(this, args);
|
|
209
|
+
const entry = { value: result };
|
|
210
|
+
if (ttl !== void 0) {
|
|
211
|
+
entry.expiresAt = Date.now() + ttl;
|
|
212
|
+
}
|
|
213
|
+
cache.set(key, entry);
|
|
214
|
+
return result;
|
|
215
|
+
};
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
// src/decorators/shared/memoize-logic.ts
|
|
219
|
+
function memoizeMethodStage3(backend, value, context, options = {}) {
|
|
220
|
+
backend.metadata.set(MetadataKeys.MEMOIZE, context.metadata, context.name, options);
|
|
221
|
+
return memoizeMethod(value, options);
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
// src/decorators/stage3/index.ts
|
|
225
|
+
var NonNull = defineFieldDecorator(nonNullFieldStage3);
|
|
226
|
+
var Singleton = defineClassDecorator(singletonClassStage3);
|
|
227
|
+
var Prototype = defineClassDecorator(prototypeClassStage3);
|
|
228
|
+
function Memoize(options = {}) {
|
|
229
|
+
return defineMethodDecorator(
|
|
230
|
+
(backend, value, context) => memoizeMethodStage3(backend, value, context, options)
|
|
231
|
+
);
|
|
232
|
+
}
|
|
233
|
+
function Factory(key) {
|
|
234
|
+
return defineClassDecorator((backend, value, context) => {
|
|
235
|
+
factoryClassStage3(backend, value, context, key);
|
|
236
|
+
});
|
|
237
|
+
}
|
|
238
|
+
var Data = defineClassDecorator(
|
|
239
|
+
(backend, value, context) => codegenClassMarkerStage3(backend, value, context, MetadataKeys.DATA)
|
|
240
|
+
);
|
|
241
|
+
var Builder = defineClassDecorator(
|
|
242
|
+
(backend, value, context) => codegenClassMarkerStage3(backend, value, context, MetadataKeys.BUILDER)
|
|
243
|
+
);
|
|
244
|
+
var ToString = defineClassDecorator(
|
|
245
|
+
(backend, value, context) => codegenClassMarkerStage3(backend, value, context, MetadataKeys.TO_STRING)
|
|
246
|
+
);
|
|
247
|
+
|
|
248
|
+
// src/stage3/index.ts
|
|
249
|
+
function getClassMetadata(cls) {
|
|
250
|
+
return cls[Symbol.metadata];
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
export { Builder, Data, Factory, Memoize, NonNull, Prototype, Singleton, Stage3Backend, ToString, createFromFactory, defineClassDecorator, defineFieldDecorator, defineGetterDecorator, defineMethodDecorator, defineSetterDecorator, getClassMetadata, getFactoryRegistry, registerFactory, stage3Backend };
|
|
254
|
+
//# sourceMappingURL=index.js.map
|
|
255
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/core/metadata-store.ts","../../src/stage3/backend.ts","../../src/stage3/decorate.ts","../../src/core/metadata-keys.ts","../../src/decorators/shared/factory.ts","../../src/decorators/shared/non-null.ts","../../src/decorators/shared/singleton.ts","../../src/utils/index.ts","../../src/decorators/shared/prototype.ts","../../src/decorators/shared/memoize.ts","../../src/decorators/shared/memoize-logic.ts","../../src/decorators/stage3/index.ts","../../src/stage3/index.ts"],"names":["bucket","Singleton","Prototype"],"mappings":"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","file":"index.js","sourcesContent":["import type { MetadataKeyList, PropertyName } from './types.js';\n\n/**\n * Storage interface used by both decorator backends. Legacy delegates to\n * `reflect-metadata`; Stage 3 uses the WeakMap implementation below.\n */\nexport interface MetadataStore {\n /** Store `value` under `key`. Omit `propertyKey` for class-level scope. */\n set<V>(key: string, target: object, propertyKey: PropertyName | undefined, value: V): void;\n\n /** Read the value stored under `key`, or `undefined`. */\n get<V>(key: string, target: object, propertyKey?: PropertyName): V | undefined;\n\n /** True if `key` exists at the given scope. */\n has(key: string, target: object, propertyKey?: PropertyName): boolean;\n\n /** Remove the entry. Returns true if it existed. */\n delete(key: string, target: object, propertyKey?: PropertyName): boolean;\n\n /** All keys at the given scope. */\n list(target: object, propertyKey?: PropertyName): MetadataKeyList;\n}\n\n/**\n * WeakMap-backed `MetadataStore`. Used directly by the Stage 3 backend.\n * Layout: target -> (propertyKey or class-level) -> key -> value.\n */\nexport class WeakMapMetadataStore implements MetadataStore {\n private readonly classScopes = new WeakMap<object, Map<string, unknown>>();\n private readonly memberScopes = new WeakMap<object, Map<string | symbol, Map<string, unknown>>>();\n\n set<V>(key: string, target: object, propertyKey: PropertyName | undefined, value: V): void {\n const bucket = this.bucket(target, propertyKey, true)!;\n bucket.set(key, value);\n }\n\n get<V>(key: string, target: object, propertyKey?: PropertyName): V | undefined {\n const bucket = this.bucket(target, propertyKey, false);\n return bucket?.get(key) as V | undefined;\n }\n\n has(key: string, target: object, propertyKey?: PropertyName): boolean {\n const bucket = this.bucket(target, propertyKey, false);\n return bucket?.has(key) ?? false;\n }\n\n delete(key: string, target: object, propertyKey?: PropertyName): boolean {\n const bucket = this.bucket(target, propertyKey, false);\n if (!bucket) return false;\n return bucket.delete(key);\n }\n\n list(target: object, propertyKey?: PropertyName): MetadataKeyList {\n const bucket = this.bucket(target, propertyKey, false);\n if (!bucket) return [];\n return Array.from(bucket.keys());\n }\n\n private bucket(\n target: object,\n propertyKey: PropertyName | undefined,\n createIfMissing: boolean,\n ): Map<string, unknown> | undefined {\n if (propertyKey === undefined) {\n let bucket = this.classScopes.get(target);\n if (!bucket && createIfMissing) {\n bucket = new Map();\n this.classScopes.set(target, bucket);\n }\n return bucket;\n }\n\n let perTarget = this.memberScopes.get(target);\n if (!perTarget) {\n if (!createIfMissing) return undefined;\n perTarget = new Map();\n this.memberScopes.set(target, perTarget);\n }\n\n let bucket = perTarget.get(propertyKey);\n if (!bucket) {\n if (!createIfMissing) return undefined;\n bucket = new Map();\n perTarget.set(propertyKey, bucket);\n }\n return bucket;\n }\n}\n","import type { Backend } from '../core/backend.js';\nimport type { MetadataStore } from '../core/metadata-store.js';\nimport { WeakMapMetadataStore } from '../core/metadata-store.js';\n\n/**\n * Backend for the Stage 3 ECMAScript decorator standard (TS 5.0+).\n *\n * Stage 3 doesn't use `reflect-metadata`. Each decorator's `context.metadata`\n * is a per-class `Record<PropertyKey, unknown>` accessible at runtime as\n * `MyClass[Symbol.metadata]`. We key the WeakMap on that object so all\n * decorators on the same class share storage and consumers can recover the\n * metadata at runtime via `Class[Symbol.metadata]`.\n *\n * @see https://github.com/tc39/proposal-decorators\n * @see https://github.com/tc39/proposal-decorator-metadata\n */\nexport class Stage3Backend implements Backend {\n readonly kind = 'stage3' as const;\n readonly metadata: MetadataStore = new WeakMapMetadataStore();\n}\n\n/** Shared instance. */\nexport const stage3Backend = new Stage3Backend();\n","import type { Backend } from '../core/backend.js';\nimport type { AnyClass } from '../legacy/decorate.js';\nimport { stage3Backend } from './backend.js';\n\n/**\n * Logic shapes for Stage 3 decorator authoring.\n *\n * Stage 3 contexts are richer than legacy: `context.metadata` holds per-class\n * storage, `context.addInitializer(fn)` hooks into instance construction, and\n * `context.access` exposes get/set helpers. Logic functions get the full\n * context so they can use any of it.\n */\nexport type Stage3ClassLogic = (\n backend: Backend,\n value: AnyClass,\n context: ClassDecoratorContext,\n) => AnyClass | void;\n\nexport type Stage3FieldLogic<This = unknown, Value = unknown> = (\n backend: Backend,\n context: ClassFieldDecoratorContext<This, Value>,\n) => ((this: This, initialValue: Value) => Value) | void;\n\nexport type Stage3MethodLogic<\n This = unknown,\n Args extends unknown[] = unknown[],\n Return = unknown,\n> = (\n backend: Backend,\n value: (this: This, ...args: Args) => Return,\n context: ClassMethodDecoratorContext<This, (this: This, ...args: Args) => Return>,\n) => ((this: This, ...args: Args) => Return) | void;\n\nexport type Stage3GetterLogic<This = unknown, Value = unknown> = (\n backend: Backend,\n value: (this: This) => Value,\n context: ClassGetterDecoratorContext<This, Value>,\n) => ((this: This) => Value) | void;\n\nexport type Stage3SetterLogic<This = unknown, Value = unknown> = (\n backend: Backend,\n value: (this: This, v: Value) => void,\n context: ClassSetterDecoratorContext<This, Value>,\n) => ((this: This, v: Value) => void) | void;\n\n/**\n * Build a Stage 3 class decorator.\n *\n * @example\n * const Tracked = defineClassDecorator((backend, _value, context) => {\n * backend.metadata.set('tracked', context.metadata as object, undefined, true);\n * });\n */\nexport function defineClassDecorator(\n logic: Stage3ClassLogic,\n): <T extends AnyClass>(value: T, context: ClassDecoratorContext) => T | void {\n return function decorator<T extends AnyClass>(\n value: T,\n context: ClassDecoratorContext,\n ): T | void {\n return logic(stage3Backend, value, context) as T | void;\n };\n}\n\n/**\n * Build a Stage 3 field decorator. The logic can return an initializer\n * transformer that receives the field's initial value and returns the value\n * to store. Returning `void` leaves the initializer alone.\n */\nexport function defineFieldDecorator<This = unknown, Value = unknown>(\n logic: Stage3FieldLogic<This, Value>,\n) {\n return function decorator(\n _value: undefined,\n context: ClassFieldDecoratorContext<This, Value>,\n ): ((this: This, initialValue: Value) => Value) | void {\n return logic(stage3Backend, context);\n };\n}\n\n/** Build a Stage 3 method decorator. The logic may return a wrapping function. */\nexport function defineMethodDecorator<\n This = unknown,\n Args extends unknown[] = unknown[],\n Return = unknown,\n>(logic: Stage3MethodLogic<This, Args, Return>) {\n return function decorator(\n value: (this: This, ...args: Args) => Return,\n context: ClassMethodDecoratorContext<This, (this: This, ...args: Args) => Return>,\n ): ((this: This, ...args: Args) => Return) | void {\n return logic(stage3Backend, value, context);\n };\n}\n\n/** Build a Stage 3 getter decorator. */\nexport function defineGetterDecorator<This = unknown, Value = unknown>(\n logic: Stage3GetterLogic<This, Value>,\n) {\n return function decorator(\n value: (this: This) => Value,\n context: ClassGetterDecoratorContext<This, Value>,\n ): ((this: This) => Value) | void {\n return logic(stage3Backend, value, context);\n };\n}\n\n/** Build a Stage 3 setter decorator. */\nexport function defineSetterDecorator<This = unknown, Value = unknown>(\n logic: Stage3SetterLogic<This, Value>,\n) {\n return function decorator(\n value: (this: This, v: Value) => void,\n context: ClassSetterDecoratorContext<This, Value>,\n ): ((this: This, v: Value) => void) | void {\n return logic(stage3Backend, value, context);\n };\n}\n","/**\n * Metadata keys used across the library. Adding one? Use the `lombok-ts:`\n * prefix and check `metadata-keys.test.ts` so uniqueness stays enforced.\n */\n\nconst PREFIX = 'lombok-ts:';\n\nexport const MetadataKeys = {\n // Class-level (Lombok)\n DATA: `${PREFIX}data`,\n VALUE: `${PREFIX}value`,\n BUILDER: `${PREFIX}builder`,\n TO_STRING: `${PREFIX}toString`,\n EQUALS: `${PREFIX}equals`,\n UTILITY_CLASS: `${PREFIX}utilityClass`,\n FIELD_DEFAULTS: `${PREFIX}fieldDefaults`,\n ACCESSORS: `${PREFIX}accessors`,\n LOG: `${PREFIX}log`,\n\n // Class-level (TS-only)\n OBSERVABLE: `${PREFIX}observable`,\n SERIALIZABLE: `${PREFIX}serializable`,\n DEEP_FREEZE: `${PREFIX}deepFreeze`,\n TRACE: `${PREFIX}trace`,\n\n // Class-level (GoF)\n SINGLETON: `${PREFIX}singleton`,\n FACTORY: `${PREFIX}factory`,\n ABSTRACT_FACTORY: `${PREFIX}abstractFactory`,\n PROTOTYPE: `${PREFIX}prototype`,\n ADAPTER: `${PREFIX}adapter`,\n BRIDGE: `${PREFIX}bridge`,\n COMPOSITE: `${PREFIX}composite`,\n WRAPS: `${PREFIX}wraps`,\n FACADE: `${PREFIX}facade`,\n FLYWEIGHT: `${PREFIX}flyweight`,\n PROXY: `${PREFIX}proxy`,\n CHAIN_OF_RESPONSIBILITY: `${PREFIX}chainOfResponsibility`,\n COMMAND: `${PREFIX}command`,\n INTERPRETER: `${PREFIX}interpreter`,\n ITERABLE: `${PREFIX}iterable`,\n MEDIATOR: `${PREFIX}mediator`,\n MEMENTO: `${PREFIX}memento`,\n STATE: `${PREFIX}state`,\n STRATEGY: `${PREFIX}strategy`,\n TEMPLATE_METHOD: `${PREFIX}templateMethod`,\n VISITABLE: `${PREFIX}visitable`,\n VISITOR: `${PREFIX}visitor`,\n\n // Field-level\n GETTER: `${PREFIX}getter`,\n SETTER: `${PREFIX}setter`,\n NON_NULL: `${PREFIX}nonNull`,\n WITH: `${PREFIX}with`,\n DELEGATE: `${PREFIX}delegate`,\n VALIDATE: `${PREFIX}validate`,\n TO_STRING_EXCLUDE: `${PREFIX}toString:exclude`,\n TO_STRING_INCLUDE: `${PREFIX}toString:include`,\n EQUALS_EXCLUDE: `${PREFIX}equals:exclude`,\n SERIALIZABLE_EXCLUDE: `${PREFIX}serializable:exclude`,\n SERIALIZABLE_TRANSFORM: `${PREFIX}serializable:transform`,\n SERIALIZABLE_ALIAS: `${PREFIX}serializable:alias`,\n BUILDER_DEFAULT: `${PREFIX}builder:default`,\n SINGULAR: `${PREFIX}singular`,\n ITERATE_OVER: `${PREFIX}iterateOver`,\n\n // Method-level\n MEMOIZE: `${PREFIX}memoize`,\n DEBOUNCE: `${PREFIX}debounce`,\n THROTTLE: `${PREFIX}throttle`,\n RETRY: `${PREFIX}retry`,\n HANDLER: `${PREFIX}handler`,\n TRANSITION: `${PREFIX}transition`,\n HOOK: `${PREFIX}hook`,\n\n // Parameter-level\n NON_NULL_PARAM: `${PREFIX}nonNull:param`,\n\n // Internal, framework-managed\n FIELDS: `${PREFIX}internal:fields`,\n CONSTRUCTOR_PARAMS: `${PREFIX}internal:constructorParams`,\n BACKEND: `${PREFIX}internal:backend`,\n} as const;\n\nexport type MetadataKey = (typeof MetadataKeys)[keyof typeof MetadataKeys];\n\nexport const METADATA_KEY_PREFIX = PREFIX;\n","import type { Backend } from '../../core/backend.js';\nimport { MetadataKeys } from '../../core/metadata-keys.js';\nimport type { AnyClass } from '../../legacy/decorate.js';\n\n/** Global factory registry keyed by `@Factory('key')` string. */\nconst factoryRegistry = new Map<string, AnyClass>();\n\nexport function registerFactory(key: string, ctor: AnyClass): void {\n factoryRegistry.set(key, ctor);\n}\n\nexport function createFromFactory<T = unknown>(key: string, ...args: unknown[]): T {\n const ctor = factoryRegistry.get(key);\n if (!ctor) {\n throw new Error(`No factory registered for key \"${key}\"`);\n }\n return new ctor(...args) as T;\n}\n\nexport function getFactoryRegistry(): ReadonlyMap<string, AnyClass> {\n return factoryRegistry;\n}\n\nexport function factoryClassLegacy(backend: Backend, target: AnyClass, key: string): void {\n backend.metadata.set(MetadataKeys.FACTORY, target, undefined, key);\n registerFactory(key, target);\n}\n\nexport function factoryClassStage3(\n backend: Backend,\n _value: AnyClass,\n context: ClassDecoratorContext,\n key: string,\n): void {\n backend.metadata.set(MetadataKeys.FACTORY, context.metadata as object, undefined, key);\n registerFactory(key, _value);\n}\n\nexport function codegenClassMarkerLegacy(\n backend: Backend,\n target: AnyClass,\n metadataKey: string,\n): void {\n backend.metadata.set(metadataKey, target, undefined, true);\n}\n\nexport function codegenClassMarkerStage3(\n backend: Backend,\n _value: AnyClass,\n context: ClassDecoratorContext,\n metadataKey: string,\n): void {\n backend.metadata.set(metadataKey, context.metadata as object, undefined, true);\n}\n","import type { Backend } from '../../core/backend.js';\nimport { MetadataKeys } from '../../core/metadata-keys.js';\nimport type { PropertyName } from '../../core/types.js';\n\nexport function assertNonNull(value: unknown, label: string): void {\n if (value === null || value === undefined) {\n throw new TypeError(`${label} must not be null or undefined`);\n }\n}\n\nexport function nonNullFieldLegacy(\n backend: Backend,\n targetPrototype: object,\n propertyKey: PropertyName,\n): void {\n backend.metadata.set(MetadataKeys.NON_NULL, targetPrototype, propertyKey, true);\n const key = String(propertyKey);\n let stored: unknown;\n\n Object.defineProperty(targetPrototype, propertyKey, {\n configurable: true,\n enumerable: true,\n get() {\n return stored;\n },\n set(value: unknown) {\n assertNonNull(value, key);\n stored = value;\n },\n });\n}\n\nexport function nonNullParameterLegacy(\n backend: Backend,\n targetPrototype: object,\n propertyKey: PropertyName | undefined,\n parameterIndex: number,\n): void {\n backend.metadata.set(MetadataKeys.NON_NULL_PARAM, targetPrototype, propertyKey, parameterIndex);\n}\n\nexport function wrapMethodWithNonNullParams(\n original: (...args: unknown[]) => unknown,\n paramIndices: number[],\n methodName: string,\n): (...args: unknown[]) => unknown {\n return function (this: unknown, ...args: unknown[]) {\n for (const index of paramIndices) {\n assertNonNull(args[index], `${methodName} argument at index ${index}`);\n }\n return original.apply(this, args);\n };\n}\n\nexport function nonNullFieldStage3<This, Value>(\n backend: Backend,\n context: ClassFieldDecoratorContext<This, Value>,\n): ((this: This, initialValue: Value) => Value) | void {\n backend.metadata.set(MetadataKeys.NON_NULL, context.metadata as object, context.name, true);\n const name = String(context.name);\n return function (initialValue: Value): Value {\n assertNonNull(initialValue, name);\n return initialValue;\n };\n}\n","import type { Backend } from '../../core/backend.js';\nimport { MetadataKeys } from '../../core/metadata-keys.js';\nimport type { AnyClass } from '../../legacy/decorate.js';\n\nexport function singletonClassLegacy(backend: Backend, target: AnyClass): AnyClass {\n backend.metadata.set(MetadataKeys.SINGLETON, target, undefined, true);\n\n const Singleton = class extends target {\n static #instance: object | undefined;\n\n constructor(...args: unknown[]) {\n if (Singleton.#instance) {\n return Singleton.#instance;\n }\n super(...args);\n Singleton.#instance = this as object;\n }\n };\n\n return Singleton as AnyClass;\n}\n\nexport function singletonClassStage3(\n backend: Backend,\n value: AnyClass,\n context: ClassDecoratorContext,\n): AnyClass {\n backend.metadata.set(MetadataKeys.SINGLETON, context.metadata as object, undefined, true);\n\n const Singleton = class extends value {\n static #instance: object | undefined;\n\n constructor(...args: unknown[]) {\n if (Singleton.#instance) {\n return Singleton.#instance;\n }\n super(...args);\n Singleton.#instance = this as object;\n }\n };\n\n return Singleton as AnyClass;\n}\n","/** Recursively clones primitives, arrays, and plain objects. */\nexport function deepClone<T>(obj: T): T {\n if (obj === null || typeof obj !== 'object') {\n return obj;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => deepClone(item)) as T;\n }\n\n const cloned = {} as T;\n for (const key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n cloned[key] = deepClone(obj[key]);\n }\n }\n return cloned;\n}\n\n/** Freezes an object and recursively freezes its nested objects. */\nexport function deepFreeze<T extends object>(obj: T): Readonly<T> {\n Object.freeze(obj);\n\n for (const key of Object.keys(obj) as (keyof T)[]) {\n const value = obj[key];\n if (value !== null && typeof value === 'object' && !Object.isFrozen(value)) {\n deepFreeze(value as object);\n }\n }\n\n return obj;\n}\n\n/** Structural equality for primitives, arrays, and plain objects. */\nexport function deepEquals(a: unknown, b: unknown): boolean {\n if (a === b) return true;\n\n if (typeof a !== typeof b) return false;\n\n if (a === null || b === null) return a === b;\n\n if (typeof a !== 'object' || typeof b !== 'object') return false;\n\n if (Array.isArray(a) !== Array.isArray(b)) return false;\n\n if (Array.isArray(a) && Array.isArray(b)) {\n if (a.length !== b.length) return false;\n return a.every((item, index) => deepEquals(item, b[index]));\n }\n\n const aKeys = Object.keys(a as object);\n const bKeys = Object.keys(b as object);\n\n if (aKeys.length !== bKeys.length) return false;\n\n return aKeys.every((key) =>\n deepEquals((a as Record<string, unknown>)[key], (b as Record<string, unknown>)[key]),\n );\n}\n\n/** djb2-ish 32-bit hash over the JSON-serialized value. */\nexport function hashCode(obj: unknown): number {\n const str = JSON.stringify(obj);\n let hash = 0;\n for (let i = 0; i < str.length; i++) {\n const char = str.charCodeAt(i);\n hash = (hash << 5) - hash + char;\n hash = hash & hash;\n }\n return hash;\n}\n\n/** Uppercase the first letter. */\nexport function capitalize(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\n/** Strip dashes/underscores, capitalize the next character. */\nexport function toCamelCase(str: string): string {\n return str.replace(/[-_](.)/g, (_, char) => char.toUpperCase());\n}\n\n/** `toCamelCase` plus uppercase first letter. */\nexport function toPascalCase(str: string): string {\n const camel = toCamelCase(str);\n return capitalize(camel);\n}\n","import type { Backend } from '../../core/backend.js';\nimport { MetadataKeys } from '../../core/metadata-keys.js';\nimport type { AnyClass } from '../../legacy/decorate.js';\nimport { deepClone } from '../../utils/index.js';\n\nexport function prototypeClassLegacy(backend: Backend, target: AnyClass): AnyClass {\n backend.metadata.set(MetadataKeys.PROTOTYPE, target, undefined, true);\n\n const Prototype = class extends target {\n constructor(...args: unknown[]) {\n super(...args);\n const clone = deepClone(this) as object;\n return clone;\n }\n };\n\n return Prototype as AnyClass;\n}\n\nexport function prototypeClassStage3(\n backend: Backend,\n value: AnyClass,\n context: ClassDecoratorContext,\n): AnyClass {\n backend.metadata.set(MetadataKeys.PROTOTYPE, context.metadata as object, undefined, true);\n\n const Prototype = class extends value {\n constructor(...args: unknown[]) {\n super(...args);\n const clone = deepClone(this) as object;\n return clone;\n }\n };\n\n return Prototype as AnyClass;\n}\n","export interface MemoizeOptions {\n /** Time-to-live in milliseconds. Omit for infinite cache. */\n ttl?: number;\n}\n\ninterface CacheEntry {\n value: unknown;\n expiresAt?: number;\n}\n\nconst CACHE_MISS = Symbol('memoize-cache-miss');\n\nfunction buildCacheKey(args: unknown[]): string {\n return JSON.stringify(args);\n}\n\nfunction getFromCache(\n cache: Map<string, CacheEntry>,\n key: string,\n ttl?: number,\n): unknown | typeof CACHE_MISS {\n const entry = cache.get(key);\n if (!entry) return CACHE_MISS;\n if (ttl !== undefined && entry.expiresAt !== undefined && Date.now() > entry.expiresAt) {\n cache.delete(key);\n return CACHE_MISS;\n }\n return entry.value;\n}\n\nexport function memoizeMethod<T extends (...args: unknown[]) => unknown>(\n original: T,\n options: MemoizeOptions = {},\n): T {\n const cache = new Map<string, CacheEntry>();\n const ttl = options.ttl;\n\n return function (this: unknown, ...args: unknown[]) {\n const key = buildCacheKey(args);\n const cached = getFromCache(cache, key, ttl);\n if (cached !== CACHE_MISS) {\n return cached;\n }\n const result = original.apply(this, args);\n const entry: CacheEntry = { value: result };\n if (ttl !== undefined) {\n entry.expiresAt = Date.now() + ttl;\n }\n cache.set(key, entry);\n return result;\n } as T;\n}\n","import type { Backend } from '../../core/backend.js';\nimport { MetadataKeys } from '../../core/metadata-keys.js';\nimport type { PropertyName } from '../../core/types.js';\nimport { memoizeMethod, type MemoizeOptions } from './memoize.js';\n\nexport function memoizeMethodLegacy(\n backend: Backend,\n targetPrototype: object,\n propertyKey: PropertyName,\n descriptor: PropertyDescriptor,\n options: MemoizeOptions = {},\n): PropertyDescriptor | void {\n backend.metadata.set(MetadataKeys.MEMOIZE, targetPrototype, propertyKey, options);\n const original = descriptor.value;\n if (typeof original !== 'function') return;\n return {\n ...descriptor,\n value: memoizeMethod(original as (...args: unknown[]) => unknown, options),\n };\n}\n\nexport function memoizeMethodStage3<This, Args extends unknown[], Return>(\n backend: Backend,\n value: (this: This, ...args: Args) => Return,\n context: ClassMethodDecoratorContext<This, (this: This, ...args: Args) => Return>,\n options: MemoizeOptions = {},\n): (this: This, ...args: Args) => Return {\n backend.metadata.set(MetadataKeys.MEMOIZE, context.metadata as object, context.name, options);\n return memoizeMethod(value as (...args: unknown[]) => unknown, options) as (\n this: This,\n ...args: Args\n ) => Return;\n}\n","import { MetadataKeys } from '../../core/metadata-keys.js';\nimport {\n defineClassDecorator,\n defineFieldDecorator,\n defineMethodDecorator,\n} from '../../stage3/decorate.js';\nimport {\n codegenClassMarkerStage3,\n factoryClassStage3,\n createFromFactory,\n getFactoryRegistry,\n registerFactory,\n} from '../shared/factory.js';\nimport {\n memoizeMethodStage3,\n nonNullFieldStage3,\n prototypeClassStage3,\n singletonClassStage3,\n} from '../shared/index.js';\nimport type { MemoizeOptions } from '../shared/memoize.js';\n\n/** Validates field initial values are not null or undefined. */\nexport const NonNull = defineFieldDecorator(nonNullFieldStage3);\n\n/** Ensures only one instance of the class exists. */\nexport const Singleton = defineClassDecorator(singletonClassStage3);\n\n/** Returns a deep clone on every `new` call. */\nexport const Prototype = defineClassDecorator(prototypeClassStage3);\n\n/** Caches method return values. Optional TTL in milliseconds. */\nexport function Memoize(options: MemoizeOptions = {}) {\n return defineMethodDecorator((backend, value, context) =>\n memoizeMethodStage3(backend, value, context, options),\n );\n}\n\n/** Registers the class in the global factory registry under `key`. */\nexport function Factory(key: string) {\n return defineClassDecorator((backend, value, context) => {\n factoryClassStage3(backend, value, context, key);\n });\n}\n\n/** Composite Lombok `@Data` — codegen generates getters, setters, toString, equals. */\nexport const Data = defineClassDecorator((backend, value, context) =>\n codegenClassMarkerStage3(backend, value, context, MetadataKeys.DATA),\n);\n\n/** Fluent builder — codegen generates a companion builder class. */\nexport const Builder = defineClassDecorator((backend, value, context) =>\n codegenClassMarkerStage3(backend, value, context, MetadataKeys.BUILDER),\n);\n\n/** Auto `toString()` — codegen generates the method body. */\nexport const ToString = defineClassDecorator((backend, value, context) =>\n codegenClassMarkerStage3(backend, value, context, MetadataKeys.TO_STRING),\n);\n\nexport { createFromFactory, getFactoryRegistry, registerFactory };\n","/**\n * Stage 3 decorator backend, for the modern ECMAScript decorator standard\n * (TS 5.0+, with `experimentalDecorators` set to false or unset).\n *\n * No `reflect-metadata` here. Each decorator's `context.metadata` holds\n * per-class storage, accessible at runtime as `MyClass[Symbol.metadata]`.\n *\n * Stage 3 has no parameter decorators. Reach for the legacy backend if you\n * need them.\n *\n * @example\n * import { defineClassDecorator } from 'lombok-typescript/stage3';\n *\n * const Tracked = defineClassDecorator((backend, _value, context) => {\n * backend.metadata.set('tracked', context.metadata as object, undefined, true);\n * });\n */\n\nexport { Stage3Backend, stage3Backend } from './backend.js';\nexport {\n defineClassDecorator,\n defineFieldDecorator,\n defineMethodDecorator,\n defineGetterDecorator,\n defineSetterDecorator,\n} from './decorate.js';\nexport type {\n Stage3ClassLogic,\n Stage3FieldLogic,\n Stage3MethodLogic,\n Stage3GetterLogic,\n Stage3SetterLogic,\n} from './decorate.js';\nexport {\n NonNull,\n Singleton,\n Prototype,\n Memoize,\n Factory,\n Data,\n Builder,\n ToString,\n createFromFactory,\n getFactoryRegistry,\n registerFactory,\n} from '../decorators/stage3/index.js';\n\n/** Read the Stage 3 `Symbol.metadata` object from a class, if present. */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getClassMetadata(cls: new (...args: any[]) => any): object | undefined {\n return (cls as { [Symbol.metadata]?: object })[Symbol.metadata];\n}\n"]}
|
package/package.json
ADDED
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "lombok-typescript",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "Lombok-like decorators and code generation for TypeScript - reduce boilerplate with powerful annotations and Gang-of-Four design patterns",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "./dist/index.cjs",
|
|
7
|
+
"module": "./dist/index.js",
|
|
8
|
+
"types": "./dist/index.d.ts",
|
|
9
|
+
"exports": {
|
|
10
|
+
".": {
|
|
11
|
+
"types": "./dist/index.d.ts",
|
|
12
|
+
"import": "./dist/index.js",
|
|
13
|
+
"require": "./dist/index.cjs"
|
|
14
|
+
},
|
|
15
|
+
"./core": {
|
|
16
|
+
"types": "./dist/core/index.d.ts",
|
|
17
|
+
"import": "./dist/core/index.js",
|
|
18
|
+
"require": "./dist/core/index.cjs"
|
|
19
|
+
},
|
|
20
|
+
"./legacy": {
|
|
21
|
+
"types": "./dist/legacy/index.d.ts",
|
|
22
|
+
"import": "./dist/legacy/index.js",
|
|
23
|
+
"require": "./dist/legacy/index.cjs"
|
|
24
|
+
},
|
|
25
|
+
"./stage3": {
|
|
26
|
+
"types": "./dist/stage3/index.d.ts",
|
|
27
|
+
"import": "./dist/stage3/index.js",
|
|
28
|
+
"require": "./dist/stage3/index.cjs"
|
|
29
|
+
},
|
|
30
|
+
"./codegen": {
|
|
31
|
+
"types": "./dist/codegen/index.d.ts",
|
|
32
|
+
"import": "./dist/codegen/index.js",
|
|
33
|
+
"require": "./dist/codegen/index.cjs"
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
"bin": {
|
|
37
|
+
"lombok-ts": "./dist/cli/index.js"
|
|
38
|
+
},
|
|
39
|
+
"files": [
|
|
40
|
+
"dist",
|
|
41
|
+
"README.md",
|
|
42
|
+
"LICENSE"
|
|
43
|
+
],
|
|
44
|
+
"keywords": [
|
|
45
|
+
"lombok",
|
|
46
|
+
"typescript",
|
|
47
|
+
"decorators",
|
|
48
|
+
"codegen",
|
|
49
|
+
"ts-morph",
|
|
50
|
+
"design-patterns",
|
|
51
|
+
"gof",
|
|
52
|
+
"gang-of-four",
|
|
53
|
+
"builder",
|
|
54
|
+
"data-class",
|
|
55
|
+
"boilerplate",
|
|
56
|
+
"annotations",
|
|
57
|
+
"getter",
|
|
58
|
+
"setter",
|
|
59
|
+
"immutable",
|
|
60
|
+
"singleton",
|
|
61
|
+
"factory",
|
|
62
|
+
"strategy",
|
|
63
|
+
"observer",
|
|
64
|
+
"nestjs"
|
|
65
|
+
],
|
|
66
|
+
"author": "A-Dev-Kit",
|
|
67
|
+
"license": "MIT",
|
|
68
|
+
"repository": {
|
|
69
|
+
"type": "git",
|
|
70
|
+
"url": "git+https://github.com/A-Dev-Kit/lombok-typescript.git"
|
|
71
|
+
},
|
|
72
|
+
"bugs": {
|
|
73
|
+
"url": "https://github.com/A-Dev-Kit/lombok-typescript/issues"
|
|
74
|
+
},
|
|
75
|
+
"homepage": "https://github.com/A-Dev-Kit/lombok-typescript#readme",
|
|
76
|
+
"engines": {
|
|
77
|
+
"node": ">=22.0.0"
|
|
78
|
+
},
|
|
79
|
+
"devDependencies": {
|
|
80
|
+
"@types/node": "^24.13.2",
|
|
81
|
+
"@vitest/coverage-v8": "^3.2.6",
|
|
82
|
+
"@vitest/ui": "^3.2.6",
|
|
83
|
+
"eslint": "^9.39.4",
|
|
84
|
+
"expect-type": "^1.3.0",
|
|
85
|
+
"globals": "^15.15.0",
|
|
86
|
+
"prettier": "^3.8.4",
|
|
87
|
+
"tsup": "^8.5.1",
|
|
88
|
+
"tsx": "^4.22.4",
|
|
89
|
+
"typescript": "^5.9.3",
|
|
90
|
+
"typescript-eslint": "^8.61.0",
|
|
91
|
+
"vitest": "^3.2.6"
|
|
92
|
+
},
|
|
93
|
+
"dependencies": {
|
|
94
|
+
"bundle-require": "^5.1.0",
|
|
95
|
+
"cac": "^6.7.14",
|
|
96
|
+
"reflect-metadata": "^0.2.2",
|
|
97
|
+
"ts-morph": "^26.0.0"
|
|
98
|
+
},
|
|
99
|
+
"peerDependencies": {
|
|
100
|
+
"typescript": ">=5.0.0"
|
|
101
|
+
},
|
|
102
|
+
"publishConfig": {
|
|
103
|
+
"registry": "https://registry.npmjs.org"
|
|
104
|
+
},
|
|
105
|
+
"scripts": {
|
|
106
|
+
"build": "tsup",
|
|
107
|
+
"build:watch": "tsup --watch",
|
|
108
|
+
"dev": "tsx watch src/index.ts",
|
|
109
|
+
"test": "vitest run",
|
|
110
|
+
"test:watch": "vitest",
|
|
111
|
+
"test:coverage": "vitest run --coverage",
|
|
112
|
+
"test:ui": "vitest --ui",
|
|
113
|
+
"lint": "eslint .",
|
|
114
|
+
"lint:fix": "eslint . --fix",
|
|
115
|
+
"format": "prettier --write .",
|
|
116
|
+
"format:check": "prettier --check .",
|
|
117
|
+
"typecheck": "tsc --noEmit",
|
|
118
|
+
"clean": "rm -rf dist .lombok coverage .tsbuildinfo"
|
|
119
|
+
}
|
|
120
|
+
}
|