aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPatrick Lehmann <Patrick.Lehmann@plc2.de>2021-08-13 23:12:20 +0200
committerumarcor <unai.martinezcorral@ehu.eus>2021-08-23 16:35:35 +0200
commit6bd13c9f82e2b06bebdea8fc82a83604d5d500d1 (patch)
tree3949bd340a6ebd2f49ae70c626415dd50508efd8
parent05b01cb126a3a18b2e067ea240a271f6de134311 (diff)
downloadghdl-6bd13c9f82e2b06bebdea8fc82a83604d5d500d1.tar.gz
ghdl-6bd13c9f82e2b06bebdea8fc82a83604d5d500d1.tar.bz2
ghdl-6bd13c9f82e2b06bebdea8fc82a83604d5d500d1.zip
Fixed missed adjustments to range in expressions.
-rw-r--r--pyGHDL/dom/Expression.py15
-rw-r--r--pyGHDL/dom/_Translate.py4
2 files changed, 9 insertions, 10 deletions
diff --git a/pyGHDL/dom/Expression.py b/pyGHDL/dom/Expression.py
index e8488b590..3769b9fb6 100644
--- a/pyGHDL/dom/Expression.py
+++ b/pyGHDL/dom/Expression.py
@@ -92,7 +92,7 @@ from pyVHDLModel.SyntaxModel import (
from pyGHDL.libghdl import utils
from pyGHDL.libghdl._types import Iir
from pyGHDL.libghdl.vhdl import nodes
-from pyGHDL.dom import DOMMixin, DOMException
+from pyGHDL.dom import DOMMixin, DOMException, Position
from pyGHDL.dom._Utils import GetIirKindOfNode
from pyGHDL.dom.Symbol import SimpleSubtypeSymbol
from pyGHDL.dom.Aggregates import (
@@ -570,25 +570,24 @@ class Aggregate(VHDLModel_Aggregate, DOMMixin):
index = GetExpressionFromNode(nodes.Get_Choice_Expression(item))
choices.append(IndexedAggregateElement(item, index, value))
elif kind == nodes.Iir_Kind.Choice_By_Range:
- r = GetRangeFromNode(nodes.Get_Choice_Range(item))
-
- rangeKind = GetIirKindOfNode(discreteRange)
+ choiceRange = nodes.Get_Choice_Range(item)
+ rangeKind = GetIirKindOfNode(choiceRange)
if rangeKind == nodes.Iir_Kind.Range_Expression:
- rng = GetRangeFromNode(discreteRange)
+ rng = GetRangeFromNode(choiceRange)
elif rangeKind in (
nodes.Iir_Kind.Attribute_Name,
nodes.Iir_Kind.Parenthesis_Name,
):
- rng = GetNameFromNode(discreteRange)
+ rng = GetNameFromNode(choiceRange)
else:
- pos = Position.parse(generateNode)
+ pos = Position.parse(item)
raise DOMException(
"Unknown discete range kind '{kind}' in for...generate statement at line {line}.".format(
kind=rangeKind.name, line=pos.Line
)
)
- choices.append(RangedAggregateElement(item, r, value))
+ choices.append(RangedAggregateElement(item, rng, value))
elif kind == nodes.Iir_Kind.Choice_By_Name:
name = GetNameFromNode(nodes.Get_Choice_Name(item))
symbol = Symbol(item, name)
diff --git a/pyGHDL/dom/_Translate.py b/pyGHDL/dom/_Translate.py
index a4be6a792..f5f2eda3e 100644
--- a/pyGHDL/dom/_Translate.py
+++ b/pyGHDL/dom/_Translate.py
@@ -872,8 +872,8 @@ def GetSequentialStatementsFromChainedNodes(
pos = Position.parse(statement)
kind = GetIirKindOfNode(statement)
-# if kind == nodes.Iir_Kind.Sensitized_Process_Statement:
-# yield ProcessStatement.parse(statement, label, True)
+ # if kind == nodes.Iir_Kind.Sensitized_Process_Statement:
+ # yield ProcessStatement.parse(statement, label, True)
if kind == nodes.Iir_Kind.If_Statement:
print(
"[NOT IMPLEMENTED] If statement (label: '{label}') at line {line}".format(