Files
traitify-ts/src/TraitExpression.ts
Julien Valverdé df7e7f3401
All checks were successful
continuous-integration/drone/push Build is passing
Fixed TraitExpressionBuilder
2024-02-19 22:08:24 +01:00

161 lines
3.9 KiB
TypeScript

import { AbstractClass, Class, Simplify } from "type-fest"
import { Trait, TraitTuple } from "./Trait"
import { TraitBuilder } from "./TraitBuilder"
import { Extend, StaticMembers } from "./util"
export class TraitExpression<
Superclass extends AbstractClass<object>,
const Traits extends Trait<any, any, any, any>[],
> {
constructor(
readonly superclass: Superclass,
readonly traits: Traits,
) {}
get extends(): (
AbstractClass<
Simplify<
Extend<[
InstanceType<Superclass>,
...TraitTuple.MapImplInstance<Traits>,
]>
>,
ConstructorParameters<Superclass>
> &
Simplify<
Extend<[
StaticMembers<Superclass>,
...TraitTuple.MapImplStaticMembers<Traits>,
]>
>
) {
return this.traits.reduce(
(previous, trait) => trait.apply(previous),
this.superclass,
) as any
}
implementsStatic(target: ImplementsStatic<typeof this>, context: any) {}
subtrait<
This extends TraitExpression<typeof TraitExpression.NullSuperclass, any>
>(
this: This
) {
return new TraitBuilder<
This,
Simplify<
Extend<TraitTuple.MapAbstract<Traits>>
>,
Simplify<
Extend<TraitTuple.MapStaticAbstract<Traits>>
>,
AbstractClass<
Simplify<
Extend<TraitTuple.MapImplInstance<Traits>>
>
> &
Simplify<
Extend<TraitTuple.MapImplStaticMembers<Traits>>
>
>(
this,
{} as any,
{} as any,
Super => class extends Super {} as any,
)
}
}
export namespace TraitExpression {
export class NullSuperclass {
static readonly _tag = "@thilawyn/traitify-ts/TraitExpression.NullSuperclass"
constructor(...args: any[]) {}
}
export type Superclass<T> = (
T extends TraitExpression<infer Superclass, any>
? Superclass
: never
)
export type Traits<T> = (
T extends TraitExpression<any, infer Traits>
? Traits
: never
)
}
export type Implements<
Exp extends TraitExpression<any, Trait<any, any, any, any>[]>
> = (
Simplify<
Extend<
TraitTuple.MapAbstract<
TraitExpression.Traits<Exp>
>
>
>
)
export type ImplementsStatic<
Exp extends TraitExpression<any, Trait<any, any, any, any>[]>
> = (
Simplify<
Extend<
TraitTuple.MapStaticAbstract<
TraitExpression.Traits<Exp>
>
>
>
)
export type TraitExpressionClass<
Exp extends TraitExpression<any, Trait<any, any, any, any>[]>
> = (
AbstractClass<
TraitExpressionInstance<Exp>,
ConstructorParameters<TraitExpression.Superclass<Exp>>
> &
TraitExpressionStaticMembers<Exp>
)
export type TraitExpressionConcreteClass<
Exp extends TraitExpression<any, Trait<any, any, any, any>[]>
> = (
Class<
TraitExpressionInstance<Exp>,
ConstructorParameters<TraitExpression.Superclass<Exp>>
> &
TraitExpressionStaticMembers<Exp>
)
export type TraitExpressionInstance<
Exp extends TraitExpression<any, Trait<any, any, any, any>[]>
> = (
Simplify<
Extend<[
InstanceType<TraitExpression.Superclass<Exp>>,
...TraitTuple.MapInstance<TraitExpression.Traits<Exp>>,
]>
>
)
export type TraitExpressionStaticMembers<
Exp extends TraitExpression<any, Trait<any, any, any, any>[]>
> = (
Simplify<
Extend<[
StaticMembers<TraitExpression.Superclass<Exp>>,
...TraitTuple.MapStaticMembers<TraitExpression.Traits<Exp>>,
]>
>
)