diff options
author | Patrick Lehmann <Patrick.Lehmann@plc2.de> | 2021-08-17 10:16:59 +0200 |
---|---|---|
committer | umarcor <unai.martinezcorral@ehu.eus> | 2021-08-23 16:35:36 +0200 |
commit | c34b020a8c1b6aa5083a637e3e9062c7a71b309a (patch) | |
tree | fdfcb1d344e55983f01091be66c6571b9fc782fa | |
parent | ad58c297680fe0256eacd12249d2131b00ff9b66 (diff) | |
download | ghdl-c34b020a8c1b6aa5083a637e3e9062c7a71b309a.tar.gz ghdl-c34b020a8c1b6aa5083a637e3e9062c7a71b309a.tar.bz2 ghdl-c34b020a8c1b6aa5083a637e3e9062c7a71b309a.zip |
Some updates.
-rw-r--r-- | pyGHDL/dom/Sequential.py | 68 | ||||
-rw-r--r-- | pyGHDL/dom/_Translate.py | 20 | ||||
-rw-r--r-- | pyGHDL/dom/formatting/prettyprint.py | 4 | ||||
-rw-r--r-- | testsuite/pyunit/Current.vhdl | 4 |
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; |