# 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: Mentor specific classes
#
# 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 ToolChain import ToolChainException, VendorConfiguration
__api__ = [
'MentorException',
'Configuration'
]
__all__ = __api__
[docs]class MentorException(ToolChainException):
pass
[docs]class Configuration(VendorConfiguration):
"""Configuration routines for Mentor Graphics as a vendor.
This configuration provides a common installation directory setup for all
Mentor Graphics tools installed on a system.
"""
_vendor = "Mentor" #: The name of the tools vendor.
_section = "INSTALL.Mentor" #: The name of the configuration section. Pattern: ``INSTALL.Vendor.ToolName``.
_template = {
"ALL": {
"INSTALL.ModelSim": {
"SectionName": "",
"Version": "${${SectionName}:Version}",
"Edition": "${${SectionName}:Edition}",
"InstallationDirectory": "${${SectionName}:InstallationDirectory}",
"BinaryDirectory": "${${SectionName}:BinaryDirectory}",
"AdditionalVComOptions": "${${SectionName}:AdditionalVComOptions}",
"AdditionalVSimOptions": "${${SectionName}:AdditionalVSimOptions}"
}
},
"Windows": {
_section: {
"InstallationDirectory": "C:/Mentor"
}
},
"Linux": {
_section: {
"InstallationDirectory": "/opt/mentor"
}
}
} #: The template for the configuration sections represented as nested dictionaries.
[docs] def _GetDefaultInstallationDirectory(self):
path = self._TestDefaultInstallPath({"Windows": "Mentor", "Linux": "Mentor"})
if path is None: return super()._GetDefaultInstallationDirectory()
return path.as_posix()