0.1.0 #1
@@ -28,6 +28,7 @@
|
||||
"clean:node": "rm -rf node_modules"
|
||||
},
|
||||
"dependencies": {
|
||||
"hotscript": "^1.0.13",
|
||||
"type-fest": "^4.10.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
|
||||
24
src/tests.ts
24
src/tests.ts
@@ -1,6 +1,7 @@
|
||||
import { Simplify } from "type-fest"
|
||||
import { TraitAbstractMembers, TraitImplInstance, expresses, trait } from "."
|
||||
import { Trait, TraitAbstractMembers, TraitImplInstance, expresses, trait } from "."
|
||||
import { MergeInheritanceTree, TraitsAbstractMembers } from "./util"
|
||||
import { Call, Fn, Tuples } from "hotscript"
|
||||
|
||||
|
||||
const PrintsHelloOnNew = trait()(Super =>
|
||||
@@ -41,12 +42,31 @@ const ActiveStatefulSubscription = trait<ActiveStatefulSubscriptionAbstractMembe
|
||||
)
|
||||
|
||||
|
||||
interface AbstractMembersOfTrait extends Fn {
|
||||
return: this["arg0"] extends Trait<infer AbstractMembers, any>
|
||||
? AbstractMembers
|
||||
: never
|
||||
}
|
||||
|
||||
// type Test = Simplify<TraitImplInstance<ReturnType<typeof Identifiable<bigint>>>>
|
||||
type Test1 = [
|
||||
TraitAbstractMembers<typeof StatefulSubscription>,
|
||||
TraitAbstractMembers<typeof ActiveStatefulSubscription>,
|
||||
]
|
||||
type Test2 = Simplify<MergeInheritanceTree<Test1>>
|
||||
type Test2 = TraitsAbstractMembers<[
|
||||
typeof StatefulSubscription,
|
||||
typeof ActiveStatefulSubscription,
|
||||
]>
|
||||
type Test3 = Simplify<
|
||||
MergeInheritanceTree<
|
||||
Call<Tuples.Map<AbstractMembersOfTrait>, [
|
||||
typeof StatefulSubscription,
|
||||
typeof ActiveStatefulSubscription,
|
||||
]>
|
||||
>
|
||||
>
|
||||
// type Test2 = Simplify<MergeInheritanceTree<Test1>>
|
||||
|
||||
|
||||
const appliedIdentifiable = Identifiable<bigint>().apply({} as any)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user