diff options
author | umarcor <unai.martinezcorral@ehu.eus> | 2020-08-27 09:59:59 +0200 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2020-09-16 07:57:25 +0200 |
commit | 63fd2ca7ce387c914668f8393962751a55ac4138 (patch) | |
tree | d1c3314e812ddb1c6b744f2708d5797db0e2103e /testsuite/python | |
parent | bec6b6245851c955fc7e16835af81a4417133e05 (diff) | |
download | ghdl-63fd2ca7ce387c914668f8393962751a55ac4138.tar.gz ghdl-63fd2ca7ce387c914668f8393962751a55ac4138.tar.bz2 ghdl-63fd2ca7ce387c914668f8393962751a55ac4138.zip |
py: add 'show_ports.py' to testsuite/python/units01
Diffstat (limited to 'testsuite/python')
-rw-r--r-- | testsuite/python/units01/demo.vhdl | 5 | ||||
-rw-r--r-- | testsuite/python/units01/show_ports.py | 108 | ||||
-rwxr-xr-x | testsuite/python/units01/show_units.py | 16 | ||||
-rwxr-xr-x | testsuite/python/units01/testsuite.sh | 4 |
4 files changed, 125 insertions, 8 deletions
diff --git a/testsuite/python/units01/demo.vhdl b/testsuite/python/units01/demo.vhdl index 4e40f7e94..ed98c936a 100644 --- a/testsuite/python/units01/demo.vhdl +++ b/testsuite/python/units01/demo.vhdl @@ -1,4 +1,9 @@ entity e1 is +port ( + CLK: in std_logic; + RST: in std_logic; + Q: out std_logic_vector(7 downto 0) +); end e1; architecture behav of e1 is diff --git a/testsuite/python/units01/show_ports.py b/testsuite/python/units01/show_ports.py new file mode 100644 index 000000000..0076e4779 --- /dev/null +++ b/testsuite/python/units01/show_ports.py @@ -0,0 +1,108 @@ +#!/usr/bin/env python +from sys import argv +from pathlib import Path + +import libghdl +from libghdl.thin import name_table +from libghdl.thin import files_map +from libghdl.thin.vhdl import nodes +from libghdl.thin.vhdl import sem_lib +from libghdl.thin.vhdl import pyutils + + +def get_identifier_ptr(n): + """Return the python string from node :param n: identifier""" + return name_table.Get_Name_Ptr(nodes.Get_Identifier(n)).decode("utf-8") + + +def get_port_mode(port) -> str: + """Return the Mode of a port, as a string""" + mode = nodes.Get_Mode(port) + return ( + "in" + if mode == nodes.Iir_Mode.In_Mode + else "out" + if mode == nodes.Iir_Mode.Out_Mode + else "inout" + if mode == nodes.Iir_Mode.Inout_Mode + else "buffer" + if mode == nodes.Iir_Mode.Buffer_Mode + else "linkage" + if mode == nodes.Iir_Mode.Linkage_Mode + else "unknown" + ) + + +def get_port_type(port) -> str: + "Return the Type of a port, as a string" + subtype = nodes.Get_Subtype_Indication(port) + skind = nodes.Get_Kind(subtype) + + if skind == nodes.Iir_Kind.Simple_Name: + return get_identifier_ptr(subtype) + + if skind == nodes.Iir_Kind.Array_Subtype_Definition: + mark = get_identifier_ptr(nodes.Get_Subtype_Type_Mark(subtype)) + + for rng in pyutils.flist_iter(nodes.Get_Index_Constraint_List(subtype)): + if nodes.Get_Kind(rng) == nodes.Iir_Kind.Range_Expression: + return "%s(%d %s %d)" % ( + mark, + nodes.Get_Value(nodes.Get_Left_Limit_Expr(rng)), + "downto" if nodes.Get_Direction(rng) else "to", + nodes.Get_Value(nodes.Get_Right_Limit_Expr(rng)), + ) + return "UNSUPPORTED array_subtype_definition" + + return "UNSUPPORTED" + + +def list_units(filename): + # Load the file + file_id = name_table.Get_Identifier(filename.encode("utf_8")) + sfe = files_map.Read_Source_File(name_table.Null_Identifier, file_id) + if sfe == files_map.No_Source_File_Entry: + print("cannot open file '%s'" % filename) + return + + # Parse + file = sem_lib.Load_File(sfe) + + # Display all design units + unit = nodes.Get_First_Design_Unit(file) + while unit != nodes.Null_Iir: + lib_unit = nodes.Get_Library_Unit(unit) + if nodes.Get_Kind(lib_unit) == nodes.Iir_Kind.Entity_Declaration: + print(" - entity %s" % get_identifier_ptr(lib_unit)) + for port in pyutils.chain_iter(nodes.Get_Port_Chain(lib_unit)): + print( + " * %s %s %s" + % ( + get_identifier_ptr(port), + get_port_mode(port), + get_port_type(port), + ) + ) + elif nodes.Get_Kind(lib_unit) == nodes.Iir_Kind.Architecture_Body: + print( + " - architecture %s of %s" + % ( + get_identifier_ptr(lib_unit), + get_identifier_ptr(nodes.Get_Entity_Name(lib_unit)), + ) + ) + else: + print("unknown unit!") + unit = nodes.Get_Chain(unit) + + +if __name__ == "__main__": + # Initialization: set options and then load libaries + libghdl.set_option(b"--std=08") + libghdl.analyze_init() + + # Recursively find and parse all the files with extension *.vhdl + if len(argv) > 1: + for file in Path(argv[1]).glob("**/*.vhdl"): + print("ยท %s" % file) + list_units(str(file)) diff --git a/testsuite/python/units01/show_units.py b/testsuite/python/units01/show_units.py index aad377723..56ab8adee 100755 --- a/testsuite/python/units01/show_units.py +++ b/testsuite/python/units01/show_units.py @@ -1,9 +1,9 @@ #!/usr/bin/env python import libghdl -import libghdl.thin.name_table as name_table -import libghdl.thin.files_map as files_map -import libghdl.thin.vhdl.nodes as nodes -import libghdl.thin.vhdl.sem_lib as sem_lib +from libghdl.thin import name_table +from libghdl.thin import files_map +from libghdl.thin.vhdl import nodes +from libghdl.thin.vhdl import sem_lib def init(): @@ -22,10 +22,10 @@ def list_units(filename): file_id = name_table.Get_Identifier(filename.encode("utf_8")) sfe = files_map.Read_Source_File(name_table.Null_Identifier, file_id) if sfe == files_map.No_Source_File_Entry: - print("cannot open file '{}'".format(filename)) + print("cannot open file '%s'" % filename) return - # Parse and analyze + # Parse file = sem_lib.Load_File(sfe) # Display all design units @@ -33,9 +33,9 @@ def list_units(filename): while unit != nodes.Null_Iir: lib_unit = nodes.Get_Library_Unit(unit) if nodes.Get_Kind(lib_unit) == nodes.Iir_Kind.Entity_Declaration: - print("entity {}".format(get_identifier_ptr(lib_unit))) + print("entity %s" % get_identifier_ptr(lib_unit)) elif nodes.Get_Kind(lib_unit) == nodes.Iir_Kind.Architecture_Body: - print("architecture {}".format(get_identifier_ptr(lib_unit))) + print("architecture %s" % get_identifier_ptr(lib_unit)) else: print("unknown unit!") unit = nodes.Get_Chain(unit) diff --git a/testsuite/python/units01/testsuite.sh b/testsuite/python/units01/testsuite.sh index 43ba6cd0f..f45d12ac3 100755 --- a/testsuite/python/units01/testsuite.sh +++ b/testsuite/python/units01/testsuite.sh @@ -4,4 +4,8 @@ $PYTHON show_units.py +echo "" + +$PYTHON show_ports.py ./ + echo "Test successful" |