aboutsummaryrefslogtreecommitdiffstats
path: root/pyGHDL/cli/DOM.py
blob: 622a70d16b1480f74f0b5dd0b3ec25381e121df7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#!/usr/bin/env python3

from sys import argv
from sys import exit as sysexit

from pathlib import Path
from textwrap import dedent

from pydecor import export

from pyGHDL import GHDLBaseException
from pyGHDL.libghdl import LibGHDLException
from pyGHDL.dom import DOMException
from pyGHDL.dom.NonStandard import Design, Document
from pyGHDL.dom.formatting.prettyprint import PrettyPrint, PrettyPrintException

__all__ = []
__api__ = __all__


@export
class Application:
    _design: Design

    def __init__(self):
        self._design = Design()

    def addFile(self, filename: Path, library: str):
        lib = self._design.GetLibrary(library)

        document = Document(filename)
        self._design.AddDocument(document, lib)

    def prettyPrint(self):
        PP = PrettyPrint()

        buffer = []

        buffer.append("Design:")
        for line in PP.formatDesign(self._design, 1):
            buffer.append(line)

        print("\n".join(buffer))

        document: Document = self._design.Documents[0]
        print()
        print(
            "libghdl processing time: {: 5.3f} us".format(
                document.LibGHDLProcessingTime * 10 ** 6
            )
        )
        print(
            "DOM translation time:    {:5.3f} us".format(
                document.DOMTranslationTime * 10 ** 6
            )
        )


def handleException(ex):
    if isinstance(ex, PrettyPrintException):
        print("PP:", ex)
        return 0
    elif isinstance(ex, DOMException):
        print("DOM:", ex)
        ex2 = ex.__cause__
        if ex2 is not None:
            for message in ex2.InternalErrors:
                print("libghdl: {message}".format(message=message))
            return 0
        return 4
    elif isinstance(ex, LibGHDLException):
        print("LIB:", ex)
        for message in ex.InternalErrors:
            print("  {message}".format(message=message))
        return 3
    elif isinstance(ex, GHDLBaseException):
        print("GHDL:", ex)
        return 2
    else:
        print(
            "Fatal: An unhandled exception has reached to the top-most exception handler."
        )
        return 1


def main(items=argv[1:]):
    _exitcode = 0

    if len(items) < 1:
        print("Please, provide the files to be analyzed as CLI arguments.")
        print("Using <testsuite/pyunit/SimpleEntity.vhdl> for demo purposes.\n")
        items = ["testsuite/pyunit/Current.vhdl"]

    for item in items:
        try:
            app = Application()
            app.addFile(Path(item), "default_lib")
            app.prettyPrint()
        except GHDLBaseException as ex:
            _exitcode = handleException(ex)
        except Exception as ex:
            print(
                dedent(
                    """\
                    Fatal: An unhandled exception has reached to the top-most exception handler.
                    Exception: {name}
                    """.format(
                        name=ex.__class__.__name__
                    )
                )
            )
            if isinstance(ex, ValueError):
                print("  Message: {msg}".format(msg=str(ex)))
            if ex.__cause__ is not None:
                print("Cause:     {msg}".format(msg=str(ex.__cause__)))

    return _exitcode


if __name__ == "__main__":
    sysexit(main())