Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Phodal
Coca
提交
f578fcc7
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,体验更适合开发者的 AI 搜索 >>
未验证
提交
f578fcc7
编写于
1月 09, 2020
作者:
P
Phodal Huang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat: [ts] add implement support
上级
a45f6f17
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
34 addition
and
9 deletion
+34
-9
trial/pkg/application/ts/ts_ident_app.go
trial/pkg/application/ts/ts_ident_app.go
+3
-3
trial/pkg/application/ts/ts_ident_app_test.go
trial/pkg/application/ts/ts_ident_app_test.go
+1
-0
trial/pkg/ast/typescript_ident_listener.go
trial/pkg/ast/typescript_ident_listener.go
+30
-6
未找到文件。
trial/pkg/application/ts/ts_ident_app.go
浏览文件 @
f578fcc7
...
...
@@ -14,7 +14,7 @@ func processStream(is antlr.CharStream) *parser.TypeScriptParser {
return
parser
}
func
Process
J
sString
(
code
string
)
*
parser
.
TypeScriptParser
{
func
Process
T
sString
(
code
string
)
*
parser
.
TypeScriptParser
{
is
:=
antlr
.
NewInputStream
(
code
)
return
processStream
(
is
)
}
...
...
@@ -23,8 +23,8 @@ type TypeScriptApiApp struct {
}
func
(
j
*
TypeScriptApiApp
)
Analysis
(
code
string
)
domain
.
JClassNode
{
jsParser
:=
ProcessJ
sString
(
code
)
context
:=
js
Parser
.
Program
()
scriptParser
:=
ProcessT
sString
(
code
)
context
:=
script
Parser
.
Program
()
listener
:=
ast
.
NewTypeScriptIdentListener
()
antlr
.
NewParseTreeWalker
()
.
Walk
(
listener
,
context
)
...
...
trial/pkg/application/ts/ts_ident_app_test.go
浏览文件 @
f578fcc7
...
...
@@ -38,4 +38,5 @@ class Person implements IPerson {
`
)
g
.
Expect
(
results
.
Class
)
.
To
(
Equal
(
"Person"
))
g
.
Expect
(
results
.
Implements
[
0
])
.
To
(
Equal
(
"IPerson"
))
}
\ No newline at end of file
trial/pkg/ast/typescript_ident_listener.go
浏览文件 @
f578fcc7
...
...
@@ -6,14 +6,15 @@ import (
"reflect"
)
var
currentNode
domain
.
JClassNode
var
currentNode
*
domain
.
JClassNode
var
classNodeQueue
[]
domain
.
JClassNode
type
TypeScriptIdentListener
struct
{
parser
.
BaseTypeScriptParserListener
}
func
NewTypeScriptIdentListener
()
*
TypeScriptIdentListener
{
currentNode
=
*
domain
.
NewClassNode
()
currentNode
=
domain
.
NewClassNode
()
return
&
TypeScriptIdentListener
{}
}
...
...
@@ -22,7 +23,33 @@ func (s *TypeScriptIdentListener) EnterProgram(ctx *parser.ProgramContext) {
}
func
(
s
*
TypeScriptIdentListener
)
EnterClassDeclaration
(
ctx
*
parser
.
ClassDeclarationContext
)
{
currentNode
=
domain
.
NewClassNode
()
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
)
}
}
classNodeQueue
=
append
(
classNodeQueue
,
*
currentNode
)
}
func
(
s
*
TypeScriptIdentListener
)
ExitClassDeclaration
(
ctx
*
parser
.
ClassDeclarationContext
)
{
if
len
(
classNodeQueue
)
>=
1
{
if
len
(
classNodeQueue
)
==
1
{
currentNode
=
&
classNodeQueue
[
0
]
}
else
{
classNodeQueue
=
classNodeQueue
[
0
:
len
(
classNodeQueue
)
-
1
]
currentNode
=
&
classNodeQueue
[
len
(
classNodeQueue
)
-
1
]
}
}
else
{
currentNode
=
domain
.
NewClassNode
()
}
}
func
(
s
*
TypeScriptIdentListener
)
EnterArgumentsExpression
(
ctx
*
parser
.
ArgumentsExpressionContext
)
{
...
...
@@ -45,8 +72,5 @@ func (s *TypeScriptIdentListener) EnterMemberDotExpression(ctx *parser.MemberDot
}
func
(
s
*
TypeScriptIdentListener
)
GetNodeInfo
()
domain
.
JClassNode
{
return
currentNode
return
*
currentNode
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录