-
Notifications
You must be signed in to change notification settings - Fork 13k
Description
I maintain google/schema-dts which generates typings for schema.org JSON-LD. The generated typings are ~10k loc and involves a lot of type unions (e.g. Thing can be Organization or CreativeWork or Person or ...), and these can get pretty nested.
Compiling these works for me and the vast majority of users. But I get constant reports of JavaScript heap OOM errors from users consuming the typings. See google/schema-dts#34. I haven't been able to repro this at all, but I'm still hoping for some guidance on getting a better memory footprint for the type checker.
FYI, the .d.ts file looks something like this: https://unpkg.com/[email protected]/schema.d.ts
Questions (I'd take answers to any of these):
- Are there better strategies for writing these in a more memory friendly way? e.g. naming intermediate types, or declaring all properties in one huge object and defining respective types in terms of
Pick<>
? - Are there any profiling tools that anyone would recommend using to track this down?
- any other advice is appreciated.
Unfortunately splitting the types up isn't an option (at least not obviously) because the types are deeply self referential.