Source code for ToolChain.Aldec

# EMACS settings: -*-	tab-width: 2; indent-tabs-mode: t; python-indent-offset: 2 -*-
# vim: tabstop=2:shiftwidth=2:noexpandtab
# kate: tab-width 2; replace-tabs off; indent-width 2;
#
# ==============================================================================
# Authors:          Patrick Lehmann
#                   Martin Zabel
#
# Python Class:     TODO
#
# License:
# ==============================================================================
# Copyright 2007-2016 Technische Universitaet Dresden - Germany
#                     Chair of VLSI-Design, Diagnostics and Architecture
#
# 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.
# ==============================================================================
#
# load dependencies
from lib.Functions            import Init
from ToolChain                import ToolChainException, VendorConfiguration


__api__ = [
	'AldecException',
	'Configuration'
]
__all__ = __api__


[docs]class AldecException(ToolChainException): """Base class for all Aldec tool's exceptions."""
[docs]class Configuration(VendorConfiguration): """Configuration routines for Aldec as a vendor. This configuration provides a common installation directory setup for all Aldec tools installed on a system. """ _vendor = "Aldec" #: The name of the tools vendor. _section = "INSTALL.Aldec" #: The name of the configuration section. Pattern: ``INSTALL.Vendor.ToolName``. _template = { "ALL": { "INSTALL.ActiveHDL": { "SectionName": "", "Version": "${${SectionName}:Version}", "Edition": "${${SectionName}:Edition}", "InstallationDirectory": "${${SectionName}:InstallationDirectory}", "BinaryDirectory": "${${SectionName}:BinaryDirectory}" } }, "Windows": { _section: { "InstallationDirectory": "C:/Aldec" } }, "Linux": { _section: { "InstallationDirectory": "/opt/Aldec" } } } #: The template for the configuration sections represented as nested dictionaries.
[docs] def ConfigureForAll(self): super().ConfigureForAll() self._host.LogNormal("{DARK_GREEN}Aldec is now configured.{NOCOLOR}".format(**Init.Foreground), indent=1)
[docs] def _GetDefaultInstallationDirectory(self): path = self._TestDefaultInstallPath({"Windows": "Aldec", "Linux": "Aldec"}) if path is None: return super()._GetDefaultInstallationDirectory() return path.as_posix()