Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
wechaty
wechaty
提交
f6ec50f4
W
wechaty
项目概览
wechaty
/
wechaty
上一次同步 大约 3 年
通知
304
Star
10499
Fork
6
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
152
列表
看板
标记
里程碑
合并请求
1
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
W
wechaty
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
152
Issue
152
列表
看板
标记
里程碑
合并请求
1
合并请求
1
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
f6ec50f4
编写于
5月 23, 2018
作者:
Huan (李卓桓)
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
code clean
上级
81112d56
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
27 addition
and
9 deletion
+27
-9
src/contact.spec.ts
src/contact.spec.ts
+17
-4
src/contact.ts
src/contact.ts
+5
-4
src/room.ts
src/room.ts
+5
-1
未找到文件。
src/contact.spec.ts
浏览文件 @
f6ec50f4
...
...
@@ -4,16 +4,21 @@ import * as test from 'blue-tape'
import
{
cloneClass
}
from
'
clone-class
'
import
{
Contact
}
from
'
./contact
'
import
{
Contact
as
GlobalContact
}
from
'
./contact
'
// tslint:disable-next-line:variable-name
const
Contact
=
cloneClass
(
GlobalContact
)
test
(
'
Should not be able to instanciate directly
'
,
async
t
=>
{
// tslint:disable-next-line:variable-name
const
MyContact
=
cloneClass
(
Contact
)
t
.
throws
(()
=>
{
const
c
=
new
Contact
(
'
xxx
'
)
const
c
=
new
My
Contact
(
'
xxx
'
)
t
.
fail
(
c
.
name
())
},
'
should throw when `new Contact()`
'
)
t
.
throws
(()
=>
{
const
c
=
Contact
.
load
(
'
xxx
'
)
const
c
=
My
Contact
.
load
(
'
xxx
'
)
t
.
fail
(
c
.
name
())
},
'
should throw when `Contact.load()`
'
)
})
...
...
@@ -34,7 +39,7 @@ test('Should not be able to instanciate through cloneClass without puppet', asyn
})
test
(
'
S
hould be able to instanciate through cloneClass with puppet
'
,
async
t
=>
{
test
(
'
s
hould be able to instanciate through cloneClass with puppet
'
,
async
t
=>
{
// tslint:disable-next-line:variable-name
const
MyContact
=
cloneClass
(
Contact
)
MyContact
.
puppet
=
{}
as
any
...
...
@@ -50,3 +55,11 @@ test('Should be able to instanciate through cloneClass with puppet', async t =>
},
'
should not throw when `MyContact.load()`
'
)
})
test
(
'
should throw when instanciate the global class
'
,
async
t
=>
{
t
.
throws
(()
=>
{
const
c
=
GlobalContact
.
load
(
'
xxx
'
)
t
.
fail
(
'
should not run to here
'
)
t
.
fail
(
c
.
toString
())
},
'
should throw when we instanciate a global class
'
)
})
src/contact.ts
浏览文件 @
f6ec50f4
...
...
@@ -93,11 +93,9 @@ export class Contact extends PuppetAccessory implements Sayable {
id
:
string
,
):
T
[
'
prototype
'
]
{
if
(
!
this
.
pool
)
{
log
.
verbose
(
'
Contact
'
,
'
load(%s) init pool
'
,
id
)
this
.
pool
=
new
Map
<
string
,
Contact
>
()
}
if
(
this
===
Contact
)
{
throw
new
Error
(
'
must not use the global Contact. use a cloned child via cloneClass instead.
'
)
}
if
(
this
.
pool
===
Contact
.
pool
)
{
throw
new
Error
(
'
the current pool is equal to the global pool error!
'
)
}
...
...
@@ -213,7 +211,10 @@ export class Contact extends PuppetAccessory implements Sayable {
const
MyClass
=
instanceToClass
(
this
,
Contact
)
if
(
MyClass
===
Contact
)
{
throw
new
Error
(
'
Contact class can not be instanciated directly! See: https://github.com/Chatie/wechaty/issues/1217
'
)
throw
new
Error
(
'
Contact class can not be instanciated directly!
'
+
'
See: https://github.com/Chatie/wechaty/issues/1217
'
,
)
}
if
(
!
this
.
puppet
)
{
...
...
src/room.ts
浏览文件 @
f6ec50f4
...
...
@@ -75,7 +75,7 @@ export interface RoomPayload {
*/
export
class
Room
extends
PuppetAccessory
implements
Sayable
{
protected
static
readonly
pool
=
new
Map
<
string
,
Room
>
()
protected
static
pool
:
Map
<
string
,
Room
>
/**
* Create a new room.
...
...
@@ -175,6 +175,10 @@ export class Room extends PuppetAccessory implements Sayable {
throw
new
Error
(
'
no id
'
)
}
if
(
!
this
.
pool
)
{
this
.
pool
=
new
Map
<
string
,
Room
>
()
}
const
existingRoom
=
this
.
pool
.
get
(
id
)
if
(
existingRoom
)
{
return
existingRoom
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录