Add a function that strip the wizard informations from the comment, and return the...
authorduplo <duplo@38d2e660-2303-0410-9eaa-f027e97ec537>
Wed, 21 Jan 2009 14:58:23 +0000 (14:58 +0000)
committerduplo <duplo@38d2e660-2303-0410-9eaa-f027e97ec537>
Wed, 21 Jan 2009 14:58:23 +0000 (14:58 +0000)
git-svn-id: https://src.develer.com/svnoss/bertos/trunk@2195 38d2e660-2303-0410-9eaa-f027e97ec537

wizard/BWizard.py
wizard/bertos_utils.py

index 851021cec4f7a9b4d05c3ff9bba18209a83c7b20..9a035b963b8991ee41ed5be9bcbc344164193a28 100644 (file)
@@ -22,6 +22,8 @@ class BWizard(QWizard):
     
     def __init__(self):
         QWizard.__init__(self)
+        # TODO: choose the right minimum size
+        self.setMinimumSize(1000, 500)
         self.setWindowTitle(self.tr("Create a BeRTOS project"))
         self._addPages()
         self._connectSignals()
index fbf83818f9e31b7668809881bcdd1d0da4a6fcd5..e8033d7d8e564815a949781a5cc3a915c1a2e66b 100644 (file)
@@ -114,6 +114,19 @@ def formatModuleNameValue(text):
     block = re.findall("\s*([^\s]+)\s*(.+?)\s*$", text, re.MULTILINE)
     return block[0]
 
+def getDescriptionInformations(text):
+    """
+    Take the doxygen comment and strip the wizard informations, returning the tuple
+    (comment, wizard_informations)
+    """
+    informations = {}
+    index = text.find("$WIZARD")
+    if index != -1:
+        exec(text[index + 1:])
+        informations.update(WIZARD)
+    return text[:index].strip(), informations
+        
+
 def loadModuleInfos(path):
     """
     Return the module configurations found in the given path as a dict with the name as key
@@ -124,9 +137,11 @@ def loadModuleInfos(path):
     for definition in findDefinitions(const.MODULE_CONFIGURATION, path):
         moduleName = definition[0].replace("cfg_", "").replace(".h", "")
         moduleInfos[moduleName] = {}
-        for description, define in getDefinitionBlocks(open(definition[1] + "/" + definition[0], "r").read()):
+        for comment, define in getDefinitionBlocks(open(definition[1] + "/" + definition[0], "r").read()):
             name, value = formatModuleNameValue(define)
+            description, informations = getDescriptionInformations(comment)
             moduleInfos[moduleName][name] = {}
             moduleInfos[moduleName][name]["value"] = value
             moduleInfos[moduleName][name]["description"] = description
+            moduleInfos[moduleName][name]["informations"] = informations
     return moduleInfos