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
|
from typing import cast
from pyTooling.Decorators import export
from pyTooling.Configuration.YAML import Dictionary
from pyTooling.CLIAbstraction import Executable
from .. import Tool, ToolInstance
from ..Interface import HDLSimulator
from pyEDAA.CLITool.GHDL import GHDL as CLI_GHDL
@export
class GHDLInstance(ToolInstance, HDLSimulator):
_platform: str
_runtime: str
_backend: str
_ghdl: CLI_GHDL
def __init__(self, config: Dictionary, parent: 'GHDL'):
super().__init__(config, parent)
self._ghdl = None
self._platform = config["Platform"]
self._runtime = config["Runtime"]
self._backend = config["Backend"]
@property
def Platform(self) -> str:
"""Platform GHDL runs on: ``win32``, ``win64``, ``lin64``."""
return self._platform
@property
def Runtime(self) -> str:
"""Runtime used to run GHDL: ``mingw32``, ``mingw64``, ``ucrt64``, ``gnatgpl32``, ``lin64``."""
return self._runtime
@property
def Backend(self) -> str:
"""GHDL's backend (``mcode``, ``llvm`` or ``gcc``."""
return self._backend
def _CreateGHDLCLIInstance(self) -> CLI_GHDL:
if self._ghdl is None:
self._ghdl = CLI_GHDL(binaryDirectoryPath=self.BinaryDirectory)
return self._ghdl
def GetGHDL(self) -> CLI_GHDL:
return self._CreateGHDLCLIInstance()
# def GetLibraryCreator(self) -> Executable:
# raise NotImplementedError(f"")
#
# def GetLibraryMapper(self) -> Executable:
# raise NotImplementedError(f"")
#
# def GetLibraryDeleter(self) -> Executable:
# raise NotImplementedError(f"")
def GetVHDLAnalyzer(self) -> Executable:
return self._CreateGHDLCLIInstance().GetGHDLAsAnalyzer()
def GetEloborator(self) -> Executable:
return self._CreateGHDLCLIInstance().GetGHDLAsElaborator()
def GetSimulator(self) -> Executable:
return self._CreateGHDLCLIInstance().GetGHDLAsSimulator()
@export
class GHDL(Tool, HDLSimulator):
_vendorKey = "OpenSource" #: Key of the parent node (vendor) in the configuration structure.
_key = "GHDL" #: Key used in the configuration structure.
_instanceClass = GHDLInstance
@property
def Default(self) -> GHDLInstance:
return cast(GHDLInstance, super().Default)
# def GetLibraryCreator(self) -> Executable:
# raise NotImplementedError(f"")
#
# def GetLibraryMapper(self) -> Executable:
# raise NotImplementedError(f"")
#
# def GetLibraryDeleter(self) -> Executable:
# raise NotImplementedError(f"")
def GetVHDLAnalyzer(self) -> Executable:
raise NotImplementedError(f"")
def GetEloborator(self) -> Executable:
raise NotImplementedError(f"")
def GetSimulator(self) -> Executable:
raise NotImplementedError(f"")
|