Add a stub of the configuration storing procedure
[bertos.git] / wizard / BModulePage.py
index 9c26fcbecf2df11166c6f3ff69593cd0326abfe2..ad942334496c8565447d19e79cb83eba622bee2d 100644 (file)
@@ -32,6 +32,7 @@ class BModulePage(BWizardPage):
     def _setupButtonGroup(self):
         self._buttonGroup = QButtonGroup()
         self._buttonGroup.setExclusive(False)
+        self.connect(self._buttonGroup, SIGNAL("buttonClicked(int)"), self._moduleSelectionChanged)
     
     def _loadModuleData(self):
         modules = bertos_utils.loadModuleInfosDict(self._projectInfoRetrieve("SOURCES_PATH"))
@@ -52,47 +53,74 @@ class BModulePage(BWizardPage):
             checkBox = QCheckBox()
             self._buttonGroup.addButton(checkBox, index)
             self.pageContent.moduleTable.setCellWidget(index, 0, checkBox)
+            checkBox.setChecked(modules[module]["enabled"])
     
     def _fillPropertyTable(self):
-        module = unicode(self.pageContent.moduleTable.item(self.pageContent.moduleTable.currentRow(), 1).text())
+        self.savePage()
+        module = self._currentModule()
         configuration = self._projectInfoRetrieve("MODULES")[module]["configuration"]
         configurations = self._projectInfoRetrieve("CONFIGURATIONS")[configuration]
         self.pageContent.propertyTable.clear()
         self.pageContent.propertyTable.setRowCount(len(configurations))
-        for index, parameter in enumerate(configurations):
-            self.pageContent.propertyTable.setItem(index, 0, QTableWidgetItem(parameter))
-            if "type" in configurations[parameter]["informations"].keys() and configurations[parameter]["informations"]["type"] == "boolean":
-                ## boolean parameter
+        for index, property in enumerate(configurations):
+            item = QTableWidgetItem(property)
+            item.setData(Qt.UserRole, qvariant_converter.convertString(property))
+            self.pageContent.propertyTable.setItem(index, 0, item)
+            if "type" in configurations[property]["informations"].keys() and configurations[property]["informations"]["type"] == "boolean":
+                ## boolean property
                 checkBox = QCheckBox()
                 self.pageContent.propertyTable.setCellWidget(index, 1, checkBox)
-                if configurations[parameter]["value"] == "1":
+                if configurations[property]["value"] == "1":
                     checkBox.setChecked(True)
                 else:
                     checkBox.setChecked(False)
-            elif "type" in configurations[parameter]["informations"].keys() and configurations[parameter]["informations"]["type"] == "enum":
-                ## enum parameter
+            elif "type" in configurations[property]["informations"].keys() and configurations[property]["informations"]["type"] == "enum":
+                ## enum property
                 comboBox = QComboBox()
                 self.pageContent.propertyTable.setCellWidget(index, 1, comboBox)
-                enum = self._projectInfoRetrieve("LISTS")[configurations[parameter]["informations"]["value_list"]]
+                enum = self._projectInfoRetrieve("LISTS")[configurations[property]["informations"]["value_list"]]
                 for element in enum:
                     comboBox.addItem(element)
             else:
-                ## int, long or undefined type parameter
+                ## int, long or undefined type property
                 spinBox = QSpinBox()
                 self.pageContent.propertyTable.setCellWidget(index, 1, spinBox)
-                if "min" in configurations[parameter]["informations"].keys():
-                    minimum = int(configurations[parameter]["informations"]["min"])
+                if "min" in configurations[property]["informations"].keys():
+                    minimum = int(configurations[property]["informations"]["min"])
                 else:
                     minimum = -32768
                 spinBox.setMinimum(minimum)
-                if "max" in configurations[parameter]["informations"].keys():
-                    maximum = int(configurations[parameter]["infomations"]["max"])
+                if "max" in configurations[property]["informations"].keys():
+                    maximum = int(configurations[property]["informations"]["max"])
                 else:
                     maximum = 32767
                 spinBox.setMaximum(maximum)
-                if "long" in configurations[parameter]["informations"].keys() and configurations[parameter]["informations"]["long"] == "True":
+                if "long" in configurations[property]["informations"].keys() and configurations[property]["informations"]["long"] == "True":
                     spinBox.setSuffix("L")
