plugin-tls 1.0.0 → 1.1.0
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.
- package/dist/extend/extend.d.ts +222 -0
- package/dist/extend/extend.d.ts.map +1 -0
- package/dist/extend/mixin.d.ts +105 -0
- package/dist/extend/mixin.d.ts.map +1 -0
- package/dist/index.d.ts +29 -251
- package/dist/index.d.ts.map +1 -0
- package/dist/options-manager/ModeOptions.d.ts +88 -0
- package/dist/options-manager/ModeOptions.d.ts.map +1 -0
- package/dist/options-manager/OptionsManager.d.ts +105 -0
- package/dist/options-manager/OptionsManager.d.ts.map +1 -0
- package/dist/options-manager/TierModeOptions.d.ts +69 -0
- package/dist/options-manager/TierModeOptions.d.ts.map +1 -0
- package/dist/options-manager/TierOptions.d.ts +48 -0
- package/dist/options-manager/TierOptions.d.ts.map +1 -0
- package/dist/options-manager/defaultOptions.d.ts +34 -0
- package/dist/options-manager/defaultOptions.d.ts.map +1 -0
- package/dist/options-manager/tools.d.ts +35 -0
- package/dist/options-manager/tools.d.ts.map +1 -0
- package/dist/plugin-host/PluginHost.d.ts +184 -0
- package/dist/plugin-host/PluginHost.d.ts.map +1 -0
- package/dist/plugin-host/TierModeOptionsPluginHost.d.ts +102 -0
- package/dist/plugin-host/TierModeOptionsPluginHost.d.ts.map +1 -0
- package/dist/plugin-host/TierOptionsPluginHost.d.ts +83 -0
- package/dist/plugin-host/TierOptionsPluginHost.d.ts.map +1 -0
- package/dist/plugin-manager/PluginManager.d.ts +119 -0
- package/dist/plugin-manager/PluginManager.d.ts.map +1 -0
- package/dist/plugin-manager/PluginManagerWithInit.d.ts +36 -0
- package/dist/plugin-manager/PluginManagerWithInit.d.ts.map +1 -0
- package/dist/plugin-tls.d.ts +1216 -160
- package/dist/plugin-tls.iife.js +1 -0
- package/dist/plugin-tls.mjs +1011 -102
- package/dist/plugin-tls.umd.js +1 -1
- package/dist/properties.d.ts +30 -0
- package/dist/properties.d.ts.map +1 -0
- package/dist/tsdoc-metadata.json +1 -1
- package/doc/api/index.md +1 -1
- package/doc/api/plugin-tls.adddefaultoptions.md +3 -3
- package/doc/api/plugin-tls.addinstoptions.md +2 -2
- package/doc/api/plugin-tls.allfunctionapply.md +26 -0
- package/doc/api/plugin-tls.becomepluginhost.md +15 -0
- package/doc/api/plugin-tls.becomepluginhost_extends.md +38 -0
- package/doc/api/plugin-tls.becomepluginhost_proxy.md +29 -0
- package/doc/api/plugin-tls.becometiermodeoptionshost.md +15 -0
- package/doc/api/plugin-tls.becometieroptionshost.md +15 -0
- package/doc/api/plugin-tls.classextender.md +15 -0
- package/doc/api/plugin-tls.classextenderprivatemember._constructors.md +13 -0
- package/doc/api/plugin-tls.classextenderprivatemember._destroys.md +13 -0
- package/doc/api/plugin-tls.classextenderprivatemember.md +21 -0
- package/doc/api/plugin-tls.classextenderprivatememberwithinit._inits.md +13 -0
- package/doc/api/plugin-tls.classextenderprivatememberwithinit.md +21 -0
- package/doc/api/plugin-tls.classextenderwithinit.md +15 -0
- package/doc/api/plugin-tls.classtype._new_.md +22 -0
- package/doc/api/plugin-tls.classtype.md +20 -0
- package/doc/api/plugin-tls.commonmodename.md +18 -0
- package/doc/api/plugin-tls.createcallerofprivatememberofextend.md +30 -0
- package/doc/api/plugin-tls.createdefinemixin.md +23 -0
- package/doc/api/plugin-tls.createextendtarget.md +30 -0
- package/doc/api/plugin-tls.createextendtargetwithinit.md +30 -0
- package/doc/api/plugin-tls.createmixintarget.md +30 -0
- package/doc/api/plugin-tls.createpluginhost.md +16 -11
- package/doc/api/plugin-tls.createpropertysetter.md +30 -0
- package/doc/api/plugin-tls.createtargetextend.md +30 -0
- package/doc/api/plugin-tls.createtargetextendwithinit.md +30 -0
- package/doc/api/plugin-tls.createtargetmixin.md +30 -0
- package/doc/api/plugin-tls.createtiermodeoptionspluginhost.md +32 -0
- package/doc/api/plugin-tls.createtieroptionspluginhost.md +30 -0
- package/doc/api/plugin-tls.defineextend.md +35 -0
- package/doc/api/plugin-tls.defineextendwithinit.md +35 -0
- package/doc/api/plugin-tls.definemixin.md +31 -0
- package/doc/api/plugin-tls.extendtarget.md +31 -0
- package/doc/api/plugin-tls.extendtargetwithinit.md +31 -0
- package/doc/api/plugin-tls.formatuseparameters.md +13 -0
- package/doc/api/plugin-tls.formatusepluginparameters.md +15 -0
- package/doc/api/plugin-tls.getnormalizepluginoptions.md +15 -0
- package/doc/api/plugin-tls.getpluginoptions.md +15 -0
- package/doc/api/plugin-tls.getpropertyvalue.md +26 -0
- package/doc/api/plugin-tls.getpropertyvaluebypath.md +26 -0
- package/doc/api/plugin-tls.gettargetproperties.md +26 -0
- package/doc/api/plugin-tls.hostinst.md +2 -2
- package/doc/api/plugin-tls.idefaultoptionshost.defaultoptions.md +1 -1
- package/doc/api/plugin-tls.idefaultoptionshost.md +1 -1
- package/doc/api/plugin-tls.iidefaultoptionshostconstructor.md +1 -1
- package/doc/api/plugin-tls.iplugin.created.md +4 -4
- package/doc/api/plugin-tls.iplugin.destroyed.md +25 -0
- package/doc/api/plugin-tls.iplugin.md +4 -3
- package/doc/api/plugin-tls.iplugin.used.md +4 -4
- package/doc/api/plugin-tls.ipluginhost.md +2 -2
- package/doc/api/plugin-tls.ipluginhost.use.md +6 -6
- package/doc/api/plugin-tls.ipluginhostconstructor.md +2 -2
- package/doc/api/plugin-tls.ipluginhostconstructor.use.md +6 -6
- package/doc/api/plugin-tls.ipluginwithinit.inited.md +25 -0
- package/doc/api/plugin-tls.ipluginwithinit.md +21 -0
- package/doc/api/plugin-tls.itiermodeoptionshost.md +21 -0
- package/doc/api/plugin-tls.itiermodeoptionshost.mode.md +11 -0
- package/doc/api/plugin-tls.itiermodeoptionshost.modeoptions.md +11 -0
- package/doc/api/plugin-tls.itiermodeoptionshostconstructor.md +13 -0
- package/doc/api/plugin-tls.itiermodeoptionspluginhost.md +15 -0
- package/doc/api/plugin-tls.itiermodeoptionspluginhostconstructor.md +15 -0
- package/doc/api/plugin-tls.itieroptionshost.defaultoptions.md +11 -0
- package/doc/api/plugin-tls.itieroptionshost.md +20 -0
- package/doc/api/plugin-tls.itieroptionshostconstructor.md +13 -0
- package/doc/api/plugin-tls.itieroptionspluginhost.md +15 -0
- package/doc/api/plugin-tls.itieroptionspluginhostconstructor.md +15 -0
- package/doc/api/plugin-tls.md +82 -6
- package/doc/api/plugin-tls.mergeproperties.md +25 -0
- package/doc/api/plugin-tls.mixin_4.md +33 -0
- package/doc/api/plugin-tls.mixintarget.md +31 -0
- package/doc/api/plugin-tls.modeoptions._constructor_.md +20 -0
- package/doc/api/plugin-tls.modeoptions._constructor__1.md +21 -0
- package/doc/api/plugin-tls.modeoptions._mode.md +11 -0
- package/doc/api/plugin-tls.modeoptions._modenames.md +11 -0
- package/doc/api/plugin-tls.modeoptions._plainfulloption.md +11 -0
- package/doc/api/plugin-tls.modeoptions.getfullmodeoption.md +29 -0
- package/doc/api/plugin-tls.modeoptions.getmodenames.md +18 -0
- package/doc/api/plugin-tls.modeoptions.getmodeoption.md +29 -0
- package/doc/api/plugin-tls.modeoptions.hasmode.md +25 -0
- package/doc/api/plugin-tls.modeoptions.md +57 -0
- package/doc/api/plugin-tls.modeoptions.mode.md +15 -0
- package/doc/api/plugin-tls.modeoptions.modenames.md +13 -0
- package/doc/api/plugin-tls.modeoptions.modes.md +13 -0
- package/doc/api/plugin-tls.modeoptions.option.md +13 -0
- package/doc/api/plugin-tls.modeoptions.optionmanager.md +13 -0
- package/doc/api/plugin-tls.modeoptions.plainfulloption.md +11 -0
- package/doc/api/plugin-tls.modeoptions.setmodeoption.md +27 -0
- package/doc/api/plugin-tls.modeoptions.updatefulloption.md +17 -0
- package/doc/api/plugin-tls.normalizepluginoptions.md +18 -0
- package/doc/api/plugin-tls.parsepropertypath.md +25 -0
- package/doc/api/plugin-tls.plugincreatedreturntype.md +3 -3
- package/doc/api/plugin-tls.pluginhost._pluginmanager.md +2 -2
- package/doc/api/plugin-tls.pluginhost.destroy.md +18 -0
- package/doc/api/plugin-tls.pluginhost.md +24 -11
- package/doc/api/plugin-tls.pluginhost.pluginmanager.md +2 -2
- package/doc/api/plugin-tls.pluginhost.use.md +5 -5
- package/doc/api/plugin-tls.pluginmanager._constructor_.md +20 -0
- package/doc/api/plugin-tls.pluginmanager.created.md +4 -4
- package/doc/api/plugin-tls.pluginmanager.destroyed.md +28 -0
- package/doc/api/plugin-tls.pluginmanager.host.md +2 -2
- package/doc/api/plugin-tls.pluginmanager.instuse.md +8 -8
- package/doc/api/plugin-tls.pluginmanager.md +12 -5
- package/doc/api/plugin-tls.pluginmanager.pluginoptsmap.md +2 -2
- package/doc/api/plugin-tls.pluginmanager.plugins.md +2 -2
- package/doc/api/plugin-tls.pluginmanager.use.md +6 -6
- package/doc/api/plugin-tls.pluginmanagerwithinit.inited.md +28 -0
- package/doc/api/plugin-tls.pluginmanagerwithinit.md +25 -0
- package/doc/api/plugin-tls.pluginusereturntype.md +3 -3
- package/doc/api/plugin-tls.privatememberofextend._constructor.md +32 -0
- package/doc/api/plugin-tls.privatememberofextend._destroy.md +25 -0
- package/doc/api/plugin-tls.privatememberofextend.md +21 -0
- package/doc/api/plugin-tls.privatememberofextendwithinit._init.md +28 -0
- package/doc/api/plugin-tls.privatememberofextendwithinit.md +21 -0
- package/doc/api/plugin-tls.replaceconstructorparameters.md +13 -0
- package/doc/api/plugin-tls.replaceconstructorreturn.md +13 -0
- package/doc/api/plugin-tls.setpropertyvalue.md +27 -0
- package/doc/api/plugin-tls.setpropertyvaluebypath.md +27 -0
- package/doc/api/plugin-tls.targetextend.md +31 -0
- package/doc/api/plugin-tls.targetextendwithinit.md +31 -0
- package/doc/api/plugin-tls.targetmixin.md +31 -0
- package/doc/api/plugin-tls.tiermodeoptions._constructor_.md +20 -0
- package/doc/api/plugin-tls.tiermodeoptions._constructor__1.md +22 -0
- package/doc/api/plugin-tls.tiermodeoptions._extends.md +11 -0
- package/doc/api/plugin-tls.tiermodeoptions.extends.md +15 -0
- package/doc/api/plugin-tls.tiermodeoptions.getfullmodeoption.md +29 -0
- package/doc/api/plugin-tls.tiermodeoptions.getmember.md +25 -0
- package/doc/api/plugin-tls.tiermodeoptions.getmodenames.md +18 -0
- package/doc/api/plugin-tls.tiermodeoptions.getmodeoptionmanager.md +25 -0
- package/doc/api/plugin-tls.tiermodeoptions.getvalue.md +25 -0
- package/doc/api/plugin-tls.tiermodeoptions.hasmodeontier.md +25 -0
- package/doc/api/plugin-tls.tiermodeoptions.md +45 -0
- package/doc/api/plugin-tls.tiermodeoptions.optionmanager.md +13 -0
- package/doc/api/plugin-tls.tiermodeoptionsdecorator.md +30 -0
- package/doc/api/plugin-tls.tiermodeoptionspluginhost._constructor_.md +20 -0
- package/doc/api/plugin-tls.tiermodeoptionspluginhost._modeoptions.md +11 -0
- package/doc/api/plugin-tls.tiermodeoptionspluginhost.md +37 -0
- package/doc/api/plugin-tls.tiermodeoptionspluginhost.mode.md +13 -0
- package/doc/api/plugin-tls.tiermodeoptionspluginhost.modeoptions.md +13 -0
- package/doc/api/plugin-tls.tiermodeoptionspluginhost.options.md +11 -0
- package/doc/api/plugin-tls.tieroptions._constructor_.md +21 -0
- package/doc/api/plugin-tls.tieroptions._extends.md +11 -0
- package/doc/api/plugin-tls.tieroptions._plainfulloption.md +11 -0
- package/doc/api/plugin-tls.tieroptions.extends.md +15 -0
- package/doc/api/plugin-tls.tieroptions.getmember.md +25 -0
- package/doc/api/plugin-tls.tieroptions.getvalue.md +25 -0
- package/doc/api/plugin-tls.tieroptions.md +37 -0
- package/doc/api/plugin-tls.tieroptions.option.md +13 -0
- package/doc/api/plugin-tls.tieroptions.plainfulloption.md +18 -0
- package/doc/api/plugin-tls.tieroptions.updatefulloption.md +17 -0
- package/doc/api/plugin-tls.tieroptionsdecorator.md +30 -0
- package/doc/api/plugin-tls.tieroptionspluginhost._constructor_.md +20 -0
- package/doc/api/plugin-tls.tieroptionspluginhost._defaultoptions.md +11 -0
- package/doc/api/plugin-tls.tieroptionspluginhost.defaultoptions.md +13 -0
- package/doc/api/plugin-tls.tieroptionspluginhost.md +35 -0
- package/package.json +23 -15
- package/doc/api/plugin-tls.createoptionspluginhost.md +0 -29
- package/doc/api/plugin-tls.ioptionspluginhost.defaultoptions.md +0 -11
- package/doc/api/plugin-tls.ioptionspluginhost.md +0 -21
- package/doc/api/plugin-tls.ioptionspluginhostconstructor.md +0 -15
- package/doc/api/plugin-tls.optionspluginhost._defaultoptions.md +0 -11
- package/doc/api/plugin-tls.optionspluginhost.defaultoptions.md +0 -13
- package/doc/api/plugin-tls.optionspluginhost.md +0 -21
- package/doc/api/plugin-tls.pluginhost._constructor_.md +0 -13
- package/doc/api/plugin-tls.pluginoptions.md +0 -11
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 类的类型、构造函数的类型
|
|
3
|
+
*
|
|
4
|
+
* @typeParam Arg - 构建函数的参数类型
|
|
5
|
+
* @typeParam Instance - 构建函数的返回的实例类型
|
|
6
|
+
*/
|
|
7
|
+
export interface ClassType<Arg extends any[] = any, Instance = any> {
|
|
8
|
+
new (...args: Arg): Instance;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* 类扩展者的私有方法
|
|
12
|
+
*/
|
|
13
|
+
export interface ClassExtenderPrivateMember<C extends new (...args: any) => any> {
|
|
14
|
+
/**
|
|
15
|
+
* 保存扩展类自定义的构建函数
|
|
16
|
+
*/
|
|
17
|
+
readonly _constructors: ((this: InstanceType<C>, ...args: ConstructorParameters<C>) => void)[];
|
|
18
|
+
/**
|
|
19
|
+
* 保存扩展类自定义的销毁函数
|
|
20
|
+
*/
|
|
21
|
+
readonly _destroys: ((this: InstanceType<C>) => void)[];
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* 类扩展者
|
|
25
|
+
*/
|
|
26
|
+
export type ClassExtender<C extends new (...args: any) => any> = C & ClassExtenderPrivateMember<C>;
|
|
27
|
+
/**
|
|
28
|
+
* 用于定义扩展选项中的私有成员
|
|
29
|
+
*/
|
|
30
|
+
export interface PrivateMemberOfExtend<TargetType extends new (...args: any) => any> {
|
|
31
|
+
/**
|
|
32
|
+
* 扩展类中用于定义在创建实例时的初始化的方法
|
|
33
|
+
* @remarks
|
|
34
|
+
* 该方法会在创建实例时自动执行,并将构建函数接收到的参数透传给方方法。
|
|
35
|
+
*
|
|
36
|
+
* 注意:
|
|
37
|
+
* _constructor 会被保存在 目标类中的 _constructors 属性中,它是一个数组。
|
|
38
|
+
*
|
|
39
|
+
* 目标类 需要在自己的构建函数中逐个调用 cla._constructors 中的函数
|
|
40
|
+
*
|
|
41
|
+
* @param args
|
|
42
|
+
*/
|
|
43
|
+
_constructor?(...args: (TargetType extends new (...args: infer A) => any ? A : never)): void;
|
|
44
|
+
/**
|
|
45
|
+
* 扩展类中用于定义在实例销毁时触发的销毁方法
|
|
46
|
+
* @remarks
|
|
47
|
+
* 该方法会在实例销毁时自动调用
|
|
48
|
+
*
|
|
49
|
+
* 注意:
|
|
50
|
+
* _destroy 会被保存在 目标类中的 _destroys 属性中,它是一个数组。
|
|
51
|
+
*
|
|
52
|
+
* 如果目标类有销毁逻辑,则需要在自己的销毁函数中逐个调用 cla._destroys 中的函数
|
|
53
|
+
*
|
|
54
|
+
* @param args
|
|
55
|
+
*/
|
|
56
|
+
_destroy?(): void;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* 定义扩展的类型便利函数
|
|
60
|
+
*
|
|
61
|
+
* @remarks
|
|
62
|
+
* 它会更改 ext 中方法的this指向为 cla & ext,不会真的执行扩展操作。
|
|
63
|
+
*
|
|
64
|
+
* 其中 ext._constructor 会被保存在 cla._constructors 属性中,它是一个数组。
|
|
65
|
+
*
|
|
66
|
+
* cla 需要在自己的构建函数中逐个调用 cla._constructors 中的函数
|
|
67
|
+
*
|
|
68
|
+
* @param cla - 扩展的目标,用作 this 的类型
|
|
69
|
+
* @param ext - 描述扩展内容的对象,会自动更改其this的类型
|
|
70
|
+
* @returns 返回注入了 this 类型的 ext 对象本身
|
|
71
|
+
*/
|
|
72
|
+
export declare function defineExtend<C extends ClassType, E>(cla: C, ext: E & ThisType<InstanceType<C> & E> & PrivateMemberOfExtend<C>): E & ThisType<C & E>;
|
|
73
|
+
/**
|
|
74
|
+
* 扩展目标
|
|
75
|
+
*
|
|
76
|
+
* @remarks
|
|
77
|
+
* 与 {@link defineExtend} 的区别是:`targetExtend` 会执行对 cla 的扩展操作,而 {@link defineExtend} 不会
|
|
78
|
+
*
|
|
79
|
+
*
|
|
80
|
+
* @param cla - 扩展的目标,也用作 this 的类型
|
|
81
|
+
* @param ext - 扩展描述对象,会自动更改其this的类型
|
|
82
|
+
* @returns 返回注入了 this 类型的 ext 对象本身
|
|
83
|
+
*/
|
|
84
|
+
export declare function targetExtend<C extends ClassType, E>(cla: C, ext: E & ThisType<InstanceType<C> & E> & PrivateMemberOfExtend<C>): E & ThisType<InstanceType<C> & E>;
|
|
85
|
+
/**
|
|
86
|
+
* 创建用于扩展目标的便捷函数
|
|
87
|
+
*
|
|
88
|
+
* @remarks
|
|
89
|
+
* 它返回的便利函数的功能与 {@link targetExtend} 的功能一样,唯一区别是不再需要接收 cla 参数了
|
|
90
|
+
*
|
|
91
|
+
* @param cla - 扩展的目标,也用作 this 的类型
|
|
92
|
+
* @returns 可以用于 扩展目标 的便利函数
|
|
93
|
+
*/
|
|
94
|
+
export declare function createTargetExtend<C extends ClassType>(cla: C): <E>(ext: E & ThisType<InstanceType<C> & E> & PrivateMemberOfExtend<C>) => E & ThisType<C & E>;
|
|
95
|
+
/**
|
|
96
|
+
* 扩展目标
|
|
97
|
+
*
|
|
98
|
+
* @remarks
|
|
99
|
+
* 会执行对 CEarth 类的扩展操作。
|
|
100
|
+
* 与 {@link targetExtend} 的区别仅仅是返回类型不一样。
|
|
101
|
+
*
|
|
102
|
+
* @param cla - 扩展的目标,也用作 this 的类型
|
|
103
|
+
* @param ext - 扩展对象,会自动更改其this的类型
|
|
104
|
+
* @returns 返回扩展后的 cla 对象
|
|
105
|
+
*/
|
|
106
|
+
export declare function extendTarget<C extends ClassType, E>(cla: C, ext: E & ThisType<InstanceType<C> & E> & PrivateMemberOfExtend<C>): ClassType<ConstructorParameters<C>, E & ThisType<InstanceType<C> & E>>;
|
|
107
|
+
/**
|
|
108
|
+
* 创建用于扩展目标工具函数
|
|
109
|
+
*
|
|
110
|
+
* @remarks
|
|
111
|
+
* 它返回的便利函数的功能与 {@link extendTarget} 的功能一样,唯一区别是不再需要接收 cla 参数了
|
|
112
|
+
*
|
|
113
|
+
* @param cla - 扩展的目标,也用作 this 的类型
|
|
114
|
+
* @returns 可以用于 扩展目标 的便利函数
|
|
115
|
+
*/
|
|
116
|
+
export declare function createExtendTarget<C extends ClassType>(cla: C): <E>(ext: E & ThisType<InstanceType<C> & E> & PrivateMemberOfExtend<C>) => ClassType<ConstructorParameters<C>, E & ThisType<InstanceType<C> & E>>;
|
|
117
|
+
/**
|
|
118
|
+
* 类扩展者的私有方法
|
|
119
|
+
*/
|
|
120
|
+
export interface ClassExtenderPrivateMemberWithInit<C extends new (...args: any) => any, InitParams extends any[] = any> extends ClassExtenderPrivateMember<C> {
|
|
121
|
+
/**
|
|
122
|
+
* 保存扩展类中自定义的初始化方法
|
|
123
|
+
*/
|
|
124
|
+
readonly _inits: ((this: InstanceType<C>, ...args: InitParams) => void)[];
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* 类扩展者
|
|
128
|
+
*/
|
|
129
|
+
export type ClassExtenderWithInit<C extends new (...args: any) => any, InitParams extends any[] = any> = C & ClassExtenderPrivateMemberWithInit<C, InitParams>;
|
|
130
|
+
/**
|
|
131
|
+
* 用于定义扩展选项中的私有成员
|
|
132
|
+
*/
|
|
133
|
+
export interface PrivateMemberOfExtendWithInit<TargetType extends new (...args: any) => any, InitParams extends any[] = any> extends PrivateMemberOfExtend<TargetType> {
|
|
134
|
+
/**
|
|
135
|
+
* 扩展类中用于定义实例初始化逻辑的方法
|
|
136
|
+
* @remarks
|
|
137
|
+
* 该方法会在调用实例的 `init()` 方法时自动执行。
|
|
138
|
+
* @param args
|
|
139
|
+
*/
|
|
140
|
+
_init?(...args: InitParams): void;
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* 对一组函数批量调用 apply
|
|
144
|
+
* @param funArr
|
|
145
|
+
* @param thisArg
|
|
146
|
+
* @param args
|
|
147
|
+
*/
|
|
148
|
+
export declare function allFunctionApply<T, A extends any[], R>(funArr: ((this: T, ...args: A) => void)[], thisArg: T, args: A): void;
|
|
149
|
+
/**
|
|
150
|
+
* 创建扩展的私有方法的调用者
|
|
151
|
+
* @param cla
|
|
152
|
+
* @returns constructed:执行所有 `_constructor` 的便利函数;initialized:执行所有 `_inits` 的便利函数
|
|
153
|
+
*/
|
|
154
|
+
export declare function createCallerOfPrivateMemberOfExtend<C extends ClassType>(cla: C): {
|
|
155
|
+
constructed: (thisArg: any, args: any[]) => void;
|
|
156
|
+
initialized: (thisArg: any, args: any[]) => void;
|
|
157
|
+
destroyed: (thisArg: any, args: any[]) => void;
|
|
158
|
+
};
|
|
159
|
+
/**
|
|
160
|
+
* 定义扩展的类型便利函数
|
|
161
|
+
*
|
|
162
|
+
* @remarks
|
|
163
|
+
* 它会更改 ext 中方法的this指向为 cla & ext,不会真的执行扩展操作。
|
|
164
|
+
*
|
|
165
|
+
* 其中:
|
|
166
|
+
* - ext._constructor 会被保存在 cla._constructors 属性中,它是一个数组。
|
|
167
|
+
* - ext._init 会被保存在 cla._inits 属性中,它是一个数组。
|
|
168
|
+
*
|
|
169
|
+
* cla 需要:
|
|
170
|
+
* - 在自己的构建函数中逐个调用 cla._constructors 中的函数
|
|
171
|
+
* - 在自己的类似初始化`init()` 方法中逐个调用 cla._constructors 中的函数
|
|
172
|
+
*
|
|
173
|
+
* @param cla - 扩展的目标,用作 this 的类型
|
|
174
|
+
* @param ext - 描述扩展内容的对象,会自动更改其this的类型
|
|
175
|
+
* @returns 返回注入了 this 类型的 ext 对象本身
|
|
176
|
+
*/
|
|
177
|
+
export declare function defineExtendWithInit<C extends ClassType, E>(cla: C, ext: E & ThisType<InstanceType<C> & E> & PrivateMemberOfExtendWithInit<C>): E & ThisType<C & E>;
|
|
178
|
+
/**
|
|
179
|
+
* 扩展目标
|
|
180
|
+
*
|
|
181
|
+
* @remarks
|
|
182
|
+
* 与 {@link defineExtendWithInit} 的区别是:`targetExtend` 会执行对 cla 的扩展操作,而 {@link defineExtendWithInit} 不会
|
|
183
|
+
*
|
|
184
|
+
*
|
|
185
|
+
* @param cla - 扩展的目标,也用作 this 的类型
|
|
186
|
+
* @param ext - 扩展描述对象,会自动更改其this的类型
|
|
187
|
+
* @returns 返回注入了 this 类型的 ext 对象本身
|
|
188
|
+
*/
|
|
189
|
+
export declare function targetExtendWithInit<C extends ClassType, E>(cla: C, ext: E & ThisType<InstanceType<C> & E> & PrivateMemberOfExtendWithInit<C>): E & ThisType<InstanceType<C> & E>;
|
|
190
|
+
/**
|
|
191
|
+
* 创建用于扩展目标的便捷函数
|
|
192
|
+
*
|
|
193
|
+
* @remarks
|
|
194
|
+
* 它返回的便利函数的功能与 {@link targetExtendWithInit} 的功能一样,唯一区别是不再需要接收 cla 参数了
|
|
195
|
+
*
|
|
196
|
+
* @param cla - 扩展的目标,也用作 this 的类型
|
|
197
|
+
* @returns 可以用于 扩展目标 的便利函数
|
|
198
|
+
*/
|
|
199
|
+
export declare function createTargetExtendWithInit<C extends ClassType>(cla: C): <E>(ext: E & ThisType<InstanceType<C> & E> & PrivateMemberOfExtendWithInit<C, any>) => E & ThisType<C & E>;
|
|
200
|
+
/**
|
|
201
|
+
* 扩展目标
|
|
202
|
+
*
|
|
203
|
+
* @remarks
|
|
204
|
+
* 会执行对 CEarth 类的扩展操作。
|
|
205
|
+
* 与 {@link targetExtendWithInit} 的区别仅仅是返回类型不一样。
|
|
206
|
+
*
|
|
207
|
+
* @param cla - 扩展的目标,也用作 this 的类型
|
|
208
|
+
* @param ext - 扩展对象,会自动更改其this的类型
|
|
209
|
+
* @returns 返回扩展后的 cla 对象
|
|
210
|
+
*/
|
|
211
|
+
export declare function extendTargetWithInit<C extends ClassType, E>(cla: C, ext: E & ThisType<InstanceType<C> & E> & PrivateMemberOfExtendWithInit<C>): ClassType<ConstructorParameters<C>, E & ThisType<InstanceType<C> & E>>;
|
|
212
|
+
/**
|
|
213
|
+
* 创建用于扩展目标工具函数
|
|
214
|
+
*
|
|
215
|
+
* @remarks
|
|
216
|
+
* 它返回的便利函数的功能与 {@link extendTargetWithInit} 的功能一样,唯一区别是不再需要接收 cla 参数了
|
|
217
|
+
*
|
|
218
|
+
* @param cla - 扩展的目标,也用作 this 的类型
|
|
219
|
+
* @returns 可以用于 扩展目标 的便利函数
|
|
220
|
+
*/
|
|
221
|
+
export declare function createExtendTargetWithInit<C extends ClassType>(cla: C): <E>(ext: E & ThisType<InstanceType<C> & E> & PrivateMemberOfExtendWithInit<C, any>) => ClassType<ConstructorParameters<C>, E & ThisType<InstanceType<C> & E>>;
|
|
222
|
+
//# sourceMappingURL=extend.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extend.d.ts","sourceRoot":"","sources":["../../src/extend/extend.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 混合
|
|
3
|
+
* @internal
|
|
4
|
+
*/
|
|
5
|
+
export declare function mixin<T, S>(target: T, source: S): T & S;
|
|
6
|
+
/**
|
|
7
|
+
* 混合
|
|
8
|
+
* @internal
|
|
9
|
+
*/
|
|
10
|
+
export declare function mixin<T, S1, S2>(target: T, source1: S1, source2: S2): T & S1 & S2;
|
|
11
|
+
/**
|
|
12
|
+
* 混合
|
|
13
|
+
* @internal
|
|
14
|
+
*/
|
|
15
|
+
export declare function mixin<T, S1, S2, S3>(target: T, source1: S1, source2: S2, source3: S3): T & S1 & S2 & S3;
|
|
16
|
+
/**
|
|
17
|
+
* 混合
|
|
18
|
+
* @internal
|
|
19
|
+
*/
|
|
20
|
+
export declare function mixin<T, S1, S2, S3, S4>(target: T, source1: S1, source2: S2, source3: S3, source4: S3): T & S1 & S2 & S3 & S4;
|
|
21
|
+
/**
|
|
22
|
+
* 混合
|
|
23
|
+
*
|
|
24
|
+
* @remarks
|
|
25
|
+
* 将 source 的所有成员混入 target 对象中。
|
|
26
|
+
*
|
|
27
|
+
* 与 `Object.assign()` 的功能类似,不同的是 `mixin()` 会在 target 对象中 保持 source 对象属性的 PropertyDescriptors
|
|
28
|
+
*
|
|
29
|
+
* @param target - 目标对象,所有 源对象 的属性都要被混入进到 目标对象中
|
|
30
|
+
* @param sources - 源对象,所有 源对象 的属性都要被混入进到 目标对象中
|
|
31
|
+
* @returns 混入后的 target
|
|
32
|
+
*/
|
|
33
|
+
export declare function mixin(target: any, ...sources: any[]): any;
|
|
34
|
+
/**
|
|
35
|
+
* 定义混合的类型便利函数
|
|
36
|
+
*
|
|
37
|
+
* @remarks
|
|
38
|
+
* 它会更改 mixin 中方法的this指向为 target & mixin,不会真的执行混合操作
|
|
39
|
+
*
|
|
40
|
+
* @param target - 混合的目标,用作 this 的类型
|
|
41
|
+
* @param mixin - 混合对象,会自动更改其this的类型
|
|
42
|
+
* @returns 返回注入了 this 类型的 mixin 对象本身
|
|
43
|
+
*/
|
|
44
|
+
export declare function defineMixin<T, M>(target: T, mixin: M & ThisType<T & M>): M & ThisType<T & M>;
|
|
45
|
+
/**
|
|
46
|
+
* 创建定义混合的类型便利函数
|
|
47
|
+
*
|
|
48
|
+
* @remarks
|
|
49
|
+
* 它返回的便利函数的功能与 {@link defineMixin} 的功能一样,唯一区别是不再需要接收 target 参数了
|
|
50
|
+
*
|
|
51
|
+
* @returns 可以用于 定义混合的 类型便利函数
|
|
52
|
+
*/
|
|
53
|
+
export declare function createDefineMixin<T>(): <M>(target: T, mixin: M & ThisType<T & M>) => M & ThisType<T & M>;
|
|
54
|
+
/**
|
|
55
|
+
* 混合目标
|
|
56
|
+
*
|
|
57
|
+
* @remarks
|
|
58
|
+
* 与 {@link defineMixin} 的区别是:`targetMixin` 会执行对 target 的混合操作,而 {@link defineMixin} 不会
|
|
59
|
+
*
|
|
60
|
+
*
|
|
61
|
+
* @param target - 混合的目标,用作 this 的类型
|
|
62
|
+
* @param m - 混合对象,会自动更改其this的类型
|
|
63
|
+
* @returns 返回注入了 this 类型的 mixin 对象本身
|
|
64
|
+
*/
|
|
65
|
+
export declare function targetMixin<T, M>(target: T, m: M & ThisType<T & M>): M & ThisType<T & M>;
|
|
66
|
+
/**
|
|
67
|
+
* 创建用于混合目标的便捷函数
|
|
68
|
+
*
|
|
69
|
+
* @remarks
|
|
70
|
+
* 它返回的便利函数的功能与 {@link targetMixin} 的功能一样,唯一区别是不再需要接收 target 参数了
|
|
71
|
+
*
|
|
72
|
+
* @param target - 混合的目标,用作 this 的类型
|
|
73
|
+
* @returns 可以用于 混合目标 的便利函数
|
|
74
|
+
*/
|
|
75
|
+
export declare function createTargetMixin<T>(target: T): <M>(m: M & ThisType<T & M>) => M & ThisType<T & M>;
|
|
76
|
+
/**
|
|
77
|
+
* 混合目标
|
|
78
|
+
*
|
|
79
|
+
* @remarks
|
|
80
|
+
* 会执行对 CEarth 类的扩展操作。
|
|
81
|
+
* 与 {@link targetMixin} 的区别仅仅是返回类型不一样。
|
|
82
|
+
*
|
|
83
|
+
* @param target - 混合的目标,用作 this 的类型
|
|
84
|
+
* @param m - 混合对象,会自动更改其this的类型
|
|
85
|
+
* @returns 返回混合后的 target 对象
|
|
86
|
+
*/
|
|
87
|
+
export declare function mixinTarget<T, M>(target: T, m: M & ThisType<T & M>): M & ThisType<T & M> & T;
|
|
88
|
+
/**
|
|
89
|
+
* 创建用于混合目标工具函数
|
|
90
|
+
*
|
|
91
|
+
* @remarks
|
|
92
|
+
* 它返回的便利函数的功能与 {@link mixinTarget} 的功能一样,唯一区别是不再需要接收 target 参数了
|
|
93
|
+
*
|
|
94
|
+
* @returns 可以用于 混合目标 的便利函数
|
|
95
|
+
*/
|
|
96
|
+
export declare function createMixinTarget<T>(target: T): <M>(m: M & ThisType<T & M>) => M & ThisType<T & M> & T;
|
|
97
|
+
/**
|
|
98
|
+
* 替换构建函数的参数
|
|
99
|
+
*/
|
|
100
|
+
export type ReplaceConstructorParameters<C extends new (...args: any) => any, NewParms extends any[]> = new (...args: NewParms) => InstanceType<C>;
|
|
101
|
+
/**
|
|
102
|
+
* 替换构造函数的返回类型
|
|
103
|
+
*/
|
|
104
|
+
export type ReplaceConstructorReturn<C extends new (...args: any) => any, NewReturn> = new (...args: ConstructorParameters<C>) => NewReturn;
|
|
105
|
+
//# sourceMappingURL=mixin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mixin.d.ts","sourceRoot":"","sources":["../../src/extend/mixin.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,wBAAgB,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;AACzD;;;GAGG;AACH,wBAAgB,KAAK,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAC7B,MAAM,EAAE,CAAC,EACT,OAAO,EAAE,EAAE,EACX,OAAO,EAAE,EAAE,GACV,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC;AACf;;;GAGG;AACH,wBAAgB,KAAK,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EACjC,MAAM,EAAE,CAAC,EACT,OAAO,EAAE,EAAE,EACX,OAAO,EAAE,EAAE,EACX,OAAO,EAAE,EAAE,GACV,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AACpB;;;GAGG;AACH,wBAAgB,KAAK,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EACrC,MAAM,EAAE,CAAC,EACT,OAAO,EAAE,EAAE,EACX,OAAO,EAAE,EAAE,EACX,OAAO,EAAE,EAAE,EAEX,OAAO,EAAE,EAAE,GACV,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AACzB;;;;;;;;;;;GAWG;AACH,wBAAgB,KAAK,CAAC,MAAM,EAAE,GAAG,EAAE,GAAG,OAAO,EAAE,GAAG,EAAE,GAAG,GAAG,CAAC;AAU3D;;;;;;;;;GASG;AACH,wBAAgB,WAAW,CAAC,CAAC,EAAE,CAAC,EAC9B,MAAM,EAAE,CAAC,EACT,KAAK,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GACzB,CAAC,GAAG,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAErB;AAED;;;;;;;GAOG;AACH,wBAAgB,iBAAiB,CAAC,CAAC,iBAEvB,CAAC,qDAKZ;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,WAAW,CAAC,CAAC,EAAE,CAAC,EAC9B,MAAM,EAAE,CAAC,EACT,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GACrB,CAAC,GAAG,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAGrB;AAED;;;;;;;;GAQG;AACH,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,sDAK7C;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,WAAW,CAAC,CAAC,EAAE,CAAC,EAC9B,MAAM,EAAE,CAAC,EACT,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GACrB,CAAC,GAAG,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAGzB;AAED;;;;;;;GAOG;AACH,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,0DAO7C;AAKD;;GAEG;AACH,MAAM,MAAM,4BAA4B,CAAC,CAAC,SAAS,KAAK,GAAG,IAAI,EAAC,GAAG,KAAG,GAAG,EAAC,QAAQ,SAAS,GAAG,EAAE,IAAI,KAAK,GAAG,IAAI,EAAC,QAAQ,KAAG,YAAY,CAAC,CAAC,CAAC,CAAC;AAE5I;;GAEG;AACH,MAAM,MAAM,wBAAwB,CAAC,CAAC,SAAS,KAAK,GAAG,IAAI,EAAC,GAAG,KAAG,GAAG,EAAC,SAAS,IAAI,KAAK,GAAG,IAAI,EAAC,qBAAqB,CAAC,CAAC,CAAC,KAAG,SAAS,CAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,254 +1,32 @@
|
|
|
1
|
-
import { AnyFunction, Optional } from 'type-tls';
|
|
2
|
-
|
|
3
1
|
/**
|
|
4
|
-
*
|
|
5
|
-
*/
|
|
6
|
-
export declare type HostInst<H> = H extends new (...args: any) => any ? InstanceType<H> : H;
|
|
7
|
-
/**
|
|
8
|
-
* 插件的接口
|
|
9
|
-
*
|
|
10
|
-
* @typeParam HOST - 插件宿主的类类型
|
|
11
|
-
* @typeParam Options - 插件的选项类型
|
|
12
|
-
*/
|
|
13
|
-
export interface IPlugin<HOST, Options = any> {
|
|
14
|
-
/**
|
|
15
|
-
* 当插件被注册时调用
|
|
16
|
-
* @param Host - 宿主的类型
|
|
17
|
-
* @param options - 注册插件时的选项
|
|
18
|
-
*/
|
|
19
|
-
used(Host: HOST, options?: Options): any;
|
|
20
|
-
/**
|
|
21
|
-
* 当宿主实例被创建时调用
|
|
22
|
-
* @param host - 新建的宿主实例
|
|
23
|
-
* @param options - 注册插件时的选项
|
|
24
|
-
*/
|
|
25
|
-
created?(host: HostInst<HOST>, options?: Options): any;
|
|
26
|
-
}
|
|
27
|
-
export declare type PluginOptions = any;
|
|
28
|
-
/**
|
|
29
|
-
* 插件的 used 方法的返回值类型
|
|
30
|
-
*/
|
|
31
|
-
export declare type PluginUseReturnType<P extends IPlugin<any>> = ReturnType<P["used"]>;
|
|
32
|
-
/**
|
|
33
|
-
* 插件的 created 方法的返回值类型
|
|
34
|
-
*/
|
|
35
|
-
export declare type PluginCreatedReturnType<P extends IPlugin<any>> = P["created"] extends AnyFunction ? ReturnType<P["created"]> : void;
|
|
36
|
-
/**
|
|
37
|
-
* 插件管理者
|
|
2
|
+
* 插件系统
|
|
38
3
|
*
|
|
39
4
|
* @remarks
|
|
40
|
-
*
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
created(hostInst: HostInst<HOST>): void;
|
|
69
|
-
/**
|
|
70
|
-
* 插件宿主实例的注册插件的方法
|
|
71
|
-
*
|
|
72
|
-
* @remarks
|
|
73
|
-
* 会调用每个插件的 {@link IPlugin.created | IPlugin.created()} 方法
|
|
74
|
-
* @param hostInst - 插件宿主的新实例
|
|
75
|
-
*/
|
|
76
|
-
instUse<Options extends PluginOptions, Plugin extends IPlugin<HOST, Options>>(hostInst: HostInst<HOST>, plugin: Plugin, options?: Options): PluginCreatedReturnType<Plugin> | undefined;
|
|
77
|
-
}
|
|
78
|
-
/**
|
|
79
|
-
* 插件宿主的接口
|
|
80
|
-
*/
|
|
81
|
-
export interface IPluginHost<HOST> {
|
|
82
|
-
/**
|
|
83
|
-
* PluginHost 的插件管理器
|
|
84
|
-
*/
|
|
85
|
-
get pluginManager(): PluginManager<HOST>;
|
|
86
|
-
/**
|
|
87
|
-
* 实例的注册插件的方法
|
|
88
|
-
* @param plugin
|
|
89
|
-
* @param options
|
|
90
|
-
* @returns
|
|
91
|
-
*/
|
|
92
|
-
use<Options extends PluginOptions, Plugin extends IPlugin<HOST, Options>>(plugin: Plugin, options?: Options): PluginCreatedReturnType<Plugin> | undefined;
|
|
93
|
-
}
|
|
94
|
-
/**
|
|
95
|
-
* 插件宿主构造函数的接口
|
|
96
|
-
*/
|
|
97
|
-
export interface IPluginHostConstructor<HOST> {
|
|
98
|
-
/**
|
|
99
|
-
* PluginHost 的插件管理器
|
|
100
|
-
*/
|
|
101
|
-
get pluginManager(): PluginManager<HOST>;
|
|
102
|
-
/**
|
|
103
|
-
* {@inheritDoc PluginManager.use}
|
|
104
|
-
*/
|
|
105
|
-
use<Plugin extends IPlugin<HOST, Options>, Options>(plugin: Plugin, options: Options): PluginUseReturnType<Plugin> | undefined;
|
|
106
|
-
}
|
|
107
|
-
/**
|
|
108
|
-
* 插件的宿主
|
|
109
|
-
*
|
|
110
|
-
* @remarks
|
|
111
|
-
* 插件宿主 就是 拥有插件机制的宿主
|
|
112
|
-
*/
|
|
113
|
-
export declare class PluginHost {
|
|
114
|
-
/**
|
|
115
|
-
* 插件管理器
|
|
116
|
-
*/
|
|
117
|
-
static get pluginManager(): PluginManager<any>;
|
|
118
|
-
static _pluginManager: PluginManager<any>;
|
|
119
|
-
/**
|
|
120
|
-
* 插件管理器 {@link PluginHost.pluginManager}
|
|
121
|
-
*/
|
|
122
|
-
get pluginManager(): PluginManager<any>;
|
|
123
|
-
/**
|
|
124
|
-
* {@inheritDoc PluginManager.use}
|
|
125
|
-
*/
|
|
126
|
-
static use<Plugin extends IPlugin<HOST, Options>, Options extends PluginOptions, HOST = typeof PluginHost>(plugin: Plugin, options: Options): ReturnType<Plugin["used"]> | undefined;
|
|
127
|
-
constructor();
|
|
128
|
-
/**
|
|
129
|
-
* 实例的注册插件的方法
|
|
130
|
-
* @param plugin
|
|
131
|
-
* @param options
|
|
132
|
-
* @returns
|
|
133
|
-
*/
|
|
134
|
-
use<Options extends PluginOptions, Plugin extends IPlugin<typeof PluginHost, Options>>(plugin: Plugin, options?: Options): PluginCreatedReturnType<Plugin> | undefined;
|
|
135
|
-
}
|
|
136
|
-
/**
|
|
137
|
-
* 创建插件的缩主类
|
|
138
|
-
*
|
|
139
|
-
* @remarks
|
|
140
|
-
* 比 直接使用 PluginHost 提供了完善的类型推导
|
|
141
|
-
* @returns
|
|
142
|
-
*/
|
|
143
|
-
export declare function createPluginHost<HOST>(): {
|
|
144
|
-
new (): {
|
|
145
|
-
/**
|
|
146
|
-
* 插件管理器 {@link CEarth.pluginManager}
|
|
147
|
-
*/
|
|
148
|
-
readonly pluginManager: PluginManager<HOST>;
|
|
149
|
-
/**
|
|
150
|
-
* 实例的注册插件的方法
|
|
151
|
-
* @param plugin
|
|
152
|
-
* @param options
|
|
153
|
-
* @returns
|
|
154
|
-
*/
|
|
155
|
-
use<Options extends unknown, Plugin_1 extends IPlugin<HOST, Options>>(plugin: Plugin_1, options?: Options | undefined): PluginCreatedReturnType<Plugin_1> | undefined;
|
|
156
|
-
};
|
|
157
|
-
/**
|
|
158
|
-
* PluginHost 的插件管理器
|
|
159
|
-
*/
|
|
160
|
-
readonly pluginManager: PluginManager<HOST>;
|
|
161
|
-
_pluginManager: PluginManager<HOST>;
|
|
162
|
-
/**
|
|
163
|
-
* {@inheritDoc PluginManager.use}
|
|
164
|
-
*/
|
|
165
|
-
use<Options_1>(plugin: IPlugin<HOST, Options_1>, options: Options_1): any;
|
|
166
|
-
};
|
|
167
|
-
/**
|
|
168
|
-
* 插件缩主类的装饰器
|
|
169
|
-
* @param target
|
|
170
|
-
* @returns
|
|
171
|
-
*/
|
|
172
|
-
export declare function pluginHost<HOST extends new (...args: any) => any>(target: HOST): HOST;
|
|
173
|
-
/**
|
|
174
|
-
* 选项插件宿主接口
|
|
175
|
-
*/
|
|
176
|
-
export interface IOptionsPluginHost<Options, HOST> extends IPluginHost<HOST> {
|
|
177
|
-
readonly defaultOptions: Options;
|
|
178
|
-
}
|
|
179
|
-
/**
|
|
180
|
-
* 选项插件宿主的构建函数接口
|
|
181
|
-
*/
|
|
182
|
-
export interface IOptionsPluginHostConstructor<Options, HOST> extends IPluginHostConstructor<HOST> {
|
|
183
|
-
get defaultOptions(): Options;
|
|
184
|
-
}
|
|
185
|
-
export declare class OptionsPluginHost<Options = any> extends PluginHost {
|
|
186
|
-
/**
|
|
187
|
-
* 全局级别的默认选项
|
|
188
|
-
*/
|
|
189
|
-
static readonly defaultOptions: any;
|
|
190
|
-
/**
|
|
191
|
-
* 实例级的默认选项
|
|
192
|
-
*/
|
|
193
|
-
get defaultOptions(): Options;
|
|
194
|
-
protected _defaultOptions: Options;
|
|
195
|
-
}
|
|
196
|
-
/**
|
|
197
|
-
* 创建带有选项机制的插件宿主类
|
|
198
|
-
* @remakers
|
|
199
|
-
* 比 直接使用 OptionsPluginHost 提供了完善的类型推导
|
|
200
|
-
*
|
|
201
|
-
* @returns
|
|
202
|
-
*/
|
|
203
|
-
export declare function createOptionsPluginHost<HOST, Options>(): {
|
|
204
|
-
new (): {
|
|
205
|
-
/**
|
|
206
|
-
* 实例级的默认选项
|
|
207
|
-
*/
|
|
208
|
-
readonly defaultOptions: Options;
|
|
209
|
-
_defaultOptions: Options;
|
|
210
|
-
readonly pluginManager: PluginManager<HOST>;
|
|
211
|
-
use<Options_1 extends unknown, Plugin_1 extends IPlugin<HOST, Options_1>>(plugin: Plugin_1, options?: Options_1 | undefined): PluginCreatedReturnType<Plugin_1> | undefined;
|
|
212
|
-
};
|
|
213
|
-
/**
|
|
214
|
-
* 全局级别的默认选项
|
|
215
|
-
*/
|
|
216
|
-
readonly defaultOptions: Options;
|
|
217
|
-
readonly pluginManager: PluginManager<HOST>;
|
|
218
|
-
_pluginManager: PluginManager<HOST>;
|
|
219
|
-
use<Options_2>(plugin: IPlugin<HOST, Options_2>, options: Options_2): any;
|
|
220
|
-
};
|
|
221
|
-
/**
|
|
222
|
-
* 默认选项宿主接口
|
|
223
|
-
*/
|
|
224
|
-
export interface IDefaultOptionsHost<Options> {
|
|
225
|
-
readonly defaultOptions: Options;
|
|
226
|
-
}
|
|
227
|
-
/**
|
|
228
|
-
* 默认选项宿主的构建函数接口
|
|
229
|
-
*/
|
|
230
|
-
export interface IIDefaultOptionsHostConstructor<Options> {
|
|
231
|
-
get defaultOptions(): Options;
|
|
232
|
-
}
|
|
233
|
-
/**
|
|
234
|
-
* 创建增加带有选项机制的装饰器
|
|
235
|
-
*
|
|
236
|
-
* @remarks
|
|
237
|
-
* 类装饰器的工厂函数
|
|
238
|
-
*
|
|
239
|
-
* @param options - 选项内容
|
|
240
|
-
* @returns
|
|
241
|
-
*/
|
|
242
|
-
export declare function addDefaultOptions<Options>(options: Options, name?: Optional<string>): <Clas extends new (...args: any) => any>(target: Clas) => void;
|
|
243
|
-
/**
|
|
244
|
-
* 创建增加带有选项机制的装饰器
|
|
245
|
-
*
|
|
246
|
-
* @remarks
|
|
247
|
-
* 静态属性装饰器
|
|
248
|
-
*
|
|
249
|
-
* @param options - 选项内容
|
|
250
|
-
* @returns
|
|
251
|
-
*/
|
|
252
|
-
export declare function addInstOptions<Clas extends new (...args: any) => any>(target: Clas, propertyKey: string, descriptor: PropertyDescriptor): PropertyDescriptor;
|
|
253
|
-
|
|
254
|
-
export {};
|
|
5
|
+
* 主要负责 SDK 的插件机制的实现
|
|
6
|
+
* 插件系统应该具备以下功能:
|
|
7
|
+
* - 注册插件
|
|
8
|
+
* - 可扩展类的静态级功能
|
|
9
|
+
* - 可扩展类的实例级功能
|
|
10
|
+
* - 可自定义暴露的功能
|
|
11
|
+
* - 可拥有私有自身的API
|
|
12
|
+
*
|
|
13
|
+
* 额外的也提供了其它的功能
|
|
14
|
+
* - 全局选项
|
|
15
|
+
* - 实例选项
|
|
16
|
+
*
|
|
17
|
+
* @packageDocumentation
|
|
18
|
+
*/
|
|
19
|
+
export * from "./extend/mixin";
|
|
20
|
+
export * from "./extend/extend";
|
|
21
|
+
export * from "./plugin-manager/PluginManager";
|
|
22
|
+
export * from "./plugin-manager/PluginManagerWithInit";
|
|
23
|
+
export * from "./options-manager/defaultOptions";
|
|
24
|
+
export * from "./options-manager/ModeOptions";
|
|
25
|
+
export * from "./options-manager/TierOptions";
|
|
26
|
+
export * from "./options-manager/TierModeOptions";
|
|
27
|
+
export * from "./options-manager/tools";
|
|
28
|
+
export * from "./plugin-host/PluginHost";
|
|
29
|
+
export * from "./plugin-host/TierOptionsPluginHost";
|
|
30
|
+
export * from "./plugin-host/TierModeOptionsPluginHost";
|
|
31
|
+
export * from "./properties";
|
|
32
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAGH,cAAc,gBAAgB,CAAA;AAC9B,cAAc,iBAAiB,CAAA;AAG/B,cAAc,gCAAgC,CAAA;AAC9C,cAAc,wCAAwC,CAAA;AAGtD,cAAc,kCAAkC,CAAA;AAChD,cAAc,+BAA+B,CAAA;AAC7C,cAAc,+BAA+B,CAAA;AAC7C,cAAc,mCAAmC,CAAA;AACjD,cAAc,yBAAyB,CAAA;AAGvC,cAAc,0BAA0B,CAAA;AACxC,cAAc,qCAAqC,CAAA;AACnD,cAAc,yCAAyC,CAAA;AAGvD,cAAc,cAAc,CAAA"}
|