Coverage for pyVHDLModel/Regions.py: 51%

93 statements  

« prev     ^ index     » next       coverage.py v7.6.9, created at 2024-12-20 22:13 +0000

1# ==================================================================================================================== # 

2# __ ___ _ ____ _ __ __ _ _ # 

3# _ __ _ \ \ / / | | | _ \| | | \/ | ___ __| | ___| | # 

4# | '_ \| | | \ \ / /| |_| | | | | | | |\/| |/ _ \ / _` |/ _ \ | # 

5# | |_) | |_| |\ V / | _ | |_| | |___| | | | (_) | (_| | __/ | # 

6# | .__/ \__, | \_/ |_| |_|____/|_____|_| |_|\___/ \__,_|\___|_| # 

7# |_| |___/ # 

8# ==================================================================================================================== # 

9# Authors: # 

10# Patrick Lehmann # 

11# # 

12# License: # 

13# ==================================================================================================================== # 

14# Copyright 2017-2024 Patrick Lehmann - Boetzingen, Germany # 

15# Copyright 2016-2017 Patrick Lehmann - Dresden, Germany # 

16# # 

17# Licensed under the Apache License, Version 2.0 (the "License"); # 

18# you may not use this file except in compliance with the License. # 

19# You may obtain a copy of the License at # 

20# # 

21# http://www.apache.org/licenses/LICENSE-2.0 # 

22# # 

23# Unless required by applicable law or agreed to in writing, software # 

24# distributed under the License is distributed on an "AS IS" BASIS, # 

25# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # 

26# See the License for the specific language governing permissions and # 

27# limitations under the License. # 

28# # 

29# SPDX-License-Identifier: Apache-2.0 # 

30# ==================================================================================================================== # 

31# 

32""" 

33This module contains parts of an abstract document language model for VHDL. 

34 

35tbd. 

36""" 

37from typing import List, Dict, Iterable, Optional as Nullable 

38 

39from pyTooling.Decorators import export, readonly 

40from pyTooling.MetaClasses import ExtendedType 

41 

42from pyVHDLModel.Object import Constant, SharedVariable, File, Variable, Signal 

43from pyVHDLModel.Subprogram import Subprogram, Function, Procedure 

44from pyVHDLModel.Type import Subtype, FullType 

45 

46 

47@export 

48class ConcurrentDeclarationRegionMixin(metaclass=ExtendedType, mixin=True): 

49 # FIXME: define list prefix type e.g. via Union 

50 _declaredItems: List #: List of all declared items in this concurrent declaration region. 

51 

52 # _attributes: Dict[str, Attribute] 

53 # _aliases: Dict[str, Alias] 

54 _types: Dict[str, FullType] #: Dictionary of all types declared in this concurrent declaration region. 

55 _subtypes: Dict[str, Subtype] #: Dictionary of all subtypes declared in this concurrent declaration region. 

56 # _objects: Dict[str, Union[Constant, Variable, Signal]] 

57 _constants: Dict[str, Constant] #: Dictionary of all constants declared in this concurrent declaration region. 

58 _signals: Dict[str, Signal] #: Dictionary of all signals declared in this concurrent declaration region. 

59 _sharedVariables: Dict[str, SharedVariable] #: Dictionary of all shared variables declared in this concurrent declaration region. 

60 _files: Dict[str, File] #: Dictionary of all files declared in this concurrent declaration region. 

61 # _subprograms: Dict[str, Dict[str, Subprogram]] #: Dictionary of all subprograms declared in this concurrent declaration region. 

62 _functions: Dict[str, Dict[str, Function]] #: Dictionary of all functions declared in this concurrent declaration region. 

63 _procedures: Dict[str, Dict[str, Procedure]] #: Dictionary of all procedures declared in this concurrent declaration region. 

64 

65 def __init__(self, declaredItems: Nullable[Iterable] = None) -> None: 

66 # TODO: extract to mixin 

67 self._declaredItems = [] # TODO: convert to dict 

68 if declaredItems is not None: 68 ↛ 69line 68 didn't jump to line 69 because the condition on line 68 was never true

69 for item in declaredItems: 

70 self._declaredItems.append(item) 

71 item._parent = self 

72 

73 self._types = {} 

74 self._subtypes = {} 

75 # self._objects = {} 

76 self._constants = {} 

77 self._signals = {} 

78 self._sharedVariables = {} 

79 self._files = {} 

80 # self._subprograms = {} 

81 self._functions = {} 

82 self._procedures = {} 

83 

84 @readonly 

85 def DeclaredItems(self) -> List: 

86 return self._declaredItems 

87 

88 @readonly 

89 def Types(self) -> Dict[str, FullType]: 

90 return self._types 

91 

92 @readonly 

93 def Subtypes(self) -> Dict[str, Subtype]: 

94 return self._subtypes 

95 

96 # @readonly 

97 # def Objects(self) -> Dict[str, Union[Constant, SharedVariable, Signal, File]]: 

98 # return self._objects 

99 

100 @readonly 

