Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Phodal
Coca
提交
fcf46593
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 搜索 >>
未验证
提交
fcf46593
编写于
1月 10, 2020
作者:
P
Phodal Huang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: fix default not class issues
上级
03d4f5a6
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
12 addition
and
2 deletion
+12
-2
trial/pkg/application/ts/ts_ident_app_test.go
trial/pkg/application/ts/ts_ident_app_test.go
+1
-2
trial/pkg/ast/typescript_ident_listener.go
trial/pkg/ast/typescript_ident_listener.go
+11
-0
未找到文件。
trial/pkg/application/ts/ts_ident_app_test.go
浏览文件 @
fcf46593
package
js_ident
import
(
"fmt"
.
"github.com/onsi/gomega"
"io/ioutil"
"testing"
...
...
@@ -53,4 +52,4 @@ func Test_TypeScriptMultipleClass(t *testing.T) {
g
.
Expect
(
len
(
results
))
.
To
(
Equal
(
2
))
g
.
Expect
(
results
[
0
]
.
Implements
[
0
])
.
To
(
Equal
(
"IPerson"
))
}
\ No newline at end of file
}
trial/pkg/ast/typescript_ident_listener.go
浏览文件 @
fcf46593
...
...
@@ -10,11 +10,14 @@ var currentNode *domain.JClassNode
var
classNodeQueue
[]
domain
.
JClassNode
var
classNodes
[]
domain
.
JClassNode
var
default_class
=
"default"
type
TypeScriptIdentListener
struct
{
parser
.
BaseTypeScriptParserListener
}
func
NewTypeScriptIdentListener
()
*
TypeScriptIdentListener
{
classNodes
=
nil
currentNode
=
domain
.
NewClassNode
()
return
&
TypeScriptIdentListener
{}
}
...
...
@@ -55,6 +58,10 @@ func (s *TypeScriptIdentListener) ExitClassDeclaration(ctx *parser.ClassDeclarat
}
func
(
s
*
TypeScriptIdentListener
)
EnterArgumentsExpression
(
ctx
*
parser
.
ArgumentsExpressionContext
)
{
if
currentNode
.
Class
==
""
{
currentNode
.
Class
=
default_class
}
if
reflect
.
TypeOf
(
ctx
.
GetChild
(
0
))
.
String
()
==
"*parser.MemberDotExpressionContext"
{
memberDotExprCtx
:=
ctx
.
GetChild
(
0
)
.
(
*
parser
.
MemberDotExpressionContext
)
buildMemberDotExpr
(
memberDotExprCtx
)
...
...
@@ -74,5 +81,9 @@ func (s *TypeScriptIdentListener) EnterMemberDotExpression(ctx *parser.MemberDot
}
func
(
s
*
TypeScriptIdentListener
)
GetNodeInfo
()
[]
domain
.
JClassNode
{
if
currentNode
.
Class
==
default_class
{
classNodes
=
append
(
classNodes
,
*
currentNode
)
currentNode
=
domain
.
NewClassNode
()
}
return
classNodes
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录