Class: ClassMethodDeclaration
compiler.ClassMethodDeclaration
Represents a class declaration in the Kipper language, which may contain methods and fields.
Since
0.12.0
Hierarchy
ClassMemberDeclaration
<ClassMethodDeclarationSemantics
,ClassMethodDeclarationTypeSemantics
>↳
ClassMethodDeclaration
Implements
Table of contents
Constructors
Properties
- _antlrRuleCtx
- _children
- _errors
- _innerScope
- _parent
- _scopeDeclaration
- _semanticData
- _skippedSemanticAnalysis
- _skippedSemanticTypeChecking
- _skippedTargetSemanticAnalysis
- _typeSemantics
- checkForWarnings
- primarySemanticTypeChecking
- targetCodeGenerator
- targetSemanticAnalysis
- kind
- ruleName
Accessors
- antlrRuleCtx
- children
- codeGenerator
- compileConfig
- errors
- hasFailed
- innerScope
- kind
- parent
- parser
- programCtx
- ruleName
- scope
- scopeCtx
- scopeDeclaration
- semanticAnalyser
- semanticData
- skippedSemanticAnalysis
- skippedSemanticTypeChecking
- sourceCode
- target
- tokenStream
- typeSemantics
Methods
- addError
- addNewChild
- ensureScopeDeclarationAvailableIfNeeded
- ensureSemanticallyValid
- ensureTypeSemanticallyValid
- getAntlrRuleChildren
- getScopeDeclaration
- getSemanticData
- getTypeSemanticData
- handleSemanticError
- hasSideEffects
- preliminaryTypeChecking
- preliminaryTypeCheckingChildren
- primaryPreliminaryTypeChecking
- primarySemanticAnalysis
- recursivelyCheckForWarnings
- semanticAnalysis
- semanticTypeChecking
- semanticallyAnalyseChildren
- semanticallyTypeCheckChildren
- targetSemanticallyAnalyseChildren
- translateCtxAndChildren
- wrapUpSemanticAnalysis
Constructors
constructor
• new ClassMethodDeclaration(antlrRuleCtx
, parent
)
Parameters
Name | Type |
---|---|
antlrRuleCtx |
ClassMethodDeclarationContext |
parent |
CompilableNodeParent |
Overrides
ClassMemberDeclaration.constructor
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:86
Properties
_antlrRuleCtx
• Readonly
Private
_antlrRuleCtx: ClassMethodDeclarationContext
parent The private field '_antlrRuleCtx' that actually stores the variable data, which is returned inside the this.antlrRuleCtx.
Implementation of
Overrides
ClassMemberDeclaration._antlrRuleCtx
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:33
_children
• Protected
_children: CompilableNodeChild
[]
Implementation of
Inherited from
ClassMemberDeclaration._children
Defined in
kipper/core/src/compiler/ast/compilable-ast-node.ts:65
_errors
• Protected
_errors: KipperError
[]
Inherited from
ClassMemberDeclaration._errors
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:75
_innerScope
• Private
Readonly
_innerScope: FunctionScope
The private field '_innerScope' that actually stores the variable data, which is returned inside the this.innerScope.
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:72
_parent
• Protected
_parent: CompilableNodeParent
Implementation of
Inherited from
ClassMemberDeclaration._parent
Defined in
kipper/core/src/compiler/ast/compilable-ast-node.ts:55
_scopeDeclaration
• Private
_scopeDeclaration: undefined
| ScopeFunctionDeclaration
The private field '_scopeDeclaration' that actually stores the variable data, which is returned inside the this.scopeDeclaration.
Overrides
ClassMemberDeclaration._scopeDeclaration
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:40
_semanticData
• Protected
_semanticData: undefined
| ClassMethodDeclarationSemantics
Implementation of
Inherited from
ClassMemberDeclaration._semanticData
Defined in
kipper/core/src/compiler/ast/ast-node.ts:56
_skippedSemanticAnalysis
• Protected
_skippedSemanticAnalysis: boolean
Inherited from
ClassMemberDeclaration._skippedSemanticAnalysis
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:85
_skippedSemanticTypeChecking
• Protected
_skippedSemanticTypeChecking: boolean
Inherited from
ClassMemberDeclaration._skippedSemanticTypeChecking
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:96
_skippedTargetSemanticAnalysis
• Protected
_skippedTargetSemanticAnalysis: boolean
Inherited from
ClassMemberDeclaration._skippedTargetSemanticAnalysis
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:43
_typeSemantics
• Protected
_typeSemantics: undefined
| ClassMethodDeclarationTypeSemantics
Implementation of
Inherited from
ClassMemberDeclaration._typeSemantics
Defined in
kipper/core/src/compiler/ast/ast-node.ts:75
checkForWarnings
• checkForWarnings: undefined
= undefined
Semantically analyses the code inside this AST node and checks for possible warnings or problematic code.
This will log all warnings using programCtx.logger and store them in warnings.
Since
0.12.0
Overrides
ClassMemberDeclaration.checkForWarnings
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:198
primarySemanticTypeChecking
• Readonly
primarySemanticTypeChecking: undefined
Overrides
ClassMemberDeclaration.primarySemanticTypeChecking
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:190
targetCodeGenerator
• Readonly
targetCodeGenerator: TargetASTNodeCodeGenerator
<ClassMethodDeclaration
, TranslatedCodeLine
[]>
Code generator function that is specific for the target language.
Since
0.8.0
Overrides
ClassMemberDeclaration.targetCodeGenerator
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:201
targetSemanticAnalysis
• Readonly
targetSemanticAnalysis: undefined
| TargetASTNodeSemanticAnalyser
<ClassMethodDeclaration
>
Semantic analyser function that is specific for the target. This only should perform logical analysis and not interpret the code/modify the semanticData field.
If this is undefined then it means there is no target specific semantic analysis that needs to be done.
Since
0.8.0
Overrides
ClassMemberDeclaration.targetSemanticAnalysis
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:200
kind
▪ Static
Readonly
kind: 22
/**
- The static kind for this AST Node. *
Since
0.12.0
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:47
ruleName
▪ Static
Readonly
ruleName: "RULE_classMethodDeclaration"
The static rule name for this AST Node.
Since
0.12.0
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:65
Accessors
antlrRuleCtx
• get
antlrRuleCtx(): ClassMethodDeclarationContext
The antlr context containing the antlr4 metadata for this expression.
Returns
Implementation of
ScopeNode.antlrRuleCtx
Overrides
ClassMemberDeclaration.antlrRuleCtx
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:95
children
• get
children(): CompilableNodeChild
[]
The children of this AST node.
Since
0.8.0
Returns
Implementation of
ScopeNode.children
Inherited from
ClassMemberDeclaration.children
Defined in
kipper/core/src/compiler/ast/compilable-ast-node.ts:71
codeGenerator
• get
codeGenerator(): KipperTargetCodeGenerator
The code generator, which will generate the code for this specific token into the this.target target language.
Since
0.8.0
Returns
Inherited from
ClassMemberDeclaration.codeGenerator
Defined in
kipper/core/src/compiler/ast/compilable-ast-node.ts:104
compileConfig
• get
compileConfig(): EvaluatedCompileConfig
The compilation config for the program of this AST node.
Since
0.10.0
Returns
Inherited from
ClassMemberDeclaration.compileConfig
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:120
errors
• get
errors(): KipperError
[]
The errors that were caused by this node. Includes all errors from children.
Since
0.10.0
Returns
Inherited from
ClassMemberDeclaration.errors
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:81
hasFailed
• get
hasFailed(): boolean
Returns true if the this.primarySemanticAnalysis semantic analysis or this.primarySemanticTypeChecking type checking of this node or any children nodes failed.
This indicates that the node is not valid and can not be translated.
Since
0.10.0
Returns
boolean
Inherited from
ClassMemberDeclaration.hasFailed
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:132
innerScope
• get
innerScope(): FunctionScope
Gets the inner scope of this method, where also the semanticData.params arguments should be registered.
Since
0.12.0
Returns
Implementation of
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:120
kind
• get
kind(): 22
Returns the kind of this AST node. This represents the specific type of the antlrRuleCtx that this AST node wraps.
This may be compared using the rule fields, for example RULE_declaration.
Since
0.12.0
Returns
22
Implementation of
ScopeNode.kind
Overrides
ClassMemberDeclaration.kind
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:57
parent
• get
parent(): CompilableNodeParent
Returns the parent that has this node as a child.
Since
0.8.0
Returns
Implementation of
ScopeNode.parent
Inherited from
ClassMemberDeclaration.parent
Defined in
kipper/core/src/compiler/ast/compilable-ast-node.ts:61
parser
• get
parser(): KipperParser
The parser that generated the parse tree and antlr rule context.
Since
0.8.0
Returns
Inherited from
ClassMemberDeclaration.parser
Defined in
kipper/core/src/compiler/ast/compilable-ast-node.ts:79
programCtx
• get
programCtx(): KipperProgramContext
The file context instance containing the metadata for the listener and this AST node.
Since
0.8.0
Returns
Inherited from
ClassMemberDeclaration.programCtx
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:112
ruleName
• get
ruleName(): "RULE_classMethodDeclaration"
Returns the rule name of this AST Node. This represents the specific type of the antlrRuleCtx that this AST node wraps.
This may be compared using the rule fields, for example RULE_declaration.
Since
0.12.0
Returns
"RULE_classMethodDeclaration"
Implementation of
ScopeNode.ruleName
Overrides
ClassMemberDeclaration.ruleName
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:82
scope
• get
scope(): ClassScope
The scope of this AST node.
Returns
Inherited from
ClassMemberDeclaration.scope
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-member-declaration.ts:45
scopeCtx
• get
scopeCtx(): ScopeNode
<LocalScope
| ClassScope
| GlobalScope
>
The context / AST node of the scope.
Since
0.8.0
Returns
ScopeNode
<LocalScope
| ClassScope
| GlobalScope
>
Inherited from
ClassMemberDeclaration.scopeCtx
Defined in
kipper/core/src/compiler/ast/compilable-ast-node.ts:120
scopeDeclaration
• get
scopeDeclaration(): undefined
| ScopeFunctionDeclaration
The ScopeDeclaration context instance for this declaration, which is used to register the declaration in the parent scope.
Since
0.12.0
Returns
undefined
| ScopeFunctionDeclaration
Overrides
ClassMemberDeclaration.scopeDeclaration
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:103
• set
scopeDeclaration(declaration
): void
Parameters
Name | Type |
---|---|
declaration |
undefined | ScopeFunctionDeclaration |
Returns
void
Overrides
ClassMemberDeclaration.scopeDeclaration
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:107
semanticAnalyser
• get
semanticAnalyser(): KipperTargetSemanticAnalyser
The translation-specific semantic analyser, which will perform semantic analysis specific for the this.target target language.
Since
0.8.0
Returns
Inherited from
ClassMemberDeclaration.semanticAnalyser
Defined in
kipper/core/src/compiler/ast/compilable-ast-node.ts:138
semanticData
• get
semanticData(): undefined
| Semantics
Returns the semantic data of this AST node.
Since
0.8.0
Returns
undefined
| Semantics
Implementation of
ScopeNode.semanticData
Inherited from
ClassMemberDeclaration.semanticData
Defined in
kipper/core/src/compiler/ast/ast-node.ts:62
• set
semanticData(value
): void
Sets the semantic data of this AST node.
Since
0.8.0
Parameters
Name | Type | Description |
---|---|---|
value |
undefined | Semantics |
The semantic data that should be written onto this AST node. |
Returns
void
Implementation of
ScopeNode.semanticData
Inherited from
ClassMemberDeclaration.semanticData
Defined in
kipper/core/src/compiler/ast/ast-node.ts:71
skippedSemanticAnalysis
• get
skippedSemanticAnalysis(): boolean
Returns true if the this.primarySemanticAnalysis semantic analysis of this node was skipped, due to required semantic data being missing. This indicates that the node is impossible to analyse as the required semantic data from other nodes is missing.
Returns
boolean
Inherited from
ClassMemberDeclaration.skippedSemanticAnalysis
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:92
skippedSemanticTypeChecking
• get
skippedSemanticTypeChecking(): boolean
Returns true if the this.primarySemanticTypeChecking type checking of this node was skipped, due to required semantic data being missing. This indicates that the node is impossible to type check as the required semantic data from other nodes is missing.
Since
0.10.0
Returns
boolean
Inherited from
ClassMemberDeclaration.skippedSemanticTypeChecking
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:104
sourceCode
• get
sourceCode(): string
The Kipper source code that was used to generate this CompilableASTNode.
Any left-over whitespaces will be removed using trim().
Since
0.8.0
Returns
string
Implementation of
ScopeNode.sourceCode
Inherited from
ClassMemberDeclaration.sourceCode
Defined in
kipper/core/src/compiler/ast/ast-node.ts:133
target
• get
target(): KipperCompileTarget
The compilation translation for this specific token.
Since
0.8.0
Returns
Inherited from
ClassMemberDeclaration.target
Defined in
kipper/core/src/compiler/ast/compilable-ast-node.ts:95
tokenStream
• get
tokenStream(): TokenStream
Returns the token stream source for this token.
Since
0.8.0
Returns
TokenStream
Inherited from
ClassMemberDeclaration.tokenStream
Defined in
kipper/core/src/compiler/ast/compilable-ast-node.ts:87
typeSemantics
• get
typeSemantics(): undefined
| TypeSemantics
Returns the type data of this AST node.
Since
0.10.0
Returns
undefined
| TypeSemantics
Implementation of
ScopeNode.typeSemantics
Inherited from
ClassMemberDeclaration.typeSemantics
Defined in
kipper/core/src/compiler/ast/ast-node.ts:81
• set
typeSemantics(value
): void
Sets the type data of this AST node.
Since
0.10.0
Parameters
Name | Type | Description |
---|---|---|
value |
undefined | TypeSemantics |
The semantic data that should be written onto this AST node. |
Returns
void
Implementation of
ScopeNode.typeSemantics
Inherited from
ClassMemberDeclaration.typeSemantics
Defined in
kipper/core/src/compiler/ast/ast-node.ts:90
Methods
addError
▸ addError(error
): void
Adds the specified error to the list of errors caused by this node.
This is not the same as reportError, since that function automatically logs the error as well and this function does not! This is only intended to keep track if a node has failed.
Parameters
Name | Type | Description |
---|---|---|
error |
KipperError |
The error to add. |
Returns
void
Inherited from
ClassMemberDeclaration.addError
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:143
addNewChild
▸ addNewChild(newChild
): void
Adds new child ctx item to this AST node. The child item should be in the order that they appeared in the this.antlrCtx parse tree.
This will also automatically set the parent of newChild to this instance.
Since
0.8.0
Parameters
Name | Type |
---|---|
newChild |
CompilableNodeChild |
Returns
void
Implementation of
Inherited from
ClassMemberDeclaration.addNewChild
Defined in
kipper/core/src/compiler/ast/compilable-ast-node.ts:149
ensureScopeDeclarationAvailableIfNeeded
▸ ensureScopeDeclarationAvailableIfNeeded(): void
Ensures that this node has a scope declaration available. This will be primarily used by declarations in their own analysis.
This will throw an error if the scope declaration is not available.
This is primarily used by the semanticTypeChecking method, which often requires the scope declaration to be available. As such this is a helper method which ensures the control flow is correct and no invalid errors are thrown. (E.g. an internal error is thrown after a normal semantic analysis error).
Intentionally this will also likely cause an UndefinedSemanticsError in case the scopeDeclaration is missing and hasFailed is returning false. Since that's an automatic contradiction, it's better to ignore it here and let the UndefinedSemanticsError be thrown later.
Throws
If the scope declaration is not available.
Since
0.11.0
Returns
void
Inherited from
ClassMemberDeclaration.ensureScopeDeclarationAvailableIfNeeded
Defined in
kipper/core/src/compiler/ast/nodes/declarations/declaration.ts:126
ensureSemanticallyValid
▸ Protected
ensureSemanticallyValid(): void
Ensures that this node successfully passed the semantic analysis. This will be primarily used by statements and declarations, which depend on other nodes to be semantically valid.
This is done by checking if the hasFailed property is set to true and if the semanticData property is undefined. If both of these conditions are met, then the node failed in an intended way and the parent should not continue processing, as it will cause errors.
This is used to help the control flow and also to ensure that other nodes do not try to access the semantic data of a node that failed, as that would cause an UndefinedSemanticsError.
Intentionally this will also likely cause an UndefinedSemanticsError in case the semantic data is missing and hasFailed is returning false. Since that's an automatic contradiction, it's better to ignore it here and let the UndefinedSemanticsError be thrown later.
Throws
If the child failed and the semantic data is undefined. Note that this is not like UndefinedSemanticsError, as that error is thrown when the semantic data is undefined in an unintended or unexpected way. This error on the other will be handled by the compiler and influence the control flow.
Since
0.10.0
Returns
void
Inherited from
ClassMemberDeclaration.ensureSemanticallyValid
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:168
ensureTypeSemanticallyValid
▸ Protected
ensureTypeSemanticallyValid(): void
Ensures that this node successfully passed the type checking step of semantic analysis. This will be primarily used by statements and declarations, which depend on other nodes to be semantically valid.
This is done by checking if the hasFailed property is set to true and if the typeSemantics property is undefined. If both of these conditions are met, then the child failed in an intended way and the parent should not continue processing, as it will cause errors.
This is used to help the control flow and also to ensure that the parent node does not try to access the type semantic data of a child node that has failed.
Intentionally this will also likely cause an UndefinedSemanticsError in case the semantic data is missing and hasFailed is returning false. Since that's an automatic contradiction, it's better to ignore it here and let the UndefinedSemanticsError be thrown later.
Throws
If the child failed and the semantic data is undefined. Note that this is not like UndefinedSemanticsError, as that error is thrown when the semantic data is undefined in an unintended or unexpected way. This error on the other will be handled by the compiler and influence the control flow.
Since
0.10.0
Returns
void
Inherited from
ClassMemberDeclaration.ensureTypeSemanticallyValid
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:195
getAntlrRuleChildren
▸ getAntlrRuleChildren(): ParseTree
[]
Returns the children of the antlrRuleCtx and throws an error in case they are undefined.
Throws
If antlrRuleCtx.children is undefined.
Since
0.8.0
Returns
ParseTree
[]
Implementation of
ScopeNode.getAntlrRuleChildren
Inherited from
ClassMemberDeclaration.getAntlrRuleChildren
Defined in
kipper/core/src/compiler/ast/ast-node.ts:161
getScopeDeclaration
▸ getScopeDeclaration(): ScopeFunctionDeclaration
Returns the scope declaration ctx of this declaration and throws an error in case it is undefined.
Throws
UndefinedDeclarationCtx If scopeDeclaration is undefined.
Since
0.10.0
Returns
Overrides
ClassMemberDeclaration.getScopeDeclaration
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:111
getSemanticData
▸ getSemanticData(): ClassMethodDeclarationSemantics
Returns the semantic data of this AST node and throws an error in case it is undefined.
Throws
If semanticData is undefined.
Since
0.8.0
Returns
ClassMethodDeclarationSemantics
Implementation of
Inherited from
ClassMemberDeclaration.getSemanticData
Defined in
kipper/core/src/compiler/ast/ast-node.ts:174
getTypeSemanticData
▸ getTypeSemanticData(): ClassMethodDeclarationTypeSemantics
Returns the type semantic data of this AST node and throws an error in case it is undefined.
Throws
UndefinedSemanticsError If semanticData is undefined.
Since
0.10.0
Returns
ClassMethodDeclarationTypeSemantics
Implementation of
Inherited from
ClassMemberDeclaration.getTypeSemanticData
Defined in
kipper/core/src/compiler/ast/ast-node.ts:187
handleSemanticError
▸ Protected
handleSemanticError(error
): void
Handles the specified error that occurred during the semantic analysis of this node in a standardised way.
Since
0.10.0
Parameters
Name | Type | Description |
---|---|---|
error |
KipperError | Error |
The error to handle. |
Returns
void
Inherited from
ClassMemberDeclaration.handleSemanticError
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:343
hasSideEffects
▸ hasSideEffects(): boolean
Returns whether this AST node has any side effects. This means that the node will change the state of the program in some way and not only return a value.
This specifically can mean it assigns or modifies a variable, calls a function, or throws an error.
Since
0.11.0
Returns
boolean
Inherited from
ClassMemberDeclaration.hasSideEffects
Defined in
kipper/core/src/compiler/ast/compilable-ast-node.ts:160
preliminaryTypeChecking
▸ preliminaryTypeChecking(): Promise
<void
>
Performs preliminary type checking on this AST node and all this.children children nodes. This uses the this.semanticData semantic data that was evaluated during this.semanticAnalysis semantic analysis.
This preliminarily sets the this.typeSemantics type semantics of this node and allows the use of this.getTypeSemanticData in any child that may need the data, without getting any error.
This is a special step in the type checking process, where the type semantics are evaluated before the actual type checking is done. This is useful for cases where children need parent data to be already evaluated, like for example inside a class when the class type is needed for checking the "this" keyword.
We will call this "Ahead of time" type evaluation, as it is done before the actual proper type checking of the node, preceding any other type checking in the entire tree.
Since
0.12.0
Returns
Promise
<void
>
Inherited from
ClassMemberDeclaration.preliminaryTypeChecking
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:246
preliminaryTypeCheckingChildren
▸ Protected
preliminaryTypeCheckingChildren(): Promise
<void
>
Runs preliminaryTypeChecking of all children nodes.
Since
0.12.0
Returns
Promise
<void
>
Inherited from
ClassMemberDeclaration.preliminaryTypeCheckingChildren
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:367
primaryPreliminaryTypeChecking
▸ primaryPreliminaryTypeChecking(): Promise
<void
>
Preliminary registers the class declaration type to allow for internal self-referential type checking.
This is part of the "Ahead of time" type evaluation, which is done before the main type checking.
Since
0.12.0
Returns
Promise
<void
>
Overrides
ClassMemberDeclaration.primaryPreliminaryTypeChecking
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:181
primarySemanticAnalysis
▸ primarySemanticAnalysis(): Promise
<void
>
Performs the semantic analysis for this Kipper token. This will log all warnings using programCtx.logger and throw errors if encountered.
This will not run in case that this.hasFailed is true, as that indicates that the semantic analysis of the children has already failed and as such no parent node should run type checking.
Returns
Promise
<void
>
Overrides
ClassMemberDeclaration.primarySemanticAnalysis
Defined in
kipper/core/src/compiler/ast/nodes/declarations/type-declaration/class-declaration/class-member-declaration/class-method-declaration/class-method-declaration.ts:131
recursivelyCheckForWarnings
▸ recursivelyCheckForWarnings(): Promise
<void
>
Recursively checks for warnings by calling this function on all this.children children and calling checkForWarnings on this class as well.
Since
0.10.0
Returns
Promise
<void
>
Inherited from
ClassMemberDeclaration.recursivelyCheckForWarnings
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:327
semanticAnalysis
▸ semanticAnalysis(): Promise
<void
>
Semantically analyses the code inside this AST node and all this.children children nodes.
This function will recursively call itself on the this.children instances and analyse the deepest children nodes first, working up as the tokens get more complex. This way the parent tokens can access the semantics of the children and properly process itself.
This function will set the this.semanticData property and allow the use of this.getSemanticData, without getting any error.
Since
0.8.0
Returns
Promise
<void
>
Inherited from
ClassMemberDeclaration.semanticAnalysis
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:212
semanticTypeChecking
▸ semanticTypeChecking(): Promise
<void
>
Performs type checking on this AST node and all this.children children nodes. This uses the this.semanticData semantic data that was evaluated during this.semanticAnalysis semantic analysis.
Since
0.10.0
Returns
Promise
<void
>
Inherited from
ClassMemberDeclaration.semanticTypeChecking
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:269
semanticallyAnalyseChildren
▸ Protected
semanticallyAnalyseChildren(): Promise
<void
>
Runs semanticAnalysis of all children nodes.
Since
0.10.0
Returns
Promise
<void
>
Inherited from
ClassMemberDeclaration.semanticallyAnalyseChildren
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:352
semanticallyTypeCheckChildren
▸ Protected
semanticallyTypeCheckChildren(): Promise
<void
>
Runs semanticTypeChecking of all children nodes.
Since
0.10.0
Returns
Promise
<void
>
Inherited from
ClassMemberDeclaration.semanticallyTypeCheckChildren
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:382
targetSemanticallyAnalyseChildren
▸ Protected
targetSemanticallyAnalyseChildren(): Promise
<void
>
Runs semanticTypeChecking of all children nodes.
Since
0.10.0
Returns
Promise
<void
>
Inherited from
ClassMemberDeclaration.targetSemanticallyAnalyseChildren
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:397
translateCtxAndChildren
▸ translateCtxAndChildren(): Promise
<TranslatedCodeLine
[]>
Generates the typescript code for this item, and all children (if they exist).
Since
0.8.0
Returns
Inherited from
ClassMemberDeclaration.translateCtxAndChildren
Defined in
kipper/core/src/compiler/ast/nodes/declarations/declaration.ts:136
wrapUpSemanticAnalysis
▸ wrapUpSemanticAnalysis(): Promise
<void
>
Wrap-up semantic analysis, which analyses this AST node and all this.children children nodes, and checks whether they are semantically valid for the this.target target language. This uses the this.semanticData semantic data and this.typeData type data that was evaluated during the previous this.semanticAnalysis semantic analysis and this.semanticTypeChecking type checking steps.
Since
0.10.0
Returns
Promise
<void
>
Inherited from
ClassMemberDeclaration.wrapUpSemanticAnalysis
Defined in
kipper/core/src/compiler/ast/analysable-ast-node.ts:301