Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Phodal
Coca
提交
517ad103
C
Coca
项目概览
Phodal
/
Coca
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
Coca
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
517ad103
编写于
1月 10, 2020
作者:
P
Phodal Huang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat: [ts] add interface support
上级
76b9628a
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
35 addition
and
9 deletion
+35
-9
trial/pkg/application/ts/ts_ident_app_test.go
trial/pkg/application/ts/ts_ident_app_test.go
+5
-4
trial/pkg/ast/typescript_ident_listener.go
trial/pkg/ast/typescript_ident_listener.go
+30
-5
未找到文件。
trial/pkg/application/ts/ts_ident_app_test.go
浏览文件 @
517ad103
...
...
@@ -38,8 +38,9 @@ class Person implements IPerson {
}
`
)
g
.
Expect
(
results
[
0
]
.
Class
)
.
To
(
Equal
(
"Person"
))
g
.
Expect
(
results
[
0
]
.
Implements
[
0
])
.
To
(
Equal
(
"IPerson"
))
g
.
Expect
(
results
[
0
]
.
Class
)
.
To
(
Equal
(
"IPerson"
))
g
.
Expect
(
results
[
1
]
.
Class
)
.
To
(
Equal
(
"Person"
))
g
.
Expect
(
results
[
1
]
.
Implements
[
0
])
.
To
(
Equal
(
"IPerson"
))
}
func
Test_TypeScriptMultipleClass
(
t
*
testing
.
T
)
{
...
...
@@ -50,6 +51,6 @@ func Test_TypeScriptMultipleClass(t *testing.T) {
results
:=
app
.
Analysis
(
string
(
code
))
g
.
Expect
(
len
(
results
))
.
To
(
Equal
(
2
))
g
.
Expect
(
results
[
0
]
.
Implements
[
0
])
.
To
(
Equal
(
"IPerson"
))
g
.
Expect
(
len
(
results
))
.
To
(
Equal
(
3
))
g
.
Expect
(
results
[
1
]
.
Implements
[
0
])
.
To
(
Equal
(
"IPerson"
))
}
trial/pkg/ast/typescript_ident_listener.go
浏览文件 @
517ad103
...
...
@@ -26,24 +26,49 @@ func (s *TypeScriptIdentListener) EnterProgram(ctx *parser.ProgramContext) {
}
func
(
s
*
TypeScriptIdentListener
)
EnterInterfaceDeclaration
(
ctx
*
parser
.
InterfaceDeclarationContext
)
{
currentNode
=
domain
.
NewClassNode
()
currentNode
.
Type
=
"Interface"
currentNode
.
Class
=
ctx
.
Identifier
()
.
GetText
()
if
ctx
.
InterfaceExtendsClause
()
!=
nil
{
extendsContext
:=
ctx
.
InterfaceExtendsClause
()
.
(
*
parser
.
InterfaceExtendsClauseContext
)
buildImplements
(
extendsContext
.
ClassOrInterfaceTypeList
())
}
}
func
(
s
*
TypeScriptIdentListener
)
ExitInterfaceDeclaration
(
ctx
*
parser
.
InterfaceDeclarationContext
)
{
exitClass
()
}
func
buildImplements
(
typeList
parser
.
IClassOrInterfaceTypeListContext
)
{
typeListContext
:=
typeList
.
(
*
parser
.
ClassOrInterfaceTypeListContext
)
for
_
,
typeType
:=
range
typeListContext
.
AllTypeReference
()
{
typeRefs
:=
typeType
.
(
*
parser
.
TypeReferenceContext
)
.
TypeName
()
.
GetText
()
currentNode
.
Implements
=
append
(
currentNode
.
Implements
,
typeRefs
)
}
}
func
(
s
*
TypeScriptIdentListener
)
EnterClassDeclaration
(
ctx
*
parser
.
ClassDeclarationContext
)
{
currentNode
=
domain
.
NewClassNode
()
currentNode
.
Type
=
"Class"
currentNode
.
Class
=
ctx
.
Identifier
()
.
GetText
()
heritageContext
:=
ctx
.
ClassHeritage
()
.
(
*
parser
.
ClassHeritageContext
)
if
heritageContext
.
ImplementsClause
()
!=
nil
{
typeList
:=
heritageContext
.
ImplementsClause
()
.
(
*
parser
.
ImplementsClauseContext
)
.
ClassOrInterfaceTypeList
()
typeListContext
:=
typeList
.
(
*
parser
.
ClassOrInterfaceTypeListContext
)
for
_
,
typeType
:=
range
typeListContext
.
AllTypeReference
()
{
typeRefs
:=
typeType
.
(
*
parser
.
TypeReferenceContext
)
.
TypeName
()
.
GetText
()
currentNode
.
Implements
=
append
(
currentNode
.
Implements
,
typeRefs
)
}
buildImplements
(
typeList
)
}
classNodeQueue
=
append
(
classNodeQueue
,
*
currentNode
)
}
func
(
s
*
TypeScriptIdentListener
)
ExitClassDeclaration
(
ctx
*
parser
.
ClassDeclarationContext
)
{
exitClass
()
}
func
exitClass
()
{
classNodes
=
append
(
classNodes
,
*
currentNode
)
if
len
(
classNodeQueue
)
>=
1
{
if
len
(
classNodeQueue
)
==
1
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录