0.1.0 #1

Merged
Thilawyn merged 65 commits from next into master 2024-02-06 03:15:40 +01:00
Showing only changes of commit 1219cd7a89 - Show all commits

View File

@@ -1,6 +1,6 @@
import { Call, Pipe, Tuples } from "hotscript" import { Call, Pipe, Tuples } from "hotscript"
import { AbstractClass, Class, Opaque } from "type-fest" import { AbstractClass, Class, Opaque } from "type-fest"
import { AbstractTag, Trait, TraitAbstractMembersFn, TraitApplierSuperTag, TraitImplClassFn, TraitImplInstanceFn } from "." import { AbstractTag, Trait, TraitApplierSuperTag, TraitOwnAbstractFn, TraitOwnImplClassFn, TraitOwnImplInstanceFn } from "."
import { ExtendFn, ExtendableFn, SimplifyFn, StaticMembersFn } from "./util" import { ExtendFn, ExtendableFn, SimplifyFn, StaticMembersFn } from "./util"
@@ -17,7 +17,7 @@ export class TraitExpression<
AbstractClass< AbstractClass<
Pipe<[ Pipe<[
InstanceType<Super>, InstanceType<Super>,
...Call<Tuples.Map<TraitImplInstanceFn>, Traits>, ...Call<Tuples.Map<TraitOwnImplInstanceFn>, Traits>,
], [ ], [
ExtendFn, ExtendFn,
SimplifyFn, SimplifyFn,
@@ -28,7 +28,7 @@ export class TraitExpression<
Pipe<[ Pipe<[
Super, Super,
...Call<Tuples.Map<TraitImplClassFn>, Traits>, ...Call<Tuples.Map<TraitOwnImplClassFn>, Traits>,
], [ ], [
Tuples.Map<StaticMembersFn>, Tuples.Map<StaticMembersFn>,
ExtendFn, ExtendFn,
@@ -47,7 +47,7 @@ export class TraitExpression<
>( >(
abstract: ( abstract: (
abstract: Pipe<Traits, [ abstract: Pipe<Traits, [
Tuples.Map<TraitAbstractMembersFn>, Tuples.Map<TraitOwnAbstractFn>,
SimplifyFn, SimplifyFn,
]> ]>
) => Opaque<SubtraitAbstract, AbstractTag>, ) => Opaque<SubtraitAbstract, AbstractTag>,
@@ -58,10 +58,12 @@ export class TraitExpression<
} }
} }
export type Implements<Exp extends TraitExpression<any, any>> = ( export type Implements<Exp extends TraitExpression<any, any>> = (
Exp extends TraitExpression<any, infer Traits> Exp extends TraitExpression<any, infer Traits>
? Pipe<Traits, [ ? Pipe<Traits, [
Tuples.Map<TraitAbstractMembersFn>, Tuples.Map<TraitOwnAbstractFn>,
ExtendFn, ExtendFn,
SimplifyFn, SimplifyFn,
]> ]>
@@ -71,7 +73,7 @@ export type Implements<Exp extends TraitExpression<any, any>> = (
class TraitExpressionBuilder< class TraitExpressionBuilder<
Super extends AbstractClass<{}>, Super extends AbstractClass<{}>,
Traits extends Trait<any, any>[], Traits extends Trait<any, any, any>[],
> { > {
constructor(public expression: TraitExpression<Super, Traits>) {} constructor(public expression: TraitExpression<Super, Traits>) {}
@@ -87,7 +89,7 @@ class TraitExpressionBuilder<
} }
expresses< expresses<
AppendTraits extends Trait<any, any>[] AppendTraits extends Trait<any, any, any>[]
>(...traits: AppendTraits) { >(...traits: AppendTraits) {
return new TraitExpressionBuilder( return new TraitExpressionBuilder(
new TraitExpression( new TraitExpression(
@@ -109,31 +111,31 @@ class TraitExpressionBuilder<
type AbstractMembersExtendable< type AbstractMembersExtendable<
Super extends AbstractClass<{}>, Super extends AbstractClass<{}>,
Traits extends Trait<any, any>[], Traits extends Trait<any, any, any>[],
> = ( > = (
Call<ExtendableFn, [ Call<ExtendableFn, [
InstanceType<Super>, InstanceType<Super>,
...Call<Tuples.Map<TraitAbstractMembersFn>, Traits>, ...Call<Tuples.Map<TraitOwnAbstractFn>, Traits>,
]> ]>
) )
type ImplInstanceExtendable< type ImplInstanceExtendable<
Super extends AbstractClass<{}>, Super extends AbstractClass<{}>,
Traits extends Trait<any, any>[], Traits extends Trait<any, any, any>[],
> = ( > = (
Call<ExtendableFn, [ Call<ExtendableFn, [
InstanceType<Super>, InstanceType<Super>,
...Call<Tuples.Map<TraitImplInstanceFn>, Traits>, ...Call<Tuples.Map<TraitOwnImplInstanceFn>, Traits>,
]> ]>
) )
type ImplStaticMembersExtendable< type ImplStaticMembersExtendable<
Super extends AbstractClass<{}>, Super extends AbstractClass<{}>,
Traits extends Trait<any, any>[], Traits extends Trait<any, any, any>[],
> = ( > = (
Pipe<[ Pipe<[
Super, Super,
...Call<Tuples.Map<TraitImplClassFn>, Traits>, ...Call<Tuples.Map<TraitOwnImplClassFn>, Traits>,
], [ ], [
Tuples.Map<StaticMembersFn>, Tuples.Map<StaticMembersFn>,
ExtendableFn, ExtendableFn,
@@ -142,7 +144,7 @@ type ImplStaticMembersExtendable<
type GetTraitExpression< type GetTraitExpression<
Super extends AbstractClass<{}>, Super extends AbstractClass<{}>,
Traits extends Trait<any, any>[], Traits extends Trait<any, any, any>[],
> = ( > = (
Call<Tuples.IsEmpty, Traits> extends true Call<Tuples.IsEmpty, Traits> extends true
? "Cannot express an empty list of traits." ? "Cannot express an empty list of traits."