aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--pyGHDL/dom/Concurrent.py50
1 files changed, 37 insertions, 13 deletions
diff --git a/pyGHDL/dom/Concurrent.py b/pyGHDL/dom/Concurrent.py
index d4e7cf6ff..c9a67f1e1 100644
--- a/pyGHDL/dom/Concurrent.py
+++ b/pyGHDL/dom/Concurrent.py
@@ -48,6 +48,7 @@ from pyVHDLModel.SyntaxModel import (
Name,
SequentialStatement,
IfGenerateBranch,
+ Expression,
)
from pyGHDL.libghdl import Iir
@@ -199,13 +200,40 @@ class IfGenerateBranch(VHDLModel_IfGenerateBranch):
def __init__(
self,
branchNode: Iir,
+ condition: Expression,
alternativeLabel: str = None,
declaredItems: Iterable = None,
statements: Iterable[ConcurrentStatement] = None,
):
- super().__init__(declaredItems, statements)
+ super().__init__(condition, declaredItems, statements)
DOMMixin.__init__(self, branchNode)
+ @classmethod
+ def parse(cls, generateNode: Iir) -> "IfGenerateBranch":
+ from pyGHDL.dom._Translate import (
+ GetDeclaredItemsFromChainedNodes,
+ GetStatementsFromChainedNodes,
+ GetExpressionFromNode,
+ )
+
+ condition = GetExpressionFromNode(nodes.Get_Condition(generateNode))
+ body = nodes.Get_Generate_Statement_Body(generateNode)
+
+ alternativeLabelId = nodes.Get_Alternative_Label(body)
+ alternativeLabel = ""
+
+ declarationChain = nodes.Get_Declaration_Chain(body)
+ declaredItems = GetDeclaredItemsFromChainedNodes(
+ declarationChain, "if-generate branch", alternativeLabel
+ )
+
+ statementChain = nodes.Get_Concurrent_Statement_Chain(body)
+ statements = GetStatementsFromChainedNodes(
+ statementChain, "if-generate branch", alternativeLabel
+ )
+
+ return cls(body, condition, alternativeLabel, declaredItems, statements)
+
@export
class IfGenerateStatement(VHDLModel_IfGenerateStatement, DOMMixin):
@@ -218,25 +246,21 @@ class IfGenerateStatement(VHDLModel_IfGenerateStatement, DOMMixin):
from pyGHDL.dom._Translate import (
GetDeclaredItemsFromChainedNodes,
GetStatementsFromChainedNodes,
+ GetExpressionFromNode,
)
# TODO: get branches
# TODO: get declared items
# TODO: get concurrent statements
- body = nodes.Get_Generate_Statement_Body(generateNode)
- alternativeLabelId = nodes.Get_Alternative_Label(body)
- alternativeLabel = ""
-
- declarationChain = nodes.Get_Declaration_Chain(body)
- declaredItems = GetDeclaredItemsFromChainedNodes(
- declarationChain, "if-generate", label
- )
-
- statementChain = nodes.Get_Concurrent_Statement_Chain(body)
- statements = GetStatementsFromChainedNodes(statementChain, "if-generate", label)
+ print(generateNode, GetIirKindOfNode(generateNode))
+ ifBranch = IfGenerateBranch.parse(generateNode)
- ifBranch = IfGenerateBranch(body, alternativeLabel, declaredItems, statements)
+ elseClause = generateNode
+ while (
+ elseClause := nodes.Get_Generate_Else_Clause(elseClause)
+ ) != nodes.Null_Iir:
+ print(elseClause, GetIirKindOfNode(elseClause))
return cls(generateNode, label, ifBranch)