From 03ebe085ddcc9a24ae54308c613165ee355518a1 Mon Sep 17 00:00:00 2001 From: Phodal Huang Date: Tue, 2 Jun 2020 21:02:56 +0800 Subject: [PATCH] fix: fix decl issue --- .../TypeScriptFullIdentListener.kt | 59 +++++++++---------- 1 file changed, 29 insertions(+), 30 deletions(-) diff --git a/chapi-ast-typescript/src/main/kotlin/chapi/ast/typescriptast/TypeScriptFullIdentListener.kt b/chapi-ast-typescript/src/main/kotlin/chapi/ast/typescriptast/TypeScriptFullIdentListener.kt index 6ea1aade..f88c858e 100644 --- a/chapi-ast-typescript/src/main/kotlin/chapi/ast/typescriptast/TypeScriptFullIdentListener.kt +++ b/chapi-ast-typescript/src/main/kotlin/chapi/ast/typescriptast/TypeScriptFullIdentListener.kt @@ -66,24 +66,8 @@ class TypeScriptFullIdentListener(private var node: TSIdentify) : TypeScriptAstL this.buildConstructorMethod(childCtx as TypeScriptParser.ConstructorDeclarationContext) currentNode.Functions += codeFunction } - "PropertyMemberDeclarationContext" -> { - this.buildPropertyMember(childCtx as TypeScriptParser.PropertyMemberDeclarationContext) - } - else -> { - println("handleClassBodyElements -> childElementType : $childElementType") - } - } - } - } - - private fun buildPropertyMember(originCtx: TypeScriptParser.PropertyMemberDeclarationContext) { - val childType = originCtx::class.java.simpleName - - when (childType) { - "PropertyDeclarationExpressionContext" -> { - val ctx = originCtx as TypeScriptParser.PropertyDeclarationExpressionContext - val isField = ctx.propertyName() != null - if (isField) { + "PropertyDeclarationExpressionContext" -> { + val ctx = childCtx as TypeScriptParser.PropertyDeclarationExpressionContext val codeField = CodeField( TypeValue = ctx.propertyName().text ) @@ -98,20 +82,35 @@ class TypeScriptFullIdentListener(private var node: TSIdentify) : TypeScriptAstL currentNode.Fields += codeField } - } - "MethodDeclarationExpressionContext" -> { - val ctx = originCtx as TypeScriptParser.MethodDeclarationExpressionContext - val codeFunction = CodeFunction( - Name = ctx.propertyName().text, - Position = buildPosition(ctx) - ) - val callSignCtx = ctx.callSignature() - - if (callSignCtx.typeAnnotation() != null) { - codeFunction.ReturnType = buildTypeAnnotation(callSignCtx.typeAnnotation())!! + "MethodDeclarationExpressionContext" -> { + val ctx = childCtx as TypeScriptParser.MethodDeclarationExpressionContext + val codeFunction = CodeFunction( + Name = ctx.propertyName().text, + Position = buildPosition(ctx) + ) + val callSignCtx = ctx.callSignature() + + if (callSignCtx.typeAnnotation() != null) { + codeFunction.ReturnType = buildTypeAnnotation(callSignCtx.typeAnnotation())!! + } + + currentNode.Functions += codeFunction } + else -> { + println("handleClassBodyElements -> childElementType : $childElementType") + } + } + } + } + + private fun buildPropertyMember(originCtx: TypeScriptParser.PropertyMemberDeclarationContext) { + val childType = originCtx::class.java.simpleName.toString() - currentNode.Functions += codeFunction + print(childType) + when (childType) { + + else -> { + println("handleClassBody -> buildPropertyMember") } } }