Source code for pyVHDLModel.Regions

# ==================================================================================================================== #
#             __     ___   _ ____  _     __  __           _      _                                                     #
#   _ __  _   \ \   / / | | |  _ \| |   |  \/  | ___   __| | ___| |                                                    #
#  | '_ \| | | \ \ / /| |_| | | | | |   | |\/| |/ _ \ / _` |/ _ \ |                                                    #
#  | |_) | |_| |\ V / |  _  | |_| | |___| |  | | (_) | (_| |  __/ |                                                    #
#  | .__/ \__, | \_/  |_| |_|____/|_____|_|  |_|\___/ \__,_|\___|_|                                                    #
#  |_|    |___/                                                                                                        #
# ==================================================================================================================== #
# Authors:                                                                                                             #
#   Patrick Lehmann                                                                                                    #
#                                                                                                                      #
# License:                                                                                                             #
# ==================================================================================================================== #
# Copyright 2017-2025 Patrick Lehmann - Boetzingen, Germany                                                            #
# Copyright 2016-2017 Patrick Lehmann - Dresden, Germany                                                               #
#                                                                                                                      #
# Licensed under the Apache License, Version 2.0 (the "License");                                                      #
# you may not use this file except in compliance with the License.                                                     #
# You may obtain a copy of the License at                                                                              #
#                                                                                                                      #
#   http://www.apache.org/licenses/LICENSE-2.0                                                                         #
#                                                                                                                      #
# Unless required by applicable law or agreed to in writing, software                                                  #
# distributed under the License is distributed on an "AS IS" BASIS,                                                    #
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.                                             #
# See the License for the specific language governing permissions and                                                  #
# limitations under the License.                                                                                       #
#                                                                                                                      #
# SPDX-License-Identifier: Apache-2.0                                                                                  #
# ==================================================================================================================== #
#
"""
This module contains parts of an abstract document language model for VHDL.

tbd.
"""
from typing                 import List, Dict, Iterable, Optional as Nullable

from pyTooling.Decorators   import export, readonly
from pyTooling.MetaClasses  import ExtendedType

from pyVHDLModel.Object     import Constant, SharedVariable, File, Variable, Signal
from pyVHDLModel.Subprogram import Subprogram, Function, Procedure
from pyVHDLModel.Type       import Subtype, FullType


