aboutsummaryrefslogtreecommitdiffstats
path: root/pyGHDL/libghdl/flags.py
diff options
context:
space:
mode:
authortgingold <tgingold@users.noreply.github.com>2022-12-24 16:33:33 +0100
committerGitHub <noreply@github.com>2022-12-24 16:33:33 +0100
commita1b9335c08140fc9fc5d02591f3cb2870c5ba988 (patch)
treeea1659124a516bcadb592f836c3426f93d1b09fb /pyGHDL/libghdl/flags.py
parentfd0c0bc0b8357f58d44f9b7e03367d5c2e3e906f (diff)
parent1e5aad63f64ff9b91b1a10c16f82fa29de42dbb4 (diff)
downloadghdl-a1b9335c08140fc9fc5d02591f3cb2870c5ba988.tar.gz
ghdl-a1b9335c08140fc9fc5d02591f3cb2870c5ba988.tar.bz2
ghdl-a1b9335c08140fc9fc5d02591f3cb2870c5ba988.zip
Merge pull request #2282 from Paebbels/paebbels/ams
Activate VHDL-2008 and VHDL-AMS based on selected VHDL dialect
Diffstat (limited to 'pyGHDL/libghdl/flags.py')
-rw-r--r--pyGHDL/libghdl/flags.py30
1 files changed, 29 insertions, 1 deletions
diff --git a/pyGHDL/libghdl/flags.py b/pyGHDL/libghdl/flags.py
index fadd3bb52..dc5da6d60 100644
--- a/pyGHDL/libghdl/flags.py
+++ b/pyGHDL/libghdl/flags.py
@@ -33,25 +33,53 @@
# ============================================================================
from ctypes import c_bool, sizeof
+from enum import unique, IntEnum
+
+from pyTooling.Decorators import export
from pyGHDL.libghdl import libghdl
__all__ = [
"Flag_Elocations",
"Verbose",
+ "MB_Comment",
+ "Explicit",
+ "Relaxed",
"Flag_Elaborate_With_Outdated",
"Flag_Force_Analysis",
+ "AMS_Vhdl",
"Flag_Gather_Comments",
]
assert sizeof(c_bool) == 1
+
+@export
+@unique
+class VhdlStandard(IntEnum):
+ """An enumeration representing libghdl's internal ``Vhdl_Std_Type`` enumeration type."""
+
+ Vhdl_87 = 0 #: VHDL'87
+ Vhdl_93 = 1 #: VHDL'93
+ Vhdl_00 = 2 #: VHDL'2000
+ Vhdl_02 = 3 #: VHDL'2002
+ Vhdl_08 = 4 #: VHDL'2008
+ Vhdl_19 = 5 #: VHDL'2019
+
+
Flag_Elocations = c_bool.in_dll(libghdl, "flags__flag_elocations")
-Verbose = c_bool.in_dll(libghdl, "flags__verbose")
+Verbose = c_bool.in_dll(libghdl, "flags__verbose") #: Internal boolean flag representing :option:`-v`.
+MB_Comment = c_bool.in_dll(libghdl, "flags__mb_comment") #: Internal boolean flag representing :option:`--mb-comment`.
+Explicit = c_bool.in_dll(libghdl, "flags__flag_explicit") #: Internal boolean flag representing :option:`-fexplicit`.
+Relaxed = c_bool.in_dll(
+ libghdl, "flags__flag_relaxed_rules"
+) #: Internal boolean flag representing :option:`-frelaxed`.
Flag_Elaborate_With_Outdated = c_bool.in_dll(libghdl, "flags__flag_elaborate_with_outdated")
Flag_Force_Analysis = c_bool.in_dll(libghdl, "flags__flag_force_analysis")
+AMS_Vhdl = c_bool.in_dll(libghdl, "flags__ams_vhdl") #: Internal boolean flag representing :option:`-ams`.
+
Flag_Gather_Comments = c_bool.in_dll(libghdl, "flags__flag_gather_comments")