X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=wizard%2FBToolchainPage.py;h=6c43ec10d403390a052062ab3f96ecd7e3ef905b;hb=2fab4324b03a9f916e71a214845f7da18c3969b3;hp=bce7471f938a06c265f5e93c843e164764c11b8f;hpb=73f1c621ec1c4054d533cdad5bb066b407b829e6;p=bertos.git diff --git a/wizard/BToolchainPage.py b/wizard/BToolchainPage.py index bce7471f..6c43ec10 100644 --- a/wizard/BToolchainPage.py +++ b/wizard/BToolchainPage.py @@ -9,6 +9,8 @@ # Author: Lorenzo Berni # +import os + from BWizardPage import * import BToolchainSearch import bertos_utils @@ -18,6 +20,7 @@ class BToolchainPage(BWizardPage): def __init__(self): BWizardPage.__init__(self, "toolchain_select.ui") self.setTitle(self.tr("Select toolchain")) + self._validationProcess = None self._populateToolchainList() self._connectSignals() @@ -45,14 +48,39 @@ class BToolchainPage(BWizardPage): self.emit(SIGNAL("completeChanged()")) def _search(self): - pass + dirList = [unicode(element.toString()) for element in self._settingsRetrieve("search_dir_list").toList()] + if(self._settingsRetrieve("path_search").toBool()): + dirList += [element for element in bertos_utils.getSystemPath()] + toolchainList = bertos_utils.findToolchains(dirList) + storedToolchainList = self._settingsRetrieve("toolchains").toList() + storedToolchainList = set([unicode(toolchain.toString()) for toolchain in storedToolchainList]) + toolchainList =set(toolchainList) - set(storedToolchainList) + for element in toolchainList: + item = QListWidgetItem(element) + item.setData(Qt.UserRole, QVariant(element)) + self.pageContent.toolchainList.addItem(item) + self._settingsStore("toolchains", list(toolchainList.union(storedToolchainList))) - def _connectSignals(self): self.connect(self.pageContent.toolchainList, SIGNAL("itemSelectionChanged()"), self._selectionChanged) self.connect(self.pageContent.addButton, SIGNAL("clicked()"), self.addToolchain) self.connect(self.pageContent.removeButton, SIGNAL("clicked()"), self.removeToolchain) self.connect(self.pageContent.searchButton, SIGNAL("clicked()"), self.searchToolchain) + self.connect(self.pageContent.checkButton, SIGNAL("clicked()"), self.validateToolchains) + + def _validItem(self, index, infos): + item = self.pageContent.toolchainList.item(index) + needed = self._projectInfoRetrieve("CPU_INFOS") + if infos["target"].find(unicode(needed[QString("TOOLCHAIN")])) != -1: + item.setIcon(QIcon(":/images/ok.png")) + else: + item.setIcon(QIcon(":/images/warning.png")) + item.setToolTip("Version: " + infos["version"] + "
Target: " + infos["target"] + + "
Thread model: " + infos["thread"]) + + def _invalidItem(self, index): + item = self.pageContent.toolchainList.item(index) + item.setIcon(QIcon(":/images/error.png")) def addToolchain(self): sel_toolchain = QFileDialog.getOpenFileName(self, self.tr("Choose the toolchain"), "") @@ -69,7 +97,7 @@ class BToolchainPage(BWizardPage): item = self.pageContent.toolchainList.takeItem(self.pageContent.toolchainList.currentRow()) item = item.data(Qt.UserRole).toString() toolchains = self._settingsRetrieve("toolchains").toList() - toolchains = [toolchain.toString() for toolchain in toolchains] + toolchains = [unicode(toolchain.toString()) for toolchain in toolchains] toolchains.remove(unicode(item)) self._settingsStore("toolchains", toolchains) @@ -78,6 +106,23 @@ class BToolchainPage(BWizardPage): self.connect(search, SIGNAL("accepted()"), self._search) search.exec_() + def validateToolchains(self): + for i in range(self.pageContent.toolchainList.count()): + filename = self.pageContent.toolchainList.item(i).text() + self._validationProcess = QProcess() + self._validationProcess.start(filename, ["-v"]) + self._validationProcess.waitForStarted(10) + if self._validationProcess.waitForFinished(20): + description = str(self._validationProcess.readAllStandardError()) + infos = bertos_utils.getToolchainInfo(description) + if len(infos.keys()) == 4: + self._validItem(i, infos) + else: + self._invalidItem(i) + else: + self._validationProcess.kill() + self._invalidItem(i) + def isComplete(self): if self.pageContent.toolchainList.currentRow() != -1: self._projectInfoStore("TOOLCHAIN", self.pageContent.toolchainList.item(self.pageContent.toolchainList.currentRow()).data(Qt.UserRole).toString())