-                spinBox.setValue(int(configurations[parameter]["value"].replace("L", "")))
+                spinBox.setValue(int(configurations[property]["value"].replace("L", "")))
+    
+    def _currentModule(self):
+        return unicode(self.pageContent.moduleTable.item(self.pageContent.moduleTable.currentRow(), 1).text())
+    
+    def _currentModuleConfigurations(self):
+        return self._projectInfoRetrieve("MODULES")[self._currentModule()]["configuration"]
+    
+    def _currentProperty(self):
+        return qvariant_converter.getString(self.pageContent.propertyTable.item(self.pageContent.propertyTable.currentRow(), 0).data(Qt.UserRole))
+    
+    def _currentPropertyItem(self):
+        return self.pageContent.propertyTable.item(self.pageContent.propertyTable.currentRow(), 0)
+    
+    def _resetPropertyDescription(self):
+        for index in range(self.pageContent.propertyTable.rowCount()):
+            propertyName = qvariant_converter.getString(self.pageContent.propertyTable.item(index, 0).data(Qt.UserRole))
+            self.pageContent.propertyTable.item(index, 0).setText(propertyName)
+    
+    def _showPropertyDescription(self):
+        self._resetPropertyDescription()
+        description = self._projectInfoRetrieve("CONFIGURATIONS")[self._currentModuleConfigurations()][self._currentProperty()]["description"]
+        name = self._currentProperty()
+        self._currentPropertyItem().setText(name + "\n" + description)
     
     def _setupUi(self):
         self.pageContent.moduleTable.horizontalHeader().setResizeMode(QHeaderView.ResizeToContents)
@@ -110,4 +138,72 @@ class BModulePage(BWizardPage):
         self.pageContent.propertyTable.setRowCount(0)
     
     def _connectSignals(self):
-        self.connect(self.pageContent.moduleTable, SIGNAL("itemSelectionChanged()"), self._fillPropertyTable)
\ No newline at end of file
+        self.connect(self.pageContent.moduleTable, SIGNAL("itemSelectionChanged()"), self._fillPropertyTable)
+        self.connect(self.pageContent.propertyTable, SIGNAL("itemSelectionChanged()"), self._showPropertyDescription)
+
+    def _moduleSelectionChanged(self, index):
+        module = unicode(self.pageContent.moduleTable.item(index, 1).text())
+        if self._buttonGroup.button(index).isChecked():
+            self._moduleSelected(module)
+        else:
+            self._moduleUnselected(module)
+    
+    def _moduleSelected(self, selectedModule):
+        modules = self._projectInfoRetrieve("MODULES")
+        modules[selectedModule]["enabled"] = True
+        self._projectInfoStore("MODULES", modules)
+        depends = self._projectInfoRetrieve("MODULES")[selectedModule]["depends"]
+        unsatisfied = self.selectDependencyCheck(selectedModule)
+        if len(unsatisfied) > 0:
+            message = self.tr("The module %1 needs the following modules:\n%2.\n\nDo you want to resolve automatically the problem?")
+            message = message.arg(selectedModule).arg(", ".join(unsatisfied))
+            choice = QMessageBox.warning(self, self.tr("Dependency error"), message, QMessageBox.Yes | QMessageBox.No, QMessageBox.Yes)
+            if choice == QMessageBox.Yes:
+                for module in unsatisfied:
+                    modules = self._projectInfoRetrieve("MODULES")
+                    modules[module]["enabled"] = True
+                for index in range(self.pageContent.moduleTable.rowCount()):
+                    if unicode(self.pageContent.moduleTable.item(index, 1).text()) in unsatisfied:
+                        self._buttonGroup.button(index).setChecked(True)
+    
+    def _moduleUnselected(self, unselectedModule):
+        modules = self._projectInfoRetrieve("MODULES")
+        modules[unselectedModule]["enabled"] = False
+        self._projectInfoStore("MODULES", modules)
+        unsatisfied = self.unselectDependencyCheck(unselectedModule)
+        if len(unsatisfied) > 0:
+            message = self.tr("The module %1 is needed by the following modules:\n%2.\n\nDo you want to resolve automatically the problem?")
+            message = message.arg(unselectedModule).arg(", ".join(unsatisfied))
+            choice = QMessageBox.warning(self, self.tr("Dependency error"), message, QMessageBox.Yes | QMessageBox.No, QMessageBox.Yes)
+            if choice == QMessageBox.Yes:
+                for module in unsatisfied:
+                    modules = self._projectInfoRetrieve("MODULES")
+                    modules[module]["enabled"] = False
+                for index in range(self.pageContent.moduleTable.rowCount()):
+                    if unicode(self.pageContent.moduleTable.item(index, 1).text()) in unsatisfied:
+                        self._buttonGroup.button(index).setChecked(False)
+    
+    
+    def selectDependencyCheck(self, module):
+        unsatisfied = set()
+        modules = self._projectInfoRetrieve("MODULES")
+        for dependency in modules[module]["depends"]:
+            if not modules[dependency]["enabled"]:
+                unsatisfied |= set([dependency])
+                if dependency not in unsatisfied:
+                    unsatisfied |= self.selectDependencyCheck(dependency)
+        return unsatisfied
+    
+    def unselectDependencyCheck(self, dependency):
+        unsatisfied = set()
+        modules = self._projectInfoRetrieve("MODULES")
+        for module, informations in modules.items():
+            if dependency in informations["depends"] and informations["enabled"]:
+                unsatisfied |= set([module])
+                if dependency not in unsatisfied:
+                    unsatisfied |= self.unselectDependencyCheck(module)
+        return unsatisfied
+    
+    def savePage(self):
+        for index in range(self.pageContent.propertyTable.rowCount()):
+            print qvariant_converter.getString(self.pageContent.propertyTable.item(index, 0).data(Qt.UserRole))
\ No newline at end of file