# Copyright 2008 Develer S.r.l. (http://www.develer.com/)
# All rights reserved.
#
-# $Id:$
+# $Id$
#
# Author: Lorenzo Berni <duplo@develer.com>
#
BWizardPage.__init__(self, UI_LOCATION + "/toolchain_select.ui")
self.setTitle(self.tr("Select toolchain"))
self._validation_process = None
+ self._valid_items = []
## Overloaded QWizardPage methods. ##
self._clearList()
self.setupUi()
self._populateToolchainList()
+ if len(self._valid_items) == 1:
+ self.pageContent.toolchainList.setCurrentItem(self._valid_items[0])
####
infos.update(qvariant_converter.getStringDict(self.pageContent.toolchainList.currentItem().data(Qt.UserRole)))
self.pageContent.infoLabel.setText("GCC " + infos["version"] + " (" + infos["build"] + ")\nTarget: " + infos["target"] + "\nPath: " + os.path.normpath(infos["path"]))
self.pageContent.infoLabel.setVisible(True)
+ if self.isDefaultToolchain(infos):
+ self.disableRemoveButton()
+ else:
+ self.enableRemoveButton()
self.emit(SIGNAL("completeChanged()"))
def addToolchain(self):
Fills the toolchain list with the toolchains stored in the QSettings.
"""
toolchains = self.toolchains()
+ if os.name == "nt":
+ import winreg_importer
+ stored_toolchains = winreg_importer.getBertosToolchains()
+ for toolchain in stored_toolchains:
+ toolchains[toolchain] = True
sel_toolchain = self.projectInfo("TOOLCHAIN")
for key, value in toolchains.items():
item = QListWidgetItem(key)
item.setData(Qt.UserRole, qvariant_converter.convertStringDict({"path": key}))
self.pageContent.toolchainList.addItem(item)
- if sel_toolchain is not None and sel_toolchain["path"] == key:
+ if sel_toolchain and sel_toolchain["path"] == key:
self.pageContent.toolchainList.setCurrentItem(item)
if value:
self.validateToolchain(self.pageContent.toolchainList.row(item))
toolchain_list = bertos_utils.findToolchains(dir_list)
stored_toolchains = self.toolchains()
for element in toolchain_list:
- if not element in stored_toolchains.keys():
+ if not element in stored_toolchains:
item = QListWidgetItem(element)
item.setData(Qt.UserRole, qvariant_converter.convertStringDict({"path": element}))
self.pageContent.toolchainList.addItem(item)
stored_toolchains[element] = False
self.setToolchains(stored_toolchains)
+ self.showMessage(self.tr("Toolchain search result."), self.tr("%1 toolchains founded").arg(len(stored_toolchains)))
def _validItem(self, index, infos):
"""
new_data.update(infos)
item.setData(Qt.UserRole, qvariant_converter.convertStringDict(new_data))
needed = self.projectInfo("CPU_INFOS")
- if "target" in infos.keys() and infos["target"].find(needed["TOOLCHAIN"]) != -1:
+ if "target" in infos and infos["target"].find(needed["TOOLCHAIN"]) != -1:
item.setIcon(QIcon(":/images/ok.png"))
+ self._valid_items.append(item)
else:
item.setIcon(QIcon(":/images/warning.png"))
- if "version" in infos.keys() and "target" in infos.keys():
- item.setText("GCC " + infos["version"] + " - " + infos["target"])
+ if "version" in infos and "target" in infos:
+ item.setText("GCC " + infos["version"] + " - " + infos["target"].strip())
def _invalidItem(self, index):
"""
if self._validation_process.waitForFinished(200):
description = str(self._validation_process.readAllStandardError())
info = bertos_utils.getToolchainInfo(description)
- if len(info.keys()) >= 4:
+ if len(info) >= 4:
valid = True
else:
self._validation_process.kill()
self._invalidItem(i)
toolchains = self.toolchains()
toolchains[filename] = True
- self.setToolchains(toolchains)
\ No newline at end of file
+ self.setToolchains(toolchains)
+
+ def isDefaultToolchain(self, toolchain):
+ """
+ Returns True if the given toolchain is one of the default toolchains.
+ """
+ if os.name == "nt":
+ import winreg_importer
+ stored_toolchains = winreg_importer.getBertosToolchains()
+ if toolchain["path"] in stored_toolchains:
+ return True
+ return False
+
+ def disableRemoveButton(self):
+ """
+ Disable the remove button.
+ """
+ self.pageContent.removeButton.setEnabled(False)
+
+ def enableRemoveButton(self):
+ """
+ Enable the remove button.
+ """
+ self.pageContent.removeButton.setEnabled(True)
+
\ No newline at end of file