101 def Constants(self) -> Dict[str, Constant]: 

102 return self._constants 

103 

104 @readonly 

105 def Signals(self) -> Dict[str, Signal]: 

106 return self._signals 

107 

108 @readonly 

109 def SharedVariables(self) -> Dict[str, SharedVariable]: 

110 return self._sharedVariables 

111 

112 @readonly 

113 def Files(self) -> Dict[str, File]: 

114 return self._files 

115 

116 # @readonly 

117 # def Subprograms(self) -> Dict[str, Subprogram]: 

118 # return self._subprograms 

119 

120 @readonly 

121 def Functions(self) -> Dict[str, Dict[str, Function]]: 

122 return self._functions 

123 

124 @readonly 

125 def Procedures(self) -> Dict[str, Dict[str, Procedure]]: 

126 return self._procedures 

127 

128 def IndexDeclaredItems(self) -> None: 

129 """ 

130 Index declared items listed in the concurrent declaration region. 

131 

132 .. rubric:: Algorithm 

133 

134 1. Iterate all declared items: 

135 

136 * Every declared item is added to :attr:`_namespace`. 

137 * If the declared item is a :class:`~pyVHDLModel.Type.FullType`, then add an entry to :attr:`_types`. 

138 * If the declared item is a :class:`~pyVHDLModel.Type.SubType`, then add an entry to :attr:`_subtypes`. 

139 * If the declared item is a :class:`~pyVHDLModel.Subprogram.Function`, then add an entry to :attr:`_functions`. 

140 * If the declared item is a :class:`~pyVHDLModel.Subprogram.Procedure`, then add an entry to :attr:`_procedures`. 

141 * If the declared item is a :class:`~pyVHDLModel.Object.Constant`, then add an entry to :attr:`_constants`. 

142 * If the declared item is a :class:`~pyVHDLModel.Object.Signal`, then add an entry to :attr:`_signals`. 

143 * If the declared item is a :class:`~pyVHDLModel.Object.Variable`, TODO. 

144 * If the declared item is a :class:`~pyVHDLModel.Object.SharedVariable`, then add an entry to :attr:`_sharedVariables`. 

145 * If the declared item is a :class:`~pyVHDLModel.Object.File`, then add an entry to :attr:`_files`. 

146 * If the declared item is neither of these types, call :meth:`_IndexOtherDeclaredItem`. |br| 

147 Derived classes may override this virtual function. 

148 

149 .. seealso:: 

150 

151 :meth:`pyVHDLModel.Design.IndexPackages` 

152 Iterate all packages in the design and index declared items. 

153 :meth:`pyVHDLModel.Library.IndexPackages` 

154 Iterate all packages in the library and index declared items. 

155 :meth:`pyVHDLModel.Library._IndexOtherDeclaredItem` 

156 Iterate all packages in the library and index declared items. 

157 """ 

158 for item in self._declaredItems: 

159 if isinstance(item, FullType): 

160 self._types[item._normalizedIdentifier] = item 

161 self._namespace._elements[item._normalizedIdentifier] = item 

162 elif isinstance(item, Subtype): 162 ↛ 165line 162 didn't jump to line 165 because the condition on line 162 was always true

163 self._subtypes[item._normalizedIdentifier] = item 

164 self._namespace._elements[item._normalizedIdentifier] = item 

165 elif isinstance(item, Function): 

166 self._functions[item._normalizedIdentifier] = item 

167 self._namespace._elements[item._normalizedIdentifier] = item 

168 elif isinstance(item, Procedure): 

169 self._procedures[item._normalizedIdentifier] = item 

170 self._namespace._elements[item._normalizedIdentifier] = item 

171 elif isinstance(item, Constant): 

172 for normalizedIdentifier in item._normalizedIdentifiers: 

173 self._constants[normalizedIdentifier] = item 

174 self._namespace._elements[normalizedIdentifier] = item 

175 # self._objects[normalizedIdentifier] = item 

176 elif isinstance(item, Signal): 

177 for normalizedIdentifier in item._normalizedIdentifiers: 

178 self._signals[normalizedIdentifier] = item 

179 self._namespace._elements[normalizedIdentifier] = item 

180 elif isinstance(item, Variable): 

181 print(f"IndexDeclaredItems - {item._identifiers}") 

182 elif isinstance(item, SharedVariable): 

183 for normalizedIdentifier in item._normalizedIdentifiers: 

184 self._sharedVariables[normalizedIdentifier] = item 

185 self._namespace._elements[normalizedIdentifier] = item 

186 elif isinstance(item, File): 

187 for normalizedIdentifier in item._normalizedIdentifiers: 

188 self._files[normalizedIdentifier] = item 

189 self._namespace._elements[normalizedIdentifier] = item 

190 else: 

191 self._IndexOtherDeclaredItem(item) 

192 

193 def _IndexOtherDeclaredItem(self, item) -> None: 

194 print(f"_IndexOtherDeclaredItem - {item}\n ({' -> '.join(t.__name__ for t in type(item).mro())})")