@ddd-ts/shape 0.0.0-compute-timeout-on-process.3 → 0.0.0-compute-timeout-on-process.5

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 (56) hide show
  1. package/LICENSE +21 -0
  2. package/dist/_.d.ts +38 -0
  3. package/dist/_.d.ts.map +1 -0
  4. package/dist/_.js +37 -0
  5. package/dist/_.js.map +1 -0
  6. package/dist/addons/microsecond-timestamp.d.ts +27 -0
  7. package/dist/addons/microsecond-timestamp.d.ts.map +1 -0
  8. package/dist/addons/microsecond-timestamp.js +62 -0
  9. package/dist/addons/microsecond-timestamp.js.map +1 -0
  10. package/dist/choice.d.ts +28 -0
  11. package/dist/choice.d.ts.map +1 -0
  12. package/dist/choice.js +45 -0
  13. package/dist/choice.js.map +1 -0
  14. package/dist/class.d.ts +27 -0
  15. package/dist/class.d.ts.map +1 -0
  16. package/dist/class.js +31 -0
  17. package/dist/class.js.map +1 -0
  18. package/dist/dict.d.ts +38 -0
  19. package/dist/dict.d.ts.map +1 -0
  20. package/dist/dict.js +42 -0
  21. package/dist/dict.js.map +1 -0
  22. package/dist/discriminated-union.d.ts +63 -0
  23. package/dist/discriminated-union.d.ts.map +1 -0
  24. package/dist/discriminated-union.js +65 -0
  25. package/dist/discriminated-union.js.map +1 -0
  26. package/dist/either.d.ts +79 -0
  27. package/dist/either.d.ts.map +1 -0
  28. package/dist/either.js +52 -0
  29. package/dist/either.js.map +1 -0
  30. package/dist/index.d.ts +14 -0
  31. package/dist/index.js +15 -0
  32. package/dist/literal.d.ts +19 -0
  33. package/dist/literal.d.ts.map +1 -0
  34. package/dist/literal.js +28 -0
  35. package/dist/literal.js.map +1 -0
  36. package/dist/mapping.d.ts +34 -0
  37. package/dist/mapping.d.ts.map +1 -0
  38. package/dist/mapping.js +46 -0
  39. package/dist/mapping.js.map +1 -0
  40. package/dist/multiple.d.ts +23 -0
  41. package/dist/multiple.d.ts.map +1 -0
  42. package/dist/multiple.js +120 -0
  43. package/dist/multiple.js.map +1 -0
  44. package/dist/nothing.d.ts +18 -0
  45. package/dist/nothing.d.ts.map +1 -0
  46. package/dist/nothing.js +20 -0
  47. package/dist/nothing.js.map +1 -0
  48. package/dist/optional.d.ts +29 -0
  49. package/dist/optional.d.ts.map +1 -0
  50. package/dist/optional.js +35 -0
  51. package/dist/optional.js.map +1 -0
  52. package/dist/primitive.d.ts +21 -0
  53. package/dist/primitive.d.ts.map +1 -0
  54. package/dist/primitive.js +31 -0
  55. package/dist/primitive.js.map +1 -0
  56. package/package.json +12 -15
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2023 Aetherall
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/dist/_.d.ts ADDED
@@ -0,0 +1,38 @@
1
+ import { ClassShorthand, IClass } from "./class.js";
2
+ import { DictShorthand, IDict } from "./dict.js";
3
+ import { Primitive, PrimitiveShorthand } from "./primitive.js";
4
+ import { IMultiple, MultipleShorthand } from "./multiple.js";
5
+ import { Nothing, NothingShorthand } from "./nothing.js";
6
+ import { ILiteral, LiteralShorthand } from "./literal.js";
7
+
8
+ //#region src/_.d.ts
9
+ declare abstract class Empty {}
10
+ interface Constructor<T = any, P extends any[] = any[]> {
11
+ new (...args: P): T;
12
+ }
13
+ type AbstractConstructor<T = any, P extends any[] = any[]> = abstract new (...args: P) => T;
14
+ interface Definition {
15
+ $shape: string;
16
+ $inline: any;
17
+ $serialize(value: any): any;
18
+ $deserialize(value: any): any;
19
+ }
20
+ type MakeAbstract<T> = T extends (new (...params: infer P) => infer R) ? Omit<T, ""> & (abstract new (...params: P) => R) : never;
21
+ type Concrete<T extends AbstractConstructor<any>> = T extends (abstract new (...params: infer P) => infer R) ? Omit<T, ""> & {
22
+ new (...params: P): R;
23
+ } : never;
24
+ type Shorthand = Definition | DictShorthand | PrimitiveShorthand | MultipleShorthand | NothingShorthand | ClassShorthand | LiteralShorthand;
25
+ type DefinitionOf<T extends Shorthand | Definition, B extends AbstractConstructor<{}> = typeof Empty> = T extends LiteralShorthand ? ILiteral<T, B> : T extends undefined ? ReturnType<typeof Nothing<B>> : T extends PrimitiveShorthand ? ReturnType<typeof Primitive<T, B>> : T extends MultipleShorthand ? IMultiple<T[0], B> : T extends ClassShorthand ? IClass<T, B> : T extends Definition ? T : T extends DictShorthand ? IDict<T, B> : never;
26
+ declare function Shape<const S extends Definition | Shorthand, B extends AbstractConstructor<{}> = typeof Empty>(shorthand: S, base?: B): DefinitionOf<S, B>;
27
+ type Expand<T> = T extends {
28
+ serialize(): any;
29
+ } ? T : T extends Date ? T : T extends Record<string, any> ? { [key in keyof T]: Expand<T[key]> } : T;
30
+ declare function forward<T extends AbstractConstructor<{
31
+ value: any;
32
+ }>, const Forward extends (T extends AbstractConstructor<{
33
+ value: infer U;
34
+ }> ? (keyof U)[] : never)>(base: T, forward: Forward): MakeAbstract<T & (new (...args: ConstructorParameters<T>) => InstanceType<T> & { [K in Forward[number]]: InstanceType<T>["value"][K] })>;
35
+ type MergeClasses<B extends AbstractConstructor, Current extends AbstractConstructor> = abstract new (...args: ConstructorParameters<Current>) => InstanceType<B> & InstanceType<Current>;
36
+ //#endregion
37
+ export { AbstractConstructor, Concrete, Constructor, Definition, DefinitionOf, Empty, Expand, MakeAbstract, MergeClasses, Shape, Shorthand, forward };
38
+ //# sourceMappingURL=_.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_.d.ts","names":[],"sources":["../src/_.ts"],"mappings":";;;;;;;;uBAOsB,KAAA;AAAA,UAEL,WAAA;EAAA,QACP,IAAA,EAAM,CAAA,GAAI,CAAA;AAAA;AAAA,KAER,mBAAA,sDAGS,IAAA,EAAM,CAAA,KAAM,CAAA;AAAA,UAEhB,UAAA;EACf,MAAA;EACA,OAAA;EACA,UAAA,CAAW,KAAA;EACX,YAAA,CAAa,KAAA;AAAA;AAAA,KAGH,YAAA,MAAkB,CAAA,kBACzB,MAAA,yBAED,IAAA,CAAK,CAAA,0BAA2B,MAAA,EAAQ,CAAA,KAAM,CAAA;AAAA,KAGtC,QAAA,WAAmB,mBAAA,SAC7B,CAAA,2BACK,MAAA,yBAED,IAAA,CAAK,CAAA;EAAA,QACK,MAAA,EAAQ,CAAA,GAAI,CAAA;AAAA;AAAA,KAIhB,SAAA,GACR,UAAA,GACA,aAAA,GACA,kBAAA,GACA,iBAAA,GACA,gBAAA,GACA,cAAA,GACA,gBAAA;AAAA,KAEQ,YAAA,WACA,SAAA,GAAY,UAAA,YACZ,mBAAA,cAAiC,KAAA,IACzC,CAAA,SAAU,gBAAA,GACV,QAAA,CAAS,CAAA,EAAG,CAAA,IACZ,CAAA,qBACE,UAAA,QAAkB,OAAA,CAAQ,CAAA,KAC1B,CAAA,SAAU,kBAAA,GACR,UAAA,QAAkB,SAAA,CAAU,CAAA,EAAG,CAAA,KAC/B,CAAA,SAAU,iBAAA,GACR,SAAA,CAAU,CAAA,KAAM,CAAA,IAChB,CAAA,SAAU,cAAA,GACR,MAAA,CAAO,CAAA,EAAG,CAAA,IACV,CAAA,SAAU,UAAA,GACR,CAAA,GACA,CAAA,SAAU,aAAA,GACR,KAAA,CAAM,CAAA,EAAG,CAAA;AAAA,iBAGT,KAAA,iBACE,UAAA,GAAa,SAAA,YACnB,mBAAA,cAAiC,KAAA,CAAA,CAC3C,SAAA,EAAW,CAAA,EAAG,IAAA,GAAM,CAAA,GAAmB,YAAA,CAAa,CAAA,EAAG,CAAA;AAAA,KAuC7C,MAAA,MAAY,CAAA;EAAY,SAAA;AAAA,IAChC,CAAA,GACA,CAAA,SAAU,IAAA,GACR,CAAA,GACA,CAAA,SAAU,MAAA,gCACQ,CAAA,GAAI,MAAA,CAAO,CAAA,CAAE,GAAA,OAC7B,CAAA;AAAA,iBAEQ,OAAA,WACJ,mBAAA;EAAsB,KAAA;AAAA,2BACV,CAAA,SAAU,mBAAA;EAAsB,KAAA;AAAA,YAC3C,CAAA,aAAA,CAGX,IAAA,EAAM,CAAA,EACN,OAAA,EAAS,OAAA,GACR,YAAA,CACD,CAAA,YAEO,IAAA,EAAM,qBAAA,CAAsB,CAAA,MAC5B,YAAA,CAAa,CAAA,YACV,OAAA,WAAkB,YAAA,CAAa,CAAA,WAAY,CAAA;AAAA,KAa3C,YAAA,WACA,mBAAA,kBACM,mBAAA,qBAEb,IAAA,EAAM,qBAAA,CAAsB,OAAA,MAC5B,YAAA,CAAa,CAAA,IAAK,YAAA,CAAa,OAAA"}
package/dist/_.js ADDED
@@ -0,0 +1,37 @@
1
+ import { Class } from "./class.js";
2
+ import { Dict } from "./dict.js";
3
+ import { Primitive } from "./primitive.js";
4
+ import { Multiple } from "./multiple.js";
5
+ import { Nothing } from "./nothing.js";
6
+ import { Literal } from "./literal.js";
7
+
8
+ //#region src/_.ts
9
+ var Empty = class {};
10
+ function Shape(shorthand, base = Empty) {
11
+ if (typeof shorthand === "string" || typeof shorthand === "number") return Literal(shorthand, base);
12
+ if (shorthand && "$shape" in shorthand && "name" in shorthand && typeof shorthand.name === "string") {
13
+ if (shorthand.name.startsWith("$")) return shorthand;
14
+ return Class(shorthand, base);
15
+ }
16
+ if (shorthand === void 0) return Nothing(void 0, base);
17
+ if ([
18
+ String,
19
+ Number,
20
+ Date,
21
+ Boolean
22
+ ].includes(shorthand)) return Primitive(shorthand, base);
23
+ if (shorthand && "prototype" in shorthand) return Class(shorthand, base);
24
+ if (Array.isArray(shorthand)) return Multiple(shorthand[0], base);
25
+ if (typeof shorthand === "object") return Dict(shorthand, base);
26
+ throw new Error(`Could not determine longhand from shorthand ${JSON.stringify(shorthand)}`);
27
+ }
28
+ function forward(base, forward) {
29
+ for (const key of forward) Object.defineProperty(base.prototype, key, { get() {
30
+ return this.value[key].bind(this.value);
31
+ } });
32
+ return base;
33
+ }
34
+
35
+ //#endregion
36
+ export { Empty, Shape, forward };
37
+ //# sourceMappingURL=_.js.map
package/dist/_.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_.js","names":[],"sources":["../src/_.ts"],"sourcesContent":["import { Class, IClass, ClassShorthand } from \"./class\";\nimport { Dict, IDict, DictShorthand } from \"./dict\";\nimport { Primitive, PrimitiveShorthand } from \"./primitive\";\nimport { Multiple, IMultiple, MultipleShorthand } from \"./multiple\";\nimport { Nothing, NothingShorthand } from \"./nothing\";\nimport { Literal, ILiteral, LiteralShorthand } from \"./literal\";\n\nexport abstract class Empty {}\n\nexport interface Constructor<T = any, P extends any[] = any[]> {\n new (...args: P): T;\n}\nexport type AbstractConstructor<\n T = any,\n P extends any[] = any[],\n> = abstract new (...args: P) => T;\n\nexport interface Definition {\n $shape: string;\n $inline: any;\n $serialize(value: any): any;\n $deserialize(value: any): any;\n}\n\nexport type MakeAbstract<T> = T extends new (\n ...params: infer P\n) => infer R\n ? Omit<T, \"\"> & (abstract new (...params: P) => R)\n : never;\n\nexport type Concrete<T extends AbstractConstructor<any>> =\n T extends abstract new (\n ...params: infer P\n ) => infer R\n ? Omit<T, \"\"> & {\n new (...params: P): R;\n }\n : never;\n\nexport type Shorthand =\n | Definition\n | DictShorthand\n | PrimitiveShorthand\n | MultipleShorthand\n | NothingShorthand\n | ClassShorthand\n | LiteralShorthand;\n\nexport type DefinitionOf<\n T extends Shorthand | Definition,\n B extends AbstractConstructor<{}> = typeof Empty,\n> = T extends LiteralShorthand\n ? ILiteral<T, B>\n : T extends undefined\n ? ReturnType<typeof Nothing<B>>\n : T extends PrimitiveShorthand\n ? ReturnType<typeof Primitive<T, B>>\n : T extends MultipleShorthand\n ? IMultiple<T[0], B>\n : T extends ClassShorthand\n ? IClass<T, B>\n : T extends Definition\n ? T\n : T extends DictShorthand\n ? IDict<T, B>\n : never;\n\nexport function Shape<\n const S extends Definition | Shorthand,\n B extends AbstractConstructor<{}> = typeof Empty,\n>(shorthand: S, base: B = Empty as any): DefinitionOf<S, B> {\n if (typeof shorthand === \"string\" || typeof shorthand === \"number\") {\n return Literal(shorthand, base) as any;\n }\n\n if (\n shorthand &&\n \"$shape\" in shorthand &&\n \"name\" in shorthand &&\n typeof shorthand.name === \"string\"\n ) {\n if ((shorthand as any).name.startsWith(\"$\")) {\n return shorthand as any;\n }\n return Class(shorthand as any, base) as any;\n }\n if (shorthand === undefined) {\n return Nothing(undefined, base) as any;\n }\n if ([String, Number, Date, Boolean].includes(shorthand as any)) {\n return Primitive(shorthand as any, base) as any;\n }\n if (shorthand && \"prototype\" in shorthand) {\n return Class(shorthand as any, base) as any;\n }\n\n if (Array.isArray(shorthand)) {\n return (Multiple as any)(shorthand[0] as any, base);\n }\n\n if (typeof shorthand === \"object\") {\n return Dict(shorthand as any, base) as any;\n }\n\n throw new Error(\n `Could not determine longhand from shorthand ${JSON.stringify(shorthand)}`,\n );\n}\n\nexport type Expand<T> = T extends { serialize(): any }\n ? T\n : T extends Date\n ? T\n : T extends Record<string, any>\n ? { [key in keyof T]: Expand<T[key]> }\n : T;\n\nexport function forward<\n T extends AbstractConstructor<{ value: any }>,\n const Forward extends T extends AbstractConstructor<{ value: infer U }>\n ? (keyof U)[]\n : never,\n>(\n base: T,\n forward: Forward,\n): MakeAbstract<\n T &\n (new (\n ...args: ConstructorParameters<T>\n ) => InstanceType<T> & {\n [K in Forward[number]]: InstanceType<T>[\"value\"][K];\n })\n> {\n for (const key of forward) {\n Object.defineProperty(base.prototype, key, {\n get() {\n return (this.value as any)[key].bind(this.value);\n },\n });\n }\n return base as any;\n}\n\nexport type MergeClasses<\n B extends AbstractConstructor,\n Current extends AbstractConstructor,\n> = abstract new (\n ...args: ConstructorParameters<Current>\n) => InstanceType<B> & InstanceType<Current>;\n"],"mappings":";;;;;;;;AAOA,IAAsB,QAAtB,MAA4B;AA4D5B,SAAgB,MAGd,WAAc,OAAU,OAAkC;AAC1D,KAAI,OAAO,cAAc,YAAY,OAAO,cAAc,SACxD,QAAO,QAAQ,WAAW,KAAK;AAGjC,KACE,aACA,YAAY,aACZ,UAAU,aACV,OAAO,UAAU,SAAS,UAC1B;AACA,MAAK,UAAkB,KAAK,WAAW,IAAI,CACzC,QAAO;AAET,SAAO,MAAM,WAAkB,KAAK;;AAEtC,KAAI,cAAc,OAChB,QAAO,QAAQ,QAAW,KAAK;AAEjC,KAAI;EAAC;EAAQ;EAAQ;EAAM;EAAQ,CAAC,SAAS,UAAiB,CAC5D,QAAO,UAAU,WAAkB,KAAK;AAE1C,KAAI,aAAa,eAAe,UAC9B,QAAO,MAAM,WAAkB,KAAK;AAGtC,KAAI,MAAM,QAAQ,UAAU,CAC1B,QAAQ,SAAiB,UAAU,IAAW,KAAK;AAGrD,KAAI,OAAO,cAAc,SACvB,QAAO,KAAK,WAAkB,KAAK;AAGrC,OAAM,IAAI,MACR,+CAA+C,KAAK,UAAU,UAAU,GACzE;;AAWH,SAAgB,QAMd,MACA,SAQA;AACA,MAAK,MAAM,OAAO,QAChB,QAAO,eAAe,KAAK,WAAW,KAAK,EACzC,MAAM;AACJ,SAAQ,KAAK,MAAc,KAAK,KAAK,KAAK,MAAM;IAEnD,CAAC;AAEJ,QAAO"}
@@ -0,0 +1,27 @@
1
+ //#region src/addons/microsecond-timestamp.d.ts
2
+ declare class MicrosecondTimestamp {
3
+ readonly micros: bigint;
4
+ static MILLISECOND: MicrosecondTimestamp;
5
+ static SECOND: MicrosecondTimestamp;
6
+ static MINUTE: MicrosecondTimestamp;
7
+ static HOUR: MicrosecondTimestamp;
8
+ static DAY: MicrosecondTimestamp;
9
+ static WEEK: MicrosecondTimestamp;
10
+ static MONTH: MicrosecondTimestamp;
11
+ constructor(micros: bigint);
12
+ isAfter(other: MicrosecondTimestamp): boolean;
13
+ equals(other: MicrosecondTimestamp): boolean;
14
+ isBefore(other: MicrosecondTimestamp): boolean;
15
+ add(micros: bigint | MicrosecondTimestamp): MicrosecondTimestamp;
16
+ sub(micros: bigint | MicrosecondTimestamp): MicrosecondTimestamp;
17
+ mult(factor: number): MicrosecondTimestamp;
18
+ static now(): MicrosecondTimestamp;
19
+ static fromNanoseconds(nanoseconds: bigint): MicrosecondTimestamp;
20
+ static fromMicroseconds(microseconds: bigint): MicrosecondTimestamp;
21
+ static deserialize(serialized: Date | MicrosecondTimestamp | bigint): MicrosecondTimestamp;
22
+ serialize(): Date;
23
+ static sort(left: MicrosecondTimestamp, right: MicrosecondTimestamp): number;
24
+ }
25
+ //#endregion
26
+ export { MicrosecondTimestamp };
27
+ //# sourceMappingURL=microsecond-timestamp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"microsecond-timestamp.d.ts","names":[],"sources":["../../src/addons/microsecond-timestamp.ts"],"mappings":";cAAa,oBAAA;EAAA,SASU,MAAA;EAAA,OARd,WAAA,EAAW,oBAAA;EAAA,OACX,MAAA,EAAM,oBAAA;EAAA,OACN,MAAA,EAAM,oBAAA;EAAA,OACN,IAAA,EAAI,oBAAA;EAAA,OACJ,GAAA,EAAG,oBAAA;EAAA,OACH,IAAA,EAAI,oBAAA;EAAA,OACJ,KAAA,EAAK,oBAAA;cAES,MAAA;EAErB,OAAA,CAAQ,KAAA,EAAO,oBAAA;EAIf,MAAA,CAAO,KAAA,EAAO,oBAAA;EAId,QAAA,CAAS,KAAA,EAAO,oBAAA;EAIhB,GAAA,CAAI,MAAA,WAAiB,oBAAA,GAAuB,oBAAA;EAM5C,GAAA,CAAI,MAAA,WAAiB,oBAAA,GAAuB,oBAAA;EAM5C,IAAA,CAAK,MAAA,WAAiB,oBAAA;EAAA,OAIf,GAAA,CAAA,GAAO,oBAAA;EAAA,OAIP,eAAA,CAAgB,WAAA,WAAsB,oBAAA;EAAA,OAItC,gBAAA,CAAiB,YAAA,WAAuB,oBAAA;EAAA,OAIxC,WAAA,CACL,UAAA,EAAY,IAAA,GAAO,oBAAA,YAClB,oBAAA;EAmBH,SAAA,CAAA,GAAS,IAAA;EAAA,OAMF,IAAA,CAAK,IAAA,EAAM,oBAAA,EAAsB,KAAA,EAAO,oBAAA;AAAA"}
@@ -0,0 +1,62 @@
1
+ //#region src/addons/microsecond-timestamp.ts
2
+ var MicrosecondTimestamp = class MicrosecondTimestamp {
3
+ static MILLISECOND = new MicrosecondTimestamp(BigInt(1e3));
4
+ static SECOND = this.MILLISECOND.mult(1e3);
5
+ static MINUTE = this.SECOND.mult(60);
6
+ static HOUR = this.MINUTE.mult(60);
7
+ static DAY = this.HOUR.mult(24);
8
+ static WEEK = this.DAY.mult(7);
9
+ static MONTH = this.DAY.mult(30);
10
+ constructor(micros) {
11
+ this.micros = micros;
12
+ }
13
+ isAfter(other) {
14
+ return this.micros > other.micros;
15
+ }
16
+ equals(other) {
17
+ return this.micros === other.micros;
18
+ }
19
+ isBefore(other) {
20
+ return this.micros < other.micros;
21
+ }
22
+ add(micros) {
23
+ const value = micros instanceof MicrosecondTimestamp ? micros.micros : micros;
24
+ return new MicrosecondTimestamp(this.micros + value);
25
+ }
26
+ sub(micros) {
27
+ const value = micros instanceof MicrosecondTimestamp ? micros.micros : micros;
28
+ return new MicrosecondTimestamp(this.micros - value);
29
+ }
30
+ mult(factor) {
31
+ return new MicrosecondTimestamp(this.micros * BigInt(factor));
32
+ }
33
+ static now() {
34
+ return new MicrosecondTimestamp(BigInt(Date.now()) * BigInt(1e3));
35
+ }
36
+ static fromNanoseconds(nanoseconds) {
37
+ return new MicrosecondTimestamp(nanoseconds / BigInt(1e3));
38
+ }
39
+ static fromMicroseconds(microseconds) {
40
+ return new MicrosecondTimestamp(microseconds);
41
+ }
42
+ static deserialize(serialized) {
43
+ if (serialized instanceof MicrosecondTimestamp) return serialized;
44
+ if (typeof serialized === "bigint") return new MicrosecondTimestamp(serialized);
45
+ if ("microseconds" in serialized && typeof serialized.microseconds === "bigint") return new MicrosecondTimestamp(serialized.microseconds);
46
+ return new MicrosecondTimestamp(BigInt(serialized.getTime()) * BigInt(1e3));
47
+ }
48
+ serialize() {
49
+ const date = new Date(Number(this.micros / BigInt(1e3)));
50
+ date.microseconds = this.micros;
51
+ return date;
52
+ }
53
+ static sort(left, right) {
54
+ if (left.isAfter(right)) return 1;
55
+ if (left.isBefore(right)) return -1;
56
+ return 0;
57
+ }
58
+ };
59
+
60
+ //#endregion
61
+ export { MicrosecondTimestamp };
62
+ //# sourceMappingURL=microsecond-timestamp.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"microsecond-timestamp.js","names":[],"sources":["../../src/addons/microsecond-timestamp.ts"],"sourcesContent":["export class MicrosecondTimestamp {\n static MILLISECOND = new MicrosecondTimestamp(BigInt(1_000));\n static SECOND = this.MILLISECOND.mult(1000);\n static MINUTE = this.SECOND.mult(60);\n static HOUR = this.MINUTE.mult(60);\n static DAY = this.HOUR.mult(24);\n static WEEK = this.DAY.mult(7);\n static MONTH = this.DAY.mult(30);\n\n constructor(readonly micros: bigint) {}\n\n isAfter(other: MicrosecondTimestamp): boolean {\n return this.micros > other.micros;\n }\n\n equals(other: MicrosecondTimestamp): boolean {\n return this.micros === other.micros;\n }\n\n isBefore(other: MicrosecondTimestamp): boolean {\n return this.micros < other.micros;\n }\n\n add(micros: bigint | MicrosecondTimestamp): MicrosecondTimestamp {\n const value =\n micros instanceof MicrosecondTimestamp ? micros.micros : micros;\n return new MicrosecondTimestamp(this.micros + value);\n }\n\n sub(micros: bigint | MicrosecondTimestamp): MicrosecondTimestamp {\n const value =\n micros instanceof MicrosecondTimestamp ? micros.micros : micros;\n return new MicrosecondTimestamp(this.micros - value);\n }\n\n mult(factor: number): MicrosecondTimestamp {\n return new MicrosecondTimestamp(this.micros * BigInt(factor));\n }\n\n static now(): MicrosecondTimestamp {\n return new MicrosecondTimestamp(BigInt(Date.now()) * BigInt(1000));\n }\n\n static fromNanoseconds(nanoseconds: bigint): MicrosecondTimestamp {\n return new MicrosecondTimestamp(nanoseconds / BigInt(1000));\n }\n\n static fromMicroseconds(microseconds: bigint): MicrosecondTimestamp {\n return new MicrosecondTimestamp(microseconds);\n }\n\n static deserialize(\n serialized: Date | MicrosecondTimestamp | bigint,\n ): MicrosecondTimestamp {\n if (serialized instanceof MicrosecondTimestamp) {\n return serialized;\n }\n if (typeof serialized === \"bigint\") {\n return new MicrosecondTimestamp(serialized);\n }\n\n if (\n \"microseconds\" in serialized &&\n typeof serialized.microseconds === \"bigint\"\n ) {\n return new MicrosecondTimestamp(serialized.microseconds);\n }\n\n const micros = BigInt(serialized.getTime()) * BigInt(1000);\n return new MicrosecondTimestamp(micros);\n }\n\n serialize() {\n const date = new Date(Number(this.micros / BigInt(1000)));\n (date as any).microseconds = this.micros;\n return date;\n }\n\n static sort(left: MicrosecondTimestamp, right: MicrosecondTimestamp): number {\n if (left.isAfter(right)) {\n return 1;\n }\n if (left.isBefore(right)) {\n return -1;\n }\n return 0;\n }\n}\n"],"mappings":";AAAA,IAAa,uBAAb,MAAa,qBAAqB;CAChC,OAAO,cAAc,IAAI,qBAAqB,OAAO,IAAM,CAAC;CAC5D,OAAO,SAAS,KAAK,YAAY,KAAK,IAAK;CAC3C,OAAO,SAAS,KAAK,OAAO,KAAK,GAAG;CACpC,OAAO,OAAO,KAAK,OAAO,KAAK,GAAG;CAClC,OAAO,MAAM,KAAK,KAAK,KAAK,GAAG;CAC/B,OAAO,OAAO,KAAK,IAAI,KAAK,EAAE;CAC9B,OAAO,QAAQ,KAAK,IAAI,KAAK,GAAG;CAEhC,YAAY,AAAS,QAAgB;EAAhB;;CAErB,QAAQ,OAAsC;AAC5C,SAAO,KAAK,SAAS,MAAM;;CAG7B,OAAO,OAAsC;AAC3C,SAAO,KAAK,WAAW,MAAM;;CAG/B,SAAS,OAAsC;AAC7C,SAAO,KAAK,SAAS,MAAM;;CAG7B,IAAI,QAA6D;EAC/D,MAAM,QACJ,kBAAkB,uBAAuB,OAAO,SAAS;AAC3D,SAAO,IAAI,qBAAqB,KAAK,SAAS,MAAM;;CAGtD,IAAI,QAA6D;EAC/D,MAAM,QACJ,kBAAkB,uBAAuB,OAAO,SAAS;AAC3D,SAAO,IAAI,qBAAqB,KAAK,SAAS,MAAM;;CAGtD,KAAK,QAAsC;AACzC,SAAO,IAAI,qBAAqB,KAAK,SAAS,OAAO,OAAO,CAAC;;CAG/D,OAAO,MAA4B;AACjC,SAAO,IAAI,qBAAqB,OAAO,KAAK,KAAK,CAAC,GAAG,OAAO,IAAK,CAAC;;CAGpE,OAAO,gBAAgB,aAA2C;AAChE,SAAO,IAAI,qBAAqB,cAAc,OAAO,IAAK,CAAC;;CAG7D,OAAO,iBAAiB,cAA4C;AAClE,SAAO,IAAI,qBAAqB,aAAa;;CAG/C,OAAO,YACL,YACsB;AACtB,MAAI,sBAAsB,qBACxB,QAAO;AAET,MAAI,OAAO,eAAe,SACxB,QAAO,IAAI,qBAAqB,WAAW;AAG7C,MACE,kBAAkB,cAClB,OAAO,WAAW,iBAAiB,SAEnC,QAAO,IAAI,qBAAqB,WAAW,aAAa;AAI1D,SAAO,IAAI,qBADI,OAAO,WAAW,SAAS,CAAC,GAAG,OAAO,IAAK,CACnB;;CAGzC,YAAY;EACV,MAAM,OAAO,IAAI,KAAK,OAAO,KAAK,SAAS,OAAO,IAAK,CAAC,CAAC;AACzD,EAAC,KAAa,eAAe,KAAK;AAClC,SAAO;;CAGT,OAAO,KAAK,MAA4B,OAAqC;AAC3E,MAAI,KAAK,QAAQ,MAAM,CACrB,QAAO;AAET,MAAI,KAAK,SAAS,MAAM,CACtB,QAAO;AAET,SAAO"}
@@ -0,0 +1,28 @@
1
+ import { AbstractConstructor, Constructor, Empty } from "./_.js";
2
+
3
+ //#region src/choice.d.ts
4
+ type ChoiceMatcher<S extends string[]> = { [key in S[number]]: () => any } | ({
5
+ _: () => any;
6
+ } & { [key in S[number]]?: () => any });
7
+ type ChoiceMatcherResult<M extends ChoiceMatcher<any>> = M[keyof M] extends (() => infer R) ? R : never;
8
+ declare const Choice: <const S extends string[], B extends AbstractConstructor<{}> = typeof Empty>(config: S, base?: B) => IChoice<S, B>;
9
+ type IChoice<S extends string[], B extends AbstractConstructor<{}> = typeof Empty> = Omit<B, ""> & {
10
+ $shape: "choice";
11
+ $of: S;
12
+ values: S;
13
+ deserialize<T extends Constructor>(this: T, value: S[number]): InstanceType<T>;
14
+ $deserialize<T>(this: T, value: S[number]): S[number];
15
+ $serialize<T>(this: T, value: S[number]): S[number];
16
+ $inline: S[number];
17
+ } & (abstract new (value: S[number]) => InstanceType<B> & {
18
+ value: S[number];
19
+ is<TH, T extends S[number]>(this: TH, value: T): this is Omit<TH, "serialize" | "value"> & {
20
+ value: T;
21
+ serialize(): T;
22
+ };
23
+ match<M extends ChoiceMatcher<S>>(matcher: M): ChoiceMatcherResult<M>;
24
+ serialize(): S[number];
25
+ }) & { [K in S[number]]: <T extends Constructor>(this: T) => InstanceType<T> };
26
+ //#endregion
27
+ export { Choice, ChoiceMatcher, ChoiceMatcherResult, IChoice };
28
+ //# sourceMappingURL=choice.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"choice.d.ts","names":[],"sources":["../src/choice.ts"],"mappings":";;;KAEY,aAAA,iCAEE,CAAA;EAGR,CAAA;AAAA,cAEQ,CAAA;AAAA,KAGF,mBAAA,WAA8B,aAAA,SACxC,CAAA,OAAQ,CAAA,4BAA2B,CAAA;AAAA,cAExB,MAAA,uCAED,mBAAA,cAAuB,KAAA,EAAA,MAAA,EAEzB,CAAA,EAAC,IAAA,GACH,CAAA,KACL,OAAA,CAAQ,CAAA,EAAG,CAAA;AAAA,KAiEF,OAAA,+BAEA,mBAAA,cAAiC,KAAA,IACzC,IAAA,CAAK,CAAA;EACP,MAAA;EACA,GAAA,EAAK,CAAA;EACL,MAAA,EAAQ,CAAA;EACR,WAAA,WAAsB,WAAA,EACpB,IAAA,EAAM,CAAA,EACN,KAAA,EAAO,CAAA,WACN,YAAA,CAAa,CAAA;EAChB,YAAA,IAAgB,IAAA,EAAM,CAAA,EAAG,KAAA,EAAO,CAAA,WAAY,CAAA;EAC5C,UAAA,IAAc,IAAA,EAAM,CAAA,EAAG,KAAA,EAAO,CAAA,WAAY,CAAA;EAC1C,OAAA,EAAS,CAAA;AAAA,mBAEP,KAAA,EAAO,CAAA,aACJ,YAAA,CAAa,CAAA;EAChB,KAAA,EAAO,CAAA;EACP,EAAA,eAAiB,CAAA,UACf,IAAA,EAAM,EAAA,EACN,KAAA,EAAO,CAAA,WACE,IAAA,CAAK,EAAA;IACd,KAAA,EAAO,CAAA;IACP,SAAA,IAAa,CAAA;EAAA;EAEf,KAAA,WAAgB,aAAA,CAAc,CAAA,GAAI,OAAA,EAAS,CAAA,GAAI,mBAAA,CAAoB,CAAA;EACnE,SAAA,IAAa,CAAA;AAAA,aAEP,CAAA,sBAAuB,WAAA,EAAa,IAAA,EAAM,CAAA,KAAM,YAAA,CAAa,CAAA"}
package/dist/choice.js ADDED
@@ -0,0 +1,45 @@
1
+ import { Empty } from "./_.js";
2
+
3
+ //#region src/choice.ts
4
+ const Choice = (config, base = Empty) => {
5
+ class $Choice extends base {
6
+ static $shape = "choice";
7
+ static $of = config;
8
+ static values = config;
9
+ constructor(value) {
10
+ super();
11
+ this.value = value;
12
+ }
13
+ is(value) {
14
+ return this.value === value;
15
+ }
16
+ match(matcher) {
17
+ const handler = matcher[this.value];
18
+ if (handler) return handler();
19
+ return matcher._();
20
+ }
21
+ serialize() {
22
+ return this.value;
23
+ }
24
+ static deserialize(value) {
25
+ return new this(value);
26
+ }
27
+ static $deserialize(value) {
28
+ return value;
29
+ }
30
+ static $serialize(value) {
31
+ return value;
32
+ }
33
+ static $inline;
34
+ static {
35
+ for (const choice of config) this[choice] = function() {
36
+ return new this(choice);
37
+ };
38
+ }
39
+ }
40
+ return $Choice;
41
+ };
42
+
43
+ //#endregion
44
+ export { Choice };
45
+ //# sourceMappingURL=choice.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"choice.js","names":[],"sources":["../src/choice.ts"],"sourcesContent":["import { AbstractConstructor, Empty, Expand, Constructor } from \"./_\";\n\nexport type ChoiceMatcher<S extends string[]> =\n | {\n [key in S[number]]: () => any;\n }\n | ({\n _: () => any;\n } & {\n [key in S[number]]?: () => any;\n });\n\nexport type ChoiceMatcherResult<M extends ChoiceMatcher<any>> =\n M[keyof M] extends () => infer R ? R : never;\n\nexport const Choice = <\n const S extends string[],\n B extends AbstractConstructor<{}> = typeof Empty,\n>(\n config: S,\n base: B = Empty as any,\n): IChoice<S, B> => {\n type Inline = S[number];\n\n abstract class $Choice extends (base as any as Constructor<{}>) {\n static $shape = \"choice\" as const;\n\n static $of = config;\n static values = config;\n\n constructor(public value: Expand<Inline>) {\n super();\n }\n\n is<T extends Inline>(\n value: T,\n ): this is Omit<this, \"value\" | \"serialize\"> & {\n value: T;\n serialize(): T;\n } {\n return this.value === value;\n }\n\n match<M extends ChoiceMatcher<S>>(matcher: M): ChoiceMatcherResult<M> {\n const handler = matcher[this.value];\n if (handler) return handler();\n return (matcher as { _: () => any })._();\n }\n\n serialize(): Inline {\n return this.value;\n }\n\n static deserialize<T extends typeof $Choice>(\n this: T,\n value: Inline,\n ): InstanceType<T> {\n return new (this as any)(value as any) as InstanceType<T>;\n }\n static $deserialize<T extends typeof $Choice>(\n this: T,\n value: Inline,\n ): Inline {\n return value;\n }\n static $serialize<T extends typeof $Choice>(\n this: T,\n value: Inline,\n ): Inline {\n return value;\n }\n\n static $inline: Inline;\n\n static {\n for (const choice of config) {\n (this as any)[choice] = function <T extends Constructor>(this: T) {\n return new this(choice as any);\n };\n }\n }\n }\n\n return $Choice as any;\n};\n\nexport type IChoice<\n S extends string[],\n B extends AbstractConstructor<{}> = typeof Empty,\n> = Omit<B, \"\"> & {\n $shape: \"choice\";\n $of: S;\n values: S;\n deserialize<T extends Constructor>(\n this: T,\n value: S[number],\n ): InstanceType<T>;\n $deserialize<T>(this: T, value: S[number]): S[number];\n $serialize<T>(this: T, value: S[number]): S[number];\n $inline: S[number];\n} & (abstract new (\n value: S[number],\n ) => InstanceType<B> & {\n value: S[number];\n is<TH, T extends S[number]>(\n this: TH,\n value: T,\n ): this is Omit<TH, \"serialize\" | \"value\"> & {\n value: T;\n serialize(): T;\n };\n match<M extends ChoiceMatcher<S>>(matcher: M): ChoiceMatcherResult<M>;\n serialize(): S[number];\n }) & {\n [K in S[number]]: <T extends Constructor>(this: T) => InstanceType<T>;\n };\n//# sourceMappingURL=choice.d.ts.map\n"],"mappings":";;;AAeA,MAAa,UAIX,QACA,OAAU,UACQ;CAGlB,MAAe,gBAAiB,KAAgC;EAC9D,OAAO,SAAS;EAEhB,OAAO,MAAM;EACb,OAAO,SAAS;EAEhB,YAAY,AAAO,OAAuB;AACxC,UAAO;GADU;;EAInB,GACE,OAIA;AACA,UAAO,KAAK,UAAU;;EAGxB,MAAkC,SAAoC;GACpE,MAAM,UAAU,QAAQ,KAAK;AAC7B,OAAI,QAAS,QAAO,SAAS;AAC7B,UAAQ,QAA6B,GAAG;;EAG1C,YAAoB;AAClB,UAAO,KAAK;;EAGd,OAAO,YAEL,OACiB;AACjB,UAAO,IAAK,KAAa,MAAa;;EAExC,OAAO,aAEL,OACQ;AACR,UAAO;;EAET,OAAO,WAEL,OACQ;AACR,UAAO;;EAGT,OAAO;EAEP;AACE,QAAK,MAAM,UAAU,OACnB,CAAC,KAAa,UAAU,WAA0C;AAChE,WAAO,IAAI,KAAK,OAAc;;;;AAMtC,QAAO"}
@@ -0,0 +1,27 @@
1
+ import { AbstractConstructor, Constructor, Empty, Expand } from "./_.js";
2
+
3
+ //#region src/class.d.ts
4
+ type ClassShorthand = Constructor<{
5
+ serialize(): any;
6
+ }> & {
7
+ deserialize(value: any): any;
8
+ };
9
+ declare const Class: <S extends Constructor<{
10
+ serialize(): any;
11
+ }> & {
12
+ deserialize(value: any): any;
13
+ }, B extends AbstractConstructor<any> = typeof Empty>(of: S, base?: typeof Empty) => IClass<S, B>;
14
+ type IClass<S extends ClassShorthand, B extends AbstractConstructor<any> = typeof Empty> = (abstract new (value: InstanceType<B>) => {
15
+ value: InstanceType<B>;
16
+ serialize<T>(this: T): Expand<ReturnType<InstanceType<S>["serialize"]>>;
17
+ }) & {
18
+ $shape: "class";
19
+ $of: S;
20
+ deserialize<T extends Constructor<any>>(this: T, value: Expand<Parameters<S["deserialize"]>[0]>): InstanceType<T>;
21
+ $deserialize(value: Parameters<S["deserialize"]>[0]): InstanceType<S>;
22
+ $serialize<T>(this: T, value: InstanceType<S>): ReturnType<InstanceType<S>["serialize"]>;
23
+ $inline: InstanceType<S>;
24
+ };
25
+ //#endregion
26
+ export { Class, ClassShorthand, IClass };
27
+ //# sourceMappingURL=class.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"class.d.ts","names":[],"sources":["../src/class.ts"],"mappings":";;;KAEY,cAAA,GAAiB,WAAA;EAAc,SAAA;AAAA;EACzC,WAAA,CAAY,KAAA;AAAA;AAAA,cAGD,KAAA,aACD,WAAA;EAAc,SAAA;AAAA;EACtB,WAAA,CAAY,KAAA;AAAA,aAEJ,mBAAA,eAAwB,KAAA,EAAA,EAAA,EAE9B,CAAA,EAAC,IAAA,UAAA,KAAA,KAEJ,MAAA,CAAO,CAAA,EAAG,CAAA;AAAA,KAwCD,MAAA,WACA,cAAA,YACA,mBAAA,eAAkC,KAAA,mBAE5C,KAAA,EAAO,YAAA,CAAa,CAAA;EAEpB,KAAA,EAAO,YAAA,CAAa,CAAA;EACpB,SAAA,IAAa,IAAA,EAAM,CAAA,GAAI,MAAA,CAAO,UAAA,CAAW,YAAA,CAAa,CAAA;AAAA;EAEtD,MAAA;EACA,GAAA,EAAK,CAAA;EACL,WAAA,WAAsB,WAAA,OACpB,IAAA,EAAM,CAAA,EACN,KAAA,EAAO,MAAA,CAAO,UAAA,CAAW,CAAA,uBACxB,YAAA,CAAa,CAAA;EAChB,YAAA,CAAa,KAAA,EAAO,UAAA,CAAW,CAAA,sBAAuB,YAAA,CAAa,CAAA;EACnE,UAAA,IACE,IAAA,EAAM,CAAA,EACN,KAAA,EAAO,YAAA,CAAa,CAAA,IACnB,UAAA,CAAW,YAAA,CAAa,CAAA;EAC3B,OAAA,EAAS,YAAA,CAAa,CAAA;AAAA"}
package/dist/class.js ADDED
@@ -0,0 +1,31 @@
1
+ import { Empty } from "./_.js";
2
+
3
+ //#region src/class.ts
4
+ const Class = (of, base = Empty) => {
5
+ class $Class extends base {
6
+ static $shape = "class";
7
+ static $of = of;
8
+ constructor(value) {
9
+ super();
10
+ this.value = value;
11
+ }
12
+ static deserialize(value) {
13
+ return new this(of.deserialize(value));
14
+ }
15
+ serialize() {
16
+ return this.value.serialize();
17
+ }
18
+ static $deserialize(value) {
19
+ return of.deserialize(value);
20
+ }
21
+ static $serialize(value) {
22
+ return value.serialize();
23
+ }
24
+ static $inline;
25
+ }
26
+ return $Class;
27
+ };
28
+
29
+ //#endregion
30
+ export { Class };
31
+ //# sourceMappingURL=class.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"class.js","names":[],"sources":["../src/class.ts"],"sourcesContent":["import { AbstractConstructor, Empty, Constructor, Expand } from \"./_\";\n\nexport type ClassShorthand = Constructor<{ serialize(): any }> & {\n deserialize(value: any): any;\n};\n\nexport const Class = <\n S extends Constructor<{ serialize(): any }> & {\n deserialize(value: any): any;\n },\n B extends AbstractConstructor<any> = typeof Empty,\n>(\n of: S,\n base = Empty,\n): IClass<S, B> => {\n type Serialized = ReturnType<InstanceType<S>[\"serialize\"]>;\n type Inline = InstanceType<S>;\n\n abstract class $Class extends base {\n static $shape = \"class\" as const;\n static $of = of;\n\n constructor(public value: InstanceType<B>) {\n super();\n }\n\n static deserialize<T extends Constructor<any>>(\n this: T,\n value: Expand<Parameters<S[\"deserialize\"]>[0]>,\n ): InstanceType<T> {\n return new this(of.deserialize(value)) as InstanceType<T>;\n }\n\n serialize<T extends $Class>(this: T): Expand<Serialized> {\n return this.value.serialize();\n }\n\n static $deserialize(value: Parameters<S[\"deserialize\"]>[0]): Inline {\n return of.deserialize(value);\n }\n\n static $serialize<T extends typeof $Class>(\n this: T,\n value: Inline,\n ): Serialized {\n return value.serialize();\n }\n\n static $inline: Inline;\n }\n\n return $Class as any;\n};\n\nexport type IClass<\n S extends ClassShorthand,\n B extends AbstractConstructor<any> = typeof Empty,\n> = (abstract new (\n value: InstanceType<B>,\n) => {\n value: InstanceType<B>;\n serialize<T>(this: T): Expand<ReturnType<InstanceType<S>[\"serialize\"]>>;\n}) & {\n $shape: \"class\";\n $of: S;\n deserialize<T extends Constructor<any>>(\n this: T,\n value: Expand<Parameters<S[\"deserialize\"]>[0]>,\n ): InstanceType<T>;\n $deserialize(value: Parameters<S[\"deserialize\"]>[0]): InstanceType<S>;\n $serialize<T>(\n this: T,\n value: InstanceType<S>,\n ): ReturnType<InstanceType<S>[\"serialize\"]>;\n $inline: InstanceType<S>;\n};\n"],"mappings":";;;AAMA,MAAa,SAMX,IACA,OAAO,UACU;CAIjB,MAAe,eAAe,KAAK;EACjC,OAAO,SAAS;EAChB,OAAO,MAAM;EAEb,YAAY,AAAO,OAAwB;AACzC,UAAO;GADU;;EAInB,OAAO,YAEL,OACiB;AACjB,UAAO,IAAI,KAAK,GAAG,YAAY,MAAM,CAAC;;EAGxC,YAAyD;AACvD,UAAO,KAAK,MAAM,WAAW;;EAG/B,OAAO,aAAa,OAAgD;AAClE,UAAO,GAAG,YAAY,MAAM;;EAG9B,OAAO,WAEL,OACY;AACZ,UAAO,MAAM,WAAW;;EAG1B,OAAO;;AAGT,QAAO"}
package/dist/dict.d.ts ADDED
@@ -0,0 +1,38 @@
1
+ import { AbstractConstructor, Constructor, DefinitionOf, Empty, Expand, Shorthand } from "./_.js";
2
+
3
+ //#region src/dict.d.ts
4
+ type DictShorthand = {
5
+ [key: string]: Shorthand;
6
+ };
7
+ type Internal<S extends DictShorthand, B extends AbstractConstructor<{}>> = {
8
+ Definition: { -readonly [K in keyof S]: DefinitionOf<S[K]> };
9
+ Serialized: (B extends {
10
+ $name: infer U;
11
+ } ? {
12
+ $name: U;
13
+ } : {}) & { -readonly [K in keyof S]: ReturnType<DefinitionOf<S[K]>["$serialize"]> };
14
+ Deserializing: (B extends {
15
+ $name: infer U;
16
+ } ? {
17
+ $name: U;
18
+ } : {}) & { -readonly [K in keyof S]: Parameters<DefinitionOf<S[K]>["$deserialize"]>[0] };
19
+ Inline: { -readonly [K in keyof S]: DefinitionOf<S[K]>["$inline"] };
20
+ };
21
+ declare const Dict: <const S extends {
22
+ [key: string]: any;
23
+ }, B extends AbstractConstructor<{}> = typeof Empty>(of: S, base?: B) => IDict<S, B>;
24
+ type IDict<S extends {
25
+ [key: string]: any;
26
+ }, B extends AbstractConstructor<{}> = typeof Empty> = Omit<B, ""> & {
27
+ $shape: "dict";
28
+ $of: S;
29
+ deserialize<T extends Constructor>(this: T, value: Expand<Internal<S, B>["Serialized"]>): InstanceType<T>;
30
+ $deserialize<T>(this: T, value: Internal<S, B>["Deserializing"]): Internal<S, B>["Inline"];
31
+ $serialize<T extends Constructor>(this: T, value: InstanceType<T>): Internal<S, B>["Serialized"];
32
+ $inline: Internal<S, B>["Inline"];
33
+ } & (abstract new (value: Expand<Internal<S, B>["Inline"]>) => InstanceType<B> & {
34
+ serialize(): Expand<Internal<S, B>["Serialized"]>;
35
+ } & Internal<S, B>["Inline"]);
36
+ //#endregion
37
+ export { Dict, DictShorthand, IDict };
38
+ //# sourceMappingURL=dict.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dict.d.ts","names":[],"sources":["../src/dict.ts"],"mappings":";;;KAUY,aAAA;EAAA,CAAmB,GAAA,WAAc,SAAA;AAAA;AAAA,KAExC,QAAA,WAAmB,aAAA,YAAyB,mBAAA;EAC/C,UAAA,0BAAoC,CAAA,GAAI,YAAA,CAAa,CAAA,CAAE,CAAA;EACvD,UAAA,GAAa,CAAA;IAAY,KAAA;EAAA;IAAqB,KAAA,EAAO,CAAA;EAAA,kCAC7B,CAAA,GAAI,UAAA,CAAW,YAAA,CAAa,CAAA,CAAE,CAAA;EAEtD,aAAA,GAAgB,CAAA;IAAY,KAAA;EAAA;IAAqB,KAAA,EAAO,CAAA;EAAA,kCAChC,CAAA,GAAI,UAAA,CAAW,YAAA,CAAa,CAAA,CAAE,CAAA;EAEtD,MAAA,0BACwB,CAAA,GAAI,YAAA,CAAa,CAAA,CAAE,CAAA;AAAA;AAAA,cAIhC,IAAA;EAAA,CACQ,GAAA;AAAA,aACT,mBAAA,cAAuB,KAAA,EAAA,EAAA,EAE7B,CAAA,EAAC,IAAA,GACC,CAAA,KACL,KAAA,CAAM,CAAA,EAAG,CAAA;AAAA,KAwDA,KAAA;EAAA,CAEP,GAAA;AAAA,aAEO,mBAAA,cAAiC,KAAA,IACzC,IAAA,CAAK,CAAA;EACP,MAAA;EACA,GAAA,EAAK,CAAA;EACL,WAAA,WAAsB,WAAA,EACpB,IAAA,EAAM,CAAA,EACN,KAAA,EAAO,MAAA,CAAO,QAAA,CAAS,CAAA,EAAG,CAAA,mBACzB,YAAA,CAAa,CAAA;EAChB,YAAA,IACE,IAAA,EAAM,CAAA,EACN,KAAA,EAAO,QAAA,CAAS,CAAA,EAAG,CAAA,qBAClB,QAAA,CAAS,CAAA,EAAG,CAAA;EACf,UAAA,WAAqB,WAAA,EACnB,IAAA,EAAM,CAAA,EACN,KAAA,EAAO,YAAA,CAAa,CAAA,IACnB,QAAA,CAAS,CAAA,EAAG,CAAA;EACf,OAAA,EAAS,QAAA,CAAS,CAAA,EAAG,CAAA;AAAA,mBAEnB,KAAA,EAAO,MAAA,CAAO,QAAA,CAAS,CAAA,EAAG,CAAA,iBACvB,YAAA,CAAa,CAAA;EAChB,SAAA,IAAa,MAAA,CAAO,QAAA,CAAS,CAAA,EAAG,CAAA;AAAA,IAC9B,QAAA,CAAS,CAAA,EAAG,CAAA"}
package/dist/dict.js ADDED
@@ -0,0 +1,42 @@
1
+ import { Empty, Shape } from "./_.js";
2
+
3
+ //#region src/dict.ts
4
+ const Dict = (of, base = Empty) => {
5
+ class $Dict extends base {
6
+ static $shape = "dict";
7
+ static $of = of;
8
+ constructor(...args) {
9
+ super();
10
+ Object.assign(this, args[0]);
11
+ }
12
+ serialize() {
13
+ return $Dict.$serialize(this);
14
+ }
15
+ static deserialize(value) {
16
+ const runtime = this.$deserialize(value);
17
+ return new this(runtime);
18
+ }
19
+ static $deserialize(value) {
20
+ const transform = Object.entries(of).map(([key, child]) => {
21
+ return [key, Shape(child).$deserialize(value[key])];
22
+ });
23
+ return Object.fromEntries(transform);
24
+ }
25
+ static $serialize(value) {
26
+ const transform = Object.entries(of).map(([key, child]) => {
27
+ return [key, Shape(child).$serialize(value[key])];
28
+ });
29
+ const merge = Object.fromEntries(transform);
30
+ if ("$name" in base) return {
31
+ ...merge,
32
+ $name: base.$name
33
+ };
34
+ return merge;
35
+ }
36
+ }
37
+ return $Dict;
38
+ };
39
+
40
+ //#endregion
41
+ export { Dict };
42
+ //# sourceMappingURL=dict.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dict.js","names":[],"sources":["../src/dict.ts"],"sourcesContent":["import {\n DefinitionOf,\n Shorthand,\n Shape,\n Expand,\n AbstractConstructor,\n Constructor,\n Empty,\n} from \"./_\";\n\nexport type DictShorthand = { [key: string]: Shorthand };\n\ntype Internal<S extends DictShorthand, B extends AbstractConstructor<{}>> = {\n Definition: { -readonly [K in keyof S]: DefinitionOf<S[K]> };\n Serialized: (B extends { $name: infer U } ? { $name: U } : {}) & {\n -readonly [K in keyof S]: ReturnType<DefinitionOf<S[K]>[\"$serialize\"]>;\n };\n Deserializing: (B extends { $name: infer U } ? { $name: U } : {}) & {\n -readonly [K in keyof S]: Parameters<DefinitionOf<S[K]>[\"$deserialize\"]>[0];\n };\n Inline: {\n -readonly [K in keyof S]: DefinitionOf<S[K]>[\"$inline\"];\n };\n};\n\nexport const Dict = <\n const S extends { [key: string]: any },\n B extends AbstractConstructor<{}> = typeof Empty,\n>(\n of: S,\n base: B = Empty as any,\n): IDict<S, B> => {\n abstract class $Dict extends (base as any as AbstractConstructor<{}>) {\n static $shape = \"dict\" as const;\n static $of = of;\n\n constructor(...args: any[]) {\n super();\n Object.assign(this, args[0]);\n }\n\n serialize() {\n return $Dict.$serialize(this as any) as any;\n }\n\n static deserialize<T extends Constructor>(\n this: T,\n value: any,\n ): InstanceType<T> {\n const runtime = (this as any).$deserialize(value as any);\n return new this(runtime as any) as any;\n }\n\n static $deserialize<T extends typeof $Dict>(this: T, value: any): any {\n const split = Object.entries(of);\n const transform = split.map(([key, child]) => {\n const longhand = Shape(child) as any;\n const deserialized = longhand.$deserialize((value as any)[key]);\n return [key, deserialized];\n });\n const merge = Object.fromEntries(transform);\n return merge;\n }\n\n static $serialize<T extends typeof $Dict>(\n this: T,\n value: InstanceType<T>,\n ): any {\n const split = Object.entries(of);\n const transform = split.map(([key, child]) => {\n const longhand = Shape(child as any) as any;\n const serialized = longhand.$serialize((value as any)[key]);\n return [key, serialized];\n });\n const merge = Object.fromEntries(transform);\n\n if (\"$name\" in base) {\n return { ...merge, $name: base.$name } as any;\n }\n\n return merge as any;\n }\n }\n\n return $Dict as any;\n};\n\nexport type IDict<\n S extends {\n [key: string]: any;\n },\n B extends AbstractConstructor<{}> = typeof Empty,\n> = Omit<B, \"\"> & {\n $shape: \"dict\";\n $of: S;\n deserialize<T extends Constructor>(\n this: T,\n value: Expand<Internal<S, B>[\"Serialized\"]>,\n ): InstanceType<T>;\n $deserialize<T>(\n this: T,\n value: Internal<S, B>[\"Deserializing\"],\n ): Internal<S, B>[\"Inline\"];\n $serialize<T extends Constructor>(\n this: T,\n value: InstanceType<T>,\n ): Internal<S, B>[\"Serialized\"];\n $inline: Internal<S, B>[\"Inline\"];\n} & (abstract new (\n value: Expand<Internal<S, B>[\"Inline\"]>,\n ) => InstanceType<B> & {\n serialize(): Expand<Internal<S, B>[\"Serialized\"]>;\n } & Internal<S, B>[\"Inline\"]);\n"],"mappings":";;;AAyBA,MAAa,QAIX,IACA,OAAU,UACM;CAChB,MAAe,cAAe,KAAwC;EACpE,OAAO,SAAS;EAChB,OAAO,MAAM;EAEb,YAAY,GAAG,MAAa;AAC1B,UAAO;AACP,UAAO,OAAO,MAAM,KAAK,GAAG;;EAG9B,YAAY;AACV,UAAO,MAAM,WAAW,KAAY;;EAGtC,OAAO,YAEL,OACiB;GACjB,MAAM,UAAW,KAAa,aAAa,MAAa;AACxD,UAAO,IAAI,KAAK,QAAe;;EAGjC,OAAO,aAA8C,OAAiB;GAEpE,MAAM,YADQ,OAAO,QAAQ,GAAG,CACR,KAAK,CAAC,KAAK,WAAW;AAG5C,WAAO,CAAC,KAFS,MAAM,MAAM,CACC,aAAc,MAAc,KAAK,CACrC;KAC1B;AAEF,UADc,OAAO,YAAY,UAAU;;EAI7C,OAAO,WAEL,OACK;GAEL,MAAM,YADQ,OAAO,QAAQ,GAAG,CACR,KAAK,CAAC,KAAK,WAAW;AAG5C,WAAO,CAAC,KAFS,MAAM,MAAa,CACR,WAAY,MAAc,KAAK,CACnC;KACxB;GACF,MAAM,QAAQ,OAAO,YAAY,UAAU;AAE3C,OAAI,WAAW,KACb,QAAO;IAAE,GAAG;IAAO,OAAO,KAAK;IAAO;AAGxC,UAAO;;;AAIX,QAAO"}
@@ -0,0 +1,63 @@
1
+ import { ClassShorthand } from "./class.js";
2
+ import { DictShorthand } from "./dict.js";
3
+ import { AbstractConstructor, Definition, DefinitionOf, Empty, Expand, Shorthand } from "./_.js";
4
+
5
+ //#region src/discriminated-union.d.ts
6
+ type UnionToIntersection<U> = (U extends unknown ? (k: U) => void : never) extends ((k: infer I) => void) ? I : never;
7
+ type PopUnion<U> = UnionToOvlds<U> extends ((a: infer A) => void) ? A : never;
8
+ type UnionToArray<T, A extends unknown[] = []> = IsUnion<T> extends true ? UnionToArray<Exclude<T, PopUnion<T>>, [PopUnion<T>, ...A]> : [T, ...A];
9
+ type IsUnion<T> = [T] extends [UnionToIntersection<T>] ? false : true;
10
+ type CountUnion<T> = UnionToArray<T> extends infer U extends any[] ? U["length"] : never;
11
+ type UnshiftUnion<U> = UnionToArray<U> extends [infer F, ...any[]] ? F : never;
12
+ type UnionToOvlds<U> = UnionToIntersection<U extends any ? (f: U) => void : never>;
13
+ type IsStringLiteral<T> = T extends string ? string extends T ? false : true : false;
14
+ type FindBestKeyForMatching<FromUnion> = UnshiftUnion<keyof FromUnion extends infer K ? K extends keyof FromUnion ? CountUnion<Pick<FromUnion, K>[K]> extends CountUnion<FromUnion> ? [IsStringLiteral<FromUnion[K]>] extends [true] ? K : never : never : never : never>;
15
+ type MatcherConfig = {
16
+ [key: string]: any;
17
+ };
18
+ type ExhaustiveMatcher<C> = C extends MatcherConfig ? { [key in keyof C]: (value: Expand<DefinitionOf<C[key]>["$inline"]>) => any } : never;
19
+ type UnsafeFallthroughMatcher<C> = C extends MatcherConfig ? { [key in keyof C]?: (value: Expand<DefinitionOf<C[key]>["$inline"]>) => any } & {
20
+ _: (value: Expand<DefinitionOf<C[keyof C]>["$inline"]>) => any;
21
+ } : never;
22
+ type PartialMatcher<C> = C extends MatcherConfig ? { [key in keyof C]?: (value: Expand<DefinitionOf<C[key]>["$inline"]>) => any } : never;
23
+ type Matcher<C> = C extends MatcherConfig ? ExhaustiveMatcher<C> | UnsafeFallthroughMatcher<C> | PartialMatcher<C> : never;
24
+ type Config = DictShorthandInput | ClassInput | ClassDictInput | DictInput;
25
+ type ClassInput = ClassShorthand;
26
+ type ClassDictInput = ClassShorthand & {
27
+ $of: {};
28
+ };
29
+ type DictInput = {
30
+ $of: {};
31
+ };
32
+ type DictShorthandInput = DictShorthand;
33
+ type Access<T, K> = K extends keyof T ? T[K] : never;
34
+ type Entries<T extends readonly any[], K> = UnionToIntersection<{ [i in keyof T]: Access<GetShape<T[i]>, K> extends infer U extends string ? IsStringLiteral<U> extends true ? { [key in U]: T[i] extends DictShorthandInput ? DefinitionOf<T[i]> : T[i] } : never : never }[number]>;
35
+ type GetShape<S extends Config> = S extends DictInput ? S["$of"] : S extends ClassInput ? Access<S, "prototype"> : S;
36
+ type BestKey<S extends readonly Config[]> = { [key in keyof S]: GetShape<S[key]> }[number] extends infer U ? FindBestKeyForMatching<U> : never;
37
+ type DiscriminatedUnionConfiguration = readonly Config[];
38
+ declare function findBestKey(config: DiscriminatedUnionConfiguration): string;
39
+ declare function prepareShapeMap(config: DiscriminatedUnionConfiguration, key: string): {
40
+ [key: string]: Definition;
41
+ };
42
+ type Internal<S extends DiscriminatedUnionConfiguration, K extends BestKey<S>> = {
43
+ Map: Entries<S, K>;
44
+ Serialized: ReturnType<DefinitionOf<S[number]>["$serialize"]>;
45
+ Inline: DefinitionOf<S[number]>["$inline"];
46
+ };
47
+ declare const DiscriminatedUnion: <S extends DiscriminatedUnionConfiguration, K extends BestKey<S>, const B extends AbstractConstructor = typeof Empty>(of: S, base?: B | undefined) => IDiscriminatedUnion<S, K, B>;
48
+ type IDiscriminatedUnion<S extends DiscriminatedUnionConfiguration, K extends BestKey<S>, B extends AbstractConstructor = typeof Empty> = Omit<B, "prototype"> & {
49
+ $shape: "discriminated-union";
50
+ $of: S;
51
+ serialized: Internal<S, K>["Serialized"];
52
+ deserialize<T>(this: T, value: Expand<Internal<S, K>["Serialized"]>): T extends AbstractConstructor ? InstanceType<T> : any;
53
+ $deserialize<T>(this: T, value: Internal<S, K>["Serialized"]): Internal<S, K>["Inline"];
54
+ $serialize<T extends AbstractConstructor>(this: T, value: InstanceType<T>): Internal<S, K>["Serialized"];
55
+ $inline: Internal<S, K>["Inline"];
56
+ } & (abstract new (value: Internal<S, K>["Inline"]) => InstanceType<B> & {
57
+ value: Internal<S, K>["Inline"];
58
+ serialize(): Internal<S, K>["Serialized"];
59
+ match<M extends Matcher<Internal<S, K>["Map"]>, F extends (M extends ExhaustiveMatcher<Internal<S, K>["Map"]> ? [] : M extends UnsafeFallthroughMatcher<Internal<S, K>["Map"]> ? [] : M extends PartialMatcher<Internal<S, K>["Map"]> ? [fallback: (value: Omit<Internal<S, K>["Map"], keyof M>[keyof Omit<Internal<S, K>["Map"], keyof M>] extends infer U extends Shorthand ? Expand<DefinitionOf<U>["$inline"]> : never) => any] : [])>(matcher: M, ...fallback_n: F): (M[keyof M] extends ((...args: any[]) => any) ? ReturnType<M[keyof M]> : never) | (F[0] extends ((...args: any[]) => any) ? ReturnType<F[0]> : never);
60
+ });
61
+ //#endregion
62
+ export { BestKey, DiscriminatedUnion, DiscriminatedUnionConfiguration, IDiscriminatedUnion, findBestKey, prepareShapeMap };
63
+ //# sourceMappingURL=discriminated-union.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"discriminated-union.d.ts","names":[],"sources":["../src/discriminated-union.ts"],"mappings":"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"}
@@ -0,0 +1,65 @@
1
+ import { Empty, Shape } from "./_.js";
2
+
3
+ //#region src/discriminated-union.ts
4
+ function findBestKey(config) {
5
+ const hash = {};
6
+ for (const c of config) {
7
+ const shape = "$of" in c ? c.$of : c;
8
+ for (const key in shape) {
9
+ const k = key;
10
+ if (hash[key]) hash[key].add(shape[k]);
11
+ else hash[key] = new Set([shape[k]]);
12
+ }
13
+ }
14
+ const key = Object.entries(hash).map(([key, value]) => [key, value.size]).filter(([_, value]) => value === config.length).sort((a, b) => b[1] - a[1])?.[0]?.[0];
15
+ if (!key) throw new Error("Could not find key for DiscriminatedUnion");
16
+ return key;
17
+ }
18
+ function prepareShapeMap(config, key) {
19
+ return config.reduce((acc, c) => {
20
+ const shape = Shape(c);
21
+ const discriminator = key in c ? c[key] : "$of" in c ? c.$of[key] : shape.$of[key];
22
+ acc[discriminator] = shape;
23
+ return acc;
24
+ }, {});
25
+ }
26
+ const DiscriminatedUnion = (of, ...args) => {
27
+ const base = args[0] || Empty;
28
+ const key = findBestKey(of);
29
+ const map = prepareShapeMap(of, key);
30
+ class $DiscriminatedUnion extends base {
31
+ constructor(value) {
32
+ super();
33
+ this.value = value;
34
+ }
35
+ static $of = of;
36
+ static $shape = "discriminated-union";
37
+ serialize() {
38
+ return $DiscriminatedUnion.$serialize(this.value);
39
+ }
40
+ match(matcher, fallback) {
41
+ const element = this.value;
42
+ const handler = matcher[element[key]];
43
+ if (handler) return handler(element);
44
+ if (fallback) return fallback(element);
45
+ if (matcher._) return matcher._(element);
46
+ throw new Error("Non-exhaustive match");
47
+ }
48
+ static deserialize(value) {
49
+ return new this(this.$deserialize(value));
50
+ }
51
+ static $deserialize(value) {
52
+ const definition = map[value[key]];
53
+ if (!definition) throw new Error("Cannot deserialize DiscriminatedUnion");
54
+ return definition.$deserialize(value);
55
+ }
56
+ static $serialize(value) {
57
+ return map[value[key]].$serialize(value);
58
+ }
59
+ }
60
+ return $DiscriminatedUnion;
61
+ };
62
+
63
+ //#endregion
64
+ export { DiscriminatedUnion, findBestKey, prepareShapeMap };
65
+ //# sourceMappingURL=discriminated-union.js.map