X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=wizard%2FBModulePage.py;h=ccaf621c4f53e12ecddce7b162165875c1f719a4;hb=7f0679e3d2edfba574b4732c458480ed0799acd0;hp=8d382be26ab953624106fb9b331b6aafe87d0790;hpb=e81b42f69babe03edac5abe1ebc6a511d6d33faf;p=bertos.git diff --git a/wizard/BModulePage.py b/wizard/BModulePage.py index 8d382be2..ccaf621c 100644 --- a/wizard/BModulePage.py +++ b/wizard/BModulePage.py @@ -35,6 +35,7 @@ import os +from PyQt4.QtCore import * from PyQt4.QtGui import * from BWizardPage import * import bertos_utils @@ -85,11 +86,13 @@ class BModulePage(BWizardPage): """ Overload of the BWizardPage reloadData method. """ - QApplication.instance().setOverrideCursor(Qt.WaitCursor) - self.setupUi() - self.loadModuleData() - self.fillModuleTree() - QApplication.instance().restoreOverrideCursor() + try: + QApplication.instance().setOverrideCursor(Qt.WaitCursor) + self.setupUi() + self.loadModuleData() + self.fillModuleTree() + finally: + QApplication.instance().restoreOverrideCursor() #### @@ -221,7 +224,7 @@ class BModulePage(BWizardPage): and not self.projectInfo("LISTS") \ and not self.projectInfo("CONFIGURATIONS"): try: - bertos_utils.loadModuleData(self.project()) + self.project().loadModuleData() except ModuleDefineException, e: self.exceptionOccurred(self.tr("Error parsing line '%2' in file %1").arg(e.path).arg(e.line)) except EnumDefineException, e: @@ -401,65 +404,75 @@ class BModulePage(BWizardPage): """ Resolves the selection dependencies. """ - modules = self.projectInfo("MODULES") - modules[selectedModule]["enabled"] = True - self.setProjectInfo("MODULES", modules) - depends = self.projectInfo("MODULES")[selectedModule]["depends"] - unsatisfied = [] - if self.pageContent.automaticFix.isChecked(): - unsatisfied = self.selectDependencyCheck(selectedModule) - if len(unsatisfied) > 0: - for module in unsatisfied: - modules = self.projectInfo("MODULES") - modules[module]["enabled"] = True - for category in range(self.pageContent.moduleTree.topLevelItemCount()): - item = self.pageContent.moduleTree.topLevelItem(category) - for child in range(item.childCount()): - if unicode(item.child(child).text(0)) in unsatisfied: - self.setBold(item.child(child), True) - self.setBold(item, True) - item.child(child).setCheckState(0, Qt.Checked) - - def moduleUnselected(self, unselectedModule): - """ - Resolves the unselection dependencies. - """ - modules = self.projectInfo("MODULES") - modules[unselectedModule]["enabled"] = False - self.setProjectInfo("MODULES", modules) - unsatisfied = [] - unsatisfied_params = [] - if self.pageContent.automaticFix.isChecked(): - unsatisfied, unsatisfied_params = self.unselectDependencyCheck(unselectedModule) - if len(unsatisfied) > 0 or len(unsatisfied_params) > 0: - message = [] - heading = self.tr("The module %1 is needed by").arg(unselectedModule) - message.append(heading) - module_list = ", ".join(unsatisfied) - param_list = ", ".join(["%s (%s)" %(param_name, module) for module, param_name in unsatisfied_params]) - if module_list: - message.append(QString(module_list)) - if module_list and param_list: - message.append(self.tr("and by")) - if param_list: - message.append(QString(param_list)) - message_str = QStringList(message).join(" ") - message_str.append(self.tr("\n\nDo you want to automatically fix these conflicts?")) - choice = QMessageBox.warning(self, self.tr("Dependency error"), message_str, QMessageBox.Yes | QMessageBox.No, QMessageBox.Yes) - if choice == QMessageBox.Yes: + try: + qApp.setOverrideCursor(Qt.WaitCursor) + modules = self.projectInfo("MODULES") + modules[selectedModule]["enabled"] = True + self.setProjectInfo("MODULES", modules) + depends = self.projectInfo("MODULES")[selectedModule]["depends"] + unsatisfied = [] + if self.pageContent.automaticFix.isChecked(): + unsatisfied = self.selectDependencyCheck(selectedModule) + if len(unsatisfied) > 0: for module in unsatisfied: modules = self.projectInfo("MODULES") - modules[module]["enabled"] = False + modules[module]["enabled"] = True for category in range(self.pageContent.moduleTree.topLevelItemCount()): item = self.pageContent.moduleTree.topLevelItem(category) for child in range(item.childCount()): if unicode(item.child(child).text(0)) in unsatisfied: - item.child(child).setCheckState(0, Qt.Unchecked) - for module, param in unsatisfied_params: - configuration_file = self.projectInfo("MODULES")[module]["configuration"] - configurations = self.projectInfo("CONFIGURATIONS") - configurations[configuration_file][param]["value"] = "0" - self.setProjectInfo("CONFIGURATIONS", configurations) + self.setBold(item.child(child), True) + self.setBold(item, True) + item.child(child).setCheckState(0, Qt.Checked) + finally: + qApp.restoreOverrideCursor() + + def moduleUnselected(self, unselectedModule): + """ + Resolves the unselection dependencies. + """ + try: + qApp.setOverrideCursor(Qt.WaitCursor) + modules = self.projectInfo("MODULES") + modules[unselectedModule]["enabled"] = False + self.setProjectInfo("MODULES", modules) + unsatisfied = [] + unsatisfied_params = [] + if self.pageContent.automaticFix.isChecked(): + unsatisfied, unsatisfied_params = self.unselectDependencyCheck(unselectedModule) + if len(unsatisfied) > 0 or len(unsatisfied_params) > 0: + message = [] + heading = self.tr("The module %1 is needed by").arg(unselectedModule) + message.append(heading) + module_list = ", ".join(unsatisfied) + param_list = ", ".join(["%s (%s)" %(param_name, module) for module, param_name in unsatisfied_params]) + if module_list: + message.append(QString(module_list)) + if module_list and param_list: + message.append(self.tr("and by")) + if param_list: + message.append(QString(param_list)) + message_str = QStringList(message).join(" ") + message_str.append(self.tr("\n\nDo you want to automatically fix these conflicts?")) + qApp.restoreOverrideCursor() + choice = QMessageBox.warning(self, self.tr("Dependency error"), message_str, QMessageBox.Yes | QMessageBox.No, QMessageBox.Yes) + qApp.setOverrideCursor(Qt.WaitCursor) + if choice == QMessageBox.Yes: + for module in unsatisfied: + modules = self.projectInfo("MODULES") + modules[module]["enabled"] = False + for category in range(self.pageContent.moduleTree.topLevelItemCount()): + item = self.pageContent.moduleTree.topLevelItem(category) + for child in range(item.childCount()): + if unicode(item.child(child).text(0)) in unsatisfied: + item.child(child).setCheckState(0, Qt.Unchecked) + for module, param in unsatisfied_params: + configuration_file = self.projectInfo("MODULES")[module]["configuration"] + configurations = self.projectInfo("CONFIGURATIONS") + configurations[configuration_file][param]["value"] = "0" + self.setProjectInfo("CONFIGURATIONS", configurations) + finally: + qApp.restoreOverrideCursor() def selectDependencyCheck(self, module): """ @@ -472,8 +485,12 @@ class BModulePage(BWizardPage): conditional_deps = () for i, param_name in configurations["paramlist"]: information = configurations[param_name] - if information["informations"]["type"] == "boolean" and information["value"] != "0" and "conditional_deps" in information["informations"]: + if information["informations"]["type"] == "boolean" and \ + information["value"] != "0" and \ + "conditional_deps" in information["informations"]: + conditional_deps += information["informations"]["conditional_deps"] + for dependency in modules[module]["depends"] + conditional_deps: if dependency in modules and not modules[dependency]["enabled"]: unsatisfied |= set([dependency])