aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPatrick Lehmann <Patrick.Lehmann@plc2.de>2021-08-17 10:16:59 +0200
committerumarcor <unai.martinezcorral@ehu.eus>2021-08-23 16:35:36 +0200
commitc34b020a8c1b6aa5083a637e3e9062c7a71b309a (patch)
treefdfcb1d344e55983f01091be66c6571b9fc782fa
parentad58c297680fe0256eacd12249d2131b00ff9b66 (diff)
downloadghdl-c34b020a8c1b6aa5083a637e3e9062c7a71b309a.tar.gz
ghdl-c34b020a8c1b6aa5083a637e3e9062c7a71b309a.tar.bz2
ghdl-c34b020a8c1b6aa5083a637e3e9062c7a71b309a.zip
Some updates.
-rw-r--r--pyGHDL/dom/Sequential.py68
-rw-r--r--pyGHDL/dom/_Translate.py20
-rw-r--r--pyGHDL/dom/formatting/prettyprint.py4
-rw-r--r--testsuite/pyunit/Current.vhdl4
4 files changed, 75 insertions, 21 deletions
diff --git a/pyGHDL/dom/Sequential.py b/pyGHDL/dom/Sequential.py
index 7fe94fad5..cb6fa5a8f 100644
--- a/pyGHDL/dom/Sequential.py
+++ b/pyGHDL/dom/Sequential.py
@@ -49,6 +49,8 @@ from pyVHDLModel.SyntaxModel import (
ForLoopStatement as VHDLModel_ForLoopStatement,
SequentialSimpleSignalAssignment as VHDLModel_SequentialSimpleSignalAssignment,
SequentialProcedureCall as VHDLModel_SequentialProcedureCall,
+ SequentialAssertStatement as VHDLModel_SequentialAssertStatement,
+ SequentialReportStatement as VHDLModel_SequentialReportStatement,
Name,
SequentialStatement,
Expression,
@@ -211,7 +213,7 @@ class Case(VHDLModel_Case, DOMMixin):
if block is nodes.Null_Iir:
return cls(caseNode, choices)
- statementChain = nodes.Get_Sequential_Statement_Chain(block)
+ statementChain = nodes.Get_Sequential_Statement_Chain(caseNode)
statements = GetSequentialStatementsFromChainedNodes(
statementChain, "case", label
)
@@ -271,7 +273,7 @@ class CaseStatement(VHDLModel_CaseStatement, DOMMixin):
cases = []
choices = None
alternative = nodes.Get_Case_Statement_Alternative_Chain(caseNode)
- caseNode = alternative
+ cNode = alternative
while alternative != nodes.Null_Iir:
choiceKind = GetIirKindOfNode(alternative)
@@ -319,7 +321,7 @@ class CaseStatement(VHDLModel_CaseStatement, DOMMixin):
choices = None
cases.append(OthersCase.parse(alternative, label))
alternative = nodes.Get_Chain(alternative)
- caseNode = alternative
+ cNode = alternative
continue
else:
pos = Position.parse(alternative)
@@ -330,9 +332,9 @@ class CaseStatement(VHDLModel_CaseStatement, DOMMixin):
)
if choices is not None:
- cases.append(Case.parse(alternative, choices, label))
+ cases.append(Case.parse(cNode, choices, label))
- caseNode = alternative
+ cNode = alternative
choices = [
choice,
]
@@ -340,7 +342,7 @@ class CaseStatement(VHDLModel_CaseStatement, DOMMixin):
alternative = nodes.Get_Chain(alternative)
if choices is not None:
- cases.append(Case.parse(alternative, choices, label))
+ cases.append(Case.parse(cNode, choices, label))
return cls(caseNode, label, expression, cases)
@@ -431,11 +433,11 @@ class SequentialProcedureCall(VHDLModel_SequentialProcedureCall, DOMMixin):
def __init__(
self,
callNode: Iir,
- label: str,
procedureName: Name,
parameterMappings: Iterable,
+ label: str = None,
):
- super().__init__(label, procedureName, parameterMappings)
+ super().__init__(procedureName, parameterMappings, label)
DOMMixin.__init__(self, callNode)
@classmethod
@@ -451,4 +453,52 @@ class SequentialProcedureCall(VHDLModel_SequentialProcedureCall, DOMMixin):
# TODO: parameter mappings
parameterMappings = []
- return cls(callNode, label, procedureName, parameterMappings)
+ return cls(callNode, procedureName, parameterMappings, label)
+
+
+@export
+class SequentialAssertStatement(VHDLModel_SequentialAssertStatement, DOMMixin):
+ def __init__(
+ self,
+ assertNode: Iir,
+ condition: Expression,
+ message: Expression,
+ severity: Expression = None,
+ label: str = None,
+ ):
+ super().__init__(label, condition, message, severity, label)
+ DOMMixin.__init__(self, assertNode)
+
+ @classmethod
+ def parse(cls, assertNode: Iir, label: str) -> "SequentialAssertStatement":
+ from pyGHDL.dom._Utils import GetIirKindOfNode
+ from pyGHDL.dom._Translate import GetExpressionFromNode
+
+ condition = ""
+ message = ""
+ severity = ""
+
+ return cls(assertNode, condition, message, severity, label)
+
+
+@export
+class SequentialReportStatement(VHDLModel_SequentialReportStatement, DOMMixin):
+ def __init__(
+ self,
+ reportNode: Iir,
+ message: Expression,
+ severity: Expression = None,
+ label: str = None,
+ ):
+ super().__init__(label, message, severity, label)
+ DOMMixin.__init__(self, reportNode)
+
+ @classmethod
+ def parse(cls, reportNode: Iir, label: str) -> "SequentialReportStatement":
+ from pyGHDL.dom._Utils import GetIirKindOfNode
+ from pyGHDL.dom._Translate import GetExpressionFromNode
+
+ message = ""
+ severity = ""
+
+ return cls(reportNode, message, severity, label)
diff --git a/pyGHDL/dom/_Translate.py b/pyGHDL/dom/_Translate.py
index 00194cb09..06afa960b 100644
--- a/pyGHDL/dom/_Translate.py
+++ b/pyGHDL/dom/_Translate.py
@@ -34,7 +34,13 @@ from typing import List, Generator
from pydecor import export
-from pyGHDL.dom.Sequential import IfStatement, ForLoopStatement, CaseStatement
+from pyGHDL.dom.Sequential import (
+ IfStatement,
+ ForLoopStatement,
+ CaseStatement,
+ SequentialReportStatement,
+ SequentialAssertStatement,
+)
from pyVHDLModel.SyntaxModel import (
Constraint,
Direction,
@@ -907,17 +913,9 @@ def GetSequentialStatementsFromChainedNodes(
)
)
elif kind == nodes.Iir_Kind.Report_Statement:
- print(
- "[NOT IMPLEMENTED] Report statement (label: '{label}') at line {line}".format(
- label=label, line=pos.Line
- )
- )
+ yield SequentialReportStatement.parse(statement, label)
elif kind == nodes.Iir_Kind.Assertion_Statement:
- print(
- "[NOT IMPLEMENTED] Report statement (label: '{label}') at line {line}".format(
- label=label, line=pos.Line
- )
- )
+ yield SequentialAssertStatement.parse(statement, label)
else:
raise DOMException(
"Unknown statement of kind '{kind}' in {entity} '{name}' at {file}:{line}:{column}.".format(
diff --git a/pyGHDL/dom/formatting/prettyprint.py b/pyGHDL/dom/formatting/prettyprint.py
index 9917394da..6314d37f2 100644
--- a/pyGHDL/dom/formatting/prettyprint.py
+++ b/pyGHDL/dom/formatting/prettyprint.py
@@ -566,7 +566,9 @@ class PrettyPrint:
)
elif isinstance(item, UseClause):
buffer.append(
- "{prefix}- use {names}".format(prefix=prefix, names=", ".join([str(n) for n in item.Names]))
+ "{prefix}- use {names}".format(
+ prefix=prefix, names=", ".join([str(n) for n in item.Names])
+ )
)
elif isinstance(item, Package):
buffer.append(
diff --git a/testsuite/pyunit/Current.vhdl b/testsuite/pyunit/Current.vhdl
index 240c11d5f..a397e8700 100644
--- a/testsuite/pyunit/Current.vhdl
+++ b/testsuite/pyunit/Current.vhdl
@@ -111,9 +111,13 @@ begin
case foo_bar is
when 0 =>
+ report "hello" & " " & "world";
when 1 | 2 =>
+ report "vhdl" severity note;
when 3 to 4 =>
+ assert true nor false report "nothing";
when 5 to 6 | 8 to 9 =>
+ assert true nor false report "nothing" severity warning or error;
when others =>
end case;
end process;