aboutsummaryrefslogtreecommitdiffstats
path: root/pyGHDL/dom/Literal.py
diff options
context:
space:
mode:
Diffstat (limited to 'pyGHDL/dom/Literal.py')
-rw-r--r--pyGHDL/dom/Literal.py24
1 files changed, 24 insertions, 0 deletions
diff --git a/pyGHDL/dom/Literal.py b/pyGHDL/dom/Literal.py
index 78f3f279a..4fe3a843c 100644
--- a/pyGHDL/dom/Literal.py
+++ b/pyGHDL/dom/Literal.py
@@ -39,6 +39,8 @@ from pydecor import export
from pyVHDLModel.VHDLModel import (
IntegerLiteral as VHDLModel_IntegerLiteral,
FloatingPointLiteral as VHDLModel_FloatingPointLiteral,
+ PhysicalIntegerLiteral as VHDLModel_PhysicalIntegerLiteral,
+ PhysicalFloatingLiteral as VHDLModel_PhysicalFloatingLiteral,
CharacterLiteral as VHDLModel_CharacterLiteral,
StringLiteral as VHDLModel_StringLiteral,
)
@@ -63,6 +65,28 @@ class FloatingPointLiteral(VHDLModel_FloatingPointLiteral):
@export
+class PhysicalIntegerLiteral(VHDLModel_PhysicalIntegerLiteral):
+ @classmethod
+ def parse(cls, node):
+ value = nodes.Get_Value(node)
+ unit = nodes.Get_Unit_Name(node)
+ unitName = name_table.Get_Name_Ptr(unit)
+
+ return cls(value, unitName)
+
+
+@export
+class PhysicalFloatingLiteral(VHDLModel_PhysicalFloatingLiteral):
+ @classmethod
+ def parse(cls, node):
+ value = nodes.Get_Fp_Value(node)
+ unit = nodes.Get_Unit_Name(node)
+ unitName = name_table.Get_Name_Ptr(unit)
+
+ return cls(value, unitName)
+
+
+@export
class CharacterLiteral(VHDLModel_CharacterLiteral):
@classmethod
def parse(cls, node):