[docs] @export class ConcurrentDeclarationRegionMixin(metaclass=ExtendedType, mixin=True): # FIXME: define list prefix type e.g. via Union _declaredItems: List #: List of all declared items in this concurrent declaration region. # _attributes: Dict[str, Attribute] # _aliases: Dict[str, Alias] _types: Dict[str, FullType] #: Dictionary of all types declared in this concurrent declaration region. _subtypes: Dict[str, Subtype] #: Dictionary of all subtypes declared in this concurrent declaration region. # _objects: Dict[str, Union[Constant, Variable, Signal]] _constants: Dict[str, Constant] #: Dictionary of all constants declared in this concurrent declaration region. _signals: Dict[str, Signal] #: Dictionary of all signals declared in this concurrent declaration region. _sharedVariables: Dict[str, SharedVariable] #: Dictionary of all shared variables declared in this concurrent declaration region. _files: Dict[str, File] #: Dictionary of all files declared in this concurrent declaration region. # _subprograms: Dict[str, Dict[str, Subprogram]] #: Dictionary of all subprograms declared in this concurrent declaration region. _functions: Dict[str, Dict[str, Function]] #: Dictionary of all functions declared in this concurrent declaration region. _procedures: Dict[str, Dict[str, Procedure]] #: Dictionary of all procedures declared in this concurrent declaration region.
[docs] def __init__(self, declaredItems: Nullable[Iterable] = None) -> None: # TODO: extract to mixin self._declaredItems = [] # TODO: convert to dict if declaredItems is not None: for item in declaredItems: self._declaredItems.append(item) item._parent = self self._types = {} self._subtypes = {} # self._objects = {} self._constants = {} self._signals = {} self._sharedVariables = {} self._files = {} # self._subprograms = {} self._functions = {} self._procedures = {}
@readonly def DeclaredItems(self) -> List: return self._declaredItems @readonly def Types(self) -> Dict[str, FullType]: return self._types @readonly def Subtypes(self) -> Dict[str, Subtype]: return self._subtypes # @readonly # def Objects(self) -> Dict[str, Union[Constant, SharedVariable, Signal, File]]: # return self._objects @readonly def Constants(self) -> Dict[str, Constant]: return self._constants @readonly def Signals(self) -> Dict[str, Signal]: return self._signals @readonly def SharedVariables(self) -> Dict[str, SharedVariable]: return self._sharedVariables @readonly def Files(self) -> Dict[str, File]: return self._files # @readonly # def Subprograms(self) -> Dict[str, Subprogram]: # return self._subprograms @readonly def Functions(self) -> Dict[str, Dict[str, Function]]: return self._functions @readonly def Procedures(self) -> Dict[str, Dict[str, Procedure]]: return self._procedures
[docs] def IndexDeclaredItems(self) -> None: """ Index declared items listed in the concurrent declaration region. .. rubric:: Algorithm 1. Iterate all declared items: * Every declared item is added to :attr:`_namespace`. * If the declared item is a :class:`~pyVHDLModel.Type.FullType`, then add an entry to :attr:`_types`. * If the declared item is a :class:`~pyVHDLModel.Type.SubType`, then add an entry to :attr:`_subtypes`. * If the declared item is a :class:`~pyVHDLModel.Subprogram.Function`, then add an entry to :attr:`_functions`. * If the declared item is a :class:`~pyVHDLModel.Subprogram.Procedure`, then add an entry to :attr:`_procedures`. * If the declared item is a :class:`~pyVHDLModel.Object.Constant`, then add an entry to :attr:`_constants`. * If the declared item is a :class:`~pyVHDLModel.Object.Signal`, then add an entry to :attr:`_signals`. * If the declared item is a :class:`~pyVHDLModel.Object.Variable`, TODO. * If the declared item is a :class:`~pyVHDLModel.Object.SharedVariable`, then add an entry to :attr:`_sharedVariables`. * If the declared item is a :class:`~pyVHDLModel.Object.File`, then add an entry to :attr:`_files`. * If the declared item is neither of these types, call :meth:`_IndexOtherDeclaredItem`. |br| Derived classes may override this virtual function. .. seealso:: :meth:`pyVHDLModel.Design.IndexPackages` Iterate all packages in the design and index declared items. :meth:`pyVHDLModel.Library.IndexPackages` Iterate all packages in the library and index declared items. :meth:`pyVHDLModel.Library._IndexOtherDeclaredItem` Iterate all packages in the library and index declared items. """ for item in self._declaredItems: if isinstance(item, FullType): self._types[item._normalizedIdentifier] = item self._namespace._elements[item._normalizedIdentifier] = item elif isinstance(item, Subtype): self._subtypes[item._normalizedIdentifier] = item self._namespace._elements[item._normalizedIdentifier] = item elif isinstance(item, Function): self._functions[item._normalizedIdentifier] = item self._namespace._elements[item._normalizedIdentifier] = item elif isinstance(item, Procedure): self._procedures[item._normalizedIdentifier] = item self._namespace._elements[item._normalizedIdentifier] = item elif isinstance(item, Constant): for normalizedIdentifier in item._normalizedIdentifiers: self._constants[normalizedIdentifier] = item self._namespace._elements[normalizedIdentifier] = item # self._objects[normalizedIdentifier] = item elif isinstance(item, Signal): for normalizedIdentifier in item._normalizedIdentifiers: self._signals[normalizedIdentifier] = item self._namespace._elements[normalizedIdentifier] = item elif isinstance(item, Variable): print(f"IndexDeclaredItems - {item._identifiers}") elif isinstance(item, SharedVariable): for normalizedIdentifier in item._normalizedIdentifiers: self._sharedVariables[normalizedIdentifier] = item self._namespace._elements[normalizedIdentifier] = item elif isinstance(item, File): for normalizedIdentifier in item._normalizedIdentifiers: self._files[normalizedIdentifier] = item self._namespace._elements[normalizedIdentifier] = item else: self._IndexOtherDeclaredItem(item)
def _IndexOtherDeclaredItem(self, item) -> None: print(f"_IndexOtherDeclaredItem - {item}\n ({' -> '.join(t.__name__ for t in type(item).mro())})")