ToolSetup.OpenSource.GHDL

ToolSetup/OpenSource/GHDL.py
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"")