Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Phodal
Coca
提交
02675166
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,发现更多精彩内容 >>
未验证
提交
02675166
编写于
1月 10, 2020
作者:
P
Phodal Huang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat: [ts] add extend support
上级
cf41c74d
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
19 addition
and
4 deletion
+19
-4
trial/pkg/application/ts/ts_ident_app_test.go
trial/pkg/application/ts/ts_ident_app_test.go
+14
-0
trial/pkg/ast/typescript_ident_listener.go
trial/pkg/ast/typescript_ident_listener.go
+5
-4
未找到文件。
trial/pkg/application/ts/ts_ident_app_test.go
浏览文件 @
02675166
...
...
@@ -57,6 +57,20 @@ func Test_TypeScriptMultipleClass(t *testing.T) {
g
.
Expect
(
results
[
3
]
.
Class
)
.
To
(
Equal
(
"default"
))
}
func
Test_TypeScriptAbstractClass
(
t
*
testing
.
T
)
{
g
:=
NewGomegaWithT
(
t
)
app
:=
new
(
TypeScriptApiApp
)
code
,
_
:=
ioutil
.
ReadFile
(
"../../../../_fixtures/ts/AbstractClass.ts"
)
results
:=
app
.
Analysis
(
string
(
code
))
g
.
Expect
(
len
(
results
))
.
To
(
Equal
(
3
))
g
.
Expect
(
results
[
0
]
.
Type
)
.
To
(
Equal
(
"Class"
))
g
.
Expect
(
results
[
1
]
.
Class
)
.
To
(
Equal
(
"Employee"
))
g
.
Expect
(
results
[
1
]
.
Extend
)
.
To
(
Equal
(
"Person"
))
}
func
Test_ShouldGetClassFromModule
(
t
*
testing
.
T
)
{
g
:=
NewGomegaWithT
(
t
)
...
...
trial/pkg/ast/typescript_ident_listener.go
浏览文件 @
02675166
...
...
@@ -71,10 +71,6 @@ func BuildInterfaceTypeBody(ctx *parser.TypeMemberListContext, classNode *domain
methodSignature
:=
memberChild
.
(
*
parser
.
MethodSignatureContext
)
method
:=
domain
.
NewJMethod
()
method
.
Name
=
methodSignature
.
PropertyName
()
.
GetText
()
if
typeMemberCtx
.
Type_
()
!=
nil
{
// todo need a case ?
method
.
Type
=
typeMemberCtx
.
Type_
()
.
GetText
()
}
FillMethodFromCallSignature
(
methodSignature
.
CallSignature
()
.
(
*
parser
.
CallSignatureContext
),
&
method
)
classNode
.
Methods
=
append
(
classNode
.
Methods
,
method
)
...
...
@@ -124,6 +120,11 @@ func (s *TypeScriptIdentListener) EnterClassDeclaration(ctx *parser.ClassDeclara
currentNode
.
Implements
=
append
(
currentNode
.
Implements
,
BuildImplements
(
typeList
)
...
)
}
if
heritageContext
.
ClassExtendsClause
()
!=
nil
{
referenceContext
:=
heritageContext
.
ClassExtendsClause
()
.
(
*
parser
.
ClassExtendsClauseContext
)
.
TypeReference
()
.
(
*
parser
.
TypeReferenceContext
)
currentNode
.
Extend
=
referenceContext
.
TypeName
()
.
GetText
()
}
for
_
,
classElement
:=
range
ctx
.
ClassTail
()
.
(
*
parser
.
ClassTailContext
)
.
AllClassElement
()
{
elementChild
:=
classElement
.
GetChild
(
0
)
if
reflect
.
TypeOf
(
elementChild
)
.
String
()
==
"*parser.ConstructorDeclarationContext"
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录